diff --git a/.eslintignore b/.eslintignore
new file mode 100644
index 00000000..2489a350
--- /dev/null
+++ b/.eslintignore
@@ -0,0 +1,9 @@
+.github/
+dist/
+docs/
+external/
+lang/
+scripts/
+styles/
+templates/
+src/**/*.svelte
\ No newline at end of file
diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml
index b414128d..5abef0b2 100644
--- a/.github/workflows/main.yml
+++ b/.github/workflows/main.yml
@@ -2,7 +2,7 @@ name: Release Creation
on:
release:
- types: [published]
+ types: [ published ]
jobs:
build:
@@ -39,10 +39,14 @@ jobs:
manifest: https://raw.githubusercontent.com/${{github.repository}}/next/module.json
download: https://github.com/${{github.repository}}/releases/download/${{github.event.release.tag_name}}/module.zip
+ # Install packages.
+ - run: npm install
+ # Build distribution.
+ - run: npm run build
# Create a zip file with all files required by the module to add to the release
- - run: zip -r ./module.zip module.json LICENSE styles/ scripts/ templates/ languages/
+ - run: zip -r ./module.zip module.json LICENSE styles/ templates/ languages/ module.js style.css
# Create a release for this specific version
- name: Update Release with Files
diff --git a/.gitignore b/.gitignore
index a2801871..7dd91b8b 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,2 +1,6 @@
.idea/*
-node_modules/*
\ No newline at end of file
+node_modules/*
+dist/*
+.vite-cache/*
+module.js
+style.css
\ No newline at end of file
diff --git a/changelog.md b/changelog.md
index b48e8119..bba122b8 100644
--- a/changelog.md
+++ b/changelog.md
@@ -1,34 +1,56 @@
# Item Piles Changelog
+## Version 2.0.0
+
+- Added fully-featured merchant functionality
+ - Per item type and per actor price modifiers (give that chatty bard a discount)
+ - Infinite currencies & infinite item quantities
+ - Custom item price support - you can configure items to cost other items to buy. Crafting merchants anyone?
+ - Roll table support to generate the listing on merchants
+- Reworked the way currencies work to support item-based currencies
+- Rewrote the entire module from scratch for long term viability
+- Added support for the TwoDSix system (Traveler)
+- Tweaked existing systems to work with the new currency system
+- Tweaked D&D 5e system implementation
+ - Dropping spells onto item piles will now convert them into scrolls
+ - Taking and dropping items from piles will now clear attunement and proficiency
+
## Version 1.4.8
+
- Updated German localization (Thank you, gsterling on GitHub)
- Added Starfinder system support (Thank you, dizko on GitHub)
- Updated Tormenta20 system configuration (Thank you, mclemente on GitHub)
- Fixed hidden item piles being able to be opened
## Version 1.4.7
+
- Fixed issue in latest PF2 update which changed the attribute path for quantities
## Version 1.4.6
-- Adjusted API to use native foundry `Item#fromDropData` instead of my own implementation (Thank you, TheGiddyLimit on GitHub!)
-- Fixed issue relating to some systems not generating a new ID for items, which caused false-positives when trying to find similar items on actors that were the source of said items
-- Fixed issue where systems would override core functions on items that modify names and other data, Item Piles will now always call the system's Item specific functions
- - Fixes issue with PF1 items sometimes showing up as identified when they were unidentified
-- Added support for the Warhammer Fantasy Roleplay 4th Ed system
-- Added support for the Splittermond system
+
+- Adjusted API to use native foundry `Item#fromDropData` instead of my own implementation (Thank you, TheGiddyLimit on
+ GitHub!)
+- Fixed issue relating to some systems not generating a new ID for items, which caused false-positives when trying to
+ find similar items on actors that were the source of said items
+- Fixed issue where systems would override core functions on items that modify names and other data, Item Piles will now
+ always call the system's Item specific functions
+ - Fixes issue with PF1 items sometimes showing up as identified when they were unidentified
+- Added support for the Warhammer Fantasy Roleplay 4th Ed system
+- Added support for the Splittermond system
## Version 1.4.5
-- Fixed Item Piles inventory UI in GM mode making item quantity inputs look disabled when an item had 0 quantity
+- Fixed Item Piles inventory UI in GM mode making item quantity inputs look disabled when an item had 0 quantity
## Version 1.4.4
- Added a right click context menu to the item pile inventory UI, with an option to show an item's image to everyone
- Improved Request Trade button in the player list when the Minimal UI module is active
-- Improved splitting API functions to improve performance when playing on Forge
+- Improved splitting API functions to improve performance when playing on Forge
- Improved documentation to better describe what each API method requires
- Tweaked `Split n ways` button to disable itself instead of becoming hidden
-- Tweaked system recognition to allow systems to set the required settings through the API, which suppresses the system incompatibility warning
+- Tweaked system recognition to allow systems to set the required settings through the API, which suppresses the system
+ incompatibility warning
- Fixed various bugs surrounding splitting item piles
- Fixed issue with the `Split n ways` button not working sometimes
@@ -120,7 +142,7 @@
- Added `Item Filters` setting - now you can more accurately filter items you do not want to show up in item piles, such
as natural weapons
- Updated all supported systems to support the above and added migrations to convert existing settings to the new system
- - reset your Item Piles module settings to ensure you have the latest system configurations
+ - reset your Item Piles module settings to ensure you have the latest system configurations
- Removed `Item Type Attribute` and `Item Type Filters` as the above feature covers these cases
- Added debounce to the token image refresh so that it doesn't try to change its image too often
- Further fixes to `ItemPiles.API.addItems`
diff --git a/languages/en.json b/languages/en.json
index a597289c..55408fce 100644
--- a/languages/en.json
+++ b/languages/en.json
@@ -1,319 +1,502 @@
{
- "ITEM-PILES": {
- "Items": "Items",
- "Currencies": "Currencies",
- "Currency": "Currency",
- "ContextMenu": {
- "ShowToPlayers": "Item Piles: Show pile to players",
- "RequestTrade": "Item Piles: Request Trade"
+ "ITEM-PILES": {
+ "Items": "Items",
+ "Currencies": "Currencies",
+ "Currency": "Currency",
+ "ContextMenu": {
+ "ShowToPlayers": "Item Piles: Show pile to players",
+ "RequestTrade": "Item Piles: Request Trade"
+ },
+ "Notifications": {
+ "UpdateItemPileSuccess": "Item Pile successfully updated.",
+ "UpdateMerchantSuccess": "Merchant successfully updated."
+ },
+ "Inspect": {
+ "Title": "Inspecting Pile Contents",
+ "AsActor": "You're inspecting this pile as {actorName}.",
+ "Owner": "As an owner of this Item Pile, you can edit the item pile's contents.",
+ "Empty": "This pile is empty.",
+ "Destroyed": "This pile no longer exists and lies barren.",
+ "TakeAll": "Take All Items",
+ "Take": "Take",
+ "Close": "Close Lid",
+ "Leave": "Leave",
+ "NoShareLeft": "No share left...",
+ "NoneLeft": "None left...",
+ "OpenSheet": "Open Sheet",
+ "AddCurrency": "Add currency",
+ "SplitAll": "Split {num_players} ways",
+ "SplitItems": "Split items {num_players} ways",
+ "SplitCurrencies": "Split currency {num_players} ways"
+ },
+ "Trade": {
+ "Title": "Item Piles: Trading",
+ "Accept": "Accept",
+ "Decline": "Decline",
+ "Mute": "Mute",
+ "AutoDecline": "You did not respond to the trade request quickly enough, so it was auto-declined.",
+ "Declined": "The other user declined the trade request.",
+ "Private": "Make this trade private",
+ "PrivateExplanation": "No chat card are posted, and no one can spectate",
+ "Over": "This trade is no longer active.",
+ "Between": "Trade between {actor_1} and {actor_2}",
+ "DragDrop": "Drag & drop items to begin trading",
+ "Prompt": {
+ "Title": "Item Piles: Send Trade Request",
+ "User": "Select which user you want to trade with:",
+ "PickActor": "Select which actor you will represent in the trade:",
+ "PickedActor": "The actor that you will represent in the trade:",
+ "PickToken": "Pick selected token",
+ "DropActor": "Drag and drop actor here",
+ "Label": "Send trade request"
+ },
+ "NoActiveUsers": {
+ "Title": "Item Piles: No Active Users",
+ "Content": "No players are active, so you have no one to trade with."
+ },
+ "Request": {
+ "Title": "Item Piles: Trade Request",
+ "Content": "{trading_actor_name} (user {trading_user_name}) wants to trade with you.",
+ "PrivateContent": "{trading_actor_name} (user {trading_user_name}) wants to privately trade with you.",
+ "AcceptQuery": "Do you accept?"
+ },
+ "OngoingRequest": {
+ "Content": "Wait for response from {user_name}...",
+ "Label": "Cancel trade request"
+ },
+ "CancelledRequest": {
+ "Content": "The trade request was cancelled by {user_name}."
+ },
+ "AddCurrency": {
+ "Title": "Add Currencies",
+ "Content": "Add currencies to the active trade with {trader_actor_name}",
+ "Label": "Update Currencies"
+ },
+ "GMAddCurrency": "Add Currency (GM mode)",
+ "Closed": {
+ "Title": "Trade Closed",
+ "You": "You closed the trading window, so the trade was cancelled.",
+ "Them": "User \"{user_name}\" closed the trading window, so the trade was cancelled.",
+ "Someone": "One of the users closed the trading window, so the trade was cancelled."
+ },
+ "Disconnected": "One of the users was disconnected, so the trade was cancelled.",
+ "UserCharacterWarning": "You picked the actor \"{actor_name}\" which is the assigned character of the player \"{player_name}\". Are you sure you want to do this?",
+ "UserActiveCharacterWarning": "You picked the actor \"{actor_name}\" which is the assigned character of the player \"{player_name}\", who is active . Are you sure you want to do this?",
+ "ActorOwnerWarning": "You do not own this actor, so you cannot trade with it."
+ },
+ "Merchant": {
+ "AllTypes": "All types",
+ "Buy": "Buy",
+ "NoItemsForSale": "Merchant has nothing for sale",
+ "NoItemsToSell": "You have nothing to sell to this merchant",
+ "OpenTimes": "Open Times",
+ "Closed": "Merchant is closed, reopens in {}",
+ "Hours": "Hours",
+ "Minutes": "Minutes",
+ "Sell": "Sell",
+ "Description": "Description",
+ "Settings": "Settings",
+ "Override": "Override",
+ "EditTypePrices": "Edit Per-Type Cost Modifiers",
+ "EditTypePricesExplanation": "Toggle the visibility of per-type sliders in the Buy Items tab",
+ "BuyNoItems": "Merchant has no items",
+ "SellNoItems": "You have no items to sell to this merchant",
+ "CurrentItems": "Current items",
+ "NoRollTables": "No roll tables exist, create one to get started",
+ "ClickRoll": "Click roll to start",
+ "RolledTimes": "Rolled {rolls} times",
+ "KeepRolled": "Keep rolled",
+ "AddAll": "Add All Items",
+ "ClearAllItems": "Clear All Actor Items"
+ },
+ "Errors": {
+ "DisallowedItemDrop": "You cannot drop \"{type}\" items",
+ "DisallowedItemTrade": "You cannot trade \"{type}\" items",
+ "DisallowedItemSell": "This merchant does not accept \"{type}\" items",
+ "NoSourceDrop": "You cannot drop items from the item bar unless you are a GM.",
+ "PileTooFar": "You're too far away to interact with this pile.",
+ "PileLocked": "This item pile is locked and cannot be opened - you can't drop items in it.",
+ "DropNoToken": "You don't have a token on this scene, so you can't drop any items here."
+ },
+ "Dialogs": {
+ "TypeWarning": {
+ "Title": "Item Type Warning",
+ "DropContent": "You're dropping an item that is of a type (\"{type}\") that is normally not allowed to be dropped. Are you sure you want to do this?",
+ "TradeContent": "You're attempting to trade an item that is of a type (\"{type}\") that is normally not allowed to be traded. Are you sure you want to do this?",
+ "SellContent": "You're attempting to sell item of type (\"{type}\") that the merchant normally doesn't accept. Are you sure you want to do this?"
+ },
+ "ResetSettings": {
+ "Title": "Reset Item Piles Module Settings",
+ "Content": "Are you sure you want to reset all of the Item Piles module settings to the current system's defaults? THIS CANNOT BE UNDONE! ",
+ "Confirm": "Reset Module Settings"
+ },
+ "LinkedActorWarning": {
+ "Title": "Item Piles & Linked Actor",
+ "Content": "Are you sure you want to turn this linked actor into an item pile? This actor's token is linked and all tokens of this actor will share its inventory and currencies."
+ },
+ "NoSystemFound": {
+ "Title": "System Not Recognized",
+ "Content": "This system is not currently fully supported. This means that the module does not know how to best handle this system's items, but can still operate in a limited fashion. You can configure the module's settings yourself, but it requires a bit of technical know-how. If you have any questions, ping Wasp#2005 on the Foundry discord."
+ },
+ "SystemFound": {
+ "Title": "System Recognized",
+ "Content": "This system was previously not supported, but in an recent update it was added as a supported system! Do you want to load this system's default Item Pile settings?",
+ "Confirm": "Apply System Defaults"
+ },
+ "NewSystemVersion": {
+ "Title": "New System Version",
+ "Content": "The default settings for the system you're using was updated, would you like to override your module settings with the updated ones?",
+ "Confirm": "Update settings"
+ },
+ "ResetSharingData": {
+ "Title": "Reset Sharing Data",
+ "Content": "This will reset all of the history of players having taken their share from this pile. Are you sure you want to do this?",
+ "Confirm": "Reset Sharing Data"
+ },
+ "ClearAllItems": {
+ "Title": "Clear All Actor Items",
+ "Content": "This will clear all of the actor's items, are you sure you want to do this?"
+ }
+ },
+ "Applications": {
+ "DropItem": {
+ "Title": "Dropping Item",
+ "Dropping": "You're dropping",
+ "ExistingPiles": "You're adding this item to the item pile \"{item_pile_name}\".",
+ "QuantityToDrop": "You have {quantity} of this item, how many do you want to drop?",
+ "AddToPile": "Add to pile",
+ "NewPile": "Create new pile"
+ },
+ "DropCurrencies": {
+ "Title": "Dropping Currencies",
+ "Player": "You can drop the following currencies into this item pile:",
+ "GM": "As a GM, you can add currencies to this item pile:",
+ "NoCurrency": "{actor_name} has no valid currencies...",
+ "AddToPile": "Add to pile"
+ },
+ "TradeMerchantItem": {
+ "Title": "Trading Item: {item_name}",
+ "BuyItem": "Buy Item",
+ "SellItem": "Sell Item",
+ "YouPay": "You pay",
+ "YouReceive": "You receive",
+ "TheyReceive": "They receive",
+ "Quantity": "Quantity",
+ "Change": "Change",
+ "YouCantAfford": "You cannot afford this price",
+ "TheyCantAfford": "They cannot afford this price",
+ "MaxQuantity": "Max {quantity}"
+ },
+ "Settings": {
+ "Title": "Item Piles Module Configuration",
+ "Local": "Local Settings",
+ "Module": "Module Settings",
+ "System": "System Specific Settings",
+ "Donate": "If you like this module, consider donating to keep it running!",
+ "MoreToCome": "And with more configuration options to come...",
+ "Request": "Request new features here.",
+ "Submit": "Submit Settings"
+ },
+ "CurrenciesEditor": {
+ "Title": "Item Piles Currencies Editor",
+ "TitleActor": "Item Piles Currencies Editor: {actor_name}",
+ "Explanation": "Here you can define which currencies on characters that can be picked up from item piles, such as currencies.",
+ "ExplanationSmallAttributes": "In D&D5e, currencies exist on actors on the attribute path \"actor.data.data.currency.gp\", so you'd add your own with the name \"Gold Coins\" and attribute path \"data.currency.gp\". Add one by clicking the plus in the header.",
+ "ExplanationSmallItems": "In other systems, they may be actual items on the actor - in this case, you can drag and drop items onto this list to add it to the currencies.",
+ "DragDrop": "Drag and drop an item to add it to the list",
+ "Name": "Currency name",
+ "Exchange": "Exchange",
+ "Data": "Data",
+ "Icon": "Icon",
+ "AddNew": "Add new currency",
+ "Submit": "Submit currencies"
+ },
+ "ItemEditor": {
+ "Title": "Item Piles Item Editor: {item_name}",
+ "Update": "Update Item",
+ "General": "General Settings",
+ "Price": "Price Settings",
+ "NotForSale": "Item Is Not For Sale",
+ "NotForSaleExplanation": "When enabled, this item is not for sale and cannot be bought. It still shows up in the merchant's item list unless the item is also hidden.",
+ "Hidden": "Item Is Hidden",
+ "HiddenExplanation": "When enabled, this item does not show up in the merchant's item lists.",
+ "DisplayQuantity": "Item Quantity Visibility",
+ "DisplayQuantityExplanation": "This configures how the quantity this item in the store is shown, if at all.",
+ "DisplayQuantityDefault": "Default to merchant setting",
+ "DisplayQuantityYes": "Yes, always show quantity",
+ "DisplayQuantityNo": "No, always hide quantity",
+ "InfiniteQuantity": "Infinite Quantity",
+ "InfiniteQuantityExplanation": "When enabled, this item cannot run out of quantity when sold by a merchant.",
+ "PriceExplanation": "In this tab, you can configure the price of this item, including whether this item will cost other items to purchase.",
+ "BasePrice": "Base Price",
+ "BasePriceExplanation": "This configures the normal price of this item.",
+ "Free": "Item Is Free",
+ "FreeExplanation": "When enabled, this item does not cost any money to purchase from the merchant.",
+ "DisableNormalCost": "Disable Normal Cost",
+ "DisableNormalCostExplanation": "When this is enabled, the item cannot be purchased with the primary currency and must be purchased with one of the purchase options below.",
+ "PurchaseOptions": "Purchase Options",
+ "PurchaseOptionsExplanation": "Here you can configure the alternate ways to purchase this item. Each group represents a different way that a character can buy this item from other",
+ "CantBeSoldToMerchants": "Can't Be Sold To Merchants",
+ "CantBeSoldToMerchantsExplanation": "When enabled, this item cannot be sold back to merchants, only purchased.",
+ "AddPurchaseOption": "Add Purchase Option",
+ "DropMeClickMe": "Click to add an attribute or drag & drop an item to add",
+ "PricePreset": "Or select an exiting price preset:",
+ "SelectPreset": "Select price preset"
+ },
+ "FilterEditor": {
+ "Title": "Item Piles Filters Editor",
+ "TitleActor": "Item Piles Filters Editor: {actor_name}",
+ "Explanation": "Here you can define multiple types of filters that will exclude certain types of items. Based on the attribute path given, the item pile could find the \"type\" of an item and based on the filters, it hides those items in the item pile inventory UI.",
+ "Filters": "Filters",
+ "Path": "Attribute path",
+ "AddNew": "Add new filter",
+ "Submit": "Submit filters"
+ },
+ "SimilaritiesEditor": {
+ "Title": "Item Piles Similarities Editor",
+ "Explanation_P1": "Here you can define multiple types of identifiers that helps Item Piles differentiate between similar items. In almost every system, items can be differentiated with their \"name\" and \"type\".",
+ "Explanation_P2": "But in some cases, such as in Pathfinder 2nd Edition, temporary items may share those with permanent items. So by adding \"data.temporary.value\", your temporary items are considered \"unique\" and separate from permanent ones.",
+ "Path": "Attribute path",
+ "AddNew": "Add new attribute path",
+ "Submit": "Submit item similarities"
+ },
+ "ItemTypePriceModifiersEditor": {
+ "Title": "Item Type Price Modifiers Editor",
+ "TitleActor": "Item Type Price Modifiers Editor: {actor_name}",
+ "Explanation": "Here you can define the price and sell price modifiers for this merchant relating to specific item types. The \"Override\" setting means that it overrides the merchant's normal price modifiers.",
+ "ItemType": "Item Type",
+ "Override": "Override",
+ "Submit": "Submit price modifiers"
+ },
+ "PriceModifiersEditor": {
+ "Title": "Item Piles Price Modifiers Editor",
+ "TitleActor": "Item Piles Price Modifiers Editor: {actor_name}",
+ "Explanation": "Here you can define the price and sell price modifiers for this merchant relating to specific actors. The \"Override\" setting means that it overrides the merchant's normal price modifiers, including item-type specific price modifiers.",
+ "DragDrop": "Drag and drop an actor to add it to the list",
+ "Actor": "Actor",
+ "Override": "Override",
+ "Submit": "Submit price modifiers"
+ },
+ "ItemPileConfig": {
+ "Title": "Item Pile Configuration: {actor_name}",
+ "Configure": "Item Pile",
+ "Update": "Update Item Pile",
+ "Main": {
+ "Title": "Main Settings",
+ "EnabledPile": "Enabled",
+ "EnabledPileExplanation": "Whether this should act as an item pile.",
+ "InspectItems": "Enable Item Inspect",
+ "InspectItemsExplanation": "Clicking item names will open the item's sheet.",
+ "Distance": "Interaction Distance",
+ "GridUnits": "Grid Units (leave empty for infinite)",
+ "Macro": "On Interact Macro",
+ "MacroExplanation": "Name of macro to execute when this pile is interacted with.",
+ "MacroPlaceholder": "Insert macro name",
+ "EditDescription": "Edit Description",
+ "EditDescriptionExplanation": "This description is shown in relevant interfaces when the item pile is viewed",
+ "DeleteWhenEmpty": "Delete when empty",
+ "DeleteWhenEmptyExplanation": "Causes this item pile to auto-delete itself once it's empty.",
+ "DeleteWhenEmptyDefault": "Default module setting",
+ "DeleteWhenEmptyYes": "Yes, delete when empty",
+ "DeleteWhenEmptyNo": "No, don't delete when empty",
+ "OverrideCurrencies": "Override Currencies",
+ "OverrideCurrenciesExplanation": "Configure if this pile should be able to transfer other currencies than the default.",
+ "ConfigureOverrideCurrencies": "Configure Override Currencies",
+ "OverrideItemFilters": "Override Item Filters",
+ "OverrideItemFiltersExplanation": "Configure if this pile should be able to transfer other types items than the default.",
+ "ConfigureOverrideItemFilters": "Configure Override Item Filters"
},
- "Inspect": {
- "Title": "Inspecting Pile Contents",
- "AsActor": "You're inspecting this pile as {actorName} ",
- "Owner": "As an owner of this Item Pile, you can edit the item pile's contents.",
- "Empty": "This pile is empty.",
- "Destroyed": "This pile no longer exists and lies barren.",
- "TakeAll": "Take All Items",
- "Take": "Take",
- "Close": "Close Lid",
- "Leave": "Leave",
- "NoShareLeft": "No share left...",
- "NoneLeft": "None left...",
- "OpenSheet": "Open Sheet",
- "AddCurrency": "Add currency",
- "SplitAll": "Split {num_players} ways",
- "SplitItems": "Split items {num_players} ways",
- "SplitCurrencies": "Split currency {num_players} ways"
+ "Other": {
+ "Title": "Other Settings"
},
- "Trade": {
- "Title": "Item Piles: Trading",
- "Accept": "Accept",
- "Decline": "Decline",
- "Mute": "Mute",
- "AutoDecline": "You did not respond to the trade request quickly enough, so it was auto-declined.",
- "Declined": "The other user declined the trade request.",
- "Private": "Make this trade private",
- "PrivateExplanation": "No chat card are posted, and no one can spectate",
- "Over": "This trade is no longer active.",
- "Between": "Trade between {actor_1} and {actor_2}",
- "DragDrop": "Drag & drop items to begin trading",
- "Request": {
- "Title": "Item Piles: Send Trade Request",
- "User": "Select which user you want to trade with:",
- "PickActor": "Select which actor you will represent in the trade:",
- "PickedActor": "The actor that you will represent in the trade:",
- "PickToken": "Pick selected token",
- "DropActor": "Drag and drop actor here",
- "Label": "Send trade request"
- },
- "NoActiveUsers": {
- "Title": "Item Piles: No Active Users",
- "Content": "No players are active, so you have no one to trade with."
- },
- "Prompt": {
- "Title": "Item Piles: Trade Request",
- "Content": "{trading_actor_name} (user {trading_user_name}) wants to trade with you.",
- "PrivateContent": "{trading_actor_name} (user {trading_user_name}) wants to privately trade with you.",
- "AcceptQuery": "Do you accept?"
- },
- "OngoingRequest": {
- "Content": "Wait for response from {user_name}...",
- "Label": "Cancel trade request"
- },
- "CancelledRequest": {
- "Content": "The trade request was cancelled by {user_name}."
- },
- "AddCurrency": {
- "Title": "Add Currencies",
- "Content": "Add currencies to the active trade with {trader_actor_name}",
- "Label": "Update Currencies"
- },
- "GMAddCurrency": "Add Currency (GM mode)",
- "Closed": {
- "Title": "Trade Closed",
- "You": "You closed the trading window, so the trade was cancelled.",
- "Them": "User \"{user_name}\" closed the trading window, so the trade was cancelled.",
- "Someone": "One of the users closed the trading window, so the trade was cancelled."
- },
- "Disconnected": "One of the users was disconnected, so the trade was cancelled.",
- "UserCharacterWarning": "You picked the actor \"{actor_name}\" which is the assigned character of the player \"{player_name}\". Are you sure you want to do this?",
- "UserActiveCharacterWarning": "You picked the actor \"{actor_name}\" which is the assigned character of the player \"{player_name}\", who is active . Are you sure you want to do this?",
- "ActorOwnerWarning": "You do not own this actor, so you cannot trade with it."
+ "SingleItem": {
+ "Title": "Single Item Settings",
+ "DisplayOneContainerWarning": "Warning! You have both \"Display Single Item Image\" and \"Is Container\" enabled. In this case, the container images takes priority.",
+ "DisplayOne": "Display Single Item Image",
+ "DisplayOneExplanation": "If the pile is made up of a single item, this sets the pile token's image to be the image of the item.",
+ "OverrideScale": "Override single item token scale",
+ "Scale": "Single item token scale",
+ "ItemName": "Use Item Name",
+ "ItemNameExplanation": "Causes the item pile to be named after the single item it contains."
},
- "Errors": {
- "DisallowedItemDrop": "You cannot drop \"{type}\" items",
- "DisallowedItemTrade": "You cannot trade \"{type}\" items",
- "NoSourceDrop": "You cannot drop items from the item bar unless you are a GM.",
- "PileTooFar": "You're too far away to interact with this pile.",
- "PileLocked": "This item pile is locked and cannot be opened - you can't drop items in it.",
- "DropNoToken": "You don't have a token on this scene, so you can't drop any items here."
+ "Container": {
+ "Title": "Container Settings",
+ "IsContainer": "Is Container",
+ "Locked": "Is Locked",
+ "Closed": "Is Closed",
+ "ClosedImagePath": "Closed Image Path",
+ "EmptyImagePath": "Empty Image Path",
+ "OpenedImagePath": "Opened Image Path",
+ "LockedImagePath": "Locked Image Path",
+ "CloseSoundPath": "Closing Sound Path",
+ "OpenSoundPath": "Opening Sound Path",
+ "LockedSoundPath": "Locked Sound Path"
},
- "Dialogs": {
- "DropTypeWarning": {
- "Title": "Item Type Warning",
- "Content": "You're dropping an item that is of a type (\"{type}\") that is normally not allowed to be dropped. Are you sure you want to do this?"
- },
- "TradeTypeWarning": {
- "Title": "Item Type Warning",
- "Content": "You're attempting to trade an item that is of a type (\"{type}\") that is normally not allowed to be traded. Are you sure you want to do this?"
- },
- "ResetSettings": {
- "Title": "Reset Item Piles Module Settings",
- "Content": "Are you sure you want to reset all of the Item Piles module settings to the current system's defaults? THIS CANNOT BE UNDONE! ",
- "Confirm": "Reset Module Settings"
- },
- "LinkedActorWarning": {
- "Title": "Item Piles & Linked Actor",
- "Content": "Are you sure you want to turn this linked actor into an item pile? This actor's token is linked and all tokens of this actor will share its inventory and currencies."
- },
- "NoSystemFound": {
- "Title": "System Not Recognized",
- "Content": "This system is not currently fully supported. This means that the module does not know how to best handle this system's items, but can still operate in a limited fashion. You can configure the module's settings yourself, but it requires a bit of technical know-how. If you have any questions, ping Wasp#2005 on the Foundry discord."
- },
- "SystemFound": {
- "Title": "System Recognized",
- "Content": "This system was previously not supported, but in an recent update it was added as a supported system! Do you want to load this system's default Item Pile settings?",
- "Confirm": "Apply System Defaults"
- },
- "ResetSharingData": {
- "Title": "Reset Sharing Data",
- "Content": "This will reset all of the history of players having taken their share from this pile. Are you sure you want to do this?",
- "Confirm": "Reset Sharing Data"
- },
- "Cancel": "Cancel"
+ "Sharing": {
+ "Title": "Sharing Settings",
+ "ShareItemsEnabled": "Sharing Enabled: Items",
+ "ShareItemsEnabledExplanation": "When this is enabled, players can only take their share of the quantities of items. Disabled means they can take as much as they want.",
+ "ShareCurrenciesEnabled": "Sharing Enabled: Currencies",
+ "ShareCurrenciesEnabledExplanation": "When this is enabled, players can only take their share of the quantities of currencies. Disabled means they can take as much as they want.",
+ "TakeAllEnabled": "Enable Take All Button",
+ "TakeAllEnabledExplanation": "Enables the \"Take All\" button when looting this item pile. Requires both of the above sharing settings to be disabled.",
+ "SplitAllEnabled": "Enable Split With Players Button",
+ "SplitAllEnabledExplanation": "Enables the \"Split [number] ways\" button when looting this item pile. Pressing this button makes all players (or only active players, see below) receive their share of the item pile.",
+ "InactivePlayers": "Split Only With Active Players",
+ "InactivePlayersExplanation": "Only players who are active when this item pile is looted will be given their share of the pile.",
+ "ResetSharingData": "Reset Sharing Data",
+ "ResetSharingDataExplanation": "If the Item Pile's content was manually changed while people were looting it, the sharing data may become out of sync with the players' actual shares. Pressing this button will reset everyone's share in this pile."
},
- "CurrenciesEditor": {
- "Title": "Currencies Editor",
- "Explanation": "Here you can define which currencies on characters that can be picked up from item piles, such as currencies. In D&D5e, currencies exist on actors on the attribute path \"actor.data.data.currency.gp\", so you'd add your own with the name \"Gold Coins\" and attribute path \"data.currency.gp\".",
- "Name": "Currency name",
- "Path": "Currency path",
- "Icon": "Currency icon",
- "AddNew": "Add new currency",
- "Submit": "Submit currencies"
- },
- "FilterEditor": {
- "Title": "Item Filters Editor",
- "Explanation": "Here you can define multiple types of filters that will exclude certain types of items. Based on the attribute path given, the item pile could find the \"type\" of an item and based on the filters, it hides those items in the item pile inventory UI.",
- "Filters": "Filters",
- "Path": "Attribute path",
- "AddNew": "Add new filter",
- "Submit": "Submit filters"
- },
- "SimilaritiesEditor": {
- "Title": "Item Similarities Editor",
- "Explanation_P1": "Here you can define multiple types of identifiers that helps Item Piles differentiate between similar items. In almost every system, items can be differentiated with their \"name\" and \"type\".",
- "Explanation_P2": "But in some cases, such as in Pathfinder 2nd Edition, temporary items may share those with permanent items. So by adding \"data.temporary.value\", you temporary items are considered \"unique\".",
- "Path": "Attribute path",
- "AddNew": "Add new attribute path",
- "Submit": "Submit item similarities"
- },
- "Defaults": {
- "Title": "Item Pile Configuration",
- "Configure": "Item Pile",
- "Update": "Update Item Pile",
- "Main": {
- "Title": "Main Settings",
- "EnabledPile": "Enabled",
- "EnabledPileExplanation": "Whether this should act as an item pile.",
- "InspectItems": "Enable Item Inspect",
- "InspectItemsExplanation": "Clicking item names will open the item's sheet.",
- "Distance": "Interaction Distance",
- "GridUnits": "Grid Units (leave empty for infinite)",
- "Macro": "On Interact Macro",
- "MacroExplanation": "Name of macro to execute when this pile is interacted with.",
- "MacroPlaceholder": "Insert macro name",
- "DeleteWhenEmpty": "Delete when empty",
- "DeleteWhenEmptyExplanation": "Causes this item pile to auto-delete itself once it's empty.",
- "DeleteWhenEmptyDefault": "Default module setting",
- "DeleteWhenEmptyYes": "Yes, delete when empty",
- "DeleteWhenEmptyNo": "No, don't delete when empty",
- "OverrideCurrencies": "Override Currencies",
- "OverrideCurrenciesExplanation": "Configure if this pile should be able to transfer other currencies than the default.",
- "ConfigureOverrideCurrencies": "Configure Override Currencies",
- "OverrideItemFilters": "Override Item Filters",
- "OverrideItemFiltersExplanation": "Configure if this pile should be able to transfer other types items than the default.",
- "ConfigureOverrideItemFilters": "Configure Override Item Filters"
- },
- "Other": {
- "Title": "Other Settings"
- },
- "SingleItem": {
- "Title": "Single Item Settings",
- "DisplayOneContainerWarning": "Warning! You have both \"Display Single Item Image\" and \"Is Container\" enabled. In this case, the container images takes priority.",
- "DisplayOne": "Display Single Item Image",
- "DisplayOneExplanation": "If the pile is made up of a single item, this sets the pile token's image to be the image of the item.",
- "OverrideScale": "Override single item token scale",
- "Scale": "Single item token scale",
- "ItemName": "Use Item Name",
- "ItemNameExplanation": "Causes the item pile to be named after the single item it contains."
- },
- "Container": {
- "Title": "Container Settings",
- "IsContainer": "Is Container",
- "Locked": "Is Locked",
- "Closed": "Is Closed",
- "ClosedImagePath": "Closed Image Path",
- "EmptyImagePath": "Empty Image Path",
- "OpenedImagePath": "Opened Image Path",
- "LockedImagePath": "Locked Image Path",
- "CloseSoundPath": "Closing Sound Path",
- "OpenSoundPath": "Opening Sound Path",
- "LockedSoundPath": "Locked Sound Path"
- },
- "Sharing": {
- "Title": "Sharing Settings",
- "ShareItemsEnabled": "Sharing Enabled: Items",
- "ShareItemsEnabledExplanation": "When this is enabled, players can only take their share of the quantities of items. Disabled means they can take as much as they want.",
- "ShareCurrenciesEnabled": "Sharing Enabled: Currencies",
- "ShareCurrenciesEnabledExplanation": "When this is enabled, players can only take their share of the quantities of currencies. Disabled means they can take as much as they want.",
- "TakeAllEnabled": "Enable Take All Button",
- "TakeAllEnabledExplanation": "Enables the \"Take All\" button when looting this item pile. Requires both of the above sharing settings to be disabled.",
- "SplitAllEnabled": "Enable Split With Players Button",
- "SplitAllEnabledExplanation": "Enables the \"Split [number] ways\" button when looting this item pile. Pressing this button makes all players (or only active players, see below) receive their share of the item pile.",
- "InactivePlayers": "Split Only With Active Players",
- "InactivePlayersExplanation": "Only players who are active when this item pile is looted will be given their share of the pile.",
- "ResetSharingData": "Reset Sharing Data",
- "ResetSharingDataExplanation": "If the Item Pile's content was manually changed while people were looting it, the sharing data may become out of sync with the players' actual shares. Pressing this button will reset everyone's share in this pile."
- }
- },
- "HUD": {
- "ToggleLocked": "Toggle Locked",
- "ToggleClosed": "Toggle Closed",
- "Configure": "Configure Pile"
- },
- "DropItem": {
- "Title": "Dropping Item",
- "Dropping": "You're dropping",
- "ExistingPiles": "You're adding this item to the item pile \"{item_pile_name}\".",
- "QuantityToDrop": "You have {quantity} of this item, how many do you want to drop?",
- "AddToPile": "Add to pile",
- "NewPile": "Create new pile",
- "Cancel": "Cancel"
- },
- "DropCurrencies": {
- "Title": "Dropping Currencies",
- "Player": "You can drop the following currencies into this item pile:",
- "GM": "As a GM, you can add currencies to this item pile:",
- "NoCurrency": "{actor_name} has no valid currencies...",
- "Cancel": "Cancel",
- "AddToPile": "Add to pile"
- },
- "Chat": {
- "Pickup": "{name} picked up the following items:",
- "Split": "An item pile's content was split among {num_players} players, and each one has received:",
- "TradeComplete": "{party_1} and {party_2} completed a trade.",
- "TradeStarted": "{party_1} and {party_2} started a trade.",
- "TradeStartedButton": "Click the button below to spectate:",
- "TradeSpectate": "Spectate Trade",
- "SpectateDisabled": "Trade Completed",
- "PrivateTrade": "Private Trade",
- "ExpandTrade": "View full trade details"
- },
- "Setting": {
- "Reset": {
- "Title": "Reset settings to default",
- "Label": "Reset Item Piles Settings To Default",
- "Hint": "This will reset all of the settings of Item Piles back to the active game system's default."
- },
- "ActorClass": {
- "Title": "Actor class type",
- "Label": "This setting defines the type of actor that will be used for the default item pile actor that is created on first item drop. In the case of D&D5e, this is \"character\", as it does not have a dedicated loot actor type."
- },
- "Quantity": {
- "Title": "Item quantity attribute",
- "Label": "Here you can configure what the attribute path is for each item's quantity. For example, in D&D5e system, each item's quantity is stored in the item's \"item.data.data.quantity\" attribute, so you'd put \"data.quantity\" in this setting."
- },
- "Currencies": {
- "Title": "Currencies",
- "Label": "Configure Currencies",
- "Hint": "This setting define the currencies that are eligible for pickup, which may not be actual items but numerical inputs on the character sheet."
- },
- "ItemFilters": {
- "Title": "Item filters",
- "Label": "Configure Item Filters",
- "Hint": "Here you can configure what items are ignored and not listed in the item pile dialogs."
- },
- "ItemSimilarities": {
- "Title": "Item Similarities",
- "Label": "Configure Item Similarities",
- "Hint": "Here you can configure what how items are detected to be the same in this system. Some systems may have data that distinguishes items differently than others, such as temporary items."
- },
- "EnableTrading": {
- "Title": "Enable Trading",
- "Hint": "This enables trading - with this disabled, no one can initiate any trade."
- },
- "ShowTradeButton": {
- "Title": "Show Trade Button",
- "Hint": "Enabling this will display a trade button just below the player list in the bottom right."
- },
- "OutputToChat": {
- "Title": "Output to chat",
- "Label": "Whenever any player picks up items from an item pile, this will send a message showing what was picked up.",
- "Off": "Off - turn off messages",
- "Public": "Public - everyone can see messages",
- "SelfGM": "Private - only GMs and user can see messages",
- "Blind": "Blind - only GMs can see messages"
- },
- "InvertSheetOpen": {
- "Title": "Invert Ctrl + Double Click Open",
- "Label": "Normally, you have to hold control when you want to open an item pile's actor sheet. Enabling this makes the item pile actor sheet open by default, and holding control opens the item pile inventory UI."
- },
- "HideActorHeaderText": {
- "Title": "Hide actor header text",
- "Label": "Hides the \"Item Piles\" text in the actor header - useful if you have too many modules, and the header is getting crowded."
- },
- "DeleteEmptyPiles": {
- "Title": "Auto-delete empty piles",
- "Label": "This causes item piles to delete themselves once they run out of items. This can be overridden on individual item piles."
- },
- "PreloadFiles": {
- "Title": "Preload Files",
- "Label": "Causes files (images and audio) of piles to be preloaded, resulting in a seamless experience."
- },
- "Debug": {
- "Title": "Enable debugging",
- "Label": "Prints debug messages to the console"
- }
+ "Merchant": {
+ "Title": "Merchant Settings",
+ "Enabled": "Is Merchant",
+ "EnabledExplanation": "Players cannot pick up items from merchants, but must instead purchase them",
+ "MerchantImage": "Merchant Image",
+ "MerchantImageExplanation": "This is the image that will be displayed in the merchant's interface",
+ "InfiniteQuantity": "Infinite Quantity",
+ "InfiniteQuantityExplanation": "When enabled, this merchant cannot run out of items.",
+ "InfiniteCurrency": "Infinite Currencies",
+ "InfiniteCurrencyExplanation": "When enabled, selling items to this merchant will not subtract from its currencies.",
+ "DisplayQuantity": "Item Quantity Visibility",
+ "DisplayQuantityExplanation": "This configures how the quantity of items in the store is shown, if at all.",
+ "DisplayQuantityYes": "Yes, show quantity (unless item says otherwise)",
+ "DisplayQuantityNo": "No, hide quantity (unless item says otherwise)",
+ "DisplayQuantityYesAlways": "Yes, always show quantity",
+ "DisplayQuantityNoAlways": "No, always hide quantity",
+ "PurchaseOnly": "Purchase Only",
+ "PurchaseOnlyExplanation": "When enabled, characters cannot sell items to this merchant.",
+ "HideNewItems": "Hide New Items",
+ "HideNewItemsExplanation": "When enabled, any items sold to this merchant will be hidden.",
+ "OnyAcceptBasePrice": "Only Accept Base Price",
+ "OnyAcceptBasePriceExplanation": "When enabled, all items sold to this merchant must use the base price, and not any custom prices.",
+ "OpenTimes": "Open Times",
+ "OpenTimesExplanation": "When enabled, the merchant is can only be interacted by players at certain times of the day.",
+ "PriceModifierTitle": "Buy and Sell Price Modifiers",
+ "PriceModifierExplanation": "This configures the modifiers for the cost of every item in the shop. You can also configure modifiers per item type, and even for specific characters (such as silver-tongued bards). You are not limited to 200%, type into the field to go even higher.",
+ "BuyPriceModifier": "Buy Price Modifier (%)",
+ "SellPriceModifier": "Sell Price Modifier (%)",
+ "ItemTypeModifier": "Item Type Price Modifiers",
+ "ItemTypeModifiersExplanation": "In this dialog you can configure price modifiers for individual item types.",
+ "ConfigureItemTypePriceModifiers": "Configure Item Type Price Modifiers.",
+ "ActorPriceModifiers": "Per-Actor Override Price Modifiers",
+ "ActorPriceModifiersExplanation": "Here you can configure if certain specific actors should have different price modifiers than the price modifiers above.",
+ "ConfigureActorPriceModifiers": "Configure Actor Price Modifiers."
}
+ },
+ "PricePresetEditor": {
+ "Title": "Price Presets Editor",
+ "Update": "Update Presets",
+ "Explanation": "Here you can create multiple preset prices that can then be easily used in items' custom prices."
+ }
+ },
+ "HUD": {
+ "ToggleLocked": "Toggle Locked",
+ "ToggleClosed": "Toggle Closed",
+ "Configure": "Configure Pile"
+ },
+ "Chat": {
+ "Pickup": "{name} picked up the following items:",
+ "Split": "An item pile's content was split among {num_players} players, and each one has received:",
+ "TradeComplete": "{party_1} and {party_2} completed a trade.",
+ "TradeStarted": "{party_1} and {party_2} started a trade.",
+ "TradeStartedButton": "Click the button below to spectate:",
+ "TradeSpectate": "Spectate Trade",
+ "SpectateDisabled": "Trade Concluded",
+ "PrivateTrade": "Private Trade",
+ "ExpandTrade": "View full trade details",
+ "MerchantTraded": "{name} bought the following things from {merchant}:"
+ },
+ "Settings": {
+ "Configure": {
+ "Title": "Module Configuration",
+ "Label": "Configure Module",
+ "Hint": "You can configure Item Piles in this dialog."
+ },
+ "Reset": {
+ "Title": "Reset settings to default",
+ "Label": "Reset Item Piles Settings To Default",
+ "Hint": "This will reset all of the settings of Item Piles back to the active game system's default."
+ },
+ "ActorClass": {
+ "Title": "Actor class type",
+ "Hint": "This setting defines the type of actor that will be used for the default item pile actor that is created on first item drop. In the case of D&D5e, this is \"character\", as it does not have a dedicated loot actor type."
+ },
+ "Quantity": {
+ "Title": "Item quantity attribute",
+ "Hint": "Here you can configure what the attribute path is for each item's quantity. For example, in D&D5e system, each item's quantity is stored in the item's \"item.data.data.quantity\" attribute, so you'd put \"data.quantity\" in this setting."
+ },
+ "Price": {
+ "Title": "Item price attribute",
+ "Hint": "Here you can configure what the attribute path is for each item's price. For example, in D&D5e system, each item's quantity is stored in the item's \"item.data.data.price\" attribute, so you'd put \"data.price\" in this setting."
+ },
+ "Currencies": {
+ "Title": "Currencies",
+ "Label": "Configure Currencies",
+ "Hint": "This setting define the currencies that are eligible for pickup, which may not be actual items but numerical inputs on the character sheet."
+ },
+ "ItemFilters": {
+ "Title": "Item filters",
+ "Label": "Configure Item Filters",
+ "Hint": "Here you can configure what items are ignored and not listed in the item pile dialogs."
+ },
+ "ItemSimilarities": {
+ "Title": "Item Similarities",
+ "Label": "Configure Item Similarities",
+ "Hint": "Here you can configure what how items are detected to be the same in this system. Some systems may have data that distinguishes items differently than others, such as temporary items."
+ },
+ "PricePresets": {
+ "Title": "Price Presets",
+ "Label": "Configure Price Presets",
+ "Hint": "Here you can configure custom preset prices that you can then easily import onto items."
+ },
+ "EnableDroppingItems": {
+ "Title": "Enable Dropping Items",
+ "Hint": "This enables users being able to drop items on the ground to create their own item piles - with this disabled, users cannot create new piles, nor add items to existing piles."
+ },
+ "EnableTrading": {
+ "Title": "Enable Trading",
+ "Hint": "This enables trading - with this disabled, no one can initiate any trade."
+ },
+ "ShowTradeButton": {
+ "Title": "Show Trade Button",
+ "Hint": "Enabling this will display a trade button just below the player list in the bottom right."
+ },
+ "InspectItemsTrade": {
+ "Title": "Enable Inspecting Items During Trades",
+ "Hint": "Enabling this makes it so that users can click items that are being traded and open the item's sheet to preview them."
+ },
+ "OutputToChat": {
+ "Title": "Output to chat",
+ "Hint": "Whenever any player picks up items from an item pile, this will send a message showing what was picked up.",
+ "Off": "Off - turn off messages",
+ "Public": "Public - everyone can see messages",
+ "SelfGM": "Private - only GMs and user can see messages",
+ "Blind": "Blind - only GMs can see messages"
+ },
+ "InvertSheetOpen": {
+ "Title": "Invert Ctrl + Double Click Open",
+ "Hint": "Normally, you have to hold control when you want to open an item pile's actor sheet. Enabling this makes the item pile actor sheet open by default, and holding control opens the item pile inventory UI."
+ },
+ "HideActorHeaderText": {
+ "Title": "Hide actor header text",
+ "Hint": "Hides the \"Item Piles\" text in the actor header - useful if you have too many modules, and the header is getting crowded."
+ },
+ "DeleteEmptyPiles": {
+ "Title": "Auto-delete empty piles",
+ "Hint": "This causes item piles to delete themselves once they run out of items. This can be overridden on individual item piles."
+ },
+ "PreloadFiles": {
+ "Title": "Preload Files",
+ "Hint": "Causes files (images and audio) of piles to be preloaded, resulting in a seamless experience."
+ },
+ "Debug": {
+ "Title": "Enable debugging",
+ "Hint": "Prints debug messages to the console"
+ },
+ "DebugHooks": {
+ "Title": "Enable debugging of hooks",
+ "Hint": "Prints the item pile hooks and their contents to the console"
+ }
}
+ }
}
\ No newline at end of file
diff --git a/languages/fr.json b/languages/fr.json
index b1976165..912d04c8 100644
--- a/languages/fr.json
+++ b/languages/fr.json
@@ -9,7 +9,7 @@
},
"Inspect": {
"Title": "Inspection de la pile",
- "AsActor": "Vous inspectez cette pile en tant que {actorName} ",
+ "AsActor": "Vous inspectez cette pile en tant que {actorName}.",
"Owner": "En tant que propriƩtaire de ce tas d'objets, vous pouvez en modifier le contenu.",
"Empty": "Cette pile est vide.",
"Destroyed": "Cette pile n'existe plus.",
diff --git a/module.js.map b/module.js.map
new file mode 100644
index 00000000..b5f56e2b
--- /dev/null
+++ b/module.js.map
@@ -0,0 +1 @@
+{"version":3,"file":"module.js","sources":["src/systems/dnd5e.js","src/systems/pf1.js","src/systems/pf2e.js","src/systems/ds4.js","src/systems/d35e.js","src/systems/sfrpg.js","src/systems/swade.js","src/systems/tormenta20.js","src/systems/wfrp4e.js","src/systems/splittermond.js","src/systems/twodsix.js","src/systems.js","src/constants/settings.js","src/constants/constants.js","src/helpers/helpers.js","src/helpers/utilities.js","src/helpers/pile-utilities.js","node_modules/svelte/internal/index.mjs","node_modules/svelte/store/index.mjs","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/util/index.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/store/index.js","node_modules/svelte/easing/index.mjs","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/math/index.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/animation/AnimationControl.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/animation/AnimationManager.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/constants.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/convertRelative.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/animation/AnimationAPI.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/animation/AnimationGroupControl.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/animation/AnimationGroupAPI.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/initial/Centered.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/initial/index.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/PositionChangeSet.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/PositionData.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/PositionStateAPI.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/StyleCache.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/transform/TransformData.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/validators/AdapterValidators.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/validators/BasicBounds.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/validators/TransformBounds.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/validators/index.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/transform/Transforms.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/update/UpdateElementData.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/animate/index.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/update/UpdateElementManager.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/position/Position.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/internal/ApplicationState.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/internal/GetSvelteData.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/internal/loadSvelteConfig.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/internal/SvelteReactive.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/SvelteApplication.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/component/core/TJSContainer.svelte","node_modules/svelte/transition/index.mjs","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/transition/index.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/component/core/TJSGlassPane.svelte","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/action/index.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/helper/index.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/component/core/application/TJSHeaderButton.svelte","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/component/core/application/TJSApplicationHeader.svelte","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/component/core/application/ResizableHandle.svelte","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/component/core/application/ApplicationShell.svelte","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/component/core/dialog/DialogContent.svelte","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/component/core/dialog/DialogShell.svelte","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/internal/DialogData.js","node_modules/@typhonjs-fvtt/runtime/_dist/svelte/application/TJSDialog.js","src/applications/components/FilePicker.svelte","src/helpers/sharing-utilities.js","src/applications/components/SliderInput.svelte","src/applications/editors/price-modifiers-editor/price-modifiers-editor.svelte","src/applications/editors/price-modifiers-editor/price-modifiers-editor.js","src/applications/components/DropZone.svelte","src/applications/editors/currencies-editor/CurrencyList.svelte","src/applications/editors/currencies-editor/currency-store.js","src/applications/editors/currencies-editor/currencies-editor-shell.svelte","src/applications/editors/currencies-editor/currencies-editor.js","src/applications/editors/item-filters-editor/item-filters-editor.svelte","src/applications/editors/item-filters-editor/item-filters-editor.js","src/applications/components/Tabs.svelte","src/constants/hooks.js","src/hotkeys.js","src/applications/dialogs/drop-item-dialog/drop-item-dialog-shell.svelte","src/applications/dialogs/drop-item-dialog/drop-item-dialog.js","src/applications/item-pile-inventory-app/ListEntry.svelte","src/applications/item-pile-inventory-app/ItemList.svelte","src/applications/dialogs/drop-currency-dialog/drop-currency-dialog-shell.svelte","src/applications/dialogs/drop-currency-dialog/drop-currency-dialog.js","src/applications/item-pile-inventory-app/CurrencyList.svelte","src/applications/item-pile-inventory-app/ActorPicker.svelte","src/stores/pile-item.js","src/stores/item-pile-store.js","src/applications/item-pile-inventory-app/item-pile-inventory-shell.svelte","src/applications/item-pile-inventory-app/item-pile-inventory-app.js","src/helpers/transaction.js","node_modules/@typhonjs-fvtt/svelte-standard/_dist/component/internal/StyleManager.js","node_modules/@typhonjs-fvtt/svelte-standard/_dist/component/internal/cssVariables.js","node_modules/@typhonjs-fvtt/svelte-standard/_dist/component/internal/FoundryStyles.js","node_modules/@typhonjs-fvtt/svelte-standard/_dist/component/standard/label/TJSToggleLabel.svelte","node_modules/@typhonjs-fvtt/svelte-standard/_dist/component/standard/menu/TJSMenu.svelte","node_modules/@typhonjs-fvtt/svelte-standard/_dist/component/standard/index.js","src/applications/components/PriceSelector.svelte","src/applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog-shell.svelte","src/applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog.js","src/stores/merchant-store.js","src/applications/merchant-app/MerchantLeftPane.svelte","src/applications/editors/item-editor/ItemPriceStore.js","node_modules/svelte/animate/index.mjs","node_modules/svelte-dnd-action/src/helpers/dispatcher.js","node_modules/svelte-dnd-action/src/constants.js","node_modules/svelte-dnd-action/src/helpers/intersection.js","node_modules/svelte-dnd-action/src/helpers/listUtil.js","node_modules/svelte-dnd-action/src/helpers/scroller.js","node_modules/svelte-dnd-action/src/helpers/util.js","node_modules/svelte-dnd-action/src/helpers/observer.js","node_modules/svelte-dnd-action/src/helpers/windowScroller.js","node_modules/svelte-dnd-action/src/helpers/svelteNodeClone.js","node_modules/svelte-dnd-action/src/helpers/styler.js","node_modules/svelte-dnd-action/src/pointerAction.js","node_modules/svelte-dnd-action/src/helpers/aria.js","node_modules/svelte-dnd-action/src/keyboardAction.js","node_modules/svelte-dnd-action/src/action.js","src/applications/editors/item-editor/PriceList.svelte","src/applications/editors/item-editor/item-editor-shell.svelte","src/applications/editors/item-editor/item-editor.js","src/applications/merchant-app/MerchantItemEntry.svelte","src/applications/merchant-app/MerchantBuyTab.svelte","src/applications/merchant-app/MerchantSellTab.svelte","src/applications/merchant-app/MerchantPopulateItemsTab.svelte","src/applications/merchant-app/MerchantRightPane.svelte","src/applications/merchant-app/MerchantTopBar.svelte","src/applications/merchant-app/merchant-app-shell.svelte","src/applications/merchant-app/merchant-app.js","src/API/private-api.js","src/applications/components/CustomDialog.svelte","src/applications/trade-dialogs/ActorDropSelect.svelte","src/applications/trade-dialogs/trade-dialog-prompt.svelte","node_modules/svelte/motion/index.mjs","src/applications/trade-dialogs/trade-dialog-request.svelte","src/applications/trade-dialogs/trade-dialogs.js","src/applications/trading-app/trade-store.js","src/applications/trading-app/TradeEntry.svelte","src/applications/trading-app/trading-app-shell.svelte","src/applications/trading-app/trading-app.js","src/API/trade-api.js","src/API/chat-api.js","src/socket.js","src/API/api.js","src/applications/editors/item-type-price-modifiers-editor/item-type-price-modifiers-editor.svelte","src/applications/editors/item-type-price-modifiers-editor/item-type-price-modifiers-editor.js","src/applications/item-pile-config/item-pile-config.svelte","src/applications/item-pile-config/item-pile-config.js","src/foundry-ui-overrides.js","src/libwrapper.js","src/applications/settings-app/Setting.svelte","src/applications/editors/item-similarities-editor/item-similarities-editor.svelte","src/applications/editors/item-similarities-editor/item-similarities-editor.js","src/applications/editors/index.js","src/applications/settings-app/SettingButton.svelte","src/applications/settings-app/settings-shell.svelte","src/applications/settings-app/settings-app.js","src/settings.js","src/module.js"],"sourcesContent":["export default {\n \n \"VERSION\": \"1.0.0\",\n \n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\n \"ACTOR_CLASS_TYPE\": \"character\",\n \n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity\",\n \n // The item price attribute is the path to the attribute on each item that determine how much it costs\n \"ITEM_PRICE_ATTRIBUTE\": \"data.price\",\n \n // Item filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\n \"ITEM_FILTERS\": [\n {\n \"path\": \"type\",\n \"filters\": \"spell,feat,class\"\n },\n {\n \"path\": \"data.weaponType\",\n \"filters\": \"natural\"\n }\n ],\n \n \"ITEM_TRANSFORMER\": async (itemData) => {\n [\"equipped\", \"proficient\", \"prepared\"].forEach(key => delete itemData.data[key]);\n itemData.data.attunement = Math.min(CONFIG.DND5E.attunementTypes.REQUIRED, itemData.data.attunement);\n if (itemData.type === \"spell\") {\n const scroll = await Item.implementation.createScrollFromSpell(itemData);\n itemData = scroll.data;\n }\n return itemData;\n },\n \n // Item similarities determines how item piles detect similarities and differences in the system\n \"ITEM_SIMILARITIES\": [\"name\", \"type\"],\n \n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\n // In the case of attributes, the path is relative to the \"actor.data\"\n // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data\n \"CURRENCIES\": [\n {\n type: \"attribute\",\n name: \"DND5E.CurrencyPP\",\n img: \"icons/commodities/currency/coin-inset-snail-silver.webp\",\n abbreviation: \"{#}PP\",\n data: {\n path: \"data.currency.pp\"\n },\n primary: false,\n exchangeRate: 10\n },\n {\n type: \"attribute\",\n name: \"DND5E.CurrencyGP\",\n img: \"icons/commodities/currency/coin-embossed-crown-gold.webp\",\n abbreviation: \"{#}GP\",\n data: {\n path: \"data.currency.gp\",\n },\n primary: true,\n exchangeRate: 1\n },\n {\n type: \"attribute\",\n name: \"DND5E.CurrencyEP\",\n img: \"icons/commodities/currency/coin-inset-copper-axe.webp\",\n abbreviation: \"{#}EP\",\n data: {\n path: \"data.currency.ep\",\n },\n primary: false,\n exchangeRate: 0.5\n },\n {\n type: \"attribute\",\n name: \"DND5E.CurrencySP\",\n img: \"icons/commodities/currency/coin-engraved-moon-silver.webp\",\n abbreviation: \"{#}SP\",\n data: {\n path: \"data.currency.sp\",\n },\n primary: false,\n exchangeRate: 0.1\n },\n {\n type: \"attribute\",\n name: \"DND5E.CurrencyCP\",\n img: \"icons/commodities/currency/coin-engraved-waves-copper.webp\",\n abbreviation: \"{#}CP\",\n data: {\n path: \"data.currency.cp\",\n },\n primary: false,\n exchangeRate: 0.01\n }\n ]\n}","export default {\r\n\r\n \"VERSION\": \"1.0.0\",\r\n\r\n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\r\n \"ACTOR_CLASS_TYPE\": \"npc\",\r\n\r\n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\r\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity\",\r\n\r\n // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\r\n \"ITEM_FILTERS\": [\r\n {\r\n \"path\": \"type\",\r\n \"filters\": \"attack,buff,class,feat,race,spell\"\r\n }\r\n ],\r\n\r\n // Item similarities determines how item piles detect similarities and differences in the system\r\n \"ITEM_SIMILARITIES\": [\"name\", \"type\"],\r\n\r\n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\r\n // In the case of attributes, the path is relative to the \"actor.data\"\r\n // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data\r\n \"CURRENCIES\": [\r\n {\r\n type: \"attribute\",\r\n name: \"PF1.CurrencyPlatinumP\",\r\n img: \"systems/pf1/icons/items/inventory/coins-silver.jpg\",\r\n abbreviation: \"{#}PP\",\r\n data: {\r\n path: \"data.currency.gold\",\r\n },\r\n primary: true,\r\n exchangeRate: 10\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"DS4.CharacterCurrencyGold\",\r\n img: \"systems/pf1/icons/items/inventory/coin-gold.jpg\",\r\n abbreviation: \"{#}G\",\r\n data: {\r\n path: \"data.currency.gold\",\r\n },\r\n primary: true,\r\n exchangeRate: 1\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"PF1.CurrencySilverP\",\r\n img: \"systems/pf1/icons/items/inventory/coin-silver.jpg\",\r\n abbreviation: \"{#}SP\",\r\n data: {\r\n path: \"data.currency.sp\",\r\n },\r\n primary: false,\r\n exchangeRate: 0.1\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"PF1.CurrencyCopperP\",\r\n img: \"systems/pf1/icons/items/inventory/coin-copper.jpg\",\r\n abbreviation: \"{#}C\",\r\n data: {\r\n path: \"data.currency.cp\",\r\n },\r\n primary: false,\r\n exchangeRate: 0.01\r\n }\r\n ]\r\n}","export default {\r\n\r\n \"VERSION\": \"1.0.0\",\r\n\r\n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\r\n \"ACTOR_CLASS_TYPE\": \"loot\",\r\n\r\n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\r\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity\",\r\n\r\n // The item price attribute is the path to the attribute on each item that determine how much it costs\r\n \"ITEM_PRICE_ATTRIBUTE\": \"data.price\",\r\n\r\n // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\r\n \"ITEM_FILTERS\": [\r\n {\r\n \"path\": \"type\",\r\n \"filters\": \"action,spell,melee,lore,heritage,feat,effect,class,background,ancestry\"\r\n }\r\n ],\r\n\r\n // Item similarities determines how item piles detect similarities and differences in the system\r\n \"ITEM_SIMILARITIES\": [\"name\", \"type\", \"data.temporary.value\"],\r\n\r\n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\r\n // In the case of attributes, the path is relative to the \"actor.data\"\r\n // In the case of items, it is recommended you export the item with `.toObject()`, put it into `data.item`, and strip out any module data\r\n \"CURRENCIES\": [\r\n {\r\n type: \"item\",\r\n name: \"Platinum Pieces\",\r\n img: \"systems/pf2e/icons/equipment/treasure/currency/platinum-pieces.webp\",\r\n abbreviation: \"{#}PP\",\r\n data: {\r\n uuid: \"Compendium.pf2e.equipment-srd.JuNPeK5Qm1w6wpb4\"\r\n },\r\n primary: false,\r\n exchangeRate: 10\r\n },\r\n {\r\n type: \"item\",\r\n name: \"Gold Pieces\",\r\n img: \"systems/pf2e/icons/equipment/treasure/currency/gold-pieces.webp\",\r\n abbreviation: \"{#}GP\",\r\n data: {\r\n uuid: \"Compendium.pf2e.equipment-srd.B6B7tBWJSqOBz5zz\"\r\n },\r\n primary: true,\r\n exchangeRate: 1\r\n },\r\n {\r\n type: \"item\",\r\n name: \"Silver Pieces\",\r\n img: \"systems/pf2e/icons/equipment/treasure/currency/silver-pieces.webp\",\r\n abbreviation: \"{#}SP\",\r\n data: {\r\n uuid: \"Compendium.pf2e.equipment-srd.5Ew82vBF9YfaiY9f\"\r\n },\r\n primary: false,\r\n exchangeRate: 0.1\r\n },\r\n {\r\n type: \"item\",\r\n name: \"Copper Pieces\",\r\n img: \"systems/pf2e/icons/equipment/treasure/currency/copper-pieces.webp\",\r\n abbreviation: \"{#}CP\",\r\n data: {\r\n uuid: \"Compendium.pf2e.equipment-srd.lzJ8AVhRcbFul5fh\"\r\n },\r\n primary: false,\r\n exchangeRate: 0.01\r\n }\r\n ]\r\n}\r\n","// Item Piles Definitions for Foundry VTT Game System Dungeonslayers 4\n\nexport default {\n\n \"VERSION\": \"1.0.0\",\n\n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\n \"ACTOR_CLASS_TYPE\": \"character\",\n\n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity\",\n\n // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\n \"ITEM_FILTERS\": [\n {\n \"path\": \"type\",\n \"filters\": \"spell,talent,racialAbility,language,alphabet,specialCreatureAbility\"\n }\n ],\n\n // Item similarities determines how item piles detect similarities and differences in the system\n \"ITEM_SIMILARITIES\": [\"name\", \"type\"],\n\n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\n // In the case of attributes, the path is relative to the \"actor.data\"\n // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data\n \"CURRENCIES\": [\n {\n type: \"attribute\",\n name: \"DS4.CharacterCurrencyGold\",\n img: \"icons/commodities/currency/coin-embossed-crown-gold.webp\",\n abbreviation: \"{#}G\",\n data: {\n path: \"data.currency.gold\",\n },\n primary: true,\n exchangeRate: 1\n },\n {\n type: \"attribute\",\n name: \"DS4.CharacterCurrencySilver\",\n img: \"icons/commodities/currency/coin-inset-snail-silver.webp\",\n abbreviation: \"{#}S\",\n data: {\n path: \"data.currency.silver\",\n },\n primary: false,\n exchangeRate: 0.1\n },\n {\n type: \"attribute\",\n name: \"DS4.CharacterCurrencyCopper\",\n img: \"icons/commodities/currency/coin-engraved-waves-copper.webp\",\n abbreviation: \"{#}C\",\n data: {\n path: \"data.currency.copper\",\n },\n primary: false,\n exchangeRate: 0.01\n }\n ]\n}","export default {\r\n\r\n \"VERSION\": \"1.0.0\",\r\n\r\n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\r\n \"ACTOR_CLASS_TYPE\": \"npc\",\r\n\r\n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\r\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity\",\r\n\r\n // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\r\n \"ITEM_FILTERS\": [\r\n {\r\n \"path\": \"type\",\r\n \"filters\": \"spell,feat,class,race,attack,full-attack,buff,aura,alignment,enhancement,damage-type,material\"\r\n }\r\n ],\r\n\r\n // Item similarities determines how item piles detect similarities and differences in the system\r\n \"ITEM_SIMILARITIES\": [\"name\", \"type\"],\r\n\r\n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\r\n // In the case of attributes, the path is relative to the \"actor.data\"\r\n // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data\r\n \"CURRENCIES\": [\r\n {\r\n type: \"attribute\",\r\n name: \"DND5E.CurrencyPP\",\r\n img: \"icons/commodities/currency/coin-inset-snail-silver.webp\",\r\n abbreviation: \"{#}PP\",\r\n data: {\r\n path: \"data.currency.pp\"\r\n },\r\n primary: false,\r\n exchangeRate: 10\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"DND5E.CurrencyGP\",\r\n img: \"icons/commodities/currency/coin-embossed-crown-gold.webp\",\r\n abbreviation: \"{#}GP\",\r\n data: {\r\n path: \"data.currency.gp\",\r\n },\r\n primary: true,\r\n exchangeRate: 1\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"DND5E.CurrencySP\",\r\n img: \"icons/commodities/currency/coin-engraved-moon-silver.webp\",\r\n abbreviation: \"{#}SP\",\r\n data: {\r\n path: \"data.currency.sp\",\r\n },\r\n primary: false,\r\n exchangeRate: 0.1\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"DND5E.CurrencyCP\",\r\n img: \"icons/commodities/currency/coin-engraved-waves-copper.webp\",\r\n abbreviation: \"{#}CP\",\r\n data: {\r\n path: \"data.currency.cp\",\r\n },\r\n primary: false,\r\n exchangeRate: 0.01\r\n }\r\n ]\r\n}","export default {\n\n \"VERSION\": \"1.0.0\",\n\n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\n \"ACTOR_CLASS_TYPE\": \"npc2\",\n\n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity\",\n\n // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\n \"ITEM_FILTERS\": [\n {\n \"path\": \"type\",\n \"filters\": \"attack,buff,class,feat,race,spell\"\n }\n ],\n\n // Item similarities determines how item piles detect similarities and differences in the system\n \"ITEM_SIMILARITIES\": [\"name\", \"type\"],\n\n \"CURRENCIES\": {\n \"Credits\": [\n {\n type: \"attribute\",\n name: \"SFRPG.Currencies.Credits\",\n img: \"systems/sfrpg/icons/equipment/goods/credstick.jpg\",\n abbreviation: \"{#}C\",\n data: {\n path: \"data.currency.credit\",\n },\n primary: true,\n exchangeRate: 1\n }\n ],\n \"Universal Polymer Base\": [\n {\n type: \"attribute\",\n name: \"SFRPG.Currencies.UPBs\",\n img: \"systems/sfrpg/icons/equipment/goods/upb.jpg\",\n abbreviation: \"{#} UBP\",\n data: {\n path: \"data.currency.upb\",\n },\n primary: false,\n exchangeRate: 1\n }\n ]\n }\n}","export default {\r\n\r\n \"VERSION\": \"1.0.0\",\r\n\r\n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\r\n \"ACTOR_CLASS_TYPE\": \"character\",\r\n\r\n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\r\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity\",\r\n\r\n // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\r\n \"ITEM_FILTERS\": [\r\n {\r\n \"path\": \"type\",\r\n \"filters\": \"edge,hindrance,skill,power,ability\"\r\n }\r\n ],\r\n\r\n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\r\n // In the case of attributes, the path is relative to the \"actor.data\"\r\n // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data\r\n \"CURRENCIES\": [\r\n {\r\n type: \"attribute\",\r\n name: \"SWADE.Currency\",\r\n img: \"icons/svg/coins.svg\",\r\n abbreviation: \"{#}T\",\r\n data: {\r\n path: \"data.details.currency\",\r\n },\r\n primary: true,\r\n exchangeRate: 1\r\n }\r\n ]\r\n}","export default {\r\n\r\n \"VERSION\": \"1.0.0\",\r\n\r\n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\r\n \"ACTOR_CLASS_TYPE\": \"character\",\r\n\r\n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\r\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.qtd\",\r\n\r\n // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\r\n \"ITEM_FILTERS\": [\r\n {\r\n \"path\": \"type\",\r\n \"filters\": \"magia, poder, classe\"\r\n },\r\n {\r\n \"path\": \"data.tipoUso\",\r\n \"filters\": \"nat\"\r\n }\r\n ],\r\n\r\n // Item similarities determines how item piles detect similarities and differences in the system\r\n \"ITEM_SIMILARITIES\": [\"name\", \"type\"],\r\n\r\n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\r\n // In the case of attributes, the path is relative to the \"actor.data\"\r\n // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data\r\n \"CURRENCIES\": [\r\n {\r\n type: \"attribute\",\r\n name: \"Ouro\",\r\n img: \"icons/commodities/currency/coin-embossed-insect-gold.webp\",\r\n abbreviation: \"{#}O\",\r\n data: {\r\n path: \"data.dinheiro.to\",\r\n },\r\n primary: true,\r\n exchangeRate: 1\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"Prata\",\r\n img: \"icons/commodities/currency/coin-embossed-unicorn-silver.webp\",\r\n abbreviation: \"{#}P\",\r\n data: {\r\n path: \"data.dinheiro.tp\",\r\n },\r\n primary: false,\r\n exchangeRate: 0.1\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"Cobre\",\r\n img: \"icons/commodities/currency/coin-engraved-waves-copper.webp\",\r\n abbreviation: \"{#}C\",\r\n data: {\r\n path: \"data.dinheiro.tc\",\r\n },\r\n primary: false,\r\n exchangeRate: 0.01\r\n }\r\n ]\r\n}","export default {\r\n\r\n \"VERSION\": \"1.0.0\",\r\n\r\n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\r\n \"ACTOR_CLASS_TYPE\": \"character\",\r\n\r\n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\r\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity.value\",\r\n\r\n // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\r\n \"ITEM_FILTERS\": [\r\n {\r\n \"path\": \"type\",\r\n \"filters\": \"career,container,critical,disease,injury,mutation,prayer,psychology,talent,skill,spell,trait,extendedTest,vehicleMod,cargo\"\r\n }\r\n ],\r\n\r\n // Item similarities determines how item piles detect similarities and differences in the system\r\n \"ITEM_SIMILARITIES\": [\"name\", \"type\"],\r\n\r\n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\r\n // In the case of attributes, the path is relative to the \"actor.data\"\r\n // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data\r\n \"CURRENCIES\": []\r\n}","export default {\r\n\r\n \"VERSION\": \"1.0.0\",\r\n\r\n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\r\n \"ACTOR_CLASS_TYPE\": \"npc\",\r\n\r\n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\r\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity\",\r\n\r\n // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\r\n \"ITEM_FILTERS\": [\r\n {\r\n \"path\": \"type\",\r\n \"filters\": \"spell,strength,weakness,mastery,species,culture,ancestry,education,resource,npcfeature,moonsign,language,culturelore,statuseffect,spelleffect\"\r\n }\r\n ],\r\n\r\n // Item similarities determines how item piles detect similarities and differences in the system\r\n \"ITEM_SIMILARITIES\": [\"name\", \"type\", \"data.sufferedDamage\", \"data.quality\"],\r\n\r\n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\r\n // In the case of attributes, the path is relative to the \"actor.data\"\r\n // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data\r\n \"CURRENCIES\": [\r\n {\r\n type: \"attribute\",\r\n name: \"Solare\",\r\n img: \"icons/commodities/currency/coins-assorted-mix-copper.webp\",\r\n abbreviation: \"{#}S\",\r\n data: {\r\n path: \"data.currency.S\",\r\n },\r\n primary: false,\r\n exchangeRate: 10000\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"Lunare\",\r\n img: \"icons/commodities/currency/coin-embossed-unicorn-silver.webp\",\r\n abbreviation: \"{#}L\",\r\n data: {\r\n path: \"data.currency.L\",\r\n },\r\n primary: false,\r\n exchangeRate: 100\r\n },\r\n {\r\n type: \"attribute\",\r\n name: \"Telare\",\r\n img: \"icons/commodities/currency/coins-assorted-mix-platinum.webp\",\r\n abbreviation: \"{#}T\",\r\n data: {\r\n path: \"data.currency.T\",\r\n },\r\n primary: true,\r\n exchangeRate: 1\r\n }\r\n ]\r\n}","export default {\n \n \"VERSION\": \"1.0.0\",\n \n // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.\n \"ACTOR_CLASS_TYPE\": \"traveller\",\n \n // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists\n \"ITEM_QUANTITY_ATTRIBUTE\": \"data.quantity\",\n \n // The item price attribute is the path to the attribute on each item that determine how much it costs\n \"ITEM_PRICE_ATTRIBUTE\": \"data.price\",\n \n // Item filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes\n \"ITEM_FILTERS\": [\n {\n \"path\": \"type\",\n \"filters\": \"skills\"\n }\n ],\n \n // Item similarities determines how item piles detect similarities and differences in the system\n \"ITEM_SIMILARITIES\": [\"name\", \"type\", \"techLevel\"],\n \n // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)\n // In the case of attributes, the path is relative to the \"actor.data\"\n // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data\n \"CURRENCIES\": [\n {\n type: \"attribute\",\n name: \"Credits\",\n img: \"systems/twodsix/assets/icons/id-card.svg\",\n abbreviation: \"Cr {#}\",\n data: {\n path: \"data.finances.cash\"\n },\n primary: true,\n exchangeRate: 1\n }\n ]\n}","import dnd5e from \"./systems/dnd5e.js\";\n\n// ā IMPORT SYSTEMS HERE ā\nimport pf1 from \"./systems/pf1.js\";\nimport pf2e from \"./systems/pf2e.js\";\nimport ds4 from \"./systems/ds4.js\";\nimport d35e from \"./systems/d35e.js\";\nimport sfrpg from \"./systems/sfrpg.js\";\nimport swade from \"./systems/swade.js\";\nimport tormenta20 from \"./systems/tormenta20.js\";\nimport wfrp4e from \"./systems/wfrp4e.js\"\nimport splittermond from \"./systems/splittermond.js\"\nimport twodsix from \"./systems/twodsix.js\";\n// ā IMPORT SYSTEMS HERE ā\n\n/**\n * NOTE: YOUR PULL REQUEST WILL NOT BE ACCEPTED IF YOU DO NOT\n * FOLLOW THE CONVENTION IN THE D&D 5E SYSTEM FILE\n */\nexport const SYSTEMS = {\n \n SUPPORTED_SYSTEMS: {\n dnd5e,\n // ā ADD SYSTEMS HERE ā\n pf1,\n pf2e,\n ds4,\n d35e,\n sfrpg,\n swade,\n tormenta20,\n wfrp4e,\n splittermond,\n twodsix\n // ā ADD SYSTEMS HERE ā\n },\n \n DEFAULT_SETTINGS: {\n ACTOR_CLASS_TYPE: \"\",\n ITEM_QUANTITY_ATTRIBUTE: \"\",\n ITEM_PRICE_ATTRIBUTE: \"\",\n ITEM_FILTERS: [],\n ITEM_SIMILARITIES: [],\n CURRENCIES: {\n \"itemBased\": false,\n \"list\": []\n }\n },\n \n get HAS_SYSTEM_SUPPORT() {\n return !!this.SUPPORTED_SYSTEMS?.[game.system.id];\n },\n \n get DATA() {\n return this.SUPPORTED_SYSTEMS?.[game.system.id] ?? this.DEFAULT_SETTINGS;\n }\n};","import { SYSTEMS } from \"../systems.js\";\r\n\r\nconst SETTINGS = {\r\n \r\n // Client settings\r\n OUTPUT_TO_CHAT: \"outputToChat\",\r\n INVERT_SHEET_OPEN: \"invertSheetOpen\",\r\n HIDE_ACTOR_HEADER_TEXT: \"hideActorHeaderText\",\r\n PRELOAD_FILES: \"preloadFiles\",\r\n DEBUG: \"debug\",\r\n DEBUG_HOOKS: \"debugHooks\",\r\n \r\n // Module Settings\r\n ENABLE_DROPPING_ITEMS: \"enableDroppingItems\",\r\n ENABLE_TRADING: \"enableTrading\",\r\n SHOW_TRADE_BUTTON: \"showTradeButton\",\r\n DELETE_EMPTY_PILES: \"deleteEmptyPiles\",\r\n INSPECT_ITEMS_IN_TRADE: \"inspectItemsInTrade\",\r\n \r\n // System Settings\r\n CURRENCIES: \"currencies\",\r\n ITEM_FILTERS: \"itemFilters\",\r\n ACTOR_CLASS_TYPE: \"actorClassType\",\r\n ITEM_QUANTITY_ATTRIBUTE: \"itemQuantityAttribute\",\r\n ITEM_PRICE_ATTRIBUTE: \"itemPriceAttribute\",\r\n ITEM_SIMILARITIES: \"itemSimilarities\",\r\n \r\n // Hidden settings\r\n DEFAULT_ITEM_PILE_JOURNAL_ID: \"defaultItemPileJournalID\",\r\n DEFAULT_ITEM_PILE_ACTOR_ID: \"defaultItemPileActorID\",\r\n SYSTEM_FOUND: \"systemFound\",\r\n SYSTEM_NOT_FOUND_WARNING_SHOWN: \"systemNotFoundWarningShown\",\r\n PRECONFIGURED_SYSTEM: \"preconfiguredSystem\",\r\n SYSTEM_VERSION: \"systemVersion\",\r\n\r\n GET_DEFAULT() {\r\n return foundry.utils.deepClone(SETTINGS.DEFAULTS())\r\n },\r\n \r\n GET_SYSTEM_DEFAULTS() {\r\n return Object.fromEntries(Object.entries(SETTINGS.GET_DEFAULT()).filter(entry => {\r\n return entry[1].system;\r\n }));\r\n },\r\n \r\n DEFAULTS: () => ({\r\n \r\n [SETTINGS.CURRENCIES]: {\r\n name: \"ITEM-PILES.Settings.Currencies.Title\",\r\n label: \"ITEM-PILES.Settings.Currencies.Label\",\r\n hint: \"ITEM-PILES.Settings.Currencies.Hint\",\r\n icon: \"fa fa-money-bill-alt\",\r\n application: \"currencies\",\r\n scope: \"world\",\r\n config: false,\r\n system: true,\r\n default: SYSTEMS.DATA.CURRENCIES,\r\n type: Object\r\n },\r\n \r\n [SETTINGS.ITEM_FILTERS]: {\r\n name: \"ITEM-PILES.Settings.ItemFilters.Title\",\r\n label: \"ITEM-PILES.Settings.ItemFilters.Label\",\r\n hint: \"ITEM-PILES.Settings.ItemFilters.Hint\",\r\n icon: \"fa fa-filter\",\r\n application: \"item-filters\",\r\n scope: \"world\",\r\n config: false,\r\n system: true,\r\n default: SYSTEMS.DATA.ITEM_FILTERS,\r\n type: Array\r\n },\r\n \r\n [SETTINGS.ITEM_SIMILARITIES]: {\r\n name: \"ITEM-PILES.Settings.ItemSimilarities.Title\",\r\n label: \"ITEM-PILES.Settings.ItemSimilarities.Label\",\r\n hint: \"ITEM-PILES.Settings.ItemSimilarities.Hint\",\r\n icon: \"fa fa-equals\",\r\n application: \"item-similarities\",\r\n scope: \"world\",\r\n config: false,\r\n system: true,\r\n default: SYSTEMS.DATA.ITEM_SIMILARITIES,\r\n type: Array\r\n },\r\n \r\n [SETTINGS.ACTOR_CLASS_TYPE]: {\r\n name: \"ITEM-PILES.Settings.ActorClass.Title\",\r\n hint: \"ITEM-PILES.Settings.ActorClass.Hint\",\r\n scope: \"world\",\r\n config: false,\r\n system: true,\r\n default: SYSTEMS.DATA.ACTOR_CLASS_TYPE,\r\n type: String\r\n },\r\n \r\n [SETTINGS.ITEM_QUANTITY_ATTRIBUTE]: {\r\n name: \"ITEM-PILES.Settings.Quantity.Title\",\r\n hint: \"ITEM-PILES.Settings.Quantity.Hint\",\r\n scope: \"world\",\r\n config: false,\r\n system: true,\r\n default: SYSTEMS.DATA.ITEM_QUANTITY_ATTRIBUTE,\r\n type: String\r\n },\r\n \r\n [SETTINGS.ITEM_PRICE_ATTRIBUTE]: {\r\n name: \"ITEM-PILES.Settings.Price.Title\",\r\n hint: \"ITEM-PILES.Settings.Price.Hint\",\r\n scope: \"world\",\r\n config: false,\r\n system: true,\r\n default: SYSTEMS.DATA.ITEM_PRICE_ATTRIBUTE,\r\n type: String\r\n },\r\n\r\n [SETTINGS.SYSTEM_VERSION]: {\r\n scope: \"world\",\r\n config: false,\r\n default: \"0.0.0\",\r\n type: String\r\n },\r\n \r\n [SETTINGS.DEFAULT_ITEM_PILE_ACTOR_ID]: {\r\n scope: \"world\",\r\n config: false,\r\n default: \"\",\r\n type: String\r\n },\r\n \r\n [SETTINGS.DEFAULT_ITEM_PILE_JOURNAL_ID]: {\r\n scope: \"world\",\r\n config: false,\r\n default: \"\",\r\n type: String\r\n },\r\n \r\n [SETTINGS.SYSTEM_FOUND]: {\r\n scope: \"world\",\r\n config: false,\r\n default: false,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.SYSTEM_NOT_FOUND_WARNING_SHOWN]: {\r\n scope: \"world\",\r\n config: false,\r\n default: false,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.PRECONFIGURED_SYSTEM]: {\r\n scope: \"world\",\r\n config: false,\r\n default: false,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.OUTPUT_TO_CHAT]: {\r\n name: \"ITEM-PILES.Settings.OutputToChat.Title\",\r\n hint: \"ITEM-PILES.Settings.OutputToChat.Hint\",\r\n scope: \"world\",\r\n config: false,\r\n default: 1,\r\n choices: [\r\n \"ITEM-PILES.Settings.OutputToChat.Off\",\r\n \"ITEM-PILES.Settings.OutputToChat.Public\",\r\n \"ITEM-PILES.Settings.OutputToChat.SelfGM\",\r\n \"ITEM-PILES.Settings.OutputToChat.Blind\",\r\n ],\r\n type: Number\r\n },\r\n \r\n [SETTINGS.INSPECT_ITEMS_IN_TRADE]: {\r\n name: \"ITEM-PILES.Settings.InspectItemsTrade.Title\",\r\n hint: \"ITEM-PILES.Settings.InspectItemsTrade.Hint\",\r\n scope: \"world\",\r\n config: false,\r\n default: true,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.DELETE_EMPTY_PILES]: {\r\n name: \"ITEM-PILES.Settings.DeleteEmptyPiles.Title\",\r\n hint: \"ITEM-PILES.Settings.DeleteEmptyPiles.Hint\",\r\n scope: \"world\",\r\n config: false,\r\n default: false,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.ENABLE_DROPPING_ITEMS]: {\r\n name: \"ITEM-PILES.Settings.EnableDroppingItems.Title\",\r\n hint: \"ITEM-PILES.Settings.EnableDroppingItems.Hint\",\r\n scope: \"world\",\r\n config: false,\r\n default: true,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.ENABLE_TRADING]: {\r\n name: \"ITEM-PILES.Settings.EnableTrading.Title\",\r\n hint: \"ITEM-PILES.Settings.EnableTrading.Hint\",\r\n scope: \"world\",\r\n config: false,\r\n default: true,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.SHOW_TRADE_BUTTON]: {\r\n name: \"ITEM-PILES.Settings.ShowTradeButton.Title\",\r\n hint: \"ITEM-PILES.Settings.ShowTradeButton.Hint\",\r\n scope: \"world\",\r\n config: false,\r\n default: true,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.INVERT_SHEET_OPEN]: {\r\n name: \"ITEM-PILES.Settings.InvertSheetOpen.Title\",\r\n hint: \"ITEM-PILES.Settings.InvertSheetOpen.Hint\",\r\n scope: \"client\",\r\n config: false,\r\n default: false,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.HIDE_ACTOR_HEADER_TEXT]: {\r\n name: \"ITEM-PILES.Settings.HideActorHeaderText.Title\",\r\n hint: \"ITEM-PILES.Settings.HideActorHeaderText.Hint\",\r\n scope: \"client\",\r\n config: false,\r\n default: false,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.PRELOAD_FILES]: {\r\n name: \"ITEM-PILES.Settings.PreloadFiles.Title\",\r\n hint: \"ITEM-PILES.Settings.PreloadFiles.Hint\",\r\n scope: \"client\",\r\n config: false,\r\n default: true,\r\n type: Boolean\r\n },\r\n \r\n [SETTINGS.DEBUG]: {\r\n name: \"ITEM-PILES.Settings.Debug.Title\",\r\n hint: \"ITEM-PILES.Settings.Debug.Hint\",\r\n scope: \"client\",\r\n config: false,\r\n default: false,\r\n type: Boolean\r\n },\r\n \r\n \r\n [SETTINGS.DEBUG_HOOKS]: {\r\n name: \"ITEM-PILES.Settings.DebugHooks.Title\",\r\n hint: \"ITEM-PILES.Settings.DebugHooks.Hint\",\r\n scope: \"client\",\r\n config: false,\r\n default: false,\r\n type: Boolean\r\n },\r\n \r\n })\r\n}\r\n\r\nexport default SETTINGS;","const module_name = \"item-piles\";\r\nconst module_path = `modules/${module_name}/`;\r\nconst baseFlag = `flags.${module_name}.`\r\n\r\nconst CONSTANTS = {\r\n \r\n MODULE_NAME: module_name,\r\n PATH: module_path,\r\n \r\n FLAGS: {\r\n PILE: baseFlag + \"data\",\r\n SHARING: baseFlag + \"sharing\",\r\n ITEM: baseFlag + \"item\",\r\n PUBLIC_TRADE_ID: baseFlag + \"publicTradeId\",\r\n TRADE_USERS: baseFlag + \"tradeUsers\",\r\n TEMPORARY_ITEM: baseFlag + \"temporary_item\"\r\n },\r\n \r\n ITEM_DEFAULTS: {\r\n hidden: false,\r\n notForSale: false,\r\n infiniteQuantity: false,\r\n displayQuantity: \"default\",\r\n free: false,\r\n disableNormalCost: false,\r\n prices: []\r\n },\r\n \r\n PILE_DEFAULTS: {\r\n // Core settings\r\n enabled: false,\r\n distance: 1,\r\n macro: \"\",\r\n deleteWhenEmpty: \"default\",\r\n canInspectItems: true,\r\n \r\n // Overrides\r\n overrideItemFilters: false,\r\n overrideCurrencies: false,\r\n \r\n // Token settings\r\n displayOne: false,\r\n showItemName: false,\r\n overrideSingleItemScale: false,\r\n singleItemScale: 1.0,\r\n \r\n // Sharing settings\r\n shareItemsEnabled: false,\r\n shareCurrenciesEnabled: true,\r\n takeAllEnabled: false,\r\n splitAllEnabled: true,\r\n activePlayers: false,\r\n \r\n // Container settings\r\n isContainer: false,\r\n closed: false,\r\n locked: false,\r\n closedImage: \"\",\r\n emptyImage: \"\",\r\n openedImage: \"\",\r\n lockedImage: \"\",\r\n closeSound: \"\",\r\n openSound: \"\",\r\n lockedSound: \"\",\r\n unlockedSound: \"\",\r\n \r\n // Merchant settings\r\n isMerchant: false,\r\n isClosed: false,\r\n infiniteQuantity: false,\r\n infiniteCurrencies: true,\r\n purchaseOnly: false,\r\n hideNewItems: false,\r\n displayQuantity: \"yes\",\r\n buyPriceModifier: 1,\r\n sellPriceModifier: 0.5,\r\n itemTypePriceModifiers: [],\r\n actorPriceModifiers: [],\r\n openTimes: {\r\n enabled: false,\r\n open: {\r\n hour: 9,\r\n minute: 0\r\n },\r\n close: {\r\n hour: 18,\r\n minute: 0\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport default CONSTANTS;","import CONSTANTS from \"../constants/constants.js\";\r\n\r\nexport const debounceManager = {\r\n \r\n debounces: {},\r\n \r\n setDebounce(id, method) {\r\n if (this.debounces[id]) {\r\n return this.debounces[id];\r\n }\r\n this.debounces[id] = debounce(function (...args) {\r\n delete debounceManager.debounces[id];\r\n return method(...args);\r\n }, 50);\r\n return this.debounces[id];\r\n }\r\n};\r\n\r\nexport const hooks = {\r\n run: true,\r\n _hooks: {},\r\n \r\n async runWithout(callback) {\r\n this.run = false;\r\n await callback();\r\n this.run = true;\r\n },\r\n \r\n call(hook, ...args) {\r\n if (!this.run) return;\r\n return Hooks.call(hook, ...args);\r\n },\r\n \r\n callAll(hook, ...args) {\r\n if (!this.run) return;\r\n return Hooks.callAll(hook, ...args);\r\n },\r\n \r\n on(hook, callback) {\r\n Hooks.on(hook, (...args) => {\r\n if (!this.run) return;\r\n callback(...args);\r\n });\r\n }\r\n}\r\n\r\nexport function wait(ms) {\r\n return new Promise(resolve => setTimeout(resolve, ms));\r\n}\r\n\r\nexport function getSetting(key) {\r\n return game.settings.get(CONSTANTS.MODULE_NAME, key);\r\n}\r\n\r\nexport function setSetting(key, value) {\r\n if (value === undefined) throw new Error(\"setSetting | value must not be undefined!\");\r\n return game.settings.set(CONSTANTS.MODULE_NAME, key, value);\r\n}\r\n\r\nexport function debug(msg, args = \"\") {\r\n if (game.settings.get(CONSTANTS.MODULE_NAME, \"debug\")) {\r\n console.log(`DEBUG | Item Piles | ${msg}`, args)\r\n }\r\n}\r\n\r\nexport function custom_notify(message) {\r\n message = `Item Piles | ${message}`;\r\n ui.notifications.notify(message);\r\n console.log(message.replace(\" \", \"\\n\"));\r\n}\r\n\r\nexport function custom_warning(warning, notify = false) {\r\n warning = `Item Piles | ${warning}`;\r\n if (notify) {\r\n ui.notifications.warn(warning);\r\n }\r\n console.warn(warning.replace(\" \", \"\\n\"));\r\n}\r\n\r\nexport function custom_error(error, notify = true) {\r\n error = `Item Piles | ${error}`;\r\n if (notify) {\r\n ui.notifications.error(error);\r\n }\r\n return new Error(error.replace(\" \", \"\\n\"));\r\n}\r\n\r\nexport function dialogLayout({\r\n title = \"Item Piles\",\r\n message,\r\n icon = \"fas fa-exclamation-triangle\",\r\n extraHtml = \"\"\r\n } = {}) {\r\n return `\r\n
\r\n
\r\n
${title}
\r\n
${message}
\r\n ${extraHtml}\r\n
\r\n `;\r\n}\r\n\r\n\r\nexport function isRealNumber(inNumber) {\r\n return !isNaN(inNumber)\r\n && typeof inNumber === \"number\"\r\n && isFinite(inNumber);\r\n}\r\n\r\nexport function isActiveGM(user) {\r\n return user.active && user.isGM;\r\n}\r\n\r\nexport function getActiveGMs() {\r\n return game.users.filter(isActiveGM);\r\n}\r\n\r\nexport function isResponsibleGM() {\r\n if (!game.user.isGM) {\r\n return false;\r\n }\r\n return !getActiveGMs().some(other => other.data._id < game.user.data._id);\r\n}\r\n\r\nexport function isGMConnected() {\r\n return !!Array.from(game.users).find(user => user.isGM && user.active);\r\n}\r\n\r\nexport function roundToDecimals(num, decimals) {\r\n return Number(num.toFixed(decimals));\r\n}","export function getActor(target) {\r\n if (target instanceof Actor) return target;\r\n if (stringIsUuid(target)) {\r\n target = fromUuidFast(target);\r\n }\r\n target = getDocument(target);\r\n return target?.actor ?? target;\r\n}\r\n\r\nexport function getToken(documentUuid) {\r\n const document = fromUuidFast(documentUuid);\r\n return document?.token || false;\r\n}\r\n\r\nexport function getDocument(target) {\r\n if (stringIsUuid(target)) {\r\n target = fromUuidFast(target);\r\n }\r\n return target?.document ?? target;\r\n}\r\n\r\nexport function stringIsUuid(inId) {\r\n return typeof inId === \"string\"\r\n && (inId.match(/\\./g) || []).length\r\n && !inId.endsWith(\".\");\r\n}\r\n\r\n/**\r\n * Retrieves an object from the scene using its UUID, avoiding compendiums as they would have to be async'd\r\n *\r\n * @param uuid\r\n * @returns {null}\r\n */\r\nexport function fromUuidFast(uuid) {\r\n let parts = uuid.split(\".\");\r\n let doc;\r\n \r\n const [docName, docId] = parts.slice(0, 2);\r\n parts = parts.slice(2);\r\n const collection = CONFIG[docName].collection.instance;\r\n doc = collection.get(docId);\r\n \r\n // Embedded Documents\r\n while (doc && (parts.length > 1)) {\r\n const [embeddedName, embeddedId] = parts.slice(0, 2);\r\n doc = doc.getEmbeddedDocument(embeddedName, embeddedId);\r\n parts = parts.slice(2);\r\n }\r\n return doc || null;\r\n}\r\n\r\nexport function getUuid(target) {\r\n if(stringIsUuid(target)) return target;\r\n const document = getDocument(target);\r\n return document?.uuid ?? false;\r\n}\r\n\r\n/**\r\n * Find and retrieves an item in a list of items\r\n *\r\n * @param {Array- } items\r\n * @param {Item|Object} findItem\r\n * @returns {*}\r\n */\r\nexport function findSimilarItem(items, findItem) {\r\n \r\n const itemSimilarities = game.itempiles.ITEM_SIMILARITIES;\r\n \r\n const findItemId = findItem instanceof Item ? findItem.id : findItem._id;\r\n \r\n return items.find(item => {\r\n const itemId = item instanceof Item ? item.id : item._id;\r\n if (itemId && findItemId && itemId === findItemId) {\r\n return true;\r\n }\r\n \r\n const itemData = item instanceof Item ? item.toObject() : item;\r\n for (const path of itemSimilarities) {\r\n if (getProperty(itemData, path) !== getProperty(findItem, path)) {\r\n return false;\r\n }\r\n }\r\n \r\n return true;\r\n });\r\n}\r\n\r\nexport function setSimilarityProperties(obj, item){\r\n const itemData = item instanceof Item ? item.toObject() : item;\r\n setProperty(obj, \"_id\", itemData._id);\r\n game.itempiles.ITEM_SIMILARITIES.forEach(prop => {\r\n setProperty(obj, prop, getProperty(itemData, prop));\r\n })\r\n return obj;\r\n}\r\n\r\n/**\r\n * Returns a given item's quantity\r\n *\r\n * @param {Item/Object} item\r\n * @returns {number}\r\n */\r\nexport function getItemQuantity(item) {\r\n const itemData = item instanceof Item ? item.toObject() : item;\r\n return Number(getProperty(itemData, game.itempiles.ITEM_QUANTITY_ATTRIBUTE) ?? 0);\r\n}\r\n\r\n/**\r\n * Returns a given item's quantity\r\n *\r\n * @param {Object} itemData\r\n * @param {Number} quantity\r\n * @returns {Object}\r\n */\r\nexport function setItemQuantity(itemData, quantity) {\r\n setProperty(itemData, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, quantity)\r\n return itemData;\r\n}\r\n\r\n/**\r\n * Retrieves all visible tokens on a given location\r\n *\r\n * @param position\r\n * @returns {Array
}\r\n */\r\nexport function getTokensAtLocation(position) {\r\n const tokens = [...canvas.tokens.placeables].filter(token => token.visible);\r\n return tokens.filter(token => {\r\n return position.x >= token.x && position.x < (token.x + (token.data.width * canvas.grid.size))\r\n && position.y >= token.y && position.y < (token.y + (token.data.height * canvas.grid.size));\r\n });\r\n}\r\n\r\nexport function distance_between_rect(p1, p2) {\r\n \r\n const x1 = p1.x;\r\n const y1 = p1.y;\r\n const x1b = p1.x + p1.w;\r\n const y1b = p1.y + p1.h;\r\n \r\n const x2 = p2.x;\r\n const y2 = p2.y;\r\n const x2b = p2.x + p2.w;\r\n const y2b = p2.y + p2.h;\r\n \r\n const left = x2b < x1;\r\n const right = x1b < x2;\r\n const bottom = y2b < y1;\r\n const top = y1b < y2;\r\n \r\n if (top && left) {\r\n return distance_between({ x: x1, y: y1b }, { x: x2b, y: y2 });\r\n } else if (left && bottom) {\r\n return distance_between({ x: x1, y: y1 }, { x: x2b, y: y2b });\r\n } else if (bottom && right) {\r\n return distance_between({ x: x1b, y: y1 }, { x: x2, y: y2b });\r\n } else if (right && top) {\r\n return distance_between({ x: x1b, y: y1b }, { x: x2, y: y2 });\r\n } else if (left) {\r\n return x1 - x2b;\r\n } else if (right) {\r\n return x2 - x1b;\r\n } else if (bottom) {\r\n return y1 - y2b;\r\n } else if (top) {\r\n return y2 - y1b;\r\n }\r\n \r\n return 0;\r\n \r\n}\r\n\r\nexport function distance_between(a, b) {\r\n return new Ray(a, b).distance;\r\n}\r\n\r\nexport function grids_between_tokens(a, b) {\r\n return Math.floor(distance_between_rect(a, b) / canvas.grid.size) + 1\r\n}\r\n\r\nexport function tokens_close_enough(a, b, maxDistance) {\r\n const distance = grids_between_tokens(a, b);\r\n return maxDistance >= distance;\r\n}\r\n\r\nexport function refreshAppsWithDocument(doc, callback) {\r\n const apps = Object.values(ui.windows).filter(app => app.id.endsWith(doc.id));\r\n for (const app of apps) {\r\n if (app[callback]) {\r\n app[callback]();\r\n }\r\n }\r\n}","import * as Utilities from \"./utilities.js\"\nimport CONSTANTS from \"../constants/constants.js\";\nimport * as Helpers from \"./helpers.js\";\n\nfunction getFlagData(inDocument, flag, defaults, existing = false) {\n const defaultFlags = foundry.utils.duplicate(defaults);\n const flags = existing || (getProperty(inDocument.data, flag) ?? {});\n const data = foundry.utils.duplicate(flags);\n return foundry.utils.mergeObject(defaultFlags, data);\n}\n\nexport function getItemFlagData(item) {\n return getFlagData(Utilities.getDocument(item), CONSTANTS.FLAGS.ITEM, CONSTANTS.ITEM_DEFAULTS);\n}\n\nexport function getActorFlagData(target, data = false) {\n return getFlagData(Utilities.getActor(target), CONSTANTS.FLAGS.PILE, CONSTANTS.PILE_DEFAULTS, data);\n}\n\nexport function isValidItemPile(target, data = false) {\n const targetActor = Utilities.getActor(target);\n const pileData = getActorFlagData(targetActor, data);\n return targetActor && pileData?.enabled;\n}\n\nexport function isItemPileContainer(target, data = false) {\n const targetActor = Utilities.getActor(target);\n const pileData = getActorFlagData(targetActor, data);\n return pileData?.enabled && pileData?.isContainer;\n}\n\nexport function isItemPileMerchant(target, data = false) {\n const targetActor = Utilities.getActor(target);\n const pileData = getActorFlagData(targetActor, data);\n return pileData?.enabled && pileData?.isMerchant;\n}\n\nexport function isItemPileClosed(target, data = false) {\n const targetActor = Utilities.getActor(target);\n const pileData = getActorFlagData(targetActor, data);\n if (!pileData?.enabled || !pileData?.isContainer) return false;\n return pileData.closed;\n}\n\nexport function isItemPileLocked(target, data = false) {\n const targetActor = Utilities.getActor(target);\n const pileData = getActorFlagData(targetActor, data);\n if (!pileData?.enabled || !pileData?.isContainer) return false;\n return pileData.locked;\n}\n\nexport function isItemPileEmpty(target) {\n \n const targetActor = Utilities.getActor(target);\n if (!targetActor) return false;\n \n const validItemPile = isValidItemPile(targetActor);\n if (!validItemPile) return false;\n \n const hasNoItems = getActorItems(targetActor).length === 0;\n const hasNoAttributes = getActorCurrencies(targetActor).length === 0;\n \n return validItemPile && hasNoItems && hasNoAttributes;\n \n}\n\nexport function shouldItemPileBeDeleted(targetUuid) {\n \n const target = Utilities.fromUuidFast(targetUuid);\n \n if (!(target instanceof TokenDocument)) return false;\n \n if (!isItemPileEmpty(target)) return false;\n \n const pileData = getActorFlagData(target);\n \n return {\n \"default\": Helpers.getSetting(\"deleteEmptyPiles\"), \"true\": true, \"false\": false\n }[pileData?.deleteWhenEmpty ?? \"default\"];\n \n}\n\nexport function getActorItems(target, { itemFilters = false } = {}) {\n const actor = Utilities.getActor(target);\n const actorItemFilters = itemFilters ? cleanItemFilters(itemFilters) : getActorItemFilters(actor);\n const currencies = getActorCurrencies(actor).map(entry => entry.id);\n return actor.items.filter(item => currencies.indexOf(item.id) === -1 && !isItemInvalid(actor, item, actorItemFilters));\n}\n\nexport function getActorCurrencies(target, { forActor = false, currencyList = false, getAll = false } = {}) {\n const actor = Utilities.getActor(target);\n const actorItems = Array.from(actor.items);\n currencyList = currencyList || getActorCurrencyList(forActor || actor);\n let currencies = currencyList.map((currency, index) => {\n if (currency.type === \"attribute\") {\n return {\n ...currency,\n quantity: getProperty(actor.data, currency.data.path) ?? 0,\n path: currency.data.path,\n id: currency.data.path,\n index\n }\n }\n const item = Utilities.findSimilarItem(actorItems, currency.data.item);\n return {\n ...currency, quantity: item ? Utilities.getItemQuantity(item) : 0, id: item?.id || null, item, index\n }\n });\n if (!getAll) {\n currencies = currencies.filter(currency => currency.quantity);\n }\n return currencies;\n}\n\nexport function getActorPrimaryCurrency(target) {\n const actor = Utilities.getActor(target);\n return getActorCurrencies(actor).find(currency => currency.primary);\n}\n\nexport function getActorCurrencyList(target, pileData = false) {\n const targetActor = Utilities.getActor(target);\n pileData = getActorFlagData(targetActor, pileData);\n return (pileData.overrideCurrencies || game.itempiles.CURRENCIES).map(currency => {\n currency.name = game.i18n.localize(currency.name);\n return currency;\n });\n}\n\n\nexport function getActorItemFilters(target, pileData = false) {\n if (!target) return cleanItemFilters(game.itempiles.ITEM_FILTERS);\n const targetActor = Utilities.getActor(target);\n pileData = getActorFlagData(targetActor, pileData);\n return isValidItemPile(targetActor, pileData) && pileData?.overrideItemFilters ? cleanItemFilters(pileData.overrideItemFilters) : cleanItemFilters(game.itempiles.ITEM_FILTERS);\n}\n\nexport function cleanItemFilters(itemFilters) {\n return itemFilters ? foundry.utils.duplicate(itemFilters).map(filter => {\n filter.path = filter.path.trim();\n filter.filters = Array.isArray(filter.filters) ? filter.filters : filter.filters.split(',').map(string => string.trim());\n filter.filters = new Set(filter.filters)\n return filter;\n }) : [];\n}\n\nexport function isItemInvalid(targetActor, item, itemFilters = false) {\n const pileItemFilters = itemFilters ? itemFilters : getActorItemFilters(targetActor)\n const itemData = item instanceof Item ? item.toObject() : item;\n for (const filter of pileItemFilters) {\n if (!hasProperty(itemData, filter.path)) continue;\n const attributeValue = getProperty(itemData, filter.path);\n if (filter.filters.has(attributeValue)) {\n return attributeValue;\n }\n }\n return false;\n}\n\nexport function isItemCurrency(item, { target = false } = {}) {\n const actor = Utilities.getActor(target ? target : item.parent);\n const currencies = getActorCurrencies(actor, { getAll: true })\n .filter(currency => currency.type === \"item\")\n .map(item => item.data.item);\n return !!Utilities.findSimilarItem(currencies, item);\n}\n\n\nexport function getItemPileTokenImage(token, { data = false, items = false, currencies = false } = {}) {\n \n const tokenDocument = Utilities.getDocument(token);\n \n const itemPileData = getActorFlagData(tokenDocument, data);\n \n let originalImg;\n if (tokenDocument instanceof TokenDocument) {\n originalImg = tokenDocument.data.img;\n } else {\n originalImg = tokenDocument.data.token.img;\n }\n \n if (!isValidItemPile(tokenDocument)) return originalImg;\n \n items = items || getActorItems(tokenDocument).map(item => item.toObject());\n currencies = currencies || getActorCurrencies(tokenDocument);\n \n const numItems = items.length + currencies.length;\n \n let img;\n \n if (itemPileData.displayOne && numItems === 1) {\n img = items.length > 0 ? items[0].img : currencies[0].img;\n } else if (itemPileData.displayOne && numItems > 1) {\n img = (tokenDocument.actor ?? tokenDocument).data.token.img;\n }\n \n if (itemPileData.isContainer) {\n \n img = itemPileData.lockedImage || itemPileData.closedImage || itemPileData.openedImage || itemPileData.emptyImage;\n \n if (itemPileData.locked && itemPileData.lockedImage) {\n img = itemPileData.lockedImage;\n } else if (itemPileData.closed && itemPileData.closedImage) {\n img = itemPileData.closedImage;\n } else if (itemPileData.emptyImage && isItemPileEmpty(tokenDocument)) {\n img = itemPileData.emptyImage;\n } else if (itemPileData.openedImage) {\n img = itemPileData.openedImage;\n }\n \n }\n \n return img || originalImg;\n \n}\n\nexport function getItemPileTokenScale(target, { data = false, items = false, currencies = false } = {}) {\n \n const pileDocument = Utilities.getDocument(target);\n \n let itemPileData = getActorFlagData(pileDocument, data);\n \n let baseScale;\n if (pileDocument instanceof TokenDocument) {\n baseScale = pileDocument.data.scale;\n } else {\n baseScale = pileDocument.data.token.scale;\n }\n \n if (!isValidItemPile(pileDocument, itemPileData)) {\n return baseScale;\n }\n \n items = items || getActorItems(pileDocument);\n currencies = currencies || getActorCurrencies(pileDocument);\n \n const numItems = items.length + currencies.length;\n \n if (itemPileData.isContainer || !itemPileData.displayOne || !itemPileData.overrideSingleItemScale || numItems > 1 || numItems === 0) {\n return baseScale;\n }\n \n return itemPileData.singleItemScale;\n \n}\n\nexport function getItemPileName(target, { data = false, items = false, currencies = false } = {}) {\n \n const pileDocument = Utilities.getDocument(target);\n \n const itemPileData = getActorFlagData(pileDocument, data);\n \n let name = pileDocument instanceof TokenDocument ? pileDocument.data.name : pileDocument.data.token.name;\n \n if (!isValidItemPile(pileDocument, itemPileData)) {\n return name;\n }\n \n items = items || getActorItems(pileDocument);\n currencies = currencies || getActorCurrencies(pileDocument);\n \n const numItems = items.length + currencies.length;\n \n if (itemPileData.isContainer || !itemPileData.displayOne || !itemPileData.showItemName || numItems > 1 || numItems === 0) {\n return name;\n }\n \n const item = items.length > 0 ? items[0] : currencies[0];\n \n return item.name;\n \n}\n\nfunction getRelevantTokensAndActor(target) {\n \n const relevantDocument = Utilities.getDocument(target);\n \n let documentActor;\n let documentTokens = [];\n \n if (relevantDocument instanceof Actor) {\n documentActor = relevantDocument;\n if (relevantDocument.token) {\n documentTokens.push(relevantDocument?.token);\n } else {\n documentTokens = canvas.tokens.placeables.filter(token => token.document.actor === documentActor).map(token => token.document);\n }\n } else {\n documentActor = relevantDocument.actor;\n if (relevantDocument.isLinked) {\n documentTokens = canvas.tokens.placeables.filter(token => token.document.actor === documentActor).map(token => token.document);\n } else {\n documentTokens.push(relevantDocument);\n }\n }\n \n return [documentActor, documentTokens]\n \n}\n\nexport async function updateItemPileData(target, flagData, tokenData) {\n \n if (!flagData) flagData = getActorFlagData(target);\n if (!tokenData) tokenData = {};\n \n const [documentActor, documentTokens] = getRelevantTokensAndActor(target);\n \n const items = getActorItems(documentActor, { itemFilters: flagData.overrideItemFilters });\n const currencies = getActorCurrencies(documentActor, { currencyList: flagData.overrideCurrencies });\n \n const pileData = { data: flagData, items, currencies };\n \n const updates = documentTokens.map(tokenDocument => {\n const newTokenData = foundry.utils.mergeObject(tokenData, {\n \"img\": getItemPileTokenImage(tokenDocument, pileData),\n \"scale\": getItemPileTokenScale(tokenDocument, pileData),\n \"name\": getItemPileName(tokenDocument, pileData),\n });\n const data = {\n \"_id\": tokenDocument.id, ...newTokenData\n };\n if (!foundry.utils.isObjectEmpty(flagData)) {\n data[CONSTANTS.FLAGS.PILE] = flagData;\n }\n return data\n });\n \n await canvas.scene.updateEmbeddedDocuments(\"Token\", updates);\n \n if (!foundry.utils.isObjectEmpty(flagData)) {\n await documentActor.update({\n [CONSTANTS.FLAGS.PILE]: flagData, [`token.${CONSTANTS.FLAGS.PILE}`]: flagData\n });\n }\n \n return true;\n}\n\nexport async function updateItemData(item, update) {\n const flagData = foundry.utils.mergeObject(getItemFlagData(item), update.flags ?? {});\n return item.update({\n ...update?.data ?? {}, [CONSTANTS.FLAGS.ITEM]: flagData\n });\n}\n\n/* -------------------------- Merchant Methods ------------------------- */\n\nexport function getMerchantModifiersForActor(merchant, { item = false, actor = false, pileFlagData = false } = {}) {\n \n let {\n buyPriceModifier, sellPriceModifier, itemTypePriceModifiers, actorPriceModifiers\n } = getActorFlagData(merchant, pileFlagData);\n \n if (item) {\n const itemTypePriceModifier = itemTypePriceModifiers.find(priceData => priceData.type === item.type);\n if (itemTypePriceModifier) {\n buyPriceModifier = itemTypePriceModifier.override ? itemTypePriceModifier.buyPriceModifier : buyPriceModifier * itemTypePriceModifier.buyPriceModifier;\n sellPriceModifier = itemTypePriceModifier.override ? itemTypePriceModifier.sellPriceModifier : sellPriceModifier * itemTypePriceModifier.sellPriceModifier;\n }\n }\n \n if (actor && actorPriceModifiers) {\n const actorSpecificModifiers = actorPriceModifiers?.find(data => data.actorUuid === Utilities.getUuid(actor));\n if (actorSpecificModifiers) {\n buyPriceModifier = actorSpecificModifiers.override ? actorSpecificModifiers.buyPriceModifier : buyPriceModifier * actorSpecificModifiers.buyPriceModifier;\n sellPriceModifier = actorSpecificModifiers.override ? actorSpecificModifiers.sellPriceModifier : sellPriceModifier * actorSpecificModifiers.sellPriceModifier;\n }\n }\n \n return {\n buyPriceModifier, sellPriceModifier\n }\n}\n\nfunction getPriceArray(totalCost, currencies) {\n \n const smallestExchangeRate = Math.min(...currencies.map(currency => currency.exchangeRate));\n const decimals = smallestExchangeRate.toString().split(\".\")[1].length;\n \n let fraction = Helpers.roundToDecimals(totalCost % 1, decimals);\n let cost = Math.round(totalCost - fraction);\n \n const prices = [];\n \n let skipPrimary = false;\n const primaryCurrency = currencies.find(currency => currency.primary)\n if (cost) {\n skipPrimary = true;\n prices.push({\n ...primaryCurrency,\n cost: cost,\n baseCost: cost,\n maxCurrencyCost: totalCost,\n string: primaryCurrency.abbreviation.replace('{#}', cost)\n });\n }\n \n for (const currency of currencies) {\n \n if (currency === primaryCurrency && skipPrimary) continue;\n \n const numCurrency = Math.floor(Helpers.roundToDecimals(fraction / currency.exchangeRate, decimals));\n \n fraction = Helpers.roundToDecimals(fraction - (numCurrency * currency.exchangeRate), decimals);\n \n prices.push({\n ...currency,\n cost: Math.round(numCurrency),\n baseCost: Math.round(numCurrency),\n maxCurrencyCost: Math.ceil(totalCost / currency.exchangeRate),\n string: currency.abbreviation.replace(\"{#}\", numCurrency)\n });\n }\n \n prices.sort((a, b) => b.exchangeRate - a.exchangeRate);\n \n return prices;\n}\n\nexport function getItemPrices(item, {\n seller = false, buyer = false, sellerFlagData = false, buyerFlagData = false, itemFlagData = false, quantity = 1\n} = {}) {\n \n let priceData = [];\n \n buyerFlagData = getActorFlagData(buyer, buyerFlagData);\n if (!buyerFlagData?.enabled || !buyerFlagData?.isMerchant) {\n buyerFlagData = false;\n }\n \n sellerFlagData = getActorFlagData(seller, sellerFlagData);\n if (!sellerFlagData?.enabled || !sellerFlagData?.isMerchant) {\n sellerFlagData = false;\n }\n \n itemFlagData = itemFlagData || getItemFlagData(item);\n \n if (itemFlagData?.free) {\n return priceData;\n }\n \n let merchant = sellerFlagData ? seller : buyer;\n \n // Retrieve the item price modifiers\n let modifier = 1;\n if (sellerFlagData) {\n \n modifier = getMerchantModifiersForActor(seller, {\n item, actor: buyer, pileFlagData: sellerFlagData\n }).buyPriceModifier;\n \n } else if (buyerFlagData) {\n \n modifier = getMerchantModifiersForActor(buyer, {\n item, actor: seller, pileFlagData: buyerFlagData\n }).sellPriceModifier;\n \n }\n \n if (!modifier) {\n return priceData;\n }\n \n const currencyList = getActorCurrencyList(merchant);\n const currencies = getActorCurrencies(merchant, { currencyList, getAll: true });\n \n // In order to easily calculate an item's total worth, we can use the smallest exchange rate and convert all prices\n // to it, in order have a stable form of exchange calculation\n const smallestExchangeRate = Math.min(...currencies.map(currency => currency.exchangeRate));\n const decimals = smallestExchangeRate.toString().split(\".\")[1].length;\n \n // If the item does include its normal cost, we calculate that here\n if (!itemFlagData.disableNormalCost) {\n \n const overallCost = getProperty(item.toObject(), game.itempiles.ITEM_PRICE_ATTRIBUTE);\n \n // Base prices is the displayed price, without quantity taken into account\n const baseCost = Helpers.roundToDecimals(overallCost * modifier, decimals);\n const basePrices = getPriceArray(baseCost, currencies);\n \n // Prices is the cost with the amount of quantity taken into account, which may change the number of the different\n // types of currencies it costs (eg, an item wouldn't cost 1 gold and 100 silver, it would cost 11 gold\n let totalCost = Helpers.roundToDecimals(overallCost * modifier * quantity, decimals);\n let prices = getPriceArray(totalCost, currencies);\n \n if (baseCost) {\n \n priceData.push({\n basePrices,\n basePriceString: basePrices.filter(price => price.cost).map(price => price.string).join(\" \"),\n prices,\n priceString: prices.filter(price => price.cost).map(price => price.string).join(\" \"),\n totalCost,\n baseCost,\n primary: true,\n maxQuantity: 0,\n quantity\n });\n \n }\n }\n \n // If the item has custom prices, we include them here\n if (itemFlagData.prices.length) {\n \n priceData = priceData.concat(itemFlagData.prices.map(priceGroup => {\n const prices = priceGroup.map(price => {\n const itemModifier = price.fixed ? 1 : modifier;\n const cost = Math.round(price.quantity * itemModifier * quantity);\n const baseCost = Math.round(price.quantity * itemModifier);\n price.name = game.i18n.localize(price.name);\n return {\n ...price,\n cost,\n baseCost,\n priceString: cost ? price.abbreviation.replace(\"{#}\", cost) : \"\",\n basePriceString: baseCost ? price.abbreviation.replace(\"{#}\", baseCost) : \"\"\n };\n });\n \n return {\n prices,\n priceString: prices.filter(price => price.priceString).map(price => price.priceString).join(\" \"),\n basePriceString: prices.filter(price => price.basePriceString).map(price => price.basePriceString).join(\" \"),\n maxQuantity: 0,\n quantity\n }\n }));\n }\n \n const buyerInfiniteCurrencies = buyerFlagData?.infiniteCurrencies;\n const buyerInfiniteQuantity = buyerFlagData?.infiniteQuantity;\n \n // If there's a buyer, we also calculate how many of the item the buyer can afford\n if (!buyer) return priceData;\n \n const recipientCurrencies = getActorCurrencies(buyer, { currencyList });\n const totalCurrencies = recipientCurrencies.map(currency => currency.quantity * currency.exchangeRate).reduce((acc, num) => acc + num, 0);\n \n // For each price group, check for properties and items and make sure that the actor can afford it\n for (const priceGroup of priceData) {\n priceGroup.maxQuantity = Infinity;\n if (priceGroup.baseCost !== undefined) {\n if (buyerInfiniteCurrencies) continue;\n priceGroup.maxQuantity = Math.floor(totalCurrencies / priceGroup.baseCost);\n priceGroup.prices.forEach(price => {\n price.maxQuantity = priceGroup.maxQuantity;\n });\n } else {\n if (buyerInfiniteQuantity) continue;\n for (const price of priceGroup.prices) {\n if (price.type === \"attribute\") {\n const attributeQuantity = Number(getProperty(buyer.data, price.data.path));\n price.buyerQuantity = attributeQuantity;\n price.maxQuantity = Math.floor(attributeQuantity / price.baseCost);\n priceGroup.maxQuantity = Math.min(priceGroup.maxQuantity, price.maxQuantity)\n } else {\n const foundItem = Utilities.findSimilarItem(buyer.items, price.data.item);\n const itemQuantity = foundItem ? Utilities.getItemQuantity(foundItem) : 0;\n price.buyerQuantity = itemQuantity;\n price.maxQuantity = Math.floor(itemQuantity / price.baseCost);\n priceGroup.maxQuantity = Math.min(priceGroup.maxQuantity, price.maxQuantity);\n }\n }\n }\n }\n \n return priceData;\n}\n\nexport function getPricesForItems(itemsToBuy, {\n seller = false, buyer = false, sellerFlagData = false, buyerFlagData = false\n} = {}) {\n \n sellerFlagData = getActorFlagData(seller, sellerFlagData);\n if (!sellerFlagData?.enabled || !sellerFlagData?.isMerchant) {\n sellerFlagData = false;\n }\n \n buyerFlagData = getActorFlagData(buyer, buyerFlagData);\n if (!buyerFlagData?.enabled || !buyerFlagData?.isMerchant) {\n buyerFlagData = false;\n }\n \n const merchant = sellerFlagData ? seller : buyer;\n const currencyList = getActorCurrencyList(merchant);\n const currencies = getActorCurrencies(merchant, { currencyList, getAll: true });\n const smallestExchangeRate = Math.min(...currencies.map(currency => currency.exchangeRate));\n const decimals = smallestExchangeRate.toString().split(\".\")[1].length;\n \n const recipientCurrencies = getActorCurrencies(buyer, { currencyList, getAll: true });\n \n const buyerInfiniteCurrencies = buyerFlagData?.infiniteCurrencies;\n \n const paymentData = itemsToBuy.map(data => {\n const prices = getItemPrices(data.item, {\n seller, buyer, sellerFlagData, buyerFlagData, itemFlagData: data.itemFlagData, quantity: data.quantity || 1\n })[data.paymentIndex || 0];\n return {\n ...prices, item: data.item\n };\n })\n .reduce((priceData, priceGroup) => {\n \n if (!priceGroup.maxQuantity) return priceData;\n \n if (priceGroup.primary) {\n \n priceData.totalCurrencyCost = Helpers.roundToDecimals(priceData.totalCurrencyCost + priceGroup.totalCost, decimals);\n priceData.primary = true;\n \n } else {\n \n for (const price of priceGroup.prices) {\n \n let existingPrice = priceData.otherPrices.find(otherPrice => {\n return otherPrice.id === price.id || (otherPrice.name === price.name && otherPrice.img === price.img && otherPrice.type === price.type);\n });\n \n if (existingPrice) {\n existingPrice.cost += price.cost;\n } else {\n const index = priceData.otherPrices.push(price);\n existingPrice = priceData.otherPrices[index - 1];\n existingPrice.quantity = 0;\n }\n \n existingPrice.quantity += price.cost;\n existingPrice.buyerQuantity -= price.cost;\n \n if (existingPrice.buyerQuantity < 0) {\n priceData.canBuy = false;\n }\n }\n }\n \n priceData.buyerReceive.push({\n type: \"item\",\n name: priceGroup.item.name,\n img: priceGroup.item.img,\n quantity: priceGroup.quantity,\n item: priceGroup.item,\n \n });\n \n return priceData;\n \n }, {\n totalCurrencyCost: 0, canBuy: true, primary: false, finalPrices: [], otherPrices: [],\n \n buyerReceive: [], buyerChange: [], sellerReceive: []\n });\n \n if (paymentData.totalCurrencyCost) {\n \n // The price array that we need to fill\n const prices = getPriceArray(paymentData.totalCurrencyCost, recipientCurrencies);\n \n // This is the target price amount we need to hit\n let priceLeft = paymentData.totalCurrencyCost;\n \n // Starting from the smallest currency increment in the price\n for (let i = prices.length - 1; i >= 0; i--) {\n \n const price = prices[i];\n \n const buyerPrice = {\n ...price, buyerQuantity: buyerInfiniteCurrencies ? Infinity : price.quantity, quantity: 0, isCurrency: true\n }\n \n if (price.type === \"item\") {\n buyerPrice.item = price.data.item;\n }\n \n // If we have met the price target (or exceeded it, eg, we need change), populate empty entry\n if (priceLeft <= 0 || !price.cost) {\n paymentData.finalPrices.push(buyerPrice);\n continue;\n }\n \n // If the buyer does not have enough to cover the cost, put what we can into it, otherwise all of it\n buyerPrice.quantity = buyerPrice.buyerQuantity < price.cost ? buyerPrice.buyerQuantity : price.cost;\n \n // If it's the primary currency\n if (price.primary) {\n // And the buyer has enough of the primary currency to cover the rest of the price, use that\n const totalCurrencyValue = Helpers.roundToDecimals(buyerPrice.buyerQuantity * price.exchangeRate, decimals);\n if (totalCurrencyValue > priceLeft) {\n buyerPrice.quantity = Math.ceil(priceLeft);\n }\n }\n \n paymentData.finalPrices.push(buyerPrice);\n \n // Then adjust the remaining price - if this goes below zero, we will need change back\n priceLeft = Helpers.roundToDecimals(priceLeft - (buyerPrice.quantity * price.exchangeRate), decimals);\n \n }\n \n // If there's STILL some remaining price (eg, we haven't been able to scrounge up enough currency to pay for it)\n // we can start using the larger currencies, such as platinum in D&D 5e\n while (priceLeft > 0) {\n \n // We then need to loop through each price, and check if we have any more left over\n for (const buyerPrice of paymentData.finalPrices) {\n \n // If we don't, look for the next one\n let buyerCurrencyQuantity = buyerPrice.buyerQuantity - buyerPrice.quantity;\n if (!buyerCurrencyQuantity) continue;\n \n // Otherwise, add enough to cover the remaining cost\n const newQuantity = Math.ceil(Math.min(buyerCurrencyQuantity, priceLeft / buyerPrice.exchangeRate));\n buyerPrice.quantity += newQuantity;\n priceLeft = Helpers.roundToDecimals(priceLeft - (newQuantity * buyerPrice.exchangeRate), decimals);\n \n if (priceLeft <= 0) break;\n \n }\n \n if (priceLeft > 0) {\n paymentData.finalPrices = paymentData.finalPrices.sort((a, b) => b.exchangeRate - a.exchangeRate);\n } else {\n break;\n }\n }\n \n paymentData.finalPrices = paymentData.finalPrices.sort((a, b) => b.exchangeRate - a.exchangeRate);\n \n // Since the change will be negative, we'll need to flip it, since this is what we'll get back\n let change = Math.abs(priceLeft);\n for (const currency of currencies) {\n \n if (!change) break;\n \n // Get the remaining price, and normalize it to this currency\n let numCurrency = Math.floor(Helpers.roundToDecimals(change / currency.exchangeRate, decimals));\n change = Helpers.roundToDecimals(change - (numCurrency * currency.exchangeRate), decimals);\n \n // If there's some currencies to be gotten back\n if (numCurrency) {\n // We check if we've paid with this currency\n const payment = paymentData.finalPrices.find(payment => {\n return payment.id === currency.id || (payment.name === currency.name && payment.img === currency.img && payment.type === currency.type);\n });\n if (!payment) continue;\n \n // If we have paid with this currency, and we're getting some back, we can do one of two things:\n if ((payment.quantity - numCurrency) >= 0) {\n // Either just subtract it from the total paid if some of our payment will still remain\n // IE, the change we got back didn't cancel out the payment\n payment.quantity -= numCurrency;\n } else {\n // Or if it does cancel out our payment, we add that to the change we'll get back and remove the payment entirely\n paymentData.buyerChange.push({\n ...currency, isCurrency: true, quantity: numCurrency - payment.quantity\n });\n payment.quantity = 0;\n }\n }\n }\n \n // Copy the final currencies that the seller will get\n paymentData.sellerReceive = paymentData.finalPrices.map(price => {\n return { ...price };\n });\n \n // But, we'll need to make sure they have enough change to _give_ to the buyer\n // We collate the total amount of change needed\n let changeNeeded = paymentData.buyerChange.reduce((acc, change) => {\n const currency = currencies.find(currency => {\n return change.id === currency.id || (change.name === currency.name && change.img === currency.img && change.type === currency.type);\n });\n return acc + currency.quantity >= change.quantity ? 0 : (change.quantity - currency.quantity) * change.exchangeRate;\n }, 0);\n \n // If the seller needs give the buyer some change, we'll modify the payment they'll get to cover for it\n if (changeNeeded) {\n \n // If the seller is being given enough of the primary currency to cover for the cost, we use that\n const primaryCurrency = paymentData.sellerReceive.find(price => price.primary && (price.quantity * price.exchangeRate) > changeNeeded);\n if (primaryCurrency) {\n primaryCurrency.quantity--;\n changeNeeded -= 1 * primaryCurrency.exchangeRate;\n } else {\n // Otherwise, we'll use the biggest currency we can find to cover for it\n const biggestCurrency = paymentData.sellerReceive.find(price => price.quantity && (price.quantity * price.exchangeRate) > changeNeeded);\n biggestCurrency.quantity--;\n changeNeeded -= 1 * biggestCurrency.exchangeRate;\n }\n \n changeNeeded = Math.abs(changeNeeded);\n \n // Then loop through each currency and add enough currency so that the total adds up\n for (const currency of paymentData.sellerReceive) {\n if (!changeNeeded) break;\n let numCurrency = Math.floor(Helpers.roundToDecimals(changeNeeded / currency.exchangeRate, decimals));\n changeNeeded = Helpers.roundToDecimals(changeNeeded - (numCurrency * currency.exchangeRate), decimals);\n currency.quantity += numCurrency;\n }\n }\n }\n \n paymentData.finalPrices = paymentData.finalPrices.concat(paymentData.otherPrices);\n paymentData.sellerReceive = paymentData.sellerReceive.concat(paymentData.otherPrices);\n \n paymentData.basePriceString = paymentData.finalPrices\n .filter(price => price.cost)\n .map(price => {\n return price.abbreviation.replace(\"{#}\", price.cost)\n }).join(\" \");\n \n delete paymentData.otherPrices;\n \n return paymentData;\n \n}","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","import { group_outros, transition_out, check_outros } from 'svelte/internal';\n\n/**\n * Provides a solid string hashing algorithm.\n *\n * Sourced from: https://stackoverflow.com/a/52171480\n *\n * @param {string} str - String to hash.\n *\n * @param {number} seed - A seed value altering the hash.\n *\n * @returns {number} Hash code.\n */\nfunction hashCode(str, seed = 0)\n{\n if (typeof str !== 'string') { return 0; }\n\n let h1 = 0xdeadbeef ^ seed, h2 = 0x41c6ce57 ^ seed;\n\n for (let ch, i = 0; i < str.length; i++)\n {\n ch = str.charCodeAt(i);\n h1 = Math.imul(h1 ^ ch, 2654435761);\n h2 = Math.imul(h2 ^ ch, 1597334677);\n }\n\n h1 = Math.imul(h1 ^ (h1 >>> 16), 2246822507) ^ Math.imul(h2 ^ (h2 >>> 13), 3266489909);\n h2 = Math.imul(h2 ^ (h2 >>> 16), 2246822507) ^ Math.imul(h1 ^ (h1 >>> 13), 3266489909);\n\n return 4294967296 * (2097151 & h2) + (h1 >>> 0);\n}\n\nconst s_UUIDV4_REGEX = /^[0-9A-F]{8}-[0-9A-F]{4}-4[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i;\n\n/**\n * Generates a UUID v4 compliant ID. Please use a complete UUID generation package for guaranteed compliance.\n *\n * This code is an evolution of the following Gist.\n * https://gist.github.com/jed/982883\n *\n * There is a public domain / free copy license attached to it that is not a standard OSS license...\n * https://gist.github.com/jed/982883#file-license-txt\n *\n * @returns {string} UUIDv4\n */\nfunction uuidv4()\n{\n return ([1e7] + -1e3 + -4e3 + -8e3 + -1e11).replace(/[018]/g, (c) =>\n (c ^ (globalThis.crypto || globalThis.msCrypto).getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16));\n}\n\n/**\n * Validates that the given string is formatted as a UUIDv4 string.\n *\n * @param {string} uuid - UUID string to test.\n *\n * @returns {boolean} Is UUIDv4 string.\n */\nuuidv4.isValid = (uuid) => s_UUIDV4_REGEX.test(uuid);\n\n/**\n * Normalizes a string.\n *\n * @param {string} query - A string to normalize for comparisons.\n *\n * @returns {string} Cleaned string.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/normalize\n */\nfunction normalizeString(query)\n{\n return query.trim().normalize('NFD').replace(/[\\x00-\\x1F]/gm, '');\n}\n\n/**\n * Recursive function that finds the closest parent stacking context.\n * See also https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Positioning/Understanding_z_index/The_stacking_context\n *\n * Original author: Kerry Liu / https://github.com/gwwar\n * @see: https://github.com/gwwar/z-context/blob/master/content-script.js\n * @see: https://github.com/gwwar/z-context/blob/master/LICENSE\n *\n * @param {Element} node -\n *\n * @returns {StackingContext} The closest parent stacking context\n */\nfunction getStackingContext(node)\n{\n // the root element (HTML).\n if (!node || node.nodeName === 'HTML')\n {\n return { node: document.documentElement, reason: 'root' };\n }\n\n // handle shadow root elements.\n if (node.nodeName === '#document-fragment')\n {\n return getStackingContext(node.host);\n }\n\n const computedStyle = globalThis.getComputedStyle(node);\n\n // position: fixed or sticky.\n if (computedStyle.position === 'fixed' || computedStyle.position === 'sticky')\n {\n return { node: node, reason: `position: ${computedStyle.position}` };\n }\n\n // positioned (absolutely or relatively) with a z-index value other than \"auto\".\n if (computedStyle.zIndex !== 'auto' && computedStyle.position !== 'static')\n {\n return { node: node, reason: `position: ${computedStyle.position}; z-index: ${computedStyle.zIndex}` };\n }\n\n // elements with an opacity value less than 1.\n if (computedStyle.opacity !== '1')\n {\n return { node: node, reason: `opacity: ${computedStyle.opacity}` };\n }\n\n // elements with a transform value other than \"none\".\n if (computedStyle.transform !== 'none')\n {\n return { node: node, reason: `transform: ${computedStyle.transform}` };\n }\n\n // elements with a mix-blend-mode value other than \"normal\".\n if (computedStyle.mixBlendMode !== 'normal')\n {\n return { node: node, reason: `mixBlendMode: ${computedStyle.mixBlendMode}` };\n }\n\n // elements with a filter value other than \"none\".\n if (computedStyle.filter !== 'none')\n {\n return { node: node, reason: `filter: ${computedStyle.filter}` };\n }\n\n // elements with a perspective value other than \"none\".\n if (computedStyle.perspective !== 'none')\n {\n return { node: node, reason: `perspective: ${computedStyle.perspective}` };\n }\n\n // elements with a clip-path value other than \"none\".\n if (computedStyle.clipPath !== 'none')\n {\n return { node: node, reason: `clip-path: ${computedStyle.clipPath} ` };\n }\n\n // elements with a mask value other than \"none\".\n const mask = computedStyle.mask || computedStyle.webkitMask;\n if (mask !== 'none' && mask !== undefined)\n {\n return { node: node, reason: `mask: ${mask}` };\n }\n\n // elements with a mask-image value other than \"none\".\n const maskImage = computedStyle.maskImage || computedStyle.webkitMaskImage;\n if (maskImage !== 'none' && maskImage !== undefined)\n {\n return { node: node, reason: `mask-image: ${maskImage}` };\n }\n\n // elements with a mask-border value other than \"none\".\n const maskBorder = computedStyle.maskBorder || computedStyle.webkitMaskBorder;\n if (maskBorder !== 'none' && maskBorder !== undefined)\n {\n return { node: node, reason: `mask-border: ${maskBorder}` };\n }\n\n // elements with isolation set to \"isolate\".\n if (computedStyle.isolation === 'isolate')\n {\n return { node: node, reason: `isolation: ${computedStyle.isolation}` };\n }\n\n // transform or opacity in will-change even if you don't specify values for these attributes directly.\n if (computedStyle.willChange === 'transform' || computedStyle.willChange === 'opacity')\n {\n return { node: node, reason: `willChange: ${computedStyle.willChange}` };\n }\n\n // elements with -webkit-overflow-scrolling set to \"touch\".\n if (computedStyle.webkitOverflowScrolling === 'touch')\n {\n return { node: node, reason: '-webkit-overflow-scrolling: touch' };\n }\n\n // an item with a z-index value other than \"auto\".\n if (computedStyle.zIndex !== 'auto')\n {\n const parentStyle = globalThis.getComputedStyle(node.parentNode);\n // with a flex|inline-flex parent.\n if (parentStyle.display === 'flex' || parentStyle.display === 'inline-flex')\n {\n return {\n node: node,\n reason: `flex-item; z-index: ${computedStyle.zIndex}`,\n };\n // with a grid parent.\n }\n else if (parentStyle.grid !== 'none / none / none / row / auto / auto')\n {\n return {\n node: node,\n reason: `child of grid container; z-index: ${computedStyle.zIndex}`,\n };\n }\n }\n\n // contain with a value of layout, or paint, or a composite value that includes either of them\n const contain = computedStyle.contain;\n if (['layout', 'paint', 'strict', 'content'].indexOf(contain) > -1 ||\n contain.indexOf('paint') > -1 ||\n contain.indexOf('layout') > -1\n )\n {\n return {\n node: node,\n reason: `contain: ${contain}`,\n };\n }\n\n return getStackingContext(node.parentNode);\n}\n\n/**\n * @typedef {Object} StackingContext\n *\n * @property {Element} node A DOM Element\n * @property {string} reason Reason for why a stacking context was created\n */\n\nconst s_REGEX = /(\\d+)\\s*px/;\n\n/**\n * Parses a pixel string / computed styles. Ex. `100px` returns `100`.\n *\n * @param {string} value - Value to parse.\n *\n * @returns {number|undefined} The integer component of a pixel string.\n */\nfunction styleParsePixels(value)\n{\n if (typeof value !== 'string') { return void 0; }\n\n const isPixels = s_REGEX.test(value);\n const number = parseInt(value);\n\n return isPixels && Number.isFinite(number) ? number : void 0;\n}\n\n/**\n * Defines the application shell contract. If Svelte components export getter / setters for the following properties\n * then that component is considered an application shell.\n *\n * @type {string[]}\n */\nconst applicationShellContract = ['elementRoot'];\n\nObject.freeze(applicationShellContract);\n\n/**\n * Provides a method to determine if the passed in object / Svelte component follows the application shell contract.\n * This involves ensuring that the accessors defined in `applicationShellContract`.\n *\n * Note: A caveat is that when using Vite in a developer build components are wrapped in a proxy / ProxyComponent that\n * defines instance accessors versus on the prototype, so the check below ensures that all accessors in the contract are\n * either available on the prototype or directly on the instance.\n *\n * @param {*} component - Object / component to test.\n *\n * @returns {boolean} Whether the component is a ApplicationShell or TJSApplicationShell.\n */\nfunction isApplicationShell(component)\n{\n if (component === null || component === void 0) { return false; }\n\n let compHasContract = true;\n let protoHasContract = true;\n\n // Check for accessors on the instance.\n for (const accessor of applicationShellContract)\n {\n const descriptor = Object.getOwnPropertyDescriptor(component, accessor);\n if (descriptor === void 0 || descriptor.get === void 0 || descriptor.set === void 0) { compHasContract = false; }\n }\n\n // Get the prototype which is the parent SvelteComponent that has any getter / setters.\n const prototype = Object.getPrototypeOf(component);\n\n // Verify the application shell contract. If the accessors (getters / setters) are defined for\n // `applicationShellContract`.\n for (const accessor of applicationShellContract)\n {\n const descriptor = Object.getOwnPropertyDescriptor(prototype, accessor);\n if (descriptor === void 0 || descriptor.get === void 0 || descriptor.set === void 0) { protoHasContract = false; }\n }\n\n return compHasContract || protoHasContract;\n}\n\n/**\n * Provides basic duck typing to determine if the provided object is a HMR ProxyComponent instance or class.\n *\n * @param {*} comp - Data to check as a HMR proxy component.\n *\n * @returns {boolean} Whether basic duck typing succeeds.\n */\nfunction isHMRProxy(comp)\n{\n const instanceName = comp?.constructor?.name;\n if (typeof instanceName === 'string' && (instanceName.startsWith('Proxy<') || instanceName === 'ProxyComponent'))\n {\n return true;\n }\n\n const prototypeName = comp?.prototype?.constructor?.name;\n return typeof prototypeName === 'string' && (prototypeName.startsWith('Proxy<') ||\n prototypeName === 'ProxyComponent');\n}\n\n/**\n * Provides basic duck typing to determine if the provided function is a constructor function for a Svelte component.\n *\n * @param {*} comp - Data to check as a Svelte component.\n *\n * @returns {boolean} Whether basic duck typing succeeds.\n */\nfunction isSvelteComponent(comp)\n{\n if (comp === null || comp === void 0 || typeof comp !== 'function') { return false; }\n\n // When using Vite in a developer build the SvelteComponent is wrapped in a ProxyComponent class.\n // This class doesn't define methods on the prototype, so we must check if the constructor name\n // starts with `Proxy<` as it provides the wrapped component as `Proxy<_wrapped component name_>`.\n const prototypeName = comp?.prototype?.constructor?.name;\n if (typeof prototypeName === 'string' && (prototypeName.startsWith('Proxy<') || prototypeName === 'ProxyComponent'))\n {\n return true;\n }\n\n return typeof window !== void 0 ?\n typeof comp.prototype.$destroy === 'function' && typeof comp.prototype.$on === 'function' : // client-side\n typeof comp.render === 'function'; // server-side\n}\n\n/**\n * Runs outro transition then destroys Svelte component.\n *\n * Workaround for https://github.com/sveltejs/svelte/issues/4056\n *\n * @param {*} instance - A Svelte component.\n */\nasync function outroAndDestroy(instance)\n{\n return new Promise((resolve) =>\n {\n if (instance.$$.fragment && instance.$$.fragment.o)\n {\n group_outros();\n transition_out(instance.$$.fragment, 0, 0, () =>\n {\n instance.$destroy();\n resolve();\n });\n check_outros();\n }\n else\n {\n instance.$destroy();\n resolve();\n }\n });\n}\n\n/**\n * Parses a TyphonJS Svelte config object ensuring that classes specified are Svelte components and props are set\n * correctly.\n *\n * @param {object} config - Svelte config object.\n *\n * @param {*} [thisArg] - `This` reference to set for invoking any props function.\n *\n * @returns {object} The processed Svelte config object.\n */\nfunction parseSvelteConfig(config, thisArg = void 0)\n{\n if (typeof config !== 'object')\n {\n throw new TypeError(`parseSvelteConfig - 'config' is not an object:\\n${JSON.stringify(config)}.`);\n }\n\n if (!isSvelteComponent(config.class))\n {\n throw new TypeError(\n `parseSvelteConfig - 'class' is not a Svelte component constructor for config:\\n${JSON.stringify(config)}.`);\n }\n\n if (config.hydrate !== void 0 && typeof config.hydrate !== 'boolean')\n {\n throw new TypeError(\n `parseSvelteConfig - 'hydrate' is not a boolean for config:\\n${JSON.stringify(config)}.`);\n }\n\n if (config.intro !== void 0 && typeof config.intro !== 'boolean')\n {\n throw new TypeError(\n `parseSvelteConfig - 'intro' is not a boolean for config:\\n${JSON.stringify(config)}.`);\n }\n\n if (config.target !== void 0 && typeof config.target !== 'string' && !(config.target instanceof HTMLElement) &&\n !(config.target instanceof ShadowRoot) && !(config.target instanceof DocumentFragment))\n {\n throw new TypeError(\n `parseSvelteConfig - 'target' is not a string, HTMLElement, ShadowRoot, or DocumentFragment for config:\\n${\n JSON.stringify(config)}.`);\n }\n\n if (config.anchor !== void 0 && typeof config.anchor !== 'string' && !(config.anchor instanceof HTMLElement) &&\n !(config.anchor instanceof ShadowRoot) && !(config.anchor instanceof DocumentFragment))\n {\n throw new TypeError(\n `parseSvelteConfig - 'anchor' is not a string, HTMLElement, ShadowRoot, or DocumentFragment for config:\\n${\n JSON.stringify(config)}.`);\n }\n\n if (config.context !== void 0 && typeof config.context !== 'function' && !(config.context instanceof Map) &&\n typeof config.context !== 'object')\n {\n throw new TypeError(\n `parseSvelteConfig - 'context' is not a Map, function or object for config:\\n${JSON.stringify(config)}.`);\n }\n\n // Validate extra TyphonJS options --------------------------------------------------------------------------------\n\n // `selectorTarget` optionally stores a target element found in main element.\n if (config.selectorTarget !== void 0 && typeof config.selectorTarget !== 'string')\n {\n throw new TypeError(\n `parseSvelteConfig - 'selectorTarget' is not a string for config:\\n${JSON.stringify(config)}.`);\n }\n\n // `options` stores `injectApp`, `injectEventbus`, and `selectorElement`.\n if (config.options !== void 0 && typeof config.options !== 'object')\n {\n throw new TypeError(\n `parseSvelteConfig - 'options' is not an object for config:\\n${JSON.stringify(config)}.`);\n }\n\n // Validate TyphonJS standard options.\n if (config.options !== void 0)\n {\n if (config.options.injectApp !== void 0 && typeof config.options.injectApp !== 'boolean')\n {\n throw new TypeError(\n `parseSvelteConfig - 'options.injectApp' is not a boolean for config:\\n${JSON.stringify(config)}.`);\n }\n\n if (config.options.injectEventbus !== void 0 && typeof config.options.injectEventbus !== 'boolean')\n {\n throw new TypeError(\n `parseSvelteConfig - 'options.injectEventbus' is not a boolean for config:\\n${JSON.stringify(config)}.`);\n }\n\n // `selectorElement` optionally stores a main element selector to be found in a HTMLElement target.\n if (config.options.selectorElement !== void 0 && typeof config.options.selectorElement !== 'string')\n {\n throw new TypeError(\n `parseSvelteConfig - 'selectorElement' is not a string for config:\\n${JSON.stringify(config)}.`);\n }\n }\n\n const svelteConfig = { ...config };\n\n // Delete extra Svelte options.\n delete svelteConfig.options;\n\n let externalContext = {};\n\n // If a context callback function is provided then invoke it with `this` being the Foundry app.\n // If an object is returned it adds the entries to external context.\n if (typeof svelteConfig.context === 'function')\n {\n const contextFunc = svelteConfig.context;\n delete svelteConfig.context;\n\n const result = contextFunc.call(thisArg);\n if (typeof result === 'object')\n {\n externalContext = { ...result };\n }\n else\n {\n throw new Error(`parseSvelteConfig - 'context' is a function that did not return an object for config:\\n${\n JSON.stringify(config)}`);\n }\n }\n else if (svelteConfig.context instanceof Map)\n {\n externalContext = Object.fromEntries(svelteConfig.context);\n delete svelteConfig.context;\n }\n else if (typeof svelteConfig.context === 'object')\n {\n externalContext = svelteConfig.context;\n delete svelteConfig.context;\n }\n\n // If a props is a function then invoke it with `this` being the Foundry app.\n // If an object is returned set it as the props.\n svelteConfig.props = s_PROCESS_PROPS(svelteConfig.props, thisArg, config);\n\n // Process children components attaching to external context.\n if (Array.isArray(svelteConfig.children))\n {\n const children = [];\n\n for (let cntr = 0; cntr < svelteConfig.children.length; cntr++)\n {\n const child = svelteConfig.children[cntr];\n\n if (!isSvelteComponent(child.class))\n {\n throw new Error(`parseSvelteConfig - 'class' is not a Svelte component for child[${cntr}] for config:\\n${\n JSON.stringify(config)}`);\n }\n\n child.props = s_PROCESS_PROPS(child.props, thisArg, config);\n\n children.push(child);\n }\n\n if (children.length > 0)\n {\n externalContext.children = children;\n }\n\n delete svelteConfig.children;\n }\n else if (typeof svelteConfig.children === 'object')\n {\n if (!isSvelteComponent(svelteConfig.children.class))\n {\n throw new Error(`parseSvelteConfig - 'class' is not a Svelte component for children object for config:\\n${\n JSON.stringify(config)}`);\n }\n\n svelteConfig.children.props = s_PROCESS_PROPS(svelteConfig.children.props, thisArg, config);\n\n externalContext.children = [svelteConfig.children];\n delete svelteConfig.children;\n }\n\n if (!(svelteConfig.context instanceof Map))\n {\n svelteConfig.context = new Map();\n }\n\n svelteConfig.context.set('external', externalContext);\n\n return svelteConfig;\n}\n\n/**\n * Processes Svelte props. Potentially props can be a function to invoke with `thisArg`.\n *\n * @param {object|Function} props - Svelte props.\n *\n * @param {*} thisArg - `This` reference to set for invoking any props function.\n *\n * @param {object} config - Svelte config\n *\n * @returns {object|void} Svelte props.\n */\nfunction s_PROCESS_PROPS(props, thisArg, config)\n{\n // If a props is a function then invoke it with `this` being the Foundry app.\n // If an object is returned set it as the props.\n if (typeof props === 'function')\n {\n const result = props.call(thisArg);\n if (typeof result === 'object')\n {\n return result;\n }\n else\n {\n throw new Error(`parseSvelteConfig - 'props' is a function that did not return an object for config:\\n${\n JSON.stringify(config)}`);\n }\n }\n else if (typeof props === 'object')\n {\n return props;\n }\n else if (props !== void 0)\n {\n throw new Error(\n `parseSvelteConfig - 'props' is not a function or an object for config:\\n${JSON.stringify(config)}`);\n }\n\n return {};\n}\n\n/**\n * Wraps a callback in a debounced timeout.\n *\n * Delay execution of the callback function until the function has not been called for the given delay in milliseconds.\n *\n * @param {Function} callback - A function to execute once the debounced threshold has been passed.\n *\n * @param {number} delay - An amount of time in milliseconds to delay.\n *\n * @return {Function} A wrapped function that can be called to debounce execution.\n */\nfunction debounce(callback, delay)\n{\n let timeoutId;\n\n return function(...args)\n {\n clearTimeout(timeoutId);\n timeoutId = setTimeout(() => { callback.apply(this, args); }, delay);\n }\n}\n\n/**\n * Provides a method to determine if the passed in Svelte component has a getter accessor.\n *\n * @param {*} object - An object.\n *\n * @param {string} accessor - Accessor to test.\n *\n * @returns {boolean} Whether the component has the getter for accessor.\n */\nfunction hasGetter(object, accessor)\n{\n if (object === null || object === void 0) { return false; }\n\n // Check for instance accessor.\n const iDescriptor = Object.getOwnPropertyDescriptor(object, accessor);\n if (iDescriptor !== void 0 && iDescriptor.get !== void 0) { return true; }\n\n // Walk parent prototype chain. Check for descriptor at each prototype level.\n for (let o = Object.getPrototypeOf(object); o; o = Object.getPrototypeOf(o))\n {\n const descriptor = Object.getOwnPropertyDescriptor(o, accessor);\n if (descriptor !== void 0 && descriptor.get !== void 0) { return true; }\n }\n\n return false;\n}\n\n/**\n * Provides a method to determine if the passed in Svelte component has a getter & setter accessor.\n *\n * @param {*} object - An object.\n *\n * @param {string} accessor - Accessor to test.\n *\n * @returns {boolean} Whether the component has the getter and setter for accessor.\n */\nfunction hasAccessor(object, accessor)\n{\n if (object === null || object === void 0) { return false; }\n\n // Check for instance accessor.\n const iDescriptor = Object.getOwnPropertyDescriptor(object, accessor);\n if (iDescriptor !== void 0 && iDescriptor.get !== void 0 && iDescriptor.set !== void 0) { return true; }\n\n // Walk parent prototype chain. Check for descriptor at each prototype level.\n for (let o = Object.getPrototypeOf(object); o; o = Object.getPrototypeOf(o))\n {\n const descriptor = Object.getOwnPropertyDescriptor(o, accessor);\n if (descriptor !== void 0 && descriptor.get !== void 0 && descriptor.set !== void 0) { return true; }\n }\n\n return false;\n}\n\n/**\n * Provides a method to determine if the passed in Svelte component has a setter accessor.\n *\n * @param {*} object - An object.\n *\n * @param {string} accessor - Accessor to test.\n *\n * @returns {boolean} Whether the component has the setter for accessor.\n */\nfunction hasSetter(object, accessor)\n{\n if (object === null || object === void 0) { return false; }\n\n // Check for instance accessor.\n const iDescriptor = Object.getOwnPropertyDescriptor(object, accessor);\n if (iDescriptor !== void 0 && iDescriptor.set !== void 0) { return true; }\n\n // Walk parent prototype chain. Check for descriptor at each prototype level.\n for (let o = Object.getPrototypeOf(object); o; o = Object.getPrototypeOf(o))\n {\n const descriptor = Object.getOwnPropertyDescriptor(o, accessor);\n if (descriptor !== void 0 && descriptor.set !== void 0) { return true; }\n }\n\n return false;\n}\n\n/**\n * Returns whether the target is or has the given prototype walking up the prototype chain.\n *\n * @param {*} target - Any target to test.\n *\n * @param {Function} Prototype - Prototype function / class constructor to find.\n *\n * @returns {boolean} Target matches prototype.\n */\nfunction hasPrototype(target, Prototype)\n{\n /* c8 ignore next */\n if (typeof target !== 'function') { return false; }\n\n if (target === Prototype) { return true; }\n\n // Walk parent prototype chain. Check for descriptor at each prototype level.\n for (let proto = Object.getPrototypeOf(target); proto; proto = Object.getPrototypeOf(proto))\n {\n if (proto === Prototype) { return true; }\n }\n\n return false;\n}\n\nfunction set(obj, key, val) {\n\tif (typeof val.value === 'object') val.value = klona(val.value);\n\tif (!val.enumerable || val.get || val.set || !val.configurable || !val.writable || key === '__proto__') {\n\t\tObject.defineProperty(obj, key, val);\n\t} else obj[key] = val.value;\n}\n\nfunction klona(x) {\n\tif (typeof x !== 'object') return x;\n\n\tvar i=0, k, list, tmp, str=Object.prototype.toString.call(x);\n\n\tif (str === '[object Object]') {\n\t\ttmp = Object.create(x.__proto__ || null);\n\t} else if (str === '[object Array]') {\n\t\ttmp = Array(x.length);\n\t} else if (str === '[object Set]') {\n\t\ttmp = new Set;\n\t\tx.forEach(function (val) {\n\t\t\ttmp.add(klona(val));\n\t\t});\n\t} else if (str === '[object Map]') {\n\t\ttmp = new Map;\n\t\tx.forEach(function (val, key) {\n\t\t\ttmp.set(klona(key), klona(val));\n\t\t});\n\t} else if (str === '[object Date]') {\n\t\ttmp = new Date(+x);\n\t} else if (str === '[object RegExp]') {\n\t\ttmp = new RegExp(x.source, x.flags);\n\t} else if (str === '[object DataView]') {\n\t\ttmp = new x.constructor( klona(x.buffer) );\n\t} else if (str === '[object ArrayBuffer]') {\n\t\ttmp = x.slice(0);\n\t} else if (str.slice(-6) === 'Array]') {\n\t\t// ArrayBuffer.isView(x)\n\t\t// ~> `new` bcuz `Buffer.slice` => ref\n\t\ttmp = new x.constructor(x);\n\t}\n\n\tif (tmp) {\n\t\tfor (list=Object.getOwnPropertySymbols(x); i < list.length; i++) {\n\t\t\tset(tmp, list[i], Object.getOwnPropertyDescriptor(x, list[i]));\n\t\t}\n\n\t\tfor (i=0, list=Object.getOwnPropertyNames(x); i < list.length; i++) {\n\t\t\tif (Object.hasOwnProperty.call(tmp, k=list[i]) && tmp[k] === x[k]) continue;\n\t\t\tset(tmp, k, Object.getOwnPropertyDescriptor(x, k));\n\t\t}\n\t}\n\n\treturn tmp || x;\n}\n\n/**\n * Provides common object manipulation utilities including depth traversal, obtaining accessors, safely setting values /\n * equality tests, and validation.\n */\n\nconst s_TAG_OBJECT = '[object Object]';\n\n/**\n * Recursively deep merges all source objects into the target object in place. Like `Object.assign` if you provide `{}`\n * as the target a copy is produced. If the target and source property are object literals they are merged.\n * Deleting keys is supported by specifying a property starting with `-=`.\n *\n * @param {object} target - Target object.\n *\n * @param {...object} sourceObj - One or more source objects.\n *\n * @returns {object} Target object.\n */\nfunction deepMerge(target = {}, ...sourceObj)\n{\n if (Object.prototype.toString.call(target) !== s_TAG_OBJECT)\n {\n throw new TypeError(`deepMerge error: 'target' is not an 'object'.`);\n }\n\n for (let cntr = 0; cntr < sourceObj.length; cntr++)\n {\n if (Object.prototype.toString.call(sourceObj[cntr]) !== s_TAG_OBJECT)\n {\n throw new TypeError(`deepMerge error: 'sourceObj[${cntr}]' is not an 'object'.`);\n }\n }\n\n return _deepMerge(target, ...sourceObj);\n}\n\n/**\n * Tests for whether an object is iterable.\n *\n * @param {*} value - Any value.\n *\n * @returns {boolean} Whether object is iterable.\n */\nfunction isIterable(value)\n{\n if (value === null || value === void 0 || typeof value !== 'object') { return false; }\n\n return typeof value[Symbol.iterator] === 'function';\n}\n\n/**\n * Tests for whether an object is async iterable.\n *\n * @param {*} value - Any value.\n *\n * @returns {boolean} Whether value is async iterable.\n */\nfunction isIterableAsync(value)\n{\n if (value === null || value === void 0 || typeof value !== 'object') { return false; }\n\n return typeof value[Symbol.asyncIterator] === 'function';\n}\n\n/**\n * Tests for whether object is not null and a typeof object.\n *\n * @param {*} value - Any value.\n *\n * @returns {boolean} Is it an object.\n */\nfunction isObject(value)\n{\n return value !== null && typeof value === 'object';\n}\n\n/**\n * Tests for whether the given value is a plain object.\n *\n * An object is plain if it is created by either: {}, new Object() or Object.create(null).\n *\n * @param {*} value - Any value\n *\n * @returns {boolean} Is it a plain object.\n */\nfunction isPlainObject(value)\n{\n if (Object.prototype.toString.call(value) !== s_TAG_OBJECT) { return false; }\n\n const prototype = Object.getPrototypeOf(value);\n return prototype === null || prototype === Object.prototype;\n}\n\n/**\n * Provides a way to safely access an objects data / entries given an accessor string which describes the\n * entries to walk. To access deeper entries into the object format the accessor string with `.` between entries\n * to walk.\n *\n * @param {object} data - An object to access entry data.\n *\n * @param {string} accessor - A string describing the entries to access.\n *\n * @param {*} defaultValue - (Optional) A default value to return if an entry for accessor is not found.\n *\n * @returns {object} The data object.\n */\nfunction safeAccess(data, accessor, defaultValue = void 0)\n{\n if (typeof data !== 'object') { return defaultValue; }\n if (typeof accessor !== 'string') { return defaultValue; }\n\n const access = accessor.split('.');\n\n // Walk through the given object by the accessor indexes.\n for (let cntr = 0; cntr < access.length; cntr++)\n {\n // If the next level of object access is undefined or null then return the empty string.\n if (typeof data[access[cntr]] === 'undefined' || data[access[cntr]] === null) { return defaultValue; }\n\n data = data[access[cntr]];\n }\n\n return data;\n}\n\n/**\n * Provides a way to safely set an objects data / entries given an accessor string which describes the\n * entries to walk. To access deeper entries into the object format the accessor string with `.` between entries\n * to walk.\n *\n * @param {object} data - An object to access entry data.\n *\n * @param {string} accessor - A string describing the entries to access.\n *\n * @param {*} value - A new value to set if an entry for accessor is found.\n *\n * @param {string} [operation='set'] - Operation to perform including: 'add', 'div', 'mult', 'set',\n * 'set-undefined', 'sub'.\n *\n * @param {boolean} [createMissing=true] - If true missing accessor entries will be created as objects\n * automatically.\n *\n * @returns {boolean} True if successful.\n */\nfunction safeSet(data, accessor, value, operation = 'set', createMissing = true)\n{\n if (typeof data !== 'object') { throw new TypeError(`safeSet Error: 'data' is not an 'object'.`); }\n if (typeof accessor !== 'string') { throw new TypeError(`safeSet Error: 'accessor' is not a 'string'.`); }\n\n const access = accessor.split('.');\n\n // Walk through the given object by the accessor indexes.\n for (let cntr = 0; cntr < access.length; cntr++)\n {\n // If data is an array perform validation that the accessor is a positive integer otherwise quit.\n if (Array.isArray(data))\n {\n const number = (+access[cntr]);\n\n if (!Number.isInteger(number) || number < 0) { return false; }\n }\n\n if (cntr === access.length - 1)\n {\n switch (operation)\n {\n case 'add':\n data[access[cntr]] += value;\n break;\n\n case 'div':\n data[access[cntr]] /= value;\n break;\n\n case 'mult':\n data[access[cntr]] *= value;\n break;\n\n case 'set':\n data[access[cntr]] = value;\n break;\n\n case 'set-undefined':\n if (typeof data[access[cntr]] === 'undefined') { data[access[cntr]] = value; }\n break;\n\n case 'sub':\n data[access[cntr]] -= value;\n break;\n }\n }\n else\n {\n // If createMissing is true and the next level of object access is undefined then create a new object entry.\n if (createMissing && typeof data[access[cntr]] === 'undefined') { data[access[cntr]] = {}; }\n\n // Abort if the next level is null or not an object and containing a value.\n if (data[access[cntr]] === null || typeof data[access[cntr]] !== 'object') { return false; }\n\n data = data[access[cntr]];\n }\n }\n\n return true;\n}\n\n/**\n * Internal implementation for `deepMerge`.\n *\n * @param {object} target - Target object.\n *\n * @param {...object} sourceObj - One or more source objects.\n *\n * @returns {object} Target object.\n */\nfunction _deepMerge(target = {}, ...sourceObj)\n{\n // Iterate and merge all source objects into target.\n for (let cntr = 0; cntr < sourceObj.length; cntr++)\n {\n const obj = sourceObj[cntr];\n\n for (const prop in obj)\n {\n if (Object.prototype.hasOwnProperty.call(obj, prop))\n {\n // Handle the special property starting with '-=' to delete keys.\n if (prop.startsWith('-='))\n {\n delete target[prop.slice(2)];\n continue;\n }\n\n // If target already has prop and both target[prop] and obj[prop] are object literals then merge them\n // otherwise assign obj[prop] to target[prop].\n target[prop] = Object.prototype.hasOwnProperty.call(target, prop) && target[prop]?.constructor === Object &&\n obj[prop]?.constructor === Object ? _deepMerge({}, target[prop], obj[prop]) : obj[prop];\n }\n }\n }\n\n return target;\n}\n\n/**\n * Attempts to create a Foundry UUID from standard drop data. This may not work for all systems.\n *\n * @param {object} data - Drop transfer data.\n *\n * @param {ParseDataTransferOptions} opts - Optional parameters.\n *\n * @returns {string|undefined} Foundry UUID for drop data.\n */\nfunction getUUIDFromDataTransfer(data, { actor = true, compendium = true, world = true, types = void 0 } = {})\n{\n if (typeof data !== 'object') { return void 0; }\n if (Array.isArray(types) && !types.includes(data.type)) { return void 0; }\n\n let uuid = void 0;\n\n if (typeof data.uuid === 'string') // v10 and above provides a full UUID.\n {\n const isCompendium = data.uuid.startsWith('Compendium');\n\n if (isCompendium && compendium)\n {\n uuid = data.uuid;\n }\n else if (world)\n {\n uuid = data.uuid;\n }\n }\n else // v9 and below parsing.\n {\n if (actor && world && data.actorId && data.type)\n {\n uuid = `Actor.${data.actorId}.${data.type}.${data.data._id}`;\n }\n else if (typeof data.id === 'string') // v9 and below uses `id`\n {\n if (compendium && typeof data.pack === 'string')\n {\n uuid = `Compendium.${data.pack}.${data.id}`;\n }\n else if (world)\n {\n uuid = `${data.type}.${data.id}`;\n }\n }\n }\n\n return uuid;\n}\n\nexport { debounce, deepMerge, getStackingContext, getUUIDFromDataTransfer, hasAccessor, hasGetter, hasPrototype, hasSetter, hashCode, isApplicationShell, isHMRProxy, isIterable, isIterableAsync, isObject, isPlainObject, isSvelteComponent, klona, normalizeString, outroAndDestroy, parseSvelteConfig, safeAccess, safeSet, styleParsePixels, uuidv4 };\n//# sourceMappingURL=index.js.map\n","import { writable as writable$2, derived, get } from 'svelte/store';\nimport { noop, run_all, is_function } from 'svelte/internal';\nimport { uuidv4, isPlainObject, getUUIDFromDataTransfer, isObject, isIterable, hasPrototype } from '@typhonjs-fvtt/runtime/svelte/util';\n\nclass DynReducerUtils {\n /**\n * Checks for array equality between two arrays of numbers.\n *\n * @param a - Array A\n *\n * @param b - Array B\n *\n * @returns Arrays are equal.\n */\n static arrayEquals(a, b) {\n if (a === b) {\n return true;\n }\n if (a === null || b === null) {\n return false;\n }\n /* c8 ignore next */\n if (a.length !== b.length) {\n return false;\n }\n for (let cntr = a.length; --cntr >= 0;) {\n /* c8 ignore next */\n if (a[cntr] !== b[cntr]) {\n return false;\n }\n }\n return true;\n }\n /**\n * Provides a solid string hashing algorithm.\n *\n * Sourced from: https://stackoverflow.com/a/52171480\n *\n * @param str - String to hash.\n *\n * @param seed - A seed value altering the hash.\n *\n * @returns Hash code.\n */\n static hashString(str, seed = 0) {\n let h1 = 0xdeadbeef ^ seed, h2 = 0x41c6ce57 ^ seed;\n for (let ch, i = 0; i < str.length; i++) {\n ch = str.charCodeAt(i);\n h1 = Math.imul(h1 ^ ch, 2654435761);\n h2 = Math.imul(h2 ^ ch, 1597334677);\n }\n h1 = Math.imul(h1 ^ (h1 >>> 16), 2246822507) ^ Math.imul(h2 ^ (h2 >>> 13), 3266489909);\n h2 = Math.imul(h2 ^ (h2 >>> 16), 2246822507) ^ Math.imul(h1 ^ (h1 >>> 13), 3266489909);\n return 4294967296 * (2097151 & h2) + (h1 >>> 0);\n }\n /**\n * Converts an unknown value for hashing purposes in {@link AdapterIndexer.calcHashUpdate}.\n *\n * Currently objects / Map w/ object keys is not supported. Potentially can include `object-hash` to handle this\n * case, but it is not common to use objects as keys in Maps.\n *\n * @param value - An unknown value to convert to a number.\n */\n static hashUnknown(value) {\n if (value === null || value === void 0) {\n return 0;\n }\n let result = 0;\n switch (typeof value) {\n case 'boolean':\n result = value ? 1 : 0;\n break;\n case 'bigint':\n result = Number(BigInt.asIntN(64, value));\n break;\n case 'function':\n result = this.hashString(value.name);\n break;\n case 'number':\n result = Number.isFinite(value) ? value : 0;\n break;\n case 'object':\n // TODO: consider hashing an object IE `object-hash` and convert to number.\n break;\n case 'string':\n result = this.hashString(value);\n break;\n case 'symbol':\n result = this.hashString(Symbol.keyFor(value));\n break;\n }\n return result;\n }\n /**\n * @param target -\n *\n * @param Prototype -\n *\n * @returns target constructor function has Prototype.\n */\n static hasPrototype(target, Prototype) {\n /* c8 ignore next */\n if (typeof target !== 'function') {\n return false;\n }\n if (target === Prototype) {\n return true;\n }\n // Walk parent prototype chain. Check for descriptor at each prototype level.\n for (let proto = Object.getPrototypeOf(target); proto; proto = Object.getPrototypeOf(proto)) {\n if (proto === Prototype) {\n return true;\n }\n }\n return false;\n }\n /**\n * Provides a utility method to determine if the given data is iterable / implements iterator protocol.\n *\n * @param data - Data to verify as iterable.\n *\n * @returns Is data iterable.\n */\n static isIterable(data) {\n return data !== null && data !== void 0 && typeof data === 'object' &&\n typeof data[Symbol.iterator] === 'function';\n }\n}\n\n/**\n * Provides the `derived` API for all dynamic reducers.\n */\nclass AdapterDerived {\n #hostData;\n #DerivedReducerCtor;\n #parentIndex;\n #derived = new Map();\n #destroyed = false;\n /**\n * @param hostData - Hosted data structure.\n *\n * @param parentIndex - Any associated parent index API.\n *\n * @param DerivedReducerCtor - The default derived reducer constructor function.\n */\n constructor(hostData, parentIndex, DerivedReducerCtor) {\n this.#hostData = hostData;\n this.#parentIndex = parentIndex;\n this.#DerivedReducerCtor = DerivedReducerCtor;\n Object.freeze(this);\n }\n /**\n * Creates a new derived reducer.\n *\n * @param options - Options defining the new derived reducer.\n *\n * @returns Newly created derived reducer.\n */\n create(options) {\n if (this.#destroyed) {\n throw Error(`AdapterDerived.create error: this instance has been destroyed.`);\n }\n let name;\n let rest = {};\n let ctor;\n const DerivedReducerCtor = this.#DerivedReducerCtor;\n if (typeof options === 'string') {\n name = options;\n ctor = DerivedReducerCtor;\n }\n else if (typeof options === 'function' && DynReducerUtils.hasPrototype(options, DerivedReducerCtor)) {\n ctor = options;\n }\n else if (typeof options === 'object' && options !== null) {\n ({ name, ctor = DerivedReducerCtor, ...rest } = options);\n }\n else {\n throw new TypeError(`AdapterDerived.create error: 'options' does not conform to allowed parameters.`);\n }\n if (!DynReducerUtils.hasPrototype(ctor, DerivedReducerCtor)) {\n throw new TypeError(`AdapterDerived.create error: 'ctor' is not a '${DerivedReducerCtor?.name}'.`);\n }\n name = name ?? ctor?.name;\n if (typeof name !== 'string') {\n throw new TypeError(`AdapterDerived.create error: 'name' is not a string.`);\n }\n const derivedReducer = new ctor(this.#hostData, this.#parentIndex, rest);\n this.#derived.set(name, derivedReducer);\n return derivedReducer;\n }\n /**\n * Removes all derived reducers and associated subscriptions.\n */\n clear() {\n if (this.#destroyed) {\n return;\n }\n for (const reducer of this.#derived.values()) {\n reducer.destroy();\n }\n this.#derived.clear();\n }\n /**\n * Deletes and destroys a derived reducer by name.\n *\n * @param name - Name of the derived reducer.\n */\n delete(name) {\n if (this.#destroyed) {\n throw Error(`AdapterDerived.delete error: this instance has been destroyed.`);\n }\n const reducer = this.#derived.get(name);\n if (reducer) {\n reducer.destroy();\n }\n return this.#derived.delete(name);\n }\n /**\n * Removes all derived reducers, subscriptions, and cleans up all resources.\n */\n destroy() {\n if (this.#destroyed) {\n return;\n }\n this.clear();\n this.#hostData = [null];\n this.#parentIndex = null;\n this.#destroyed = true;\n }\n /**\n * Returns an existing derived reducer.\n *\n * @param name - Name of derived reducer.\n */\n get(name) {\n if (this.#destroyed) {\n throw Error(`AdapterDerived.get error: this instance has been destroyed.`);\n }\n return this.#derived.get(name);\n }\n /**\n * Updates all managed derived reducer indexes.\n *\n * @param [force] - Force an update to subscribers.\n */\n update(force = false) {\n if (this.#destroyed) {\n return;\n }\n for (const reducer of this.#derived.values()) {\n reducer.index.update(force);\n }\n }\n}\n\n/**\n * Provides the storage and sequencing of managed filters. Each filter added may be a bespoke function or a\n * {@link DataFilter} object containing an `id`, `filter`, and `weight` attributes; `filter` is the only required\n * attribute.\n *\n * The `id` attribute can be anything that creates a unique ID for the filter; recommended strings or numbers. This\n * allows filters to be removed by ID easily.\n *\n * The `weight` attribute is a number between 0 and 1 inclusive that allows filters to be added in a\n * predictable order which is especially handy if they are manipulated at runtime. A lower weighted filter always runs\n * before a higher weighted filter. For speed and efficiency always set the heavier / more inclusive filter with a\n * lower weight; an example of this is a keyword / name that will filter out many entries making any further filtering\n * faster. If no weight is specified the default of '1' is assigned and it is appended to the end of the filters list.\n *\n * This class forms the public API which is accessible from the `.filters` getter in the main reducer implementation.\n * ```\n * const dynArray = new DynArrayReducer([...]);\n * dynArray.filters.add(...);\n * dynArray.filters.clear();\n * dynArray.filters.length;\n * dynArray.filters.remove(...);\n * dynArray.filters.removeBy(...);\n * dynArray.filters.removeById(...);\n * ```\n */\nclass AdapterFilters {\n #filtersData;\n #indexUpdate;\n #mapUnsubscribe = new Map();\n /**\n * @param indexUpdate - update function for the indexer.\n *\n * @param filtersAdapter - Stores the filter function data.\n */\n constructor(indexUpdate, filtersAdapter) {\n this.#indexUpdate = indexUpdate;\n this.#filtersData = filtersAdapter;\n Object.freeze(this);\n }\n /**\n * @returns Returns the length of the filter data.\n */\n get length() { return this.#filtersData.filters.length; }\n /**\n * Provides an iterator for filters.\n *\n * @returns Generator / iterator of filters.\n * @yields {DataFilter}\n */\n *[Symbol.iterator]() {\n if (this.#filtersData.filters.length === 0) {\n return;\n }\n for (const entry of this.#filtersData.filters) {\n yield { ...entry };\n }\n }\n /**\n * @param filters -\n */\n add(...filters) {\n /**\n * Tracks the number of filters added that have subscriber functionality.\n */\n let subscribeCount = 0;\n for (const filter of filters) {\n const filterType = typeof filter;\n if (filterType !== 'function' && (filterType !== 'object' || filter === null)) {\n throw new TypeError(`AdapterFilters error: 'filter' is not a function or object.`);\n }\n let data = void 0;\n let subscribeFn = void 0;\n if (filterType === 'function') {\n data = {\n id: void 0,\n filter,\n weight: 1\n };\n subscribeFn = filter.subscribe;\n }\n else if (filterType === 'object') {\n if ('filter' in filter) {\n if (typeof filter.filter !== 'function') {\n throw new TypeError(`AdapterFilters error: 'filter' attribute is not a function.`);\n }\n if (filter.weight !== void 0 && typeof filter.weight !== 'number' ||\n (filter.weight < 0 || filter.weight > 1)) {\n throw new TypeError(`AdapterFilters error: 'weight' attribute is not a number between '0 - 1' inclusive.`);\n }\n data = {\n id: filter.id !== void 0 ? filter.id : void 0,\n filter: filter.filter,\n weight: filter.weight || 1\n };\n subscribeFn = filter.filter.subscribe ?? filter.subscribe;\n }\n else {\n throw new TypeError(`AdapterFilters error: 'filter' attribute is not a function.`);\n }\n }\n // Find the index to insert where data.weight is less than existing values weight.\n const index = this.#filtersData.filters.findIndex((value) => {\n return data.weight < value.weight;\n });\n // If an index was found insert at that location.\n if (index >= 0) {\n this.#filtersData.filters.splice(index, 0, data);\n }\n else // push to end of filters.\n {\n this.#filtersData.filters.push(data);\n }\n if (typeof subscribeFn === 'function') {\n const unsubscribe = subscribeFn(this.#indexUpdate);\n // Ensure that unsubscribe is a function.\n if (typeof unsubscribe !== 'function') {\n throw new TypeError('AdapterFilters error: Filter has subscribe function, but no unsubscribe function is returned.');\n }\n // Ensure that the same filter is not subscribed to multiple times.\n if (this.#mapUnsubscribe.has(data.filter)) {\n throw new Error('AdapterFilters error: Filter added already has an unsubscribe function registered.');\n }\n this.#mapUnsubscribe.set(data.filter, unsubscribe);\n subscribeCount++;\n }\n }\n // Filters with subscriber functionality are assumed to immediately invoke the `subscribe` callback. If the\n // subscriber count is less than the amount of filters added then automatically trigger an index update manually.\n if (subscribeCount < filters.length) {\n this.#indexUpdate();\n }\n }\n /**\n * Clears and removes all filters.\n */\n clear() {\n this.#filtersData.filters.length = 0;\n // Unsubscribe from all filters with subscription support.\n for (const unsubscribe of this.#mapUnsubscribe.values()) {\n unsubscribe();\n }\n this.#mapUnsubscribe.clear();\n this.#indexUpdate();\n }\n /**\n * @param filters -\n */\n remove(...filters) {\n const length = this.#filtersData.filters.length;\n if (length === 0) {\n return;\n }\n for (const data of filters) {\n // Handle the case that the filter may either be a function or a filter entry / object.\n const actualFilter = typeof data === 'function' ? data : data !== null && typeof data === 'object' ?\n data.filter : void 0;\n if (!actualFilter) {\n continue;\n }\n for (let cntr = this.#filtersData.filters.length; --cntr >= 0;) {\n if (this.#filtersData.filters[cntr].filter === actualFilter) {\n this.#filtersData.filters.splice(cntr, 1);\n // Invoke any unsubscribe function for given filter then remove from tracking.\n let unsubscribe = void 0;\n if (typeof (unsubscribe = this.#mapUnsubscribe.get(actualFilter)) === 'function') {\n unsubscribe();\n this.#mapUnsubscribe.delete(actualFilter);\n }\n }\n }\n }\n // Update the index a filter was removed.\n if (length !== this.#filtersData.filters.length) {\n this.#indexUpdate();\n }\n }\n /**\n * Remove filters by the provided callback. The callback takes 3 parameters: `id`, `filter`, and `weight`.\n * Any truthy value returned will remove that filter.\n *\n * @param callback - Callback function to evaluate each filter entry.\n */\n removeBy(callback) {\n const length = this.#filtersData.filters.length;\n if (length === 0) {\n return;\n }\n if (typeof callback !== 'function') {\n throw new TypeError(`AdapterFilters error: 'callback' is not a function.`);\n }\n this.#filtersData.filters = this.#filtersData.filters.filter((data) => {\n const remove = callback.call(callback, { ...data });\n if (remove) {\n let unsubscribe;\n if (typeof (unsubscribe = this.#mapUnsubscribe.get(data.filter)) === 'function') {\n unsubscribe();\n this.#mapUnsubscribe.delete(data.filter);\n }\n }\n // Reverse remove boolean to properly filter / remove this filter.\n return !remove;\n });\n if (length !== this.#filtersData.filters.length) {\n this.#indexUpdate();\n }\n }\n /**\n * @param ids - Removes filters by ID.\n */\n removeById(...ids) {\n const length = this.#filtersData.filters.length;\n if (length === 0) {\n return;\n }\n this.#filtersData.filters = this.#filtersData.filters.filter((data) => {\n let remove = 0;\n for (const id of ids) {\n remove |= (data.id === id ? 1 : 0);\n }\n // If not keeping invoke any unsubscribe function for given filter then remove from tracking.\n if (!!remove) {\n let unsubscribe;\n if (typeof (unsubscribe = this.#mapUnsubscribe.get(data.filter)) === 'function') {\n unsubscribe();\n this.#mapUnsubscribe.delete(data.filter);\n }\n }\n return !remove; // Swap here to actually remove the item via array filter method.\n });\n if (length !== this.#filtersData.filters.length) {\n this.#indexUpdate();\n }\n }\n}\n\n/**\n * Provides construction and management of indexed data when there are parent indexes or filter / sort functions\n * applied.\n */\nclass AdapterIndexer {\n derivedAdapter;\n filtersData;\n hostData;\n hostUpdate;\n indexData;\n sortData;\n sortFn;\n destroyed = false;\n /**\n * @param hostData - Hosted data structure.\n *\n * @param hostUpdate - Host update function invoked on index updates.\n *\n * @param [parentIndexer] - Any associated parent index API.\n *\n * @returns Indexer adapter instance.\n */\n constructor(hostData, hostUpdate, parentIndexer) {\n this.hostData = hostData;\n this.hostUpdate = hostUpdate;\n this.indexData = { index: null, hash: null, reversed: false, parent: parentIndexer };\n }\n /**\n * @returns Returns whether the index is active.\n */\n get active() {\n return this.filtersData.filters.length > 0 || this.sortData.compareFn !== null ||\n this.indexData.parent?.active === true;\n }\n /**\n * @returns Returns length of reduced index.\n */\n get length() {\n return this.indexData.index ? this.indexData.index.length : 0;\n }\n /* c8 ignore start */\n /**\n * @returns Returns reversed state.\n */\n get reversed() { return this.indexData.reversed; }\n /* c8 ignore end */\n /**\n * @param reversed - New reversed state.\n */\n set reversed(reversed) { this.indexData.reversed = reversed; }\n // -------------------------------------------------------------------------------------------------------------------\n /**\n * Calculates a new hash value for the new index array if any. If the new index array is null then the hash value\n * is set to null. Set calculated new hash value to the index adapter hash value.\n *\n * After hash generation compare old and new hash values and perform an update if they are different. If they are\n * equal check for array equality between the old and new index array and perform an update if they are not equal.\n *\n * @param oldIndex - Old index array.\n *\n * @param oldHash - Old index hash value.\n *\n * @param [force=false] - When true forces an update to subscribers.\n */\n calcHashUpdate(oldIndex, oldHash, force = false) {\n // Use force if a boolean otherwise default to false.\n const actualForce = typeof force === 'boolean' ? force : /* c8 ignore next */ false;\n let newHash = null;\n const newIndex = this.indexData.index;\n if (newIndex) {\n for (let cntr = newIndex.length; --cntr >= 0;) {\n newHash ^= DynReducerUtils.hashUnknown(newIndex[cntr]) + 0x9e3779b9 + (newHash << 6) + (newHash >> 2);\n }\n }\n this.indexData.hash = newHash;\n if (actualForce || (oldHash === newHash ? !DynReducerUtils.arrayEquals(oldIndex, newIndex) : true)) {\n this.hostUpdate();\n }\n }\n /**\n * Destroys all resources.\n */\n destroy() {\n if (this.destroyed) {\n return;\n }\n this.indexData.index = null;\n this.indexData.hash = null;\n this.indexData.reversed = null;\n this.indexData.parent = null;\n this.destroyed = true;\n }\n /**\n * Store associated filter and sort data that are constructed after the indexer.\n *\n * @param filtersData - Associated AdapterFilters instance.\n *\n * @param sortData - Associated AdapterSort instance.\n *\n * @param derivedAdapter - Associated AdapterDerived instance.\n */\n initAdapters(filtersData, sortData, derivedAdapter) {\n this.filtersData = filtersData;\n this.sortData = sortData;\n this.derivedAdapter = derivedAdapter;\n this.sortFn = this.createSortFn();\n }\n}\n\n/**\n * Provides the storage and sequencing of a managed sort function. The sort function set may be a bespoke function or a\n * {@link DataSort} object containing an `compare`, and `subscribe` attributes; `compare` is the only required\n * attribute.\n *\n * Note: You can set a compare function that also has a subscribe function attached as the `subscribe` attribute.\n * If a subscribe function is provided the sort function can notify any updates that may change sort order and this\n * triggers an index update.\n *\n * This class forms the public API which is accessible from the `.sort` getter in the main reducer implementation.\n * ```\n * const dynArray = new DynArrayReducer([...]);\n * dynArray.sort.clear();\n * dynArray.sort.set(...);\n * ```\n */\nclass AdapterSort {\n #sortData;\n #indexUpdate;\n #unsubscribe;\n /**\n * @param indexUpdate - Function to update indexer.\n *\n * @param sortData - Storage for compare function.\n */\n constructor(indexUpdate, sortData) {\n this.#indexUpdate = indexUpdate;\n this.#sortData = sortData;\n Object.freeze(this);\n }\n /**\n * Clears & removes any assigned sort function and triggers an index update.\n */\n clear() {\n const oldCompareFn = this.#sortData.compareFn;\n this.#sortData.compareFn = null;\n if (typeof this.#unsubscribe === 'function') {\n this.#unsubscribe();\n this.#unsubscribe = void 0;\n }\n // Only update index if an old compare function is set.\n if (typeof oldCompareFn === 'function') {\n this.#indexUpdate();\n }\n }\n /**\n * @param data - A callback function that compares two values. Return > 0 to sort b before a;\n * < 0 to sort a before b; or 0 to keep original order of a & b.\n *\n * Note: You can set a compare function that also has a subscribe function attached as the `subscribe` attribute.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#parameters\n */\n set(data) {\n if (typeof this.#unsubscribe === 'function') {\n this.#unsubscribe();\n this.#unsubscribe = void 0;\n }\n let compareFn = void 0;\n let subscribeFn = void 0;\n switch (typeof data) {\n case 'function':\n compareFn = data;\n subscribeFn = data.subscribe;\n break;\n case 'object':\n // Early out if data is null / noop.\n if (data === null) {\n break;\n }\n if (typeof data.compare !== 'function') {\n throw new TypeError(`AdapterSort error: 'compare' attribute is not a function.`);\n }\n compareFn = data.compare;\n subscribeFn = data.compare.subscribe ?? data.subscribe;\n break;\n }\n if (typeof compareFn === 'function') {\n this.#sortData.compareFn = compareFn;\n }\n else {\n const oldCompareFn = this.#sortData.compareFn;\n this.#sortData.compareFn = null;\n // Update index if the old compare function exists.\n if (typeof oldCompareFn === 'function') {\n this.#indexUpdate();\n }\n return;\n }\n if (typeof subscribeFn === 'function') {\n this.#unsubscribe = subscribeFn(this.#indexUpdate);\n // Ensure that unsubscribe is a function.\n if (typeof this.#unsubscribe !== 'function') {\n throw new Error(`AdapterSort error: sort has 'subscribe' function, but no 'unsubscribe' function is returned.`);\n }\n }\n else {\n // A sort function with subscriber functionality are assumed to immediately invoke the `subscribe` callback.\n // Only manually update the index if there is no subscriber functionality.\n this.#indexUpdate();\n }\n }\n}\n\n/**\n * Provides the public API for accessing the index API.\n *\n * This class forms the public API which is accessible from the `.index` getter in the main reducer implementation.\n * ```\n * const dynArray = new DynArrayReducer([...]);\n * dynArray.index.active;\n * dynArray.index.hash;\n * dynArray.index.length;\n * dynArray.index.update(...);\n * ```\n */\nclass IndexerAPI {\n #indexData;\n /**\n * Provides a getter to determine if the index is active.\n */\n active;\n /**\n * Provides length of reduced / indexed elements.\n */\n length;\n /**\n * Manually invoke an update of the index.\n *\n * @param force - Force update to any subscribers.\n */\n update;\n constructor(adapterIndexer) {\n this.#indexData = adapterIndexer.indexData;\n this.update = adapterIndexer.update.bind(adapterIndexer);\n // Defines getters on the public API to get the index hash, active state, and index length.\n Object.defineProperties(this, {\n active: { get: () => adapterIndexer.active },\n length: { get: () => adapterIndexer.length }\n });\n Object.freeze(this);\n }\n /**\n * - Current hash value of the index.\n */\n get hash() {\n return this.#indexData.hash;\n }\n /**\n * Provides an iterator over the index array.\n *\n * @returns Iterator / generator\n * @yields {K}\n */\n *[Symbol.iterator]() {\n const indexData = this.#indexData;\n if (!indexData.index) {\n return;\n }\n const reversed = indexData.reversed;\n const length = indexData.index.length;\n if (reversed) {\n for (let cntr = length; --cntr >= 0;) {\n yield indexData.index[cntr];\n }\n }\n else {\n for (let cntr = 0; cntr < length; cntr++) {\n yield indexData.index[cntr];\n }\n }\n }\n}\n\n/**\n * Provides the public API for derived reducers. There are several ways to create a derived reducer from utilizing the\n * default implementation or passing in a constructor function / class for a custom derived reducer.\n *\n * This class forms the public API which is accessible from the `.derived` getter in the main reducer implementation.\n * ```\n * const dynArray = new DynArrayReducer([...]);\n * dynArray.derived.clear();\n * dynArray.derived.create(...);\n * dynArray.derived.delete(...);\n * dynArray.derived.destroy();\n * dynArray.derived.get(...);\n * ```\n */\nclass DerivedAPI {\n /**\n * Removes all derived reducers and associated subscriptions.\n */\n clear;\n /**\n * @param options - Options for creating a reducer.\n *\n * @returns Newly created derived reducer.\n */\n create;\n /**\n * Deletes and destroys a derived reducer.\n *\n * @param name - Name of the derived reducer\n */\n delete;\n /**\n * Removes all derived reducers, associated subscriptions, and cleans up all resources.\n */\n destroy;\n /**\n * Returns an existing derived reducer.\n *\n * @param name - Name of derived reducer.\n */\n get;\n constructor(adapterDerived) {\n this.clear = adapterDerived.clear.bind(adapterDerived);\n this.create = adapterDerived.create.bind(adapterDerived);\n this.delete = adapterDerived.delete.bind(adapterDerived);\n this.destroy = adapterDerived.destroy.bind(adapterDerived);\n this.get = adapterDerived.get.bind(adapterDerived);\n Object.freeze(this);\n }\n}\n\n/**\n */\nclass Indexer$1 extends AdapterIndexer {\n /**\n * @inheritDoc\n */\n createSortFn() {\n return (a, b) => this.sortData.compareFn(this.hostData[0][a], this.hostData[0][b]);\n }\n /**\n * Provides the custom filter / reduce step that is ~25-40% faster than implementing with `Array.reduce`.\n *\n * Note: Other loop unrolling techniques like Duff's Device gave a slight faster lower bound on large data sets,\n * but the maintenance factor is not worth the extra complication.\n *\n * @returns New filtered index array.\n */\n reduceImpl() {\n const data = [];\n const array = this.hostData[0];\n if (!array) {\n return data;\n }\n const filters = this.filtersData.filters;\n let include = true;\n const parentIndex = this.indexData.parent;\n // Source index data is coming from an active parent index.\n if (DynReducerUtils.isIterable(parentIndex) && parentIndex.active) {\n for (const adjustedIndex of parentIndex) {\n const value = array[adjustedIndex];\n include = true;\n for (let filCntr = 0, filLength = filters.length; filCntr < filLength; filCntr++) {\n if (!filters[filCntr].filter(value)) {\n include = false;\n break;\n }\n }\n if (include) {\n data.push(adjustedIndex);\n }\n }\n }\n else {\n for (let cntr = 0, length = array.length; cntr < length; cntr++) {\n include = true;\n for (let filCntr = 0, filLength = filters.length; filCntr < filLength; filCntr++) {\n if (!filters[filCntr].filter(array[cntr])) {\n include = false;\n break;\n }\n }\n if (include) {\n data.push(cntr);\n }\n }\n }\n return data;\n }\n /**\n * Update the reducer indexes. If there are changes subscribers are notified. If data order is changed externally\n * pass in true to force an update to subscribers.\n *\n * @param [force=false] - When true forces an update to subscribers.\n */\n update(force = false) {\n if (this.destroyed) {\n return;\n }\n const oldIndex = this.indexData.index;\n const oldHash = this.indexData.hash;\n const array = this.hostData[0];\n const parentIndex = this.indexData.parent;\n // Clear index if there are no filters and no sort function or the index length doesn't match the item length.\n if ((this.filtersData.filters.length === 0 && !this.sortData.compareFn) ||\n (this.indexData.index && array?.length !== this.indexData.index.length)) {\n this.indexData.index = null;\n }\n // If there are filters build new index.\n if (this.filtersData.filters.length > 0) {\n this.indexData.index = this.reduceImpl();\n }\n // If the index isn't built yet and there is an active parent index then create it from the parent.\n if (!this.indexData.index && parentIndex?.active) {\n this.indexData.index = [...parentIndex];\n }\n if (this.sortData.compareFn && Array.isArray(array)) {\n // If there is no index then create one with keys matching host item length.\n if (!this.indexData.index) {\n this.indexData.index = [...Array(array.length).keys()];\n }\n this.indexData.index.sort(this.sortFn);\n }\n this.calcHashUpdate(oldIndex, oldHash, force);\n // Update all derived reducers.\n this.derivedAdapter?.update(force);\n }\n}\n\n/**\n * Provides the base implementation derived reducer for arrays / DynArrayReducer.\n */\nclass DerivedArrayReducer {\n #array;\n #derived;\n #derivedPublicAPI;\n #filters;\n #filtersData = { filters: [] };\n #index;\n #indexPublicAPI;\n #reversed = false;\n #sort;\n #sortData = { compareFn: null };\n #subscriptions = [];\n #destroyed = false;\n /**\n * @param array - Data host array.\n *\n * @param parentIndex - Parent indexer.\n *\n * @param options - Any filters and sort functions to apply.\n */\n constructor(array, parentIndex, options) {\n this.#array = array;\n this.#index = new Indexer$1(this.#array, this.#updateSubscribers.bind(this), parentIndex);\n this.#indexPublicAPI = new IndexerAPI(this.#index);\n this.#filters = new AdapterFilters(this.#indexPublicAPI.update, this.#filtersData);\n this.#sort = new AdapterSort(this.#indexPublicAPI.update, this.#sortData);\n this.#derived = new AdapterDerived(this.#array, this.#indexPublicAPI, DerivedArrayReducer);\n this.#derivedPublicAPI = new DerivedAPI(this.#derived);\n this.#index.initAdapters(this.#filtersData, this.#sortData, this.#derived);\n let filters = void 0;\n let sort = void 0;\n if (options !== void 0 && ('filters' in options || 'sort' in options)) {\n if (options.filters !== void 0) {\n if (DynReducerUtils.isIterable(options.filters)) {\n filters = options.filters;\n }\n else {\n throw new TypeError(`DerivedArrayReducer error (DataDerivedOptions): 'filters' attribute is not iterable.`);\n }\n }\n if (options.sort !== void 0) {\n if (typeof options.sort === 'function') {\n sort = options.sort;\n }\n else if (typeof options.sort === 'object' && options.sort !== null) {\n sort = options.sort;\n }\n else {\n throw new TypeError(`DerivedArrayReducer error (DataDerivedOptions): 'sort' attribute is not a function or object.`);\n }\n }\n }\n // Add any filters and sort function defined by DataDynArray.\n if (filters) {\n this.filters.add(...filters);\n }\n if (sort) {\n this.sort.set(sort);\n }\n // Invoke an custom initialization for child classes.\n this.initialize();\n }\n /**\n * Returns the internal data of this instance. Be careful!\n *\n * Note: if an array is set as initial data then that array is used as the internal data. If any changes are\n * performed to the data externally do invoke {@link IndexerAPI.update} with `true` to recalculate the index and\n * notify all subscribers.\n *\n * @returns The internal data.\n */\n get data() { return this.#array[0]; }\n /**\n * @returns Derived public API.\n */\n get derived() { return this.#derivedPublicAPI; }\n /**\n * @returns The filters adapter.\n */\n get filters() { return this.#filters; }\n /**\n * Returns the Indexer public API.\n *\n * @returns Indexer API - is also iterable.\n */\n get index() { return this.#indexPublicAPI; }\n /**\n * Returns whether this derived reducer is destroyed.\n */\n get destroyed() { return this.#destroyed; }\n /**\n * @returns Main data / items length or indexed length.\n */\n get length() {\n const array = this.#array[0];\n return this.#index.active ? this.index.length :\n array ? array.length : 0;\n }\n /**\n * @returns Gets current reversed state.\n */\n get reversed() { return this.#reversed; }\n /**\n * @returns The sort adapter.\n */\n get sort() { return this.#sort; }\n /**\n * Sets reversed state and notifies subscribers.\n *\n * @param reversed - New reversed state.\n */\n set reversed(reversed) {\n if (typeof reversed !== 'boolean') {\n throw new TypeError(`DerivedArrayReducer.reversed error: 'reversed' is not a boolean.`);\n }\n this.#reversed = reversed;\n this.#index.reversed = reversed;\n // Recalculate index and force an update to any subscribers.\n this.index.update(true);\n }\n /**\n * Removes all derived reducers, subscriptions, and cleans up all resources.\n */\n destroy() {\n this.#destroyed = true;\n // Remove any external data reference and perform a final update.\n this.#array = [null];\n this.#index.update(true);\n // Remove all subscriptions.\n this.#subscriptions.length = 0;\n this.#derived.destroy();\n this.#index.destroy();\n this.#filters.clear();\n this.#sort.clear();\n }\n /**\n * Provides a callback for custom derived reducers to initialize any data / custom configuration. This allows\n * child classes to avoid implementing the constructor.\n *\n * @protected\n */\n initialize() { }\n /**\n * Provides an iterator for data stored in DerivedArrayReducer.\n *\n * @returns Generator / iterator of all data.\n */\n *[Symbol.iterator]() {\n const array = this.#array[0];\n if (this.#destroyed || array === null || array?.length === 0) {\n return;\n }\n if (this.#index.active) {\n for (const entry of this.index) {\n yield array[entry];\n }\n }\n else {\n if (this.reversed) {\n for (let cntr = array.length; --cntr >= 0;) {\n yield array[cntr];\n }\n }\n else {\n for (let cntr = 0; cntr < array.length; cntr++) {\n yield array[cntr];\n }\n }\n }\n }\n // -------------------------------------------------------------------------------------------------------------------\n /**\n * Subscribe to this DerivedArrayReducer.\n *\n * @param handler - Callback function that is invoked on update / changes. Receives `this` reference.\n *\n * @returns Unsubscribe function.\n */\n subscribe(handler) {\n this.#subscriptions.push(handler); // add handler to the array of subscribers\n handler(this); // call handler with current value\n // Return unsubscribe function.\n return () => {\n const index = this.#subscriptions.findIndex((sub) => sub === handler);\n if (index >= 0) {\n this.#subscriptions.splice(index, 1);\n }\n };\n }\n /**\n * Updates subscribers on changes.\n */\n #updateSubscribers() {\n for (let cntr = 0; cntr < this.#subscriptions.length; cntr++) {\n this.#subscriptions[cntr](this);\n }\n }\n}\n\n/**\n * Provides a managed array with non-destructive reducing / filtering / sorting capabilities with subscription /\n * Svelte store support.\n */\nclass DynArrayReducer {\n #array = [null];\n #derived;\n #derivedPublicAPI;\n #filters;\n #filtersData = { filters: [] };\n #index;\n #indexPublicAPI;\n #reversed = false;\n #sort;\n #sortData = { compareFn: null };\n #subscriptions = [];\n #destroyed = false;\n /**\n * Initializes DynArrayReducer. Any iterable is supported for initial data. Take note that if `data` is an array it\n * will be used as the host array and not copied. All non-array iterables otherwise create a new array / copy.\n *\n * @param [data] - Data iterable to store if array or copy otherwise.\n */\n constructor(data) {\n let dataIterable = void 0;\n let filters = void 0;\n let sort = void 0;\n if (data === null) {\n throw new TypeError(`DynArrayReducer error: 'data' is not iterable.`);\n }\n if (data !== void 0 && typeof data !== 'object' && !DynReducerUtils.isIterable(data)) {\n throw new TypeError(`DynArrayReducer error: 'data' is not iterable.`);\n }\n if (data !== void 0 && Symbol.iterator in data) {\n dataIterable = data;\n }\n else if (data !== void 0 && ('data' in data || 'filters' in data || 'sort' in data)) {\n if (data.data !== void 0 && !DynReducerUtils.isIterable(data.data)) {\n throw new TypeError(`DynArrayReducer error (DataDynArray): 'data' attribute is not iterable.`);\n }\n dataIterable = data.data;\n if (data.filters !== void 0) {\n if (DynReducerUtils.isIterable(data.filters)) {\n filters = data.filters;\n }\n else {\n throw new TypeError(`DynArrayReducer error (DataDynArray): 'filters' attribute is not iterable.`);\n }\n }\n if (data.sort !== void 0) {\n if (typeof data.sort === 'function') {\n sort = data.sort;\n }\n else if (typeof data.sort === 'object' && data.sort !== null) {\n sort = data.sort;\n }\n else {\n throw new TypeError(`DynArrayReducer error (DataDynArray): 'sort' attribute is not a function or object.`);\n }\n }\n }\n // In the case of the main data being an array directly use the array otherwise create a copy.\n if (dataIterable) {\n this.#array[0] = Array.isArray(dataIterable) ? dataIterable : [...dataIterable];\n }\n this.#index = new Indexer$1(this.#array, this.#updateSubscribers.bind(this));\n this.#indexPublicAPI = new IndexerAPI(this.#index);\n this.#filters = new AdapterFilters(this.#indexPublicAPI.update, this.#filtersData);\n this.#sort = new AdapterSort(this.#indexPublicAPI.update, this.#sortData);\n this.#derived = new AdapterDerived(this.#array, this.#indexPublicAPI, DerivedArrayReducer);\n this.#derivedPublicAPI = new DerivedAPI(this.#derived);\n this.#index.initAdapters(this.#filtersData, this.#sortData, this.#derived);\n // Add any filters and sort function defined by DataDynArray.\n if (filters) {\n this.filters.add(...filters);\n }\n if (sort) {\n this.sort.set(sort);\n }\n // Invoke an custom initialization for child classes.\n this.initialize();\n }\n /**\n * Returns the internal data of this instance. Be careful!\n *\n * Note: if an array is set as initial data then that array is used as the internal data. If any changes are\n * performed to the data externally do invoke {@link AdapterIndexer.index.update} with `true` to recalculate the\n * index and notify all subscribers.\n *\n * @returns The internal data.\n */\n get data() { return this.#array[0]; }\n /**\n * @returns Derived public API.\n */\n get derived() { return this.#derivedPublicAPI; }\n /**\n * @returns The filters adapter.\n */\n get filters() { return this.#filters; }\n /**\n * @returns Returns the Indexer public API.\n */\n get index() { return this.#indexPublicAPI; }\n /**\n * Returns whether this instance is destroyed.\n */\n get destroyed() { return this.#destroyed; }\n /**\n * Gets the main data / items length.\n *\n * @returns {number} Main data / items length.\n */\n get length() {\n const array = this.#array[0];\n return this.#index.active ? this.#indexPublicAPI.length :\n array ? array.length : 0;\n }\n /**\n * Gets current reversed state.\n *\n * @returns {boolean} Reversed state.\n */\n get reversed() { return this.#reversed; }\n /**\n * @returns The sort adapter.\n */\n get sort() { return this.#sort; }\n /**\n * Sets reversed state and notifies subscribers.\n *\n * @param reversed - New reversed state.\n */\n set reversed(reversed) {\n if (typeof reversed !== 'boolean') {\n throw new TypeError(`DynArrayReducer.reversed error: 'reversed' is not a boolean.`);\n }\n this.#reversed = reversed;\n this.#index.reversed = reversed;\n // Recalculate index and force an update to any subscribers.\n this.index.update(true);\n }\n /**\n * Removes all derived reducers, subscriptions, and cleans up all resources.\n */\n destroy() {\n if (this.#destroyed) {\n return;\n }\n this.#destroyed = true;\n this.#derived.destroy();\n // Set the backing data to null and provide a final update.\n this.#array = [null];\n this.index.update(true);\n // Remove all subscriptions.\n this.#subscriptions.length = 0;\n this.#index.destroy();\n this.#filters.clear();\n this.#sort.clear();\n }\n /**\n * Provides a callback for custom reducers to initialize any data / custom configuration. This allows\n * child classes to avoid implementing the constructor.\n *\n * @protected\n */\n initialize() { }\n /**\n * Removes internal data and pushes new data. This does not destroy any initial array set to internal data unless\n * `replace` is set to true.\n *\n * @param data - New data to set to internal data.\n *\n * @param replace=false - New data to set to internal data.\n */\n setData(data, replace = false) {\n if (data !== null && !DynReducerUtils.isIterable(data)) {\n throw new TypeError(`DynArrayReducer.setData error: 'data' is not iterable.`);\n }\n if (typeof replace !== 'boolean') {\n throw new TypeError(`DynArrayReducer.setData error: 'replace' is not a boolean.`);\n }\n const array = this.#array[0];\n // If the array isn't defined or 'replace' is true then replace internal data with new array or create an array\n // from an iterable.\n if (!Array.isArray(array) || replace) {\n if (data) {\n this.#array[0] = Array.isArray(data) ? data : [...data];\n }\n }\n else {\n if (data) {\n // Remove all entries in internal data. This will not replace any initially set array.\n array.length = 0;\n // Add all new data.\n array.push(...data);\n }\n else {\n this.#array[0] = null;\n }\n }\n // Recalculate index and force an update to any subscribers.\n this.index.update(true);\n }\n /**\n * Add a subscriber to this DynArrayReducer instance.\n *\n * @param handler - Callback function that is invoked on update / changes. Receives `this` reference.\n *\n * @returns Unsubscribe function.\n */\n subscribe(handler) {\n this.#subscriptions.push(handler); // add handler to the array of subscribers\n handler(this); // call handler with current value\n // Return unsubscribe function.\n return () => {\n const index = this.#subscriptions.findIndex((sub) => sub === handler);\n if (index >= 0) {\n this.#subscriptions.splice(index, 1);\n }\n };\n }\n /**\n * Updates subscribers on changes.\n */\n #updateSubscribers() {\n for (let cntr = 0; cntr < this.#subscriptions.length; cntr++) {\n this.#subscriptions[cntr](this);\n }\n }\n /**\n * Provides an iterator for data stored in DynArrayReducer.\n *\n * @returns Generator / iterator of all data.\n * @yields {T}\n */\n *[Symbol.iterator]() {\n const array = this.#array[0];\n if (this.#destroyed || array === null || array?.length === 0) {\n return;\n }\n if (this.#index.active) {\n for (const entry of this.index) {\n yield array[entry];\n }\n }\n else {\n if (this.reversed) {\n for (let cntr = array.length; --cntr >= 0;) {\n yield array[cntr];\n }\n }\n else {\n for (let cntr = 0; cntr < array.length; cntr++) {\n yield array[cntr];\n }\n }\n }\n }\n}\n\n/**\n */\nclass Indexer extends AdapterIndexer {\n /**\n * @inheritDoc\n */\n createSortFn() {\n return (a, b) => this.sortData.compareFn(this.hostData[0].get(a), this.hostData[0].get(b));\n }\n /**\n * Provides the custom filter / reduce step that is ~25-40% faster than implementing with `Array.reduce`.\n *\n * Note: Other loop unrolling techniques like Duff's Device gave a slight faster lower bound on large data sets,\n * but the maintenance factor is not worth the extra complication.\n *\n * @returns New filtered index array.\n */\n reduceImpl() {\n const data = [];\n const map = this.hostData[0];\n if (!map) {\n return data;\n }\n const filters = this.filtersData.filters;\n let include = true;\n const parentIndex = this.indexData.parent;\n // Source index data is coming from an active parent index.\n if (DynReducerUtils.isIterable(parentIndex) && parentIndex.active) {\n for (const key of parentIndex) {\n const value = map.get(key);\n include = true;\n for (let filCntr = 0, filLength = filters.length; filCntr < filLength; filCntr++) {\n if (!filters[filCntr].filter(value)) {\n include = false;\n break;\n }\n }\n if (include) {\n data.push(key);\n }\n }\n }\n else {\n for (const key of map.keys()) {\n include = true;\n const value = map.get(key);\n for (let filCntr = 0, filLength = filters.length; filCntr < filLength; filCntr++) {\n if (!filters[filCntr].filter(value)) {\n include = false;\n break;\n }\n }\n if (include) {\n data.push(key);\n }\n }\n }\n return data;\n }\n /**\n * Update the reducer indexes. If there are changes subscribers are notified. If data order is changed externally\n * pass in true to force an update to subscribers.\n *\n * @param [force=false] - When true forces an update to subscribers.\n */\n update(force = false) {\n if (this.destroyed) {\n return;\n }\n const oldIndex = this.indexData.index;\n const oldHash = this.indexData.hash;\n const map = this.hostData[0];\n const parentIndex = this.indexData.parent;\n // Clear index if there are no filters and no sort function or the index length doesn't match the item length.\n if ((this.filtersData.filters.length === 0 && !this.sortData.compareFn) ||\n (this.indexData.index && map?.size !== this.indexData.index.length)) {\n this.indexData.index = null;\n }\n // If there are filters build new index.\n if (this.filtersData.filters.length > 0) {\n this.indexData.index = this.reduceImpl();\n }\n // If the index isn't built yet and there is an active parent index then create it from the parent.\n if (!this.indexData.index && parentIndex?.active) {\n this.indexData.index = [...parentIndex];\n }\n if (this.sortData.compareFn && map instanceof Map) {\n // If there is no index then create one with keys matching host item length.\n if (!this.indexData.index) {\n this.indexData.index = this.indexData.index = [...map.keys()];\n }\n this.indexData.index.sort(this.sortFn);\n }\n this.calcHashUpdate(oldIndex, oldHash, force);\n // Update all derived reducers.\n this.derivedAdapter?.update(force);\n }\n}\n\n/**\n * Provides the base implementation derived reducer for arrays / DynArrayReducer.\n */\nclass DerivedMapReducer {\n #map;\n #derived;\n #derivedPublicAPI;\n #filters;\n #filtersData = { filters: [] };\n #index;\n #indexPublicAPI;\n #reversed = false;\n #sort;\n #sortData = { compareFn: null };\n #subscriptions = [];\n #destroyed = false;\n /**\n * @param map - Data host Map.\n *\n * @param parentIndex - Parent indexer.\n *\n * @param options - Any filters and sort functions to apply.\n */\n constructor(map, parentIndex, options) {\n this.#map = map;\n this.#index = new Indexer(this.#map, this.#updateSubscribers.bind(this), parentIndex);\n this.#indexPublicAPI = new IndexerAPI(this.#index);\n this.#filters = new AdapterFilters(this.#indexPublicAPI.update, this.#filtersData);\n this.#sort = new AdapterSort(this.#indexPublicAPI.update, this.#sortData);\n this.#derived = new AdapterDerived(this.#map, this.#indexPublicAPI, DerivedMapReducer);\n this.#derivedPublicAPI = new DerivedAPI(this.#derived);\n this.#index.initAdapters(this.#filtersData, this.#sortData, this.#derived);\n let filters = void 0;\n let sort = void 0;\n if (options !== void 0 && ('filters' in options || 'sort' in options)) {\n if (options.filters !== void 0) {\n if (DynReducerUtils.isIterable(options.filters)) {\n filters = options.filters;\n }\n else {\n throw new TypeError(`DerivedMapReducer error (DataDerivedOptions): 'filters' attribute is not iterable.`);\n }\n }\n if (options.sort !== void 0) {\n if (typeof options.sort === 'function') {\n sort = options.sort;\n }\n else if (typeof options.sort === 'object' && options.sort !== null) {\n sort = options.sort;\n }\n else {\n throw new TypeError(`DerivedMapReducer error (DataDerivedOptions): 'sort' attribute is not a function or object.`);\n }\n }\n }\n // Add any filters and sort function defined by DataDynArray.\n if (filters) {\n this.filters.add(...filters);\n }\n if (sort) {\n this.sort.set(sort);\n }\n // Invoke an custom initialization for child classes.\n this.initialize();\n }\n /**\n * Returns the internal data of this instance. Be careful!\n *\n * Note: The returned map is the same map set by the main reducer. If any changes are performed to the data\n * externally do invoke {@link IndexerAPI.update} with `true` to recalculate the index and notify all subscribers.\n *\n * @returns The internal data.\n */\n get data() { return this.#map[0]; }\n /**\n * @returns Derived public API.\n */\n get derived() { return this.#derivedPublicAPI; }\n /**\n * @returns The filters adapter.\n */\n get filters() { return this.#filters; }\n /**\n * Returns the Indexer public API.\n *\n * @returns Indexer API - is also iterable.\n */\n get index() { return this.#indexPublicAPI; }\n /**\n * Returns whether this derived reducer is destroyed.\n */\n get destroyed() { return this.#destroyed; }\n /**\n * @returns Main data / items length or indexed length.\n */\n get length() {\n const map = this.#map[0];\n return this.#index.active ? this.index.length :\n map ? map.size : 0;\n }\n /**\n * @returns Gets current reversed state.\n */\n get reversed() { return this.#reversed; }\n /**\n * @returns The sort adapter.\n */\n get sort() { return this.#sort; }\n /**\n * Sets reversed state and notifies subscribers.\n *\n * @param reversed - New reversed state.\n */\n set reversed(reversed) {\n if (typeof reversed !== 'boolean') {\n throw new TypeError(`DerivedMapReducer.reversed error: 'reversed' is not a boolean.`);\n }\n this.#reversed = reversed;\n this.#index.reversed = reversed;\n // Recalculate index and force an update to any subscribers.\n this.index.update(true);\n }\n /**\n * Removes all derived reducers, subscriptions, and cleans up all resources.\n */\n destroy() {\n this.#destroyed = true;\n // Remove any external data reference and perform a final update.\n this.#map = [null];\n this.#index.update(true);\n // Remove all subscriptions.\n this.#subscriptions.length = 0;\n this.#derived.destroy();\n this.#index.destroy();\n this.#filters.clear();\n this.#sort.clear();\n }\n /**\n * Provides a callback for custom derived reducers to initialize any data / custom configuration. This allows\n * child classes to avoid implementing the constructor.\n *\n * @protected\n */\n initialize() { }\n /**\n * Provides an iterator for data stored in DerivedMapReducer.\n *\n * @returns Generator / iterator of all data.\n */\n *[Symbol.iterator]() {\n const map = this.#map[0];\n if (this.#destroyed || map === null || map?.size === 0) {\n return;\n }\n if (this.#index.active) {\n for (const key of this.index) {\n yield map.get(key);\n }\n }\n else {\n if (this.reversed) {\n // TODO: Not efficient due to creating temporary values array.\n const values = [...map.values()];\n for (let cntr = values.length; --cntr >= 0;) {\n yield values[cntr];\n }\n }\n else {\n for (const value of map.values()) {\n yield value;\n }\n }\n }\n }\n // -------------------------------------------------------------------------------------------------------------------\n /**\n * Subscribe to this DerivedMapReducer.\n *\n * @param handler - Callback function that is invoked on update / changes. Receives `this` reference.\n *\n * @returns Unsubscribe function.\n */\n subscribe(handler) {\n this.#subscriptions.push(handler); // add handler to the array of subscribers\n handler(this); // call handler with current value\n // Return unsubscribe function.\n return () => {\n const index = this.#subscriptions.findIndex((sub) => sub === handler);\n if (index >= 0) {\n this.#subscriptions.splice(index, 1);\n }\n };\n }\n /**\n * Updates subscribers on changes.\n */\n #updateSubscribers() {\n for (let cntr = 0; cntr < this.#subscriptions.length; cntr++) {\n this.#subscriptions[cntr](this);\n }\n }\n}\n\n/**\n * Provides a managed Map with non-destructive reducing / filtering / sorting capabilities with subscription /\n * Svelte store support.\n */\nclass DynMapReducer {\n #map = [null];\n #derived;\n #derivedPublicAPI;\n #filters;\n #filtersData = { filters: [] };\n #index;\n #indexPublicAPI;\n #reversed = false;\n #sort;\n #sortData = { compareFn: null };\n #subscriptions = [];\n #destroyed = false;\n /**\n * Initializes DynMapReducer. Any iterable is supported for initial data. Take note that if `data` is an array it\n * will be used as the host array and not copied. All non-array iterables otherwise create a new array / copy.\n *\n * @param [data] - Data iterable to store if array or copy otherwise.\n */\n constructor(data) {\n let dataMap = void 0;\n let filters = void 0;\n let sort = void 0;\n if (data === null) {\n throw new TypeError(`DynMapReducer error: 'data' is not an object or Map.`);\n }\n if (data !== void 0 && typeof data !== 'object' && !(data instanceof Map)) {\n throw new TypeError(`DynMapReducer error: 'data' is not an object or Map.`);\n }\n if (data !== void 0 && data instanceof Map) {\n dataMap = data;\n }\n else if (data !== void 0 && ('data' in data || 'filters' in data || 'sort' in data)) {\n if (data.data !== void 0 && !(data.data instanceof Map)) {\n throw new TypeError(`DynMapReducer error (DataDynMap): 'data' attribute is not a Map.`);\n }\n dataMap = data.data;\n if (data.filters !== void 0) {\n if (DynReducerUtils.isIterable(data.filters)) {\n filters = data.filters;\n }\n else {\n throw new TypeError(`DynMapReducer error (DataDynMap): 'filters' attribute is not iterable.`);\n }\n }\n if (data.sort !== void 0) {\n if (typeof data.sort === 'function') {\n sort = data.sort;\n }\n else if (typeof data.sort === 'object' && data.sort !== null) {\n sort = data.sort;\n }\n else {\n throw new TypeError(`DynMapReducer error (DataDynMap): 'sort' attribute is not a function or object.`);\n }\n }\n }\n // In the case of the main data being an array directly use the array otherwise create a copy.\n if (dataMap) {\n this.#map[0] = dataMap;\n }\n this.#index = new Indexer(this.#map, this.#updateSubscribers.bind(this));\n this.#indexPublicAPI = new IndexerAPI(this.#index);\n this.#filters = new AdapterFilters(this.#indexPublicAPI.update, this.#filtersData);\n this.#sort = new AdapterSort(this.#indexPublicAPI.update, this.#sortData);\n this.#derived = new AdapterDerived(this.#map, this.#indexPublicAPI, DerivedMapReducer);\n this.#derivedPublicAPI = new DerivedAPI(this.#derived);\n this.#index.initAdapters(this.#filtersData, this.#sortData, this.#derived);\n // Add any filters and sort function defined by DataDynMap.\n if (filters) {\n this.filters.add(...filters);\n }\n if (sort) {\n this.sort.set(sort);\n }\n // Invoke an custom initialization for child classes.\n this.initialize();\n }\n /**\n * Returns the internal data of this instance. Be careful!\n *\n * Note: When a map is set as data then that map is used as the internal data. If any changes are\n * performed to the data externally do invoke {@link AdapterIndexer.index.update} with `true` to recalculate the\n * index and notify all subscribers.\n *\n * @returns The internal data.\n */\n get data() { return this.#map[0]; }\n /**\n * @returns Derived public API.\n */\n get derived() { return this.#derivedPublicAPI; }\n /**\n * @returns The filters adapter.\n */\n get filters() { return this.#filters; }\n /**\n * @returns Returns the Indexer public API.\n */\n get index() { return this.#indexPublicAPI; }\n /**\n * Returns whether this instance is destroyed.\n */\n get destroyed() { return this.#destroyed; }\n /**\n * Gets the main data / items length.\n *\n * @returns {number} Main data / items length.\n */\n get length() {\n const map = this.#map[0];\n return this.#index.active ? this.#indexPublicAPI.length :\n map ? map.size : 0;\n }\n /**\n * Gets current reversed state.\n *\n * @returns {boolean} Reversed state.\n */\n get reversed() { return this.#reversed; }\n /**\n * @returns The sort adapter.\n */\n get sort() { return this.#sort; }\n /**\n * Sets reversed state and notifies subscribers.\n *\n * @param reversed - New reversed state.\n */\n set reversed(reversed) {\n if (typeof reversed !== 'boolean') {\n throw new TypeError(`DynMapReducer.reversed error: 'reversed' is not a boolean.`);\n }\n this.#reversed = reversed;\n this.#index.reversed = reversed;\n // Recalculate index and force an update to any subscribers.\n this.index.update(true);\n }\n /**\n * Removes all derived reducers, subscriptions, and cleans up all resources.\n */\n destroy() {\n if (this.#destroyed) {\n return;\n }\n this.#destroyed = true;\n this.#derived.destroy();\n // Set the backing data to null and provide a final update.\n this.#map = [null];\n this.index.update(true);\n // Remove all subscriptions.\n this.#subscriptions.length = 0;\n this.#index.destroy();\n this.#filters.clear();\n this.#sort.clear();\n }\n /**\n * Provides a callback for custom reducers to initialize any data / custom configuration. This allows\n * child classes to avoid implementing the constructor.\n *\n * @protected\n */\n initialize() { }\n /**\n * Removes internal data and pushes new data. This does not destroy any initial array set to internal data unless\n * `replace` is set to true.\n *\n * @param data - New data to set to internal data.\n *\n * @param replace=false - New data to set to internal data.\n */\n setData(data, replace = false) {\n if (data !== null && !(data instanceof Map)) {\n throw new TypeError(`DynMapReducer.setData error: 'data' is not iterable.`);\n }\n if (typeof replace !== 'boolean') {\n throw new TypeError(`DynMapReducer.setData error: 'replace' is not a boolean.`);\n }\n const map = this.#map[0];\n // If the array isn't defined or 'replace' is true then replace internal data with new array or create an array\n // from an iterable.\n if (!(map instanceof Map) || replace) {\n this.#map[0] = data instanceof Map ? data : null;\n }\n else if (data instanceof Map && map instanceof Map) {\n // Create a set of all current entry IDs.\n const removeKeySet = new Set(map.keys());\n for (const key of data.keys()) {\n map.set(key, data.get(key));\n if (removeKeySet.has(key)) {\n removeKeySet.delete(key);\n }\n }\n // Remove entries that are no longer in data.\n for (const key of removeKeySet) {\n map.delete(key);\n }\n }\n else if (data === null) {\n this.#map[0] = null;\n }\n // Recalculate index and force an update to any subscribers.\n this.index.update(true);\n }\n /**\n * Add a subscriber to this DynMapReducer instance.\n *\n * @param handler - Callback function that is invoked on update / changes. Receives `this` reference.\n *\n * @returns Unsubscribe function.\n */\n subscribe(handler) {\n this.#subscriptions.push(handler); // add handler to the array of subscribers\n handler(this); // call handler with current value\n // Return unsubscribe function.\n return () => {\n const index = this.#subscriptions.findIndex((sub) => sub === handler);\n if (index >= 0) {\n this.#subscriptions.splice(index, 1);\n }\n };\n }\n /**\n * Updates subscribers on changes.\n */\n #updateSubscribers() {\n for (let cntr = 0; cntr < this.#subscriptions.length; cntr++) {\n this.#subscriptions[cntr](this);\n }\n }\n /**\n * Provides an iterator for data stored in DynMapReducer.\n *\n * @returns Generator / iterator of all data.\n * @yields {T}\n */\n *[Symbol.iterator]() {\n const map = this.#map[0];\n if (this.#destroyed || map === null || map?.size === 0) {\n return;\n }\n if (this.#index.active) {\n for (const key of this.index) {\n yield map.get(key);\n }\n }\n else {\n if (this.reversed) {\n // TODO: Not efficient due to creating temporary values array.\n const values = [...map.values()];\n for (let cntr = values.length; --cntr >= 0;) {\n yield values[cntr];\n }\n }\n else {\n for (const value of map.values()) {\n yield value;\n }\n }\n }\n }\n}\n\n/**\n * Provides a basic test for a given variable to test if it has the shape of a readable store by having a `subscribe`\n * function.\n *\n * Note: functions are also objects, so test that the variable might be a function w/ a `subscribe` function.\n *\n * @param {*} store - variable to test that might be a store.\n *\n * @returns {boolean} Whether the variable tested has the shape of a store.\n */\nfunction isReadableStore(store)\n{\n if (store === null || store === void 0) { return false; }\n\n switch (typeof store)\n {\n case 'function':\n case 'object':\n return typeof store.subscribe === 'function';\n }\n\n return false;\n}\n\n/**\n * Provides a basic test for a given variable to test if it has the shape of a writable store by having a `subscribe`\n * function and an `update` function.\n *\n * Note: functions are also objects, so test that the variable might be a function w/ a `subscribe` function.\n *\n * @param {*} store - variable to test that might be a store.\n *\n * @returns {boolean} Whether the variable tested has the shape of a store.\n */\nfunction isUpdatableStore(store)\n{\n if (store === null || store === void 0) { return false; }\n\n switch (typeof store)\n {\n case 'function':\n case 'object':\n return typeof store.subscribe === 'function' && typeof store.update === 'function';\n }\n\n return false;\n}\n\n/**\n * Provides a basic test for a given variable to test if it has the shape of a writable store by having a `subscribe`\n * `set`, and `update` functions.\n *\n * Note: functions are also objects, so test that the variable might be a function w/ `subscribe` & `set` functions.\n *\n * @param {*} store - variable to test that might be a store.\n *\n * @returns {boolean} Whether the variable tested has the shape of a store.\n */\nfunction isWritableStore(store)\n{\n if (store === null || store === void 0) { return false; }\n\n switch (typeof store)\n {\n case 'function':\n case 'object':\n return typeof store.subscribe === 'function' && typeof store.set === 'function';\n }\n\n return false;\n}\n\n/**\n * Subscribes to the given store with the update function provided and ignores the first automatic\n * update. All future updates are dispatched to the update function.\n *\n * @param {import('svelte/store').Readable | import('svelte/store').Writable} store -\n * Store to subscribe to...\n *\n * @param {import('svelte/store').Updater} update - function to receive future updates.\n *\n * @returns {import('svelte/store').Unsubscriber} Store unsubscribe function.\n */\nfunction subscribeIgnoreFirst(store, update)\n{\n let firedFirst = false;\n\n return store.subscribe((value) => {\n if (!firedFirst)\n {\n firedFirst = true;\n }\n else {\n update(value);\n }\n })\n}\n\n/**\n * Subscribes to the given store with two update functions provided. The first function is invoked on the initial\n * subscription. All future updates are dispatched to the update function.\n *\n * @param {import('svelte/store').Readable | import('svelte/store').Writable} store -\n * Store to subscribe to...\n *\n * @param {import('svelte/store').Updater} first - Function to receive first update.\n *\n * @param {import('svelte/store').Updater} update - Function to receive future updates.\n *\n * @returns {import('svelte/store').Unsubscriber} Store unsubscribe function.\n */\nfunction subscribeFirstRest(store, first, update)\n{\n let firedFirst = false;\n\n return store.subscribe((value) => {\n if (!firedFirst)\n {\n firedFirst = true;\n first(value);\n }\n else {\n update(value);\n }\n })\n}\n\n// src/generator.ts\nfunction isSimpleDeriver(deriver) {\n return deriver.length < 2;\n}\nfunction generator(storage) {\n function readable(key, value, start) {\n return {\n subscribe: writable(key, value, start).subscribe\n };\n }\n function writable(key, value, start = noop) {\n function wrap_start(ogSet) {\n return start(function wrap_set(new_value) {\n if (storage) {\n storage.setItem(key, JSON.stringify(new_value));\n }\n return ogSet(new_value);\n });\n }\n if (storage) {\n const storageValue = storage.getItem(key);\n try {\n if (storageValue) {\n value = JSON.parse(storageValue);\n }\n } catch (err) {\n }\n storage.setItem(key, JSON.stringify(value));\n }\n const ogStore = writable$2(value, start ? wrap_start : void 0);\n function set(new_value) {\n if (storage) {\n storage.setItem(key, JSON.stringify(new_value));\n }\n ogStore.set(new_value);\n }\n function update(fn) {\n set(fn(get(ogStore)));\n }\n function subscribe(run, invalidate = noop) {\n return ogStore.subscribe(run, invalidate);\n }\n return {set, update, subscribe};\n }\n function derived(key, stores, fn, initial_value) {\n const single = !Array.isArray(stores);\n const stores_array = single ? [stores] : stores;\n if (storage && storage.getItem(key)) {\n try {\n initial_value = JSON.parse(storage.getItem(key));\n } catch (err) {\n }\n }\n return readable(key, 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 input = single ? values[0] : values;\n if (isSimpleDeriver(fn)) {\n set(fn(input));\n } else {\n const result = fn(input, set);\n cleanup = is_function(result) ? result : noop;\n }\n };\n const unsubscribers = stores_array.map((store, i) => store.subscribe((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 return {\n readable,\n writable,\n derived,\n get: get\n };\n}\n\n// src/local.ts\nvar storage$1 = typeof window !== \"undefined\" ? window.localStorage : void 0;\nvar g$1 = generator(storage$1);\nvar writable$1 = g$1.writable;\n\n/**\n * @typedef {import('svelte/store').Writable} LSStore - The backing Svelte store; a writable w/ get method attached.\n */\n\nclass LocalStorage\n{\n /**\n * @type {Map}\n */\n #stores = new Map();\n\n /**\n * Creates a new LSStore for the given key.\n *\n * @param {string} key - Key to lookup in stores map.\n *\n * @param {boolean} [defaultValue] - A default value to set for the store.\n *\n * @returns {LSStore} The new LSStore.\n */\n static #createStore(key, defaultValue = void 0)\n {\n try\n {\n const value = localStorage.getItem(key);\n if (value !== null) { defaultValue = value === 'undefined' ? void 0 : JSON.parse(value); }\n }\n catch (err) { /**/ }\n\n return writable$1(key, defaultValue);\n }\n\n /**\n * Gets a store from the LSStore Map or creates a new store for the key and a given default value.\n *\n * @param {string} key - Key to lookup in stores map.\n *\n * @param {boolean} [defaultValue] - A default value to set for the store.\n *\n * @returns {LSStore} The store for the given key.\n */\n #getStore(key, defaultValue = void 0)\n {\n let store = this.#stores.get(key);\n if (store === void 0)\n {\n store = LocalStorage.#createStore(key, defaultValue);\n this.#stores.set(key, store);\n }\n\n return store;\n }\n\n /**\n * Get value from the localStorage.\n *\n * @param {string} key - Key to lookup in localStorage.\n *\n * @param {*} [defaultValue] - A default value to return if key not present in session storage.\n *\n * @returns {*} Value from session storage or if not defined any default value provided.\n */\n getItem(key, defaultValue)\n {\n let value = defaultValue;\n\n const storageValue = localStorage.getItem(key);\n\n if (storageValue !== null)\n {\n try\n {\n value = storageValue === 'undefined' ? void 0 : JSON.parse(storageValue);\n } catch (err)\n {\n value = defaultValue;\n }\n }\n else if (defaultValue !== void 0)\n {\n try\n {\n const newValue = JSON.stringify(defaultValue);\n\n // If there is no existing storage value and defaultValue is defined the storage value needs to be set.\n localStorage.setItem(key, newValue === 'undefined' ? void 0 : newValue);\n }\n catch (err) { /* */ }\n }\n\n return value;\n }\n\n /**\n * Returns the backing Svelte store for the given key; potentially sets a default value if the key\n * is not already set.\n *\n * @param {string} key - Key to lookup in localStorage.\n *\n * @param {*} [defaultValue] - A default value to return if key not present in session storage.\n *\n * @returns {LSStore} The Svelte store for this key.\n */\n getStore(key, defaultValue)\n {\n return this.#getStore(key, defaultValue);\n }\n\n /**\n * Sets the value for the given key in localStorage.\n *\n * @param {string} key - Key to lookup in localStorage.\n *\n * @param {*} value - A value to set for this key.\n */\n setItem(key, value)\n {\n const store = this.#getStore(key);\n store.set(value);\n }\n\n /**\n * Convenience method to swap a boolean value stored in session storage.\n *\n * @param {string} key - Key to lookup in localStorage.\n *\n * @param {boolean} [defaultValue] - A default value to return if key not present in session storage.\n *\n * @returns {boolean} The boolean swap for the given key.\n */\n swapItemBoolean(key, defaultValue)\n {\n const store = this.#getStore(key, defaultValue);\n\n let currentValue = false;\n\n try\n {\n currentValue = !!JSON.parse(localStorage.getItem(key));\n }\n catch (err) { /**/ }\n\n const newValue = typeof currentValue === 'boolean' ? !currentValue : false;\n\n store.set(newValue);\n return newValue;\n }\n}\n\n// src/session.ts\nvar storage = typeof window !== \"undefined\" ? window.sessionStorage : void 0;\nvar g = generator(storage);\nvar writable = g.writable;\n\n/**\n * @typedef {import('svelte/store').Writable} SSStore - The backing Svelte store; a writable w/ get method attached.\n */\n\nclass SessionStorage\n{\n /**\n * @type {Map}\n */\n #stores = new Map();\n\n /**\n * Creates a new SSStore for the given key.\n *\n * @param {string} key - Key to lookup in stores map.\n *\n * @param {boolean} [defaultValue] - A default value to set for the store.\n *\n * @returns {SSStore} The new SSStore.\n */\n static #createStore(key, defaultValue = void 0)\n {\n try\n {\n const value = sessionStorage.getItem(key);\n if (value !== null) { defaultValue = value === 'undefined' ? void 0 : JSON.parse(value); }\n }\n catch (err) { /**/ }\n\n return writable(key, defaultValue);\n }\n\n /**\n * Gets a store from the SSStore Map or creates a new store for the key and a given default value.\n *\n * @param {string} key - Key to lookup in stores map.\n *\n * @param {boolean} [defaultValue] - A default value to set for the store.\n *\n * @returns {SSStore} The store for the given key.\n */\n #getStore(key, defaultValue = void 0)\n {\n let store = this.#stores.get(key);\n if (store === void 0)\n {\n store = SessionStorage.#createStore(key, defaultValue);\n this.#stores.set(key, store);\n }\n\n return store;\n }\n\n /**\n * Get value from the sessionStorage.\n *\n * @param {string} key - Key to lookup in sessionStorage.\n *\n * @param {*} [defaultValue] - A default value to return if key not present in session storage.\n *\n * @returns {*} Value from session storage or if not defined any default value provided.\n */\n getItem(key, defaultValue)\n {\n let value = defaultValue;\n\n const storageValue = sessionStorage.getItem(key);\n\n if (storageValue !== null)\n {\n try\n {\n value = storageValue === 'undefined' ? void 0 : JSON.parse(storageValue);\n } catch (err)\n {\n value = defaultValue;\n }\n }\n else if (defaultValue !== void 0)\n {\n try\n {\n const newValue = JSON.stringify(defaultValue);\n\n // If there is no existing storage value and defaultValue is defined the storage value needs to be set.\n sessionStorage.setItem(key, newValue === 'undefined' ? void 0 : newValue);\n }\n catch (err) { /* */ }\n }\n\n return value;\n }\n\n /**\n * Returns the backing Svelte store for the given key; potentially sets a default value if the key\n * is not already set.\n *\n * @param {string} key - Key to lookup in sessionStorage.\n *\n * @param {*} [defaultValue] - A default value to return if key not present in session storage.\n *\n * @returns {SSStore} The Svelte store for this key.\n */\n getStore(key, defaultValue)\n {\n return this.#getStore(key, defaultValue);\n }\n\n /**\n * Sets the value for the given key in sessionStorage.\n *\n * @param {string} key - Key to lookup in sessionStorage.\n *\n * @param {*} value - A value to set for this key.\n */\n setItem(key, value)\n {\n const store = this.#getStore(key);\n store.set(value);\n }\n\n /**\n * Convenience method to swap a boolean value stored in session storage.\n *\n * @param {string} key - Key to lookup in sessionStorage.\n *\n * @param {boolean} [defaultValue] - A default value to return if key not present in session storage.\n *\n * @returns {boolean} The boolean swap for the given key.\n */\n swapItemBoolean(key, defaultValue)\n {\n const store = this.#getStore(key, defaultValue);\n\n let currentValue = false;\n\n try\n {\n currentValue = !!JSON.parse(sessionStorage.getItem(key));\n }\n catch (err) { /**/ }\n\n const newValue = typeof currentValue === 'boolean' ? !currentValue : false;\n\n store.set(newValue);\n return newValue;\n }\n}\n\n/**\n * @external Store\n * @see [Svelte stores](https://svelte.dev/docs#component-format-script-4-prefix-stores-with-$-to-access-their-values-store-contract)\n */\n\n/**\n * Create a store similar to [Svelte's `derived`](https://svelte.dev/docs#run-time-svelte-store-writable),\n * but which has its own `set` and `update` methods and can send values back to the origin stores.\n * [Read more...](https://github.com/PixievoltNo1/svelte-writable-derived#default-export-writablederived)\n * \n * @param {Store|Store[]} origins One or more stores to derive from. Same as\n * [`derived`](https://svelte.dev/docs#run-time-svelte-store-writable)'s 1st parameter.\n * @param {!Function} derive The callback to determine the derived value. Same as\n * [`derived`](https://svelte.dev/docs#run-time-svelte-store-writable)'s 2nd parameter.\n * @param {!Function|{withOld: !Function}} reflect Called when the\n * derived store gets a new value via its `set` or `update` methods, and determines new values for\n * the origin stores. [Read more...](https://github.com/PixievoltNo1/svelte-writable-derived#new-parameter-reflect)\n * @param [initial] The new store's initial value. Same as\n * [`derived`](https://svelte.dev/docs#run-time-svelte-store-writable)'s 3rd parameter.\n * \n * @returns {Store} A writable store.\n */\nfunction writableDerived(origins, derive, reflect, initial) {\n\tvar childDerivedSetter, originValues, blockNextDerive = false;\n\tvar reflectOldValues = \"withOld\" in reflect;\n\tvar wrappedDerive = (got, set) => {\n\t\tchildDerivedSetter = set;\n\t\tif (reflectOldValues) {\n\t\t\toriginValues = got;\n\t\t}\n\t\tif (!blockNextDerive) {\n\t\t\tlet returned = derive(got, set);\n\t\t\tif (derive.length < 2) {\n\t\t\t\tset(returned);\n\t\t\t} else {\n\t\t\t\treturn returned;\n\t\t\t}\n\t\t}\n\t\tblockNextDerive = false;\n\t};\n\tvar childDerived = derived(origins, wrappedDerive, initial);\n\t\n\tvar singleOrigin = !Array.isArray(origins);\n\tvar sendUpstream = (setWith) => {\n\t\tif (singleOrigin) {\n\t\t\tblockNextDerive = true;\n\t\t\torigins.set(setWith);\n\t\t} else {\n\t\t\tsetWith.forEach( (value, i) => {\n\t\t\t\tblockNextDerive = true;\n\t\t\t\torigins[i].set(value);\n\t\t\t} );\n\t\t}\n\t\tblockNextDerive = false;\n\t};\n\tif (reflectOldValues) {\n\t\treflect = reflect.withOld;\n\t}\n\tvar reflectIsAsync = reflect.length >= (reflectOldValues ? 3 : 2);\n\tvar cleanup = null;\n\tfunction doReflect(reflecting) {\n\t\tif (cleanup) {\n\t\t\tcleanup();\n\t\t\tcleanup = null;\n\t\t}\n\n\t\tif (reflectOldValues) {\n\t\t\tvar returned = reflect(reflecting, originValues, sendUpstream);\n\t\t} else {\n\t\t\tvar returned = reflect(reflecting, sendUpstream);\n\t\t}\n\t\tif (reflectIsAsync) {\n\t\t\tif (typeof returned == \"function\") {\n\t\t\t\tcleanup = returned;\n\t\t\t}\n\t\t} else {\n\t\t\tsendUpstream(returned);\n\t\t}\n\t}\n\t\n\tvar tryingSet = false;\n\tfunction update(fn) {\n\t\tvar isUpdated, mutatedBySubscriptions, oldValue, newValue;\n\t\tif (tryingSet) {\n\t\t\tnewValue = fn( get(childDerived) );\n\t\t\tchildDerivedSetter(newValue);\n\t\t\treturn;\n\t\t}\n\t\tvar unsubscribe = childDerived.subscribe( (value) => {\n\t\t\tif (!tryingSet) {\n\t\t\t\toldValue = value;\n\t\t\t} else if (!isUpdated) {\n\t\t\t\tisUpdated = true;\n\t\t\t} else {\n\t\t\t\tmutatedBySubscriptions = true;\n\t\t\t}\n\t\t} );\n\t\tnewValue = fn(oldValue);\n\t\ttryingSet = true;\n\t\tchildDerivedSetter(newValue);\n\t\tunsubscribe();\n\t\ttryingSet = false;\n\t\tif (mutatedBySubscriptions) {\n\t\t\tnewValue = get(childDerived);\n\t\t}\n\t\tif (isUpdated) {\n\t\t\tdoReflect(newValue);\n\t\t}\n\t}\n\treturn {\n\t\tsubscribe: childDerived.subscribe,\n\t\tset(value) { update( () => value ); },\n\t\tupdate,\n\t};\n}\n\n/**\n * Create a store for a property value in an object contained in another store.\n * [Read more...](https://github.com/PixievoltNo1/svelte-writable-derived#named-export-propertystore)\n * \n * @param {Store} origin The store containing the object to get/set from.\n * @param {string|number|symbol|Array} propName The property to get/set, or a path of\n * properties in nested objects.\n *\n * @returns {Store} A writable store.\n */\nfunction propertyStore(origin, propName) {\n\tif (!Array.isArray(propName)) {\n\t\treturn writableDerived(\n\t\t\torigin,\n\t\t\t(object) => object[propName],\n\t\t\t{ withOld(reflecting, object) {\n\t\t\t\tobject[propName] = reflecting;\n\t\t\t\treturn object;\n\t\t\t} }\n\t\t);\n\t} else {\n\t\tlet props = propName.concat();\n\t\treturn writableDerived(\n\t\t\torigin,\n\t\t\t(value) => {\n\t\t\t\tfor (let i = 0; i < props.length; ++i) {\n\t\t\t\t\tvalue = value[ props[i] ];\n\t\t\t\t}\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t{ withOld(reflecting, object) {\n\t\t\t\tlet target = object;\n\t\t\t\tfor (let i = 0; i < props.length - 1; ++i) {\n\t\t\t\t\ttarget = target[ props[i] ];\n\t\t\t\t}\n\t\t\t\ttarget[ props[props.length - 1] ] = reflecting;\n\t\t\t\treturn object;\n\t\t\t} }\n\t\t);\n\t}\n}\n\n/**\n */\nclass EmbeddedStoreManager\n{\n /**\n * RegExp for detecting CRUD updates for renderContext.\n *\n * @type {RegExp}\n */\n static #renderContextRegex = /(create|delete|update)(\\w+)/;\n\n /**\n * @type {Map}\n */\n #name = new Map();\n\n /**\n * @type {foundry.abstract.Document[]}\n */\n #document;\n\n /**\n * @type {Set}\n */\n #embeddedNames = new Set();\n\n /**\n * @param {foundry.abstract.Document[]} document - The associated document holder.\n */\n constructor(document)\n {\n this.#document = document;\n\n this.handleDocChange();\n }\n\n /**\n * @template T\n *\n * @param {string} embeddedName -\n *\n * @param {import('@typhonjs-fvtt/svelte/store').OptionsDynMapCreate} options -\n *\n * @returns {import('@typhonjs-fvtt/svelte/store').DynMapReducer} DynMapReducer instance\n */\n create(embeddedName, options)\n {\n /** @type {foundry.abstract.Document} */\n const doc = this.#document[0];\n\n let collection = null;\n\n if (doc)\n {\n try\n {\n collection = doc.getEmbeddedCollection(embeddedName);\n }\n catch (err)\n {\n console.warn(`EmbeddedStoreManager.create error: No valid embedded collection for: ${embeddedName}`);\n }\n }\n\n let embeddedData;\n\n if (!this.#name.has(embeddedName))\n {\n embeddedData = {\n collection,\n stores: new Map()\n };\n\n this.#name.set(embeddedName, embeddedData);\n }\n else\n {\n embeddedData = this.#name.get(embeddedName);\n }\n\n /** @type {string} */\n let name;\n\n /** @type {import('@typhonjs-fvtt/svelte/store').DataOptions} */\n let rest = {};\n\n /** @type {import('@typhonjs-fvtt/svelte/store').IDynMapReducerCtor} */\n let ctor;\n\n if (typeof options === 'string')\n {\n name = options;\n ctor = DynMapReducer;\n }\n else if (typeof options === 'function' && hasPrototype(options, DynMapReducer))\n {\n ctor = options;\n }\n else if (typeof options === 'object' && options !== null)\n {\n ({ name, ctor = DynMapReducer, ...rest } = options);\n }\n else\n {\n throw new TypeError(`EmbeddedStoreManager.create error: 'options' does not conform to allowed parameters.`);\n }\n\n if (!hasPrototype(ctor, DynMapReducer))\n {\n throw new TypeError(`EmbeddedStoreManager.create error: 'ctor' is not a 'DynMapReducer'.`);\n }\n\n name = name ?? ctor?.name;\n\n if (typeof name !== 'string') { throw new TypeError(`EmbeddedStoreManager.create error: 'name' is not a string.`); }\n\n if (embeddedData.stores.has(name))\n {\n return embeddedData.stores.get(name);\n }\n else\n {\n const storeOptions = collection ? { data: collection, ...rest } : { ...rest };\n const store = new ctor(storeOptions);\n embeddedData.stores.set(name, store);\n return store;\n }\n }\n\n /**\n * Destroys and removes embedded collection stores. Invoking this method with no parameters destroys all stores.\n * Invoking with an embedded name destroys all stores for that particular collection. If you provide an embedded and\n * store name just that particular store is destroyed and removed.\n *\n * @param {string} [embeddedName] - Specific embedded collection name.\n *\n * @param {string} [storeName] - Specific store name.\n *\n * @returns {boolean} One or more stores destroyed?\n */\n destroy(embeddedName, storeName)\n {\n let count = 0;\n\n // Destroy all embedded stores\n if (embeddedName === void 0)\n {\n for (const embeddedData of this.#name.values())\n {\n embeddedData.collection = null;\n for (const store of embeddedData.stores.values())\n {\n store.destroy();\n count++;\n }\n }\n\n this.#name.clear();\n }\n else if (typeof embeddedName === 'string' && storeName === void 0)\n {\n const embeddedData = this.#name.get(embeddedName);\n if (embeddedData)\n {\n embeddedData.collection = null;\n for (const store of embeddedData.stores.values())\n {\n store.destroy();\n count++;\n }\n }\n\n this.#name.delete(embeddedName);\n }\n else if (typeof embeddedName === 'string' && storeName === 'string')\n {\n const embeddedData = this.#name.get(embeddedName);\n if (embeddedData)\n {\n const store = embeddedData.stores.get(storeName);\n if (store)\n {\n store.destroy();\n count++;\n }\n }\n }\n\n return count > 0;\n }\n\n /**\n * @template T\n *\n * @param {string} embeddedName -\n *\n * @param {string} storeName -\n *\n * @returns {import('@typhonjs-fvtt/svelte/store').DynMapReducer} DynMapReducer instance.\n */\n get(embeddedName, storeName)\n {\n if (!this.#name.has(embeddedName)) { return void 0; }\n\n return this.#name.get(embeddedName).stores.get(storeName);\n }\n\n /**\n * Updates all existing embedded collection stores with the associated embedded collection\n */\n handleDocChange()\n {\n const doc = this.#document[0];\n\n if (doc instanceof foundry.abstract.Document)\n {\n const existingEmbeddedNames = new Set(this.#name.keys());\n\n /** @type {string[]} */\n const embeddedNames = Object.keys(doc.constructor?.metadata?.embedded ?? []);\n\n // Remove all previously stored embedded name CRUD keys.\n this.#embeddedNames.clear();\n\n for (const embeddedName of embeddedNames)\n {\n // Remove processed embedded name from existingEmbeddedNames set.\n existingEmbeddedNames.delete(embeddedName);\n\n // Update CRUD keys.\n this.#embeddedNames.add(`create${embeddedName}`);\n this.#embeddedNames.add(`delete${embeddedName}`);\n this.#embeddedNames.add(`update${embeddedName}`);\n\n let collection = null;\n\n try\n {\n // Update any existing stores with the actual collection.\n collection = doc.getEmbeddedCollection(embeddedName);\n }\n catch (err)\n {\n console.warn(`EmbeddedStoreManager.handleDocUpdate error: No valid embedded collection for: ${\n embeddedName}`);\n }\n\n // Update EmbeddedData for new collection.\n const embeddedData = this.#name.get(embeddedName);\n if (embeddedData)\n {\n embeddedData.collection = collection;\n\n // Update all existing stores.\n for (const store of embeddedData.stores.values()) { store.setData(collection, true); }\n }\n }\n\n // Update all existing embedded collections with null data that aren't processed above.\n for (const embeddedName of existingEmbeddedNames)\n {\n const embeddedData = this.#name.get(embeddedName);\n if (embeddedData)\n {\n embeddedData.collection = null;\n\n for (const store of embeddedData.stores.values()) { store.setData(null, true); }\n }\n }\n }\n else // Reset all embedded reducer stores to null data.\n {\n this.#embeddedNames.clear();\n\n for (const embeddedData of this.#name.values())\n {\n embeddedData.collection = null;\n\n for (const store of embeddedData.stores.values()) { store.setData(null, true); }\n }\n }\n }\n\n /**\n * Handles updates to embedded stores parsing the render context for valid embedded store types.\n *\n * On create, delete, update parse the type being modified then force index updates for the embedded type.\n *\n * @param {string} renderContext - render context update from document.\n */\n handleUpdate(renderContext)\n {\n if (!this.#embeddedNames.has(renderContext)) { return; }\n\n const match = EmbeddedStoreManager.#renderContextRegex.exec(renderContext);\n\n if (match)\n {\n const embeddedName = match[2];\n if (!this.#name.has(embeddedName)) { return; }\n\n for (const store of this.#name.get(embeddedName).stores.values())\n {\n store.index.update(true);\n }\n }\n }\n}\n\n/**\n * @typedef {object} EmbeddedCollectionData\n *\n * @property {foundry.abstract.Collection} collection -\n *\n * @property {Map>} stores -\n */\n\n/**\n * Provides a wrapper implementing the Svelte store / subscriber protocol around any Document / ClientMixinDocument.\n * This makes documents reactive in a Svelte component, but otherwise provides subscriber functionality external to\n * Svelte.\n */\nclass TJSDocument\n{\n /**\n * @type {foundry.abstract.Document[]}\n */\n #document = [void 0];\n\n /**\n * @type {EmbeddedStoreManager}\n */\n #embeddedStoreManager;\n #embeddedAPI;\n\n /**\n * @type {string}\n */\n #uuidv4;\n\n /**\n * @type {TJSDocumentOptions}\n */\n #options = { delete: void 0 };\n\n #subscriptions = [];\n #updateOptions;\n\n /**\n * @param {foundry.abstract.Document | TJSDocumentOptions} [document] - Document to wrap or TJSDocumentOptions.\n *\n * @param {TJSDocumentOptions} [options] - TJSDocument options.\n */\n constructor(document, options = {})\n {\n this.#uuidv4 = `tjs-document-${uuidv4()}`;\n\n if (isPlainObject(document)) // Handle case when only options are passed into ctor.\n {\n this.setOptions(document);\n }\n else\n {\n this.setOptions(options);\n this.set(document);\n }\n }\n\n /**\n * @returns {EmbeddedAPI} Embedded store manager.\n */\n get embedded()\n {\n if (!this.#embeddedAPI)\n {\n this.#embeddedStoreManager = new EmbeddedStoreManager(this.#document);\n this.#embeddedAPI = {\n create: (embeddedName, options) => this.#embeddedStoreManager.create(embeddedName, options),\n destroy: (embeddedName, storeName) => this.#embeddedStoreManager.destroy(embeddedName, storeName),\n get: (embeddedName, storeName) => this.#embeddedStoreManager.get(embeddedName, storeName)\n };\n }\n\n return this.#embeddedAPI;\n }\n\n /**\n * Returns the options passed on last update.\n *\n * @returns {object} Last update options.\n */\n get updateOptions() { return this.#updateOptions ?? {}; }\n\n /**\n * Returns the UUID assigned to this store.\n *\n * @returns {string} UUID\n */\n get uuidv4() { return this.#uuidv4; }\n\n /**\n * Handles cleanup when the document is deleted. Invoking any optional delete function set in the constructor.\n *\n * @returns {Promise}\n */\n async #deleted()\n {\n const doc = this.#document[0];\n\n // Check to see if the document is still in the associated collection to determine if actually deleted.\n if (doc instanceof foundry.abstract.Document && !doc?.collection?.has(doc.id))\n {\n delete doc?.apps[this.#uuidv4];\n this.#setDocument(void 0);\n\n this.#updateSubscribers(false, { action: 'delete', data: void 0 });\n\n if (typeof this.#options.delete === 'function') { await this.#options.delete(); }\n\n this.#updateOptions = void 0;\n }\n }\n\n /**\n * Completely removes all internal subscribers, any optional delete callback, and unregisters from the\n * ClientDocumentMixin `apps` tracking object.\n */\n destroy()\n {\n const doc = this.#document[0];\n\n if (this.#embeddedStoreManager)\n {\n this.#embeddedStoreManager.destroy();\n this.#embeddedStoreManager = void 0;\n this.#embeddedAPI = void 0;\n }\n\n if (doc instanceof foundry.abstract.Document)\n {\n delete doc?.apps[this.#uuidv4];\n this.#setDocument(void 0);\n }\n\n this.#options.delete = void 0;\n this.#subscriptions.length = 0;\n }\n\n /**\n * @param {boolean} [force] - unused - signature from Foundry render function.\n *\n * @param {object} [options] - Options from render call; will have document update context.\n */\n #updateSubscribers(force = false, options = {}) // eslint-disable-line no-unused-vars\n {\n this.#updateOptions = options;\n\n const doc = this.#document[0];\n\n for (let cntr = 0; cntr < this.#subscriptions.length; cntr++) { this.#subscriptions[cntr](doc, options); }\n\n if (this.#embeddedStoreManager)\n {\n this.#embeddedStoreManager.handleUpdate(options.renderContext);\n }\n }\n\n /**\n * @returns {foundry.abstract.Document | undefined} Current document\n */\n get() { return this.#document[0]; }\n\n /**\n * @param {foundry.abstract.Document | undefined} document - New document to set.\n *\n * @param {object} [options] - New document update options to set.\n */\n set(document, options = {})\n {\n if (this.#document[0])\n {\n delete this.#document[0].apps[this.#uuidv4];\n }\n\n if (document !== void 0 && !(document instanceof foundry.abstract.Document))\n {\n throw new TypeError(`TJSDocument set error: 'document' is not a valid Document or undefined.`);\n }\n\n if (options === null || typeof options !== 'object')\n {\n throw new TypeError(`TJSDocument set error: 'options' is not an object.`);\n }\n\n if (document instanceof foundry.abstract.Document)\n {\n document.apps[this.#uuidv4] = {\n close: this.#deleted.bind(this),\n render: this.#updateSubscribers.bind(this)\n };\n }\n\n this.#setDocument(document);\n this.#updateOptions = options;\n this.#updateSubscribers();\n }\n\n /**\n *\n * @param {foundry.abstract.Document | undefined} doc -\n */\n #setDocument(doc)\n {\n this.#document[0] = doc;\n\n if (this.#embeddedStoreManager) { this.#embeddedStoreManager.handleDocChange(); }\n }\n\n /**\n * Potentially sets new document from data transfer object.\n *\n * @param {object} data - Document transfer data.\n *\n * @param {ParseDataTransferOptions & TJSDocumentOptions} [options] - Optional parameters.\n *\n * @returns {Promise} Returns true if new document set from data transfer blob.\n */\n async setFromDataTransfer(data, options)\n {\n return this.setFromUUID(getUUIDFromDataTransfer(data, options), options);\n }\n\n /**\n * Sets the document by Foundry UUID performing a lookup and setting the document if found.\n *\n * @param {string} uuid - A Foundry UUID to lookup.\n *\n * @param {TJSDocumentOptions} [options] - New document update options to set.\n *\n * @returns {Promise} True if successfully set document from UUID.\n */\n async setFromUUID(uuid, options = {})\n {\n if (typeof uuid !== 'string' || uuid.length === 0) { return false; }\n\n try\n {\n const doc = await globalThis.fromUuid(uuid);\n\n if (doc)\n {\n this.set(doc, options);\n return true;\n }\n }\n catch (err) { /**/ }\n\n return false;\n }\n\n /**\n * Sets options for this document wrapper / store.\n *\n * @param {TJSDocumentOptions} options - Options for TJSDocument.\n */\n setOptions(options)\n {\n if (!isObject(options))\n {\n throw new TypeError(`TJSDocument error: 'options' is not a plain object.`);\n }\n\n if (options.delete !== void 0 && typeof options.delete !== 'function')\n {\n throw new TypeError(`TJSDocument error: 'delete' attribute in options is not a function.`);\n }\n\n if (options.delete === void 0 || typeof options.delete === 'function')\n {\n this.#options.delete = options.delete;\n }\n }\n\n /**\n * @param {function(foundry.abstract.Document, object): void} handler - Callback function that is invoked on update / changes.\n *\n * @returns {(function(): void)} Unsubscribe function.\n */\n subscribe(handler)\n {\n this.#subscriptions.push(handler); // Add handler to the array of subscribers.\n\n const updateOptions = { action: 'subscribe', data: void 0 };\n\n handler(this.#document[0], updateOptions); // Call handler with current value and update options.\n\n // Return unsubscribe function.\n return () =>\n {\n const index = this.#subscriptions.findIndex((sub) => sub === handler);\n if (index >= 0) { this.#subscriptions.splice(index, 1); }\n };\n }\n}\n\n/**\n * @typedef {object} TJSDocumentOptions\n *\n * @property {Function} [delete] - Optional delete function to invoke when document is deleted.\n */\n\n/**\n * @typedef {object} EmbeddedAPI\n *\n * @property {(embeddedName: string, options: import('@typhonjs-fvtt/runtime/svelte/store').OptionsDynMapCreate) => import('@typhonjs-fvtt/runtime/svelte/store').DynMapReducer} create - Creates an embedded collection store.\n *\n * @property {(embeddedName?: string, storeName?: string) => boolean} destroy - Destroys one or more embedded collection stores.\n *\n * @property {(embeddedName: string, storeName: string) => import('@typhonjs-fvtt/runtime/svelte/store').DynMapReducer} get - Returns a specific existing embedded collection store.\n */\n\n/**\n * Provides a wrapper implementing the Svelte store / subscriber protocol around any DocumentCollection. This makes\n * document collections reactive in a Svelte component, but otherwise provides subscriber functionality external to\n * Svelte.\n *\n * @template {DocumentCollection} T\n */\nclass TJSDocumentCollection\n{\n #collection;\n #collectionCallback;\n #uuid;\n\n /**\n * @type {TJSDocumentCollectionOptions}\n */\n #options = { delete: void 0 };\n\n #subscriptions = [];\n #updateOptions;\n\n /**\n * @param {T|TJSDocumentCollectionOptions} [collection] - Collection to wrap or TJSDocumentCollectionOptions.\n *\n * @param {TJSDocumentCollectionOptions} [options] - TJSDocumentCollection options.\n */\n constructor(collection, options = {})\n {\n this.#uuid = `tjs-collection-${uuidv4()}`;\n\n if (isPlainObject(collection)) // Handle case when only options are passed into ctor.\n {\n this.setOptions(collection);\n }\n else\n {\n this.setOptions(options);\n this.set(collection);\n }\n }\n\n /**\n * Returns the options passed on last update.\n *\n * @returns {object} Last update options.\n */\n get updateOptions() { return this.#updateOptions ?? {}; }\n\n /**\n * Returns the UUID assigned to this store.\n *\n * @returns {*} UUID\n */\n get uuid() { return this.#uuid; }\n\n /**\n * Handles cleanup when the collection is deleted. Invoking any optional delete function set in the constructor.\n *\n * @returns {Promise}\n */\n async #deleted()\n {\n const collection = this.#collection;\n\n if (collection instanceof DocumentCollection)\n {\n const index = collection?.apps?.findIndex((sub) => sub === this.#collectionCallback);\n if (index >= 0) { collection?.apps?.splice(index, 1); }\n\n this.#collection = void 0;\n }\n\n this.#notify(false, { action: 'delete', documentType: collection.documentName, documents: [], data: [] });\n\n if (typeof this.#options.delete === 'function') { await this.#options.delete(); }\n\n this.#updateOptions = void 0;\n }\n\n /**\n * Completely removes all internal subscribers, any optional delete callback, and unregisters from the\n * DocumentCollection `apps` tracking array.\n */\n destroy()\n {\n const collection = this.#collection;\n\n if (collection instanceof DocumentCollection)\n {\n const index = collection?.apps?.findIndex((sub) => sub === this.#collectionCallback);\n if (index >= 0) { collection?.apps?.splice(index, 1); }\n\n this.#collection = void 0;\n }\n\n this.#options.delete = void 0;\n this.#subscriptions.length = 0;\n }\n\n /**\n * @param {boolean} [force] - unused - signature from Foundry render function.\n *\n * @param {object} [options] - Options from render call; will have collection update context.\n */\n #notify(force = false, options = {}) // eslint-disable-line no-unused-vars\n {\n this.#updateOptions = options;\n\n // Subscriptions are stored locally as on the browser Babel is still used for private class fields / Babel\n // support until 2023. IE not doing this will require several extra method calls otherwise.\n const subscriptions = this.#subscriptions;\n const collection = this.#collection;\n\n for (let cntr = 0; cntr < subscriptions.length; cntr++) { subscriptions[cntr](collection, options); }\n }\n\n /**\n * @returns {T | undefined} Current collection\n */\n get() { return this.#collection; }\n\n /**\n * @param {T | undefined} collection - New collection to set.\n *\n * @param {object} [options] - New collection update options to set.\n */\n set(collection, options = {})\n {\n if (this.#collection)\n {\n const index = this.#collection.apps.findIndex((sub) => sub === this.#collectionCallback);\n if (index >= 0) { this.#collection.apps.splice(index, 1); }\n\n this.#collectionCallback = void 0;\n }\n\n if (collection !== void 0 && !(collection instanceof DocumentCollection))\n {\n throw new TypeError(\n `TJSDocumentCollection set error: 'collection' is not a valid DocumentCollection or undefined.`);\n }\n\n if (!isObject(options))\n {\n throw new TypeError(`TJSDocument set error: 'options' is not an object.`);\n }\n\n if (collection instanceof DocumentCollection)\n {\n this.#collectionCallback = {\n close: this.#deleted.bind(this),\n render: this.#notify.bind(this)\n };\n\n collection?.apps?.push(this.#collectionCallback);\n }\n\n this.#collection = collection;\n this.#updateOptions = options;\n this.#notify();\n }\n\n /**\n * Sets options for this collection wrapper / store.\n *\n * @param {TJSDocumentCollectionOptions} options - Options for TJSDocumentCollection.\n */\n setOptions(options)\n {\n if (!isObject(options))\n {\n throw new TypeError(`TJSDocumentCollection error: 'options' is not an object.`);\n }\n\n if (options.delete !== void 0 && typeof options.delete !== 'function')\n {\n throw new TypeError(`TJSDocumentCollection error: 'delete' attribute in options is not a function.`);\n }\n\n if (options.delete === void 0 || typeof options.delete === 'function')\n {\n this.#options.delete = options.delete;\n }\n }\n\n /**\n * @param {function(T, object): void} handler - Callback function that is invoked on update / changes.\n *\n * @returns {(function(): void)} Unsubscribe function.\n */\n subscribe(handler)\n {\n this.#subscriptions.push(handler); // Add handler to the array of subscribers.\n\n const collection = this.#collection;\n\n const documentType = collection?.documentName ?? void 0;\n\n const updateOptions = { action: 'subscribe', documentType, documents: [], data: [] };\n\n handler(collection, updateOptions); // Call handler with current value and update options.\n\n // Return unsubscribe function.\n return () =>\n {\n const index = this.#subscriptions.findIndex((sub) => sub === handler);\n if (index >= 0) { this.#subscriptions.splice(index, 1); }\n };\n }\n}\n\n/**\n * @typedef TJSDocumentCollectionOptions\n *\n * @property {Function} [delete] - Optional delete function to invoke when document is deleted.\n */\n\nconst storeState = writable$2(void 0);\n\n/**\n * @type {GameState} Provides a Svelte store wrapping the Foundry runtime / global game state.\n */\nconst gameState = {\n subscribe: storeState.subscribe,\n get: () => game\n};\n\nObject.freeze(gameState);\n\nHooks.once('ready', () => storeState.set(game));\n\n/**\n * @typedef {import('svelte/store').Readable} GameState - Provides a Svelte store wrapping the Foundry `game` global variable. It is initialized\n * on the `ready` hook. You may use this store to access the global game state from a Svelte template. It is a read only\n * store and will receive no reactive updates during runtime.\n *\n * @property {import('svelte/store').Readable.subscribe} subscribe - Provides the Svelte store subscribe function.\n *\n * @property {Function} get - Provides a mechanism to directly access the Foundry game state without subscribing.\n */\n\n/**\n * Registers game settings and creates a backing Svelte store for each setting. It is possible to add multiple\n * `onChange` callbacks on registration.\n */\nclass TJSGameSettings\n{\n /**\n * @type {Map}\n */\n #stores = new Map();\n\n /**\n * Creates a new GSWritableStore for the given key.\n *\n * @param {string} initialValue - An initial value to set to new stores.\n *\n * @returns {GSWritableStore} The new GSWritableStore.\n */\n static #createStore(initialValue)\n {\n return writable$2(initialValue);\n }\n\n /**\n * Gets a store from the GSWritableStore Map or creates a new store for the key.\n *\n * @param {string} key - Key to lookup in stores map.\n *\n * @param {string} [initialValue] - An initial value to set to new stores.\n *\n * @returns {GSWritableStore} The store for the given key.\n */\n #getStore(key, initialValue)\n {\n let store = this.#stores.get(key);\n if (store === void 0)\n {\n store = TJSGameSettings.#createStore(initialValue);\n this.#stores.set(key, store);\n }\n\n return store;\n }\n\n /**\n * Returns a readable Game Settings store for the associated key.\n *\n * @param {string} key - Game setting key.\n *\n * @returns {GSReadableStore|undefined} The associated store for the given game setting key.\n */\n getReadableStore(key)\n {\n if (!this.#stores.has(key))\n {\n console.warn(`TJSGameSettings - getReadableStore: '${key}' is not a registered setting.`);\n return;\n }\n\n const store = this.#getStore(key);\n\n return { subscribe: store.subscribe, get: store.get };\n }\n\n /**\n * Returns a writable Game Settings store for the associated key.\n *\n * @param {string} key - Game setting key.\n *\n * @returns {GSWritableStore|undefined} The associated store for the given game setting key.\n */\n getStore(key)\n {\n return this.getWritableStore(key);\n }\n\n /**\n * Returns a writable Game Settings store for the associated key.\n *\n * @param {string} key - Game setting key.\n *\n * @returns {GSWritableStore|undefined} The associated store for the given game setting key.\n */\n getWritableStore(key)\n {\n if (!this.#stores.has(key))\n {\n console.warn(`TJSGameSettings - getWritableStore: '${key}' is not a registered setting.`);\n return;\n }\n\n return this.#getStore(key);\n }\n\n /**\n * @param {GameSetting} setting - A GameSetting instance to set to Foundry game settings.\n */\n register(setting)\n {\n if (typeof setting !== 'object')\n {\n throw new TypeError(`TJSGameSettings - register: setting is not an object.`);\n }\n\n if (typeof setting.options !== 'object')\n {\n throw new TypeError(`TJSGameSettings - register: 'options' attribute is not an object.`);\n }\n\n if (setting.store !== void 0 && !isWritableStore(setting.store))\n {\n throw new TypeError(\n `TJSGameSettings - register: 'setting.store' attribute is not a writable store.`);\n }\n\n // TODO: Remove deprecation warning and fully remove support for `moduleId` in a future TRL release.\n if (typeof setting.moduleId === 'string')\n {\n console.warn(\n `TJSGameSettings - register deprecation warning: 'moduleId' should be replaced with 'namespace'.`);\n console.warn(`'moduleId' will cease to work in a future update of TRL / TJSGameSettings.`);\n }\n\n // TODO: Remove nullish coalescing operator in a future TRL release.\n const namespace = setting.namespace ?? setting.moduleId;\n const key = setting.key;\n\n if (typeof namespace !== 'string')\n {\n throw new TypeError(`TJSGameSettings - register: 'namespace' attribute is not a string.`);\n }\n\n if (typeof key !== 'string')\n {\n throw new TypeError(`TJSGameSettings - register: 'key' attribute is not a string.`);\n }\n\n const store = setting.store;\n\n /**\n * @type {GameSettingOptions}\n */\n const options = setting.options;\n\n const onchangeFunctions = [];\n\n // When true prevents local store subscription from a loop when values are object data.\n let gateSet = false;\n\n // Provides an `onChange` callback to update the associated store.\n onchangeFunctions.push((value) =>\n {\n const callbackStore = this.#getStore(key);\n if (callbackStore && !gateSet)\n {\n gateSet = true;\n callbackStore.set(value);\n gateSet = false;\n }\n });\n\n // Handle loading any existing `onChange` callbacks.\n if (isIterable(options?.onChange))\n {\n for (const entry of options.onChange)\n {\n if (typeof entry === 'function') { onchangeFunctions.push(entry); }\n }\n }\n else if (typeof options.onChange === 'function')\n {\n onchangeFunctions.push(options.onChange);\n }\n\n // Provides the final onChange callback that iterates over all the stored onChange callbacks.\n const onChange = (value) =>\n {\n for (const entry of onchangeFunctions) { entry(value); }\n };\n\n game.settings.register(namespace, key, { ...options, onChange });\n\n // Set new store value with existing setting or default value.\n const targetStore = store ? store : this.#getStore(key, game.settings.get(namespace, key));\n\n // If a store instance is passed into register then initialize it with game settings data.\n if (store)\n {\n this.#stores.set(key, targetStore);\n store.set(game.settings.get(namespace, key));\n }\n\n // Subscribe to self to set associated game setting on updates after verifying that the new value does not match\n // existing game setting.\n subscribeIgnoreFirst(targetStore, async (value) =>\n {\n if (!gateSet && game.settings.get(namespace, key) !== value)\n {\n gateSet = true;\n await game.settings.set(namespace, key, value);\n }\n\n gateSet = false;\n });\n }\n\n /**\n * Registers multiple settings.\n *\n * @param {Iterable} settings - An iterable list of game setting configurations to register.\n */\n registerAll(settings)\n {\n if (!isIterable(settings)) { throw new TypeError(`TJSGameSettings - registerAll: settings is not iterable.`); }\n\n for (const entry of settings)\n {\n if (typeof entry !== 'object')\n {\n throw new TypeError(`TJSGameSettings - registerAll: entry in settings is not an object.`);\n }\n\n // TODO: Uncomment when deprecation for 'moduleId' is removed in future TRL release.\n // if (typeof entry.namespace !== 'string')\n // {\n // throw new TypeError(`TJSGameSettings - registerAll: entry in settings missing 'namespace' attribute.`);\n // }\n\n if (typeof entry.key !== 'string')\n {\n throw new TypeError(`TJSGameSettings - registerAll: entry in settings missing 'key' attribute.`);\n }\n\n if (typeof entry.options !== 'object')\n {\n throw new TypeError(`TJSGameSettings - registerAll: entry in settings missing 'options' attribute.`);\n }\n\n this.register(entry);\n }\n }\n}\n\nexport { DerivedArrayReducer, DerivedMapReducer, DynArrayReducer, DynMapReducer, LocalStorage, SessionStorage, TJSDocument, TJSDocumentCollection, TJSGameSettings, gameState, isReadableStore, isUpdatableStore, isWritableStore, propertyStore, subscribeFirstRest, subscribeIgnoreFirst, writableDerived };\n//# sourceMappingURL=index.js.map\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","/**\n * Performs linear interpolation between a start & end value by given amount between 0 - 1 inclusive.\n *\n * @param {number} start - Start value.\n *\n * @param {number} end - End value.\n *\n * @param {number} amount - Current amount between 0 - 1 inclusive.\n *\n * @returns {number} Linear interpolated value between start & end.\n */\nfunction lerp$5(start, end, amount)\n{\n return (1 - amount) * start + amount * end;\n}\n\n/**\n * Converts the given number from degrees to radians.\n *\n * @param {number} deg - Degree number to convert\n *\n * @returns {number} Degree as radians.\n */\nfunction degToRad(deg)\n{\n return deg * (Math.PI / 180.0);\n}\n\n/**\n * Converts the given number from radians to degrees.\n *\n * @param {number} rad - Radian number to convert.\n *\n * @returns {number} Degree as radians.\n */\nfunction radToDeg(rad)\n{\n return rad * (180.0 / Math.PI);\n}\n\n/**\n * Common utilities\n * @module glMatrix\n */\n// Configuration Constants\nvar EPSILON = 0.000001;\nvar ARRAY_TYPE = typeof Float32Array !== 'undefined' ? Float32Array : Array;\nvar RANDOM = Math.random;\n/**\n * Sets the type of array used when creating new vectors and matrices\n *\n * @param {Float32ArrayConstructor | ArrayConstructor} type Array type, such as Float32Array or Array\n */\n\nfunction setMatrixArrayType(type) {\n ARRAY_TYPE = type;\n}\nvar degree = Math.PI / 180;\n/**\n * Convert Degree To Radian\n *\n * @param {Number} a Angle in Degrees\n */\n\nfunction toRadian(a) {\n return a * degree;\n}\n/**\n * Tests whether or not the arguments have approximately the same value, within an absolute\n * or relative tolerance of glMatrix.EPSILON (an absolute tolerance is used for values less\n * than or equal to 1.0, and a relative tolerance is used for larger values)\n *\n * @param {Number} a The first number to test.\n * @param {Number} b The second number to test.\n * @returns {Boolean} True if the numbers are approximately equal, false otherwise.\n */\n\nfunction equals$9(a, b) {\n return Math.abs(a - b) <= EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));\n}\nif (!Math.hypot) Math.hypot = function () {\n var y = 0,\n i = arguments.length;\n\n while (i--) {\n y += arguments[i] * arguments[i];\n }\n\n return Math.sqrt(y);\n};\n\nvar common = /*#__PURE__*/Object.freeze({\n __proto__: null,\n EPSILON: EPSILON,\n get ARRAY_TYPE () { return ARRAY_TYPE; },\n RANDOM: RANDOM,\n setMatrixArrayType: setMatrixArrayType,\n toRadian: toRadian,\n equals: equals$9\n});\n\n/**\n * 2x2 Matrix\n * @module mat2\n */\n\n/**\n * Creates a new identity mat2\n *\n * @returns {mat2} a new 2x2 matrix\n */\n\nfunction create$8() {\n var out = new ARRAY_TYPE(4);\n\n if (ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n }\n\n out[0] = 1;\n out[3] = 1;\n return out;\n}\n/**\n * Creates a new mat2 initialized with values from an existing matrix\n *\n * @param {ReadonlyMat2} a matrix to clone\n * @returns {mat2} a new 2x2 matrix\n */\n\nfunction clone$8(a) {\n var out = new ARRAY_TYPE(4);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Copy the values from one mat2 to another\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\n\nfunction copy$8(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Set a mat2 to the identity matrix\n *\n * @param {mat2} out the receiving matrix\n * @returns {mat2} out\n */\n\nfunction identity$5(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n}\n/**\n * Create a new mat2 with the given values\n *\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m10 Component in column 1, row 0 position (index 2)\n * @param {Number} m11 Component in column 1, row 1 position (index 3)\n * @returns {mat2} out A new 2x2 matrix\n */\n\nfunction fromValues$8(m00, m01, m10, m11) {\n var out = new ARRAY_TYPE(4);\n out[0] = m00;\n out[1] = m01;\n out[2] = m10;\n out[3] = m11;\n return out;\n}\n/**\n * Set the components of a mat2 to the given values\n *\n * @param {mat2} out the receiving matrix\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m10 Component in column 1, row 0 position (index 2)\n * @param {Number} m11 Component in column 1, row 1 position (index 3)\n * @returns {mat2} out\n */\n\nfunction set$8(out, m00, m01, m10, m11) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m10;\n out[3] = m11;\n return out;\n}\n/**\n * Transpose the values of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\n\nfunction transpose$2(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache\n // some values\n if (out === a) {\n var a1 = a[1];\n out[1] = a[2];\n out[2] = a1;\n } else {\n out[0] = a[0];\n out[1] = a[2];\n out[2] = a[1];\n out[3] = a[3];\n }\n\n return out;\n}\n/**\n * Inverts a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\n\nfunction invert$5(out, a) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3]; // Calculate the determinant\n\n var det = a0 * a3 - a2 * a1;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = a3 * det;\n out[1] = -a1 * det;\n out[2] = -a2 * det;\n out[3] = a0 * det;\n return out;\n}\n/**\n * Calculates the adjugate of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the source matrix\n * @returns {mat2} out\n */\n\nfunction adjoint$2(out, a) {\n // Caching this value is nessecary if out == a\n var a0 = a[0];\n out[0] = a[3];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = a0;\n return out;\n}\n/**\n * Calculates the determinant of a mat2\n *\n * @param {ReadonlyMat2} a the source matrix\n * @returns {Number} determinant of a\n */\n\nfunction determinant$3(a) {\n return a[0] * a[3] - a[2] * a[1];\n}\n/**\n * Multiplies two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @returns {mat2} out\n */\n\nfunction multiply$8(out, a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n out[0] = a0 * b0 + a2 * b1;\n out[1] = a1 * b0 + a3 * b1;\n out[2] = a0 * b2 + a2 * b3;\n out[3] = a1 * b2 + a3 * b3;\n return out;\n}\n/**\n * Rotates a mat2 by the given angle\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\n\nfunction rotate$4(out, a, rad) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n out[0] = a0 * c + a2 * s;\n out[1] = a1 * c + a3 * s;\n out[2] = a0 * -s + a2 * c;\n out[3] = a1 * -s + a3 * c;\n return out;\n}\n/**\n * Scales the mat2 by the dimensions in the given vec2\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the matrix to rotate\n * @param {ReadonlyVec2} v the vec2 to scale the matrix by\n * @returns {mat2} out\n **/\n\nfunction scale$8(out, a, v) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var v0 = v[0],\n v1 = v[1];\n out[0] = a0 * v0;\n out[1] = a1 * v0;\n out[2] = a2 * v1;\n out[3] = a3 * v1;\n return out;\n}\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n * mat2.identity(dest);\n * mat2.rotate(dest, dest, rad);\n *\n * @param {mat2} out mat2 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\n\nfunction fromRotation$4(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n out[0] = c;\n out[1] = s;\n out[2] = -s;\n out[3] = c;\n return out;\n}\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n * mat2.identity(dest);\n * mat2.scale(dest, dest, vec);\n *\n * @param {mat2} out mat2 receiving operation result\n * @param {ReadonlyVec2} v Scaling vector\n * @returns {mat2} out\n */\n\nfunction fromScaling$3(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = v[1];\n return out;\n}\n/**\n * Returns a string representation of a mat2\n *\n * @param {ReadonlyMat2} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\n\nfunction str$8(a) {\n return \"mat2(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n/**\n * Returns Frobenius norm of a mat2\n *\n * @param {ReadonlyMat2} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\n\nfunction frob$3(a) {\n return Math.hypot(a[0], a[1], a[2], a[3]);\n}\n/**\n * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix\n * @param {ReadonlyMat2} L the lower triangular matrix\n * @param {ReadonlyMat2} D the diagonal matrix\n * @param {ReadonlyMat2} U the upper triangular matrix\n * @param {ReadonlyMat2} a the input matrix to factorize\n */\n\nfunction LDU(L, D, U, a) {\n L[2] = a[2] / a[0];\n U[0] = a[0];\n U[1] = a[1];\n U[3] = a[3] - L[2] * U[1];\n return [L, D, U];\n}\n/**\n * Adds two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @returns {mat2} out\n */\n\nfunction add$8(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n return out;\n}\n/**\n * Subtracts matrix b from matrix a\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @returns {mat2} out\n */\n\nfunction subtract$6(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n return out;\n}\n/**\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyMat2} a The first matrix.\n * @param {ReadonlyMat2} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nfunction exactEquals$8(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];\n}\n/**\n * Returns whether or not the matrices have approximately the same elements in the same position.\n *\n * @param {ReadonlyMat2} a The first matrix.\n * @param {ReadonlyMat2} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nfunction equals$8(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3));\n}\n/**\n * Multiply each element of the matrix by a scalar.\n *\n * @param {mat2} out the receiving matrix\n * @param {ReadonlyMat2} a the matrix to scale\n * @param {Number} b amount to scale the matrix's elements by\n * @returns {mat2} out\n */\n\nfunction multiplyScalar$3(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n return out;\n}\n/**\n * Adds two mat2's after multiplying each element of the second operand by a scalar value.\n *\n * @param {mat2} out the receiving vector\n * @param {ReadonlyMat2} a the first operand\n * @param {ReadonlyMat2} b the second operand\n * @param {Number} scale the amount to scale b's elements by before adding\n * @returns {mat2} out\n */\n\nfunction multiplyScalarAndAdd$3(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n return out;\n}\n/**\n * Alias for {@link mat2.multiply}\n * @function\n */\n\nvar mul$8 = multiply$8;\n/**\n * Alias for {@link mat2.subtract}\n * @function\n */\n\nvar sub$6 = subtract$6;\n\nvar mat2 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$8,\n clone: clone$8,\n copy: copy$8,\n identity: identity$5,\n fromValues: fromValues$8,\n set: set$8,\n transpose: transpose$2,\n invert: invert$5,\n adjoint: adjoint$2,\n determinant: determinant$3,\n multiply: multiply$8,\n rotate: rotate$4,\n scale: scale$8,\n fromRotation: fromRotation$4,\n fromScaling: fromScaling$3,\n str: str$8,\n frob: frob$3,\n LDU: LDU,\n add: add$8,\n subtract: subtract$6,\n exactEquals: exactEquals$8,\n equals: equals$8,\n multiplyScalar: multiplyScalar$3,\n multiplyScalarAndAdd: multiplyScalarAndAdd$3,\n mul: mul$8,\n sub: sub$6\n});\n\n/**\n * 2x3 Matrix\n * @module mat2d\n * @description\n * A mat2d contains six elements defined as:\n * \n * [a, b,\n * c, d,\n * tx, ty]\n * \n * This is a short form for the 3x3 matrix:\n * \n * [a, b, 0,\n * c, d, 0,\n * tx, ty, 1]\n * \n * The last column is ignored so the array is shorter and operations are faster.\n */\n\n/**\n * Creates a new identity mat2d\n *\n * @returns {mat2d} a new 2x3 matrix\n */\n\nfunction create$7() {\n var out = new ARRAY_TYPE(6);\n\n if (ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[4] = 0;\n out[5] = 0;\n }\n\n out[0] = 1;\n out[3] = 1;\n return out;\n}\n/**\n * Creates a new mat2d initialized with values from an existing matrix\n *\n * @param {ReadonlyMat2d} a matrix to clone\n * @returns {mat2d} a new 2x3 matrix\n */\n\nfunction clone$7(a) {\n var out = new ARRAY_TYPE(6);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n return out;\n}\n/**\n * Copy the values from one mat2d to another\n *\n * @param {mat2d} out the receiving matrix\n * @param {ReadonlyMat2d} a the source matrix\n * @returns {mat2d} out\n */\n\nfunction copy$7(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n return out;\n}\n/**\n * Set a mat2d to the identity matrix\n *\n * @param {mat2d} out the receiving matrix\n * @returns {mat2d} out\n */\n\nfunction identity$4(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n out[4] = 0;\n out[5] = 0;\n return out;\n}\n/**\n * Create a new mat2d with the given values\n *\n * @param {Number} a Component A (index 0)\n * @param {Number} b Component B (index 1)\n * @param {Number} c Component C (index 2)\n * @param {Number} d Component D (index 3)\n * @param {Number} tx Component TX (index 4)\n * @param {Number} ty Component TY (index 5)\n * @returns {mat2d} A new mat2d\n */\n\nfunction fromValues$7(a, b, c, d, tx, ty) {\n var out = new ARRAY_TYPE(6);\n out[0] = a;\n out[1] = b;\n out[2] = c;\n out[3] = d;\n out[4] = tx;\n out[5] = ty;\n return out;\n}\n/**\n * Set the components of a mat2d to the given values\n *\n * @param {mat2d} out the receiving matrix\n * @param {Number} a Component A (index 0)\n * @param {Number} b Component B (index 1)\n * @param {Number} c Component C (index 2)\n * @param {Number} d Component D (index 3)\n * @param {Number} tx Component TX (index 4)\n * @param {Number} ty Component TY (index 5)\n * @returns {mat2d} out\n */\n\nfunction set$7(out, a, b, c, d, tx, ty) {\n out[0] = a;\n out[1] = b;\n out[2] = c;\n out[3] = d;\n out[4] = tx;\n out[5] = ty;\n return out;\n}\n/**\n * Inverts a mat2d\n *\n * @param {mat2d} out the receiving matrix\n * @param {ReadonlyMat2d} a the source matrix\n * @returns {mat2d} out\n */\n\nfunction invert$4(out, a) {\n var aa = a[0],\n ab = a[1],\n ac = a[2],\n ad = a[3];\n var atx = a[4],\n aty = a[5];\n var det = aa * ad - ab * ac;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = ad * det;\n out[1] = -ab * det;\n out[2] = -ac * det;\n out[3] = aa * det;\n out[4] = (ac * aty - ad * atx) * det;\n out[5] = (ab * atx - aa * aty) * det;\n return out;\n}\n/**\n * Calculates the determinant of a mat2d\n *\n * @param {ReadonlyMat2d} a the source matrix\n * @returns {Number} determinant of a\n */\n\nfunction determinant$2(a) {\n return a[0] * a[3] - a[1] * a[2];\n}\n/**\n * Multiplies two mat2d's\n *\n * @param {mat2d} out the receiving matrix\n * @param {ReadonlyMat2d} a the first operand\n * @param {ReadonlyMat2d} b the second operand\n * @returns {mat2d} out\n */\n\nfunction multiply$7(out, a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5];\n out[0] = a0 * b0 + a2 * b1;\n out[1] = a1 * b0 + a3 * b1;\n out[2] = a0 * b2 + a2 * b3;\n out[3] = a1 * b2 + a3 * b3;\n out[4] = a0 * b4 + a2 * b5 + a4;\n out[5] = a1 * b4 + a3 * b5 + a5;\n return out;\n}\n/**\n * Rotates a mat2d by the given angle\n *\n * @param {mat2d} out the receiving matrix\n * @param {ReadonlyMat2d} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2d} out\n */\n\nfunction rotate$3(out, a, rad) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5];\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n out[0] = a0 * c + a2 * s;\n out[1] = a1 * c + a3 * s;\n out[2] = a0 * -s + a2 * c;\n out[3] = a1 * -s + a3 * c;\n out[4] = a4;\n out[5] = a5;\n return out;\n}\n/**\n * Scales the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {ReadonlyMat2d} a the matrix to translate\n * @param {ReadonlyVec2} v the vec2 to scale the matrix by\n * @returns {mat2d} out\n **/\n\nfunction scale$7(out, a, v) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5];\n var v0 = v[0],\n v1 = v[1];\n out[0] = a0 * v0;\n out[1] = a1 * v0;\n out[2] = a2 * v1;\n out[3] = a3 * v1;\n out[4] = a4;\n out[5] = a5;\n return out;\n}\n/**\n * Translates the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {ReadonlyMat2d} a the matrix to translate\n * @param {ReadonlyVec2} v the vec2 to translate the matrix by\n * @returns {mat2d} out\n **/\n\nfunction translate$3(out, a, v) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5];\n var v0 = v[0],\n v1 = v[1];\n out[0] = a0;\n out[1] = a1;\n out[2] = a2;\n out[3] = a3;\n out[4] = a0 * v0 + a2 * v1 + a4;\n out[5] = a1 * v0 + a3 * v1 + a5;\n return out;\n}\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n * mat2d.identity(dest);\n * mat2d.rotate(dest, dest, rad);\n *\n * @param {mat2d} out mat2d receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2d} out\n */\n\nfunction fromRotation$3(out, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad);\n out[0] = c;\n out[1] = s;\n out[2] = -s;\n out[3] = c;\n out[4] = 0;\n out[5] = 0;\n return out;\n}\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n * mat2d.identity(dest);\n * mat2d.scale(dest, dest, vec);\n *\n * @param {mat2d} out mat2d receiving operation result\n * @param {ReadonlyVec2} v Scaling vector\n * @returns {mat2d} out\n */\n\nfunction fromScaling$2(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = v[1];\n out[4] = 0;\n out[5] = 0;\n return out;\n}\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n * mat2d.identity(dest);\n * mat2d.translate(dest, dest, vec);\n *\n * @param {mat2d} out mat2d receiving operation result\n * @param {ReadonlyVec2} v Translation vector\n * @returns {mat2d} out\n */\n\nfunction fromTranslation$3(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n out[4] = v[0];\n out[5] = v[1];\n return out;\n}\n/**\n * Returns a string representation of a mat2d\n *\n * @param {ReadonlyMat2d} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\n\nfunction str$7(a) {\n return \"mat2d(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \")\";\n}\n/**\n * Returns Frobenius norm of a mat2d\n *\n * @param {ReadonlyMat2d} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\n\nfunction frob$2(a) {\n return Math.hypot(a[0], a[1], a[2], a[3], a[4], a[5], 1);\n}\n/**\n * Adds two mat2d's\n *\n * @param {mat2d} out the receiving matrix\n * @param {ReadonlyMat2d} a the first operand\n * @param {ReadonlyMat2d} b the second operand\n * @returns {mat2d} out\n */\n\nfunction add$7(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n return out;\n}\n/**\n * Subtracts matrix b from matrix a\n *\n * @param {mat2d} out the receiving matrix\n * @param {ReadonlyMat2d} a the first operand\n * @param {ReadonlyMat2d} b the second operand\n * @returns {mat2d} out\n */\n\nfunction subtract$5(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n return out;\n}\n/**\n * Multiply each element of the matrix by a scalar.\n *\n * @param {mat2d} out the receiving matrix\n * @param {ReadonlyMat2d} a the matrix to scale\n * @param {Number} b amount to scale the matrix's elements by\n * @returns {mat2d} out\n */\n\nfunction multiplyScalar$2(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n return out;\n}\n/**\n * Adds two mat2d's after multiplying each element of the second operand by a scalar value.\n *\n * @param {mat2d} out the receiving vector\n * @param {ReadonlyMat2d} a the first operand\n * @param {ReadonlyMat2d} b the second operand\n * @param {Number} scale the amount to scale b's elements by before adding\n * @returns {mat2d} out\n */\n\nfunction multiplyScalarAndAdd$2(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n return out;\n}\n/**\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyMat2d} a The first matrix.\n * @param {ReadonlyMat2d} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nfunction exactEquals$7(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5];\n}\n/**\n * Returns whether or not the matrices have approximately the same elements in the same position.\n *\n * @param {ReadonlyMat2d} a The first matrix.\n * @param {ReadonlyMat2d} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nfunction equals$7(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5];\n return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5));\n}\n/**\n * Alias for {@link mat2d.multiply}\n * @function\n */\n\nvar mul$7 = multiply$7;\n/**\n * Alias for {@link mat2d.subtract}\n * @function\n */\n\nvar sub$5 = subtract$5;\n\nvar mat2d = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$7,\n clone: clone$7,\n copy: copy$7,\n identity: identity$4,\n fromValues: fromValues$7,\n set: set$7,\n invert: invert$4,\n determinant: determinant$2,\n multiply: multiply$7,\n rotate: rotate$3,\n scale: scale$7,\n translate: translate$3,\n fromRotation: fromRotation$3,\n fromScaling: fromScaling$2,\n fromTranslation: fromTranslation$3,\n str: str$7,\n frob: frob$2,\n add: add$7,\n subtract: subtract$5,\n multiplyScalar: multiplyScalar$2,\n multiplyScalarAndAdd: multiplyScalarAndAdd$2,\n exactEquals: exactEquals$7,\n equals: equals$7,\n mul: mul$7,\n sub: sub$5\n});\n\n/**\n * 3x3 Matrix\n * @module mat3\n */\n\n/**\n * Creates a new identity mat3\n *\n * @returns {mat3} a new 3x3 matrix\n */\n\nfunction create$6() {\n var out = new ARRAY_TYPE(9);\n\n if (ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n }\n\n out[0] = 1;\n out[4] = 1;\n out[8] = 1;\n return out;\n}\n/**\n * Copies the upper-left 3x3 values into the given mat3.\n *\n * @param {mat3} out the receiving 3x3 matrix\n * @param {ReadonlyMat4} a the source 4x4 matrix\n * @returns {mat3} out\n */\n\nfunction fromMat4$1(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[4];\n out[4] = a[5];\n out[5] = a[6];\n out[6] = a[8];\n out[7] = a[9];\n out[8] = a[10];\n return out;\n}\n/**\n * Creates a new mat3 initialized with values from an existing matrix\n *\n * @param {ReadonlyMat3} a matrix to clone\n * @returns {mat3} a new 3x3 matrix\n */\n\nfunction clone$6(a) {\n var out = new ARRAY_TYPE(9);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\n * Copy the values from one mat3 to another\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\n\nfunction copy$6(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\n * Create a new mat3 with the given values\n *\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\n * @returns {mat3} A new mat3\n */\n\nfunction fromValues$6(m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n var out = new ARRAY_TYPE(9);\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\n * Set the components of a mat3 to the given values\n *\n * @param {mat3} out the receiving matrix\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\n * @returns {mat3} out\n */\n\nfunction set$6(out, m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\n * Set a mat3 to the identity matrix\n *\n * @param {mat3} out the receiving matrix\n * @returns {mat3} out\n */\n\nfunction identity$3(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\n * Transpose the values of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\n\nfunction transpose$1(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1],\n a02 = a[2],\n a12 = a[5];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a01;\n out[5] = a[7];\n out[6] = a02;\n out[7] = a12;\n } else {\n out[0] = a[0];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a[1];\n out[4] = a[4];\n out[5] = a[7];\n out[6] = a[2];\n out[7] = a[5];\n out[8] = a[8];\n }\n\n return out;\n}\n/**\n * Inverts a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\n\nfunction invert$3(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n var b01 = a22 * a11 - a12 * a21;\n var b11 = -a22 * a10 + a12 * a20;\n var b21 = a21 * a10 - a11 * a20; // Calculate the determinant\n\n var det = a00 * b01 + a01 * b11 + a02 * b21;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = b01 * det;\n out[1] = (-a22 * a01 + a02 * a21) * det;\n out[2] = (a12 * a01 - a02 * a11) * det;\n out[3] = b11 * det;\n out[4] = (a22 * a00 - a02 * a20) * det;\n out[5] = (-a12 * a00 + a02 * a10) * det;\n out[6] = b21 * det;\n out[7] = (-a21 * a00 + a01 * a20) * det;\n out[8] = (a11 * a00 - a01 * a10) * det;\n return out;\n}\n/**\n * Calculates the adjugate of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\n\nfunction adjoint$1(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n out[0] = a11 * a22 - a12 * a21;\n out[1] = a02 * a21 - a01 * a22;\n out[2] = a01 * a12 - a02 * a11;\n out[3] = a12 * a20 - a10 * a22;\n out[4] = a00 * a22 - a02 * a20;\n out[5] = a02 * a10 - a00 * a12;\n out[6] = a10 * a21 - a11 * a20;\n out[7] = a01 * a20 - a00 * a21;\n out[8] = a00 * a11 - a01 * a10;\n return out;\n}\n/**\n * Calculates the determinant of a mat3\n *\n * @param {ReadonlyMat3} a the source matrix\n * @returns {Number} determinant of a\n */\n\nfunction determinant$1(a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20);\n}\n/**\n * Multiplies two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @returns {mat3} out\n */\n\nfunction multiply$6(out, a, b) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n var b00 = b[0],\n b01 = b[1],\n b02 = b[2];\n var b10 = b[3],\n b11 = b[4],\n b12 = b[5];\n var b20 = b[6],\n b21 = b[7],\n b22 = b[8];\n out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n return out;\n}\n/**\n * Translate a mat3 by the given vector\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to translate\n * @param {ReadonlyVec2} v vector to translate by\n * @returns {mat3} out\n */\n\nfunction translate$2(out, a, v) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a10 = a[3],\n a11 = a[4],\n a12 = a[5],\n a20 = a[6],\n a21 = a[7],\n a22 = a[8],\n x = v[0],\n y = v[1];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a10;\n out[4] = a11;\n out[5] = a12;\n out[6] = x * a00 + y * a10 + a20;\n out[7] = x * a01 + y * a11 + a21;\n out[8] = x * a02 + y * a12 + a22;\n return out;\n}\n/**\n * Rotates a mat3 by the given angle\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\n\nfunction rotate$2(out, a, rad) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a10 = a[3],\n a11 = a[4],\n a12 = a[5],\n a20 = a[6],\n a21 = a[7],\n a22 = a[8],\n s = Math.sin(rad),\n c = Math.cos(rad);\n out[0] = c * a00 + s * a10;\n out[1] = c * a01 + s * a11;\n out[2] = c * a02 + s * a12;\n out[3] = c * a10 - s * a00;\n out[4] = c * a11 - s * a01;\n out[5] = c * a12 - s * a02;\n out[6] = a20;\n out[7] = a21;\n out[8] = a22;\n return out;\n}\n/**\n * Scales the mat3 by the dimensions in the given vec2\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to rotate\n * @param {ReadonlyVec2} v the vec2 to scale the matrix by\n * @returns {mat3} out\n **/\n\nfunction scale$6(out, a, v) {\n var x = v[0],\n y = v[1];\n out[0] = x * a[0];\n out[1] = x * a[1];\n out[2] = x * a[2];\n out[3] = y * a[3];\n out[4] = y * a[4];\n out[5] = y * a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n * mat3.identity(dest);\n * mat3.translate(dest, dest, vec);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyVec2} v Translation vector\n * @returns {mat3} out\n */\n\nfunction fromTranslation$2(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = v[0];\n out[7] = v[1];\n out[8] = 1;\n return out;\n}\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n * mat3.identity(dest);\n * mat3.rotate(dest, dest, rad);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\n\nfunction fromRotation$2(out, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad);\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = -s;\n out[4] = c;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n * mat3.identity(dest);\n * mat3.scale(dest, dest, vec);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyVec2} v Scaling vector\n * @returns {mat3} out\n */\n\nfunction fromScaling$1(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = v[1];\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\n * Copies the values from a mat2d into a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat2d} a the matrix to copy\n * @returns {mat3} out\n **/\n\nfunction fromMat2d(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = 0;\n out[3] = a[2];\n out[4] = a[3];\n out[5] = 0;\n out[6] = a[4];\n out[7] = a[5];\n out[8] = 1;\n return out;\n}\n/**\n * Calculates a 3x3 matrix from the given quaternion\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyQuat} q Quaternion to create matrix from\n *\n * @returns {mat3} out\n */\n\nfunction fromQuat$1(out, q) {\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var yx = y * x2;\n var yy = y * y2;\n var zx = z * x2;\n var zy = z * y2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - yy - zz;\n out[3] = yx - wz;\n out[6] = zx + wy;\n out[1] = yx + wz;\n out[4] = 1 - xx - zz;\n out[7] = zy - wx;\n out[2] = zx - wy;\n out[5] = zy + wx;\n out[8] = 1 - xx - yy;\n return out;\n}\n/**\n * Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyMat4} a Mat4 to derive the normal matrix from\n *\n * @returns {mat3} out\n */\n\nfunction normalFromMat4(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n return out;\n}\n/**\n * Generates a 2D projection matrix with the given bounds\n *\n * @param {mat3} out mat3 frustum matrix will be written into\n * @param {number} width Width of your gl context\n * @param {number} height Height of gl context\n * @returns {mat3} out\n */\n\nfunction projection(out, width, height) {\n out[0] = 2 / width;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = -2 / height;\n out[5] = 0;\n out[6] = -1;\n out[7] = 1;\n out[8] = 1;\n return out;\n}\n/**\n * Returns a string representation of a mat3\n *\n * @param {ReadonlyMat3} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\n\nfunction str$6(a) {\n return \"mat3(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \", \" + a[6] + \", \" + a[7] + \", \" + a[8] + \")\";\n}\n/**\n * Returns Frobenius norm of a mat3\n *\n * @param {ReadonlyMat3} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\n\nfunction frob$1(a) {\n return Math.hypot(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8]);\n}\n/**\n * Adds two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @returns {mat3} out\n */\n\nfunction add$6(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n out[8] = a[8] + b[8];\n return out;\n}\n/**\n * Subtracts matrix b from matrix a\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @returns {mat3} out\n */\n\nfunction subtract$4(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n out[6] = a[6] - b[6];\n out[7] = a[7] - b[7];\n out[8] = a[8] - b[8];\n return out;\n}\n/**\n * Multiply each element of the matrix by a scalar.\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to scale\n * @param {Number} b amount to scale the matrix's elements by\n * @returns {mat3} out\n */\n\nfunction multiplyScalar$1(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n out[8] = a[8] * b;\n return out;\n}\n/**\n * Adds two mat3's after multiplying each element of the second operand by a scalar value.\n *\n * @param {mat3} out the receiving vector\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @param {Number} scale the amount to scale b's elements by before adding\n * @returns {mat3} out\n */\n\nfunction multiplyScalarAndAdd$1(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n out[6] = a[6] + b[6] * scale;\n out[7] = a[7] + b[7] * scale;\n out[8] = a[8] + b[8] * scale;\n return out;\n}\n/**\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyMat3} a The first matrix.\n * @param {ReadonlyMat3} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nfunction exactEquals$6(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5] && a[6] === b[6] && a[7] === b[7] && a[8] === b[8];\n}\n/**\n * Returns whether or not the matrices have approximately the same elements in the same position.\n *\n * @param {ReadonlyMat3} a The first matrix.\n * @param {ReadonlyMat3} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nfunction equals$6(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5],\n a6 = a[6],\n a7 = a[7],\n a8 = a[8];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8];\n return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) && Math.abs(a6 - b6) <= EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) && Math.abs(a7 - b7) <= EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7)) && Math.abs(a8 - b8) <= EPSILON * Math.max(1.0, Math.abs(a8), Math.abs(b8));\n}\n/**\n * Alias for {@link mat3.multiply}\n * @function\n */\n\nvar mul$6 = multiply$6;\n/**\n * Alias for {@link mat3.subtract}\n * @function\n */\n\nvar sub$4 = subtract$4;\n\nvar mat3 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$6,\n fromMat4: fromMat4$1,\n clone: clone$6,\n copy: copy$6,\n fromValues: fromValues$6,\n set: set$6,\n identity: identity$3,\n transpose: transpose$1,\n invert: invert$3,\n adjoint: adjoint$1,\n determinant: determinant$1,\n multiply: multiply$6,\n translate: translate$2,\n rotate: rotate$2,\n scale: scale$6,\n fromTranslation: fromTranslation$2,\n fromRotation: fromRotation$2,\n fromScaling: fromScaling$1,\n fromMat2d: fromMat2d,\n fromQuat: fromQuat$1,\n normalFromMat4: normalFromMat4,\n projection: projection,\n str: str$6,\n frob: frob$1,\n add: add$6,\n subtract: subtract$4,\n multiplyScalar: multiplyScalar$1,\n multiplyScalarAndAdd: multiplyScalarAndAdd$1,\n exactEquals: exactEquals$6,\n equals: equals$6,\n mul: mul$6,\n sub: sub$4\n});\n\n/**\n * 4x4 Matrix Format: column-major, when typed out it looks like row-major The matrices are being post multiplied.\n * @module mat4\n */\n\n/**\n * Creates a new identity mat4\n *\n * @returns {mat4} a new 4x4 matrix\n */\n\nfunction create$5() {\n var out = new ARRAY_TYPE(16);\n\n if (ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n }\n\n out[0] = 1;\n out[5] = 1;\n out[10] = 1;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a new mat4 initialized with values from an existing matrix\n *\n * @param {ReadonlyMat4} a matrix to clone\n * @returns {mat4} a new 4x4 matrix\n */\n\nfunction clone$5(a) {\n var out = new ARRAY_TYPE(16);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\n * Copy the values from one mat4 to another\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the source matrix\n * @returns {mat4} out\n */\n\nfunction copy$5(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\n * Create a new mat4 with the given values\n *\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m03 Component in column 0, row 3 position (index 3)\n * @param {Number} m10 Component in column 1, row 0 position (index 4)\n * @param {Number} m11 Component in column 1, row 1 position (index 5)\n * @param {Number} m12 Component in column 1, row 2 position (index 6)\n * @param {Number} m13 Component in column 1, row 3 position (index 7)\n * @param {Number} m20 Component in column 2, row 0 position (index 8)\n * @param {Number} m21 Component in column 2, row 1 position (index 9)\n * @param {Number} m22 Component in column 2, row 2 position (index 10)\n * @param {Number} m23 Component in column 2, row 3 position (index 11)\n * @param {Number} m30 Component in column 3, row 0 position (index 12)\n * @param {Number} m31 Component in column 3, row 1 position (index 13)\n * @param {Number} m32 Component in column 3, row 2 position (index 14)\n * @param {Number} m33 Component in column 3, row 3 position (index 15)\n * @returns {mat4} A new mat4\n */\n\nfunction fromValues$5(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n var out = new ARRAY_TYPE(16);\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m03;\n out[4] = m10;\n out[5] = m11;\n out[6] = m12;\n out[7] = m13;\n out[8] = m20;\n out[9] = m21;\n out[10] = m22;\n out[11] = m23;\n out[12] = m30;\n out[13] = m31;\n out[14] = m32;\n out[15] = m33;\n return out;\n}\n/**\n * Set the components of a mat4 to the given values\n *\n * @param {mat4} out the receiving matrix\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m03 Component in column 0, row 3 position (index 3)\n * @param {Number} m10 Component in column 1, row 0 position (index 4)\n * @param {Number} m11 Component in column 1, row 1 position (index 5)\n * @param {Number} m12 Component in column 1, row 2 position (index 6)\n * @param {Number} m13 Component in column 1, row 3 position (index 7)\n * @param {Number} m20 Component in column 2, row 0 position (index 8)\n * @param {Number} m21 Component in column 2, row 1 position (index 9)\n * @param {Number} m22 Component in column 2, row 2 position (index 10)\n * @param {Number} m23 Component in column 2, row 3 position (index 11)\n * @param {Number} m30 Component in column 3, row 0 position (index 12)\n * @param {Number} m31 Component in column 3, row 1 position (index 13)\n * @param {Number} m32 Component in column 3, row 2 position (index 14)\n * @param {Number} m33 Component in column 3, row 3 position (index 15)\n * @returns {mat4} out\n */\n\nfunction set$5(out, m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m03;\n out[4] = m10;\n out[5] = m11;\n out[6] = m12;\n out[7] = m13;\n out[8] = m20;\n out[9] = m21;\n out[10] = m22;\n out[11] = m23;\n out[12] = m30;\n out[13] = m31;\n out[14] = m32;\n out[15] = m33;\n return out;\n}\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\n\nfunction identity$2(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Transpose the values of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the source matrix\n * @returns {mat4} out\n */\n\nfunction transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a12 = a[6],\n a13 = a[7];\n var a23 = a[11];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a01;\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a02;\n out[9] = a12;\n out[11] = a[14];\n out[12] = a03;\n out[13] = a13;\n out[14] = a23;\n } else {\n out[0] = a[0];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a[1];\n out[5] = a[5];\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a[2];\n out[9] = a[6];\n out[10] = a[10];\n out[11] = a[14];\n out[12] = a[3];\n out[13] = a[7];\n out[14] = a[11];\n out[15] = a[15];\n }\n\n return out;\n}\n/**\n * Inverts a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the source matrix\n * @returns {mat4} out\n */\n\nfunction invert$2(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n return out;\n}\n/**\n * Calculates the adjugate of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the source matrix\n * @returns {mat4} out\n */\n\nfunction adjoint(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n out[0] = a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22);\n out[1] = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n out[2] = a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12);\n out[3] = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n out[4] = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n out[5] = a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22);\n out[6] = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n out[7] = a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12);\n out[8] = a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21);\n out[9] = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n out[10] = a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11);\n out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n out[13] = a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21);\n out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n out[15] = a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11);\n return out;\n}\n/**\n * Calculates the determinant of a mat4\n *\n * @param {ReadonlyMat4} a the source matrix\n * @returns {Number} determinant of a\n */\n\nfunction determinant(a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n}\n/**\n * Multiplies two mat4s\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the first operand\n * @param {ReadonlyMat4} b the second operand\n * @returns {mat4} out\n */\n\nfunction multiply$5(out, a, b) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15]; // Cache only the current line of the second matrix\n\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n out[0] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[1] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[2] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[3] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[4];\n b1 = b[5];\n b2 = b[6];\n b3 = b[7];\n out[4] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[5] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[6] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[7] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[8];\n b1 = b[9];\n b2 = b[10];\n b3 = b[11];\n out[8] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[9] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[10] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[11] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[12];\n b1 = b[13];\n b2 = b[14];\n b3 = b[15];\n out[12] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[13] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[14] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[15] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n return out;\n}\n/**\n * Translate a mat4 by the given vector\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to translate\n * @param {ReadonlyVec3} v vector to translate by\n * @returns {mat4} out\n */\n\nfunction translate$1(out, a, v) {\n var x = v[0],\n y = v[1],\n z = v[2];\n var a00, a01, a02, a03;\n var a10, a11, a12, a13;\n var a20, a21, a22, a23;\n\n if (a === out) {\n out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n } else {\n a00 = a[0];\n a01 = a[1];\n a02 = a[2];\n a03 = a[3];\n a10 = a[4];\n a11 = a[5];\n a12 = a[6];\n a13 = a[7];\n a20 = a[8];\n a21 = a[9];\n a22 = a[10];\n a23 = a[11];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a03;\n out[4] = a10;\n out[5] = a11;\n out[6] = a12;\n out[7] = a13;\n out[8] = a20;\n out[9] = a21;\n out[10] = a22;\n out[11] = a23;\n out[12] = a00 * x + a10 * y + a20 * z + a[12];\n out[13] = a01 * x + a11 * y + a21 * z + a[13];\n out[14] = a02 * x + a12 * y + a22 * z + a[14];\n out[15] = a03 * x + a13 * y + a23 * z + a[15];\n }\n\n return out;\n}\n/**\n * Scales the mat4 by the dimensions in the given vec3 not using vectorization\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to scale\n * @param {ReadonlyVec3} v the vec3 to scale the matrix by\n * @returns {mat4} out\n **/\n\nfunction scale$5(out, a, v) {\n var x = v[0],\n y = v[1],\n z = v[2];\n out[0] = a[0] * x;\n out[1] = a[1] * x;\n out[2] = a[2] * x;\n out[3] = a[3] * x;\n out[4] = a[4] * y;\n out[5] = a[5] * y;\n out[6] = a[6] * y;\n out[7] = a[7] * y;\n out[8] = a[8] * z;\n out[9] = a[9] * z;\n out[10] = a[10] * z;\n out[11] = a[11] * z;\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\n * Rotates a mat4 by the given angle around the given axis\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @param {ReadonlyVec3} axis the axis to rotate around\n * @returns {mat4} out\n */\n\nfunction rotate$1(out, a, rad, axis) {\n var x = axis[0],\n y = axis[1],\n z = axis[2];\n var len = Math.hypot(x, y, z);\n var s, c, t;\n var a00, a01, a02, a03;\n var a10, a11, a12, a13;\n var a20, a21, a22, a23;\n var b00, b01, b02;\n var b10, b11, b12;\n var b20, b21, b22;\n\n if (len < EPSILON) {\n return null;\n }\n\n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c;\n a00 = a[0];\n a01 = a[1];\n a02 = a[2];\n a03 = a[3];\n a10 = a[4];\n a11 = a[5];\n a12 = a[6];\n a13 = a[7];\n a20 = a[8];\n a21 = a[9];\n a22 = a[10];\n a23 = a[11]; // Construct the elements of the rotation matrix\n\n b00 = x * x * t + c;\n b01 = y * x * t + z * s;\n b02 = z * x * t - y * s;\n b10 = x * y * t - z * s;\n b11 = y * y * t + c;\n b12 = z * y * t + x * s;\n b20 = x * z * t + y * s;\n b21 = y * z * t - x * s;\n b22 = z * z * t + c; // Perform rotation-specific matrix multiplication\n\n out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged last row\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n return out;\n}\n/**\n * Rotates a matrix by the given angle around the X axis\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nfunction rotateX$3(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n var a20 = a[8];\n var a21 = a[9];\n var a22 = a[10];\n var a23 = a[11];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged rows\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[4] = a10 * c + a20 * s;\n out[5] = a11 * c + a21 * s;\n out[6] = a12 * c + a22 * s;\n out[7] = a13 * c + a23 * s;\n out[8] = a20 * c - a10 * s;\n out[9] = a21 * c - a11 * s;\n out[10] = a22 * c - a12 * s;\n out[11] = a23 * c - a13 * s;\n return out;\n}\n/**\n * Rotates a matrix by the given angle around the Y axis\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nfunction rotateY$3(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a03 = a[3];\n var a20 = a[8];\n var a21 = a[9];\n var a22 = a[10];\n var a23 = a[11];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged rows\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[0] = a00 * c - a20 * s;\n out[1] = a01 * c - a21 * s;\n out[2] = a02 * c - a22 * s;\n out[3] = a03 * c - a23 * s;\n out[8] = a00 * s + a20 * c;\n out[9] = a01 * s + a21 * c;\n out[10] = a02 * s + a22 * c;\n out[11] = a03 * s + a23 * c;\n return out;\n}\n/**\n * Rotates a matrix by the given angle around the Z axis\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nfunction rotateZ$3(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a03 = a[3];\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged last row\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[0] = a00 * c + a10 * s;\n out[1] = a01 * c + a11 * s;\n out[2] = a02 * c + a12 * s;\n out[3] = a03 * c + a13 * s;\n out[4] = a10 * c - a00 * s;\n out[5] = a11 * c - a01 * s;\n out[6] = a12 * c - a02 * s;\n out[7] = a13 * c - a03 * s;\n return out;\n}\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, dest, vec);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {ReadonlyVec3} v Translation vector\n * @returns {mat4} out\n */\n\nfunction fromTranslation$1(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.scale(dest, dest, vec);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {ReadonlyVec3} v Scaling vector\n * @returns {mat4} out\n */\n\nfunction fromScaling(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = v[1];\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = v[2];\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from a given angle around a given axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.rotate(dest, dest, rad, axis);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @param {ReadonlyVec3} axis the axis to rotate around\n * @returns {mat4} out\n */\n\nfunction fromRotation$1(out, rad, axis) {\n var x = axis[0],\n y = axis[1],\n z = axis[2];\n var len = Math.hypot(x, y, z);\n var s, c, t;\n\n if (len < EPSILON) {\n return null;\n }\n\n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c; // Perform rotation-specific matrix multiplication\n\n out[0] = x * x * t + c;\n out[1] = y * x * t + z * s;\n out[2] = z * x * t - y * s;\n out[3] = 0;\n out[4] = x * y * t - z * s;\n out[5] = y * y * t + c;\n out[6] = z * y * t + x * s;\n out[7] = 0;\n out[8] = x * z * t + y * s;\n out[9] = y * z * t - x * s;\n out[10] = z * z * t + c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from the given angle around the X axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.rotateX(dest, dest, rad);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nfunction fromXRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = c;\n out[6] = s;\n out[7] = 0;\n out[8] = 0;\n out[9] = -s;\n out[10] = c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from the given angle around the Y axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.rotateY(dest, dest, rad);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nfunction fromYRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = c;\n out[1] = 0;\n out[2] = -s;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = s;\n out[9] = 0;\n out[10] = c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from the given angle around the Z axis\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.rotateZ(dest, dest, rad);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\n\nfunction fromZRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = 0;\n out[4] = -s;\n out[5] = c;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from a quaternion rotation and vector translation\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, vec);\n * let quatMat = mat4.create();\n * quat4.toMat4(quat, quatMat);\n * mat4.multiply(dest, quatMat);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {ReadonlyVec3} v Translation vector\n * @returns {mat4} out\n */\n\nfunction fromRotationTranslation$1(out, q, v) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - (yy + zz);\n out[1] = xy + wz;\n out[2] = xz - wy;\n out[3] = 0;\n out[4] = xy - wz;\n out[5] = 1 - (xx + zz);\n out[6] = yz + wx;\n out[7] = 0;\n out[8] = xz + wy;\n out[9] = yz - wx;\n out[10] = 1 - (xx + yy);\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\n * Creates a new mat4 from a dual quat.\n *\n * @param {mat4} out Matrix\n * @param {ReadonlyQuat2} a Dual Quaternion\n * @returns {mat4} mat4 receiving operation result\n */\n\nfunction fromQuat2(out, a) {\n var translation = new ARRAY_TYPE(3);\n var bx = -a[0],\n by = -a[1],\n bz = -a[2],\n bw = a[3],\n ax = a[4],\n ay = a[5],\n az = a[6],\n aw = a[7];\n var magnitude = bx * bx + by * by + bz * bz + bw * bw; //Only scale if it makes sense\n\n if (magnitude > 0) {\n translation[0] = (ax * bw + aw * bx + ay * bz - az * by) * 2 / magnitude;\n translation[1] = (ay * bw + aw * by + az * bx - ax * bz) * 2 / magnitude;\n translation[2] = (az * bw + aw * bz + ax * by - ay * bx) * 2 / magnitude;\n } else {\n translation[0] = (ax * bw + aw * bx + ay * bz - az * by) * 2;\n translation[1] = (ay * bw + aw * by + az * bx - ax * bz) * 2;\n translation[2] = (az * bw + aw * bz + ax * by - ay * bx) * 2;\n }\n\n fromRotationTranslation$1(out, a, translation);\n return out;\n}\n/**\n * Returns the translation vector component of a transformation\n * matrix. If a matrix is built with fromRotationTranslation,\n * the returned vector will be the same as the translation vector\n * originally supplied.\n * @param {vec3} out Vector to receive translation component\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\n * @return {vec3} out\n */\n\nfunction getTranslation$1(out, mat) {\n out[0] = mat[12];\n out[1] = mat[13];\n out[2] = mat[14];\n return out;\n}\n/**\n * Returns the scaling factor component of a transformation\n * matrix. If a matrix is built with fromRotationTranslationScale\n * with a normalized Quaternion paramter, the returned vector will be\n * the same as the scaling vector\n * originally supplied.\n * @param {vec3} out Vector to receive scaling factor component\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\n * @return {vec3} out\n */\n\nfunction getScaling(out, mat) {\n var m11 = mat[0];\n var m12 = mat[1];\n var m13 = mat[2];\n var m21 = mat[4];\n var m22 = mat[5];\n var m23 = mat[6];\n var m31 = mat[8];\n var m32 = mat[9];\n var m33 = mat[10];\n out[0] = Math.hypot(m11, m12, m13);\n out[1] = Math.hypot(m21, m22, m23);\n out[2] = Math.hypot(m31, m32, m33);\n return out;\n}\n/**\n * Returns a quaternion representing the rotational component\n * of a transformation matrix. If a matrix is built with\n * fromRotationTranslation, the returned quaternion will be the\n * same as the quaternion originally supplied.\n * @param {quat} out Quaternion to receive the rotation component\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\n * @return {quat} out\n */\n\nfunction getRotation(out, mat) {\n var scaling = new ARRAY_TYPE(3);\n getScaling(scaling, mat);\n var is1 = 1 / scaling[0];\n var is2 = 1 / scaling[1];\n var is3 = 1 / scaling[2];\n var sm11 = mat[0] * is1;\n var sm12 = mat[1] * is2;\n var sm13 = mat[2] * is3;\n var sm21 = mat[4] * is1;\n var sm22 = mat[5] * is2;\n var sm23 = mat[6] * is3;\n var sm31 = mat[8] * is1;\n var sm32 = mat[9] * is2;\n var sm33 = mat[10] * is3;\n var trace = sm11 + sm22 + sm33;\n var S = 0;\n\n if (trace > 0) {\n S = Math.sqrt(trace + 1.0) * 2;\n out[3] = 0.25 * S;\n out[0] = (sm23 - sm32) / S;\n out[1] = (sm31 - sm13) / S;\n out[2] = (sm12 - sm21) / S;\n } else if (sm11 > sm22 && sm11 > sm33) {\n S = Math.sqrt(1.0 + sm11 - sm22 - sm33) * 2;\n out[3] = (sm23 - sm32) / S;\n out[0] = 0.25 * S;\n out[1] = (sm12 + sm21) / S;\n out[2] = (sm31 + sm13) / S;\n } else if (sm22 > sm33) {\n S = Math.sqrt(1.0 + sm22 - sm11 - sm33) * 2;\n out[3] = (sm31 - sm13) / S;\n out[0] = (sm12 + sm21) / S;\n out[1] = 0.25 * S;\n out[2] = (sm23 + sm32) / S;\n } else {\n S = Math.sqrt(1.0 + sm33 - sm11 - sm22) * 2;\n out[3] = (sm12 - sm21) / S;\n out[0] = (sm31 + sm13) / S;\n out[1] = (sm23 + sm32) / S;\n out[2] = 0.25 * S;\n }\n\n return out;\n}\n/**\n * Creates a matrix from a quaternion rotation, vector translation and vector scale\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, vec);\n * let quatMat = mat4.create();\n * quat4.toMat4(quat, quatMat);\n * mat4.multiply(dest, quatMat);\n * mat4.scale(dest, scale)\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {ReadonlyVec3} v Translation vector\n * @param {ReadonlyVec3} s Scaling vector\n * @returns {mat4} out\n */\n\nfunction fromRotationTranslationScale(out, q, v, s) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n var sx = s[0];\n var sy = s[1];\n var sz = s[2];\n out[0] = (1 - (yy + zz)) * sx;\n out[1] = (xy + wz) * sx;\n out[2] = (xz - wy) * sx;\n out[3] = 0;\n out[4] = (xy - wz) * sy;\n out[5] = (1 - (xx + zz)) * sy;\n out[6] = (yz + wx) * sy;\n out[7] = 0;\n out[8] = (xz + wy) * sz;\n out[9] = (yz - wx) * sz;\n out[10] = (1 - (xx + yy)) * sz;\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\n * Creates a matrix from a quaternion rotation, vector translation and vector scale, rotating and scaling around the given origin\n * This is equivalent to (but much faster than):\n *\n * mat4.identity(dest);\n * mat4.translate(dest, vec);\n * mat4.translate(dest, origin);\n * let quatMat = mat4.create();\n * quat4.toMat4(quat, quatMat);\n * mat4.multiply(dest, quatMat);\n * mat4.scale(dest, scale)\n * mat4.translate(dest, negativeOrigin);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {ReadonlyVec3} v Translation vector\n * @param {ReadonlyVec3} s Scaling vector\n * @param {ReadonlyVec3} o The origin vector around which to scale and rotate\n * @returns {mat4} out\n */\n\nfunction fromRotationTranslationScaleOrigin(out, q, v, s, o) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n var sx = s[0];\n var sy = s[1];\n var sz = s[2];\n var ox = o[0];\n var oy = o[1];\n var oz = o[2];\n var out0 = (1 - (yy + zz)) * sx;\n var out1 = (xy + wz) * sx;\n var out2 = (xz - wy) * sx;\n var out4 = (xy - wz) * sy;\n var out5 = (1 - (xx + zz)) * sy;\n var out6 = (yz + wx) * sy;\n var out8 = (xz + wy) * sz;\n var out9 = (yz - wx) * sz;\n var out10 = (1 - (xx + yy)) * sz;\n out[0] = out0;\n out[1] = out1;\n out[2] = out2;\n out[3] = 0;\n out[4] = out4;\n out[5] = out5;\n out[6] = out6;\n out[7] = 0;\n out[8] = out8;\n out[9] = out9;\n out[10] = out10;\n out[11] = 0;\n out[12] = v[0] + ox - (out0 * ox + out4 * oy + out8 * oz);\n out[13] = v[1] + oy - (out1 * ox + out5 * oy + out9 * oz);\n out[14] = v[2] + oz - (out2 * ox + out6 * oy + out10 * oz);\n out[15] = 1;\n return out;\n}\n/**\n * Calculates a 4x4 matrix from the given quaternion\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {ReadonlyQuat} q Quaternion to create matrix from\n *\n * @returns {mat4} out\n */\n\nfunction fromQuat(out, q) {\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var yx = y * x2;\n var yy = y * y2;\n var zx = z * x2;\n var zy = z * y2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - yy - zz;\n out[1] = yx + wz;\n out[2] = zx - wy;\n out[3] = 0;\n out[4] = yx - wz;\n out[5] = 1 - xx - zz;\n out[6] = zy + wx;\n out[7] = 0;\n out[8] = zx + wy;\n out[9] = zy - wx;\n out[10] = 1 - xx - yy;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\n * Generates a frustum matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Number} left Left bound of the frustum\n * @param {Number} right Right bound of the frustum\n * @param {Number} bottom Bottom bound of the frustum\n * @param {Number} top Top bound of the frustum\n * @param {Number} near Near bound of the frustum\n * @param {Number} far Far bound of the frustum\n * @returns {mat4} out\n */\n\nfunction frustum(out, left, right, bottom, top, near, far) {\n var rl = 1 / (right - left);\n var tb = 1 / (top - bottom);\n var nf = 1 / (near - far);\n out[0] = near * 2 * rl;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = near * 2 * tb;\n out[6] = 0;\n out[7] = 0;\n out[8] = (right + left) * rl;\n out[9] = (top + bottom) * tb;\n out[10] = (far + near) * nf;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[14] = far * near * 2 * nf;\n out[15] = 0;\n return out;\n}\n/**\n * Generates a perspective projection matrix with the given bounds.\n * The near/far clip planes correspond to a normalized device coordinate Z range of [-1, 1],\n * which matches WebGL/OpenGL's clip volume.\n * Passing null/undefined/no value for far will generate infinite projection matrix.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum, can be null or Infinity\n * @returns {mat4} out\n */\n\nfunction perspectiveNO(out, fovy, aspect, near, far) {\n var f = 1.0 / Math.tan(fovy / 2),\n nf;\n out[0] = f / aspect;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = f;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[15] = 0;\n\n if (far != null && far !== Infinity) {\n nf = 1 / (near - far);\n out[10] = (far + near) * nf;\n out[14] = 2 * far * near * nf;\n } else {\n out[10] = -1;\n out[14] = -2 * near;\n }\n\n return out;\n}\n/**\n * Alias for {@link mat4.perspectiveNO}\n * @function\n */\n\nvar perspective = perspectiveNO;\n/**\n * Generates a perspective projection matrix suitable for WebGPU with the given bounds.\n * The near/far clip planes correspond to a normalized device coordinate Z range of [0, 1],\n * which matches WebGPU/Vulkan/DirectX/Metal's clip volume.\n * Passing null/undefined/no value for far will generate infinite projection matrix.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum, can be null or Infinity\n * @returns {mat4} out\n */\n\nfunction perspectiveZO(out, fovy, aspect, near, far) {\n var f = 1.0 / Math.tan(fovy / 2),\n nf;\n out[0] = f / aspect;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = f;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[15] = 0;\n\n if (far != null && far !== Infinity) {\n nf = 1 / (near - far);\n out[10] = far * nf;\n out[14] = far * near * nf;\n } else {\n out[10] = -1;\n out[14] = -near;\n }\n\n return out;\n}\n/**\n * Generates a perspective projection matrix with the given field of view.\n * This is primarily useful for generating projection matrices to be used\n * with the still experiemental WebVR API.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Object} fov Object containing the following values: upDegrees, downDegrees, leftDegrees, rightDegrees\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\n\nfunction perspectiveFromFieldOfView(out, fov, near, far) {\n var upTan = Math.tan(fov.upDegrees * Math.PI / 180.0);\n var downTan = Math.tan(fov.downDegrees * Math.PI / 180.0);\n var leftTan = Math.tan(fov.leftDegrees * Math.PI / 180.0);\n var rightTan = Math.tan(fov.rightDegrees * Math.PI / 180.0);\n var xScale = 2.0 / (leftTan + rightTan);\n var yScale = 2.0 / (upTan + downTan);\n out[0] = xScale;\n out[1] = 0.0;\n out[2] = 0.0;\n out[3] = 0.0;\n out[4] = 0.0;\n out[5] = yScale;\n out[6] = 0.0;\n out[7] = 0.0;\n out[8] = -((leftTan - rightTan) * xScale * 0.5);\n out[9] = (upTan - downTan) * yScale * 0.5;\n out[10] = far / (near - far);\n out[11] = -1.0;\n out[12] = 0.0;\n out[13] = 0.0;\n out[14] = far * near / (near - far);\n out[15] = 0.0;\n return out;\n}\n/**\n * Generates a orthogonal projection matrix with the given bounds.\n * The near/far clip planes correspond to a normalized device coordinate Z range of [-1, 1],\n * which matches WebGL/OpenGL's clip volume.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\n\nfunction orthoNO(out, left, right, bottom, top, near, far) {\n var lr = 1 / (left - right);\n var bt = 1 / (bottom - top);\n var nf = 1 / (near - far);\n out[0] = -2 * lr;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = -2 * bt;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 2 * nf;\n out[11] = 0;\n out[12] = (left + right) * lr;\n out[13] = (top + bottom) * bt;\n out[14] = (far + near) * nf;\n out[15] = 1;\n return out;\n}\n/**\n * Alias for {@link mat4.orthoNO}\n * @function\n */\n\nvar ortho = orthoNO;\n/**\n * Generates a orthogonal projection matrix with the given bounds.\n * The near/far clip planes correspond to a normalized device coordinate Z range of [0, 1],\n * which matches WebGPU/Vulkan/DirectX/Metal's clip volume.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\n\nfunction orthoZO(out, left, right, bottom, top, near, far) {\n var lr = 1 / (left - right);\n var bt = 1 / (bottom - top);\n var nf = 1 / (near - far);\n out[0] = -2 * lr;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = -2 * bt;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = nf;\n out[11] = 0;\n out[12] = (left + right) * lr;\n out[13] = (top + bottom) * bt;\n out[14] = near * nf;\n out[15] = 1;\n return out;\n}\n/**\n * Generates a look-at matrix with the given eye position, focal point, and up axis.\n * If you want a matrix that actually makes an object look at another object, you should use targetTo instead.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {ReadonlyVec3} eye Position of the viewer\n * @param {ReadonlyVec3} center Point the viewer is looking at\n * @param {ReadonlyVec3} up vec3 pointing up\n * @returns {mat4} out\n */\n\nfunction lookAt(out, eye, center, up) {\n var x0, x1, x2, y0, y1, y2, z0, z1, z2, len;\n var eyex = eye[0];\n var eyey = eye[1];\n var eyez = eye[2];\n var upx = up[0];\n var upy = up[1];\n var upz = up[2];\n var centerx = center[0];\n var centery = center[1];\n var centerz = center[2];\n\n if (Math.abs(eyex - centerx) < EPSILON && Math.abs(eyey - centery) < EPSILON && Math.abs(eyez - centerz) < EPSILON) {\n return identity$2(out);\n }\n\n z0 = eyex - centerx;\n z1 = eyey - centery;\n z2 = eyez - centerz;\n len = 1 / Math.hypot(z0, z1, z2);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n x0 = upy * z2 - upz * z1;\n x1 = upz * z0 - upx * z2;\n x2 = upx * z1 - upy * z0;\n len = Math.hypot(x0, x1, x2);\n\n if (!len) {\n x0 = 0;\n x1 = 0;\n x2 = 0;\n } else {\n len = 1 / len;\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n y0 = z1 * x2 - z2 * x1;\n y1 = z2 * x0 - z0 * x2;\n y2 = z0 * x1 - z1 * x0;\n len = Math.hypot(y0, y1, y2);\n\n if (!len) {\n y0 = 0;\n y1 = 0;\n y2 = 0;\n } else {\n len = 1 / len;\n y0 *= len;\n y1 *= len;\n y2 *= len;\n }\n\n out[0] = x0;\n out[1] = y0;\n out[2] = z0;\n out[3] = 0;\n out[4] = x1;\n out[5] = y1;\n out[6] = z1;\n out[7] = 0;\n out[8] = x2;\n out[9] = y2;\n out[10] = z2;\n out[11] = 0;\n out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n out[15] = 1;\n return out;\n}\n/**\n * Generates a matrix that makes something look at something else.\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {ReadonlyVec3} eye Position of the viewer\n * @param {ReadonlyVec3} center Point the viewer is looking at\n * @param {ReadonlyVec3} up vec3 pointing up\n * @returns {mat4} out\n */\n\nfunction targetTo(out, eye, target, up) {\n var eyex = eye[0],\n eyey = eye[1],\n eyez = eye[2],\n upx = up[0],\n upy = up[1],\n upz = up[2];\n var z0 = eyex - target[0],\n z1 = eyey - target[1],\n z2 = eyez - target[2];\n var len = z0 * z0 + z1 * z1 + z2 * z2;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n }\n\n var x0 = upy * z2 - upz * z1,\n x1 = upz * z0 - upx * z2,\n x2 = upx * z1 - upy * z0;\n len = x0 * x0 + x1 * x1 + x2 * x2;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n out[0] = x0;\n out[1] = x1;\n out[2] = x2;\n out[3] = 0;\n out[4] = z1 * x2 - z2 * x1;\n out[5] = z2 * x0 - z0 * x2;\n out[6] = z0 * x1 - z1 * x0;\n out[7] = 0;\n out[8] = z0;\n out[9] = z1;\n out[10] = z2;\n out[11] = 0;\n out[12] = eyex;\n out[13] = eyey;\n out[14] = eyez;\n out[15] = 1;\n return out;\n}\n/**\n * Returns a string representation of a mat4\n *\n * @param {ReadonlyMat4} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\n\nfunction str$5(a) {\n return \"mat4(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \", \" + a[6] + \", \" + a[7] + \", \" + a[8] + \", \" + a[9] + \", \" + a[10] + \", \" + a[11] + \", \" + a[12] + \", \" + a[13] + \", \" + a[14] + \", \" + a[15] + \")\";\n}\n/**\n * Returns Frobenius norm of a mat4\n *\n * @param {ReadonlyMat4} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\n\nfunction frob(a) {\n return Math.hypot(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8], a[9], a[10], a[11], a[12], a[13], a[14], a[15]);\n}\n/**\n * Adds two mat4's\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the first operand\n * @param {ReadonlyMat4} b the second operand\n * @returns {mat4} out\n */\n\nfunction add$5(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n out[8] = a[8] + b[8];\n out[9] = a[9] + b[9];\n out[10] = a[10] + b[10];\n out[11] = a[11] + b[11];\n out[12] = a[12] + b[12];\n out[13] = a[13] + b[13];\n out[14] = a[14] + b[14];\n out[15] = a[15] + b[15];\n return out;\n}\n/**\n * Subtracts matrix b from matrix a\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the first operand\n * @param {ReadonlyMat4} b the second operand\n * @returns {mat4} out\n */\n\nfunction subtract$3(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n out[6] = a[6] - b[6];\n out[7] = a[7] - b[7];\n out[8] = a[8] - b[8];\n out[9] = a[9] - b[9];\n out[10] = a[10] - b[10];\n out[11] = a[11] - b[11];\n out[12] = a[12] - b[12];\n out[13] = a[13] - b[13];\n out[14] = a[14] - b[14];\n out[15] = a[15] - b[15];\n return out;\n}\n/**\n * Multiply each element of the matrix by a scalar.\n *\n * @param {mat4} out the receiving matrix\n * @param {ReadonlyMat4} a the matrix to scale\n * @param {Number} b amount to scale the matrix's elements by\n * @returns {mat4} out\n */\n\nfunction multiplyScalar(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n out[8] = a[8] * b;\n out[9] = a[9] * b;\n out[10] = a[10] * b;\n out[11] = a[11] * b;\n out[12] = a[12] * b;\n out[13] = a[13] * b;\n out[14] = a[14] * b;\n out[15] = a[15] * b;\n return out;\n}\n/**\n * Adds two mat4's after multiplying each element of the second operand by a scalar value.\n *\n * @param {mat4} out the receiving vector\n * @param {ReadonlyMat4} a the first operand\n * @param {ReadonlyMat4} b the second operand\n * @param {Number} scale the amount to scale b's elements by before adding\n * @returns {mat4} out\n */\n\nfunction multiplyScalarAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n out[6] = a[6] + b[6] * scale;\n out[7] = a[7] + b[7] * scale;\n out[8] = a[8] + b[8] * scale;\n out[9] = a[9] + b[9] * scale;\n out[10] = a[10] + b[10] * scale;\n out[11] = a[11] + b[11] * scale;\n out[12] = a[12] + b[12] * scale;\n out[13] = a[13] + b[13] * scale;\n out[14] = a[14] + b[14] * scale;\n out[15] = a[15] + b[15] * scale;\n return out;\n}\n/**\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyMat4} a The first matrix.\n * @param {ReadonlyMat4} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nfunction exactEquals$5(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5] && a[6] === b[6] && a[7] === b[7] && a[8] === b[8] && a[9] === b[9] && a[10] === b[10] && a[11] === b[11] && a[12] === b[12] && a[13] === b[13] && a[14] === b[14] && a[15] === b[15];\n}\n/**\n * Returns whether or not the matrices have approximately the same elements in the same position.\n *\n * @param {ReadonlyMat4} a The first matrix.\n * @param {ReadonlyMat4} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\n\nfunction equals$5(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var a4 = a[4],\n a5 = a[5],\n a6 = a[6],\n a7 = a[7];\n var a8 = a[8],\n a9 = a[9],\n a10 = a[10],\n a11 = a[11];\n var a12 = a[12],\n a13 = a[13],\n a14 = a[14],\n a15 = a[15];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n var b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7];\n var b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11];\n var b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) && Math.abs(a6 - b6) <= EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) && Math.abs(a7 - b7) <= EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7)) && Math.abs(a8 - b8) <= EPSILON * Math.max(1.0, Math.abs(a8), Math.abs(b8)) && Math.abs(a9 - b9) <= EPSILON * Math.max(1.0, Math.abs(a9), Math.abs(b9)) && Math.abs(a10 - b10) <= EPSILON * Math.max(1.0, Math.abs(a10), Math.abs(b10)) && Math.abs(a11 - b11) <= EPSILON * Math.max(1.0, Math.abs(a11), Math.abs(b11)) && Math.abs(a12 - b12) <= EPSILON * Math.max(1.0, Math.abs(a12), Math.abs(b12)) && Math.abs(a13 - b13) <= EPSILON * Math.max(1.0, Math.abs(a13), Math.abs(b13)) && Math.abs(a14 - b14) <= EPSILON * Math.max(1.0, Math.abs(a14), Math.abs(b14)) && Math.abs(a15 - b15) <= EPSILON * Math.max(1.0, Math.abs(a15), Math.abs(b15));\n}\n/**\n * Alias for {@link mat4.multiply}\n * @function\n */\n\nvar mul$5 = multiply$5;\n/**\n * Alias for {@link mat4.subtract}\n * @function\n */\n\nvar sub$3 = subtract$3;\n\nvar mat4 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$5,\n clone: clone$5,\n copy: copy$5,\n fromValues: fromValues$5,\n set: set$5,\n identity: identity$2,\n transpose: transpose,\n invert: invert$2,\n adjoint: adjoint,\n determinant: determinant,\n multiply: multiply$5,\n translate: translate$1,\n scale: scale$5,\n rotate: rotate$1,\n rotateX: rotateX$3,\n rotateY: rotateY$3,\n rotateZ: rotateZ$3,\n fromTranslation: fromTranslation$1,\n fromScaling: fromScaling,\n fromRotation: fromRotation$1,\n fromXRotation: fromXRotation,\n fromYRotation: fromYRotation,\n fromZRotation: fromZRotation,\n fromRotationTranslation: fromRotationTranslation$1,\n fromQuat2: fromQuat2,\n getTranslation: getTranslation$1,\n getScaling: getScaling,\n getRotation: getRotation,\n fromRotationTranslationScale: fromRotationTranslationScale,\n fromRotationTranslationScaleOrigin: fromRotationTranslationScaleOrigin,\n fromQuat: fromQuat,\n frustum: frustum,\n perspectiveNO: perspectiveNO,\n perspective: perspective,\n perspectiveZO: perspectiveZO,\n perspectiveFromFieldOfView: perspectiveFromFieldOfView,\n orthoNO: orthoNO,\n ortho: ortho,\n orthoZO: orthoZO,\n lookAt: lookAt,\n targetTo: targetTo,\n str: str$5,\n frob: frob,\n add: add$5,\n subtract: subtract$3,\n multiplyScalar: multiplyScalar,\n multiplyScalarAndAdd: multiplyScalarAndAdd,\n exactEquals: exactEquals$5,\n equals: equals$5,\n mul: mul$5,\n sub: sub$3\n});\n\n/**\n * 3 Dimensional Vector\n * @module vec3\n */\n\n/**\n * Creates a new, empty vec3\n *\n * @returns {vec3} a new 3D vector\n */\n\nfunction create$4() {\n var out = new ARRAY_TYPE(3);\n\n if (ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n }\n\n return out;\n}\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {ReadonlyVec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\n\nfunction clone$4(a) {\n var out = new ARRAY_TYPE(3);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n return out;\n}\n/**\n * Calculates the length of a vec3\n *\n * @param {ReadonlyVec3} a vector to calculate length of\n * @returns {Number} length of a\n */\n\nfunction length$4(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n return Math.hypot(x, y, z);\n}\n/**\n * Creates a new vec3 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} a new 3D vector\n */\n\nfunction fromValues$4(x, y, z) {\n var out = new ARRAY_TYPE(3);\n out[0] = x;\n out[1] = y;\n out[2] = z;\n return out;\n}\n/**\n * Copy the values from one vec3 to another\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the source vector\n * @returns {vec3} out\n */\n\nfunction copy$4(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n return out;\n}\n/**\n * Set the components of a vec3 to the given values\n *\n * @param {vec3} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} out\n */\n\nfunction set$4(out, x, y, z) {\n out[0] = x;\n out[1] = y;\n out[2] = z;\n return out;\n}\n/**\n * Adds two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nfunction add$4(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n return out;\n}\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nfunction subtract$2(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n return out;\n}\n/**\n * Multiplies two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nfunction multiply$4(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n out[2] = a[2] * b[2];\n return out;\n}\n/**\n * Divides two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nfunction divide$2(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n out[2] = a[2] / b[2];\n return out;\n}\n/**\n * Math.ceil the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to ceil\n * @returns {vec3} out\n */\n\nfunction ceil$2(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n out[2] = Math.ceil(a[2]);\n return out;\n}\n/**\n * Math.floor the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to floor\n * @returns {vec3} out\n */\n\nfunction floor$2(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n out[2] = Math.floor(a[2]);\n return out;\n}\n/**\n * Returns the minimum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nfunction min$2(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n out[2] = Math.min(a[2], b[2]);\n return out;\n}\n/**\n * Returns the maximum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nfunction max$2(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n out[2] = Math.max(a[2], b[2]);\n return out;\n}\n/**\n * Math.round the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to round\n * @returns {vec3} out\n */\n\nfunction round$2(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n out[2] = Math.round(a[2]);\n return out;\n}\n/**\n * Scales a vec3 by a scalar number\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec3} out\n */\n\nfunction scale$4(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n return out;\n}\n/**\n * Adds two vec3's after scaling the second operand by a scalar value\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec3} out\n */\n\nfunction scaleAndAdd$2(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n return out;\n}\n/**\n * Calculates the euclidian distance between two vec3's\n *\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {Number} distance between a and b\n */\n\nfunction distance$2(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n return Math.hypot(x, y, z);\n}\n/**\n * Calculates the squared euclidian distance between two vec3's\n *\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {Number} squared distance between a and b\n */\n\nfunction squaredDistance$2(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n return x * x + y * y + z * z;\n}\n/**\n * Calculates the squared length of a vec3\n *\n * @param {ReadonlyVec3} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\n\nfunction squaredLength$4(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n return x * x + y * y + z * z;\n}\n/**\n * Negates the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to negate\n * @returns {vec3} out\n */\n\nfunction negate$2(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n return out;\n}\n/**\n * Returns the inverse of the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to invert\n * @returns {vec3} out\n */\n\nfunction inverse$2(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n out[2] = 1.0 / a[2];\n return out;\n}\n/**\n * Normalize a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a vector to normalize\n * @returns {vec3} out\n */\n\nfunction normalize$4(out, a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var len = x * x + y * y + z * z;\n\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = a[0] * len;\n out[1] = a[1] * len;\n out[2] = a[2] * len;\n return out;\n}\n/**\n * Calculates the dot product of two vec3's\n *\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {Number} dot product of a and b\n */\n\nfunction dot$4(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\n/**\n * Computes the cross product of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @returns {vec3} out\n */\n\nfunction cross$2(out, a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2];\n var bx = b[0],\n by = b[1],\n bz = b[2];\n out[0] = ay * bz - az * by;\n out[1] = az * bx - ax * bz;\n out[2] = ax * by - ay * bx;\n return out;\n}\n/**\n * Performs a linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\n\nfunction lerp$4(out, a, b, t) {\n var ax = a[0];\n var ay = a[1];\n var az = a[2];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n out[2] = az + t * (b[2] - az);\n return out;\n}\n/**\n * Performs a hermite interpolation with two control points\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {ReadonlyVec3} c the third operand\n * @param {ReadonlyVec3} d the fourth operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\n\nfunction hermite(out, a, b, c, d, t) {\n var factorTimes2 = t * t;\n var factor1 = factorTimes2 * (2 * t - 3) + 1;\n var factor2 = factorTimes2 * (t - 2) + t;\n var factor3 = factorTimes2 * (t - 1);\n var factor4 = factorTimes2 * (3 - 2 * t);\n out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n return out;\n}\n/**\n * Performs a bezier interpolation with two control points\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the first operand\n * @param {ReadonlyVec3} b the second operand\n * @param {ReadonlyVec3} c the third operand\n * @param {ReadonlyVec3} d the fourth operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec3} out\n */\n\nfunction bezier(out, a, b, c, d, t) {\n var inverseFactor = 1 - t;\n var inverseFactorTimesTwo = inverseFactor * inverseFactor;\n var factorTimes2 = t * t;\n var factor1 = inverseFactorTimesTwo * inverseFactor;\n var factor2 = 3 * t * inverseFactorTimesTwo;\n var factor3 = 3 * factorTimes2 * inverseFactor;\n var factor4 = factorTimes2 * t;\n out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n return out;\n}\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec3} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec3} out\n */\n\nfunction random$3(out, scale) {\n scale = scale || 1.0;\n var r = RANDOM() * 2.0 * Math.PI;\n var z = RANDOM() * 2.0 - 1.0;\n var zScale = Math.sqrt(1.0 - z * z) * scale;\n out[0] = Math.cos(r) * zScale;\n out[1] = Math.sin(r) * zScale;\n out[2] = z * scale;\n return out;\n}\n/**\n * Transforms the vec3 with a mat4.\n * 4th vector component is implicitly '1'\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to transform\n * @param {ReadonlyMat4} m matrix to transform with\n * @returns {vec3} out\n */\n\nfunction transformMat4$2(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2];\n var w = m[3] * x + m[7] * y + m[11] * z + m[15];\n w = w || 1.0;\n out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w;\n out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w;\n out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w;\n return out;\n}\n/**\n * Transforms the vec3 with a mat3.\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to transform\n * @param {ReadonlyMat3} m the 3x3 matrix to transform with\n * @returns {vec3} out\n */\n\nfunction transformMat3$1(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2];\n out[0] = x * m[0] + y * m[3] + z * m[6];\n out[1] = x * m[1] + y * m[4] + z * m[7];\n out[2] = x * m[2] + y * m[5] + z * m[8];\n return out;\n}\n/**\n * Transforms the vec3 with a quat\n * Can also be used for dual quaternions. (Multiply it with the real part)\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec3} a the vector to transform\n * @param {ReadonlyQuat} q quaternion to transform with\n * @returns {vec3} out\n */\n\nfunction transformQuat$1(out, a, q) {\n // benchmarks: https://jsperf.com/quaternion-transform-vec3-implementations-fixed\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3];\n var x = a[0],\n y = a[1],\n z = a[2]; // var qvec = [qx, qy, qz];\n // var uv = vec3.cross([], qvec, a);\n\n var uvx = qy * z - qz * y,\n uvy = qz * x - qx * z,\n uvz = qx * y - qy * x; // var uuv = vec3.cross([], qvec, uv);\n\n var uuvx = qy * uvz - qz * uvy,\n uuvy = qz * uvx - qx * uvz,\n uuvz = qx * uvy - qy * uvx; // vec3.scale(uv, uv, 2 * w);\n\n var w2 = qw * 2;\n uvx *= w2;\n uvy *= w2;\n uvz *= w2; // vec3.scale(uuv, uuv, 2);\n\n uuvx *= 2;\n uuvy *= 2;\n uuvz *= 2; // return vec3.add(out, a, vec3.add(out, uv, uuv));\n\n out[0] = x + uvx + uuvx;\n out[1] = y + uvy + uuvy;\n out[2] = z + uvz + uuvz;\n return out;\n}\n/**\n * Rotate a 3D vector around the x-axis\n * @param {vec3} out The receiving vec3\n * @param {ReadonlyVec3} a The vec3 point to rotate\n * @param {ReadonlyVec3} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec3} out\n */\n\nfunction rotateX$2(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[0];\n r[1] = p[1] * Math.cos(rad) - p[2] * Math.sin(rad);\n r[2] = p[1] * Math.sin(rad) + p[2] * Math.cos(rad); //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\n * Rotate a 3D vector around the y-axis\n * @param {vec3} out The receiving vec3\n * @param {ReadonlyVec3} a The vec3 point to rotate\n * @param {ReadonlyVec3} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec3} out\n */\n\nfunction rotateY$2(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[2] * Math.sin(rad) + p[0] * Math.cos(rad);\n r[1] = p[1];\n r[2] = p[2] * Math.cos(rad) - p[0] * Math.sin(rad); //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\n * Rotate a 3D vector around the z-axis\n * @param {vec3} out The receiving vec3\n * @param {ReadonlyVec3} a The vec3 point to rotate\n * @param {ReadonlyVec3} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec3} out\n */\n\nfunction rotateZ$2(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[0] * Math.cos(rad) - p[1] * Math.sin(rad);\n r[1] = p[0] * Math.sin(rad) + p[1] * Math.cos(rad);\n r[2] = p[2]; //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\n * Get the angle between two 3D vectors\n * @param {ReadonlyVec3} a The first operand\n * @param {ReadonlyVec3} b The second operand\n * @returns {Number} The angle in radians\n */\n\nfunction angle$1(a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2],\n bx = b[0],\n by = b[1],\n bz = b[2],\n mag1 = Math.sqrt(ax * ax + ay * ay + az * az),\n mag2 = Math.sqrt(bx * bx + by * by + bz * bz),\n mag = mag1 * mag2,\n cosine = mag && dot$4(a, b) / mag;\n return Math.acos(Math.min(Math.max(cosine, -1), 1));\n}\n/**\n * Set the components of a vec3 to zero\n *\n * @param {vec3} out the receiving vector\n * @returns {vec3} out\n */\n\nfunction zero$2(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n out[2] = 0.0;\n return out;\n}\n/**\n * Returns a string representation of a vector\n *\n * @param {ReadonlyVec3} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\n\nfunction str$4(a) {\n return \"vec3(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \")\";\n}\n/**\n * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyVec3} a The first vector.\n * @param {ReadonlyVec3} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nfunction exactEquals$4(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2];\n}\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {ReadonlyVec3} a The first vector.\n * @param {ReadonlyVec3} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nfunction equals$4(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2];\n return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2));\n}\n/**\n * Alias for {@link vec3.subtract}\n * @function\n */\n\nvar sub$2 = subtract$2;\n/**\n * Alias for {@link vec3.multiply}\n * @function\n */\n\nvar mul$4 = multiply$4;\n/**\n * Alias for {@link vec3.divide}\n * @function\n */\n\nvar div$2 = divide$2;\n/**\n * Alias for {@link vec3.distance}\n * @function\n */\n\nvar dist$2 = distance$2;\n/**\n * Alias for {@link vec3.squaredDistance}\n * @function\n */\n\nvar sqrDist$2 = squaredDistance$2;\n/**\n * Alias for {@link vec3.length}\n * @function\n */\n\nvar len$4 = length$4;\n/**\n * Alias for {@link vec3.squaredLength}\n * @function\n */\n\nvar sqrLen$4 = squaredLength$4;\n/**\n * Perform some operation over an array of vec3s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\n\nvar forEach$2 = function () {\n var vec = create$4();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 3;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n }\n\n return a;\n };\n}();\n\nvar vec3 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$4,\n clone: clone$4,\n length: length$4,\n fromValues: fromValues$4,\n copy: copy$4,\n set: set$4,\n add: add$4,\n subtract: subtract$2,\n multiply: multiply$4,\n divide: divide$2,\n ceil: ceil$2,\n floor: floor$2,\n min: min$2,\n max: max$2,\n round: round$2,\n scale: scale$4,\n scaleAndAdd: scaleAndAdd$2,\n distance: distance$2,\n squaredDistance: squaredDistance$2,\n squaredLength: squaredLength$4,\n negate: negate$2,\n inverse: inverse$2,\n normalize: normalize$4,\n dot: dot$4,\n cross: cross$2,\n lerp: lerp$4,\n hermite: hermite,\n bezier: bezier,\n random: random$3,\n transformMat4: transformMat4$2,\n transformMat3: transformMat3$1,\n transformQuat: transformQuat$1,\n rotateX: rotateX$2,\n rotateY: rotateY$2,\n rotateZ: rotateZ$2,\n angle: angle$1,\n zero: zero$2,\n str: str$4,\n exactEquals: exactEquals$4,\n equals: equals$4,\n sub: sub$2,\n mul: mul$4,\n div: div$2,\n dist: dist$2,\n sqrDist: sqrDist$2,\n len: len$4,\n sqrLen: sqrLen$4,\n forEach: forEach$2\n});\n\n/**\n * 4 Dimensional Vector\n * @module vec4\n */\n\n/**\n * Creates a new, empty vec4\n *\n * @returns {vec4} a new 4D vector\n */\n\nfunction create$3() {\n var out = new ARRAY_TYPE(4);\n\n if (ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n }\n\n return out;\n}\n/**\n * Creates a new vec4 initialized with values from an existing vector\n *\n * @param {ReadonlyVec4} a vector to clone\n * @returns {vec4} a new 4D vector\n */\n\nfunction clone$3(a) {\n var out = new ARRAY_TYPE(4);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Creates a new vec4 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} a new 4D vector\n */\n\nfunction fromValues$3(x, y, z, w) {\n var out = new ARRAY_TYPE(4);\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = w;\n return out;\n}\n/**\n * Copy the values from one vec4 to another\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the source vector\n * @returns {vec4} out\n */\n\nfunction copy$3(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Set the components of a vec4 to the given values\n *\n * @param {vec4} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} out\n */\n\nfunction set$3(out, x, y, z, w) {\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = w;\n return out;\n}\n/**\n * Adds two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nfunction add$3(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n return out;\n}\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nfunction subtract$1(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n return out;\n}\n/**\n * Multiplies two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nfunction multiply$3(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n out[2] = a[2] * b[2];\n out[3] = a[3] * b[3];\n return out;\n}\n/**\n * Divides two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nfunction divide$1(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n out[2] = a[2] / b[2];\n out[3] = a[3] / b[3];\n return out;\n}\n/**\n * Math.ceil the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to ceil\n * @returns {vec4} out\n */\n\nfunction ceil$1(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n out[2] = Math.ceil(a[2]);\n out[3] = Math.ceil(a[3]);\n return out;\n}\n/**\n * Math.floor the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to floor\n * @returns {vec4} out\n */\n\nfunction floor$1(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n out[2] = Math.floor(a[2]);\n out[3] = Math.floor(a[3]);\n return out;\n}\n/**\n * Returns the minimum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nfunction min$1(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n out[2] = Math.min(a[2], b[2]);\n out[3] = Math.min(a[3], b[3]);\n return out;\n}\n/**\n * Returns the maximum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {vec4} out\n */\n\nfunction max$1(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n out[2] = Math.max(a[2], b[2]);\n out[3] = Math.max(a[3], b[3]);\n return out;\n}\n/**\n * Math.round the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to round\n * @returns {vec4} out\n */\n\nfunction round$1(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n out[2] = Math.round(a[2]);\n out[3] = Math.round(a[3]);\n return out;\n}\n/**\n * Scales a vec4 by a scalar number\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec4} out\n */\n\nfunction scale$3(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n return out;\n}\n/**\n * Adds two vec4's after scaling the second operand by a scalar value\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec4} out\n */\n\nfunction scaleAndAdd$1(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n return out;\n}\n/**\n * Calculates the euclidian distance between two vec4's\n *\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {Number} distance between a and b\n */\n\nfunction distance$1(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n var w = b[3] - a[3];\n return Math.hypot(x, y, z, w);\n}\n/**\n * Calculates the squared euclidian distance between two vec4's\n *\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {Number} squared distance between a and b\n */\n\nfunction squaredDistance$1(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n var w = b[3] - a[3];\n return x * x + y * y + z * z + w * w;\n}\n/**\n * Calculates the length of a vec4\n *\n * @param {ReadonlyVec4} a vector to calculate length of\n * @returns {Number} length of a\n */\n\nfunction length$3(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n return Math.hypot(x, y, z, w);\n}\n/**\n * Calculates the squared length of a vec4\n *\n * @param {ReadonlyVec4} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\n\nfunction squaredLength$3(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n return x * x + y * y + z * z + w * w;\n}\n/**\n * Negates the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to negate\n * @returns {vec4} out\n */\n\nfunction negate$1(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = -a[3];\n return out;\n}\n/**\n * Returns the inverse of the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to invert\n * @returns {vec4} out\n */\n\nfunction inverse$1(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n out[2] = 1.0 / a[2];\n out[3] = 1.0 / a[3];\n return out;\n}\n/**\n * Normalize a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a vector to normalize\n * @returns {vec4} out\n */\n\nfunction normalize$3(out, a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n var len = x * x + y * y + z * z + w * w;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = x * len;\n out[1] = y * len;\n out[2] = z * len;\n out[3] = w * len;\n return out;\n}\n/**\n * Calculates the dot product of two vec4's\n *\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @returns {Number} dot product of a and b\n */\n\nfunction dot$3(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n}\n/**\n * Returns the cross-product of three vectors in a 4-dimensional space\n *\n * @param {ReadonlyVec4} result the receiving vector\n * @param {ReadonlyVec4} U the first vector\n * @param {ReadonlyVec4} V the second vector\n * @param {ReadonlyVec4} W the third vector\n * @returns {vec4} result\n */\n\nfunction cross$1(out, u, v, w) {\n var A = v[0] * w[1] - v[1] * w[0],\n B = v[0] * w[2] - v[2] * w[0],\n C = v[0] * w[3] - v[3] * w[0],\n D = v[1] * w[2] - v[2] * w[1],\n E = v[1] * w[3] - v[3] * w[1],\n F = v[2] * w[3] - v[3] * w[2];\n var G = u[0];\n var H = u[1];\n var I = u[2];\n var J = u[3];\n out[0] = H * F - I * E + J * D;\n out[1] = -(G * F) + I * C - J * B;\n out[2] = G * E - H * C + J * A;\n out[3] = -(G * D) + H * B - I * A;\n return out;\n}\n/**\n * Performs a linear interpolation between two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the first operand\n * @param {ReadonlyVec4} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec4} out\n */\n\nfunction lerp$3(out, a, b, t) {\n var ax = a[0];\n var ay = a[1];\n var az = a[2];\n var aw = a[3];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n out[2] = az + t * (b[2] - az);\n out[3] = aw + t * (b[3] - aw);\n return out;\n}\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec4} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec4} out\n */\n\nfunction random$2(out, scale) {\n scale = scale || 1.0; // Marsaglia, George. Choosing a Point from the Surface of a\n // Sphere. Ann. Math. Statist. 43 (1972), no. 2, 645--646.\n // http://projecteuclid.org/euclid.aoms/1177692644;\n\n var v1, v2, v3, v4;\n var s1, s2;\n\n do {\n v1 = RANDOM() * 2 - 1;\n v2 = RANDOM() * 2 - 1;\n s1 = v1 * v1 + v2 * v2;\n } while (s1 >= 1);\n\n do {\n v3 = RANDOM() * 2 - 1;\n v4 = RANDOM() * 2 - 1;\n s2 = v3 * v3 + v4 * v4;\n } while (s2 >= 1);\n\n var d = Math.sqrt((1 - s1) / s2);\n out[0] = scale * v1;\n out[1] = scale * v2;\n out[2] = scale * v3 * d;\n out[3] = scale * v4 * d;\n return out;\n}\n/**\n * Transforms the vec4 with a mat4.\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the vector to transform\n * @param {ReadonlyMat4} m matrix to transform with\n * @returns {vec4} out\n */\n\nfunction transformMat4$1(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n return out;\n}\n/**\n * Transforms the vec4 with a quat\n *\n * @param {vec4} out the receiving vector\n * @param {ReadonlyVec4} a the vector to transform\n * @param {ReadonlyQuat} q quaternion to transform with\n * @returns {vec4} out\n */\n\nfunction transformQuat(out, a, q) {\n var x = a[0],\n y = a[1],\n z = a[2];\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3]; // calculate quat * vec\n\n var ix = qw * x + qy * z - qz * y;\n var iy = qw * y + qz * x - qx * z;\n var iz = qw * z + qx * y - qy * x;\n var iw = -qx * x - qy * y - qz * z; // calculate result * inverse quat\n\n out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n out[3] = a[3];\n return out;\n}\n/**\n * Set the components of a vec4 to zero\n *\n * @param {vec4} out the receiving vector\n * @returns {vec4} out\n */\n\nfunction zero$1(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n out[2] = 0.0;\n out[3] = 0.0;\n return out;\n}\n/**\n * Returns a string representation of a vector\n *\n * @param {ReadonlyVec4} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\n\nfunction str$3(a) {\n return \"vec4(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n/**\n * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyVec4} a The first vector.\n * @param {ReadonlyVec4} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nfunction exactEquals$3(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];\n}\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {ReadonlyVec4} a The first vector.\n * @param {ReadonlyVec4} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nfunction equals$3(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3));\n}\n/**\n * Alias for {@link vec4.subtract}\n * @function\n */\n\nvar sub$1 = subtract$1;\n/**\n * Alias for {@link vec4.multiply}\n * @function\n */\n\nvar mul$3 = multiply$3;\n/**\n * Alias for {@link vec4.divide}\n * @function\n */\n\nvar div$1 = divide$1;\n/**\n * Alias for {@link vec4.distance}\n * @function\n */\n\nvar dist$1 = distance$1;\n/**\n * Alias for {@link vec4.squaredDistance}\n * @function\n */\n\nvar sqrDist$1 = squaredDistance$1;\n/**\n * Alias for {@link vec4.length}\n * @function\n */\n\nvar len$3 = length$3;\n/**\n * Alias for {@link vec4.squaredLength}\n * @function\n */\n\nvar sqrLen$3 = squaredLength$3;\n/**\n * Perform some operation over an array of vec4s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec4s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\n\nvar forEach$1 = function () {\n var vec = create$3();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 4;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n vec[3] = a[i + 3];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n a[i + 3] = vec[3];\n }\n\n return a;\n };\n}();\n\nvar vec4 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$3,\n clone: clone$3,\n fromValues: fromValues$3,\n copy: copy$3,\n set: set$3,\n add: add$3,\n subtract: subtract$1,\n multiply: multiply$3,\n divide: divide$1,\n ceil: ceil$1,\n floor: floor$1,\n min: min$1,\n max: max$1,\n round: round$1,\n scale: scale$3,\n scaleAndAdd: scaleAndAdd$1,\n distance: distance$1,\n squaredDistance: squaredDistance$1,\n length: length$3,\n squaredLength: squaredLength$3,\n negate: negate$1,\n inverse: inverse$1,\n normalize: normalize$3,\n dot: dot$3,\n cross: cross$1,\n lerp: lerp$3,\n random: random$2,\n transformMat4: transformMat4$1,\n transformQuat: transformQuat,\n zero: zero$1,\n str: str$3,\n exactEquals: exactEquals$3,\n equals: equals$3,\n sub: sub$1,\n mul: mul$3,\n div: div$1,\n dist: dist$1,\n sqrDist: sqrDist$1,\n len: len$3,\n sqrLen: sqrLen$3,\n forEach: forEach$1\n});\n\n/**\n * Quaternion\n * @module quat\n */\n\n/**\n * Creates a new identity quat\n *\n * @returns {quat} a new quaternion\n */\n\nfunction create$2() {\n var out = new ARRAY_TYPE(4);\n\n if (ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n }\n\n out[3] = 1;\n return out;\n}\n/**\n * Set a quat to the identity quaternion\n *\n * @param {quat} out the receiving quaternion\n * @returns {quat} out\n */\n\nfunction identity$1(out) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n}\n/**\n * Sets a quat from the given angle and rotation axis,\n * then returns it.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyVec3} axis the axis around which to rotate\n * @param {Number} rad the angle in radians\n * @returns {quat} out\n **/\n\nfunction setAxisAngle(out, axis, rad) {\n rad = rad * 0.5;\n var s = Math.sin(rad);\n out[0] = s * axis[0];\n out[1] = s * axis[1];\n out[2] = s * axis[2];\n out[3] = Math.cos(rad);\n return out;\n}\n/**\n * Gets the rotation axis and angle for a given\n * quaternion. If a quaternion is created with\n * setAxisAngle, this method will return the same\n * values as providied in the original parameter list\n * OR functionally equivalent values.\n * Example: The quaternion formed by axis [0, 0, 1] and\n * angle -90 is the same as the quaternion formed by\n * [0, 0, 1] and 270. This method favors the latter.\n * @param {vec3} out_axis Vector receiving the axis of rotation\n * @param {ReadonlyQuat} q Quaternion to be decomposed\n * @return {Number} Angle, in radians, of the rotation\n */\n\nfunction getAxisAngle(out_axis, q) {\n var rad = Math.acos(q[3]) * 2.0;\n var s = Math.sin(rad / 2.0);\n\n if (s > EPSILON) {\n out_axis[0] = q[0] / s;\n out_axis[1] = q[1] / s;\n out_axis[2] = q[2] / s;\n } else {\n // If s is zero, return any axis (no rotation - axis does not matter)\n out_axis[0] = 1;\n out_axis[1] = 0;\n out_axis[2] = 0;\n }\n\n return rad;\n}\n/**\n * Gets the angular distance between two unit quaternions\n *\n * @param {ReadonlyQuat} a Origin unit quaternion\n * @param {ReadonlyQuat} b Destination unit quaternion\n * @return {Number} Angle, in radians, between the two quaternions\n */\n\nfunction getAngle(a, b) {\n var dotproduct = dot$2(a, b);\n return Math.acos(2 * dotproduct * dotproduct - 1);\n}\n/**\n * Multiplies two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @returns {quat} out\n */\n\nfunction multiply$2(out, a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bx = b[0],\n by = b[1],\n bz = b[2],\n bw = b[3];\n out[0] = ax * bw + aw * bx + ay * bz - az * by;\n out[1] = ay * bw + aw * by + az * bx - ax * bz;\n out[2] = az * bw + aw * bz + ax * by - ay * bx;\n out[3] = aw * bw - ax * bx - ay * by - az * bz;\n return out;\n}\n/**\n * Rotates a quaternion by the given angle about the X axis\n *\n * @param {quat} out quat receiving operation result\n * @param {ReadonlyQuat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\n\nfunction rotateX$1(out, a, rad) {\n rad *= 0.5;\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bx = Math.sin(rad),\n bw = Math.cos(rad);\n out[0] = ax * bw + aw * bx;\n out[1] = ay * bw + az * bx;\n out[2] = az * bw - ay * bx;\n out[3] = aw * bw - ax * bx;\n return out;\n}\n/**\n * Rotates a quaternion by the given angle about the Y axis\n *\n * @param {quat} out quat receiving operation result\n * @param {ReadonlyQuat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\n\nfunction rotateY$1(out, a, rad) {\n rad *= 0.5;\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var by = Math.sin(rad),\n bw = Math.cos(rad);\n out[0] = ax * bw - az * by;\n out[1] = ay * bw + aw * by;\n out[2] = az * bw + ax * by;\n out[3] = aw * bw - ay * by;\n return out;\n}\n/**\n * Rotates a quaternion by the given angle about the Z axis\n *\n * @param {quat} out quat receiving operation result\n * @param {ReadonlyQuat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\n\nfunction rotateZ$1(out, a, rad) {\n rad *= 0.5;\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bz = Math.sin(rad),\n bw = Math.cos(rad);\n out[0] = ax * bw + ay * bz;\n out[1] = ay * bw - ax * bz;\n out[2] = az * bw + aw * bz;\n out[3] = aw * bw - az * bz;\n return out;\n}\n/**\n * Calculates the W component of a quat from the X, Y, and Z components.\n * Assumes that quaternion is 1 unit in length.\n * Any existing W component will be ignored.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate W component of\n * @returns {quat} out\n */\n\nfunction calculateW(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2];\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));\n return out;\n}\n/**\n * Calculate the exponential of a unit quaternion.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate the exponential of\n * @returns {quat} out\n */\n\nfunction exp(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n var r = Math.sqrt(x * x + y * y + z * z);\n var et = Math.exp(w);\n var s = r > 0 ? et * Math.sin(r) / r : 0;\n out[0] = x * s;\n out[1] = y * s;\n out[2] = z * s;\n out[3] = et * Math.cos(r);\n return out;\n}\n/**\n * Calculate the natural logarithm of a unit quaternion.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate the exponential of\n * @returns {quat} out\n */\n\nfunction ln(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n var r = Math.sqrt(x * x + y * y + z * z);\n var t = r > 0 ? Math.atan2(r, w) / r : 0;\n out[0] = x * t;\n out[1] = y * t;\n out[2] = z * t;\n out[3] = 0.5 * Math.log(x * x + y * y + z * z + w * w);\n return out;\n}\n/**\n * Calculate the scalar power of a unit quaternion.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate the exponential of\n * @param {Number} b amount to scale the quaternion by\n * @returns {quat} out\n */\n\nfunction pow(out, a, b) {\n ln(out, a);\n scale$2(out, out, b);\n exp(out, out);\n return out;\n}\n/**\n * Performs a spherical linear interpolation between two quat\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {quat} out\n */\n\nfunction slerp(out, a, b, t) {\n // benchmarks:\n // http://jsperf.com/quaternion-slerp-implementations\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bx = b[0],\n by = b[1],\n bz = b[2],\n bw = b[3];\n var omega, cosom, sinom, scale0, scale1; // calc cosine\n\n cosom = ax * bx + ay * by + az * bz + aw * bw; // adjust signs (if necessary)\n\n if (cosom < 0.0) {\n cosom = -cosom;\n bx = -bx;\n by = -by;\n bz = -bz;\n bw = -bw;\n } // calculate coefficients\n\n\n if (1.0 - cosom > EPSILON) {\n // standard case (slerp)\n omega = Math.acos(cosom);\n sinom = Math.sin(omega);\n scale0 = Math.sin((1.0 - t) * omega) / sinom;\n scale1 = Math.sin(t * omega) / sinom;\n } else {\n // \"from\" and \"to\" quaternions are very close\n // ... so we can do a linear interpolation\n scale0 = 1.0 - t;\n scale1 = t;\n } // calculate final values\n\n\n out[0] = scale0 * ax + scale1 * bx;\n out[1] = scale0 * ay + scale1 * by;\n out[2] = scale0 * az + scale1 * bz;\n out[3] = scale0 * aw + scale1 * bw;\n return out;\n}\n/**\n * Generates a random unit quaternion\n *\n * @param {quat} out the receiving quaternion\n * @returns {quat} out\n */\n\nfunction random$1(out) {\n // Implementation of http://planning.cs.uiuc.edu/node198.html\n // TODO: Calling random 3 times is probably not the fastest solution\n var u1 = RANDOM();\n var u2 = RANDOM();\n var u3 = RANDOM();\n var sqrt1MinusU1 = Math.sqrt(1 - u1);\n var sqrtU1 = Math.sqrt(u1);\n out[0] = sqrt1MinusU1 * Math.sin(2.0 * Math.PI * u2);\n out[1] = sqrt1MinusU1 * Math.cos(2.0 * Math.PI * u2);\n out[2] = sqrtU1 * Math.sin(2.0 * Math.PI * u3);\n out[3] = sqrtU1 * Math.cos(2.0 * Math.PI * u3);\n return out;\n}\n/**\n * Calculates the inverse of a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate inverse of\n * @returns {quat} out\n */\n\nfunction invert$1(out, a) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var dot = a0 * a0 + a1 * a1 + a2 * a2 + a3 * a3;\n var invDot = dot ? 1.0 / dot : 0; // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0\n\n out[0] = -a0 * invDot;\n out[1] = -a1 * invDot;\n out[2] = -a2 * invDot;\n out[3] = a3 * invDot;\n return out;\n}\n/**\n * Calculates the conjugate of a quat\n * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate conjugate of\n * @returns {quat} out\n */\n\nfunction conjugate$1(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Creates a quaternion from the given 3x3 rotation matrix.\n *\n * NOTE: The resultant quaternion is not normalized, so you should be sure\n * to renormalize the quaternion yourself where necessary.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyMat3} m rotation matrix\n * @returns {quat} out\n * @function\n */\n\nfunction fromMat3(out, m) {\n // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes\n // article \"Quaternion Calculus and Fast Animation\".\n var fTrace = m[0] + m[4] + m[8];\n var fRoot;\n\n if (fTrace > 0.0) {\n // |w| > 1/2, may as well choose w > 1/2\n fRoot = Math.sqrt(fTrace + 1.0); // 2w\n\n out[3] = 0.5 * fRoot;\n fRoot = 0.5 / fRoot; // 1/(4w)\n\n out[0] = (m[5] - m[7]) * fRoot;\n out[1] = (m[6] - m[2]) * fRoot;\n out[2] = (m[1] - m[3]) * fRoot;\n } else {\n // |w| <= 1/2\n var i = 0;\n if (m[4] > m[0]) i = 1;\n if (m[8] > m[i * 3 + i]) i = 2;\n var j = (i + 1) % 3;\n var k = (i + 2) % 3;\n fRoot = Math.sqrt(m[i * 3 + i] - m[j * 3 + j] - m[k * 3 + k] + 1.0);\n out[i] = 0.5 * fRoot;\n fRoot = 0.5 / fRoot;\n out[3] = (m[j * 3 + k] - m[k * 3 + j]) * fRoot;\n out[j] = (m[j * 3 + i] + m[i * 3 + j]) * fRoot;\n out[k] = (m[k * 3 + i] + m[i * 3 + k]) * fRoot;\n }\n\n return out;\n}\n/**\n * Creates a quaternion from the given euler angle x, y, z.\n *\n * @param {quat} out the receiving quaternion\n * @param {x} Angle to rotate around X axis in degrees.\n * @param {y} Angle to rotate around Y axis in degrees.\n * @param {z} Angle to rotate around Z axis in degrees.\n * @returns {quat} out\n * @function\n */\n\nfunction fromEuler(out, x, y, z) {\n var halfToRad = 0.5 * Math.PI / 180.0;\n x *= halfToRad;\n y *= halfToRad;\n z *= halfToRad;\n var sx = Math.sin(x);\n var cx = Math.cos(x);\n var sy = Math.sin(y);\n var cy = Math.cos(y);\n var sz = Math.sin(z);\n var cz = Math.cos(z);\n out[0] = sx * cy * cz - cx * sy * sz;\n out[1] = cx * sy * cz + sx * cy * sz;\n out[2] = cx * cy * sz - sx * sy * cz;\n out[3] = cx * cy * cz + sx * sy * sz;\n return out;\n}\n/**\n * Returns a string representation of a quatenion\n *\n * @param {ReadonlyQuat} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\n\nfunction str$2(a) {\n return \"quat(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n/**\n * Creates a new quat initialized with values from an existing quaternion\n *\n * @param {ReadonlyQuat} a quaternion to clone\n * @returns {quat} a new quaternion\n * @function\n */\n\nvar clone$2 = clone$3;\n/**\n * Creates a new quat initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} a new quaternion\n * @function\n */\n\nvar fromValues$2 = fromValues$3;\n/**\n * Copy the values from one quat to another\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the source quaternion\n * @returns {quat} out\n * @function\n */\n\nvar copy$2 = copy$3;\n/**\n * Set the components of a quat to the given values\n *\n * @param {quat} out the receiving quaternion\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} out\n * @function\n */\n\nvar set$2 = set$3;\n/**\n * Adds two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @returns {quat} out\n * @function\n */\n\nvar add$2 = add$3;\n/**\n * Alias for {@link quat.multiply}\n * @function\n */\n\nvar mul$2 = multiply$2;\n/**\n * Scales a quat by a scalar number\n *\n * @param {quat} out the receiving vector\n * @param {ReadonlyQuat} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {quat} out\n * @function\n */\n\nvar scale$2 = scale$3;\n/**\n * Calculates the dot product of two quat's\n *\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @returns {Number} dot product of a and b\n * @function\n */\n\nvar dot$2 = dot$3;\n/**\n * Performs a linear interpolation between two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {quat} out\n * @function\n */\n\nvar lerp$2 = lerp$3;\n/**\n * Calculates the length of a quat\n *\n * @param {ReadonlyQuat} a vector to calculate length of\n * @returns {Number} length of a\n */\n\nvar length$2 = length$3;\n/**\n * Alias for {@link quat.length}\n * @function\n */\n\nvar len$2 = length$2;\n/**\n * Calculates the squared length of a quat\n *\n * @param {ReadonlyQuat} a vector to calculate squared length of\n * @returns {Number} squared length of a\n * @function\n */\n\nvar squaredLength$2 = squaredLength$3;\n/**\n * Alias for {@link quat.squaredLength}\n * @function\n */\n\nvar sqrLen$2 = squaredLength$2;\n/**\n * Normalize a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quaternion to normalize\n * @returns {quat} out\n * @function\n */\n\nvar normalize$2 = normalize$3;\n/**\n * Returns whether or not the quaternions have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyQuat} a The first quaternion.\n * @param {ReadonlyQuat} b The second quaternion.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nvar exactEquals$2 = exactEquals$3;\n/**\n * Returns whether or not the quaternions have approximately the same elements in the same position.\n *\n * @param {ReadonlyQuat} a The first vector.\n * @param {ReadonlyQuat} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nvar equals$2 = equals$3;\n/**\n * Sets a quaternion to represent the shortest rotation from one\n * vector to another.\n *\n * Both vectors are assumed to be unit length.\n *\n * @param {quat} out the receiving quaternion.\n * @param {ReadonlyVec3} a the initial vector\n * @param {ReadonlyVec3} b the destination vector\n * @returns {quat} out\n */\n\nvar rotationTo = function () {\n var tmpvec3 = create$4();\n var xUnitVec3 = fromValues$4(1, 0, 0);\n var yUnitVec3 = fromValues$4(0, 1, 0);\n return function (out, a, b) {\n var dot = dot$4(a, b);\n\n if (dot < -0.999999) {\n cross$2(tmpvec3, xUnitVec3, a);\n if (len$4(tmpvec3) < 0.000001) cross$2(tmpvec3, yUnitVec3, a);\n normalize$4(tmpvec3, tmpvec3);\n setAxisAngle(out, tmpvec3, Math.PI);\n return out;\n } else if (dot > 0.999999) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n } else {\n cross$2(tmpvec3, a, b);\n out[0] = tmpvec3[0];\n out[1] = tmpvec3[1];\n out[2] = tmpvec3[2];\n out[3] = 1 + dot;\n return normalize$2(out, out);\n }\n };\n}();\n/**\n * Performs a spherical linear interpolation with two control points\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @param {ReadonlyQuat} c the third operand\n * @param {ReadonlyQuat} d the fourth operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {quat} out\n */\n\nvar sqlerp = function () {\n var temp1 = create$2();\n var temp2 = create$2();\n return function (out, a, b, c, d, t) {\n slerp(temp1, a, d, t);\n slerp(temp2, b, c, t);\n slerp(out, temp1, temp2, 2 * t * (1 - t));\n return out;\n };\n}();\n/**\n * Sets the specified quaternion with values corresponding to the given\n * axes. Each axis is a vec3 and is expected to be unit length and\n * perpendicular to all other specified axes.\n *\n * @param {ReadonlyVec3} view the vector representing the viewing direction\n * @param {ReadonlyVec3} right the vector representing the local \"right\" direction\n * @param {ReadonlyVec3} up the vector representing the local \"up\" direction\n * @returns {quat} out\n */\n\nvar setAxes = function () {\n var matr = create$6();\n return function (out, view, right, up) {\n matr[0] = right[0];\n matr[3] = right[1];\n matr[6] = right[2];\n matr[1] = up[0];\n matr[4] = up[1];\n matr[7] = up[2];\n matr[2] = -view[0];\n matr[5] = -view[1];\n matr[8] = -view[2];\n return normalize$2(out, fromMat3(out, matr));\n };\n}();\n\nvar quat = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$2,\n identity: identity$1,\n setAxisAngle: setAxisAngle,\n getAxisAngle: getAxisAngle,\n getAngle: getAngle,\n multiply: multiply$2,\n rotateX: rotateX$1,\n rotateY: rotateY$1,\n rotateZ: rotateZ$1,\n calculateW: calculateW,\n exp: exp,\n ln: ln,\n pow: pow,\n slerp: slerp,\n random: random$1,\n invert: invert$1,\n conjugate: conjugate$1,\n fromMat3: fromMat3,\n fromEuler: fromEuler,\n str: str$2,\n clone: clone$2,\n fromValues: fromValues$2,\n copy: copy$2,\n set: set$2,\n add: add$2,\n mul: mul$2,\n scale: scale$2,\n dot: dot$2,\n lerp: lerp$2,\n length: length$2,\n len: len$2,\n squaredLength: squaredLength$2,\n sqrLen: sqrLen$2,\n normalize: normalize$2,\n exactEquals: exactEquals$2,\n equals: equals$2,\n rotationTo: rotationTo,\n sqlerp: sqlerp,\n setAxes: setAxes\n});\n\n/**\n * Dual Quaternion \n * Format: [real, dual] \n * Quaternion format: XYZW \n * Make sure to have normalized dual quaternions, otherwise the functions may not work as intended. \n * @module quat2\n */\n\n/**\n * Creates a new identity dual quat\n *\n * @returns {quat2} a new dual quaternion [real -> rotation, dual -> translation]\n */\n\nfunction create$1() {\n var dq = new ARRAY_TYPE(8);\n\n if (ARRAY_TYPE != Float32Array) {\n dq[0] = 0;\n dq[1] = 0;\n dq[2] = 0;\n dq[4] = 0;\n dq[5] = 0;\n dq[6] = 0;\n dq[7] = 0;\n }\n\n dq[3] = 1;\n return dq;\n}\n/**\n * Creates a new quat initialized with values from an existing quaternion\n *\n * @param {ReadonlyQuat2} a dual quaternion to clone\n * @returns {quat2} new dual quaternion\n * @function\n */\n\nfunction clone$1(a) {\n var dq = new ARRAY_TYPE(8);\n dq[0] = a[0];\n dq[1] = a[1];\n dq[2] = a[2];\n dq[3] = a[3];\n dq[4] = a[4];\n dq[5] = a[5];\n dq[6] = a[6];\n dq[7] = a[7];\n return dq;\n}\n/**\n * Creates a new dual quat initialized with the given values\n *\n * @param {Number} x1 X component\n * @param {Number} y1 Y component\n * @param {Number} z1 Z component\n * @param {Number} w1 W component\n * @param {Number} x2 X component\n * @param {Number} y2 Y component\n * @param {Number} z2 Z component\n * @param {Number} w2 W component\n * @returns {quat2} new dual quaternion\n * @function\n */\n\nfunction fromValues$1(x1, y1, z1, w1, x2, y2, z2, w2) {\n var dq = new ARRAY_TYPE(8);\n dq[0] = x1;\n dq[1] = y1;\n dq[2] = z1;\n dq[3] = w1;\n dq[4] = x2;\n dq[5] = y2;\n dq[6] = z2;\n dq[7] = w2;\n return dq;\n}\n/**\n * Creates a new dual quat from the given values (quat and translation)\n *\n * @param {Number} x1 X component\n * @param {Number} y1 Y component\n * @param {Number} z1 Z component\n * @param {Number} w1 W component\n * @param {Number} x2 X component (translation)\n * @param {Number} y2 Y component (translation)\n * @param {Number} z2 Z component (translation)\n * @returns {quat2} new dual quaternion\n * @function\n */\n\nfunction fromRotationTranslationValues(x1, y1, z1, w1, x2, y2, z2) {\n var dq = new ARRAY_TYPE(8);\n dq[0] = x1;\n dq[1] = y1;\n dq[2] = z1;\n dq[3] = w1;\n var ax = x2 * 0.5,\n ay = y2 * 0.5,\n az = z2 * 0.5;\n dq[4] = ax * w1 + ay * z1 - az * y1;\n dq[5] = ay * w1 + az * x1 - ax * z1;\n dq[6] = az * w1 + ax * y1 - ay * x1;\n dq[7] = -ax * x1 - ay * y1 - az * z1;\n return dq;\n}\n/**\n * Creates a dual quat from a quaternion and a translation\n *\n * @param {ReadonlyQuat2} dual quaternion receiving operation result\n * @param {ReadonlyQuat} q a normalized quaternion\n * @param {ReadonlyVec3} t tranlation vector\n * @returns {quat2} dual quaternion receiving operation result\n * @function\n */\n\nfunction fromRotationTranslation(out, q, t) {\n var ax = t[0] * 0.5,\n ay = t[1] * 0.5,\n az = t[2] * 0.5,\n bx = q[0],\n by = q[1],\n bz = q[2],\n bw = q[3];\n out[0] = bx;\n out[1] = by;\n out[2] = bz;\n out[3] = bw;\n out[4] = ax * bw + ay * bz - az * by;\n out[5] = ay * bw + az * bx - ax * bz;\n out[6] = az * bw + ax * by - ay * bx;\n out[7] = -ax * bx - ay * by - az * bz;\n return out;\n}\n/**\n * Creates a dual quat from a translation\n *\n * @param {ReadonlyQuat2} dual quaternion receiving operation result\n * @param {ReadonlyVec3} t translation vector\n * @returns {quat2} dual quaternion receiving operation result\n * @function\n */\n\nfunction fromTranslation(out, t) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n out[4] = t[0] * 0.5;\n out[5] = t[1] * 0.5;\n out[6] = t[2] * 0.5;\n out[7] = 0;\n return out;\n}\n/**\n * Creates a dual quat from a quaternion\n *\n * @param {ReadonlyQuat2} dual quaternion receiving operation result\n * @param {ReadonlyQuat} q the quaternion\n * @returns {quat2} dual quaternion receiving operation result\n * @function\n */\n\nfunction fromRotation(out, q) {\n out[0] = q[0];\n out[1] = q[1];\n out[2] = q[2];\n out[3] = q[3];\n out[4] = 0;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n return out;\n}\n/**\n * Creates a new dual quat from a matrix (4x4)\n *\n * @param {quat2} out the dual quaternion\n * @param {ReadonlyMat4} a the matrix\n * @returns {quat2} dual quat receiving operation result\n * @function\n */\n\nfunction fromMat4(out, a) {\n //TODO Optimize this\n var outer = create$2();\n getRotation(outer, a);\n var t = new ARRAY_TYPE(3);\n getTranslation$1(t, a);\n fromRotationTranslation(out, outer, t);\n return out;\n}\n/**\n * Copy the values from one dual quat to another\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a the source dual quaternion\n * @returns {quat2} out\n * @function\n */\n\nfunction copy$1(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n return out;\n}\n/**\n * Set a dual quat to the identity dual quaternion\n *\n * @param {quat2} out the receiving quaternion\n * @returns {quat2} out\n */\n\nfunction identity(out) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n out[4] = 0;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n return out;\n}\n/**\n * Set the components of a dual quat to the given values\n *\n * @param {quat2} out the receiving quaternion\n * @param {Number} x1 X component\n * @param {Number} y1 Y component\n * @param {Number} z1 Z component\n * @param {Number} w1 W component\n * @param {Number} x2 X component\n * @param {Number} y2 Y component\n * @param {Number} z2 Z component\n * @param {Number} w2 W component\n * @returns {quat2} out\n * @function\n */\n\nfunction set$1(out, x1, y1, z1, w1, x2, y2, z2, w2) {\n out[0] = x1;\n out[1] = y1;\n out[2] = z1;\n out[3] = w1;\n out[4] = x2;\n out[5] = y2;\n out[6] = z2;\n out[7] = w2;\n return out;\n}\n/**\n * Gets the real part of a dual quat\n * @param {quat} out real part\n * @param {ReadonlyQuat2} a Dual Quaternion\n * @return {quat} real part\n */\n\nvar getReal = copy$2;\n/**\n * Gets the dual part of a dual quat\n * @param {quat} out dual part\n * @param {ReadonlyQuat2} a Dual Quaternion\n * @return {quat} dual part\n */\n\nfunction getDual(out, a) {\n out[0] = a[4];\n out[1] = a[5];\n out[2] = a[6];\n out[3] = a[7];\n return out;\n}\n/**\n * Set the real component of a dual quat to the given quaternion\n *\n * @param {quat2} out the receiving quaternion\n * @param {ReadonlyQuat} q a quaternion representing the real part\n * @returns {quat2} out\n * @function\n */\n\nvar setReal = copy$2;\n/**\n * Set the dual component of a dual quat to the given quaternion\n *\n * @param {quat2} out the receiving quaternion\n * @param {ReadonlyQuat} q a quaternion representing the dual part\n * @returns {quat2} out\n * @function\n */\n\nfunction setDual(out, q) {\n out[4] = q[0];\n out[5] = q[1];\n out[6] = q[2];\n out[7] = q[3];\n return out;\n}\n/**\n * Gets the translation of a normalized dual quat\n * @param {vec3} out translation\n * @param {ReadonlyQuat2} a Dual Quaternion to be decomposed\n * @return {vec3} translation\n */\n\nfunction getTranslation(out, a) {\n var ax = a[4],\n ay = a[5],\n az = a[6],\n aw = a[7],\n bx = -a[0],\n by = -a[1],\n bz = -a[2],\n bw = a[3];\n out[0] = (ax * bw + aw * bx + ay * bz - az * by) * 2;\n out[1] = (ay * bw + aw * by + az * bx - ax * bz) * 2;\n out[2] = (az * bw + aw * bz + ax * by - ay * bx) * 2;\n return out;\n}\n/**\n * Translates a dual quat by the given vector\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a the dual quaternion to translate\n * @param {ReadonlyVec3} v vector to translate by\n * @returns {quat2} out\n */\n\nfunction translate(out, a, v) {\n var ax1 = a[0],\n ay1 = a[1],\n az1 = a[2],\n aw1 = a[3],\n bx1 = v[0] * 0.5,\n by1 = v[1] * 0.5,\n bz1 = v[2] * 0.5,\n ax2 = a[4],\n ay2 = a[5],\n az2 = a[6],\n aw2 = a[7];\n out[0] = ax1;\n out[1] = ay1;\n out[2] = az1;\n out[3] = aw1;\n out[4] = aw1 * bx1 + ay1 * bz1 - az1 * by1 + ax2;\n out[5] = aw1 * by1 + az1 * bx1 - ax1 * bz1 + ay2;\n out[6] = aw1 * bz1 + ax1 * by1 - ay1 * bx1 + az2;\n out[7] = -ax1 * bx1 - ay1 * by1 - az1 * bz1 + aw2;\n return out;\n}\n/**\n * Rotates a dual quat around the X axis\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a the dual quaternion to rotate\n * @param {number} rad how far should the rotation be\n * @returns {quat2} out\n */\n\nfunction rotateX(out, a, rad) {\n var bx = -a[0],\n by = -a[1],\n bz = -a[2],\n bw = a[3],\n ax = a[4],\n ay = a[5],\n az = a[6],\n aw = a[7],\n ax1 = ax * bw + aw * bx + ay * bz - az * by,\n ay1 = ay * bw + aw * by + az * bx - ax * bz,\n az1 = az * bw + aw * bz + ax * by - ay * bx,\n aw1 = aw * bw - ax * bx - ay * by - az * bz;\n rotateX$1(out, a, rad);\n bx = out[0];\n by = out[1];\n bz = out[2];\n bw = out[3];\n out[4] = ax1 * bw + aw1 * bx + ay1 * bz - az1 * by;\n out[5] = ay1 * bw + aw1 * by + az1 * bx - ax1 * bz;\n out[6] = az1 * bw + aw1 * bz + ax1 * by - ay1 * bx;\n out[7] = aw1 * bw - ax1 * bx - ay1 * by - az1 * bz;\n return out;\n}\n/**\n * Rotates a dual quat around the Y axis\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a the dual quaternion to rotate\n * @param {number} rad how far should the rotation be\n * @returns {quat2} out\n */\n\nfunction rotateY(out, a, rad) {\n var bx = -a[0],\n by = -a[1],\n bz = -a[2],\n bw = a[3],\n ax = a[4],\n ay = a[5],\n az = a[6],\n aw = a[7],\n ax1 = ax * bw + aw * bx + ay * bz - az * by,\n ay1 = ay * bw + aw * by + az * bx - ax * bz,\n az1 = az * bw + aw * bz + ax * by - ay * bx,\n aw1 = aw * bw - ax * bx - ay * by - az * bz;\n rotateY$1(out, a, rad);\n bx = out[0];\n by = out[1];\n bz = out[2];\n bw = out[3];\n out[4] = ax1 * bw + aw1 * bx + ay1 * bz - az1 * by;\n out[5] = ay1 * bw + aw1 * by + az1 * bx - ax1 * bz;\n out[6] = az1 * bw + aw1 * bz + ax1 * by - ay1 * bx;\n out[7] = aw1 * bw - ax1 * bx - ay1 * by - az1 * bz;\n return out;\n}\n/**\n * Rotates a dual quat around the Z axis\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a the dual quaternion to rotate\n * @param {number} rad how far should the rotation be\n * @returns {quat2} out\n */\n\nfunction rotateZ(out, a, rad) {\n var bx = -a[0],\n by = -a[1],\n bz = -a[2],\n bw = a[3],\n ax = a[4],\n ay = a[5],\n az = a[6],\n aw = a[7],\n ax1 = ax * bw + aw * bx + ay * bz - az * by,\n ay1 = ay * bw + aw * by + az * bx - ax * bz,\n az1 = az * bw + aw * bz + ax * by - ay * bx,\n aw1 = aw * bw - ax * bx - ay * by - az * bz;\n rotateZ$1(out, a, rad);\n bx = out[0];\n by = out[1];\n bz = out[2];\n bw = out[3];\n out[4] = ax1 * bw + aw1 * bx + ay1 * bz - az1 * by;\n out[5] = ay1 * bw + aw1 * by + az1 * bx - ax1 * bz;\n out[6] = az1 * bw + aw1 * bz + ax1 * by - ay1 * bx;\n out[7] = aw1 * bw - ax1 * bx - ay1 * by - az1 * bz;\n return out;\n}\n/**\n * Rotates a dual quat by a given quaternion (a * q)\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a the dual quaternion to rotate\n * @param {ReadonlyQuat} q quaternion to rotate by\n * @returns {quat2} out\n */\n\nfunction rotateByQuatAppend(out, a, q) {\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3],\n ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n out[0] = ax * qw + aw * qx + ay * qz - az * qy;\n out[1] = ay * qw + aw * qy + az * qx - ax * qz;\n out[2] = az * qw + aw * qz + ax * qy - ay * qx;\n out[3] = aw * qw - ax * qx - ay * qy - az * qz;\n ax = a[4];\n ay = a[5];\n az = a[6];\n aw = a[7];\n out[4] = ax * qw + aw * qx + ay * qz - az * qy;\n out[5] = ay * qw + aw * qy + az * qx - ax * qz;\n out[6] = az * qw + aw * qz + ax * qy - ay * qx;\n out[7] = aw * qw - ax * qx - ay * qy - az * qz;\n return out;\n}\n/**\n * Rotates a dual quat by a given quaternion (q * a)\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat} q quaternion to rotate by\n * @param {ReadonlyQuat2} a the dual quaternion to rotate\n * @returns {quat2} out\n */\n\nfunction rotateByQuatPrepend(out, q, a) {\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3],\n bx = a[0],\n by = a[1],\n bz = a[2],\n bw = a[3];\n out[0] = qx * bw + qw * bx + qy * bz - qz * by;\n out[1] = qy * bw + qw * by + qz * bx - qx * bz;\n out[2] = qz * bw + qw * bz + qx * by - qy * bx;\n out[3] = qw * bw - qx * bx - qy * by - qz * bz;\n bx = a[4];\n by = a[5];\n bz = a[6];\n bw = a[7];\n out[4] = qx * bw + qw * bx + qy * bz - qz * by;\n out[5] = qy * bw + qw * by + qz * bx - qx * bz;\n out[6] = qz * bw + qw * bz + qx * by - qy * bx;\n out[7] = qw * bw - qx * bx - qy * by - qz * bz;\n return out;\n}\n/**\n * Rotates a dual quat around a given axis. Does the normalisation automatically\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a the dual quaternion to rotate\n * @param {ReadonlyVec3} axis the axis to rotate around\n * @param {Number} rad how far the rotation should be\n * @returns {quat2} out\n */\n\nfunction rotateAroundAxis(out, a, axis, rad) {\n //Special case for rad = 0\n if (Math.abs(rad) < EPSILON) {\n return copy$1(out, a);\n }\n\n var axisLength = Math.hypot(axis[0], axis[1], axis[2]);\n rad = rad * 0.5;\n var s = Math.sin(rad);\n var bx = s * axis[0] / axisLength;\n var by = s * axis[1] / axisLength;\n var bz = s * axis[2] / axisLength;\n var bw = Math.cos(rad);\n var ax1 = a[0],\n ay1 = a[1],\n az1 = a[2],\n aw1 = a[3];\n out[0] = ax1 * bw + aw1 * bx + ay1 * bz - az1 * by;\n out[1] = ay1 * bw + aw1 * by + az1 * bx - ax1 * bz;\n out[2] = az1 * bw + aw1 * bz + ax1 * by - ay1 * bx;\n out[3] = aw1 * bw - ax1 * bx - ay1 * by - az1 * bz;\n var ax = a[4],\n ay = a[5],\n az = a[6],\n aw = a[7];\n out[4] = ax * bw + aw * bx + ay * bz - az * by;\n out[5] = ay * bw + aw * by + az * bx - ax * bz;\n out[6] = az * bw + aw * bz + ax * by - ay * bx;\n out[7] = aw * bw - ax * bx - ay * by - az * bz;\n return out;\n}\n/**\n * Adds two dual quat's\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a the first operand\n * @param {ReadonlyQuat2} b the second operand\n * @returns {quat2} out\n * @function\n */\n\nfunction add$1(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n return out;\n}\n/**\n * Multiplies two dual quat's\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a the first operand\n * @param {ReadonlyQuat2} b the second operand\n * @returns {quat2} out\n */\n\nfunction multiply$1(out, a, b) {\n var ax0 = a[0],\n ay0 = a[1],\n az0 = a[2],\n aw0 = a[3],\n bx1 = b[4],\n by1 = b[5],\n bz1 = b[6],\n bw1 = b[7],\n ax1 = a[4],\n ay1 = a[5],\n az1 = a[6],\n aw1 = a[7],\n bx0 = b[0],\n by0 = b[1],\n bz0 = b[2],\n bw0 = b[3];\n out[0] = ax0 * bw0 + aw0 * bx0 + ay0 * bz0 - az0 * by0;\n out[1] = ay0 * bw0 + aw0 * by0 + az0 * bx0 - ax0 * bz0;\n out[2] = az0 * bw0 + aw0 * bz0 + ax0 * by0 - ay0 * bx0;\n out[3] = aw0 * bw0 - ax0 * bx0 - ay0 * by0 - az0 * bz0;\n out[4] = ax0 * bw1 + aw0 * bx1 + ay0 * bz1 - az0 * by1 + ax1 * bw0 + aw1 * bx0 + ay1 * bz0 - az1 * by0;\n out[5] = ay0 * bw1 + aw0 * by1 + az0 * bx1 - ax0 * bz1 + ay1 * bw0 + aw1 * by0 + az1 * bx0 - ax1 * bz0;\n out[6] = az0 * bw1 + aw0 * bz1 + ax0 * by1 - ay0 * bx1 + az1 * bw0 + aw1 * bz0 + ax1 * by0 - ay1 * bx0;\n out[7] = aw0 * bw1 - ax0 * bx1 - ay0 * by1 - az0 * bz1 + aw1 * bw0 - ax1 * bx0 - ay1 * by0 - az1 * bz0;\n return out;\n}\n/**\n * Alias for {@link quat2.multiply}\n * @function\n */\n\nvar mul$1 = multiply$1;\n/**\n * Scales a dual quat by a scalar number\n *\n * @param {quat2} out the receiving dual quat\n * @param {ReadonlyQuat2} a the dual quat to scale\n * @param {Number} b amount to scale the dual quat by\n * @returns {quat2} out\n * @function\n */\n\nfunction scale$1(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n return out;\n}\n/**\n * Calculates the dot product of two dual quat's (The dot product of the real parts)\n *\n * @param {ReadonlyQuat2} a the first operand\n * @param {ReadonlyQuat2} b the second operand\n * @returns {Number} dot product of a and b\n * @function\n */\n\nvar dot$1 = dot$2;\n/**\n * Performs a linear interpolation between two dual quats's\n * NOTE: The resulting dual quaternions won't always be normalized (The error is most noticeable when t = 0.5)\n *\n * @param {quat2} out the receiving dual quat\n * @param {ReadonlyQuat2} a the first operand\n * @param {ReadonlyQuat2} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {quat2} out\n */\n\nfunction lerp$1(out, a, b, t) {\n var mt = 1 - t;\n if (dot$1(a, b) < 0) t = -t;\n out[0] = a[0] * mt + b[0] * t;\n out[1] = a[1] * mt + b[1] * t;\n out[2] = a[2] * mt + b[2] * t;\n out[3] = a[3] * mt + b[3] * t;\n out[4] = a[4] * mt + b[4] * t;\n out[5] = a[5] * mt + b[5] * t;\n out[6] = a[6] * mt + b[6] * t;\n out[7] = a[7] * mt + b[7] * t;\n return out;\n}\n/**\n * Calculates the inverse of a dual quat. If they are normalized, conjugate is cheaper\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a dual quat to calculate inverse of\n * @returns {quat2} out\n */\n\nfunction invert(out, a) {\n var sqlen = squaredLength$1(a);\n out[0] = -a[0] / sqlen;\n out[1] = -a[1] / sqlen;\n out[2] = -a[2] / sqlen;\n out[3] = a[3] / sqlen;\n out[4] = -a[4] / sqlen;\n out[5] = -a[5] / sqlen;\n out[6] = -a[6] / sqlen;\n out[7] = a[7] / sqlen;\n return out;\n}\n/**\n * Calculates the conjugate of a dual quat\n * If the dual quaternion is normalized, this function is faster than quat2.inverse and produces the same result.\n *\n * @param {quat2} out the receiving quaternion\n * @param {ReadonlyQuat2} a quat to calculate conjugate of\n * @returns {quat2} out\n */\n\nfunction conjugate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = a[3];\n out[4] = -a[4];\n out[5] = -a[5];\n out[6] = -a[6];\n out[7] = a[7];\n return out;\n}\n/**\n * Calculates the length of a dual quat\n *\n * @param {ReadonlyQuat2} a dual quat to calculate length of\n * @returns {Number} length of a\n * @function\n */\n\nvar length$1 = length$2;\n/**\n * Alias for {@link quat2.length}\n * @function\n */\n\nvar len$1 = length$1;\n/**\n * Calculates the squared length of a dual quat\n *\n * @param {ReadonlyQuat2} a dual quat to calculate squared length of\n * @returns {Number} squared length of a\n * @function\n */\n\nvar squaredLength$1 = squaredLength$2;\n/**\n * Alias for {@link quat2.squaredLength}\n * @function\n */\n\nvar sqrLen$1 = squaredLength$1;\n/**\n * Normalize a dual quat\n *\n * @param {quat2} out the receiving dual quaternion\n * @param {ReadonlyQuat2} a dual quaternion to normalize\n * @returns {quat2} out\n * @function\n */\n\nfunction normalize$1(out, a) {\n var magnitude = squaredLength$1(a);\n\n if (magnitude > 0) {\n magnitude = Math.sqrt(magnitude);\n var a0 = a[0] / magnitude;\n var a1 = a[1] / magnitude;\n var a2 = a[2] / magnitude;\n var a3 = a[3] / magnitude;\n var b0 = a[4];\n var b1 = a[5];\n var b2 = a[6];\n var b3 = a[7];\n var a_dot_b = a0 * b0 + a1 * b1 + a2 * b2 + a3 * b3;\n out[0] = a0;\n out[1] = a1;\n out[2] = a2;\n out[3] = a3;\n out[4] = (b0 - a0 * a_dot_b) / magnitude;\n out[5] = (b1 - a1 * a_dot_b) / magnitude;\n out[6] = (b2 - a2 * a_dot_b) / magnitude;\n out[7] = (b3 - a3 * a_dot_b) / magnitude;\n }\n\n return out;\n}\n/**\n * Returns a string representation of a dual quatenion\n *\n * @param {ReadonlyQuat2} a dual quaternion to represent as a string\n * @returns {String} string representation of the dual quat\n */\n\nfunction str$1(a) {\n return \"quat2(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \", \" + a[6] + \", \" + a[7] + \")\";\n}\n/**\n * Returns whether or not the dual quaternions have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyQuat2} a the first dual quaternion.\n * @param {ReadonlyQuat2} b the second dual quaternion.\n * @returns {Boolean} true if the dual quaternions are equal, false otherwise.\n */\n\nfunction exactEquals$1(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5] && a[6] === b[6] && a[7] === b[7];\n}\n/**\n * Returns whether or not the dual quaternions have approximately the same elements in the same position.\n *\n * @param {ReadonlyQuat2} a the first dual quat.\n * @param {ReadonlyQuat2} b the second dual quat.\n * @returns {Boolean} true if the dual quats are equal, false otherwise.\n */\n\nfunction equals$1(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5],\n a6 = a[6],\n a7 = a[7];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7];\n return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) && Math.abs(a6 - b6) <= EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) && Math.abs(a7 - b7) <= EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7));\n}\n\nvar quat2 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$1,\n clone: clone$1,\n fromValues: fromValues$1,\n fromRotationTranslationValues: fromRotationTranslationValues,\n fromRotationTranslation: fromRotationTranslation,\n fromTranslation: fromTranslation,\n fromRotation: fromRotation,\n fromMat4: fromMat4,\n copy: copy$1,\n identity: identity,\n set: set$1,\n getReal: getReal,\n getDual: getDual,\n setReal: setReal,\n setDual: setDual,\n getTranslation: getTranslation,\n translate: translate,\n rotateX: rotateX,\n rotateY: rotateY,\n rotateZ: rotateZ,\n rotateByQuatAppend: rotateByQuatAppend,\n rotateByQuatPrepend: rotateByQuatPrepend,\n rotateAroundAxis: rotateAroundAxis,\n add: add$1,\n multiply: multiply$1,\n mul: mul$1,\n scale: scale$1,\n dot: dot$1,\n lerp: lerp$1,\n invert: invert,\n conjugate: conjugate,\n length: length$1,\n len: len$1,\n squaredLength: squaredLength$1,\n sqrLen: sqrLen$1,\n normalize: normalize$1,\n str: str$1,\n exactEquals: exactEquals$1,\n equals: equals$1\n});\n\n/**\n * 2 Dimensional Vector\n * @module vec2\n */\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\n\nfunction create() {\n var out = new ARRAY_TYPE(2);\n\n if (ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n }\n\n return out;\n}\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {ReadonlyVec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\n\nfunction clone(a) {\n var out = new ARRAY_TYPE(2);\n out[0] = a[0];\n out[1] = a[1];\n return out;\n}\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\n\nfunction fromValues(x, y) {\n var out = new ARRAY_TYPE(2);\n out[0] = x;\n out[1] = y;\n return out;\n}\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the source vector\n * @returns {vec2} out\n */\n\nfunction copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n return out;\n}\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\n\nfunction set(out, x, y) {\n out[0] = x;\n out[1] = y;\n return out;\n}\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nfunction add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n return out;\n}\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nfunction subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n return out;\n}\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nfunction multiply(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n return out;\n}\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nfunction divide(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n return out;\n}\n/**\n * Math.ceil the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to ceil\n * @returns {vec2} out\n */\n\nfunction ceil(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n return out;\n}\n/**\n * Math.floor the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to floor\n * @returns {vec2} out\n */\n\nfunction floor(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n return out;\n}\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nfunction min(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n return out;\n}\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec2} out\n */\n\nfunction max(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n return out;\n}\n/**\n * Math.round the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to round\n * @returns {vec2} out\n */\n\nfunction round(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n return out;\n}\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\n\nfunction scale(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n return out;\n}\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\n\nfunction scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n return out;\n}\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {Number} distance between a and b\n */\n\nfunction distance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1];\n return Math.hypot(x, y);\n}\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\n\nfunction squaredDistance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1];\n return x * x + y * y;\n}\n/**\n * Calculates the length of a vec2\n *\n * @param {ReadonlyVec2} a vector to calculate length of\n * @returns {Number} length of a\n */\n\nfunction length(a) {\n var x = a[0],\n y = a[1];\n return Math.hypot(x, y);\n}\n/**\n * Calculates the squared length of a vec2\n *\n * @param {ReadonlyVec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\n\nfunction squaredLength(a) {\n var x = a[0],\n y = a[1];\n return x * x + y * y;\n}\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to negate\n * @returns {vec2} out\n */\n\nfunction negate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n return out;\n}\n/**\n * Returns the inverse of the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to invert\n * @returns {vec2} out\n */\n\nfunction inverse(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n return out;\n}\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a vector to normalize\n * @returns {vec2} out\n */\n\nfunction normalize(out, a) {\n var x = a[0],\n y = a[1];\n var len = x * x + y * y;\n\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = a[0] * len;\n out[1] = a[1] * len;\n return out;\n}\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {Number} dot product of a and b\n */\n\nfunction dot(a, b) {\n return a[0] * b[0] + a[1] * b[1];\n}\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @returns {vec3} out\n */\n\nfunction cross(out, a, b) {\n var z = a[0] * b[1] - a[1] * b[0];\n out[0] = out[1] = 0;\n out[2] = z;\n return out;\n}\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the first operand\n * @param {ReadonlyVec2} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {vec2} out\n */\n\nfunction lerp(out, a, b, t) {\n var ax = a[0],\n ay = a[1];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n return out;\n}\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec2} out\n */\n\nfunction random(out, scale) {\n scale = scale || 1.0;\n var r = RANDOM() * 2.0 * Math.PI;\n out[0] = Math.cos(r) * scale;\n out[1] = Math.sin(r) * scale;\n return out;\n}\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat2} m matrix to transform with\n * @returns {vec2} out\n */\n\nfunction transformMat2(out, a, m) {\n var x = a[0],\n y = a[1];\n out[0] = m[0] * x + m[2] * y;\n out[1] = m[1] * x + m[3] * y;\n return out;\n}\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat2d} m matrix to transform with\n * @returns {vec2} out\n */\n\nfunction transformMat2d(out, a, m) {\n var x = a[0],\n y = a[1];\n out[0] = m[0] * x + m[2] * y + m[4];\n out[1] = m[1] * x + m[3] * y + m[5];\n return out;\n}\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat3} m matrix to transform with\n * @returns {vec2} out\n */\n\nfunction transformMat3(out, a, m) {\n var x = a[0],\n y = a[1];\n out[0] = m[0] * x + m[3] * y + m[6];\n out[1] = m[1] * x + m[4] * y + m[7];\n return out;\n}\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {ReadonlyVec2} a the vector to transform\n * @param {ReadonlyMat4} m matrix to transform with\n * @returns {vec2} out\n */\n\nfunction transformMat4(out, a, m) {\n var x = a[0];\n var y = a[1];\n out[0] = m[0] * x + m[4] * y + m[12];\n out[1] = m[1] * x + m[5] * y + m[13];\n return out;\n}\n/**\n * Rotate a 2D vector\n * @param {vec2} out The receiving vec2\n * @param {ReadonlyVec2} a The vec2 point to rotate\n * @param {ReadonlyVec2} b The origin of the rotation\n * @param {Number} rad The angle of rotation in radians\n * @returns {vec2} out\n */\n\nfunction rotate(out, a, b, rad) {\n //Translate point to the origin\n var p0 = a[0] - b[0],\n p1 = a[1] - b[1],\n sinC = Math.sin(rad),\n cosC = Math.cos(rad); //perform rotation and translate to correct position\n\n out[0] = p0 * cosC - p1 * sinC + b[0];\n out[1] = p0 * sinC + p1 * cosC + b[1];\n return out;\n}\n/**\n * Get the angle between two 2D vectors\n * @param {ReadonlyVec2} a The first operand\n * @param {ReadonlyVec2} b The second operand\n * @returns {Number} The angle in radians\n */\n\nfunction angle(a, b) {\n var x1 = a[0],\n y1 = a[1],\n x2 = b[0],\n y2 = b[1],\n // mag is the product of the magnitudes of a and b\n mag = Math.sqrt(x1 * x1 + y1 * y1) * Math.sqrt(x2 * x2 + y2 * y2),\n // mag &&.. short circuits if mag == 0\n cosine = mag && (x1 * x2 + y1 * y2) / mag; // Math.min(Math.max(cosine, -1), 1) clamps the cosine between -1 and 1\n\n return Math.acos(Math.min(Math.max(cosine, -1), 1));\n}\n/**\n * Set the components of a vec2 to zero\n *\n * @param {vec2} out the receiving vector\n * @returns {vec2} out\n */\n\nfunction zero(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n return out;\n}\n/**\n * Returns a string representation of a vector\n *\n * @param {ReadonlyVec2} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\n\nfunction str(a) {\n return \"vec2(\" + a[0] + \", \" + a[1] + \")\";\n}\n/**\n * Returns whether or not the vectors exactly have the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyVec2} a The first vector.\n * @param {ReadonlyVec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nfunction exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1];\n}\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {ReadonlyVec2} a The first vector.\n * @param {ReadonlyVec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\n\nfunction equals(a, b) {\n var a0 = a[0],\n a1 = a[1];\n var b0 = b[0],\n b1 = b[1];\n return Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1));\n}\n/**\n * Alias for {@link vec2.length}\n * @function\n */\n\nvar len = length;\n/**\n * Alias for {@link vec2.subtract}\n * @function\n */\n\nvar sub = subtract;\n/**\n * Alias for {@link vec2.multiply}\n * @function\n */\n\nvar mul = multiply;\n/**\n * Alias for {@link vec2.divide}\n * @function\n */\n\nvar div = divide;\n/**\n * Alias for {@link vec2.distance}\n * @function\n */\n\nvar dist = distance;\n/**\n * Alias for {@link vec2.squaredDistance}\n * @function\n */\n\nvar sqrDist = squaredDistance;\n/**\n * Alias for {@link vec2.squaredLength}\n * @function\n */\n\nvar sqrLen = squaredLength;\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\n\nvar forEach = function () {\n var vec = create();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 2;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n }\n\n return a;\n };\n}();\n\nvar vec2 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create,\n clone: clone,\n fromValues: fromValues,\n copy: copy,\n set: set,\n add: add,\n subtract: subtract,\n multiply: multiply,\n divide: divide,\n ceil: ceil,\n floor: floor,\n min: min,\n max: max,\n round: round,\n scale: scale,\n scaleAndAdd: scaleAndAdd,\n distance: distance,\n squaredDistance: squaredDistance,\n length: length,\n squaredLength: squaredLength,\n negate: negate,\n inverse: inverse,\n normalize: normalize,\n dot: dot,\n cross: cross,\n lerp: lerp,\n random: random,\n transformMat2: transformMat2,\n transformMat2d: transformMat2d,\n transformMat3: transformMat3,\n transformMat4: transformMat4,\n rotate: rotate,\n angle: angle,\n zero: zero,\n str: str,\n exactEquals: exactEquals,\n equals: equals,\n len: len,\n sub: sub,\n mul: mul,\n div: div,\n dist: dist,\n sqrDist: sqrDist,\n sqrLen: sqrLen,\n forEach: forEach\n});\n\n/**\n * Provides a way to calculate velocity via effectively creating a \"complementary filter\".\n *\n * `velQuick` and `velSmooth` separately accumulate over time. `velInstant` and `velUsed` do not accumulate and are\n * discarded each update. `velQuick` is responsive, but noisy. `velSmooth` is laggy but eventually more accurate. By\n * tracking them separately the used result can be responsive in the short term and accurate in the long term.\n *\n * TODO: This class will be moved to a final location in the @typhonjs-svelte/lib/math package.\n */\nclass TJSVelocityTrack\n{\n /** @type {number} */\n #lastSampleTime;\n\n /**\n * Tracks the last sample point.\n *\n * @type {{x: number, y: number, z: number}}\n */\n #lastSamplePoint = { x: 0, y: 0, z: 0 };\n\n /**\n * Defines the settle time in milliseconds that resets any tracked velocity state.\n *\n * @type {number}\n */\n #resetDeltaTime;\n\n /**\n * Stores the scaling conversion for used velocity calculation. By default, this is 1000 which converts the velocity\n * calculation to velocity per second. Set to `1` for instance for velocity per millisecond.\n *\n * @type {number}\n */\n #scaleTime;\n\n /**\n * Stores the instant velocity between current and last sample point.\n *\n * @type {{x: number, y: number, z: number}}\n */\n #velInstant = { x: 0, y: 0, z: 0 };\n\n /**\n * Stores the `quick` running calculated velocity.\n *\n * @type {{x: number, y: number, z: number}}\n */\n #velQuick = { x: 0, y: 0, z: 0 };\n\n /**\n * Stores the `smooth` running calculated velocity.\n *\n * @type {{x: number, y: number, z: number}}\n */\n #velSmooth = { x: 0, y: 0, z: 0 };\n\n /**\n * Stores the mix between `quick` and `smooth` running velocity.\n *\n * @type {{x: number, y: number, z: number}}\n */\n #velUsed = { x: 0, y: 0, z: 0 };\n\n /**\n * Creates a velocity tracker instance.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {number} [opts.resetDeltaTime=50] - Delta time in milliseconds that resets velocity tracking.\n *\n * @param {number} [opts.scaleTime=1000] - Scales velocity calculation to new time frame. 1000 is velocity per\n * second.\n */\n constructor({ resetDeltaTime = 50, scaleTime = 1000 } = {})\n {\n this.resetDeltaTime = resetDeltaTime;\n this.scaleTime = scaleTime;\n\n Object.seal(this.#velUsed);\n }\n\n /**\n * @returns {number} Gets `resetDeltaTime`.\n */\n get resetDeltaTime() { return this.#resetDeltaTime; }\n\n /**\n * @returns {number} Gets `scaleTime`.\n */\n get scaleTime() { return this.#scaleTime; }\n\n /**\n * Sets `resetDeltaTime`.\n *\n * @param {number} resetDeltaTime - Delta time in milliseconds that resets velocity tracking.\n */\n set resetDeltaTime(resetDeltaTime)\n {\n if (!Number.isFinite(resetDeltaTime) || resetDeltaTime < 0)\n {\n throw new TypeError(`'resetDeltaTime' is not a positive finite number.`);\n }\n\n this.#resetDeltaTime = resetDeltaTime;\n }\n\n /**\n * Sets `scaleTime`.\n *\n * @param {number} scaleTime - Scales velocity calculation to new time frame. 1000 is velocity per second.\n */\n set scaleTime(scaleTime)\n {\n if (!Number.isFinite(scaleTime) || scaleTime < 0)\n {\n throw new TypeError(`'scaleTime' is not a positive finite number.`);\n }\n\n this.#scaleTime = scaleTime;\n }\n\n /**\n * Resets velocity tracking data.\n *\n * @param {number} [x=0] - 'X' value to set to last sample point.\n *\n * @param {number} [y=0] - 'Y' value to set to last sample point.\n *\n * @param {number} [z=0] - 'Z' value to set to last sample point.\n *\n * @param {number} [sampleTime=performance.now()] - A sample time in milliseconds resolution.\n */\n reset(x = 0, y = 0, z = 0, sampleTime = performance.now())\n {\n if (!Number.isFinite(x)) { throw new TypeError(`'x' is not a finite number.`); }\n if (!Number.isFinite(y)) { throw new TypeError(`'y' is not a finite number.`); }\n if (!Number.isFinite(z)) { throw new TypeError(`'z' is not a finite number.`); }\n if (!Number.isFinite(sampleTime)) { throw new TypeError(`'sampleTime' is not a finite number.`); }\n\n // Reset velocity tracking variables.\n this.#lastSampleTime = sampleTime;\n\n this.#lastSamplePoint.x = x;\n this.#lastSamplePoint.y = y;\n this.#lastSamplePoint.z = z;\n\n this.#velInstant.x = this.#velQuick.x = this.#velSmooth.x = this.#velUsed.x = 0;\n this.#velInstant.y = this.#velQuick.y = this.#velSmooth.y = this.#velUsed.y = 0;\n this.#velInstant.z = this.#velQuick.z = this.#velSmooth.z = this.#velUsed.z = 0;\n }\n\n /**\n * Runs ongoing velocity calculation of x / y / z given a sample time.\n *\n * @param {number|undefined} x - New sample X\n *\n * @param {number|undefined} y - New sample Y\n *\n * @param {number|undefined} z - New sample Z\n *\n * @param {number} [sampleTime=performance.now()] - An optional specific time w/ millisecond resolution.\n *\n * @returns {{x: number, y: number, z: number}} current velocity.\n */\n update(x = void 0, y = void 0, z = void 0, sampleTime = performance.now())\n {\n if (!Number.isFinite(sampleTime)) { throw new TypeError(`'sampleTime' is not a finite number.`); }\n\n const deltaTime = sampleTime - this.#lastSampleTime + Number.EPSILON;\n this.#lastSampleTime = sampleTime;\n\n // Reset velocity tracking if the delta time is greater than `resetDeltaTime`.\n if (deltaTime > this.#resetDeltaTime)\n {\n this.reset(x, y, z, sampleTime);\n return this.#velUsed;\n }\n\n if (Number.isFinite(x))\n {\n this.#velInstant.x = (x - this.#lastSamplePoint.x) / deltaTime;\n\n this.#lastSamplePoint.x = x;\n\n this.#velQuick.x = lerp$5(this.#velQuick.x, this.#velInstant.x, 0.1);\n this.#velSmooth.x = lerp$5(this.#velSmooth.x, this.#velInstant.x, 0.01);\n this.#velUsed.x = lerp$5(this.#velSmooth.x, this.#velQuick.x, 0.5) * this.#scaleTime;\n }\n\n if (Number.isFinite(y))\n {\n this.#velInstant.y = (y - this.#lastSamplePoint.y) / deltaTime;\n\n this.#lastSamplePoint.y = y;\n\n this.#velQuick.y = lerp$5(this.#velQuick.y, this.#velInstant.y, 0.1);\n this.#velSmooth.y = lerp$5(this.#velSmooth.y, this.#velInstant.y, 0.01);\n\n this.#velUsed.y = lerp$5(this.#velSmooth.y, this.#velQuick.y, 0.5) * this.#scaleTime;\n }\n\n if (Number.isFinite(z))\n {\n this.#velInstant.z = (z - this.#lastSamplePoint.z) / deltaTime;\n\n this.#lastSamplePoint.z = z;\n\n this.#velQuick.z = lerp$5(this.#velQuick.z, this.#velInstant.z, 0.1);\n this.#velSmooth.z = lerp$5(this.#velSmooth.z, this.#velInstant.z, 0.01);\n this.#velUsed.z = lerp$5(this.#velSmooth.z, this.#velQuick.z, 0.5) * this.#scaleTime;\n }\n\n return this.#velUsed;\n }\n\n /**\n * Gets the current velocity tracking data.\n *\n * @returns {{x: number, y: number, z: number}} Velocity tracking data.\n */\n get()\n {\n this.#velUsed.x = lerp$5(this.#velSmooth.x, this.#velQuick.x, 0.5) * this.#scaleTime;\n this.#velUsed.y = lerp$5(this.#velSmooth.y, this.#velQuick.y, 0.5) * this.#scaleTime;\n this.#velUsed.z = lerp$5(this.#velSmooth.z, this.#velQuick.z, 0.5) * this.#scaleTime;\n\n return this.#velUsed;\n }\n}\n\nexport { TJSVelocityTrack, degToRad, common as glMatrix, lerp$5 as lerp, mat2, mat2d, mat3, mat4, quat, quat2, radToDeg, vec2, vec3, vec4 };\n//# sourceMappingURL=index.js.map\n","/**\n * Provides a basic {@link TJSBasicAnimation} implementation for Position animation.\n */\nexport class AnimationControl\n{\n /** @type {object} */\n #animationData;\n\n /** @type {Promise} */\n #finishedPromise;\n\n #willFinish;\n\n /**\n * Defines a static empty / void animation control.\n *\n * @type {AnimationControl}\n */\n static #voidControl = new AnimationControl(null);\n\n /**\n * Provides a static void / undefined AnimationControl that is automatically resolved.\n *\n * @returns {AnimationControl} Void AnimationControl\n */\n static get voidControl() { return this.#voidControl; }\n\n /**\n * @param {object|null} [animationData] - Animation data from {@link AnimationAPI}.\n *\n * @param {boolean} [willFinish] - Promise that tracks animation finished state.\n */\n constructor(animationData, willFinish = false)\n {\n this.#animationData = animationData;\n this.#willFinish = willFinish;\n\n // Set this control to animation data.\n if (animationData !== null && typeof animationData === 'object')\n {\n animationData.control = this;\n }\n }\n\n /**\n * Get a promise that resolves when animation is finished.\n *\n * @returns {Promise}\n */\n get finished()\n {\n if (!(this.#finishedPromise instanceof Promise))\n {\n this.#finishedPromise = this.#willFinish ? new Promise((resolve) => this.#animationData.resolve = resolve) :\n Promise.resolve();\n }\n\n return this.#finishedPromise;\n }\n\n /**\n * Returns whether this animation is currently active / animating.\n *\n * Note: a delayed animation may not be started / active yet. Use {@link AnimationControl.isFinished} to determine\n * if an animation is actually finished.\n *\n * @returns {boolean} Animation active state.\n */\n get isActive() { return this.#animationData.active; }\n\n /**\n * Returns whether this animation is completely finished.\n *\n * @returns {boolean} Animation finished state.\n */\n get isFinished() { return this.#animationData.finished; }\n\n /**\n * Cancels the animation.\n */\n cancel()\n {\n const animationData = this.#animationData;\n\n if (animationData === null || animationData === void 0) { return; }\n\n // Set cancelled state to true and this animation data instance will be removed from AnimationManager on next\n // update.\n animationData.cancelled = true;\n }\n}\n","/**\n * Provides animation management and scheduling allowing all Position instances to utilize one micro-task.\n */\nexport class AnimationManager\n{\n /**\n * @type {object[]}\n */\n static activeList = [];\n\n /**\n * @type {object[]}\n */\n static newList = [];\n\n /**\n * @type {number}\n */\n static current;\n\n /**\n * Add animation data.\n *\n * @param {object} data -\n */\n static add(data)\n {\n const now = performance.now();\n\n // Offset start time by delta between last rAF time. This allows continuous tween cycles to appear naturally as\n // starting from the instant they are added to the AnimationManager. This is what makes `draggable` smooth when\n // easing is enabled.\n data.start = now + (AnimationManager.current - now);\n\n AnimationManager.newList.push(data);\n }\n\n /**\n * Manage all animation\n */\n static animate()\n {\n const current = AnimationManager.current = performance.now();\n\n // Early out of the rAF callback when there are no current animations.\n if (AnimationManager.activeList.length === 0 && AnimationManager.newList.length === 0)\n {\n globalThis.requestAnimationFrame(AnimationManager.animate);\n return;\n }\n\n if (AnimationManager.newList.length)\n {\n // Process new data\n for (let cntr = AnimationManager.newList.length; --cntr >= 0;)\n {\n const data = AnimationManager.newList[cntr];\n\n // If animation instance has been cancelled before start then remove it from new list and cleanup.\n if (data.cancelled)\n {\n AnimationManager.newList.splice(cntr, 1);\n data.cleanup(data);\n }\n\n // If data is active then process it now. Delayed animations start with `active` false.\n if (data.active)\n {\n // Remove from new list and add to active list.\n AnimationManager.newList.splice(cntr, 1);\n AnimationManager.activeList.push(data);\n }\n }\n }\n\n // Process active animations.\n for (let cntr = AnimationManager.activeList.length; --cntr >= 0;)\n {\n const data = AnimationManager.activeList[cntr];\n\n // Remove any animations that have been canceled.\n // Ensure that the element is still connected otherwise remove it from active list and continue.\n if (data.cancelled || (data.el !== void 0 && !data.el.isConnected))\n {\n AnimationManager.activeList.splice(cntr, 1);\n data.cleanup(data);\n continue;\n }\n\n data.current = current - data.start;\n\n // Remove this animation instance if current animating time exceeds duration.\n if (data.current >= data.duration)\n {\n // Prepare final update with end position data.\n for (let dataCntr = data.keys.length; --dataCntr >= 0;)\n {\n const key = data.keys[dataCntr];\n data.newData[key] = data.destination[key];\n }\n\n data.position.set(data.newData);\n\n AnimationManager.activeList.splice(cntr, 1);\n data.cleanup(data);\n\n continue;\n }\n\n // Apply easing to create an eased time.\n const easedTime = data.ease(data.current / data.duration);\n\n for (let dataCntr = data.keys.length; --dataCntr >= 0;)\n {\n const key = data.keys[dataCntr];\n data.newData[key] = data.interpolate(data.initial[key], data.destination[key], easedTime);\n }\n\n data.position.set(data.newData);\n }\n\n globalThis.requestAnimationFrame(AnimationManager.animate);\n }\n\n /**\n * Cancels all animations for given Position instance.\n *\n * @param {Position} position - Position instance.\n */\n static cancel(position)\n {\n for (let cntr = AnimationManager.activeList.length; --cntr >= 0;)\n {\n const data = AnimationManager.activeList[cntr];\n if (data.position === position)\n {\n AnimationManager.activeList.splice(cntr, 1);\n data.cancelled = true;\n data.cleanup(data);\n }\n }\n\n for (let cntr = AnimationManager.newList.length; --cntr >= 0;)\n {\n const data = AnimationManager.newList[cntr];\n if (data.position === position)\n {\n AnimationManager.newList.splice(cntr, 1);\n data.cancelled = true;\n data.cleanup(data);\n }\n }\n }\n\n /**\n * Cancels all active and delayed animations.\n */\n static cancelAll()\n {\n for (let cntr = AnimationManager.activeList.length; --cntr >= 0;)\n {\n const data = AnimationManager.activeList[cntr];\n data.cancelled = true;\n data.cleanup(data);\n }\n\n for (let cntr = AnimationManager.newList.length; --cntr >= 0;)\n {\n const data = AnimationManager.newList[cntr];\n data.cancelled = true;\n data.cleanup(data);\n }\n\n AnimationManager.activeList.length = 0;\n AnimationManager.newList.length = 0;\n }\n\n /**\n * Gets all {@link AnimationControl} instances for a given Position instance.\n *\n * @param {Position} position - Position instance.\n *\n * @returns {AnimationControl[]} All scheduled AnimationControl instances for the given Position instance.\n */\n static getScheduled(position)\n {\n const results = [];\n\n for (let cntr = AnimationManager.activeList.length; --cntr >= 0;)\n {\n const data = AnimationManager.activeList[cntr];\n if (data.position === position)\n {\n results.push(data.control);\n }\n }\n\n for (let cntr = AnimationManager.newList.length; --cntr >= 0;)\n {\n const data = AnimationManager.newList[cntr];\n if (data.position === position)\n {\n results.push(data.control);\n }\n }\n\n return results;\n }\n}\n\n// Start animation manager immediately. It constantly is running in background.\nAnimationManager.animate();\n","/**\n * Stores the PositionData properties that can be animated.\n *\n * @type {Set}\n */\nconst animateKeys = new Set([\n // Main keys\n 'left', 'top', 'maxWidth', 'maxHeight', 'minWidth', 'minHeight', 'width', 'height',\n 'rotateX', 'rotateY', 'rotateZ', 'scale', 'translateX', 'translateY', 'translateZ', 'zIndex',\n\n // Aliases\n 'rotation'\n]);\n\n/**\n * Defines the keys of PositionData that are transform keys.\n *\n * @type {string[]}\n */\nconst transformKeys = ['rotateX', 'rotateY', 'rotateZ', 'scale', 'translateX', 'translateY', 'translateZ'];\n\nObject.freeze(transformKeys);\n\n/**\n * Parses a relative value string in the form of '+=', '-=', or '*=' and float / numeric value. IE '+=0.2'.\n *\n * @type {RegExp}\n */\nconst relativeRegex = /^([-+*])=(-?[\\d]*\\.?[\\d]+)$/;\n\n/**\n * Provides numeric defaults for all parameters. This is used by {@link Position.get} to optionally provide\n * numeric defaults.\n *\n * @type {{rotation: number, scale: number, minWidth: null, minHeight: null, translateZ: number, top: number, left: number, maxHeight: null, translateY: number, translateX: number, width: number, transformOrigin: null, rotateX: number, rotateY: number, height: number, maxWidth: null, zIndex: null, rotateZ: number}}\n */\nconst numericDefaults = {\n // Other keys\n height: 0,\n left: 0,\n maxHeight: null,\n maxWidth: null,\n minHeight: null,\n minWidth: null,\n top: 0,\n transformOrigin: null,\n width: 0,\n zIndex: null,\n\n rotateX: 0,\n rotateY: 0,\n rotateZ: 0,\n scale: 1,\n translateX: 0,\n translateY: 0,\n translateZ: 0,\n\n rotation: 0\n};\n\nObject.freeze(numericDefaults);\n\n/**\n * Sets numeric defaults for a {@link PositionData} like object.\n *\n * @param {object} data - A PositionData like object.\n */\nfunction setNumericDefaults(data)\n{\n // Transform keys\n if (data.rotateX === null) { data.rotateX = 0; }\n if (data.rotateY === null) { data.rotateY = 0; }\n if (data.rotateZ === null) { data.rotateZ = 0; }\n if (data.translateX === null) { data.translateX = 0; }\n if (data.translateY === null) { data.translateY = 0; }\n if (data.translateZ === null) { data.translateZ = 0; }\n if (data.scale === null) { data.scale = 1; }\n\n // Aliases\n if (data.rotation === null) { data.rotation = 0; }\n}\n\n/**\n * Defines bitwise keys for transforms used in {@link Transforms.getMat4}.\n *\n * @type {object}\n */\nconst transformKeysBitwise = {\n rotateX: 1,\n rotateY: 2,\n rotateZ: 4,\n scale: 8,\n translateX: 16,\n translateY: 32,\n translateZ: 64\n};\n\nObject.freeze(transformKeysBitwise);\n\n/**\n * Defines the default transform origin.\n *\n * @type {string}\n */\nconst transformOriginDefault = 'top left';\n\n/**\n * Defines the valid transform origins.\n *\n * @type {string[]}\n */\nconst transformOrigins = ['top left', 'top center', 'top right', 'center left', 'center', 'center right', 'bottom left',\n 'bottom center', 'bottom right'];\n\nObject.freeze(transformOrigins);\n\nexport {\n animateKeys,\n numericDefaults,\n relativeRegex,\n setNumericDefaults,\n transformKeys,\n transformKeysBitwise,\n transformOriginDefault,\n transformOrigins\n};\n","import * as constants from './constants.js';\n\n/**\n * Converts any relative string values for animatable keys to actual updates performed against current data.\n *\n * @param {PositionDataExtended} positionData - position data.\n *\n * @param {Position|PositionData} position - The source position instance.\n */\nexport function convertRelative(positionData, position)\n{\n for (const key in positionData)\n {\n // Key is animatable / numeric.\n if (constants.animateKeys.has(key))\n {\n const value = positionData[key];\n\n if (typeof value !== 'string') { continue; }\n\n // Ignore 'auto' and 'inherit' string values.\n if (value === 'auto' || value === 'inherit') { continue; }\n\n const regexResults = constants.relativeRegex.exec(value);\n\n if (!regexResults)\n {\n throw new Error(\n `convertRelative error: malformed relative key (${key}) with value (${value})`);\n }\n\n const current = position[key];\n\n switch (regexResults[1])\n {\n case '-':\n positionData[key] = current - parseFloat(regexResults[2]);\n break;\n\n case '+':\n positionData[key] = current + parseFloat(regexResults[2]);\n break;\n\n case '*':\n positionData[key] = current * parseFloat(regexResults[2]);\n break;\n }\n }\n }\n}\n","import { cubicOut } from 'svelte/easing';\n\nimport { lerp } from '@typhonjs-fvtt/runtime/svelte/math';\nimport {\n isIterable,\n isObject } from '@typhonjs-fvtt/runtime/svelte/util';\n\nimport { AnimationControl } from './AnimationControl.js';\nimport { AnimationManager } from './AnimationManager.js';\n\nimport { convertRelative } from '../convertRelative.js';\n\nimport {\n animateKeys,\n setNumericDefaults } from '../constants.js';\n\nexport class AnimationAPI\n{\n /** @type {PositionData} */\n #data;\n\n /** @type {Position} */\n #position;\n\n /**\n * Tracks the number of animation control instances that are active.\n *\n * @type {number}\n */\n #instanceCount = 0;\n\n /**\n * Provides a bound function to pass as data to AnimationManager to invoke\n *\n * @type {Function}\n * @see {AnimationAPI.#cleanupInstance}\n */\n #cleanup;\n\n constructor(position, data)\n {\n this.#position = position;\n this.#data = data;\n\n this.#cleanup = this.#cleanupInstance.bind(this);\n }\n\n /**\n * Returns whether there are scheduled animations whether active or delayed for this Position.\n *\n * @returns {boolean} Are there active animation instances.\n */\n get isScheduled()\n {\n return this.#instanceCount > 0;\n }\n\n /**\n * Adds / schedules an animation w/ the AnimationManager. This contains the final steps common to all tweens.\n *\n * @param {object} initial -\n *\n * @param {object} destination -\n *\n * @param {number} duration -\n *\n * @param {HTMLElement} el -\n *\n * @param {number} delay -\n *\n * @param {Function} ease -\n *\n * @param {Function} interpolate -\n *\n * @returns {AnimationControl} The associated animation control.\n */\n #addAnimation(initial, destination, duration, el, delay, ease, interpolate)\n {\n // Set initial data for transform values that are often null by default.\n setNumericDefaults(initial);\n setNumericDefaults(destination);\n\n // Reject all initial data that is not a number.\n for (const key in initial)\n {\n if (!Number.isFinite(initial[key])) { delete initial[key]; }\n }\n\n const keys = Object.keys(initial);\n const newData = Object.assign({ immediateElementUpdate: true }, initial);\n\n // Nothing to animate, so return now.\n if (keys.length === 0) { return AnimationControl.voidControl; }\n\n const animationData = {\n active: true,\n cleanup: this.#cleanup,\n cancelled: false,\n control: void 0,\n current: 0,\n destination,\n duration: duration * 1000, // Internally the AnimationManager works in ms.\n ease,\n el,\n finished: false,\n initial,\n interpolate,\n keys,\n newData,\n position: this.#position,\n resolve: void 0,\n start: void 0\n };\n\n if (delay > 0)\n {\n animationData.active = false;\n\n // Delay w/ setTimeout and schedule w/ AnimationManager if not already canceled\n setTimeout(() =>\n {\n if (!animationData.cancelled)\n {\n animationData.active = true;\n\n const now = performance.now();\n\n // Offset start time by delta between last rAF time. This allows a delayed tween to start from the\n // precise delayed time.\n animationData.start = now + (AnimationManager.current - now);\n }\n }, delay * 1000);\n }\n\n // Schedule immediately w/ AnimationManager\n this.#instanceCount++;\n AnimationManager.add(animationData);\n\n // Create animation control\n return new AnimationControl(animationData, true);\n }\n\n /**\n * Cancels all animation instances for this Position instance.\n */\n cancel()\n {\n AnimationManager.cancel(this.#position);\n }\n\n /**\n * Cleans up an animation instance.\n *\n * @param {object} data - Animation data for an animation instance.\n */\n #cleanupInstance(data)\n {\n this.#instanceCount--;\n\n data.active = false;\n data.finished = true;\n\n if (typeof data.resolve === 'function') { data.resolve(data.cancelled); }\n }\n\n /**\n * Returns all currently scheduled AnimationControl instances for this Position instance.\n *\n * @returns {AnimationControl[]} All currently scheduled animation controls for this Position instance.\n */\n getScheduled()\n {\n return AnimationManager.getScheduled(this.#position);\n }\n\n /**\n * Provides a tween from given position data to the current position.\n *\n * @param {PositionDataExtended} fromData - The starting position.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {number} [opts.delay=0] - Delay in seconds before animation starts.\n *\n * @param {number} [opts.duration=1] - Duration in seconds.\n *\n * @param {Function} [opts.ease=cubicOut] - Easing function.\n *\n * @param {Function} [opts.interpolate=lerp] - Interpolation function.\n *\n * @returns {AnimationControl} A control object that can cancel animation and provides a `finished` Promise.\n */\n from(fromData, { delay = 0, duration = 1, ease = cubicOut, interpolate = lerp } = {})\n {\n if (!isObject(fromData))\n {\n throw new TypeError(`AnimationAPI.from error: 'fromData' is not an object.`);\n }\n\n const position = this.#position;\n const parent = position.parent;\n\n // Early out if the application is not positionable.\n if (parent !== void 0 && typeof parent?.options?.positionable === 'boolean' && !parent?.options?.positionable)\n {\n return AnimationControl.voidControl;\n }\n\n // Cache any target element allowing AnimationManager to stop animation if it becomes disconnected from DOM.\n const targetEl = parent instanceof HTMLElement ? parent : parent?.elementTarget;\n const el = targetEl instanceof HTMLElement && targetEl.isConnected ? targetEl : void 0;\n\n if (!Number.isFinite(delay) || delay < 0)\n {\n throw new TypeError(`AnimationAPI.from error: 'delay' is not a positive number.`);\n }\n\n if (!Number.isFinite(duration) || duration < 0)\n {\n throw new TypeError(`AnimationAPI.from error: 'duration' is not a positive number.`);\n }\n\n if (typeof ease !== 'function')\n {\n throw new TypeError(`AnimationAPI.from error: 'ease' is not a function.`);\n }\n\n if (typeof interpolate !== 'function')\n {\n throw new TypeError(`AnimationAPI.from error: 'interpolate' is not a function.`);\n }\n\n const initial = {};\n const destination = {};\n\n const data = this.#data;\n\n // Set initial data if the key / data is defined and the end position is not equal to current data.\n for (const key in fromData)\n {\n if (data[key] !== void 0 && fromData[key] !== data[key])\n {\n initial[key] = fromData[key];\n destination[key] = data[key];\n }\n }\n\n convertRelative(initial, data);\n\n return this.#addAnimation(initial, destination, duration, el, delay, ease, interpolate);\n }\n\n /**\n * Provides a tween from given position data to the current position.\n *\n * @param {PositionDataExtended} fromData - The starting position.\n *\n * @param {PositionDataExtended} toData - The ending position.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {number} [opts.delay=0] - Delay in seconds before animation starts.\n *\n * @param {number} [opts.duration=1] - Duration in seconds.\n *\n * @param {Function} [opts.ease=cubicOut] - Easing function.\n *\n * @param {Function} [opts.interpolate=lerp] - Interpolation function.\n *\n * @returns {AnimationControl} A control object that can cancel animation and provides a `finished` Promise.\n */\n fromTo(fromData, toData, { delay = 0, duration = 1, ease = cubicOut, interpolate = lerp } = {})\n {\n if (!isObject(fromData))\n {\n throw new TypeError(`AnimationAPI.fromTo error: 'fromData' is not an object.`);\n }\n\n if (!isObject(toData))\n {\n throw new TypeError(`AnimationAPI.fromTo error: 'toData' is not an object.`);\n }\n\n const parent = this.#position.parent;\n\n // Early out if the application is not positionable.\n if (parent !== void 0 && typeof parent?.options?.positionable === 'boolean' && !parent?.options?.positionable)\n {\n return AnimationControl.voidControl;\n }\n\n // Cache any target element allowing AnimationManager to stop animation if it becomes disconnected from DOM.\n const targetEl = parent instanceof HTMLElement ? parent : parent?.elementTarget;\n const el = targetEl instanceof HTMLElement && targetEl.isConnected ? targetEl : void 0;\n\n if (!Number.isFinite(delay) || delay < 0)\n {\n throw new TypeError(`AnimationAPI.fromTo error: 'delay' is not a positive number.`);\n }\n\n if (!Number.isFinite(duration) || duration < 0)\n {\n throw new TypeError(`AnimationAPI.fromTo error: 'duration' is not a positive number.`);\n }\n\n if (typeof ease !== 'function')\n {\n throw new TypeError(`AnimationAPI.fromTo error: 'ease' is not a function.`);\n }\n\n if (typeof interpolate !== 'function')\n {\n throw new TypeError(`AnimationAPI.fromTo error: 'interpolate' is not a function.`);\n }\n\n const initial = {};\n const destination = {};\n\n const data = this.#data;\n\n // Set initial data if the key / data is defined and the end position is not equal to current data.\n for (const key in fromData)\n {\n if (toData[key] === void 0)\n {\n console.warn(\n `AnimationAPI.fromTo warning: key ('${key}') from 'fromData' missing in 'toData'; skipping this key.`);\n continue;\n }\n\n if (data[key] !== void 0)\n {\n initial[key] = fromData[key];\n destination[key] = toData[key];\n }\n }\n\n convertRelative(initial, data);\n convertRelative(destination, data);\n\n return this.#addAnimation(initial, destination, duration, el, delay, ease, interpolate);\n }\n\n /**\n * Provides a tween to given position data from the current position.\n *\n * @param {PositionDataExtended} toData - The destination position.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {number} [opts.delay=0] - Delay in seconds before animation starts.\n *\n * @param {number} [opts.duration=1] - Duration in seconds.\n *\n * @param {Function} [opts.ease=cubicOut] - Easing function.\n *\n * @param {Function} [opts.interpolate=lerp] - Interpolation function.\n *\n * @returns {AnimationControl} A control object that can cancel animation and provides a `finished` Promise.\n */\n to(toData, { delay = 0, duration = 1, ease = cubicOut, interpolate = lerp } = {})\n {\n if (!isObject(toData))\n {\n throw new TypeError(`AnimationAPI.to error: 'toData' is not an object.`);\n }\n\n const parent = this.#position.parent;\n\n // Early out if the application is not positionable.\n if (parent !== void 0 && typeof parent?.options?.positionable === 'boolean' && !parent?.options?.positionable)\n {\n return AnimationControl.voidControl;\n }\n\n // Cache any target element allowing AnimationManager to stop animation if it becomes disconnected from DOM.\n const targetEl = parent instanceof HTMLElement ? parent : parent?.elementTarget;\n const el = targetEl instanceof HTMLElement && targetEl.isConnected ? targetEl : void 0;\n\n if (!Number.isFinite(delay) || delay < 0)\n {\n throw new TypeError(`AnimationAPI.to error: 'delay' is not a positive number.`);\n }\n\n if (!Number.isFinite(duration) || duration < 0)\n {\n throw new TypeError(`AnimationAPI.to error: 'duration' is not a positive number.`);\n }\n\n if (typeof ease !== 'function')\n {\n throw new TypeError(`AnimationAPI.to error: 'ease' is not a function.`);\n }\n\n if (typeof interpolate !== 'function')\n {\n throw new TypeError(`AnimationAPI.to error: 'interpolate' is not a function.`);\n }\n\n const initial = {};\n const destination = {};\n\n const data = this.#data;\n\n // Set initial data if the key / data is defined and the end position is not equal to current data.\n for (const key in toData)\n {\n if (data[key] !== void 0 && toData[key] !== data[key])\n {\n destination[key] = toData[key];\n initial[key] = data[key];\n }\n }\n\n convertRelative(destination, data);\n\n return this.#addAnimation(initial, destination, duration, el, delay, ease, interpolate);\n }\n\n /**\n * Returns a function that provides an optimized way to constantly update a to-tween.\n *\n * @param {Iterable} keys - The keys for quickTo.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {number} [opts.duration=1] - Duration in seconds.\n *\n * @param {Function} [opts.ease=cubicOut] - Easing function.\n *\n * @param {Function} [opts.interpolate=lerp] - Interpolation function.\n *\n * @returns {quickToCallback} quick-to tween function.\n */\n quickTo(keys, { duration = 1, ease = cubicOut, interpolate = lerp } = {})\n {\n if (!isIterable(keys))\n {\n throw new TypeError(`AnimationAPI.quickTo error: 'keys' is not an iterable list.`);\n }\n\n const parent = this.#position.parent;\n\n // Early out if the application is not positionable.\n if (parent !== void 0 && typeof parent?.options?.positionable === 'boolean' && !parent?.options?.positionable)\n {\n throw new Error(`AnimationAPI.quickTo error: 'parent' is not positionable.`);\n }\n\n if (!Number.isFinite(duration) || duration < 0)\n {\n throw new TypeError(`AnimationAPI.quickTo error: 'duration' is not a positive number.`);\n }\n\n if (typeof ease !== 'function')\n {\n throw new TypeError(`AnimationAPI.quickTo error: 'ease' is not a function.`);\n }\n\n if (typeof interpolate !== 'function')\n {\n throw new TypeError(`AnimationAPI.quickTo error: 'interpolate' is not a function.`);\n }\n\n const initial = {};\n const destination = {};\n\n const data = this.#data;\n\n // Set initial data if the key / data is defined and the end position is not equal to current data.\n for (const key of keys)\n {\n if (typeof key !== 'string')\n {\n throw new TypeError(`AnimationAPI.quickTo error: key is not a string.`);\n }\n\n if (!animateKeys.has(key))\n {\n throw new Error(`AnimationAPI.quickTo error: key ('${key}') is not animatable.`);\n }\n\n if (data[key] !== void 0)\n {\n destination[key] = data[key];\n initial[key] = data[key];\n }\n }\n\n const keysArray = [...keys];\n\n Object.freeze(keysArray);\n\n const newData = Object.assign({ immediateElementUpdate: true }, initial);\n\n const animationData = {\n active: true,\n cleanup: this.#cleanup,\n cancelled: false,\n control: void 0,\n current: 0,\n destination,\n duration: duration * 1000, // Internally the AnimationManager works in ms.\n ease,\n el: void 0,\n finished: true, // Note: start in finished state to add to AnimationManager on first callback.\n initial,\n interpolate,\n keys,\n newData,\n position: this.#position,\n resolve: void 0,\n start: void 0\n };\n\n const quickToCB = (...args) =>\n {\n const argsLength = args.length;\n\n if (argsLength === 0) { return; }\n\n for (let cntr = keysArray.length; --cntr >= 0;)\n {\n const key = keysArray[cntr];\n if (data[key] !== void 0) { initial[key] = data[key]; }\n }\n\n // Handle case where the first arg is an object. Update all quickTo keys from data contained in the object.\n if (isObject(args[0]))\n {\n const objData = args[0];\n\n for (const key in objData)\n {\n if (destination[key] !== void 0) { destination[key] = objData[key]; }\n }\n }\n else // Assign each variable argument to the key specified in the initial `keys` array above.\n {\n for (let cntr = 0; cntr < argsLength && cntr < keysArray.length; cntr++)\n {\n const key = keysArray[cntr];\n if (destination[key] !== void 0) { destination[key] = args[cntr]; }\n }\n }\n\n convertRelative(destination, data);\n\n // Set initial data for transform values that are often null by default.\n setNumericDefaults(initial);\n setNumericDefaults(destination);\n\n // Set target element to animation data to track if it is removed from the DOM hence ending the animation.\n const targetEl = parent instanceof HTMLElement ? parent : parent?.elementTarget;\n animationData.el = targetEl instanceof HTMLElement && targetEl.isConnected ? targetEl : void 0;\n\n // Reschedule the quickTo animation with AnimationManager as it is finished.\n if (animationData.finished)\n {\n animationData.finished = false;\n animationData.active = true;\n animationData.current = 0;\n\n this.#instanceCount++;\n AnimationManager.add(animationData);\n }\n else // QuickTo animation is currently scheduled w/ AnimationManager so reset start and current time.\n {\n const now = performance.now();\n\n // Offset start time by delta between last rAF time. This allows a delayed tween to start from the\n // precise delayed time.\n animationData.start = now + (AnimationManager.current - now);\n animationData.current = 0;\n }\n };\n\n quickToCB.keys = keysArray;\n\n /**\n * Sets options of quickTo tween.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {number} [opts.duration] - Duration in seconds.\n *\n * @param {Function} [opts.ease] - Easing function.\n *\n * @param {Function} [opts.interpolate] - Interpolation function.\n *\n * @returns {quickToCallback} The quickTo callback.\n */\n quickToCB.options = ({ duration, ease, interpolate } = {}) => // eslint-disable-line no-shadow\n {\n if (duration !== void 0 && (!Number.isFinite(duration) || duration < 0))\n {\n throw new TypeError(`AnimationAPI.quickTo.options error: 'duration' is not a positive number.`);\n }\n\n if (ease !== void 0 && typeof ease !== 'function')\n {\n throw new TypeError(`AnimationAPI.quickTo.options error: 'ease' is not a function.`);\n }\n\n if (interpolate !== void 0 && typeof interpolate !== 'function')\n {\n throw new TypeError(`AnimationAPI.quickTo.options error: 'interpolate' is not a function.`);\n }\n\n if (duration >= 0) { animationData.duration = duration * 1000; }\n if (ease) { animationData.ease = ease; }\n if (interpolate) { animationData.interpolate = interpolate; }\n\n return quickToCB;\n };\n\n return quickToCB;\n }\n}\n\n/**\n * @callback quickToCallback\n *\n * @param {...number|object} args - Either individual numbers corresponding to the order in which keys are specified or\n * a single object with keys specified and numerical values.\n *\n * @property {({duration?: number, ease?: Function, interpolate?: Function}) => quickToCallback} options - A function\n * to update options for quickTo function.\n */\n","/**\n * Provides a basic {@link TJSBasicAnimation} implementation for a Position animation for a group of Position instances.\n */\nexport class AnimationGroupControl\n{\n /** @type {AnimationControl[]} */\n #animationControls;\n\n /** @type {Promise[]>} */\n #finishedPromise;\n\n /**\n * Defines a static empty / void animation control.\n *\n * @type {AnimationGroupControl}\n */\n static #voidControl = new AnimationGroupControl(null);\n\n /**\n * Provides a static void / undefined AnimationGroupControl that is automatically resolved.\n *\n * @returns {AnimationGroupControl} Void AnimationGroupControl\n */\n static get voidControl() { return this.#voidControl; }\n\n /**\n * @param {AnimationControl[]} animationControls - An array of AnimationControl instances.\n */\n constructor(animationControls)\n {\n this.#animationControls = animationControls;\n }\n\n /**\n * Get a promise that resolves when all animations are finished.\n *\n * @returns {Promise[]>|Promise} Finished Promise for all animations.\n */\n get finished()\n {\n const animationControls = this.#animationControls;\n\n if (animationControls === null || animationControls === void 0) { return Promise.resolve(); }\n\n if (!(this.#finishedPromise instanceof Promise))\n {\n const promises = [];\n for (let cntr = animationControls.length; --cntr >= 0;)\n {\n promises.push(animationControls[cntr].finished);\n }\n\n this.#finishedPromise = Promise.all(promises);\n }\n\n return this.#finishedPromise;\n }\n\n /**\n * Returns whether there are active animation instances for this group.\n *\n * Note: a delayed animation may not be started / active yet. Use {@link AnimationGroupControl.isFinished} to\n * determine if all animations in the group are finished.\n *\n * @returns {boolean} Are there active animation instances.\n */\n get isActive()\n {\n const animationControls = this.#animationControls;\n\n if (animationControls === null || animationControls === void 0) { return false; }\n\n for (let cntr = animationControls.length; --cntr >= 0;)\n {\n if (animationControls[cntr].isActive) { return true; }\n }\n\n return false;\n }\n\n /**\n * Returns whether all animations in the group are finished.\n *\n * @returns {boolean} Are all animation instances finished.\n */\n get isFinished()\n {\n const animationControls = this.#animationControls;\n\n if (animationControls === null || animationControls === void 0) { return true; }\n\n for (let cntr = animationControls.length; --cntr >= 0;)\n {\n if (!animationControls[cntr].isFinished) { return false; }\n }\n\n return false;\n }\n\n /**\n * Cancels the all animations.\n */\n cancel()\n {\n const animationControls = this.#animationControls;\n\n if (animationControls === null || animationControls === void 0) { return; }\n\n for (let cntr = this.#animationControls.length; --cntr >= 0;)\n {\n this.#animationControls[cntr].cancel();\n }\n }\n}\n","import {\n isIterable,\n isObject } from '@typhonjs-fvtt/runtime/svelte/util';\n\nimport { AnimationManager } from './AnimationManager.js';\nimport { AnimationAPI } from './AnimationAPI.js';\nimport { AnimationGroupControl } from './AnimationGroupControl.js';\n\n/**\n * Provides a public API for grouping multiple {@link Position} animations together with the AnimationManager.\n *\n * Note: To remove cyclic dependencies as this class provides the Position static / group Animation API `instanceof`\n * checks are not done against Position. Instead, a check for the animate property being an instanceof\n * {@link AnimationAPI} is performed in {@link AnimationGroupAPI.#isPosition}.\n *\n * @see AnimationAPI\n */\nexport class AnimationGroupAPI\n{\n /**\n * Checks of the given object is a Position instance by checking for AnimationAPI.\n *\n * @param {*} object - Any data.\n *\n * @returns {boolean} Is Position.\n */\n static #isPosition(object)\n {\n return object !== null && typeof object === 'object' && object.animate instanceof AnimationAPI;\n }\n\n /**\n * Cancels any animation for given Position data.\n *\n * @param {Position|{position: Position}|Iterable|Iterable<{position: Position}>} position -\n */\n static cancel(position)\n {\n if (isIterable(position))\n {\n let index = -1;\n\n for (const entry of position)\n {\n index++;\n\n const actualPosition = this.#isPosition(entry) ? entry : entry.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.cancel warning: No Position instance found at index: ${index}.`);\n continue;\n }\n\n AnimationManager.cancel(actualPosition);\n }\n }\n else\n {\n const actualPosition = this.#isPosition(position) ? position : position.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.cancel warning: No Position instance found.`);\n return;\n }\n\n AnimationManager.cancel(actualPosition);\n }\n }\n\n /**\n * Cancels all Position animation.\n */\n static cancelAll() { AnimationManager.cancelAll(); }\n\n /**\n * Gets all animation controls for the given position data.\n *\n * @param {Position|{position: Position}|Iterable|Iterable<{position: Position}>} position -\n *\n * @returns {{position: Position, data: object|void, controls: AnimationControl[]}[]} Results array.\n */\n static getScheduled(position)\n {\n const results = [];\n\n if (isIterable(position))\n {\n let index = -1;\n\n for (const entry of position)\n {\n index++;\n\n const isPosition = this.#isPosition(entry);\n const actualPosition = isPosition ? entry : entry.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.getScheduled warning: No Position instance found at index: ${index}.`);\n continue;\n }\n\n const controls = AnimationManager.getScheduled(actualPosition);\n\n results.push({ position: actualPosition, data: isPosition ? void 0 : entry, controls });\n }\n }\n else\n {\n const isPosition = this.#isPosition(position);\n const actualPosition = isPosition ? position : position.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.getScheduled warning: No Position instance found.`);\n return results;\n }\n\n const controls = AnimationManager.getScheduled(actualPosition);\n\n results.push({ position: actualPosition, data: isPosition ? void 0 : position, controls });\n }\n\n return results;\n }\n\n /**\n * Provides the `from` animation tween for one or more Position instances as a group.\n *\n * @param {Position|{position: Position}|Iterable|Iterable<{position: Position}>} position -\n *\n * @param {object|Function} fromData -\n *\n * @param {object|Function} options -\n *\n * @returns {TJSBasicAnimation} Basic animation control.\n */\n static from(position, fromData, options)\n {\n if (!isObject(fromData) && typeof fromData !== 'function')\n {\n throw new TypeError(`AnimationGroupAPI.from error: 'fromData' is not an object or function.`);\n }\n\n if (options !== void 0 && !isObject(options) && typeof options !== 'function')\n {\n throw new TypeError(`AnimationGroupAPI.from error: 'options' is not an object or function.`);\n }\n\n /**\n * @type {AnimationControl[]}\n */\n const animationControls = [];\n\n let index = -1;\n let callbackOptions;\n\n const hasDataCallback = typeof fromData === 'function';\n const hasOptionCallback = typeof options === 'function';\n const hasCallback = hasDataCallback || hasOptionCallback;\n\n if (hasCallback) { callbackOptions = { index, position: void 0, data: void 0 }; }\n\n let actualFromData = fromData;\n let actualOptions = options;\n\n if (isIterable(position))\n {\n for (const entry of position)\n {\n index++;\n\n const isPosition = this.#isPosition(entry);\n const actualPosition = isPosition ? entry : entry.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.from warning: No Position instance found at index: ${index}.`);\n continue;\n }\n\n if (hasCallback)\n {\n callbackOptions.index = index;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : entry;\n }\n\n if (hasDataCallback)\n {\n actualFromData = fromData(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (actualFromData === null || actualFromData === void 0) { continue; }\n\n if (typeof actualFromData !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.from error: fromData callback function iteration(${\n index}) failed to return an object.`);\n }\n }\n\n if (hasOptionCallback)\n {\n actualOptions = options(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (actualOptions === null || actualOptions === void 0) { continue; }\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.from error: options callback function iteration(${\n index}) failed to return an object.`);\n }\n }\n\n animationControls.push(actualPosition.animate.from(actualFromData, actualOptions));\n }\n }\n else\n {\n const isPosition = this.#isPosition(position);\n const actualPosition = isPosition ? position : position.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.from warning: No Position instance found.`);\n return AnimationGroupControl.voidControl;\n }\n\n if (hasCallback)\n {\n callbackOptions.index = 0;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : position;\n }\n\n if (hasDataCallback)\n {\n actualFromData = fromData(callbackOptions);\n\n if (typeof actualFromData !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.from error: fromData callback function failed to return an object.`);\n }\n }\n\n if (hasOptionCallback)\n {\n actualOptions = options(callbackOptions);\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.from error: options callback function failed to return an object.`);\n }\n }\n\n animationControls.push(actualPosition.animate.from(actualFromData, actualOptions));\n }\n\n return new AnimationGroupControl(animationControls);\n }\n\n /**\n * Provides the `fromTo` animation tween for one or more Position instances as a group.\n *\n * @param {Position|{position: Position}|Iterable|Iterable<{position: Position}>} position -\n *\n * @param {object|Function} fromData -\n *\n * @param {object|Function} toData -\n *\n * @param {object|Function} options -\n *\n * @returns {TJSBasicAnimation} Basic animation control.\n */\n static fromTo(position, fromData, toData, options)\n {\n if (!isObject(fromData) && typeof fromData !== 'function')\n {\n throw new TypeError(`AnimationGroupAPI.fromTo error: 'fromData' is not an object or function.`);\n }\n\n if (!isObject(toData) && typeof toData !== 'function')\n {\n throw new TypeError(`AnimationGroupAPI.fromTo error: 'toData' is not an object or function.`);\n }\n\n if (options !== void 0 && !isObject(options) && typeof options !== 'function')\n {\n throw new TypeError(`AnimationGroupAPI.fromTo error: 'options' is not an object or function.`);\n }\n\n /**\n * @type {AnimationControl[]}\n */\n const animationControls = [];\n\n let index = -1;\n let callbackOptions;\n\n const hasFromCallback = typeof fromData === 'function';\n const hasToCallback = typeof toData === 'function';\n const hasOptionCallback = typeof options === 'function';\n const hasCallback = hasFromCallback || hasToCallback || hasOptionCallback;\n\n if (hasCallback) { callbackOptions = { index, position: void 0, data: void 0 }; }\n\n let actualFromData = fromData;\n let actualToData = toData;\n let actualOptions = options;\n\n if (isIterable(position))\n {\n for (const entry of position)\n {\n index++;\n\n const isPosition = this.#isPosition(entry);\n const actualPosition = isPosition ? entry : entry.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.fromTo warning: No Position instance found at index: ${index}.`);\n continue;\n }\n\n if (hasCallback)\n {\n callbackOptions.index = index;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : entry;\n }\n\n if (hasFromCallback)\n {\n actualFromData = fromData(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (actualFromData === null || actualFromData === void 0) { continue; }\n\n if (typeof actualFromData !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.fromTo error: fromData callback function iteration(${\n index}) failed to return an object.`);\n }\n }\n\n if (hasToCallback)\n {\n actualToData = toData(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (actualToData === null || actualToData === void 0) { continue; }\n\n if (typeof actualToData !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.fromTo error: toData callback function iteration(${\n index}) failed to return an object.`);\n }\n }\n\n if (hasOptionCallback)\n {\n actualOptions = options(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (actualOptions === null || actualOptions === void 0) { continue; }\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.fromTo error: options callback function iteration(${\n index}) failed to return an object.`);\n }\n }\n\n animationControls.push(actualPosition.animate.fromTo(actualFromData, actualToData, actualOptions));\n }\n }\n else\n {\n const isPosition = this.#isPosition(position);\n const actualPosition = isPosition ? position : position.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.fromTo warning: No Position instance found.`);\n return AnimationGroupControl.voidControl;\n }\n\n if (hasCallback)\n {\n callbackOptions.index = 0;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : position;\n }\n\n if (hasFromCallback)\n {\n actualFromData = fromData(callbackOptions);\n\n if (typeof actualFromData !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.fromTo error: fromData callback function failed to return an object.`);\n }\n }\n\n if (hasToCallback)\n {\n actualToData = toData(callbackOptions);\n\n if (typeof actualToData !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.fromTo error: toData callback function failed to return an object.`);\n }\n }\n\n if (hasOptionCallback)\n {\n actualOptions = options(callbackOptions);\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.fromTo error: options callback function failed to return an object.`);\n }\n }\n\n animationControls.push(actualPosition.animate.fromTo(actualFromData, actualToData, actualOptions));\n }\n\n return new AnimationGroupControl(animationControls);\n }\n\n /**\n * Provides the `to` animation tween for one or more Position instances as a group.\n *\n * @param {Position|{position: Position}|Iterable|Iterable<{position: Position}>} position -\n *\n * @param {object|Function} toData -\n *\n * @param {object|Function} options -\n *\n * @returns {TJSBasicAnimation} Basic animation control.\n */\n static to(position, toData, options)\n {\n if (!isObject(toData) && typeof toData !== 'function')\n {\n throw new TypeError(`AnimationGroupAPI.to error: 'toData' is not an object or function.`);\n }\n\n if (options !== void 0 && !isObject(options) && typeof options !== 'function')\n {\n throw new TypeError(`AnimationGroupAPI.to error: 'options' is not an object or function.`);\n }\n\n /**\n * @type {AnimationControl[]}\n */\n const animationControls = [];\n\n let index = -1;\n let callbackOptions;\n\n const hasDataCallback = typeof toData === 'function';\n const hasOptionCallback = typeof options === 'function';\n const hasCallback = hasDataCallback || hasOptionCallback;\n\n if (hasCallback) { callbackOptions = { index, position: void 0, data: void 0 }; }\n\n let actualToData = toData;\n let actualOptions = options;\n\n if (isIterable(position))\n {\n for (const entry of position)\n {\n index++;\n\n const isPosition = this.#isPosition(entry);\n const actualPosition = isPosition ? entry : entry.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.to warning: No Position instance found at index: ${index}.`);\n continue;\n }\n\n if (hasCallback)\n {\n callbackOptions.index = index;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : entry;\n }\n\n if (hasDataCallback)\n {\n actualToData = toData(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (actualToData === null || actualToData === void 0) { continue; }\n\n if (typeof actualToData !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.to error: toData callback function iteration(${\n index}) failed to return an object.`);\n }\n }\n\n if (hasOptionCallback)\n {\n actualOptions = options(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (actualOptions === null || actualOptions === void 0) { continue; }\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.to error: options callback function iteration(${\n index}) failed to return an object.`);\n }\n }\n\n animationControls.push(actualPosition.animate.to(actualToData, actualOptions));\n }\n }\n else\n {\n const isPosition = this.#isPosition(position);\n const actualPosition = isPosition ? position : position.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.to warning: No Position instance found.`);\n return AnimationGroupControl.voidControl;\n }\n\n if (hasCallback)\n {\n callbackOptions.index = 0;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : position;\n }\n\n if (hasDataCallback)\n {\n actualToData = toData(callbackOptions);\n\n if (typeof actualToData !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.to error: toData callback function failed to return an object.`);\n }\n }\n\n if (hasOptionCallback)\n {\n actualOptions = options(callbackOptions);\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.to error: options callback function failed to return an object.`);\n }\n }\n\n animationControls.push(actualPosition.animate.to(actualToData, actualOptions));\n }\n\n return new AnimationGroupControl(animationControls);\n }\n\n /**\n * Provides the `to` animation tween for one or more Position instances as a group.\n *\n * @param {Position|{position: Position}|Iterable|Iterable<{position: Position}>} position -\n *\n * @param {Iterable} keys -\n *\n * @param {object|Function} options -\n *\n * @returns {quickToCallback} Basic animation control.\n */\n static quickTo(position, keys, options)\n {\n if (!isIterable(keys))\n {\n throw new TypeError(`AnimationGroupAPI.quickTo error: 'keys' is not an iterable list.`);\n }\n\n if (options !== void 0 && !isObject(options) && typeof options !== 'function')\n {\n throw new TypeError(`AnimationGroupAPI.quickTo error: 'options' is not an object or function.`);\n }\n\n /**\n * @type {quickToCallback[]}\n */\n const quickToCallbacks = [];\n\n let index = -1;\n\n const hasOptionCallback = typeof options === 'function';\n\n const callbackOptions = { index, position: void 0, data: void 0 };\n\n let actualOptions = options;\n\n if (isIterable(position))\n {\n for (const entry of position)\n {\n index++;\n\n const isPosition = this.#isPosition(entry);\n const actualPosition = isPosition ? entry : entry.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.quickTo warning: No Position instance found at index: ${index}.`);\n continue;\n }\n\n callbackOptions.index = index;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : entry;\n\n if (hasOptionCallback)\n {\n actualOptions = options(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (actualOptions === null || actualOptions === void 0) { continue; }\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.quickTo error: options callback function iteration(${\n index}) failed to return an object.`);\n }\n }\n\n quickToCallbacks.push(actualPosition.animate.quickTo(keys, actualOptions));\n }\n }\n else\n {\n const isPosition = this.#isPosition(position);\n const actualPosition = isPosition ? position : position.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.quickTo warning: No Position instance found.`);\n return () => null;\n }\n\n callbackOptions.index = 0;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : position;\n\n if (hasOptionCallback)\n {\n actualOptions = options(callbackOptions);\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.quickTo error: options callback function failed to return an object.`);\n }\n }\n\n quickToCallbacks.push(actualPosition.animate.quickTo(keys, actualOptions));\n }\n\n const keysArray = [...keys];\n\n Object.freeze(keysArray);\n\n const quickToCB = (...args) =>\n {\n const argsLength = args.length;\n\n if (argsLength === 0) { return; }\n\n if (typeof args[0] === 'function')\n {\n const dataCallback = args[0];\n\n index = -1;\n let cntr = 0;\n\n if (isIterable(position))\n {\n for (const entry of position)\n {\n index++;\n\n const isPosition = this.#isPosition(entry);\n const actualPosition = isPosition ? entry : entry.position;\n\n if (!this.#isPosition(actualPosition)) { continue; }\n\n callbackOptions.index = index;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : entry;\n\n const toData = dataCallback(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (toData === null || toData === void 0) { continue; }\n\n /**\n * @type {boolean}\n */\n const toDataIterable = isIterable(toData);\n\n if (!Number.isFinite(toData) && !toDataIterable && typeof toData !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.quickTo error: toData callback function iteration(${\n index}) failed to return a finite number, iterable list, or object.`);\n }\n\n if (toDataIterable)\n {\n quickToCallbacks[cntr++](...toData);\n }\n else\n {\n quickToCallbacks[cntr++](toData);\n }\n }\n }\n else\n {\n const isPosition = this.#isPosition(position);\n const actualPosition = isPosition ? position : position.position;\n\n if (!this.#isPosition(actualPosition)) { return; }\n\n callbackOptions.index = 0;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : position;\n\n const toData = dataCallback(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (toData === null || toData === void 0) { return; }\n\n const toDataIterable = isIterable(toData);\n\n if (!Number.isFinite(toData) && !toDataIterable && typeof toData !== 'object')\n {\n throw new TypeError(`AnimationGroupAPI.quickTo error: toData callback function iteration(${\n index}) failed to return a finite number, iterable list, or object.`);\n }\n\n if (toDataIterable)\n {\n quickToCallbacks[cntr++](...toData);\n }\n else\n {\n quickToCallbacks[cntr++](toData);\n }\n }\n }\n else\n {\n for (let cntr = quickToCallbacks.length; --cntr >= 0;)\n {\n quickToCallbacks[cntr](...args);\n }\n }\n };\n\n quickToCB.keys = keysArray;\n\n /**\n * Sets options of quickTo tween.\n *\n * @param {object|Function} [options] - Optional parameters.\n *\n * @param {number} [options.duration] - Duration in seconds.\n *\n * @param {Function} [options.ease] - Easing function.\n *\n * @param {Function} [options.interpolate] - Interpolation function.\n *\n * @returns {quickToCallback} The quickTo callback.\n */\n quickToCB.options = (options) => // eslint-disable-line no-shadow\n {\n if (options !== void 0 && !isObject(options) && typeof options !== 'function')\n {\n throw new TypeError(`AnimationGroupAPI.quickTo error: 'options' is not an object or function.`);\n }\n\n // Set options object for each quickTo callback.\n if (isObject(options))\n {\n for (let cntr = quickToCallbacks.length; --cntr >= 0;) { quickToCallbacks[cntr].options(options); }\n }\n else if (typeof options === 'function')\n {\n if (isIterable(position))\n {\n index = -1;\n let cntr = 0;\n\n for (const entry of position)\n {\n index++;\n\n const isPosition = this.#isPosition(entry);\n const actualPosition = isPosition ? entry : entry.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(\n `AnimationGroupAPI.quickTo.options warning: No Position instance found at index: ${index}.`);\n continue;\n }\n\n callbackOptions.index = index;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : entry;\n\n actualOptions = options(callbackOptions);\n\n // Returned data from callback is null / undefined, so skip this position instance.\n if (actualOptions === null || actualOptions === void 0) { continue; }\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.quickTo.options error: options callback function iteration(${\n index}) failed to return an object.`);\n }\n\n quickToCallbacks[cntr++].options(actualOptions);\n }\n }\n else\n {\n const isPosition = this.#isPosition(position);\n const actualPosition = isPosition ? position : position.position;\n\n if (!this.#isPosition(actualPosition))\n {\n console.warn(`AnimationGroupAPI.quickTo.options warning: No Position instance found.`);\n return quickToCB;\n }\n\n callbackOptions.index = 0;\n callbackOptions.position = position;\n callbackOptions.data = isPosition ? void 0 : position;\n\n actualOptions = options(callbackOptions);\n\n if (typeof actualOptions !== 'object')\n {\n throw new TypeError(\n `AnimationGroupAPI.quickTo error: options callback function failed to return an object.`);\n }\n\n quickToCallbacks[0].options(actualOptions);\n }\n }\n\n return quickToCB;\n };\n\n return quickToCB;\n }\n}\n","export class Centered\n{\n /**\n * @type {HTMLElement}\n */\n #element;\n\n /**\n * Provides a manual setting of the element height. As things go `offsetHeight` causes a browser layout and is not\n * performance oriented. If manually set this height is used instead of `offsetHeight`.\n *\n * @type {number}\n */\n #height;\n\n /**\n * Set from an optional value in the constructor to lock accessors preventing modification.\n */\n #lock;\n\n /**\n * Provides a manual setting of the element width. As things go `offsetWidth` causes a browser layout and is not\n * performance oriented. If manually set this width is used instead of `offsetWidth`.\n *\n * @type {number}\n */\n #width;\n\n constructor({ element, lock = false, width, height } = {})\n {\n this.element = element;\n this.width = width;\n this.height = height;\n\n this.#lock = typeof lock === 'boolean' ? lock : false;\n }\n\n get element() { return this.#element; }\n\n get height() { return this.#height; }\n\n get width() { return this.#width; }\n\n set element(element)\n {\n if (this.#lock) { return; }\n\n if (element === void 0 || element === null || element instanceof HTMLElement)\n {\n this.#element = element;\n }\n else\n {\n throw new TypeError(`'element' is not a HTMLElement, undefined, or null.`);\n }\n }\n\n set height(height)\n {\n if (this.#lock) { return; }\n\n if (height === void 0 || Number.isFinite(height))\n {\n this.#height = height;\n }\n else\n {\n throw new TypeError(`'height' is not a finite number or undefined.`);\n }\n }\n\n set width(width)\n {\n if (this.#lock) { return; }\n\n if (width === void 0 || Number.isFinite(width))\n {\n this.#width = width;\n }\n else\n {\n throw new TypeError(`'width' is not a finite number or undefined.`);\n }\n }\n\n setDimension(width, height)\n {\n if (this.#lock) { return; }\n\n if (width === void 0 || Number.isFinite(width))\n {\n this.#width = width;\n }\n else\n {\n throw new TypeError(`'width' is not a finite number or undefined.`);\n }\n\n if (height === void 0 || Number.isFinite(height))\n {\n this.#height = height;\n }\n else\n {\n throw new TypeError(`'height' is not a finite number or undefined.`);\n }\n }\n\n getLeft(width)\n {\n // Determine containing bounds from manual values; or any element; lastly the browser width / height.\n const boundsWidth = this.#width ?? this.#element?.offsetWidth ?? globalThis.innerWidth;\n\n return (boundsWidth - width) / 2;\n }\n\n getTop(height)\n {\n const boundsHeight = this.#height ?? this.#element?.offsetHeight ?? globalThis.innerHeight;\n\n return (boundsHeight - height) / 2;\n }\n}\n","import { Centered } from './Centered.js';\n\nconst browserCentered = new Centered();\n\nexport { browserCentered, Centered };\n\n","export class PositionChangeSet\n{\n constructor()\n {\n this.left = false;\n this.top = false;\n this.width = false;\n this.height = false;\n this.maxHeight = false;\n this.maxWidth = false;\n this.minHeight = false;\n this.minWidth = false;\n this.zIndex = false;\n this.transform = false;\n this.transformOrigin = false;\n }\n\n hasChange()\n {\n return this.left || this.top || this.width || this.height || this.maxHeight || this.maxWidth || this.minHeight ||\n this.minWidth || this.zIndex || this.transform || this.transformOrigin;\n }\n\n set(value)\n {\n this.left = value;\n this.top = value;\n this.width = value;\n this.height = value;\n this.maxHeight = value;\n this.maxWidth = value;\n this.minHeight = value;\n this.minWidth = value;\n this.zIndex = value;\n this.transform = value;\n this.transformOrigin = value;\n }\n}\n","/**\n * Defines stored positional data.\n */\nexport class PositionData\n{\n constructor({ height = null, left = null, maxHeight = null, maxWidth = null, minHeight = null, minWidth = null,\n rotateX = null, rotateY = null, rotateZ = null, scale = null, translateX = null, translateY = null,\n translateZ = null, top = null, transformOrigin = null, width = null, zIndex = null } = {})\n {\n /**\n * @type {number|'auto'|'inherit'|null}\n */\n this.height = height;\n\n /**\n * @type {number|null}\n */\n this.left = left;\n\n /**\n * @type {number|null}\n */\n this.maxHeight = maxHeight;\n\n /**\n * @type {number|null}\n */\n this.maxWidth = maxWidth;\n\n /**\n * @type {number|null}\n */\n this.minHeight = minHeight;\n\n /**\n * @type {number|null}\n */\n this.minWidth = minWidth;\n\n /**\n * @type {number|null}\n */\n this.rotateX = rotateX;\n\n /**\n * @type {number|null}\n */\n this.rotateY = rotateY;\n\n /**\n * @type {number|null}\n */\n this.rotateZ = rotateZ;\n\n /**\n * @type {number|null}\n */\n this.scale = scale;\n\n /**\n * @type {number|null}\n */\n this.top = top;\n\n /**\n * @type {string|null}\n */\n this.transformOrigin = transformOrigin;\n\n /**\n * @type {number|null}\n */\n this.translateX = translateX;\n\n /**\n * @type {number|null}\n */\n this.translateY = translateY;\n\n /**\n * @type {number|null}\n */\n this.translateZ = translateZ;\n\n /**\n * @type {number|'auto'|'inherit'|null}\n */\n this.width = width;\n\n /**\n * @type {number|null}\n */\n this.zIndex = zIndex;\n\n Object.seal(this);\n }\n\n /**\n * Copies given data to this instance.\n *\n * @param {PositionData} data - Copy from this instance.\n *\n * @returns {PositionData} This instance.\n */\n copy(data)\n {\n this.height = data.height;\n this.left = data.left;\n this.maxHeight = data.maxHeight;\n this.maxWidth = data.maxWidth;\n this.minHeight = data.minHeight;\n this.minWidth = data.minWidth;\n this.rotateX = data.rotateX;\n this.rotateY = data.rotateY;\n this.rotateZ = data.rotateZ;\n this.scale = data.scale;\n this.top = data.top;\n this.transformOrigin = data.transformOrigin;\n this.translateX = data.translateX;\n this.translateY = data.translateY;\n this.translateZ = data.translateZ;\n this.width = data.width;\n this.zIndex = data.zIndex;\n\n return this;\n }\n}\n","import { linear } from 'svelte/easing';\n\nimport { lerp } from '@typhonjs-fvtt/runtime/svelte/math';\nimport { isIterable } from '@typhonjs-fvtt/runtime/svelte/util';\n\nexport class PositionStateAPI\n{\n /** @type {PositionData} */\n #data;\n\n /**\n * @type {Map}\n */\n #dataSaved = new Map();\n\n /** @type {Position} */\n #position;\n\n /** @type {Transforms} */\n #transforms;\n\n constructor(position, data, transforms)\n {\n this.#position = position;\n this.#data = data;\n this.#transforms = transforms;\n }\n\n /**\n * Returns any stored save state by name.\n *\n * @param {string} name - Saved data set name.\n *\n * @returns {PositionDataExtended} The saved data set.\n */\n get({ name })\n {\n if (typeof name !== 'string') { throw new TypeError(`Position - getSave error: 'name' is not a string.`); }\n\n return this.#dataSaved.get(name);\n }\n\n /**\n * Returns any associated default data.\n *\n * @returns {PositionDataExtended} Associated default data.\n */\n getDefault()\n {\n return this.#dataSaved.get('#defaultData');\n }\n\n /**\n * Removes and returns any position state by name.\n *\n * @param {object} options - Options.\n *\n * @param {string} options.name - Name to remove and retrieve.\n *\n * @returns {PositionDataExtended} Saved position data.\n */\n remove({ name })\n {\n if (typeof name !== 'string') { throw new TypeError(`Position - remove: 'name' is not a string.`); }\n\n const data = this.#dataSaved.get(name);\n this.#dataSaved.delete(name);\n\n return data;\n }\n\n /**\n * Resets data to default values and invokes set.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {boolean} [opts.keepZIndex=false] - When true keeps current z-index.\n *\n * @param {boolean} [opts.invokeSet=true] - When true invokes set method.\n *\n * @returns {boolean} Operation successful.\n */\n reset({ keepZIndex = false, invokeSet = true } = {})\n {\n const defaultData = this.#dataSaved.get('#defaultData');\n\n // Quit early if there is no saved default data.\n if (typeof defaultData !== 'object') { return false; }\n\n // Cancel all animations for Position if there are currently any scheduled.\n if (this.#position.animate.isScheduled)\n {\n this.#position.animate.cancel();\n }\n\n const zIndex = this.#position.zIndex;\n\n const data = Object.assign({}, defaultData);\n\n if (keepZIndex) { data.zIndex = zIndex; }\n\n // Reset the transform data.\n this.#transforms.reset(data);\n\n // If current minimized invoke `maximize`.\n if (this.#position.parent?.reactive?.minimized)\n {\n this.#position.parent?.maximize?.({ animate: false, duration: 0 });\n }\n\n // Note next clock tick scheduling.\n if (invokeSet) { setTimeout(() => this.#position.set(data), 0); }\n\n return true;\n }\n\n /**\n * Restores a saved positional state returning the data. Several optional parameters are available\n * to control whether the restore action occurs silently (no store / inline styles updates), animates\n * to the stored data, or simply sets the stored data. Restoring via {@link AnimationAPI.to} allows\n * specification of the duration, easing, and interpolate functions along with configuring a Promise to be\n * returned if awaiting the end of the animation.\n *\n * @param {object} params - Parameters\n *\n * @param {string} params.name - Saved data set name.\n *\n * @param {boolean} [params.remove=false] - Remove data set.\n *\n * @param {Iterable} [params.properties] - Specific properties to set / animate.\n *\n * @param {boolean} [params.silent] - Set position data directly; no store or style updates.\n *\n * @param {boolean} [params.async=false] - If animating return a Promise that resolves with any saved data.\n *\n * @param {boolean} [params.animateTo=false] - Animate to restore data.\n *\n * @param {number} [params.duration=0.1] - Duration in seconds.\n *\n * @param {Function} [params.ease=linear] - Easing function.\n *\n * @param {Function} [params.interpolate=lerp] - Interpolation function.\n *\n * @returns {PositionDataExtended|Promise} Saved position data.\n */\n restore({ name, remove = false, properties, silent = false, async = false, animateTo = false, duration = 0.1,\n ease = linear, interpolate = lerp })\n {\n if (typeof name !== 'string') { throw new TypeError(`Position - restore error: 'name' is not a string.`); }\n\n const dataSaved = this.#dataSaved.get(name);\n\n if (dataSaved)\n {\n if (remove) { this.#dataSaved.delete(name); }\n\n let data = dataSaved;\n\n if (isIterable(properties))\n {\n data = {};\n for (const property of properties) { data[property] = dataSaved[property]; }\n }\n\n // Update data directly with no store or inline style updates.\n if (silent)\n {\n for (const property in data) { this.#data[property] = data[property]; }\n return dataSaved;\n }\n else if (animateTo) // Animate to saved data.\n {\n // Provide special handling to potentially change transform origin as this parameter is not animated.\n if (data.transformOrigin !== this.#position.transformOrigin)\n {\n this.#position.transformOrigin = data.transformOrigin;\n }\n\n // Return a Promise with saved data that resolves after animation ends.\n if (async)\n {\n return this.#position.animate.to(data, { duration, ease, interpolate }).finished.then(() => dataSaved);\n }\n else // Animate synchronously.\n {\n this.#position.animate.to(data, { duration, ease, interpolate });\n }\n }\n else\n {\n // Default options is to set data for an immediate update.\n this.#position.set(data);\n }\n }\n\n return dataSaved;\n }\n\n /**\n * Saves current position state with the opportunity to add extra data to the saved state.\n *\n * @param {object} opts - Options.\n *\n * @param {string} opts.name - name to index this saved data.\n *\n * @param {...*} [opts.extra] - Extra data to add to saved data.\n *\n * @returns {PositionData} Current position data\n */\n save({ name, ...extra })\n {\n if (typeof name !== 'string') { throw new TypeError(`Position - save error: 'name' is not a string.`); }\n\n const data = this.#position.get(extra);\n\n this.#dataSaved.set(name, data);\n\n return data;\n }\n\n /**\n * Directly sets a position state.\n *\n * @param {object} opts - Options.\n *\n * @param {string} opts.name - name to index this saved data.\n *\n * @param {...*} [opts.data] - Position data to set.\n */\n set({ name, ...data })\n {\n if (typeof name !== 'string') { throw new TypeError(`Position - set error: 'name' is not a string.`); }\n\n this.#dataSaved.set(name, data);\n }\n}\n","import { writable } from 'svelte/store';\n\nimport { propertyStore } from '@typhonjs-fvtt/runtime/svelte/store';\nimport { styleParsePixels } from '@typhonjs-fvtt/runtime/svelte/util';\n\nexport class StyleCache\n{\n constructor()\n {\n /** @type {HTMLElement|undefined} */\n this.el = void 0;\n\n /** @type {CSSStyleDeclaration} */\n this.computed = void 0;\n\n /** @type {number|undefined} */\n this.marginLeft = void 0;\n\n /** @type {number|undefined} */\n this.marginTop = void 0;\n\n /** @type {number|undefined} */\n this.maxHeight = void 0;\n\n /** @type {number|undefined} */\n this.maxWidth = void 0;\n\n /** @type {number|undefined} */\n this.minHeight = void 0;\n\n /** @type {number|undefined} */\n this.minWidth = void 0;\n\n /** @type {boolean} */\n this.hasWillChange = false;\n\n /**\n * @type {ResizeObserverData}\n */\n this.resizeObserved = {\n contentHeight: void 0,\n contentWidth: void 0,\n offsetHeight: void 0,\n offsetWidth: void 0\n };\n\n /**\n * Provides a writable store to track offset & content width / height from an associated `resizeObserver` action.\n *\n * @type {Writable}\n */\n const storeResizeObserved = writable(this.resizeObserved);\n\n this.stores = {\n element: writable(this.el),\n resizeContentHeight: propertyStore(storeResizeObserved, 'contentHeight'),\n resizeContentWidth: propertyStore(storeResizeObserved, 'contentWidth'),\n resizeObserved: storeResizeObserved,\n resizeOffsetHeight: propertyStore(storeResizeObserved, 'offsetHeight'),\n resizeOffsetWidth: propertyStore(storeResizeObserved, 'offsetWidth')\n };\n }\n\n /**\n * Returns the cached offsetHeight from any attached `resizeObserver` action otherwise gets the offsetHeight from\n * the element directly. The more optimized path is using `resizeObserver` as getting it from the element\n * directly is more expensive and alters the execution order of an animation frame.\n *\n * @returns {number} The element offsetHeight.\n */\n get offsetHeight()\n {\n if (this.el instanceof HTMLElement)\n {\n return this.resizeObserved.offsetHeight !== void 0 ? this.resizeObserved.offsetHeight : this.el.offsetHeight;\n }\n\n throw new Error(`StyleCache - get offsetHeight error: no element assigned.`);\n }\n\n /**\n * Returns the cached offsetWidth from any attached `resizeObserver` action otherwise gets the offsetWidth from\n * the element directly. The more optimized path is using `resizeObserver` as getting it from the element\n * directly is more expensive and alters the execution order of an animation frame.\n *\n * @returns {number} The element offsetHeight.\n */\n get offsetWidth()\n {\n if (this.el instanceof HTMLElement)\n {\n return this.resizeObserved.offsetWidth !== void 0 ? this.resizeObserved.offsetWidth : this.el.offsetWidth;\n }\n\n throw new Error(`StyleCache - get offsetWidth error: no element assigned.`);\n }\n\n /**\n * @param {HTMLElement} el -\n *\n * @returns {boolean} Does element match cached element.\n */\n hasData(el) { return this.el === el; }\n\n /**\n * Resets the style cache.\n */\n reset()\n {\n // Remove will-change inline style from previous element if it is still connected.\n if (this.el instanceof HTMLElement && this.el.isConnected && !this.hasWillChange)\n {\n this.el.style.willChange = null;\n }\n\n this.el = void 0;\n this.computed = void 0;\n this.marginLeft = void 0;\n this.marginTop = void 0;\n this.maxHeight = void 0;\n this.maxWidth = void 0;\n this.minHeight = void 0;\n this.minWidth = void 0;\n\n this.hasWillChange = false;\n\n // Silently reset `resizedObserved`; With proper usage the `resizeObserver` action issues an update on removal.\n this.resizeObserved.contentHeight = void 0;\n this.resizeObserved.contentWidth = void 0;\n this.resizeObserved.offsetHeight = void 0;\n this.resizeObserved.offsetWidth = void 0;\n\n // Reset the tracked element this Position instance is modifying.\n this.stores.element.set(void 0);\n }\n\n /**\n * Updates the style cache with new data from the given element.\n *\n * @param {HTMLElement} el - An HTML element.\n */\n update(el)\n {\n this.el = el;\n\n this.computed = globalThis.getComputedStyle(el);\n\n this.marginLeft = styleParsePixels(el.style.marginLeft) ?? styleParsePixels(this.computed.marginLeft);\n this.marginTop = styleParsePixels(el.style.marginTop) ?? styleParsePixels(this.computed.marginTop);\n this.maxHeight = styleParsePixels(el.style.maxHeight) ?? styleParsePixels(this.computed.maxHeight);\n this.maxWidth = styleParsePixels(el.style.maxWidth) ?? styleParsePixels(this.computed.maxWidth);\n\n // Note that the computed styles for below will always be 0px / 0 when no style is active.\n this.minHeight = styleParsePixels(el.style.minHeight) ?? styleParsePixels(this.computed.minHeight);\n this.minWidth = styleParsePixels(el.style.minWidth) ?? styleParsePixels(this.computed.minWidth);\n\n // Tracks if there already is a will-change property on the inline or computed styles.\n const willChange = el.style.willChange !== '' ? el.style.willChange : void 0 ?? this.computed.willChange;\n\n this.hasWillChange = willChange !== '' && willChange !== 'auto';\n\n // Update the tracked element this Position instance is modifying.\n this.stores.element.set(el);\n }\n}\n","import { mat4, vec3 } from '@typhonjs-fvtt/runtime/svelte/math';\n\n/**\n * Provides the output data for {@link Transforms.getData}.\n */\nexport class TransformData\n{\n constructor()\n {\n Object.seal(this);\n }\n\n /**\n * Stores the calculated bounding rectangle.\n *\n * @type {DOMRect}\n */\n #boundingRect = new DOMRect();\n\n /**\n * Stores the individual transformed corner points of the window in screenspace clockwise from:\n * top left -> top right -> bottom right -> bottom left.\n *\n * @type {Vector3[]}\n */\n #corners = [vec3.create(), vec3.create(), vec3.create(), vec3.create()];\n\n /**\n * Stores the current gl-matrix mat4 data.\n *\n * @type {Matrix4}\n */\n #mat4 = mat4.create();\n\n /**\n * Stores the pre & post origin translations to apply to matrix transforms.\n *\n * @type {Matrix4[]}\n */\n #originTranslations = [mat4.create(), mat4.create()];\n\n /**\n * @returns {DOMRect} The bounding rectangle.\n */\n get boundingRect() { return this.#boundingRect; }\n\n /**\n * @returns {Vector3[]} The transformed corner points as vec3 in screen space.\n */\n get corners() { return this.#corners; }\n\n /**\n * @returns {string} Returns the CSS style string for the transform matrix.\n */\n get css() { return `matrix3d(${this.mat4.join(',')})`; }\n\n /**\n * @returns {Matrix4} The transform matrix.\n */\n get mat4() { return this.#mat4; }\n\n /**\n * @returns {Matrix4[]} The pre / post translation matrices for origin translation.\n */\n get originTranslations() { return this.#originTranslations; }\n}\n\n/**\n * @typedef {Float32Array} Vector3 - 3 Dimensional Vector.\n *\n * @see https://glmatrix.net/docs/module-vec3.html\n */\n\n/**\n * @typedef {Float32Array} Matrix4 - 4x4 Matrix; Format: column-major, when typed out it looks like row-major.\n *\n * @see https://glmatrix.net/docs/module-mat4.html\n */\n","/**\n * Provides the storage and sequencing of managed position validators. Each validator added may be a bespoke function or\n * a {@link ValidatorData} object containing an `id`, `validator`, and `weight` attributes; `validator` is the only\n * required attribute.\n *\n * The `id` attribute can be anything that creates a unique ID for the validator; recommended strings or numbers. This\n * allows validators to be removed by ID easily.\n *\n * The `weight` attribute is a number between 0 and 1 inclusive that allows validators to be added in a\n * predictable order which is especially handy if they are manipulated at runtime. A lower weighted validator always\n * runs before a higher weighted validator. If no weight is specified the default of '1' is assigned and it is appended\n * to the end of the validators list.\n *\n * This class forms the public API which is accessible from the `.validators` getter in the main Position instance.\n * ```\n * const position = new Position();\n * position.validators.add(...);\n * position.validators.clear();\n * position.validators.length;\n * position.validators.remove(...);\n * position.validators.removeBy(...);\n * position.validators.removeById(...);\n * ```\n */\nexport class AdapterValidators\n{\n /**\n * @type {ValidatorData[]}\n */\n #validatorData;\n\n #mapUnsubscribe = new Map();\n\n /**\n * @returns {[AdapterValidators, ValidatorData[]]} Returns this and internal storage for validator adapter.\n */\n constructor()\n {\n this.#validatorData = [];\n\n Object.seal(this);\n\n return [this, this.#validatorData];\n }\n\n /**\n * @returns {number} Returns the length of the validators array.\n */\n get length() { return this.#validatorData.length; }\n\n /**\n * Provides an iterator for validators.\n *\n * @returns {Generator} Generator / iterator of validators.\n * @yields {ValidatorData}\n */\n *[Symbol.iterator]()\n {\n if (this.#validatorData.length === 0) { return; }\n\n for (const entry of this.#validatorData)\n {\n yield { ...entry };\n }\n }\n\n /**\n * @param {...(ValidatorFn|ValidatorData)} validators -\n */\n add(...validators)\n {\n /**\n * Tracks the number of validators added that have subscriber functionality.\n *\n * @type {number}\n */\n let subscribeCount = 0;\n\n for (const validator of validators)\n {\n const validatorType = typeof validator;\n\n if (validatorType !== 'function' && validatorType !== 'object' || validator === null)\n {\n throw new TypeError(`AdapterValidator error: 'validator' is not a function or object.`);\n }\n\n let data = void 0;\n let subscribeFn = void 0;\n\n switch (validatorType)\n {\n case 'function':\n data = {\n id: void 0,\n validator,\n weight: 1\n };\n\n subscribeFn = validator.subscribe;\n break;\n\n case 'object':\n if (typeof validator.validator !== 'function')\n {\n throw new TypeError(`AdapterValidator error: 'validator' attribute is not a function.`);\n }\n\n if (validator.weight !== void 0 && typeof validator.weight !== 'number' ||\n (validator.weight < 0 || validator.weight > 1))\n {\n throw new TypeError(\n `AdapterValidator error: 'weight' attribute is not a number between '0 - 1' inclusive.`);\n }\n\n data = {\n id: validator.id !== void 0 ? validator.id : void 0,\n validator: validator.validator.bind(validator),\n weight: validator.weight || 1,\n instance: validator\n };\n\n subscribeFn = validator.validator.subscribe ?? validator.subscribe;\n break;\n }\n\n // Find the index to insert where data.weight is less than existing values weight.\n const index = this.#validatorData.findIndex((value) =>\n {\n return data.weight < value.weight;\n });\n\n // If an index was found insert at that location.\n if (index >= 0)\n {\n this.#validatorData.splice(index, 0, data);\n }\n else // push to end of validators.\n {\n this.#validatorData.push(data);\n }\n\n if (typeof subscribeFn === 'function')\n {\n // TODO: consider how to handle validator updates.\n const unsubscribe = subscribeFn();\n\n // Ensure that unsubscribe is a function.\n if (typeof unsubscribe !== 'function')\n {\n throw new TypeError(\n 'AdapterValidator error: Filter has subscribe function, but no unsubscribe function is returned.');\n }\n\n // Ensure that the same validator is not subscribed to multiple times.\n if (this.#mapUnsubscribe.has(data.validator))\n {\n throw new Error(\n 'AdapterValidator error: Filter added already has an unsubscribe function registered.');\n }\n\n this.#mapUnsubscribe.set(data.validator, unsubscribe);\n subscribeCount++;\n }\n }\n\n // Filters with subscriber functionality are assumed to immediately invoke the `subscribe` callback. If the\n // subscriber count is less than the amount of validators added then automatically trigger an index update\n // manually.\n // TODO: handle validator updates.\n // if (subscribeCount < validators.length) { this.#indexUpdate(); }\n }\n\n clear()\n {\n this.#validatorData.length = 0;\n\n // Unsubscribe from all validators with subscription support.\n for (const unsubscribe of this.#mapUnsubscribe.values())\n {\n unsubscribe();\n }\n\n this.#mapUnsubscribe.clear();\n\n // TODO: handle validator updates.\n // this.#indexUpdate();\n }\n\n /**\n * @param {...(ValidatorFn|ValidatorData)} validators -\n */\n remove(...validators)\n {\n const length = this.#validatorData.length;\n\n if (length === 0) { return; }\n\n for (const data of validators)\n {\n // Handle the case that the validator may either be a function or a validator entry / object.\n const actualValidator = typeof data === 'function' ? data : data !== null && typeof data === 'object' ?\n data.validator : void 0;\n\n if (!actualValidator) { continue; }\n\n for (let cntr = this.#validatorData.length; --cntr >= 0;)\n {\n if (this.#validatorData[cntr].validator === actualValidator)\n {\n this.#validatorData.splice(cntr, 1);\n\n // Invoke any unsubscribe function for given validator then remove from tracking.\n let unsubscribe = void 0;\n if (typeof (unsubscribe = this.#mapUnsubscribe.get(actualValidator)) === 'function')\n {\n unsubscribe();\n this.#mapUnsubscribe.delete(actualValidator);\n }\n }\n }\n }\n\n // Update the index a validator was removed.\n // TODO: handle validator updates.\n // if (length !== this.#validatorData.length) { this.#indexUpdate(); }\n }\n\n /**\n * Remove validators by the provided callback. The callback takes 3 parameters: `id`, `validator`, and `weight`.\n * Any truthy value returned will remove that validator.\n *\n * @param {function(*, ValidatorFn, number): boolean} callback - Callback function to evaluate each validator\n * entry.\n */\n removeBy(callback)\n {\n const length = this.#validatorData.length;\n\n if (length === 0) { return; }\n\n if (typeof callback !== 'function')\n {\n throw new TypeError(`AdapterValidator error: 'callback' is not a function.`);\n }\n\n this.#validatorData = this.#validatorData.filter((data) =>\n {\n const remove = callback.call(callback, { ...data });\n\n if (remove)\n {\n let unsubscribe;\n if (typeof (unsubscribe = this.#mapUnsubscribe.get(data.validator)) === 'function')\n {\n unsubscribe();\n this.#mapUnsubscribe.delete(data.validator);\n }\n }\n\n // Reverse remove boolean to properly validator / remove this validator.\n return !remove;\n });\n\n // TODO: handle validator updates.\n // if (length !== this.#validatorData.length) { this.#indexUpdate(); }\n }\n\n removeById(...ids)\n {\n const length = this.#validatorData.length;\n\n if (length === 0) { return; }\n\n this.#validatorData = this.#validatorData.filter((data) =>\n {\n let remove = false;\n\n for (const id of ids) { remove |= data.id === id; }\n\n // If not keeping invoke any unsubscribe function for given validator then remove from tracking.\n if (remove)\n {\n let unsubscribe;\n if (typeof (unsubscribe = this.#mapUnsubscribe.get(data.validator)) === 'function')\n {\n unsubscribe();\n this.#mapUnsubscribe.delete(data.validator);\n }\n }\n\n return !remove; // Swap here to actually remove the item via array validator method.\n });\n\n // TODO: handle validator updates.\n // if (length !== this.#validatorData.length) { this.#indexUpdate(); }\n }\n}\n\n/**\n * @callback ValidatorFn - Position validator function that takes a {@link PositionData} instance potentially\n * modifying it or returning null if invalid.\n *\n * @param {ValidationData} valData - Validation data.\n *\n * @returns {PositionData|null} The validated position data or null to cancel position update.\n *\n */\n\n/**\n * @typedef {object} ValidatorData\n *\n * @property {*} [id=undefined] - An ID associated with this validator. Can be used to remove the validator.\n *\n * @property {ValidatorFn} validator - Position validator function that takes a {@link PositionData} instance\n * potentially modifying it or returning null if invalid.\n *\n * @property {number} [weight=1] - A number between 0 and 1 inclusive to position this validator against others.\n *\n * @property {Function} [subscribe] - Optional subscribe function following the Svelte store / subscribe pattern.\n */\n","export class BasicBounds\n{\n /**\n * When true constrains the min / max width or height to element.\n *\n * @type {boolean}\n */\n #constrain;\n\n /**\n * @type {HTMLElement}\n */\n #element;\n\n /**\n * When true the validator is active.\n *\n * @type {boolean}\n */\n #enabled;\n\n /**\n * Provides a manual setting of the element height. As things go `offsetHeight` causes a browser layout and is not\n * performance oriented. If manually set this height is used instead of `offsetHeight`.\n *\n * @type {number}\n */\n #height;\n\n /**\n * Set from an optional value in the constructor to lock accessors preventing modification.\n */\n #lock;\n\n /**\n * Provides a manual setting of the element width. As things go `offsetWidth` causes a browser layout and is not\n * performance oriented. If manually set this width is used instead of `offsetWidth`.\n *\n * @type {number}\n */\n #width;\n\n constructor({ constrain = true, element, enabled = true, lock = false, width, height } = {})\n {\n this.element = element;\n this.constrain = constrain;\n this.enabled = enabled;\n this.width = width;\n this.height = height;\n\n this.#lock = typeof lock === 'boolean' ? lock : false;\n }\n\n get constrain() { return this.#constrain; }\n\n get element() { return this.#element; }\n\n get enabled() { return this.#enabled; }\n\n get height() { return this.#height; }\n\n get width() { return this.#width; }\n\n set constrain(constrain)\n {\n if (this.#lock) { return; }\n\n if (typeof constrain !== 'boolean') { throw new TypeError(`'constrain' is not a boolean.`); }\n\n this.#constrain = constrain;\n }\n\n set element(element)\n {\n if (this.#lock) { return; }\n\n if (element === void 0 || element === null || element instanceof HTMLElement)\n {\n this.#element = element;\n }\n else\n {\n throw new TypeError(`'element' is not a HTMLElement, undefined, or null.`);\n }\n }\n\n set enabled(enabled)\n {\n if (this.#lock) { return; }\n\n if (typeof enabled !== 'boolean') { throw new TypeError(`'enabled' is not a boolean.`); }\n\n this.#enabled = enabled;\n }\n\n set height(height)\n {\n if (this.#lock) { return; }\n\n if (height === void 0 || Number.isFinite(height))\n {\n this.#height = height;\n }\n else\n {\n throw new TypeError(`'height' is not a finite number or undefined.`);\n }\n }\n\n set width(width)\n {\n if (this.#lock) { return; }\n\n if (width === void 0 || Number.isFinite(width))\n {\n this.#width = width;\n }\n else\n {\n throw new TypeError(`'width' is not a finite number or undefined.`);\n }\n }\n\n setDimension(width, height)\n {\n if (this.#lock) { return; }\n\n if (width === void 0 || Number.isFinite(width))\n {\n this.#width = width;\n }\n else\n {\n throw new TypeError(`'width' is not a finite number or undefined.`);\n }\n\n if (height === void 0 || Number.isFinite(height))\n {\n this.#height = height;\n }\n else\n {\n throw new TypeError(`'height' is not a finite number or undefined.`);\n }\n }\n\n /**\n * Provides a validator that respects transforms in positional data constraining the position to within the target\n * elements bounds.\n *\n * @param {ValidationData} valData - The associated validation data for position updates.\n *\n * @returns {PositionData} Potentially adjusted position data.\n */\n validator(valData)\n {\n // Early out if element is undefined or local enabled state is false.\n if (!this.#enabled) { return valData.position; }\n\n // Determine containing bounds from manual values; or any element; lastly the browser width / height.\n const boundsWidth = this.#width ?? this.#element?.offsetWidth ?? globalThis.innerWidth;\n const boundsHeight = this.#height ?? this.#element?.offsetHeight ?? globalThis.innerHeight;\n\n if (typeof valData.position.width === 'number')\n {\n const maxW = valData.maxWidth ?? (this.#constrain ? boundsWidth : Number.MAX_SAFE_INTEGER);\n valData.position.width = valData.width = Math.clamped(valData.position.width, valData.minWidth, maxW);\n\n if ((valData.width + valData.position.left + valData.marginLeft) > boundsWidth)\n {\n valData.position.left = boundsWidth - valData.width - valData.marginLeft;\n }\n }\n\n if (typeof valData.position.height === 'number')\n {\n const maxH = valData.maxHeight ?? (this.#constrain ? boundsHeight : Number.MAX_SAFE_INTEGER);\n valData.position.height = valData.height = Math.clamped(valData.position.height, valData.minHeight, maxH);\n\n if ((valData.height + valData.position.top + valData.marginTop) > boundsHeight)\n {\n valData.position.top = boundsHeight - valData.height - valData.marginTop;\n }\n }\n\n const maxL = Math.max(boundsWidth - valData.width - valData.marginLeft, 0);\n valData.position.left = Math.round(Math.clamped(valData.position.left, 0, maxL));\n\n const maxT = Math.max(boundsHeight - valData.height - valData.marginTop, 0);\n valData.position.top = Math.round(Math.clamped(valData.position.top, 0, maxT));\n\n return valData.position;\n }\n}\n","import { TransformData } from '../transform/TransformData.js';\n\nconst s_TRANSFORM_DATA = new TransformData();\n\nexport class TransformBounds\n{\n /**\n * When true constrains the min / max width or height to element.\n *\n * @type {boolean}\n */\n #constrain;\n\n /**\n * @type {HTMLElement}\n */\n #element;\n\n /**\n * When true the validator is active.\n *\n * @type {boolean}\n */\n #enabled;\n\n /**\n * Provides a manual setting of the element height. As things go `offsetHeight` causes a browser layout and is not\n * performance oriented. If manually set this height is used instead of `offsetHeight`.\n *\n * @type {number}\n */\n #height;\n\n /**\n * Set from an optional value in the constructor to lock accessors preventing modification.\n */\n #lock;\n\n /**\n * Provides a manual setting of the element width. As things go `offsetWidth` causes a browser layout and is not\n * performance oriented. If manually set this width is used instead of `offsetWidth`.\n *\n * @type {number}\n */\n #width;\n\n constructor({ constrain = true, element, enabled = true, lock = false, width, height } = {})\n {\n this.element = element;\n this.constrain = constrain;\n this.enabled = enabled;\n this.width = width;\n this.height = height;\n\n this.#lock = typeof lock === 'boolean' ? lock : false;\n }\n\n get constrain() { return this.#constrain; }\n\n get element() { return this.#element; }\n\n get enabled() { return this.#enabled; }\n\n get height() { return this.#height; }\n\n get width() { return this.#width; }\n\n set constrain(constrain)\n {\n if (this.#lock) { return; }\n\n if (typeof constrain !== 'boolean') { throw new TypeError(`'constrain' is not a boolean.`); }\n\n this.#constrain = constrain;\n }\n\n set element(element)\n {\n if (this.#lock) { return; }\n\n if (element === void 0 || element === null || element instanceof HTMLElement)\n {\n this.#element = element;\n }\n else\n {\n throw new TypeError(`'element' is not a HTMLElement, undefined, or null.`);\n }\n }\n\n set enabled(enabled)\n {\n if (this.#lock) { return; }\n\n if (typeof enabled !== 'boolean') { throw new TypeError(`'enabled' is not a boolean.`); }\n\n this.#enabled = enabled;\n }\n\n set height(height)\n {\n if (this.#lock) { return; }\n\n if (height === void 0 || Number.isFinite(height))\n {\n this.#height = height;\n }\n else\n {\n throw new TypeError(`'height' is not a finite number or undefined.`);\n }\n }\n\n set width(width)\n {\n if (this.#lock) { return; }\n\n if (width === void 0 || Number.isFinite(width))\n {\n this.#width = width;\n }\n else\n {\n throw new TypeError(`'width' is not a finite number or undefined.`);\n }\n }\n\n setDimension(width, height)\n {\n if (this.#lock) { return; }\n\n if (width === void 0 || Number.isFinite(width))\n {\n this.#width = width;\n }\n else\n {\n throw new TypeError(`'width' is not a finite number or undefined.`);\n }\n\n if (height === void 0 || Number.isFinite(height))\n {\n this.#height = height;\n }\n else\n {\n throw new TypeError(`'height' is not a finite number or undefined.`);\n }\n }\n\n /**\n * Provides a validator that respects transforms in positional data constraining the position to within the target\n * elements bounds.\n *\n * @param {ValidationData} valData - The associated validation data for position updates.\n *\n * @returns {PositionData} Potentially adjusted position data.\n */\n validator(valData)\n {\n // Early out if element is undefined or local enabled state is false.\n if (!this.#enabled) { return valData.position; }\n\n // Determine containing bounds from manual values; or any element; lastly the browser width / height.\n const boundsWidth = this.#width ?? this.#element?.offsetWidth ?? globalThis.innerWidth;\n const boundsHeight = this.#height ?? this.#element?.offsetHeight ?? globalThis.innerHeight;\n\n // Ensure min / max width constraints when position width is a number; not 'auto' or 'inherit'. If constrain is\n // true cap width bounds.\n if (typeof valData.position.width === 'number')\n {\n const maxW = valData.maxWidth ?? (this.#constrain ? boundsWidth : Number.MAX_SAFE_INTEGER);\n valData.position.width = Math.clamped(valData.width, valData.minWidth, maxW);\n }\n\n // Ensure min / max height constraints when position height is a number; not 'auto' or 'inherit'. If constrain\n // is true cap height bounds.\n if (typeof valData.position.height === 'number')\n {\n const maxH = valData.maxHeight ?? (this.#constrain ? boundsHeight : Number.MAX_SAFE_INTEGER);\n valData.position.height = Math.clamped(valData.height, valData.minHeight, maxH);\n }\n\n // Get transform data. First set constraints including any margin top / left as offsets and width / height. Used\n // when position width / height is 'auto'.\n const data = valData.transforms.getData(valData.position, s_TRANSFORM_DATA, valData);\n\n // Check the bounding rectangle against browser height / width. Adjust position based on how far the overlap of\n // the bounding rect is outside the bounds height / width. The order below matters as the constraints are top /\n // left oriented, so perform those checks last.\n\n const initialX = data.boundingRect.x;\n const initialY = data.boundingRect.y;\n\n if (data.boundingRect.bottom + valData.marginTop > boundsHeight)\n {\n data.boundingRect.y += boundsHeight - data.boundingRect.bottom - valData.marginTop;\n }\n\n if (data.boundingRect.right + valData.marginLeft > boundsWidth)\n {\n data.boundingRect.x += boundsWidth - data.boundingRect.right - valData.marginLeft;\n }\n\n if (data.boundingRect.top - valData.marginTop < 0)\n {\n data.boundingRect.y += Math.abs(data.boundingRect.top - valData.marginTop);\n }\n\n if (data.boundingRect.left - valData.marginLeft < 0)\n {\n data.boundingRect.x += Math.abs(data.boundingRect.left - valData.marginLeft);\n }\n\n valData.position.left -= initialX - data.boundingRect.x;\n valData.position.top -= initialY - data.boundingRect.y;\n\n return valData.position;\n }\n}\n","import { BasicBounds } from './BasicBounds.js';\nimport { TransformBounds } from './TransformBounds.js';\n\nconst basicWindow = new BasicBounds({ lock: true });\nconst transformWindow = new TransformBounds({ lock: true });\n\nexport { basicWindow, BasicBounds, transformWindow, TransformBounds };\n","import { degToRad, mat4, vec3 } from '@typhonjs-fvtt/runtime/svelte/math';\n\nimport * as constants from '../constants.js';\n\nimport { TransformData } from './TransformData.js';\n\n/** @type {number[]} */\nconst s_SCALE_VECTOR = [1, 1, 1];\n\n/** @type {number[]} */\nconst s_TRANSLATE_VECTOR = [0, 0, 0];\n\n/** @type {Matrix4} */\nconst s_MAT4_RESULT = mat4.create();\n\n/** @type {Matrix4} */\nconst s_MAT4_TEMP = mat4.create();\n\n/** @type {Vector3} */\nconst s_VEC3_TEMP = vec3.create();\n\nexport class Transforms\n{\n /**\n * Stores the transform keys in the order added.\n *\n * @type {string[]}\n */\n #orderList = [];\n\n constructor()\n {\n this._data = {};\n }\n\n /**\n * @returns {boolean} Whether there are active transforms in local data.\n */\n get isActive() { return this.#orderList.length > 0; }\n\n /**\n * @returns {number|undefined} Any local rotateX data.\n */\n get rotateX() { return this._data.rotateX; }\n\n /**\n * @returns {number|undefined} Any local rotateY data.\n */\n get rotateY() { return this._data.rotateY; }\n\n /**\n * @returns {number|undefined} Any local rotateZ data.\n */\n get rotateZ() { return this._data.rotateZ; }\n\n /**\n * @returns {number|undefined} Any local rotateZ scale.\n */\n get scale() { return this._data.scale; }\n\n /**\n * @returns {number|undefined} Any local translateZ data.\n */\n get translateX() { return this._data.translateX; }\n\n /**\n * @returns {number|undefined} Any local translateZ data.\n */\n get translateY() { return this._data.translateY; }\n\n /**\n * @returns {number|undefined} Any local translateZ data.\n */\n get translateZ() { return this._data.translateZ; }\n\n /**\n * Sets the local rotateX data if the value is a finite number otherwise removes the local data.\n *\n * @param {number|null|undefined} value - A value to set.\n */\n set rotateX(value)\n {\n if (Number.isFinite(value))\n {\n if (this._data.rotateX === void 0) { this.#orderList.push('rotateX'); }\n\n this._data.rotateX = value;\n }\n else\n {\n if (this._data.rotateX !== void 0)\n {\n const index = this.#orderList.findIndex((entry) => entry === 'rotateX');\n if (index >= 0) { this.#orderList.splice(index, 1); }\n }\n\n delete this._data.rotateX;\n }\n }\n\n /**\n * Sets the local rotateY data if the value is a finite number otherwise removes the local data.\n *\n * @param {number|null|undefined} value - A value to set.\n */\n set rotateY(value)\n {\n if (Number.isFinite(value))\n {\n if (this._data.rotateY === void 0) { this.#orderList.push('rotateY'); }\n\n this._data.rotateY = value;\n }\n else\n {\n if (this._data.rotateY !== void 0)\n {\n const index = this.#orderList.findIndex((entry) => entry === 'rotateY');\n if (index >= 0) { this.#orderList.splice(index, 1); }\n }\n\n delete this._data.rotateY;\n }\n }\n\n /**\n * Sets the local rotateZ data if the value is a finite number otherwise removes the local data.\n *\n * @param {number|null|undefined} value - A value to set.\n */\n set rotateZ(value)\n {\n if (Number.isFinite(value))\n {\n if (this._data.rotateZ === void 0) { this.#orderList.push('rotateZ'); }\n\n this._data.rotateZ = value;\n }\n\n else\n {\n if (this._data.rotateZ !== void 0)\n {\n const index = this.#orderList.findIndex((entry) => entry === 'rotateZ');\n if (index >= 0) { this.#orderList.splice(index, 1); }\n }\n\n delete this._data.rotateZ;\n }\n }\n\n /**\n * Sets the local scale data if the value is a finite number otherwise removes the local data.\n *\n * @param {number|null|undefined} value - A value to set.\n */\n set scale(value)\n {\n if (Number.isFinite(value))\n {\n if (this._data.scale === void 0) { this.#orderList.push('scale'); }\n\n this._data.scale = value;\n }\n else\n {\n if (this._data.scale !== void 0)\n {\n const index = this.#orderList.findIndex((entry) => entry === 'scale');\n if (index >= 0) { this.#orderList.splice(index, 1); }\n }\n\n delete this._data.scale;\n }\n }\n\n /**\n * Sets the local translateX data if the value is a finite number otherwise removes the local data.\n *\n * @param {number|null|undefined} value - A value to set.\n */\n set translateX(value)\n {\n if (Number.isFinite(value))\n {\n if (this._data.translateX === void 0) { this.#orderList.push('translateX'); }\n\n this._data.translateX = value;\n }\n\n else\n {\n if (this._data.translateX !== void 0)\n {\n const index = this.#orderList.findIndex((entry) => entry === 'translateX');\n if (index >= 0) { this.#orderList.splice(index, 1); }\n }\n\n delete this._data.translateX;\n }\n }\n\n /**\n * Sets the local translateY data if the value is a finite number otherwise removes the local data.\n *\n * @param {number|null|undefined} value - A value to set.\n */\n set translateY(value)\n {\n if (Number.isFinite(value))\n {\n if (this._data.translateY === void 0) { this.#orderList.push('translateY'); }\n\n this._data.translateY = value;\n }\n\n else\n {\n if (this._data.translateY !== void 0)\n {\n const index = this.#orderList.findIndex((entry) => entry === 'translateY');\n if (index >= 0) { this.#orderList.splice(index, 1); }\n }\n\n delete this._data.translateY;\n }\n }\n\n /**\n * Sets the local translateZ data if the value is a finite number otherwise removes the local data.\n *\n * @param {number|null|undefined} value - A value to set.\n */\n set translateZ(value)\n {\n if (Number.isFinite(value))\n {\n if (this._data.translateZ === void 0) { this.#orderList.push('translateZ'); }\n\n this._data.translateZ = value;\n }\n\n else\n {\n if (this._data.translateZ !== void 0)\n {\n const index = this.#orderList.findIndex((entry) => entry === 'translateZ');\n if (index >= 0) { this.#orderList.splice(index, 1); }\n }\n\n delete this._data.translateZ;\n }\n }\n\n /**\n * Returns the matrix3d CSS transform for the given position / transform data.\n *\n * @param {object} [data] - Optional position data otherwise use local stored transform data.\n *\n * @returns {string} The CSS matrix3d string.\n */\n getCSS(data = this._data)\n {\n return `matrix3d(${this.getMat4(data, s_MAT4_RESULT).join(',')})`;\n }\n\n /**\n * Returns the matrix3d CSS transform for the given position / transform data.\n *\n * @param {object} [data] - Optional position data otherwise use local stored transform data.\n *\n * @returns {string} The CSS matrix3d string.\n */\n getCSSOrtho(data = this._data)\n {\n return `matrix3d(${this.getMat4Ortho(data, s_MAT4_RESULT).join(',')})`;\n }\n\n /**\n * Collects all data including a bounding rect, transform matrix, and points array of the given {@link PositionData}\n * instance with the applied local transform data.\n *\n * @param {PositionData} position - The position data to process.\n *\n * @param {TransformData} [output] - Optional TransformData output instance.\n *\n * @param {object} [validationData] - Optional validation data for adjustment parameters.\n *\n * @returns {TransformData} The output TransformData instance.\n */\n getData(position, output = new TransformData(), validationData = {})\n {\n const valWidth = validationData.width ?? 0;\n const valHeight = validationData.height ?? 0;\n const valOffsetTop = validationData.offsetTop ?? validationData.marginTop ?? 0;\n const valOffsetLeft = validationData.offsetLeft ?? validationData.offsetLeft ?? 0;\n\n position.top += valOffsetTop;\n position.left += valOffsetLeft;\n\n const width = Number.isFinite(position.width) ? position.width : valWidth;\n const height = Number.isFinite(position.height) ? position.height : valHeight;\n\n const rect = output.corners;\n\n if (this.hasTransform(position))\n {\n rect[0][0] = rect[0][1] = rect[0][2] = 0;\n rect[1][0] = width;\n rect[1][1] = rect[1][2] = 0;\n rect[2][0] = width;\n rect[2][1] = height;\n rect[2][2] = 0;\n rect[3][0] = 0;\n rect[3][1] = height;\n rect[3][2] = 0;\n\n const matrix = this.getMat4(position, output.mat4);\n\n const translate = s_GET_ORIGIN_TRANSLATION(position.transformOrigin, width, height, output.originTranslations);\n\n if (constants.transformOriginDefault === position.transformOrigin)\n {\n vec3.transformMat4(rect[0], rect[0], matrix);\n vec3.transformMat4(rect[1], rect[1], matrix);\n vec3.transformMat4(rect[2], rect[2], matrix);\n vec3.transformMat4(rect[3], rect[3], matrix);\n }\n else\n {\n vec3.transformMat4(rect[0], rect[0], translate[0]);\n vec3.transformMat4(rect[0], rect[0], matrix);\n vec3.transformMat4(rect[0], rect[0], translate[1]);\n\n vec3.transformMat4(rect[1], rect[1], translate[0]);\n vec3.transformMat4(rect[1], rect[1], matrix);\n vec3.transformMat4(rect[1], rect[1], translate[1]);\n\n vec3.transformMat4(rect[2], rect[2], translate[0]);\n vec3.transformMat4(rect[2], rect[2], matrix);\n vec3.transformMat4(rect[2], rect[2], translate[1]);\n\n vec3.transformMat4(rect[3], rect[3], translate[0]);\n vec3.transformMat4(rect[3], rect[3], matrix);\n vec3.transformMat4(rect[3], rect[3], translate[1]);\n }\n\n rect[0][0] = position.left + rect[0][0];\n rect[0][1] = position.top + rect[0][1];\n rect[1][0] = position.left + rect[1][0];\n rect[1][1] = position.top + rect[1][1];\n rect[2][0] = position.left + rect[2][0];\n rect[2][1] = position.top + rect[2][1];\n rect[3][0] = position.left + rect[3][0];\n rect[3][1] = position.top + rect[3][1];\n }\n else\n {\n rect[0][0] = position.left;\n rect[0][1] = position.top;\n rect[1][0] = position.left + width;\n rect[1][1] = position.top;\n rect[2][0] = position.left + width;\n rect[2][1] = position.top + height;\n rect[3][0] = position.left;\n rect[3][1] = position.top + height;\n\n mat4.identity(output.mat4);\n }\n\n let maxX = Number.MIN_SAFE_INTEGER;\n let maxY = Number.MIN_SAFE_INTEGER;\n let minX = Number.MAX_SAFE_INTEGER;\n let minY = Number.MAX_SAFE_INTEGER;\n\n for (let cntr = 4; --cntr >= 0;)\n {\n if (rect[cntr][0] > maxX) { maxX = rect[cntr][0]; }\n if (rect[cntr][0] < minX) { minX = rect[cntr][0]; }\n if (rect[cntr][1] > maxY) { maxY = rect[cntr][1]; }\n if (rect[cntr][1] < minY) { minY = rect[cntr][1]; }\n }\n\n const boundingRect = output.boundingRect;\n boundingRect.x = minX;\n boundingRect.y = minY;\n boundingRect.width = maxX - minX;\n boundingRect.height = maxY - minY;\n\n position.top -= valOffsetTop;\n position.left -= valOffsetLeft;\n\n return output;\n }\n\n /**\n * Creates a transform matrix based on local data applied in order it was added.\n *\n * If no data object is provided then the source is the local transform data. If another data object is supplied\n * then the stored local transform order is applied then all remaining transform keys are applied. This allows the\n * construction of a transform matrix in advance of setting local data and is useful in collision detection.\n *\n * @param {object} [data] - PositionData instance or local transform data.\n *\n * @param {Matrix4} [output] - The output mat4 instance.\n *\n * @returns {Matrix4} Transform matrix.\n */\n getMat4(data = this._data, output = mat4.create())\n {\n const matrix = mat4.identity(output);\n\n // Bitwise tracks applied transform keys from local transform data.\n let seenKeys = 0;\n\n const orderList = this.#orderList;\n\n // First apply ordered transforms from local transform data.\n for (let cntr = 0; cntr < orderList.length; cntr++)\n {\n const key = orderList[cntr];\n\n switch (key)\n {\n case 'rotateX':\n seenKeys |= constants.transformKeysBitwise.rotateX;\n mat4.multiply(matrix, matrix, mat4.fromXRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'rotateY':\n seenKeys |= constants.transformKeysBitwise.rotateY;\n mat4.multiply(matrix, matrix, mat4.fromYRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'rotateZ':\n seenKeys |= constants.transformKeysBitwise.rotateZ;\n mat4.multiply(matrix, matrix, mat4.fromZRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'scale':\n seenKeys |= constants.transformKeysBitwise.scale;\n s_SCALE_VECTOR[0] = s_SCALE_VECTOR[1] = data[key];\n mat4.multiply(matrix, matrix, mat4.fromScaling(s_MAT4_TEMP, s_SCALE_VECTOR));\n break;\n\n case 'translateX':\n seenKeys |= constants.transformKeysBitwise.translateX;\n s_TRANSLATE_VECTOR[0] = data.translateX;\n s_TRANSLATE_VECTOR[1] = 0;\n s_TRANSLATE_VECTOR[2] = 0;\n mat4.multiply(matrix, matrix, mat4.fromTranslation(s_MAT4_TEMP, s_TRANSLATE_VECTOR));\n break;\n\n case 'translateY':\n seenKeys |= constants.transformKeysBitwise.translateY;\n s_TRANSLATE_VECTOR[0] = 0;\n s_TRANSLATE_VECTOR[1] = data.translateY;\n s_TRANSLATE_VECTOR[2] = 0;\n mat4.multiply(matrix, matrix, mat4.fromTranslation(s_MAT4_TEMP, s_TRANSLATE_VECTOR));\n break;\n\n case 'translateZ':\n seenKeys |= constants.transformKeysBitwise.translateZ;\n s_TRANSLATE_VECTOR[0] = 0;\n s_TRANSLATE_VECTOR[1] = 0;\n s_TRANSLATE_VECTOR[2] = data.translateZ;\n mat4.multiply(matrix, matrix, mat4.fromTranslation(s_MAT4_TEMP, s_TRANSLATE_VECTOR));\n break;\n }\n }\n\n // Now apply any new keys not set in local transform data that have not been applied yet.\n if (data !== this._data)\n {\n for (let cntr = 0; cntr < constants.transformKeys.length; cntr++)\n {\n const key = constants.transformKeys[cntr];\n\n // Reject bad / no data or if the key has already been applied.\n if (data[key] === null || (seenKeys & constants.transformKeysBitwise[key]) > 0) { continue; }\n\n switch (key)\n {\n case 'rotateX':\n mat4.multiply(matrix, matrix, mat4.fromXRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'rotateY':\n mat4.multiply(matrix, matrix, mat4.fromYRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'rotateZ':\n mat4.multiply(matrix, matrix, mat4.fromZRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'scale':\n s_SCALE_VECTOR[0] = s_SCALE_VECTOR[1] = data[key];\n mat4.multiply(matrix, matrix, mat4.fromScaling(s_MAT4_TEMP, s_SCALE_VECTOR));\n break;\n\n case 'translateX':\n s_TRANSLATE_VECTOR[0] = data[key];\n s_TRANSLATE_VECTOR[1] = 0;\n s_TRANSLATE_VECTOR[2] = 0;\n mat4.multiply(matrix, matrix, mat4.fromTranslation(s_MAT4_TEMP, s_TRANSLATE_VECTOR));\n break;\n\n case 'translateY':\n s_TRANSLATE_VECTOR[0] = 0;\n s_TRANSLATE_VECTOR[1] = data[key];\n s_TRANSLATE_VECTOR[2] = 0;\n mat4.multiply(matrix, matrix, mat4.fromTranslation(s_MAT4_TEMP, s_TRANSLATE_VECTOR));\n break;\n\n case 'translateZ':\n s_TRANSLATE_VECTOR[0] = 0;\n s_TRANSLATE_VECTOR[1] = 0;\n s_TRANSLATE_VECTOR[2] = data[key];\n mat4.multiply(matrix, matrix, mat4.fromTranslation(s_MAT4_TEMP, s_TRANSLATE_VECTOR));\n break;\n }\n }\n }\n\n return matrix;\n }\n\n /**\n * Provides an orthographic enhancement to convert left / top positional data to a translate operation.\n *\n * This transform matrix takes into account that the remaining operations are , but adds any left / top attributes from passed in data to\n * translate X / Y.\n *\n * If no data object is provided then the source is the local transform data. If another data object is supplied\n * then the stored local transform order is applied then all remaining transform keys are applied. This allows the\n * construction of a transform matrix in advance of setting local data and is useful in collision detection.\n *\n * @param {object} [data] - PositionData instance or local transform data.\n *\n * @param {Matrix4} [output] - The output mat4 instance.\n *\n * @returns {Matrix4} Transform matrix.\n */\n getMat4Ortho(data = this._data, output = mat4.create())\n {\n const matrix = mat4.identity(output);\n\n // Attempt to retrieve values from passed in data otherwise default to 0.\n // Always perform the translation last regardless of order added to local transform data.\n // Add data.left to translateX and data.top to translateY.\n s_TRANSLATE_VECTOR[0] = (data.left ?? 0) + (data.translateX ?? 0);\n s_TRANSLATE_VECTOR[1] = (data.top ?? 0) + (data.translateY ?? 0);\n s_TRANSLATE_VECTOR[2] = data.translateZ ?? 0;\n mat4.multiply(matrix, matrix, mat4.fromTranslation(s_MAT4_TEMP, s_TRANSLATE_VECTOR));\n\n // Scale can also be applied out of order.\n if (data.scale !== null)\n {\n s_SCALE_VECTOR[0] = s_SCALE_VECTOR[1] = data.scale;\n mat4.multiply(matrix, matrix, mat4.fromScaling(s_MAT4_TEMP, s_SCALE_VECTOR));\n }\n\n // Early out if there is not rotation data.\n if (data.rotateX === null && data.rotateY === null && data.rotateZ === null) { return matrix; }\n\n // Rotation transforms must be applied in the order they are added.\n\n // Bitwise tracks applied transform keys from local transform data.\n let seenKeys = 0;\n\n const orderList = this.#orderList;\n\n // First apply ordered transforms from local transform data.\n for (let cntr = 0; cntr < orderList.length; cntr++)\n {\n const key = orderList[cntr];\n\n switch (key)\n {\n case 'rotateX':\n seenKeys |= constants.transformKeysBitwise.rotateX;\n mat4.multiply(matrix, matrix, mat4.fromXRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'rotateY':\n seenKeys |= constants.transformKeysBitwise.rotateY;\n mat4.multiply(matrix, matrix, mat4.fromYRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'rotateZ':\n seenKeys |= constants.transformKeysBitwise.rotateZ;\n mat4.multiply(matrix, matrix, mat4.fromZRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n }\n }\n\n // Now apply any new keys not set in local transform data that have not been applied yet.\n if (data !== this._data)\n {\n for (let cntr = 0; cntr < constants.transformKeys.length; cntr++)\n {\n const key = constants.transformKeys[cntr];\n\n // Reject bad / no data or if the key has already been applied.\n if (data[key] === null || (seenKeys & constants.transformKeysBitwise[key]) > 0) { continue; }\n\n switch (key)\n {\n case 'rotateX':\n mat4.multiply(matrix, matrix, mat4.fromXRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'rotateY':\n mat4.multiply(matrix, matrix, mat4.fromYRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n\n case 'rotateZ':\n mat4.multiply(matrix, matrix, mat4.fromZRotation(s_MAT4_TEMP, degToRad(data[key])));\n break;\n }\n }\n }\n\n return matrix;\n }\n\n /**\n * Tests an object if it contains transform keys and the values are finite numbers.\n *\n * @param {object} data - An object to test for transform data.\n *\n * @returns {boolean} Whether the given PositionData has transforms.\n */\n hasTransform(data)\n {\n for (const key of constants.transformKeys)\n {\n if (Number.isFinite(data[key])) { return true; }\n }\n\n return false;\n }\n\n /**\n * Resets internal data from the given object containing valid transform keys.\n *\n * @param {object} data - An object with transform data.\n */\n reset(data)\n {\n for (const key in data)\n {\n if (constants.transformKeys.includes(key))\n {\n if (Number.isFinite(data[key]))\n {\n this._data[key] = data[key];\n }\n else\n {\n const index = this.#orderList.findIndex((entry) => entry === key);\n if (index >= 0) { this.#orderList.splice(index, 1); }\n\n delete this._data[key];\n }\n }\n }\n }\n}\n\n/**\n * Returns the translations necessary to translate a matrix operation based on the `transformOrigin` parameter of the\n * given position instance. The first entry / index 0 is the pre-translation and last entry / index 1 is the post-\n * translation.\n *\n * This method is used internally, but may be useful if you need the origin translation matrices to transform\n * bespoke points based on any `transformOrigin` set in {@link PositionData}.\n *\n * @param {string} transformOrigin - The transform origin attribute from PositionData.\n *\n * @param {number} width - The PositionData width or validation data width when 'auto'.\n *\n * @param {number} height - The PositionData height or validation data height when 'auto'.\n *\n * @param {Matrix4[]} output - Output Mat4 array.\n *\n * @returns {Matrix4[]} Output Mat4 array.\n */\nfunction s_GET_ORIGIN_TRANSLATION(transformOrigin, width, height, output)\n{\n const vector = s_VEC3_TEMP;\n\n switch (transformOrigin)\n {\n case 'top left':\n vector[0] = vector[1] = 0;\n mat4.fromTranslation(output[0], vector);\n mat4.fromTranslation(output[1], vector);\n break;\n\n case 'top center':\n vector[0] = -width * 0.5;\n vector[1] = 0;\n mat4.fromTranslation(output[0], vector);\n vector[0] = width * 0.5;\n mat4.fromTranslation(output[1], vector);\n break;\n\n case 'top right':\n vector[0] = -width;\n vector[1] = 0;\n mat4.fromTranslation(output[0], vector);\n vector[0] = width;\n mat4.fromTranslation(output[1], vector);\n break;\n\n case 'center left':\n vector[0] = 0;\n vector[1] = -height * 0.5;\n mat4.fromTranslation(output[0], vector);\n vector[1] = height * 0.5;\n mat4.fromTranslation(output[1], vector);\n break;\n\n case null: // By default null / no transform is center.\n case 'center':\n vector[0] = -width * 0.5;\n vector[1] = -height * 0.5;\n mat4.fromTranslation(output[0], vector);\n vector[0] = width * 0.5;\n vector[1] = height * 0.5;\n mat4.fromTranslation(output[1], vector);\n break;\n\n case 'center right':\n vector[0] = -width;\n vector[1] = -height * 0.5;\n mat4.fromTranslation(output[0], vector);\n vector[0] = width;\n vector[1] = height * 0.5;\n mat4.fromTranslation(output[1], vector);\n break;\n\n case 'bottom left':\n vector[0] = 0;\n vector[1] = -height;\n mat4.fromTranslation(output[0], vector);\n vector[1] = height;\n mat4.fromTranslation(output[1], vector);\n break;\n\n case 'bottom center':\n vector[0] = -width * 0.5;\n vector[1] = -height;\n mat4.fromTranslation(output[0], vector);\n vector[0] = width * 0.5;\n vector[1] = height;\n mat4.fromTranslation(output[1], vector);\n break;\n\n case 'bottom right':\n vector[0] = -width;\n vector[1] = -height;\n mat4.fromTranslation(output[0], vector);\n vector[0] = width;\n vector[1] = height;\n mat4.fromTranslation(output[1], vector);\n break;\n\n // No valid transform origin parameter; set identity.\n default:\n mat4.identity(output[0]);\n mat4.identity(output[1]);\n break;\n }\n\n return output;\n}\n","import { writable } from 'svelte/store';\n\nimport { TransformData } from '../transform/TransformData.js';\nimport { PositionData } from '../PositionData.js';\n\nexport class UpdateElementData\n{\n constructor()\n {\n /**\n * Stores the private data from Position.\n *\n * @type {PositionData}\n */\n this.data = void 0;\n\n /**\n * Provides a copy of local data sent to subscribers.\n *\n * @type {PositionData}\n */\n this.dataSubscribers = new PositionData();\n\n /**\n * Stores the current dimension data used for the readable `dimension` store.\n *\n * @type {{width: number | 'auto', height: number | 'auto'}}\n */\n this.dimensionData = { width: 0, height: 0 };\n\n /**\n * @type {PositionChangeSet}\n */\n this.changeSet = void 0;\n\n /**\n * @type {PositionOptions}\n */\n this.options = void 0;\n\n /**\n * Stores if this Position / update data is queued for update.\n *\n * @type {boolean}\n */\n this.queued = false;\n\n /**\n * @type {StyleCache}\n */\n this.styleCache = void 0;\n\n /**\n * @type {Transforms}\n */\n this.transforms = void 0;\n\n /**\n * Stores the current transform data used for the readable `transform` store. It is only active when there are\n * subscribers to the store or calculateTransform options is true.\n *\n * @type {TransformData}\n */\n this.transformData = new TransformData();\n\n /**\n * @type {(function(PositionData): void)[]}\n */\n this.subscriptions = void 0;\n\n /**\n * @type {Writable<{width: (number|\"auto\"), height: (number|\"auto\")}>}\n */\n this.storeDimension = writable(this.dimensionData);\n\n // When there are subscribers set option to calculate transform updates; set to false when no subscribers.\n\n /**\n * @type {Writable}\n */\n this.storeTransform = writable(this.transformData, () =>\n {\n this.options.transformSubscribed = true;\n return () => this.options.transformSubscribed = false;\n });\n\n /**\n * Stores the queued state for update element processing.\n *\n * @type {boolean}\n */\n this.queued = false;\n\n // Seal data backing readable stores.\n Object.seal(this.dimensionData);\n }\n}\n","import { isWritableStore } from '@typhonjs-fvtt/runtime/svelte/store';\n\n/**\n * Svelte doesn't provide any events for the animate directive.\n *\n * The provided function below wraps a Svelte animate directive function generating bubbling events for start & end of\n * animation.\n *\n * These events are `animate:start` and `animate:end`.\n *\n * This is useful for instance if you are animating several nodes in a scrollable container where the overflow parameter\n * needs to be set to `none` while animating such that the scrollbar is not activated by the animation.\n *\n * Optionally you may also provide a boolean writable store that will be set to true when animation is active. In some\n * cases this leads to an easier implementation for gating on animation state.\n *\n * @example With events \n * const flipWithEvents = animateEvents(flip);\n * \n *\n * console.log('animate:start')\n * on:animate:end={() => console.log('animate:end')}>\n * {#each someData as entry (entry.id)}\n * \n * {/each}\n\n * @example With optional store \n * const isAnimating = writable(false);\n * const flipWithEvents = animateEvents(flip, isAnimating);\n * \n *\n * \n * {#each someData as entry (entry.id)}\n * \n * {/each}\n *\n * @param {(node: Element, { from: DOMRect, to: DOMRect }, params?: *) =>\n * import('svelte/animate').AnimationConfig} fn - A Svelte animation function.\n *\n * @param {import('svelte/store').Writable} [store] - An optional boolean writable store that is set to true\n * when animation is active.\n *\n * @returns {(node: Element, { from: DOMRect, to: DOMRect }, params?: *) =>\n * import('svelte/animate').AnimationConfig} Wrapped animation function.\n */\nfunction animateEvents(fn, store = void 0)\n{\n if (typeof fn !== 'function') { throw new TypeError(`'fn' is not a function.`); }\n if (store !== void 0 && !isWritableStore(store)) { throw new TypeError(`'store' is not a writable store.`); }\n\n // Track a single start / end sequence across all animations.\n let startFired = false;\n let endFired = false;\n\n return (node, animations, params = {}) =>\n {\n const animationConfig = fn(node, animations, params);\n\n // Store any existing tick function.\n const existingTick = animationConfig.tick;\n\n // Use tick callback to fire events only once when t / time is 0 and 1.\n animationConfig.tick = (t, u) =>\n {\n // If there is any tick function then invoke it.\n if (existingTick) { existingTick(t, u); }\n\n if (!startFired && t === 0)\n {\n if (store) { store.set(true); }\n node.dispatchEvent(new CustomEvent('animate:start', { bubbles: true }));\n startFired = true;\n endFired = false;\n }\n\n if (!endFired && t === 1)\n {\n if (store) { store.set(false); }\n node.dispatchEvent(new CustomEvent('animate:end', { bubbles: true }));\n endFired = true;\n startFired = false;\n }\n };\n\n return animationConfig;\n }\n}\n\n/**\n * Awaits `requestAnimationFrame` calls by the counter specified. This allows asynchronous applications for direct /\n * inline style modification amongst other direct animation techniques.\n *\n * @param {number} [cntr=1] - A positive integer greater than 0 for amount of requestAnimationFrames to wait.\n *\n * @returns {Promise} Returns current time equivalent to `performance.now()`.\n */\nasync function nextAnimationFrame(cntr = 1)\n{\n if (!Number.isInteger(cntr) || cntr < 1)\n {\n throw new TypeError(`nextAnimationFrame error: 'cntr' must be a positive integer greater than 0.`);\n }\n\n let currentTime = performance.now();\n for (;--cntr >= 0;)\n {\n currentTime = await new Promise((resolve) => requestAnimationFrame(resolve));\n }\n\n return currentTime;\n}\n\nexport { animateEvents, nextAnimationFrame };\n//# sourceMappingURL=index.js.map\n","import { nextAnimationFrame } from '@typhonjs-fvtt/runtime/svelte/animate';\n\n/**\n * Decouples updates to any parent target HTMLElement inline styles. Invoke {@link Position.elementUpdated} to await\n * on the returned promise that is resolved with the current render time via `nextAnimationFrame` /\n * `requestAnimationFrame`. This allows the underlying data model to be updated immediately while updates to the\n * element are in sync with the browser and potentially in the future be further throttled.\n *\n * @param {HTMLElement} el - The target HTMLElement.\n */\nexport class UpdateElementManager\n{\n static list = [];\n static listCntr = 0;\n\n static updatePromise;\n\n static get promise() { return this.updatePromise; }\n\n /**\n * Potentially adds the given element and internal updateData instance to the list.\n *\n * @param {HTMLElement} el - An HTMLElement instance.\n *\n * @param {UpdateElementData} updateData - An UpdateElementData instance.\n *\n * @returns {Promise} The unified next frame update promise. Returns `currentTime`.\n */\n static add(el, updateData)\n {\n if (this.listCntr < this.list.length)\n {\n const entry = this.list[this.listCntr];\n entry[0] = el;\n entry[1] = updateData;\n }\n else\n {\n this.list.push([el, updateData]);\n }\n\n this.listCntr++;\n updateData.queued = true;\n\n if (!this.updatePromise) { this.updatePromise = this.wait(); }\n\n return this.updatePromise;\n }\n\n /**\n * Await on `nextAnimationFrame` and iterate over list map invoking callback functions.\n *\n * @returns {Promise} The next frame Promise / currentTime from nextAnimationFrame.\n */\n static async wait()\n {\n // Await the next animation frame. In the future this can be extended to multiple frames to divide update rate.\n const currentTime = await nextAnimationFrame();\n\n this.updatePromise = void 0;\n\n for (let cntr = this.listCntr; --cntr >= 0;)\n {\n // Obtain data for entry.\n const entry = this.list[cntr];\n const el = entry[0];\n const updateData = entry[1];\n\n // Clear entry data.\n entry[0] = void 0;\n entry[1] = void 0;\n\n // Reset queued state.\n updateData.queued = false;\n\n // Early out if the element is no longer connected to the DOM / shadow root.\n // if (!el.isConnected || !updateData.changeSet.hasChange()) { continue; }\n if (!el.isConnected) { continue; }\n\n if (updateData.options.ortho)\n {\n s_UPDATE_ELEMENT_ORTHO(el, updateData);\n }\n else\n {\n s_UPDATE_ELEMENT(el, updateData);\n }\n\n // If calculate transform options is enabled then update the transform data and set the readable store.\n if (updateData.options.calculateTransform || updateData.options.transformSubscribed)\n {\n s_UPDATE_TRANSFORM(el, updateData);\n }\n\n // Update all subscribers with changed data.\n this.updateSubscribers(updateData);\n }\n\n this.listCntr = 0;\n\n return currentTime;\n }\n\n /**\n * Potentially immediately updates the given element.\n *\n * @param {HTMLElement} el - An HTMLElement instance.\n *\n * @param {UpdateElementData} updateData - An UpdateElementData instance.\n */\n static immediate(el, updateData)\n {\n // Early out if the element is no longer connected to the DOM / shadow root.\n // if (!el.isConnected || !updateData.changeSet.hasChange()) { continue; }\n if (!el.isConnected) { return; }\n\n if (updateData.options.ortho)\n {\n s_UPDATE_ELEMENT_ORTHO(el, updateData);\n }\n else\n {\n s_UPDATE_ELEMENT(el, updateData);\n }\n\n // If calculate transform options is enabled then update the transform data and set the readable store.\n if (updateData.options.calculateTransform || updateData.options.transformSubscribed)\n {\n s_UPDATE_TRANSFORM(el, updateData);\n }\n\n // Update all subscribers with changed data.\n this.updateSubscribers(updateData);\n }\n\n /**\n * @param {UpdateElementData} updateData - Data change set.\n */\n static updateSubscribers(updateData)\n {\n const data = updateData.data;\n const changeSet = updateData.changeSet;\n\n if (!changeSet.hasChange()) { return; }\n\n // Make a copy of the data.\n const output = updateData.dataSubscribers.copy(data);\n\n const subscriptions = updateData.subscriptions;\n\n // Early out if there are no subscribers.\n if (subscriptions.length > 0)\n {\n for (let cntr = 0; cntr < subscriptions.length; cntr++) { subscriptions[cntr](output); }\n }\n\n // Update dimension data if width / height has changed.\n if (changeSet.width || changeSet.height)\n {\n updateData.dimensionData.width = data.width;\n updateData.dimensionData.height = data.height;\n updateData.storeDimension.set(updateData.dimensionData);\n }\n\n changeSet.set(false);\n }\n}\n\n/**\n * Decouples updates to any parent target HTMLElement inline styles. Invoke {@link Position.elementUpdated} to await\n * on the returned promise that is resolved with the current render time via `nextAnimationFrame` /\n * `requestAnimationFrame`. This allows the underlying data model to be updated immediately while updates to the\n * element are in sync with the browser and potentially in the future be further throttled.\n *\n * @param {HTMLElement} el - The target HTMLElement.\n *\n * @param {UpdateElementData} updateData - Update data.\n */\nfunction s_UPDATE_ELEMENT(el, updateData)\n{\n const changeSet = updateData.changeSet;\n const data = updateData.data;\n\n if (changeSet.left)\n {\n el.style.left = `${data.left}px`;\n }\n\n if (changeSet.top)\n {\n el.style.top = `${data.top}px`;\n }\n\n if (changeSet.zIndex)\n {\n el.style.zIndex = typeof data.zIndex === 'number' ? `${data.zIndex}` : null;\n }\n\n if (changeSet.width)\n {\n el.style.width = typeof data.width === 'number' ? `${data.width}px` : data.width;\n }\n\n if (changeSet.height)\n {\n el.style.height = typeof data.height === 'number' ? `${data.height}px` : data.height;\n }\n\n if (changeSet.transformOrigin)\n {\n // When set to 'center' we can simply set the transform to null which is center by default.\n el.style.transformOrigin = data.transformOrigin === 'center' ? null : data.transformOrigin;\n }\n\n // Update all transforms in order added to transforms object.\n if (changeSet.transform)\n {\n el.style.transform = updateData.transforms.isActive ? updateData.transforms.getCSS() : null;\n }\n}\n\n/**\n * Decouples updates to any parent target HTMLElement inline styles. Invoke {@link Position.elementUpdated} to await\n * on the returned promise that is resolved with the current render time via `nextAnimationFrame` /\n * `requestAnimationFrame`. This allows the underlying data model to be updated immediately while updates to the\n * element are in sync with the browser and potentially in the future be further throttled.\n *\n * @param {HTMLElement} el - The target HTMLElement.\n *\n * @param {UpdateElementData} updateData - Update data.\n */\nfunction s_UPDATE_ELEMENT_ORTHO(el, updateData)\n{\n const changeSet = updateData.changeSet;\n const data = updateData.data;\n\n if (changeSet.zIndex)\n {\n el.style.zIndex = typeof data.zIndex === 'number' ? `${data.zIndex}` : null;\n }\n\n if (changeSet.width)\n {\n el.style.width = typeof data.width === 'number' ? `${data.width}px` : data.width;\n }\n\n if (changeSet.height)\n {\n el.style.height = typeof data.height === 'number' ? `${data.height}px` : data.height;\n }\n\n if (changeSet.transformOrigin)\n {\n // When set to 'center' we can simply set the transform to null which is center by default.\n el.style.transformOrigin = data.transformOrigin === 'center' ? null : data.transformOrigin;\n }\n\n // Update all transforms in order added to transforms object.\n if (changeSet.left || changeSet.top || changeSet.transform)\n {\n el.style.transform = updateData.transforms.getCSSOrtho(data);\n }\n}\n\n/**\n * Updates the applied transform data and sets the readble `transform` store.\n *\n * @param {HTMLElement} el - The target HTMLElement.\n *\n * @param {UpdateElementData} updateData - Update element data.\n */\nfunction s_UPDATE_TRANSFORM(el, updateData)\n{\n s_VALIDATION_DATA.height = updateData.data.height !== 'auto' ? updateData.data.height :\n updateData.styleCache.offsetHeight;\n\n s_VALIDATION_DATA.width = updateData.data.width !== 'auto' ? updateData.data.width :\n updateData.styleCache.offsetWidth;\n\n s_VALIDATION_DATA.marginLeft = updateData.styleCache.marginLeft;\n\n s_VALIDATION_DATA.marginTop = updateData.styleCache.marginTop;\n\n // Get transform data. First set constraints including any margin top / left as offsets and width / height. Used\n // when position width / height is 'auto'.\n updateData.transforms.getData(updateData.data, updateData.transformData, s_VALIDATION_DATA);\n\n updateData.storeTransform.set(updateData.transformData);\n}\n\nconst s_VALIDATION_DATA = {\n height: void 0,\n width: void 0,\n marginLeft: void 0,\n marginTop: void 0\n};\n","import {\n propertyStore,\n subscribeIgnoreFirst } from '@typhonjs-fvtt/runtime/svelte/store';\n\nimport {\n isIterable,\n isObject,\n isPlainObject } from '@typhonjs-fvtt/runtime/svelte/util';\n\nimport { AnimationAPI } from './animation/AnimationAPI.js';\nimport { AnimationGroupAPI } from './animation/AnimationGroupAPI.js';\nimport * as constants from './constants.js';\nimport { convertRelative } from './convertRelative.js';\nimport * as positionInitial from './initial/index.js';\nimport { PositionChangeSet } from './PositionChangeSet.js';\nimport { PositionData } from './PositionData.js';\nimport { PositionStateAPI } from './PositionStateAPI.js';\nimport { StyleCache } from './StyleCache.js';\nimport { TransformData } from './transform/TransformData.js';\nimport { AdapterValidators } from './validators/AdapterValidators.js';\nimport * as positionValidators from './validators/index.js';\nimport { Transforms } from './transform/Transforms.js';\nimport { UpdateElementData } from './update/UpdateElementData.js';\nimport { UpdateElementManager } from './update/UpdateElementManager.js';\n\n/**\n * Provides a store for position following the subscriber protocol in addition to providing individual writable derived\n * stores for each independent variable.\n */\nexport class Position\n{\n /**\n * @type {PositionData}\n */\n #data = new PositionData();\n\n /**\n * Provides the animation API.\n *\n * @type {AnimationAPI}\n */\n #animate = new AnimationAPI(this, this.#data);\n\n /**\n * Stores the style attributes that changed on update.\n *\n * @type {PositionChangeSet}\n */\n #positionChangeSet = new PositionChangeSet();\n\n /**\n * Stores ongoing options that are set in the constructor or by transform store subscription.\n *\n * @type {PositionOptions}\n */\n #options = {\n calculateTransform: false,\n initialHelper: void 0,\n ortho: true,\n transformSubscribed: false\n };\n\n /**\n * The associated parent for positional data tracking. Used in validators.\n *\n * @type {PositionParent}\n */\n #parent;\n\n /**\n * @type {StorePosition}\n */\n #stores;\n\n /**\n * Stores an instance of the computer styles for the target element.\n *\n * @type {StyleCache}\n */\n #styleCache;\n\n /**\n * Stores the subscribers.\n *\n * @type {(function(PositionData): void)[]}\n */\n #subscriptions = [];\n\n /**\n * @type {Transforms}\n */\n #transforms = new Transforms();\n\n /**\n * @type {UpdateElementData}\n */\n #updateElementData;\n\n /**\n * Stores the UpdateElementManager wait promise.\n *\n * @type {Promise}\n */\n #updateElementPromise;\n\n /**\n * @type {AdapterValidators}\n */\n #validators;\n\n /**\n * @type {ValidatorData[]}\n */\n #validatorData;\n\n /**\n * @type {PositionStateAPI}\n */\n #state = new PositionStateAPI(this, this.#data, this.#transforms);\n\n /**\n * @returns {AnimationGroupAPI} Public Animation API.\n */\n static get Animate() { return AnimationGroupAPI; }\n\n /**\n * @returns {{browserCentered?: Centered, Centered?: *}} Initial position helpers.\n */\n static get Initial() { return positionInitial; }\n\n /**\n * Returns TransformData class / constructor.\n *\n * @returns {TransformData} TransformData class / constructor.\n */\n static get TransformData() { return TransformData; }\n\n /**\n * Returns default validators.\n *\n * Note: `basicWindow` and `BasicBounds` will eventually be removed.\n *\n * @returns {{basicWindow?: BasicBounds, transformWindow?: TransformBounds, TransformBounds?: *, BasicBounds?: *}}\n * Available validators.\n */\n static get Validators() { return positionValidators; }\n\n /**\n * Returns a duplicate of a given position instance copying any options and validators.\n *\n * // TODO: Consider more safety over options processing.\n *\n * @param {Position} position - A position instance.\n *\n * @param {PositionOptions} options - Position options.\n *\n * @returns {Position} A duplicate position instance.\n */\n static duplicate(position, options)\n {\n if (!(position instanceof Position)) { throw new TypeError(`'position' is not an instance of Position.`); }\n\n const newPosition = new Position(options);\n\n newPosition.#options = Object.assign({}, position.#options, options);\n newPosition.#validators.add(...position.#validators);\n\n newPosition.set(position.#data);\n\n return newPosition;\n }\n\n /**\n * @param {PositionParent|PositionOptionsAll} [parent] - A potential parent element or object w/ `elementTarget`\n * getter. May also be the PositionOptions object w/ 1 argument.\n *\n * @param {PositionOptionsAll} [options] - Default values.\n */\n constructor(parent, options)\n {\n // Test if `parent` is a plain object; if so treat as options object.\n if (isPlainObject(parent))\n {\n options = parent;\n }\n else\n {\n this.#parent = parent;\n }\n\n const data = this.#data;\n const transforms = this.#transforms;\n\n this.#styleCache = new StyleCache();\n\n const updateData = new UpdateElementData();\n\n updateData.changeSet = this.#positionChangeSet;\n updateData.data = this.#data;\n updateData.options = this.#options;\n updateData.styleCache = this.#styleCache;\n updateData.subscriptions = this.#subscriptions;\n updateData.transforms = this.#transforms;\n\n this.#updateElementData = updateData;\n\n if (typeof options === 'object')\n {\n // Set Position options\n if (typeof options.calculateTransform === 'boolean')\n {\n this.#options.calculateTransform = options.calculateTransform;\n }\n\n if (typeof options.ortho === 'boolean')\n {\n this.#options.ortho = options.ortho;\n }\n\n // Set default values from options.\n\n if (Number.isFinite(options.height) || options.height === 'auto' || options.height === 'inherit' ||\n options.height === null)\n {\n data.height = updateData.dimensionData.height = typeof options.height === 'number' ?\n Math.round(options.height) : options.height;\n }\n\n if (Number.isFinite(options.left) || options.left === null)\n {\n data.left = typeof options.left === 'number' ? Math.round(options.left) : options.left;\n }\n\n if (Number.isFinite(options.maxHeight) || options.maxHeight === null)\n {\n data.maxHeight = typeof options.maxHeight === 'number' ? Math.round(options.maxHeight) : options.maxHeight;\n }\n\n if (Number.isFinite(options.maxWidth) || options.maxWidth === null)\n {\n data.maxWidth = typeof options.maxWidth === 'number' ? Math.round(options.maxWidth) : options.maxWidth;\n }\n\n if (Number.isFinite(options.minHeight) || options.minHeight === null)\n {\n data.minHeight = typeof options.minHeight === 'number' ? Math.round(options.minHeight) : options.minHeight;\n }\n\n if (Number.isFinite(options.minWidth) || options.minWidth === null)\n {\n data.minWidth = typeof options.minWidth === 'number' ? Math.round(options.minWidth) : options.minWidth;\n }\n\n if (Number.isFinite(options.rotateX) || options.rotateX === null)\n {\n transforms.rotateX = data.rotateX = options.rotateX;\n }\n\n if (Number.isFinite(options.rotateY) || options.rotateY === null)\n {\n transforms.rotateY = data.rotateY = options.rotateY;\n }\n\n if (Number.isFinite(options.rotateZ) || options.rotateZ === null)\n {\n transforms.rotateZ = data.rotateZ = options.rotateZ;\n }\n\n if (Number.isFinite(options.scale) || options.scale === null)\n {\n transforms.scale = data.scale = options.scale;\n }\n\n if (Number.isFinite(options.top) || options.top === null)\n {\n data.top = typeof options.top === 'number' ? Math.round(options.top) : options.top;\n }\n\n if (typeof options.transformOrigin === 'string' || options.transformOrigin === null)\n {\n data.transformOrigin = constants.transformOrigins.includes(options.transformOrigin) ?\n options.transformOrigin : null;\n }\n\n if (Number.isFinite(options.translateX) || options.translateX === null)\n {\n transforms.translateX = data.translateX = options.translateX;\n }\n\n if (Number.isFinite(options.translateY) || options.translateY === null)\n {\n transforms.translateY = data.translateY = options.translateY;\n }\n\n if (Number.isFinite(options.translateZ) || options.translateZ === null)\n {\n transforms.translateZ = data.translateZ = options.translateZ;\n }\n\n if (Number.isFinite(options.width) || options.width === 'auto' || options.width === 'inherit' ||\n options.width === null)\n {\n data.width = updateData.dimensionData.width = typeof options.width === 'number' ?\n Math.round(options.width) : options.width;\n }\n\n if (Number.isFinite(options.zIndex) || options.zIndex === null)\n {\n data.zIndex = typeof options.zIndex === 'number' ? Math.round(options.zIndex) : options.zIndex;\n }\n }\n\n this.#stores = {\n // The main properties for manipulating Position.\n height: propertyStore(this, 'height'),\n left: propertyStore(this, 'left'),\n rotateX: propertyStore(this, 'rotateX'),\n rotateY: propertyStore(this, 'rotateY'),\n rotateZ: propertyStore(this, 'rotateZ'),\n scale: propertyStore(this, 'scale'),\n top: propertyStore(this, 'top'),\n transformOrigin: propertyStore(this, 'transformOrigin'),\n translateX: propertyStore(this, 'translateX'),\n translateY: propertyStore(this, 'translateY'),\n translateZ: propertyStore(this, 'translateZ'),\n width: propertyStore(this, 'width'),\n zIndex: propertyStore(this, 'zIndex'),\n\n // Stores that control validation when width / height is not `auto`.\n maxHeight: propertyStore(this, 'maxHeight'),\n maxWidth: propertyStore(this, 'maxWidth'),\n minHeight: propertyStore(this, 'minHeight'),\n minWidth: propertyStore(this, 'minWidth'),\n\n // Readable stores based on updates or from resize observer changes.\n dimension: { subscribe: updateData.storeDimension.subscribe },\n element: { subscribe: this.#styleCache.stores.element.subscribe },\n resizeContentHeight: { subscribe: this.#styleCache.stores.resizeContentHeight.subscribe },\n resizeContentWidth: { subscribe: this.#styleCache.stores.resizeContentWidth.subscribe },\n resizeOffsetHeight: { subscribe: this.#styleCache.stores.resizeOffsetHeight.subscribe },\n resizeOffsetWidth: { subscribe: this.#styleCache.stores.resizeOffsetWidth.subscribe },\n transform: { subscribe: updateData.storeTransform.subscribe },\n\n // Protected store that should only be set by resizeObserver action.\n resizeObserved: this.#styleCache.stores.resizeObserved,\n };\n\n // When resize change from any applied resizeObserver action automatically set data for new validation run.\n // A resizeObserver prop should be set to true for ApplicationShell components or usage of resizeObserver action\n // to monitor for changes. This should only be used on elements that have 'auto' for width or height.\n subscribeIgnoreFirst(this.#stores.resizeObserved, (resizeData) =>\n {\n const parent = this.#parent;\n const el = parent instanceof HTMLElement ? parent : parent?.elementTarget;\n\n // Only invoke set if there is a target element and the resize data has a valid offset width & height.\n if (el instanceof HTMLElement && Number.isFinite(resizeData?.offsetWidth) &&\n Number.isFinite(resizeData?.offsetHeight))\n {\n this.set(data);\n }\n });\n\n this.#stores.transformOrigin.values = constants.transformOrigins;\n\n [this.#validators, this.#validatorData] = new AdapterValidators();\n\n if (options?.initial || options?.positionInitial)\n {\n const initialHelper = options.initial ?? options.positionInitial;\n\n if (typeof initialHelper?.getLeft !== 'function' || typeof initialHelper?.getTop !== 'function')\n {\n throw new Error(\n `'options.initial' position helper does not contain 'getLeft' and / or 'getTop' functions.`);\n }\n\n this.#options.initialHelper = options.initial;\n }\n\n if (options?.validator)\n {\n if (isIterable(options?.validator)) { this.validators.add(...options.validator); }\n else { this.validators.add(options.validator); }\n }\n }\n\n /**\n * Returns the animation API.\n *\n * @returns {AnimationAPI} Animation API.\n */\n get animate()\n {\n return this.#animate;\n }\n\n /**\n * Returns the dimension data for the readable store.\n *\n * @returns {{width: number | 'auto', height: number | 'auto'}} Dimension data.\n */\n get dimension()\n {\n return this.#updateElementData.dimensionData;\n }\n\n /**\n * Returns the current HTMLElement being positioned.\n *\n * @returns {HTMLElement|undefined} Current HTMLElement being positioned.\n */\n get element()\n {\n return this.#styleCache.el;\n }\n\n /**\n * Returns a promise that is resolved on the next element update with the time of the update.\n *\n * @returns {Promise} Promise resolved on element update.\n */\n get elementUpdated()\n {\n return this.#updateElementPromise;\n }\n\n /**\n * Returns the associated {@link PositionParent} instance.\n *\n * @returns {PositionParent} The PositionParent instance.\n */\n get parent() { return this.#parent; }\n\n /**\n * Returns the state API.\n *\n * @returns {PositionStateAPI} Position state API.\n */\n get state() { return this.#state; }\n\n /**\n * Returns the derived writable stores for individual data variables.\n *\n * @returns {StorePosition} Derived / writable stores.\n */\n get stores() { return this.#stores; }\n\n /**\n * Returns the transform data for the readable store.\n *\n * @returns {TransformData} Transform Data.\n */\n get transform()\n {\n return this.#updateElementData.transformData;\n }\n\n /**\n * Returns the validators.\n *\n * @returns {AdapterValidators} validators.\n */\n get validators() { return this.#validators; }\n\n /**\n * Sets the associated {@link PositionParent} instance. Resets the style cache and default data.\n *\n * @param {PositionParent|void} parent - A PositionParent instance.\n */\n set parent(parent)\n {\n if (parent !== void 0 && !(parent instanceof HTMLElement) && !isObject(parent))\n {\n throw new TypeError(`'parent' is not an HTMLElement, object, or undefined.`);\n }\n\n this.#parent = parent;\n\n // Reset any stored default data & the style cache.\n this.#state.remove({ name: '#defaultData' });\n this.#styleCache.reset();\n\n // If a parent is defined then invoke set to update any parent element.\n if (parent) { this.set(this.#data); }\n }\n\n// Data accessors ----------------------------------------------------------------------------------------------------\n\n /**\n * @returns {number|'auto'|'inherit'|null} height\n */\n get height() { return this.#data.height; }\n\n /**\n * @returns {number|null} left\n */\n get left() { return this.#data.left; }\n\n /**\n * @returns {number|null} maxHeight\n */\n get maxHeight() { return this.#data.maxHeight; }\n\n /**\n * @returns {number|null} maxWidth\n */\n get maxWidth() { return this.#data.maxWidth; }\n\n /**\n * @returns {number|null} minHeight\n */\n get minHeight() { return this.#data.minHeight; }\n\n /**\n * @returns {number|null} minWidth\n */\n get minWidth() { return this.#data.minWidth; }\n\n /**\n * @returns {number|null} rotateX\n */\n get rotateX() { return this.#data.rotateX; }\n\n /**\n * @returns {number|null} rotateY\n */\n get rotateY() { return this.#data.rotateY; }\n\n /**\n * @returns {number|null} rotateZ\n */\n get rotateZ() { return this.#data.rotateZ; }\n\n /**\n * @returns {number|null} alias for rotateZ\n */\n get rotation() { return this.#data.rotateZ; }\n\n /**\n * @returns {number|null} scale\n */\n get scale() { return this.#data.scale; }\n\n /**\n * @returns {number|null} top\n */\n get top() { return this.#data.top; }\n\n /**\n * @returns {string} transformOrigin\n */\n get transformOrigin() { return this.#data.transformOrigin; }\n\n /**\n * @returns {number|null} translateX\n */\n get translateX() { return this.#data.translateX; }\n\n /**\n * @returns {number|null} translateY\n */\n get translateY() { return this.#data.translateY; }\n\n /**\n * @returns {number|null} translateZ\n */\n get translateZ() { return this.#data.translateZ; }\n\n /**\n * @returns {number|'auto'|'inherit'|null} width\n */\n get width() { return this.#data.width; }\n\n /**\n * @returns {number|null} z-index\n */\n get zIndex() { return this.#data.zIndex; }\n\n /**\n * @param {number|string|null} height -\n */\n set height(height)\n {\n this.#stores.height.set(height);\n }\n\n /**\n * @param {number|string|null} left -\n */\n set left(left)\n {\n this.#stores.left.set(left);\n }\n\n /**\n * @param {number|string|null} maxHeight -\n */\n set maxHeight(maxHeight)\n {\n this.#stores.maxHeight.set(maxHeight);\n }\n\n /**\n * @param {number|string|null} maxWidth -\n */\n set maxWidth(maxWidth)\n {\n this.#stores.maxWidth.set(maxWidth);\n }\n\n /**\n * @param {number|string|null} minHeight -\n */\n set minHeight(minHeight)\n {\n this.#stores.minHeight.set(minHeight);\n }\n\n /**\n * @param {number|string|null} minWidth -\n */\n set minWidth(minWidth)\n {\n this.#stores.minWidth.set(minWidth);\n }\n\n /**\n * @param {number|string|null} rotateX -\n */\n set rotateX(rotateX)\n {\n this.#stores.rotateX.set(rotateX);\n }\n\n /**\n * @param {number|string|null} rotateY -\n */\n set rotateY(rotateY)\n {\n this.#stores.rotateY.set(rotateY);\n }\n\n /**\n * @param {number|string|null} rotateZ -\n */\n set rotateZ(rotateZ)\n {\n this.#stores.rotateZ.set(rotateZ);\n }\n\n /**\n * @param {number|string|null} rotateZ - alias for rotateZ\n */\n set rotation(rotateZ)\n {\n this.#stores.rotateZ.set(rotateZ);\n }\n\n /**\n * @param {number|string|null} scale -\n */\n set scale(scale)\n {\n this.#stores.scale.set(scale);\n }\n\n /**\n * @param {number|string|null} top -\n */\n set top(top)\n {\n this.#stores.top.set(top);\n }\n\n /**\n * @param {string} transformOrigin -\n */\n set transformOrigin(transformOrigin)\n {\n if (constants.transformOrigins.includes(transformOrigin)) { this.#stores.transformOrigin.set(transformOrigin); }\n }\n\n /**\n * @param {number|string|null} translateX -\n */\n set translateX(translateX)\n {\n this.#stores.translateX.set(translateX);\n }\n\n /**\n * @param {number|string|null} translateY -\n */\n set translateY(translateY)\n {\n this.#stores.translateY.set(translateY);\n }\n\n /**\n * @param {number|string|null} translateZ -\n */\n set translateZ(translateZ)\n {\n this.#stores.translateZ.set(translateZ);\n }\n\n /**\n * @param {number|string|null} width -\n */\n set width(width)\n {\n this.#stores.width.set(width);\n }\n\n /**\n * @param {number|string|null} zIndex -\n */\n set zIndex(zIndex)\n {\n this.#stores.zIndex.set(zIndex);\n }\n\n /**\n * Assigns current position to object passed into method.\n *\n * @param {object|PositionData} [position] - Target to assign current position data.\n *\n * @param {PositionGetOptions} [options] - Defines options for specific keys and substituting null for numeric\n * default values.\n *\n * @returns {PositionData} Passed in object with current position data.\n */\n get(position = {}, options)\n {\n const keys = options?.keys;\n const excludeKeys = options?.exclude;\n const numeric = options?.numeric ?? false;\n\n if (isIterable(keys))\n {\n // Replace any null values potentially with numeric default values.\n if (numeric)\n {\n for (const key of keys) { position[key] = this[key] ?? constants.numericDefaults[key]; }\n }\n else // Accept current values.\n {\n for (const key of keys) { position[key] = this[key]; }\n }\n\n // Remove any excluded keys.\n if (isIterable(excludeKeys))\n {\n for (const key of excludeKeys) { delete position[key]; }\n }\n\n return position;\n }\n else\n {\n const data = Object.assign(position, this.#data);\n\n // Remove any excluded keys.\n if (isIterable(excludeKeys))\n {\n for (const key of excludeKeys) { delete data[key]; }\n }\n\n // Potentially set numeric defaults.\n if (numeric) { constants.setNumericDefaults(data); }\n\n return data;\n }\n }\n\n /**\n * @returns {PositionData} Current position data.\n */\n toJSON()\n {\n return Object.assign({}, this.#data);\n }\n\n /**\n * All calculation and updates of position are implemented in {@link Position}. This allows position to be fully\n * reactive and in control of updating inline styles for the application.\n *\n * Note: the logic for updating position is improved and changes a few aspects from the default\n * {@link Application.setPosition}. The gate on `popOut` is removed, so to ensure no positional application occurs\n * popOut applications can set `this.options.positionable` to false ensuring no positional inline styles are\n * applied.\n *\n * The initial set call on an application with a target element will always set width / height as this is\n * necessary for correct calculations.\n *\n * When a target element is present updated styles are applied after validation. To modify the behavior of set\n * implement one or more validator functions and add them from the application via\n * `this.position.validators.add()`.\n *\n * Updates to any target element are decoupled from the underlying Position data. This method returns this instance\n * that you can then await on the target element inline style update by using {@link Position.elementUpdated}.\n *\n * @param {PositionDataExtended} [position] - Position data to set.\n *\n * @returns {Position} This Position instance.\n */\n set(position = {})\n {\n if (typeof position !== 'object') { throw new TypeError(`Position - set error: 'position' is not an object.`); }\n\n const parent = this.#parent;\n\n // An early out to prevent `set` from taking effect if options `positionable` is false.\n if (parent !== void 0 && typeof parent?.options?.positionable === 'boolean' && !parent?.options?.positionable)\n {\n return this;\n }\n\n // Callers can specify to immediately update an associated element. This is useful if set is called from\n // requestAnimationFrame / rAF. Library integrations like GSAP invoke set from rAF.\n const immediateElementUpdate = position.immediateElementUpdate === true;\n\n const data = this.#data;\n const transforms = this.#transforms;\n\n // Find the target HTML element and verify that it is connected storing it in `el`.\n const targetEl = parent instanceof HTMLElement ? parent : parent?.elementTarget;\n const el = targetEl instanceof HTMLElement && targetEl.isConnected ? targetEl : void 0;\n\n const changeSet = this.#positionChangeSet;\n const styleCache = this.#styleCache;\n\n if (el)\n {\n // Cache the computed styles of the element.\n if (!styleCache.hasData(el))\n {\n styleCache.update(el);\n\n // Add will-change property if not already set in inline or computed styles.\n if (!styleCache.hasWillChange)\n {\n el.style.willChange = this.#options.ortho ? 'transform' : 'top, left, transform';\n }\n\n // Update all properties / clear queued state.\n changeSet.set(true);\n this.#updateElementData.queued = false;\n }\n\n // Converts any relative string position data to numeric inputs.\n convertRelative(position, this);\n\n position = this.#updatePosition(position, parent, el, styleCache);\n\n // Check if a validator cancelled the update.\n if (position === null) { return this; }\n }\n\n if (Number.isFinite(position.left))\n {\n position.left = Math.round(position.left);\n\n if (data.left !== position.left) { data.left = position.left; changeSet.left = true; }\n }\n\n if (Number.isFinite(position.top))\n {\n position.top = Math.round(position.top);\n\n if (data.top !== position.top) { data.top = position.top; changeSet.top = true; }\n }\n\n if (Number.isFinite(position.maxHeight) || position.maxHeight === null)\n {\n position.maxHeight = typeof position.maxHeight === 'number' ? Math.round(position.maxHeight) : null;\n\n if (data.maxHeight !== position.maxHeight) { data.maxHeight = position.maxHeight; changeSet.maxHeight = true; }\n }\n\n if (Number.isFinite(position.maxWidth) || position.maxWidth === null)\n {\n position.maxWidth = typeof position.maxWidth === 'number' ? Math.round(position.maxWidth) : null;\n\n if (data.maxWidth !== position.maxWidth) { data.maxWidth = position.maxWidth; changeSet.maxWidth = true; }\n }\n\n if (Number.isFinite(position.minHeight) || position.minHeight === null)\n {\n position.minHeight = typeof position.minHeight === 'number' ? Math.round(position.minHeight) : null;\n\n if (data.minHeight !== position.minHeight) { data.minHeight = position.minHeight; changeSet.minHeight = true; }\n }\n\n if (Number.isFinite(position.minWidth) || position.minWidth === null)\n {\n position.minWidth = typeof position.minWidth === 'number' ? Math.round(position.minWidth) : null;\n\n if (data.minWidth !== position.minWidth) { data.minWidth = position.minWidth; changeSet.minWidth = true; }\n }\n\n if (Number.isFinite(position.rotateX) || position.rotateX === null)\n {\n if (data.rotateX !== position.rotateX)\n {\n data.rotateX = transforms.rotateX = position.rotateX;\n changeSet.transform = true;\n }\n }\n\n if (Number.isFinite(position.rotateY) || position.rotateY === null)\n {\n if (data.rotateY !== position.rotateY)\n {\n data.rotateY = transforms.rotateY = position.rotateY;\n changeSet.transform = true;\n }\n }\n\n if (Number.isFinite(position.rotateZ) || position.rotateZ === null)\n {\n if (data.rotateZ !== position.rotateZ)\n {\n data.rotateZ = transforms.rotateZ = position.rotateZ;\n changeSet.transform = true;\n }\n }\n\n if (Number.isFinite(position.scale) || position.scale === null)\n {\n position.scale = typeof position.scale === 'number' ? Math.max(0, Math.min(position.scale, 1000)) : null;\n\n if (data.scale !== position.scale)\n {\n data.scale = transforms.scale = position.scale;\n changeSet.transform = true;\n }\n }\n\n if ((typeof position.transformOrigin === 'string' && constants.transformOrigins.includes(\n position.transformOrigin)) || position.transformOrigin === null)\n {\n if (data.transformOrigin !== position.transformOrigin)\n {\n data.transformOrigin = position.transformOrigin;\n changeSet.transformOrigin = true;\n }\n }\n\n if (Number.isFinite(position.translateX) || position.translateX === null)\n {\n if (data.translateX !== position.translateX)\n {\n data.translateX = transforms.translateX = position.translateX;\n changeSet.transform = true;\n }\n }\n\n if (Number.isFinite(position.translateY) || position.translateY === null)\n {\n if (data.translateY !== position.translateY)\n {\n data.translateY = transforms.translateY = position.translateY;\n changeSet.transform = true;\n }\n }\n\n if (Number.isFinite(position.translateZ) || position.translateZ === null)\n {\n if (data.translateZ !== position.translateZ)\n {\n data.translateZ = transforms.translateZ = position.translateZ;\n changeSet.transform = true;\n }\n }\n\n if (Number.isFinite(position.zIndex))\n {\n position.zIndex = Math.round(position.zIndex);\n\n if (data.zIndex !== position.zIndex) { data.zIndex = position.zIndex; changeSet.zIndex = true; }\n }\n\n if (Number.isFinite(position.width) || position.width === 'auto' || position.width === 'inherit' ||\n position.width === null)\n {\n position.width = typeof position.width === 'number' ? Math.round(position.width) : position.width;\n\n if (data.width !== position.width) { data.width = position.width; changeSet.width = true; }\n }\n\n if (Number.isFinite(position.height) || position.height === 'auto' || position.height === 'inherit' ||\n position.height === null)\n {\n position.height = typeof position.height === 'number' ? Math.round(position.height) : position.height;\n\n if (data.height !== position.height) { data.height = position.height; changeSet.height = true; }\n }\n\n if (el)\n {\n const defaultData = this.#state.getDefault();\n\n // Set default data after first set operation that has a target element.\n if (typeof defaultData !== 'object')\n {\n this.#state.save({ name: '#defaultData', ...Object.assign({}, data) });\n }\n\n // If `immediateElementUpdate` is true in position data passed to `set` then update the element immediately.\n // This is for rAF based library integrations like GSAP.\n if (immediateElementUpdate)\n {\n UpdateElementManager.immediate(el, this.#updateElementData);\n this.#updateElementPromise = Promise.resolve(performance.now());\n }\n // Else if not queued then queue an update for the next rAF callback.\n else if (!this.#updateElementData.queued)\n {\n this.#updateElementPromise = UpdateElementManager.add(el, this.#updateElementData);\n }\n }\n else\n {\n // Notify main store subscribers.\n UpdateElementManager.updateSubscribers(this.#updateElementData);\n }\n\n return this;\n }\n\n /**\n *\n * @param {function(PositionData): void} handler - Callback function that is invoked on update / changes. Receives\n * a copy of the PositionData.\n *\n * @returns {(function(): void)} Unsubscribe function.\n */\n subscribe(handler)\n {\n this.#subscriptions.push(handler); // add handler to the array of subscribers\n\n handler(Object.assign({}, this.#data)); // call handler with current value\n\n // Return unsubscribe function.\n return () =>\n {\n const index = this.#subscriptions.findIndex((sub) => sub === handler);\n if (index >= 0) { this.#subscriptions.splice(index, 1); }\n };\n }\n\n /**\n * @param {PositionDataExtended} opts -\n *\n * @param {number|null} opts.left -\n *\n * @param {number|null} opts.top -\n *\n * @param {number|null} opts.maxHeight -\n *\n * @param {number|null} opts.maxWidth -\n *\n * @param {number|null} opts.minHeight -\n *\n * @param {number|null} opts.minWidth -\n *\n * @param {number|'auto'|null} opts.width -\n *\n * @param {number|'auto'|null} opts.height -\n *\n * @param {number|null} opts.rotateX -\n *\n * @param {number|null} opts.rotateY -\n *\n * @param {number|null} opts.rotateZ -\n *\n * @param {number|null} opts.scale -\n *\n * @param {string} opts.transformOrigin -\n *\n * @param {number|null} opts.translateX -\n *\n * @param {number|null} opts.translateY -\n *\n * @param {number|null} opts.translateZ -\n *\n * @param {number|null} opts.zIndex -\n *\n * @param {number|null} opts.rotation - alias for rotateZ\n *\n * @param {*} opts.rest -\n *\n * @param {object} parent -\n *\n * @param {HTMLElement} el -\n *\n * @param {StyleCache} styleCache -\n *\n * @returns {null|PositionData} Updated position data or null if validation fails.\n */\n #updatePosition({\n // Directly supported parameters\n left, top, maxWidth, maxHeight, minWidth, minHeight, width, height, rotateX, rotateY, rotateZ, scale,\n transformOrigin, translateX, translateY, translateZ, zIndex,\n\n // Aliased parameters\n rotation,\n\n ...rest\n } = {}, parent, el, styleCache)\n {\n let currentPosition = s_DATA_UPDATE.copy(this.#data);\n\n // Update width if an explicit value is passed, or if no width value is set on the element.\n if (el.style.width === '' || width !== void 0)\n {\n if (width === 'auto' || (currentPosition.width === 'auto' && width !== null))\n {\n currentPosition.width = 'auto';\n width = styleCache.offsetWidth;\n }\n else if (width === 'inherit' || (currentPosition.width === 'inherit' && width !== null))\n {\n currentPosition.width = 'inherit';\n width = styleCache.offsetWidth;\n }\n else\n {\n const newWidth = Number.isFinite(width) ? width : currentPosition.width;\n currentPosition.width = width = Number.isFinite(newWidth) ? Math.round(newWidth) : styleCache.offsetWidth;\n }\n }\n else\n {\n width = Number.isFinite(currentPosition.width) ? currentPosition.width : styleCache.offsetWidth;\n }\n\n // Update height if an explicit value is passed, or if no height value is set on the element.\n if (el.style.height === '' || height !== void 0)\n {\n if (height === 'auto' || (currentPosition.height === 'auto' && height !== null))\n {\n currentPosition.height = 'auto';\n height = styleCache.offsetHeight;\n }\n else if (height === 'inherit' || (currentPosition.height === 'inherit' && height !== null))\n {\n currentPosition.height = 'inherit';\n height = styleCache.offsetHeight;\n }\n else\n {\n const newHeight = Number.isFinite(height) ? height : currentPosition.height;\n currentPosition.height = height = Number.isFinite(newHeight) ? Math.round(newHeight) :\n styleCache.offsetHeight;\n }\n }\n else\n {\n height = Number.isFinite(currentPosition.height) ? currentPosition.height : styleCache.offsetHeight;\n }\n\n // Update left\n if (Number.isFinite(left))\n {\n currentPosition.left = left;\n }\n else if (!Number.isFinite(currentPosition.left))\n {\n // Potentially use any initial position helper if available or set to 0.\n currentPosition.left = typeof this.#options.initialHelper?.getLeft === 'function' ?\n this.#options.initialHelper.getLeft(width) : 0;\n }\n\n // Update top\n if (Number.isFinite(top))\n {\n currentPosition.top = top;\n }\n else if (!Number.isFinite(currentPosition.top))\n {\n // Potentially use any initial position helper if available or set to 0.\n currentPosition.top = typeof this.#options.initialHelper?.getTop === 'function' ?\n this.#options.initialHelper.getTop(height) : 0;\n }\n\n if (Number.isFinite(maxHeight) || maxHeight === null)\n {\n currentPosition.maxHeight = Number.isFinite(maxHeight) ? Math.round(maxHeight) : null;\n }\n\n if (Number.isFinite(maxWidth) || maxWidth === null)\n {\n currentPosition.maxWidth = Number.isFinite(maxWidth) ? Math.round(maxWidth) : null;\n }\n\n if (Number.isFinite(minHeight) || minHeight === null)\n {\n currentPosition.minHeight = Number.isFinite(minHeight) ? Math.round(minHeight) : null;\n }\n\n if (Number.isFinite(minWidth) || minWidth === null)\n {\n currentPosition.minWidth = Number.isFinite(minWidth) ? Math.round(minWidth) : null;\n }\n\n // Update rotate X/Y/Z, scale, z-index\n if (Number.isFinite(rotateX) || rotateX === null) { currentPosition.rotateX = rotateX; }\n if (Number.isFinite(rotateY) || rotateY === null) { currentPosition.rotateY = rotateY; }\n\n // Handle alias for rotateZ. First check if `rotateZ` is valid and different from the current value. Next check if\n // `rotation` is valid and use it for `rotateZ`.\n if (rotateZ !== currentPosition.rotateZ && (Number.isFinite(rotateZ) || rotateZ === null))\n {\n currentPosition.rotateZ = rotateZ;\n }\n else if (rotation !== currentPosition.rotateZ && (Number.isFinite(rotation) || rotation === null))\n {\n currentPosition.rotateZ = rotation;\n }\n\n if (Number.isFinite(translateX) || translateX === null) { currentPosition.translateX = translateX; }\n if (Number.isFinite(translateY) || translateY === null) { currentPosition.translateY = translateY; }\n if (Number.isFinite(translateZ) || translateZ === null) { currentPosition.translateZ = translateZ; }\n\n if (Number.isFinite(scale) || scale === null)\n {\n currentPosition.scale = typeof scale === 'number' ? Math.max(0, Math.min(scale, 1000)) : null;\n }\n\n if (typeof transformOrigin === 'string' || transformOrigin === null)\n {\n currentPosition.transformOrigin = constants.transformOrigins.includes(transformOrigin) ? transformOrigin :\n null;\n }\n\n if (Number.isFinite(zIndex) || zIndex === null)\n {\n currentPosition.zIndex = typeof zIndex === 'number' ? Math.round(zIndex) : zIndex;\n }\n\n const validatorData = this.#validatorData;\n\n // If there are any validators allow them to potentially modify position data or reject the update.\n if (validatorData.length)\n {\n s_VALIDATION_DATA.parent = parent;\n\n s_VALIDATION_DATA.el = el;\n\n s_VALIDATION_DATA.computed = styleCache.computed;\n\n s_VALIDATION_DATA.transforms = this.#transforms;\n\n s_VALIDATION_DATA.height = height;\n\n s_VALIDATION_DATA.width = width;\n\n s_VALIDATION_DATA.marginLeft = styleCache.marginLeft;\n\n s_VALIDATION_DATA.marginTop = styleCache.marginTop;\n\n s_VALIDATION_DATA.maxHeight = styleCache.maxHeight ?? currentPosition.maxHeight;\n\n s_VALIDATION_DATA.maxWidth = styleCache.maxWidth ?? currentPosition.maxWidth;\n\n // Given a parent w/ reactive state and is minimized ignore styleCache min-width/height.\n const isMinimized = parent?.reactive?.minimized ?? false;\n\n // Note the use of || for accessing the style cache as the left hand is ignored w/ falsy values such as '0'.\n s_VALIDATION_DATA.minHeight = isMinimized ? currentPosition.minHeight ?? 0 :\n styleCache.minHeight || (currentPosition.minHeight ?? 0);\n\n s_VALIDATION_DATA.minWidth = isMinimized ? currentPosition.minWidth ?? 0 :\n styleCache.minWidth || (currentPosition.minWidth ?? 0);\n\n for (let cntr = 0; cntr < validatorData.length; cntr++)\n {\n s_VALIDATION_DATA.position = currentPosition;\n s_VALIDATION_DATA.rest = rest;\n currentPosition = validatorData[cntr].validator(s_VALIDATION_DATA);\n\n if (currentPosition === null) { return null; }\n }\n }\n\n // Return the updated position object.\n return currentPosition;\n }\n}\n\nconst s_DATA_UPDATE = new PositionData();\n\n/**\n * @type {ValidationData}\n */\nconst s_VALIDATION_DATA = {\n position: void 0,\n parent: void 0,\n el: void 0,\n computed: void 0,\n transforms: void 0,\n height: void 0,\n width: void 0,\n marginLeft: void 0,\n marginTop: void 0,\n maxHeight: void 0,\n maxWidth: void 0,\n minHeight: void 0,\n minWidth: void 0,\n rest: void 0\n};\n\nObject.seal(s_VALIDATION_DATA);\n\n/**\n * @typedef {object} InitialHelper\n *\n * @property {Function} getLeft - A function that takes the width parameter and returns the left position.\n *\n * @property {Function} getTop - A function that takes the height parameter and returns the top position.\n */\n\n/**\n * @typedef {object} PositionDataExtended\n *\n * @property {number|string|null} [height] -\n *\n * @property {number|string|null} [left] -\n *\n * @property {number|string|null} [maxHeight] -\n *\n * @property {number|string|null} [maxWidth] -\n *\n * @property {number|string|null} [minHeight] -\n *\n * @property {number|string|null} [minWidth] -\n *\n * @property {number|string|null} [rotateX] -\n *\n * @property {number|string|null} [rotateY] -\n *\n * @property {number|string|null} [rotateZ] -\n *\n * @property {number|string|null} [scale] -\n *\n * @property {number|string|null} [top] -\n *\n * @property {string|null} [transformOrigin] -\n *\n * @property {number|string|null} [translateX] -\n *\n * @property {number|string|null} [translateY] -\n *\n * @property {number|string|null} [translateZ] -\n *\n * @property {number|string|null} [width] -\n *\n * @property {number|string|null} [zIndex] -\n *\n * Extended properties -----------------------------------------------------------------------------------------------\n *\n * @property {boolean} [immediateElementUpdate] - When true any associated element is updated immediately.\n *\n * @property {number|null} [rotation] - Alias for `rotateZ`.\n */\n\n/**\n * @typedef {object} PositionGetOptions\n *\n * @property {Iterable} keys - When provided only these keys are copied.\n *\n * @property {Iterable} exclude - When provided these keys are excluded.\n *\n * @property {boolean} numeric - When true any `null` values are converted into defaults.\n */\n\n/**\n * @typedef {object} PositionOptions - Options set in constructor.\n *\n * @property {boolean} calculateTransform - When true always calculate transform data.\n *\n * @property {InitialHelper} initialHelper - Provides a helper for setting initial position data.\n *\n * @property {boolean} ortho - Sets Position to orthographic mode using just transform / matrix3d for positioning.\n *\n * @property {boolean} transformSubscribed - Set to true when there are subscribers to the readable transform store.\n */\n\n/**\n * @typedef {PositionOptions & PositionData} PositionOptionsAll\n */\n\n/**\n * @typedef {HTMLElement | object} PositionParent\n *\n * @property {Function} [elementTarget] - Potentially returns any parent object.\n */\n\n/**\n * @typedef {object} ResizeObserverData\n *\n * @property {number|undefined} contentHeight -\n *\n * @property {number|undefined} contentWidth -\n *\n * @property {number|undefined} offsetHeight -\n *\n * @property {number|undefined} offsetWidth -\n */\n\n/**\n * @typedef {object} StorePosition - Provides individual writable stores for {@link Position}.\n *\n * @property {import('svelte/store').Readable<{width: number, height: number}>} dimension - Readable store for dimension\n * data.\n *\n * @property {import('svelte/store').Readable} element - Readable store for current element.\n *\n * @property {import('svelte/store').Writable} left - Derived store for `left` updates.\n *\n * @property {import('svelte/store').Writable} top - Derived store for `top` updates.\n *\n * @property {import('svelte/store').Writable} width - Derived store for `width` updates.\n *\n * @property {import('svelte/store').Writable} height - Derived store for `height` updates.\n *\n * @property {import('svelte/store').Writable} maxHeight - Derived store for `maxHeight` updates.\n *\n * @property {import('svelte/store').Writable} maxWidth - Derived store for `maxWidth` updates.\n *\n * @property {import('svelte/store').Writable} minHeight - Derived store for `minHeight` updates.\n *\n * @property {import('svelte/store').Writable} minWidth - Derived store for `minWidth` updates.\n *\n * @property {import('svelte/store').Readable} resizeContentHeight - Readable store for `contentHeight`.\n *\n * @property {import('svelte/store').Readable} resizeContentWidth - Readable store for `contentWidth`.\n *\n * @property {import('svelte/store').Writable} resizeObserved - Protected store for resize observer updates.\n *\n * @property {import('svelte/store').Readable} resizeOffsetHeight - Readable store for `offsetHeight`.\n *\n * @property {import('svelte/store').Readable} resizeOffsetWidth - Readable store for `offsetWidth`.\n *\n * @property {import('svelte/store').Writable} rotate - Derived store for `rotate` updates.\n *\n * @property {import('svelte/store').Writable} rotateX - Derived store for `rotateX` updates.\n *\n * @property {import('svelte/store').Writable} rotateY - Derived store for `rotateY` updates.\n *\n * @property {import('svelte/store').Writable} rotateZ - Derived store for `rotateZ` updates.\n *\n * @property {import('svelte/store').Writable} scale - Derived store for `scale` updates.\n *\n * @property {import('svelte/store').Readable} transform - Readable store for transform data.\n *\n * @property {import('svelte/store').Writable} transformOrigin - Derived store for `transformOrigin`.\n *\n * @property {import('svelte/store').Writable} translateX - Derived store for `translateX` updates.\n *\n * @property {import('svelte/store').Writable} translateY - Derived store for `translateY` updates.\n *\n * @property {import('svelte/store').Writable} translateZ - Derived store for `translateZ` updates.\n *\n * @property {import('svelte/store').Writable} zIndex - Derived store for `zIndex` updates.\n */\n\n/**\n * @typedef {object} ValidationData\n *\n * @property {PositionData} position -\n *\n * @property {PositionParent} parent -\n *\n * @property {HTMLElement} el -\n *\n * @property {CSSStyleDeclaration} computed -\n *\n * @property {Transforms} transforms -\n *\n * @property {number} height -\n *\n * @property {number} width -\n *\n * @property {number|undefined} marginLeft -\n *\n * @property {number|undefined} marginTop -\n *\n * @property {number|undefined} maxHeight -\n *\n * @property {number|undefined} maxWidth -\n *\n * @property {number|undefined} minHeight -\n *\n * @property {number|undefined} minWidth -\n *\n * @property {object} rest - The rest of any data submitted to {@link Position.set}\n */\n","import { linear } from \"svelte/easing\";\nimport { lerp } from '@typhonjs-fvtt/runtime/svelte/math';\nimport { isObject } from '@typhonjs-fvtt/runtime/svelte/util';\n\nexport class ApplicationState\n{\n /** @type {ApplicationShellExt} */\n #application;\n\n /** @type {Map} */\n #dataSaved = new Map();\n\n /**\n * @param {ApplicationShellExt} application - The application.\n */\n constructor(application)\n {\n this.#application = application;\n }\n\n /**\n * Returns current application state along with any extra data passed into method.\n *\n * @param {object} [extra] - Extra data to add to application state.\n *\n * @returns {ApplicationData} Passed in object with current application state.\n */\n get(extra = {})\n {\n return Object.assign(extra, {\n position: this.#application?.position?.get(),\n beforeMinimized: this.#application?.position?.state.get({ name: '#beforeMinimized' }),\n options: Object.assign({}, this.#application?.options),\n ui: { minimized: this.#application?.reactive?.minimized }\n });\n }\n\n /**\n * Returns any stored save state by name.\n *\n * @param {string} name - Saved data set name.\n *\n * @returns {ApplicationData} The saved data set.\n */\n getSave({ name })\n {\n if (typeof name !== 'string')\n {\n throw new TypeError(`ApplicationState - getSave error: 'name' is not a string.`);\n }\n\n return this.#dataSaved.get(name);\n }\n\n /**\n * Removes and returns any application state by name.\n *\n * @param {object} options - Options.\n *\n * @param {string} options.name - Name to remove and retrieve.\n *\n * @returns {ApplicationData} Saved application data.\n */\n remove({ name })\n {\n if (typeof name !== 'string') { throw new TypeError(`ApplicationState - remove: 'name' is not a string.`); }\n\n const data = this.#dataSaved.get(name);\n this.#dataSaved.delete(name);\n\n return data;\n }\n\n /**\n * Restores a saved application state returning the data. Several optional parameters are available\n * to control whether the restore action occurs silently (no store / inline styles updates), animates\n * to the stored data, or simply sets the stored data. Restoring via {@link AnimationAPI.to} allows\n * specification of the duration, easing, and interpolate functions along with configuring a Promise to be\n * returned if awaiting the end of the animation.\n *\n * @param {object} params - Parameters\n *\n * @param {string} params.name - Saved data set name.\n *\n * @param {boolean} [params.remove=false] - Remove data set.\n *\n * @param {boolean} [params.async=false] - If animating return a Promise that resolves with any saved data.\n *\n * @param {boolean} [params.animateTo=false] - Animate to restore data.\n *\n * @param {number} [params.duration=0.1] - Duration in seconds.\n *\n * @param {Function} [params.ease=linear] - Easing function.\n *\n * @param {Function} [params.interpolate=lerp] - Interpolation function.\n *\n * @returns {ApplicationData|Promise} Saved application data.\n */\n restore({ name, remove = false, async = false, animateTo = false, duration = 0.1, ease = linear,\n interpolate = lerp })\n {\n if (typeof name !== 'string')\n {\n throw new TypeError(`ApplicationState - restore error: 'name' is not a string.`);\n }\n\n const dataSaved = this.#dataSaved.get(name);\n\n if (dataSaved)\n {\n if (remove) { this.#dataSaved.delete(name); }\n\n if (async)\n {\n return this.set(dataSaved, { async, animateTo, duration, ease, interpolate }).then(() => dataSaved);\n }\n else\n {\n this.set(dataSaved, { async, animateTo, duration, ease, interpolate });\n }\n }\n\n return dataSaved;\n }\n\n /**\n * Saves current application state with the opportunity to add extra data to the saved state.\n *\n * @param {object} options - Options.\n *\n * @param {string} options.name - name to index this saved data.\n *\n * @param {...*} [options.extra] - Extra data to add to saved data.\n *\n * @returns {ApplicationData} Current application data\n */\n save({ name, ...extra })\n {\n if (typeof name !== 'string') { throw new TypeError(`ApplicationState - save error: 'name' is not a string.`); }\n\n const data = this.get(extra);\n\n this.#dataSaved.set(name, data);\n\n return data;\n }\n\n /**\n * Restores a saved application state returning the data. Several optional parameters are available\n * to control whether the restore action occurs silently (no store / inline styles updates), animates\n * to the stored data, or simply sets the stored data. Restoring via {@link AnimationAPI.to} allows\n * specification of the duration, easing, and interpolate functions along with configuring a Promise to be\n * returned if awaiting the end of the animation.\n *\n * Note: If serializing application state any minimized apps will use the before minimized state on initial render\n * of the app as it is currently not possible to render apps with Foundry VTT core API in the minimized state.\n *\n * TODO: THIS METHOD NEEDS TO BE REFACTORED WHEN TRL IS MADE INTO A STANDALONE FRAMEWORK.\n *\n * @param {ApplicationData} data - Saved data set name.\n *\n * @param {object} [opts] - Optional parameters\n *\n * @param {boolean} [opts.async=false] - If animating return a Promise that resolves with any saved data.\n *\n * @param {boolean} [opts.animateTo=false] - Animate to restore data.\n *\n * @param {number} [opts.duration=0.1] - Duration in seconds.\n *\n * @param {Function} [opts.ease=linear] - Easing function.\n *\n * @param {Function} [opts.interpolate=lerp] - Interpolation function.\n *\n * @returns {ApplicationShellExt|Promise} When synchronous the application or Promise when\n * animating resolving with application.\n */\n set(data, { async = false, animateTo = false, duration = 0.1, ease = linear, interpolate = lerp } = {})\n {\n if (!isObject(data))\n {\n throw new TypeError(`ApplicationState - restore error: 'data' is not an object.`);\n }\n\n const application = this.#application;\n\n if (!isObject(data?.position))\n {\n console.warn(`ApplicationState.set warning: 'data.position' is not an object.`);\n return application;\n }\n\n // TODO: TAKE NOTE THAT WE ARE ACCESSING A FOUNDRY APP v1 GETTER HERE TO DETERMINE IF APPLICATION IS RENDERED.\n // TODO: THIS NEEDS TO BE REFACTORED WHEN CONVERTING TRL TO A GENERIC FRAMEWORK.\n const rendered = application.rendered;\n\n if (animateTo && !rendered)\n {\n console.warn(`ApplicationState.set warning: Application is not rendered and 'animateTo' is true.`);\n return application;\n }\n\n // Update data directly with no store or inline style updates.\n if (animateTo) // Animate to saved data.\n {\n // Provide special handling to potentially change transform origin as this parameter is not animated.\n if (data.position.transformOrigin !== application.position.transformOrigin)\n {\n application.position.transformOrigin = data.position.transformOrigin;\n }\n\n if (isObject(data?.ui))\n {\n const minimized = typeof data.ui?.minimized === 'boolean' ? data.ui.minimized : false;\n\n if (application?.reactive?.minimized && !minimized)\n {\n application.maximize({ animate: false, duration: 0 });\n }\n }\n\n const promise = application.position.animate.to(data.position,\n { duration, ease, interpolate }).finished.then((cancelled) =>\n {\n if (cancelled) { return application; }\n\n // Merge in saved options to application.\n if (isObject(data?.options))\n {\n application?.reactive.mergeOptions(data.options);\n }\n\n if (isObject(data?.ui))\n {\n const minimized = typeof data.ui?.minimized === 'boolean' ? data.ui.minimized : false;\n\n // Application is currently minimized and stored state is not, so reset minimized state without\n // animation.\n if (!application?.reactive?.minimized && minimized)\n {\n application.minimize({ animate: false, duration: 0 });\n }\n }\n\n if (isObject(data?.beforeMinimized))\n {\n application.position.state.set({ name: '#beforeMinimized', ...data.beforeMinimized });\n }\n\n return application;\n });\n\n // Return a Promise with the application that resolves after animation ends.\n if (async) { return promise; }\n }\n else\n {\n if (rendered)\n {\n // Merge in saved options to application.\n if (isObject(data?.options))\n {\n application?.reactive.mergeOptions(data.options);\n }\n\n if (isObject(data?.ui))\n {\n const minimized = typeof data.ui?.minimized === 'boolean' ? data.ui.minimized : false;\n\n // Application is currently minimized and stored state is not, so reset minimized state without\n // animation.\n if (application?.reactive?.minimized && !minimized)\n {\n application.maximize({ animate: false, duration: 0 });\n }\n else if (!application?.reactive?.minimized && minimized)\n {\n application.minimize({ animate: false, duration });\n }\n }\n\n if (isObject(data?.beforeMinimized))\n {\n application.position.state.set({ name: '#beforeMinimized', ...data.beforeMinimized });\n }\n\n // Default options is to set data for an immediate update.\n application.position.set(data.position);\n }\n else\n {\n // When not rendered set position to the 'beforeMinimized' data if it exists otherwise set w/ 'position'.\n // Currently w/ Foundry core Application API it is impossible to initially render an app in the minimized\n // state.\n\n let positionData = data.position;\n\n if (isObject(data.beforeMinimized))\n {\n // Take before minimized data.\n positionData = data.beforeMinimized;\n\n // Apply position left / top to before minimized data. This covers the case when an app is minimized,\n // but then moved. This allows restoration of the before minimized parameters w/ the last position\n // location.\n positionData.left = data.position.left;\n positionData.top = data.position.top;\n }\n\n application.position.set(positionData);\n }\n }\n\n return application;\n }\n}\n\n/**\n * @typedef {object} ApplicationData\n *\n * @property {PositionDataExtended} position - Application position.\n *\n * @property {object} beforeMinimized - Any application saved position state for #beforeMinimized\n *\n * @property {object} options - Application options.\n *\n * @property {object} ui - Application UI state.\n */\n","/**\n * Provides a helper class for {@link SvelteApplication} by combining all methods that work on the {@link SvelteData[]}\n * of mounted components. This class is instantiated and can be retrieved by the getter `svelte` via SvelteApplication.\n */\nexport class GetSvelteData\n{\n /**\n * @type {MountedAppShell[]|null[]}\n */\n #applicationShellHolder;\n\n /**\n * @type {SvelteData[]}\n */\n #svelteData;\n\n /**\n * Keep a direct reference to the SvelteData array in an associated {@link SvelteApplication}.\n *\n * @param {MountedAppShell[]|null[]} applicationShellHolder - A reference to the MountedAppShell array.\n *\n * @param {SvelteData[]} svelteData - A reference to the SvelteData array of mounted components.\n */\n constructor(applicationShellHolder, svelteData)\n {\n this.#applicationShellHolder = applicationShellHolder;\n this.#svelteData = svelteData;\n }\n\n /**\n * Returns any mounted {@link MountedAppShell}.\n *\n * @returns {MountedAppShell|null} Any mounted application shell.\n */\n get applicationShell() { return this.#applicationShellHolder[0]; }\n\n /**\n * Returns the indexed Svelte component.\n *\n * @param {number} index -\n *\n * @returns {object} The loaded Svelte component.\n */\n component(index)\n {\n const data = this.#svelteData[index];\n return typeof data === 'object' ? data?.component : void 0;\n }\n\n /**\n * Returns the Svelte component entries iterator.\n *\n * @returns {Generator>} Svelte component entries iterator.\n * @yields\n */\n *componentEntries()\n {\n for (let cntr = 0; cntr < this.#svelteData.length; cntr++)\n {\n yield [cntr, this.#svelteData[cntr].component];\n }\n }\n\n /**\n * Returns the Svelte component values iterator.\n *\n * @returns {Generator} Svelte component values iterator.\n * @yields\n */\n *componentValues()\n {\n for (let cntr = 0; cntr < this.#svelteData.length; cntr++)\n {\n yield this.#svelteData[cntr].component;\n }\n }\n\n /**\n * Returns the indexed SvelteData entry.\n *\n * @param {number} index -\n *\n * @returns {SvelteData} The loaded Svelte config + component.\n */\n data(index)\n {\n return this.#svelteData[index];\n }\n\n /**\n * Returns the {@link SvelteData} instance for a given component.\n *\n * @param {object} component - Svelte component.\n *\n * @returns {SvelteData} - The loaded Svelte config + component.\n */\n dataByComponent(component)\n {\n for (const data of this.#svelteData)\n {\n if (data.component === component) { return data; }\n }\n\n return void 0;\n }\n\n /**\n * Returns the SvelteData entries iterator.\n *\n * @returns {IterableIterator<[number, SvelteData]>} SvelteData entries iterator.\n */\n dataEntries()\n {\n return this.#svelteData.entries();\n }\n\n /**\n * Returns the SvelteData values iterator.\n *\n * @returns {IterableIterator} SvelteData values iterator.\n */\n dataValues()\n {\n return this.#svelteData.values();\n }\n\n /**\n * Returns the length of the mounted Svelte component list.\n *\n * @returns {number} Length of mounted Svelte component list.\n */\n get length()\n {\n return this.#svelteData.length;\n }\n}\n","import {\n isApplicationShell,\n parseSvelteConfig } from '@typhonjs-fvtt/runtime/svelte/util';\n\n/**\n * Instantiates and attaches a Svelte component to the main inserted HTML.\n *\n * @param {object} opts - Optional parameters.\n *\n * @param {object} opts.app - The target application\n *\n * @param {HTMLElement} opts.template - Any HTML template.\n *\n * @param {object} opts.config - Svelte component options\n *\n * @param {Function} opts.elementRootUpdate - A callback to assign to the external context.\n *\n * @returns {SvelteData} The config + instantiated Svelte component.\n */\nexport function loadSvelteConfig({ app, template, config, elementRootUpdate } = {})\n{\n const svelteOptions = typeof config.options === 'object' ? config.options : {};\n\n let target;\n\n // A specific HTMLElement to append Svelte component.\n if (config.target instanceof HTMLElement)\n {\n target = config.target;\n }\n // A string target defines a selector to find in existing HTML.\n else if (template instanceof HTMLElement && typeof config.target === 'string')\n {\n target = template.querySelector(config.target);\n }\n else // No target defined, create a document fragment.\n {\n target = document.createDocumentFragment();\n }\n\n if (target === void 0)\n {\n console.log(\n `%c[TRL] loadSvelteConfig error - could not find target selector, '${config.target}', for config:\\n`,\n 'background: rgb(57,34,34)', config);\n\n throw new Error();\n }\n\n const NewSvelteComponent = config.class;\n\n const svelteConfig = parseSvelteConfig({ ...config, target }, app);\n\n const externalContext = svelteConfig.context.get('external');\n\n // Inject the Foundry application instance and `elementRootUpdate` to the external context.\n externalContext.application = app;\n externalContext.elementRootUpdate = elementRootUpdate;\n\n let eventbus;\n\n // Potentially inject any TyphonJS eventbus and track the proxy in the SvelteData instance.\n if (typeof app._eventbus === 'object' && typeof app._eventbus.createProxy === 'function')\n {\n eventbus = app._eventbus.createProxy();\n externalContext.eventbus = eventbus;\n }\n\n // Create the Svelte component.\n /**\n * @type {import('svelte').SvelteComponent}\n */\n const component = new NewSvelteComponent(svelteConfig);\n\n // Set any eventbus to the config.\n svelteConfig.eventbus = eventbus;\n\n /**\n * @type {HTMLElement}\n */\n let element;\n\n // We can directly get the root element from components which follow the application store contract.\n if (isApplicationShell(component))\n {\n element = component.elementRoot;\n }\n\n // Detect if target is a synthesized DocumentFragment with a child element. Child elements will be present\n // if the Svelte component mounts and renders initial content into the document fragment.\n if (target instanceof DocumentFragment && target.firstElementChild)\n {\n if (element === void 0) { element = target.firstElementChild; }\n template.append(target);\n }\n else if (config.target instanceof HTMLElement && element === void 0)\n {\n if (config.target instanceof HTMLElement && typeof svelteOptions.selectorElement !== 'string')\n {\n console.log(\n `%c[TRL] loadSvelteConfig error - HTMLElement target with no 'selectorElement' defined.\\n` +\n `\\nNote: If configuring an application shell and directly targeting a HTMLElement did you bind an` +\n `'elementRoot' and include ''?\\n` +\n `\\nOffending config:\\n`, 'background: rgb(57,34,34)', config);\n\n throw new Error();\n }\n\n // The target is an HTMLElement so find the Application element from `selectorElement` option.\n element = target.querySelector(svelteOptions.selectorElement);\n\n if (element === null || element === void 0)\n {\n console.log(\n `%c[TRL] loadSvelteConfig error - HTMLElement target with 'selectorElement', '${\n svelteOptions.selectorElement}', not found for config:\\n`,\n 'background: rgb(57,34,34)', config);\n\n throw new Error();\n }\n }\n\n // If the configuration / original target is an HTML element then do not inject HTML.\n const injectHTML = !(config.target instanceof HTMLElement);\n\n return { config: svelteConfig, component, element, injectHTML };\n}\n","import { derived, writable } from \"svelte/store\";\n\nimport {\n propertyStore,\n subscribeIgnoreFirst } from '@typhonjs-fvtt/runtime/svelte/store';\n\nimport {\n deepMerge,\n safeAccess,\n safeSet } from '@typhonjs-fvtt/runtime/svelte/util';\n\n/**\n * Contains the reactive functionality / Svelte stores associated with SvelteApplication.\n */\nexport class SvelteReactive\n{\n /**\n * @type {SvelteApplication}\n */\n #application;\n\n /**\n * @type {boolean}\n */\n #initialized = false;\n\n /**\n * The Application option store which is injected into mounted Svelte component context under the `external` key.\n *\n * @type {StoreAppOptions}\n */\n #storeAppOptions;\n\n /**\n * Stores the update function for `#storeAppOptions`.\n *\n * @type {import('svelte/store').Writable.update}\n */\n #storeAppOptionsUpdate;\n\n /**\n * Stores the UI state data to make it accessible via getters.\n *\n * @type {object}\n */\n #dataUIState;\n\n /**\n * The UI option store which is injected into mounted Svelte component context under the `external` key.\n *\n * @type {StoreUIOptions}\n */\n #storeUIState;\n\n /**\n * Stores the update function for `#storeUIState`.\n *\n * @type {import('svelte/store').Writable.update}\n */\n #storeUIStateUpdate;\n\n /**\n * Stores the unsubscribe functions from local store subscriptions.\n *\n * @type {import('svelte/store').Unsubscriber[]}\n */\n #storeUnsubscribe = [];\n\n /**\n * @param {SvelteApplication} application - The host Foundry application.\n */\n constructor(application)\n {\n this.#application = application;\n }\n\n /**\n * Initializes reactive support. Package private for internal use.\n *\n * @returns {SvelteStores} Internal methods to interact with Svelte stores.\n * @package\n */\n initialize()\n {\n if (this.#initialized) { return; }\n\n this.#initialized = true;\n\n this.#storesInitialize();\n\n return {\n appOptionsUpdate: this.#storeAppOptionsUpdate,\n uiOptionsUpdate: this.#storeUIStateUpdate,\n subscribe: this.#storesSubscribe.bind(this),\n unsubscribe: this.#storesUnsubscribe.bind(this)\n };\n }\n\n// Only reactive getters ---------------------------------------------------------------------------------------------\n\n /**\n * Returns the current dragging UI state.\n *\n * @returns {boolean} Dragging UI state.\n */\n get dragging() { return this.#dataUIState.dragging; }\n\n /**\n * Returns the current minimized UI state.\n *\n * @returns {boolean} Minimized UI state.\n */\n get minimized() { return this.#dataUIState.minimized; }\n\n /**\n * Returns the current resizing UI state.\n *\n * @returns {boolean} Resizing UI state.\n */\n get resizing() { return this.#dataUIState.resizing; }\n\n// Reactive getter / setters -----------------------------------------------------------------------------------------\n\n /**\n * Returns the draggable app option.\n *\n * @returns {boolean} Draggable app option.\n */\n get draggable() { return this.#application?.options?.draggable; }\n\n /**\n * Returns the headerButtonNoClose app option.\n *\n * @returns {boolean} Remove the close the button in header app option.\n */\n get headerButtonNoClose() { return this.#application?.options?.headerButtonNoClose; }\n\n /**\n * Returns the headerButtonNoLabel app option.\n *\n * @returns {boolean} Remove the labels from buttons in header app option.\n */\n get headerButtonNoLabel() { return this.#application?.options?.headerButtonNoLabel; }\n\n /**\n * Returns the headerNoTitleMinimized app option.\n *\n * @returns {boolean} When true removes the header title when minimized.\n */\n get headerNoTitleMinimized() { return this.#application?.options?.headerNoTitleMinimized; }\n\n /**\n * Returns the minimizable app option.\n *\n * @returns {boolean} Minimizable app option.\n */\n get minimizable() { return this.#application?.options?.minimizable; }\n\n /**\n * @inheritDoc\n */\n get popOut() { return this.#application.popOut; }\n\n /**\n * Returns the resizable option.\n *\n * @returns {boolean} Resizable app option.\n */\n get resizable() { return this.#application?.options?.resizable; }\n\n /**\n * Returns the store for app options.\n *\n * @returns {StoreAppOptions} App options store.\n */\n get storeAppOptions() { return this.#storeAppOptions; }\n\n /**\n * Returns the store for UI options.\n *\n * @returns {StoreUIOptions} UI options store.\n */\n get storeUIState() { return this.#storeUIState; }\n\n /**\n * Returns the title accessor from the parent Application class.\n * TODO: Application v2; note that super.title localizes `this.options.title`; IMHO it shouldn't.\n *\n * @returns {string} Title.\n */\n get title() { return this.#application.title; }\n\n /**\n * Sets `this.options.draggable` which is reactive for application shells.\n *\n * @param {boolean} draggable - Sets the draggable option.\n */\n set draggable(draggable)\n {\n if (typeof draggable === 'boolean') { this.setOptions('draggable', draggable); }\n }\n\n /**\n * Sets `this.options.headerButtonNoClose` which is reactive for application shells.\n *\n * @param {boolean} headerButtonNoClose - Sets the headerButtonNoClose option.\n */\n set headerButtonNoClose(headerButtonNoClose)\n {\n if (typeof headerButtonNoClose === 'boolean') { this.setOptions('headerButtonNoClose', headerButtonNoClose); }\n }\n\n /**\n * Sets `this.options.headerButtonNoLabel` which is reactive for application shells.\n *\n * @param {boolean} headerButtonNoLabel - Sets the headerButtonNoLabel option.\n */\n set headerButtonNoLabel(headerButtonNoLabel)\n {\n if (typeof headerButtonNoLabel === 'boolean') { this.setOptions('headerButtonNoLabel', headerButtonNoLabel); }\n }\n\n /**\n * Sets `this.options.headerNoTitleMinimized` which is reactive for application shells.\n *\n * @param {boolean} headerNoTitleMinimized - Sets the headerNoTitleMinimized option.\n */\n set headerNoTitleMinimized(headerNoTitleMinimized)\n {\n if (typeof headerNoTitleMinimized === 'boolean')\n {\n this.setOptions('headerNoTitleMinimized', headerNoTitleMinimized);\n }\n }\n\n /**\n * Sets `this.options.minimizable` which is reactive for application shells that are also pop out.\n *\n * @param {boolean} minimizable - Sets the minimizable option.\n */\n set minimizable(minimizable)\n {\n if (typeof minimizable === 'boolean') { this.setOptions('minimizable', minimizable); }\n }\n\n /**\n * Sets `this.options.popOut` which is reactive for application shells. This will add / remove this application\n * from `ui.windows`.\n *\n * @param {boolean} popOut - Sets the popOut option.\n */\n set popOut(popOut)\n {\n if (typeof popOut === 'boolean') { this.setOptions('popOut', popOut); }\n }\n\n /**\n * Sets `this.options.resizable` which is reactive for application shells.\n *\n * @param {boolean} resizable - Sets the resizable option.\n */\n set resizable(resizable)\n {\n if (typeof resizable === 'boolean') { this.setOptions('resizable', resizable); }\n }\n\n /**\n * Sets `this.options.title` which is reactive for application shells.\n *\n * Note: Will set empty string if title is undefined or null.\n *\n * @param {string|undefined|null} title - Application title; will be localized, so a translation key is fine.\n */\n set title(title)\n {\n if (typeof title === 'string')\n {\n this.setOptions('title', title);\n }\n else if (title === void 0 || title === null)\n {\n this.setOptions('title', '');\n }\n }\n\n /**\n * Provides a way to safely get this applications options given an accessor string which describes the\n * entries to walk. To access deeper entries into the object format the accessor string with `.` between entries\n * to walk.\n *\n * // TODO DOCUMENT the accessor in more detail.\n *\n * @param {string} accessor - The path / key to set. You can set multiple levels.\n *\n * @param {*} [defaultValue] - A default value returned if the accessor is not found.\n *\n * @returns {*} Value at the accessor.\n */\n getOptions(accessor, defaultValue)\n {\n return safeAccess(this.#application.options, accessor, defaultValue);\n }\n\n /**\n * Provides a way to merge `options` into this applications options and update the appOptions store.\n *\n * @param {object} options - The options object to merge with `this.options`.\n */\n mergeOptions(options)\n {\n this.#storeAppOptionsUpdate((instanceOptions) => deepMerge(instanceOptions, options));\n }\n\n /**\n * Provides a way to safely set this applications options given an accessor string which describes the\n * entries to walk. To access deeper entries into the object format the accessor string with `.` between entries\n * to walk.\n *\n * Additionally if an application shell Svelte component is mounted and exports the `appOptions` property then\n * the application options is set to `appOptions` potentially updating the application shell / Svelte component.\n *\n * // TODO DOCUMENT the accessor in more detail.\n *\n * @param {string} accessor - The path / key to set. You can set multiple levels.\n *\n * @param {*} value - Value to set.\n */\n setOptions(accessor, value)\n {\n const success = safeSet(this.#application.options, accessor, value);\n\n // If `this.options` modified then update the app options store.\n if (success)\n {\n this.#storeAppOptionsUpdate(() => this.#application.options);\n }\n }\n\n /**\n * Initializes the Svelte stores and derived stores for the application options and UI state.\n *\n * While writable stores are created the update method is stored in private variables locally and derived Readable\n * stores are provided for essential options which are commonly used.\n *\n * These stores are injected into all Svelte components mounted under the `external` context: `storeAppOptions` and\n * ` storeUIState`.\n */\n #storesInitialize()\n {\n const writableAppOptions = writable(this.#application.options);\n\n // Keep the update function locally, but make the store essentially readable.\n this.#storeAppOptionsUpdate = writableAppOptions.update;\n\n /**\n * Create custom store. The main subscribe method for all app options changes is provided along with derived\n * writable stores for all reactive options.\n *\n * @type {StoreAppOptions}\n */\n const storeAppOptions = {\n subscribe: writableAppOptions.subscribe,\n\n draggable: propertyStore(writableAppOptions, 'draggable'),\n headerButtonNoClose: propertyStore(writableAppOptions, 'headerButtonNoClose'),\n headerButtonNoLabel: propertyStore(writableAppOptions, 'headerButtonNoLabel'),\n headerNoTitleMinimized: propertyStore(writableAppOptions, 'headerNoTitleMinimized'),\n minimizable: propertyStore(writableAppOptions, 'minimizable'),\n popOut: propertyStore(writableAppOptions, 'popOut'),\n resizable: propertyStore(writableAppOptions, 'resizable'),\n title: propertyStore(writableAppOptions, 'title')\n };\n\n Object.freeze(storeAppOptions);\n\n this.#storeAppOptions = storeAppOptions;\n\n this.#dataUIState = {\n dragging: false,\n headerButtons: [],\n minimized: this.#application._minimized,\n resizing: false\n };\n\n // Create a store for UI state data.\n const writableUIOptions = writable(this.#dataUIState);\n\n // Keep the update function locally, but make the store essentially readable.\n this.#storeUIStateUpdate = writableUIOptions.update;\n\n /**\n * @type {StoreUIOptions}\n */\n const storeUIState = {\n subscribe: writableUIOptions.subscribe,\n\n dragging: propertyStore(writableUIOptions, 'dragging'),\n headerButtons: derived(writableUIOptions, ($options, set) => set($options.headerButtons)),\n minimized: derived(writableUIOptions, ($options, set) => set($options.minimized)),\n resizing: propertyStore(writableUIOptions, 'resizing')\n };\n\n Object.freeze(storeUIState);\n\n // Initialize the store with options set in the Application constructor.\n this.#storeUIState = storeUIState;\n }\n\n /**\n * Registers local store subscriptions for app options. `popOut` controls registering this app with `ui.windows`.\n * `zIndex` controls the z-index style of the element root.\n *\n * @see SvelteApplication._injectHTML\n */\n #storesSubscribe()\n {\n // Register local subscriptions.\n\n // Handles updating header buttons to add / remove the close button.\n this.#storeUnsubscribe.push(subscribeIgnoreFirst(this.#storeAppOptions.headerButtonNoClose, (value) =>\n {\n this.updateHeaderButtons({ headerButtonNoClose: value });\n }));\n\n // Handles updating header buttons to add / remove button labels.\n this.#storeUnsubscribe.push(subscribeIgnoreFirst(this.#storeAppOptions.headerButtonNoLabel, (value) =>\n {\n this.updateHeaderButtons({ headerButtonNoLabel: value });\n }));\n\n // Handles adding / removing this application from `ui.windows` when popOut changes.\n this.#storeUnsubscribe.push(subscribeIgnoreFirst(this.#storeAppOptions.popOut, (value) =>\n {\n if (value && this.#application.rendered)\n {\n ui.windows[this.#application.appId] = this.#application;\n }\n else\n {\n delete ui.windows[this.#application.appId];\n }\n }));\n }\n\n /**\n * Unsubscribes from any locally monitored stores.\n *\n * @see SvelteApplication.close\n */\n #storesUnsubscribe()\n {\n this.#storeUnsubscribe.forEach((unsubscribe) => unsubscribe());\n this.#storeUnsubscribe = [];\n }\n\n /**\n * Updates the UI Options store with the current header buttons. You may dynamically add / remove header buttons\n * if using an application shell Svelte component. In either overriding `_getHeaderButtons` or responding to the\n * Hooks fired return a new button array and the uiOptions store is updated and the application shell will render\n * the new buttons.\n *\n * Optionally you can set in the Foundry app options `headerButtonNoClose` to remove the close button and\n * `headerButtonNoLabel` to true and labels will be removed from the header buttons.\n *\n * @param {object} opts - Optional parameters (for internal use)\n *\n * @param {boolean} opts.headerButtonNoClose - The value for `headerButtonNoClose`.\n *\n * @param {boolean} opts.headerButtonNoLabel - The value for `headerButtonNoLabel`.\n */\n updateHeaderButtons({ headerButtonNoClose = this.#application.options.headerButtonNoClose,\n headerButtonNoLabel = this.#application.options.headerButtonNoLabel } = {})\n {\n let buttons = this.#application._getHeaderButtons();\n\n // Remove close button if this.options.headerButtonNoClose is true;\n if (typeof headerButtonNoClose === 'boolean' && headerButtonNoClose)\n {\n buttons = buttons.filter((button) => button.class !== 'close');\n }\n\n // Remove labels if this.options.headerButtonNoLabel is true;\n if (typeof headerButtonNoLabel === 'boolean' && headerButtonNoLabel)\n {\n for (const button of buttons) { button.label = void 0; }\n }\n\n this.#storeUIStateUpdate((options) =>\n {\n options.headerButtons = buttons;\n return options;\n });\n }\n}\n","// import { Position } from '@typhonjs-fvtt/runtime/svelte/store';\nimport { Position } from './position/Position.js';\n\nimport {\n deepMerge,\n hasGetter,\n isApplicationShell,\n isHMRProxy,\n outroAndDestroy } from '@typhonjs-fvtt/runtime/svelte/util';\n\nimport {\n ApplicationState,\n GetSvelteData,\n loadSvelteConfig,\n SvelteReactive } from './internal/index.js';\n\n/**\n * Provides a Svelte aware extension to Application to control the app lifecycle appropriately. You can declaratively\n * load one or more components from `defaultOptions`.\n */\nexport class SvelteApplication extends Application\n{\n /**\n * Stores the first mounted component which follows the application shell contract.\n *\n * @type {MountedAppShell[]|null[]} Application shell.\n */\n #applicationShellHolder = [null];\n\n /**\n * Stores and manages application state for saving / restoring / serializing.\n *\n * @type {ApplicationState}\n */\n #applicationState;\n\n /**\n * Stores the target element which may not necessarily be the main element.\n *\n * @type {HTMLElement}\n */\n #elementTarget = null;\n\n /**\n * Stores the content element which is set for application shells.\n *\n * @type {HTMLElement}\n */\n #elementContent = null;\n\n /**\n * Stores initial z-index from `_renderOuter` to set to target element / Svelte component.\n *\n * @type {number}\n */\n #initialZIndex = 95;\n\n /**\n * Stores on mount state which is checked in _render to trigger onSvelteMount callback.\n *\n * @type {boolean}\n */\n #onMount = false;\n\n /**\n * The position store.\n *\n * @type {Position}\n */\n #position;\n\n /**\n * Contains the Svelte stores and reactive accessors.\n *\n * @type {SvelteReactive}\n */\n #reactive;\n\n /**\n * Stores SvelteData entries with instantiated Svelte components.\n *\n * @type {SvelteData[]}\n */\n #svelteData = [];\n\n /**\n * Provides a helper class that combines multiple methods for interacting with the mounted components tracked in\n * {@link SvelteData}.\n *\n * @type {GetSvelteData}\n */\n #getSvelteData = new GetSvelteData(this.#applicationShellHolder, this.#svelteData);\n\n /**\n * Contains methods to interact with the Svelte stores.\n *\n * @type {SvelteStores}\n */\n #stores;\n\n /**\n * @inheritDoc\n */\n constructor(options = {})\n {\n super(options);\n\n this.#applicationState = new ApplicationState(this);\n\n // Initialize Position with the position object set by Application.\n this.#position = new Position(this, {\n ...this.position,\n ...this.options,\n initial: this.options.positionInitial,\n ortho: this.options.positionOrtho,\n validator: this.options.positionValidator\n });\n\n // Remove old position field.\n delete this.position;\n\n /**\n * Define accessors to retrieve Position by `this.position`.\n *\n * @member {Position} position - Adds accessors to SvelteApplication to get / set the position data.\n *\n * @memberof SvelteApplication#\n */\n Object.defineProperty(this, 'position', {\n get: () => this.#position,\n set: (position) => { if (typeof position === 'object') { this.#position.set(position); } }\n });\n\n this.#reactive = new SvelteReactive(this);\n\n this.#stores = this.#reactive.initialize();\n }\n\n /**\n * Specifies the default options that SvelteApplication supports.\n *\n * @returns {object} options - Application options.\n * @see https://foundryvtt.com/api/Application.html#options\n */\n static get defaultOptions()\n {\n return deepMerge(super.defaultOptions, {\n defaultCloseAnimation: true, // If false the default slide close animation is not run.\n draggable: true, // If true then application shells are draggable.\n headerButtonNoClose: false, // If true then the close header button is removed.\n headerButtonNoLabel: false, // If true then header button labels are removed for application shells.\n headerNoTitleMinimized: false, // If true then header title is hidden when application is minimized.\n minHeight: MIN_WINDOW_HEIGHT, // Assigned to position. Number specifying minimum window height.\n minWidth: MIN_WINDOW_WIDTH, // Assigned to position. Number specifying minimum window width.\n positionable: true, // If false then `position.set` does not take effect.\n positionInitial: Position.Initial.browserCentered, // A helper for initial position placement.\n positionOrtho: true, // When true Position is optimized for orthographic use.\n positionValidator: Position.Validators.transformWindow, // A function providing the default validator.\n transformOrigin: 'top left' // By default, 'top / left' respects rotation when minimizing.\n });\n }\n\n /**\n * Returns the content element if an application shell is mounted.\n *\n * @returns {HTMLElement} Content element.\n */\n get elementContent() { return this.#elementContent; }\n\n /**\n * Returns the target element or main element if no target defined.\n *\n * @returns {HTMLElement} Target element.\n */\n get elementTarget() { return this.#elementTarget; }\n\n /**\n * Returns the reactive accessors & Svelte stores for SvelteApplication.\n *\n * @returns {SvelteReactive} The reactive accessors & Svelte stores.\n */\n get reactive() { return this.#reactive; }\n\n /**\n * Returns the application state manager.\n *\n * @returns {ApplicationState} The application state manager.\n */\n get state() { return this.#applicationState; }\n\n /**\n * Returns the Svelte helper class w/ various methods to access mounted Svelte components.\n *\n * @returns {GetSvelteData} GetSvelteData\n */\n get svelte() { return this.#getSvelteData; }\n\n /**\n * In this case of when a template is defined in app options `html` references the inner HTML / template. However,\n * to activate classic v1 tabs for a Svelte component the element target is passed as an array simulating JQuery as\n * the element is retrieved immediately and the core listeners use standard DOM queries.\n *\n * @inheritDoc\n * @protected\n * @ignore\n */\n _activateCoreListeners(html)\n {\n super._activateCoreListeners(typeof this.options.template === 'string' ? html : [this.#elementTarget]);\n }\n\n /**\n * Provide an override to set this application as the active window regardless of z-index. Changes behaviour from\n * Foundry core. This is important / used for instance in dialog key handling for left / right button selection.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {boolean} [opts.force=false] - Force bring to top; will increment z-index by popOut order.\n *\n */\n bringToTop({ force = false } = {})\n {\n if (force || this.popOut) { super.bringToTop(); }\n\n // If the activeElement is not `document.body` and not contained in this app via elementTarget then blur the\n // current active element and make `document.body`focused. This allows key to close all open apps / windows.\n if (document.activeElement !== document.body && !this.elementTarget.contains(document.activeElement))\n {\n // Blur current active element.\n if (document.activeElement instanceof HTMLElement) { document.activeElement.blur(); }\n\n // Make document body focused.\n document.body.focus();\n }\n\n ui.activeWindow = this;\n }\n\n /**\n * Note: This method is fully overridden and duplicated as Svelte components need to be destroyed manually and the\n * best visual result is to destroy them after the default slide up animation occurs, but before the element\n * is removed from the DOM.\n *\n * If you destroy the Svelte components before the slide up animation the Svelte elements are removed immediately\n * from the DOM. The purpose of overriding ensures the slide up animation is always completed before\n * the Svelte components are destroyed and then the element is removed from the DOM.\n *\n * Close the application and un-register references to it within UI mappings.\n * This function returns a Promise which resolves once the window closing animation concludes\n *\n * @param {object} [options] - Optional parameters.\n *\n * @param {boolean} [options.force] - Force close regardless of render state.\n *\n * @returns {Promise} A Promise which resolves once the application is closed.\n * @ignore\n */\n async close(options = {})\n {\n const states = Application.RENDER_STATES;\n if (!options.force && ![states.RENDERED, states.ERROR].includes(this._state)) { return; }\n\n // Unsubscribe from any local stores.\n this.#stores.unsubscribe();\n\n /**\n * @ignore\n */\n this._state = states.CLOSING;\n\n /**\n * Get the element.\n *\n * @type {HTMLElement}\n */\n const el = this.#elementTarget;\n if (!el) { return this._state = states.CLOSED; }\n\n // Make any window content overflow hidden to avoid any scrollbars appearing in default or Svelte outro\n // transitions.\n const content = el.querySelector('.window-content');\n if (content)\n {\n content.style.overflow = 'hidden';\n\n // Set all children of content to overflow hidden as if there is going to be additional scrolling elements\n // they are likely one level deep.\n for (let cntr = content.children.length; --cntr >= 0;)\n {\n content.children[cntr].style.overflow = 'hidden';\n }\n }\n\n // Dispatch Hooks for closing the base and subclass applications\n for (const cls of this.constructor._getInheritanceChain())\n {\n /**\n * A hook event that fires whenever this Application is closed.\n *\n * @param {Application} app The Application instance being closed\n *\n * @param {jQuery[]} html The application HTML when it is closed\n *\n * @function closeApplication\n *\n * @memberof hookEvents\n */\n Hooks.call(`close${cls.name}`, this, el);\n }\n\n // If options `defaultCloseAnimation` is false then do not execute the standard slide up animation.\n // This allows Svelte components to provide any out transition. Application shells will automatically set\n // `defaultCloseAnimation` based on any out transition set or unset.\n const animate = typeof this.options.defaultCloseAnimation === 'boolean' ? this.options.defaultCloseAnimation :\n true;\n\n if (animate)\n {\n // Set min height for full slide.\n el.style.minHeight = '0';\n\n const { paddingBottom, paddingTop } = globalThis.getComputedStyle(el);\n\n // Slide-up application.\n await el.animate([\n { maxHeight: `${el.clientHeight}px`, paddingTop, paddingBottom },\n { maxHeight: 0, paddingTop: 0, paddingBottom: 0 }\n ], { duration: 250, easing: 'ease-in', fill: 'forwards' }).finished;\n }\n\n // Stores the Promises returned from running outro transitions and destroying each Svelte component.\n const svelteDestroyPromises = [];\n\n // Manually invoke the destroy callbacks for all Svelte components.\n for (const entry of this.#svelteData)\n {\n // Use `outroAndDestroy` to run outro transitions before destroying.\n svelteDestroyPromises.push(outroAndDestroy(entry.component));\n\n // If any proxy eventbus has been added then remove all event registrations from the component.\n const eventbus = entry.config.eventbus;\n if (typeof eventbus === 'object' && typeof eventbus.off === 'function')\n {\n eventbus.off();\n entry.config.eventbus = void 0;\n }\n }\n\n // Await all Svelte components to destroy.\n await Promise.all(svelteDestroyPromises);\n\n // Reset SvelteData like this to maintain reference to GetSvelteData / `this.svelte`.\n this.#svelteData.length = 0;\n\n // Remove element from the DOM. Most SvelteComponents have already removed it.\n el.remove();\n\n // Silently restore any width / height state before minimized as applicable.\n this.position.state.restore({\n name: '#beforeMinimized',\n properties: ['width', 'height'],\n silent: true,\n remove: true\n });\n\n // Clean up data\n this.#applicationShellHolder[0] = null;\n /**\n * @ignore\n */\n this._element = null;\n this.#elementContent = null;\n this.#elementTarget = null;\n delete ui.windows[this.appId];\n /**\n * @ignore\n */\n this._minimized = false;\n /**\n * @ignore\n */\n this._scrollPositions = null;\n this._state = states.CLOSED;\n\n this.#onMount = false;\n\n // Update the minimized UI store options.\n this.#stores.uiOptionsUpdate((storeOptions) => deepMerge(storeOptions, { minimized: this._minimized }));\n }\n\n /**\n * Inject the Svelte components defined in `this.options.svelte`. The Svelte component can attach to the existing\n * pop-out of Application or provide no template and render into a document fragment which is then attached to the\n * DOM.\n *\n * @param {JQuery} html -\n *\n * @inheritDoc\n * @ignore\n */\n _injectHTML(html)\n {\n if (this.popOut && html.length === 0 && Array.isArray(this.options.svelte))\n {\n throw new Error(\n 'SvelteApplication - _injectHTML - A popout app with no template can only support one Svelte component.');\n }\n\n // Make sure the store is updated with the latest header buttons. Also allows filtering buttons before display.\n this.reactive.updateHeaderButtons();\n\n // Create a function to generate a callback for Svelte components to invoke to update the tracked elements for\n // application shells in the rare cases that the main element root changes. The update is only trigged on\n // successive changes of `elementRoot`. Returns a boolean to indicate the element roots are updated.\n const elementRootUpdate = () =>\n {\n let cntr = 0;\n\n return (elementRoot) =>\n {\n if (elementRoot !== null && elementRoot !== void 0 && cntr++ > 0)\n {\n this.#updateApplicationShell();\n return true;\n }\n\n return false;\n };\n };\n\n if (Array.isArray(this.options.svelte))\n {\n for (const svelteConfig of this.options.svelte)\n {\n const svelteData = loadSvelteConfig({\n app: this,\n template: html[0],\n config: svelteConfig,\n elementRootUpdate\n });\n\n if (isApplicationShell(svelteData.component))\n {\n if (this.svelte.applicationShell !== null)\n {\n throw new Error(\n `SvelteApplication - _injectHTML - An application shell is already mounted; offending config:\n ${JSON.stringify(svelteConfig)}`);\n }\n\n this.#applicationShellHolder[0] = svelteData.component;\n\n // If Vite / HMR / svelte_hmr is enabled then add a hook to receive callbacks when the ProxyComponent\n // refreshes. Update the element root accordingly and force an update to Position.\n // See this issue for info about `on_hmr`:\n // https://github.com/sveltejs/svelte-hmr/issues/57\n if (isHMRProxy(svelteData.component) && Array.isArray(svelteData.component?.$$?.on_hmr))\n {\n svelteData.component.$$.on_hmr.push(() => () => this.#updateApplicationShell());\n }\n }\n\n this.#svelteData.push(svelteData);\n }\n }\n else if (typeof this.options.svelte === 'object')\n {\n const svelteData = loadSvelteConfig({\n app: this,\n template: html[0],\n config: this.options.svelte,\n elementRootUpdate\n });\n\n if (isApplicationShell(svelteData.component))\n {\n // A sanity check as shouldn't hit this case as only one component is being mounted.\n if (this.svelte.applicationShell !== null)\n {\n throw new Error(\n `SvelteApplication - _injectHTML - An application shell is already mounted; offending config:\n ${JSON.stringify(this.options.svelte)}`);\n }\n\n this.#applicationShellHolder[0] = svelteData.component;\n\n // If Vite / HMR / svelte_hmr is enabled then add a hook to receive callbacks when the ProxyComponent\n // refreshes. Update the element root accordingly and force an update to Position.\n // See this issue for info about `on_hmr`:\n // https://github.com/sveltejs/svelte-hmr/issues/57\n if (isHMRProxy(svelteData.component) && Array.isArray(svelteData.component?.$$?.on_hmr))\n {\n svelteData.component.$$.on_hmr.push(() => () => this.#updateApplicationShell());\n }\n }\n\n this.#svelteData.push(svelteData);\n }\n\n // Detect if this is a synthesized DocumentFragment.\n const isDocumentFragment = html.length && html[0] instanceof DocumentFragment;\n\n // If any of the Svelte components mounted directly targets an HTMLElement then do not inject HTML.\n let injectHTML = true;\n for (const svelteData of this.#svelteData)\n {\n if (!svelteData.injectHTML) { injectHTML = false; break; }\n }\n if (injectHTML) { super._injectHTML(html); }\n\n if (this.svelte.applicationShell !== null)\n {\n this._element = $(this.svelte.applicationShell.elementRoot);\n\n // Detect if the application shell exports an `elementContent` accessor.\n this.#elementContent = hasGetter(this.svelte.applicationShell, 'elementContent') ?\n this.svelte.applicationShell.elementContent : null;\n\n // Detect if the application shell exports an `elementTarget` accessor.\n this.#elementTarget = hasGetter(this.svelte.applicationShell, 'elementTarget') ?\n this.svelte.applicationShell.elementTarget : null;\n }\n else if (isDocumentFragment) // Set the element of the app to the first child element in order of Svelte components mounted.\n {\n for (const svelteData of this.#svelteData)\n {\n if (svelteData.element instanceof HTMLElement)\n {\n this._element = $(svelteData.element);\n break;\n }\n }\n }\n\n // Potentially retrieve a specific target element if `selectorTarget` is defined otherwise make the target the\n // main element.\n if (this.#elementTarget === null)\n {\n const element = typeof this.options.selectorTarget === 'string' ?\n this._element.find(this.options.selectorTarget) : this._element;\n\n this.#elementTarget = element[0];\n }\n\n // TODO VERIFY THIS CHECK ESPECIALLY `this.#elementTarget.length === 0`.\n if (this.#elementTarget === null || this.#elementTarget === void 0 || this.#elementTarget.length === 0)\n {\n throw new Error(`SvelteApplication - _injectHTML: Target element '${this.options.selectorTarget}' not found.`);\n }\n\n // The initial zIndex may be set in application options or for popOut applications is stored by `_renderOuter`\n // in `this.#initialZIndex`.\n if (typeof this.options.positionable === 'boolean' && this.options.positionable)\n {\n this.#elementTarget.style.zIndex = typeof this.options.zIndex === 'number' ? this.options.zIndex :\n this.#initialZIndex ?? 95;\n }\n\n // Subscribe to local store handling.\n this.#stores.subscribe();\n }\n\n /**\n * Provides a mechanism to update the UI options store for maximized.\n *\n * Note: the sanity check is duplicated from {@link Application.maximize} the store is updated _before_\n * performing the rest of animations. This allows application shells to remove / show any resize handlers\n * correctly. Extra constraint data is stored in a saved position state in {@link SvelteApplication.minimize}\n * to animate the content area.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {boolean} [opts.animate=true] - When true perform default maximizing animation.\n *\n * @param {number} [opts.duration=0.1] - Controls content area animation duration in seconds.\n */\n async maximize({ animate = true, duration = 0.1 } = {})\n {\n if (!this.popOut || [false, null].includes(this._minimized)) { return; }\n\n this._minimized = null;\n\n const durationMS = duration * 1000; // For WAAPI.\n\n // Get content\n const element = this.elementTarget;\n const header = element.querySelector('.window-header');\n const content = element.querySelector('.window-content');\n\n // Get the complete position before minimized. Used to reset min width & height to initial values later.\n const positionBefore = this.position.state.get({ name: '#beforeMinimized' });\n\n // First animate / restore width / async.\n if (animate)\n {\n await this.position.state.restore({\n name: '#beforeMinimized',\n async: true,\n animateTo: true,\n properties: ['width'],\n duration: 0.1\n });\n }\n\n // Reset display none on all children of header.\n for (let cntr = header.children.length; --cntr >= 0;) { header.children[cntr].style.display = null; }\n\n content.style.display = null;\n\n let constraints;\n\n if (animate)\n {\n // Next animate / restore height synchronously and remove key. Retrieve constraints data for slide up animation\n // below.\n ({ constraints } = this.position.state.restore({\n name: '#beforeMinimized',\n animateTo: true,\n properties: ['height'],\n remove: true,\n duration\n }));\n }\n else\n {\n ({ constraints } = this.position.state.remove({ name: '#beforeMinimized' }));\n }\n\n // Slide down content with stored constraints.\n await content.animate([\n { maxHeight: 0, paddingTop: 0, paddingBottom: 0, offset: 0 },\n { ...constraints, offset: 1 },\n { maxHeight: '100%', offset: 1 },\n ], { duration: durationMS, fill: 'forwards' }).finished; // WAAPI in ms.\n\n // Restore previous min width & height from saved data, app options, or default Foundry values.\n this.position.set({\n minHeight: positionBefore.minHeight ?? this.options?.minHeight ?? MIN_WINDOW_HEIGHT,\n minWidth: positionBefore.minWidth ?? this.options?.minWidth ?? MIN_WINDOW_WIDTH,\n });\n\n // Remove inline styles that override any styles assigned to the app.\n element.style.minWidth = null;\n element.style.minHeight = null;\n\n element.classList.remove('minimized');\n\n this._minimized = false;\n\n // Using a 50ms timeout prevents any instantaneous display of scrollbars with the above maximize animation.\n setTimeout(() =>\n {\n content.style.overflow = null;\n\n // Reset all children of content removing overflow hidden.\n for (let cntr = content.children.length; --cntr >= 0;)\n {\n content.children[cntr].style.overflow = null;\n }\n }, 50);\n\n this.#stores.uiOptionsUpdate((options) => deepMerge(options, { minimized: false }));\n }\n\n /**\n * Provides a mechanism to update the UI options store for minimized.\n *\n * Note: the sanity check is duplicated from {@link Application.minimize} the store is updated _before_\n * performing the rest of animations. This allows application shells to remove / show any resize handlers\n * correctly. Extra constraint data is stored in a saved position state in {@link SvelteApplication.minimize}\n * to animate the content area.\n *\n * @param {object} [opts] - Optional parameters\n *\n * @param {boolean} [opts.animate=true] - When true perform default minimizing animation.\n *\n * @param {number} [opts.duration=0.1] - Controls content area animation duration in seconds.\n */\n async minimize({ animate = true, duration = 0.1 } = {})\n {\n if (!this.rendered || !this.popOut || [true, null].includes(this._minimized)) { return; }\n\n this.#stores.uiOptionsUpdate((options) => deepMerge(options, { minimized: true }));\n\n this._minimized = null;\n\n const durationMS = duration * 1000; // For WAAPI.\n\n const element = this.elementTarget;\n\n // Get content\n const header = element.querySelector('.window-header');\n const content = element.querySelector('.window-content');\n\n // Save current max / min height & width.\n const beforeMinWidth = this.position.minWidth;\n const beforeMinHeight = this.position.minHeight;\n\n // Set minimized min width & height for header bar.\n this.position.set({ minWidth: 100, minHeight: 30 });\n\n // Also set inline styles to override any styles scoped to the app.\n element.style.minWidth = '100px';\n element.style.minHeight = '30px';\n\n if (content)\n {\n content.style.overflow = 'hidden';\n\n // Set all children of content to overflow hidden as if there is going to be additional scrolling elements\n // they are likely one level deep.\n for (let cntr = content.children.length; --cntr >= 0;)\n {\n content.children[cntr].style.overflow = 'hidden';\n }\n }\n\n const { paddingBottom, paddingTop } = globalThis.getComputedStyle(content);\n\n // Extra data that is saved with the current position. Used during `maximize`.\n const constraints = {\n maxHeight: `${content.clientHeight}px`,\n paddingTop,\n paddingBottom\n };\n\n // Slide-up content\n if (animate)\n {\n const animation = content.animate([\n constraints,\n { maxHeight: 0, paddingTop: 0, paddingBottom: 0 }\n ], { duration: durationMS, fill: 'forwards' }); // WAAPI in ms.\n\n // Set display style to none when animation finishes.\n animation.finished.then(() => content.style.display = 'none');\n }\n else\n {\n setTimeout(() => content.style.display = 'none', durationMS);\n }\n\n // Save current position state and add the constraint data to use in `maximize`.\n const saved = this.position.state.save({ name: '#beforeMinimized', constraints });\n\n // Set the initial before min width & height.\n saved.minWidth = beforeMinWidth;\n saved.minHeight = beforeMinHeight;\n\n const headerOffsetHeight = header.offsetHeight;\n\n // minHeight needs to be adjusted to header height.\n this.position.minHeight = headerOffsetHeight;\n\n if (animate)\n {\n // First await animation of height upward.\n await this.position.animate.to({ height: headerOffsetHeight }, { duration }).finished;\n }\n\n // Set all header buttons besides close and the window title to display none.\n for (let cntr = header.children.length; --cntr >= 0;)\n {\n const className = header.children[cntr].className;\n\n if (className.includes('window-title') || className.includes('close')) { continue; }\n\n // v10+ of Foundry core styles automatically hides anything besides the window title and close button, so\n // explicitly set display to block.\n if (className.includes('keep-minimized'))\n {\n header.children[cntr].style.display = 'block';\n continue;\n }\n\n header.children[cntr].style.display = 'none';\n }\n\n if (animate)\n {\n // Await animation of width to the left / minimum width.\n await this.position.animate.to({ width: MIN_WINDOW_WIDTH }, { duration: 0.1 }).finished;\n }\n\n element.classList.add('minimized');\n\n this._minimized = true;\n }\n\n /**\n * Provides a callback after all Svelte components are initialized.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {HTMLElement} [opts.element] - HTMLElement container for main application element.\n *\n * @param {HTMLElement} [opts.elementContent] - HTMLElement container for content area of application shells.\n *\n * @param {HTMLElement} [opts.elementTarget] - HTMLElement container for main application target element.\n */\n onSvelteMount({ element, elementContent, elementTarget } = {}) {} // eslint-disable-line no-unused-vars\n\n /**\n * Provides a callback after the main application shell is remounted. This may occur during HMR / hot module\n * replacement or directly invoked from the `elementRootUpdate` callback passed to the application shell component\n * context.\n *\n * @param {object} [opts] - Optional parameters.\n *\n * @param {HTMLElement} [opts.element] - HTMLElement container for main application element.\n *\n * @param {HTMLElement} [opts.elementContent] - HTMLElement container for content area of application shells.\n *\n * @param {HTMLElement} [opts.elementTarget] - HTMLElement container for main application target element.\n */\n onSvelteRemount({ element, elementContent, elementTarget } = {}) {} // eslint-disable-line no-unused-vars\n\n /**\n * Override replacing HTML as Svelte components control the rendering process. Only potentially change the outer\n * application frame / title for pop-out applications.\n *\n * @inheritDoc\n * @ignore\n */\n _replaceHTML(element, html) // eslint-disable-line no-unused-vars\n {\n if (!element.length) { return; }\n\n this.reactive.updateHeaderButtons();\n }\n\n /**\n * Provides an override verifying that a new Application being rendered for the first time doesn't have a\n * corresponding DOM element already loaded. This is a check that only occurs when `this._state` is\n * `Application.RENDER_STATES.NONE`. It is useful in particular when SvelteApplication has a static ID\n * explicitly set in `this.options.id` and long intro / outro transitions are assigned. If a new application\n * sharing this static ID attempts to open / render for the first time while an existing DOM element sharing\n * this static ID exists then the initial render is cancelled below rather than crashing later in the render\n * cycle {@link Position.set}.\n *\n * @inheritDoc\n * @protected\n * @ignore\n */\n async _render(force = false, options = {})\n {\n if (this._state === Application.RENDER_STATES.NONE &&\n document.querySelector(`#${this.id}`) instanceof HTMLElement)\n {\n console.warn(`SvelteApplication - _render: A DOM element already exists for CSS ID '${this.id\n }'. Cancelling initial render for new application with appId '${this.appId}'.`);\n\n return;\n }\n\n await super._render(force, options);\n\n if (!this.#onMount)\n {\n this.onSvelteMount({ element: this._element[0], elementContent: this.#elementContent, elementTarget:\n this.#elementTarget });\n\n this.#onMount = true;\n }\n }\n\n /**\n * Render the inner application content. Only render a template if one is defined otherwise provide an empty\n * JQuery element per the core Foundry API.\n *\n * @param {Object} data The data used to render the inner template\n *\n * @returns {Promise.} A promise resolving to the constructed jQuery object\n *\n * @protected\n * @ignore\n */\n async _renderInner(data)\n {\n const html = typeof this.template === 'string' ? await renderTemplate(this.template, data) :\n document.createDocumentFragment();\n\n return $(html);\n }\n\n /**\n * Stores the initial z-index set in `_renderOuter` which is used in `_injectHTML` to set the target element\n * z-index after the Svelte component is mounted.\n *\n * @returns {Promise} Outer frame / unused.\n * @protected\n * @ignore\n */\n async _renderOuter()\n {\n const html = await super._renderOuter();\n this.#initialZIndex = html[0].style.zIndex;\n return html;\n }\n\n /**\n * All calculation and updates of position are implemented in {@link Position.set}. This allows position to be fully\n * reactive and in control of updating inline styles for the application.\n *\n * This method remains for backward compatibility with Foundry. If you have a custom override quite likely you need\n * to update to using the {@link Position.validators} functionality.\n *\n * @param {PositionDataExtended} [position] - Position data.\n *\n * @returns {Position} The updated position object for the application containing the new values\n */\n setPosition(position)\n {\n return this.position.set(position);\n }\n\n /**\n * This method is invoked by the `elementRootUpdate` callback that is added to the external context passed to\n * Svelte components. When invoked it updates the local element roots tracked by SvelteApplication.\n *\n * This method may also be invoked by HMR / hot module replacement via `svelte-hmr`.\n */\n #updateApplicationShell()\n {\n const applicationShell = this.svelte.applicationShell;\n\n if (applicationShell !== null)\n {\n this._element = $(applicationShell.elementRoot);\n\n // Detect if the application shell exports an `elementContent` accessor.\n this.#elementContent = hasGetter(applicationShell, 'elementContent') ?\n applicationShell.elementContent : null;\n\n // Detect if the application shell exports an `elementTarget` accessor.\n this.#elementTarget = hasGetter(applicationShell, 'elementTarget') ?\n applicationShell.elementTarget : null;\n\n if (this.#elementTarget === null)\n {\n const element = typeof this.options.selectorTarget === 'string' ?\n this._element.find(this.options.selectorTarget) : this._element;\n\n this.#elementTarget = element[0];\n }\n\n // The initial zIndex may be set in application options or for popOut applications is stored by `_renderOuter`\n // in `this.#initialZIndex`.\n if (typeof this.options.positionable === 'boolean' && this.options.positionable)\n {\n this.#elementTarget.style.zIndex = typeof this.options.zIndex === 'number' ? this.options.zIndex :\n this.#initialZIndex ?? 95;\n\n super.bringToTop();\n\n // Ensure that new root element has inline position styles set.\n this.position.set(this.position.get());\n }\n\n super._activateCoreListeners([this.#elementTarget]);\n\n this.onSvelteRemount({ element: this._element[0], elementContent: this.#elementContent, elementTarget:\n this.#elementTarget });\n }\n }\n}\n\n/**\n * @typedef {object} SvelteData\n *\n * @property {object} config -\n *\n * @property {import('svelte').SvelteComponent} component -\n *\n * @property {HTMLElement} element -\n *\n * @property {boolean} injectHTML -\n */\n\n/**\n * @typedef {object} SvelteStores\n *\n * @property {import('svelte/store').Writable.update} appOptionsUpdate - Update function for app options store.\n *\n * @property {Function} subscribe - Subscribes to local stores.\n *\n * @property {import('svelte/store').Writable.update} uiOptionsUpdate - Update function for UI options store.\n *\n * @property {Function} unsubscribe - Unsubscribes from local stores.\n */\n","\n\n\n\n{#if Array.isArray(children)}\n {#each children as child}\n \n {/each}\n{:else if warn}\n Container warning: No children.
\n{/if}\n\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","import { linear } from 'svelte/easing';\nimport { lerp } from '@typhonjs-fvtt/runtime/svelte/math';\nimport { fade, slide } from 'svelte/transition';\n\n/**\n * Provides a rotate transition. For options `easing` is applied to to the rotate transition. The default easing is\n * linear.\n *\n * Note: that when reversing the transition that time goes from `1 - 0`, so if specific options are applied for\n * rotating out transition then `end` and `initial` are swapped.\n *\n * @param {HTMLElement} node - The transition node.\n *\n * @param {object} options - Optional parameters.\n *\n * @param {number} [options.delay] - Delay in ms before start of transition.\n *\n * @param {number} [options.duration] - Total transition length in ms.\n *\n * @param {Function} [options.easing=linear] - The easing function to apply to the rotate transition.\n *\n * @param {number} [options.end=0] - End rotation in degrees.\n *\n * @param {number} [options.initial=0] - Initial rotation in degrees.\n *\n * @returns {{duration: number, css: (function(*=): string), delay: number, easing: (x: number) => number}}\n * Transition object.\n */\nfunction rotate(node, options)\n{\n const easingRotate = options.easing ?? linear;\n\n const initialDeg = options.initial ?? 0;\n const endDeg = options.end ?? 0;\n\n return {\n delay: options.delay ?? 0,\n duration: options.duration ?? 500,\n easing: linear,\n css: (t) =>\n {\n const rotateT = easingRotate(t);\n return `transform: rotate(${lerp(initialDeg, endDeg, rotateT)}deg)`;\n }\n };\n}\n\n/**\n * Combines rotate & fade transitions into a single transition. For options `easing` this is applied to both transitions,\n * however if provided `easingRotate` and / or `easingFade` will take precedence. The default easing is linear.\n *\n * Note: that when reversing the transition that time goes from `1 - 0`, so if specific options are applied for\n * rotating out transition then `end` and `initial` are swapped.\n *\n * @param {HTMLElement} node - The transition node.\n *\n * @param {object} options - Optional parameters.\n *\n * @param {number} [options.delay] - Delay in ms before start of transition.\n *\n * @param {number} [options.duration] - Total transition length in ms.\n *\n * @param {Function} [options.easing=linear] - The easing function to apply to both slide & fade transitions.\n *\n * @param {Function} [options.easingFade=linear] - The easing function to apply to the fade transition.\n *\n * @param {Function} [options.easingRotate=linear] - The easing function to apply to the rotate transition.\n *\n * @param {number} [options.end=0] - End rotation in degrees.\n *\n * @param {number} [options.initial=0] - Initial rotation in degrees.\n *\n * @returns {{duration: number, css: (function(*=): string), delay: number, easing: (x: number) => number}}\n * Transition object.\n */\nfunction rotateFade(node, options)\n{\n const easingFade = options.easingFade || options.easing || linear;\n const easingRotate = options.easingRotate || options.easing || linear;\n\n const fadeTransition = fade(node);\n\n const initialDeg = options.initial ?? 0;\n const endDeg = options.end ?? 0;\n\n return {\n delay: options.delay ?? 0,\n duration: options.duration ?? 500,\n easing: linear,\n css: (t) =>\n {\n const fadeT = easingFade(t);\n const rotateT = easingRotate(t);\n\n return `transform: rotate(${lerp(initialDeg, endDeg, rotateT)}deg); ${fadeTransition.css(fadeT, 1 - fadeT)}`;\n }\n };\n}\n\n/**\n * Combines slide & fade transitions into a single transition. For options `easing` this is applied to both transitions,\n * however if provided `easingSlide` and / or `easingFade` will take precedence. The default easing is linear.\n *\n * @param {HTMLElement} node - The transition node.\n *\n * @param {object} options - Optional parameters.\n *\n * @param {number} [options.delay] - Delay in ms before start of transition.\n *\n * @param {number} [options.duration] - Total transition length in ms.\n *\n * @param {Function} [options.easing=linear] - The easing function to apply to both slide & fade transitions.\n *\n * @param {Function} [options.easingFade=linear] - The easing function to apply to the fade transition.\n *\n * @param {Function} [options.easingSlide=linear] - The easing function to apply to the slide transition.\n *\n * @returns {{duration: number, css: (function(*=): string), delay: number, easing: (x: number) => number}}\n * Transition object.\n */\nfunction slideFade(node, options)\n{\n const fadeEasing = options.easingFade || options.easing || linear;\n const slideEasing = options.easingSlide || options.easing || linear;\n\n const fadeTransition = fade(node);\n const slideTransition = slide(node);\n\n return {\n delay: options.delay || 0,\n duration: options.duration || 500,\n easing: linear,\n css: (t) =>\n {\n const fadeT = fadeEasing(t);\n const slideT = slideEasing(t);\n return `${slideTransition.css(slideT, 1 - slideT)}; ${fadeTransition.css(fadeT, 1 - fadeT)}`;\n }\n };\n}\n\n/**\n * Converts a Svelte transition to an animation. Both transitions & animations use the same CSS / styles solution and\n * resulting data so wrap the transition function with the signature of an animation.\n *\n * @param {(node: Element, params?: object) => import('svelte/transition').TransitionConfig} fn - A Svelte transition\n * function.\n *\n * @returns {(node: Element, { from: DOMRect, to: DOMRect }, params?: object) =>\n * import('svelte/transition').TransitionConfig} Transition function converted to an animation.\n */\nfunction toAnimation(fn) {\n return (node, animations, params = {}) => fn(node, params);\n}\n\nconst s_DEFAULT_TRANSITION = () => void 0;\nconst s_DEFAULT_TRANSITION_OPTIONS = {};\n\nexport { rotate, rotateFade, s_DEFAULT_TRANSITION, s_DEFAULT_TRANSITION_OPTIONS, slideFade, toAnimation };\n//# sourceMappingURL=index.js.map\n","\n\n\n\n\n \n
\n\n\n","import { isUpdatableStore, isWritableStore } from '@typhonjs-fvtt/runtime/svelte/store';\nimport { styleParsePixels, debounce, hasSetter } from '@typhonjs-fvtt/runtime/svelte/util';\nimport { cubicOut } from 'svelte/easing';\n\n/**\n * Provides an action to always blur the element when any pointer up event occurs on the element.\n *\n * @param {HTMLElement} node - The node to handle always blur on pointer up.\n */\nfunction alwaysBlur(node)\n{\n function blur()\n {\n setTimeout(() => { if (document.activeElement === node) { node.blur(); } }, 0);\n }\n\n node.addEventListener('pointerup', blur);\n\n return {\n destroy: () => node.removeEventListener('pointerup', blur)\n };\n}\n\n/**\n * Provides an action to monitor the given HTMLElement node with `ResizeObserver` posting width / height changes\n * to the target in various ways depending on the shape of the target. The target can be one of the following and the\n * precedence order is listed from top to bottom:\n *\n * - has a `resizeObserved` function as attribute; offset then content width / height are passed as parameters.\n * - has a `setContentBounds` function as attribute; content width / height are passed as parameters.\n * - has a `setDimension` function as attribute; offset width / height are passed as parameters.\n * - target is an object; offset and content width / height attributes are directly set on target.\n * - target is a function; the function is invoked with offset then content width / height parameters.\n * - has a writable store `resizeObserved` as an attribute; updated with offset & content width / height.\n * - has an object 'stores' that has a writable store `resizeObserved` as an attribute; updated with offset &\n * content width / height.\n *\n * Note: Svelte currently uses an archaic IFrame based workaround to monitor offset / client width & height changes.\n * A more up to date way to do this is with ResizeObserver. To track when Svelte receives ResizeObserver support\n * monitor this issue: {@link https://github.com/sveltejs/svelte/issues/4233}\n *\n * Can-I-Use: {@link https://caniuse.com/resizeobserver}\n *\n * @param {HTMLElement} node - The node associated with the action.\n *\n * @param {ResizeObserverTarget} target - An object or function to update with observed width & height changes.\n *\n * @returns {{update: Function, destroy: Function}} The action lifecycle methods.\n * @see {@link https://github.com/sveltejs/svelte/issues/4233}\n */\nfunction resizeObserver(node, target)\n{\n ResizeObserverManager.add(node, target);\n\n return {\n update: (newTarget) =>\n {\n ResizeObserverManager.remove(node, target);\n target = newTarget;\n ResizeObserverManager.add(node, target);\n },\n\n destroy: () =>\n {\n ResizeObserverManager.remove(node, target);\n }\n };\n}\n\n/**\n * Provides a function that when invoked with an element updates the cached styles for each subscriber of the element.\n *\n * The style attributes cached to calculate offset height / width include border & padding dimensions. You only need\n * to update the cache if you change border or padding attributes of the element.\n *\n * @param {HTMLElement} el - An HTML element.\n */\nresizeObserver.updateCache = function(el)\n{\n if (!(el instanceof HTMLElement)) { throw new TypeError(`resizeObserverUpdate error: 'el' is not an HTMLElement.`); }\n\n const subscribers = s_MAP.get(el);\n\n if (Array.isArray(subscribers))\n {\n const computed = globalThis.getComputedStyle(el);\n\n // Cache styles first from any inline styles then computed styles defaulting to 0 otherwise.\n // Used to create the offset width & height values from the context box ResizeObserver provides.\n const borderBottom = styleParsePixels(el.style.borderBottom) ?? styleParsePixels(computed.borderBottom) ?? 0;\n const borderLeft = styleParsePixels(el.style.borderLeft) ?? styleParsePixels(computed.borderLeft) ?? 0;\n const borderRight = styleParsePixels(el.style.borderRight) ?? styleParsePixels(computed.borderRight) ?? 0;\n const borderTop = styleParsePixels(el.style.borderTop) ?? styleParsePixels(computed.borderTop) ?? 0;\n const paddingBottom = styleParsePixels(el.style.paddingBottom) ?? styleParsePixels(computed.paddingBottom) ?? 0;\n const paddingLeft = styleParsePixels(el.style.paddingLeft) ?? styleParsePixels(computed.paddingLeft) ?? 0;\n const paddingRight = styleParsePixels(el.style.paddingRight) ?? styleParsePixels(computed.paddingRight) ?? 0;\n const paddingTop = styleParsePixels(el.style.paddingTop) ?? styleParsePixels(computed.paddingTop) ?? 0;\n\n const additionalWidth = borderLeft + borderRight + paddingLeft + paddingRight;\n const additionalHeight = borderTop + borderBottom + paddingTop + paddingBottom;\n\n for (const subscriber of subscribers)\n {\n subscriber.styles.additionalWidth = additionalWidth;\n subscriber.styles.additionalHeight = additionalHeight;\n s_UPDATE_SUBSCRIBER(subscriber, subscriber.contentWidth, subscriber.contentHeight);\n }\n }\n};\n\n// Below is the static ResizeObserverManager ------------------------------------------------------------------------\n\nconst s_MAP = new Map();\n\n/**\n * Provides a static / single instance of ResizeObserver that can notify listeners in different ways.\n *\n * The action, {@link resizeObserver}, utilizes ResizeObserverManager for automatic registration and removal\n * via Svelte.\n */\nclass ResizeObserverManager\n{\n /**\n * Add an HTMLElement and ResizeObserverTarget instance for monitoring. Create cached style attributes for the\n * given element include border & padding dimensions for offset width / height calculations.\n *\n * @param {HTMLElement} el - The element to observe.\n *\n * @param {ResizeObserverTarget} target - A target that contains one of several mechanisms for updating resize data.\n */\n static add(el, target)\n {\n const updateType = s_GET_UPDATE_TYPE(target);\n\n if (updateType === 0)\n {\n throw new Error(`'target' does not match supported ResizeObserverManager update mechanisms.`);\n }\n\n const computed = globalThis.getComputedStyle(el);\n\n // Cache styles first from any inline styles then computed styles defaulting to 0 otherwise.\n // Used to create the offset width & height values from the context box ResizeObserver provides.\n const borderBottom = styleParsePixels(el.style.borderBottom) ?? styleParsePixels(computed.borderBottom) ?? 0;\n const borderLeft = styleParsePixels(el.style.borderLeft) ?? styleParsePixels(computed.borderLeft) ?? 0;\n const borderRight = styleParsePixels(el.style.borderRight) ?? styleParsePixels(computed.borderRight) ?? 0;\n const borderTop = styleParsePixels(el.style.borderTop) ?? styleParsePixels(computed.borderTop) ?? 0;\n const paddingBottom = styleParsePixels(el.style.paddingBottom) ?? styleParsePixels(computed.paddingBottom) ?? 0;\n const paddingLeft = styleParsePixels(el.style.paddingLeft) ?? styleParsePixels(computed.paddingLeft) ?? 0;\n const paddingRight = styleParsePixels(el.style.paddingRight) ?? styleParsePixels(computed.paddingRight) ?? 0;\n const paddingTop = styleParsePixels(el.style.paddingTop) ?? styleParsePixels(computed.paddingTop) ?? 0;\n\n const data = {\n updateType,\n target,\n\n // Stores most recent contentRect.width and contentRect.height values from ResizeObserver.\n contentWidth: 0,\n contentHeight: 0,\n\n // Convenience data for total border & padding for offset width & height calculations.\n styles: {\n additionalWidth: borderLeft + borderRight + paddingLeft + paddingRight,\n additionalHeight: borderTop + borderBottom + paddingTop + paddingBottom\n }\n };\n\n if (s_MAP.has(el))\n {\n const subscribers = s_MAP.get(el);\n subscribers.push(data);\n }\n else\n {\n s_MAP.set(el, [data]);\n }\n\n s_RESIZE_OBSERVER.observe(el);\n }\n\n /**\n * Removes all targets from monitoring when just an element is provided otherwise removes a specific target\n * from the monitoring map. If no more targets remain then the element is removed from monitoring.\n *\n * @param {HTMLElement} el - Element to remove from monitoring.\n *\n * @param {ResizeObserverTarget} [target] - A specific target to remove from monitoring.\n */\n static remove(el, target = void 0)\n {\n const subscribers = s_MAP.get(el);\n if (Array.isArray(subscribers))\n {\n const index = subscribers.findIndex((entry) => entry.target === target);\n if (index >= 0)\n {\n // Update target subscriber with undefined values.\n s_UPDATE_SUBSCRIBER(subscribers[index], void 0, void 0);\n\n subscribers.splice(index, 1);\n }\n\n // Remove element monitoring if last target removed.\n if (subscribers.length === 0)\n {\n s_MAP.delete(el);\n s_RESIZE_OBSERVER.unobserve(el);\n }\n }\n }\n}\n\n/**\n * Defines the various shape / update type of the given target.\n *\n * @type {Record}\n */\nconst s_UPDATE_TYPES = {\n none: 0,\n attribute: 1,\n function: 2,\n resizeObserved: 3,\n setContentBounds: 4,\n setDimension: 5,\n storeObject: 6,\n storesObject: 7\n};\n\nconst s_RESIZE_OBSERVER = new ResizeObserver((entries) =>\n{\n for (const entry of entries)\n {\n const subscribers = s_MAP.get(entry?.target);\n\n if (Array.isArray(subscribers))\n {\n const contentWidth = entry.contentRect.width;\n const contentHeight = entry.contentRect.height;\n\n for (const subscriber of subscribers)\n {\n s_UPDATE_SUBSCRIBER(subscriber, contentWidth, contentHeight);\n }\n }\n }\n});\n\n/**\n * Determines the shape of the target instance regarding valid update mechanisms to set width & height changes.\n *\n * @param {*} target - The target instance.\n *\n * @returns {number} Update type value.\n */\nfunction s_GET_UPDATE_TYPE(target)\n{\n if (target?.resizeObserved instanceof Function) { return s_UPDATE_TYPES.resizeObserved; }\n if (target?.setDimension instanceof Function) { return s_UPDATE_TYPES.setDimension; }\n if (target?.setContentBounds instanceof Function) { return s_UPDATE_TYPES.setContentBounds; }\n\n const targetType = typeof target;\n\n // Does the target have resizeObserved writable store?\n if ((targetType === 'object' || targetType === 'function'))\n {\n if (isUpdatableStore(target.resizeObserved))\n {\n return s_UPDATE_TYPES.storeObject;\n }\n\n // Now check for a child stores object which is a common TRL pattern for exposing stores.\n const stores = target?.stores;\n if (typeof stores === 'object' || typeof stores === 'function')\n {\n if (isUpdatableStore(stores.resizeObserved))\n {\n return s_UPDATE_TYPES.storesObject;\n }\n }\n }\n\n if (targetType === 'object') { return s_UPDATE_TYPES.attribute; }\n\n if (targetType === 'function') { return s_UPDATE_TYPES.function; }\n\n return s_UPDATE_TYPES.none;\n}\n\n/**\n * Updates a subscriber target with given content width & height values. Offset width & height is calculated from\n * the content values + cached styles.\n *\n * @param {object} subscriber - Internal data about subscriber.\n *\n * @param {number|undefined} contentWidth - ResizeObserver contentRect.width value or undefined.\n *\n * @param {number|undefined} contentHeight - ResizeObserver contentRect.height value or undefined.\n */\nfunction s_UPDATE_SUBSCRIBER(subscriber, contentWidth, contentHeight)\n{\n const styles = subscriber.styles;\n\n subscriber.contentWidth = contentWidth;\n subscriber.contentHeight = contentHeight;\n\n const offsetWidth = Number.isFinite(contentWidth) ? contentWidth + styles.additionalWidth : void 0;\n const offsetHeight = Number.isFinite(contentHeight) ? contentHeight + styles.additionalHeight : void 0;\n\n const target = subscriber.target;\n\n switch (subscriber.updateType)\n {\n case s_UPDATE_TYPES.attribute:\n target.contentWidth = contentWidth;\n target.contentHeight = contentHeight;\n target.offsetWidth = offsetWidth;\n target.offsetHeight = offsetHeight;\n break;\n\n case s_UPDATE_TYPES.function:\n target?.(offsetWidth, offsetHeight, contentWidth, contentHeight);\n break;\n\n case s_UPDATE_TYPES.resizeObserved:\n target.resizeObserved?.(offsetWidth, offsetHeight, contentWidth, contentHeight);\n break;\n\n case s_UPDATE_TYPES.setContentBounds:\n target.setContentBounds?.(contentWidth, contentHeight);\n break;\n\n case s_UPDATE_TYPES.setDimension:\n target.setDimension?.(offsetWidth, offsetHeight);\n break;\n\n case s_UPDATE_TYPES.storeObject:\n target.resizeObserved.update((object) =>\n {\n object.contentHeight = contentHeight;\n object.contentWidth = contentWidth;\n object.offsetHeight = offsetHeight;\n object.offsetWidth = offsetWidth;\n\n return object;\n });\n break;\n\n case s_UPDATE_TYPES.storesObject:\n target.stores.resizeObserved.update((object) =>\n {\n object.contentHeight = contentHeight;\n object.contentWidth = contentWidth;\n object.offsetHeight = offsetHeight;\n object.offsetWidth = offsetWidth;\n\n return object;\n });\n break;\n }\n}\n\n/**\n * @typedef {object | Function} ResizeObserverTarget\n *\n * @property {number} [contentHeight] -\n *\n * @property {number} [contentWidth] -\n *\n * @property {number} [offsetHeight] -\n *\n * @property {number} [offsetWidth] -\n *\n * @property {Writable | Function} [resizedObserver] - Either a function or a writable store.\n *\n * @property {Function} [setContentSize] - A function that is invoked with content width & height changes.\n *\n * @property {Function} [setDimension] - A function that is invoked with offset width & height changes.\n *\n * @property {{resizedObserver: Writable}} [stores] - An object with a writable store.\n */\n\n/**\n * Provides an action to save `scrollTop` of an element with a vertical scrollbar. This action should be used on the\n * scrollable element and must include a writable store that holds the active store for the current `scrollTop` value.\n * You may switch the stores externally and this action will set the `scrollTop` based on the newly set store. This is\n * useful for instance providing a select box that controls the scrollable container.\n *\n * @param {HTMLElement} element - The target scrollable HTML element.\n *\n * @param {import('svelte/store').Writable} store - A writable store that stores the element scrollTop.\n */\nfunction applyScrolltop(element, store)\n{\n if (!isWritableStore(store))\n {\n throw new TypeError(`applyScrolltop error: 'store' must be a writable Svelte store.`);\n }\n\n function storeUpdate(value)\n {\n if (!Number.isFinite(value)) { return; }\n\n // For some reason for scrollTop to take on first update from a new element setTimeout is necessary.\n setTimeout(() => element.scrollTop = value, 0);\n }\n\n let unsubscribe = store.subscribe(storeUpdate);\n\n const resizeControl = resizeObserver(element, debounce(() => {\n if (element.isConnected) { store.set(element.scrollTop); }\n }, 500));\n\n /**\n * Save target `scrollTop` to the current set store.\n *\n * @param {Event} event -\n */\n function onScroll(event)\n {\n store.set(event.target.scrollTop);\n }\n\n const debounceFn = debounce((e) => onScroll(e), 500);\n\n element.addEventListener('scroll', debounceFn);\n\n return {\n update: (newStore) =>\n {\n unsubscribe();\n store = newStore;\n\n if (!isWritableStore(store))\n {\n throw new TypeError(`applyScrolltop.update error: 'store' must be a writable Svelte store.`);\n }\n\n unsubscribe = store.subscribe(storeUpdate);\n },\n\n destroy: () =>\n {\n element.removeEventListener('scroll', debounceFn);\n unsubscribe();\n resizeControl.destroy();\n }\n };\n}\n\n/**\n * Provides an action to apply style properties provided as an object.\n *\n * @param {HTMLElement} node - Target element\n *\n * @param {object} properties - Key / value object of properties to set.\n *\n * @returns {Function} Update function.\n */\nfunction applyStyles(node, properties)\n{\n /** Sets properties on node. */\n function setProperties()\n {\n if (typeof properties !== 'object') { return; }\n\n for (const prop of Object.keys(properties))\n {\n node.style.setProperty(`${prop}`, properties[prop]);\n }\n }\n\n setProperties();\n\n return {\n update(newProperties)\n {\n properties = newProperties;\n setProperties();\n }\n };\n}\n\n/**\n * Provides an action to blur the element when any pointer down event occurs outside the element. This can be useful\n * for input elements including select to blur / unfocus the element when any pointer down occurs outside the element.\n *\n * @param {HTMLElement} node - The node to handle automatic blur on focus loss.\n */\nfunction autoBlur(node)\n{\n function blur() { document.body.removeEventListener('pointerdown', onPointerDown); }\n function focus() { document.body.addEventListener('pointerdown', onPointerDown); }\n\n /**\n * Blur the node if a pointer down event happens outside the node.\n * @param {PointerEvent} event\n */\n function onPointerDown(event)\n {\n if (event.target === node || node.contains(event.target)) { return; }\n\n if (document.activeElement === node) { node.blur(); }\n }\n\n node.addEventListener('blur', blur);\n node.addEventListener('focus', focus);\n\n return {\n destroy: () =>\n {\n document.body.removeEventListener('pointerdown', onPointerDown);\n node.removeEventListener('blur', blur);\n node.removeEventListener('focus', focus);\n }\n };\n}\n\n/**\n * Provides an action to apply a Position instance to a HTMLElement and invoke `position.parent`\n *\n * @param {HTMLElement} node - The node associated with the action.\n *\n * @param {Position} position - A position instance.\n *\n * @returns {{update: Function, destroy: Function}} The action lifecycle methods.\n */\nfunction applyPosition(node, position)\n{\n if (hasSetter(position, 'parent')) { position.parent = node; }\n\n return {\n update: (newPosition) =>\n {\n // Sanity case to short circuit update if positions are the same instance.\n if (newPosition === position && newPosition.parent === position.parent) { return; }\n\n if (hasSetter(position)) { position.parent = void 0; }\n\n position = newPosition;\n\n if (hasSetter(position, 'parent')) { position.parent = node; }\n },\n\n destroy: () => { if (hasSetter(position, 'parent')) { position.parent = void 0; } }\n };\n}\n\n/**\n * Provides an action to enable pointer dragging of an HTMLElement and invoke `position.set` on a given {@link Position}\n * instance provided. When the attached boolean store state changes the draggable action is enabled or disabled.\n *\n * @param {HTMLElement} node - The node associated with the action.\n *\n * @param {object} params - Required parameters.\n *\n * @param {Position} params.position - A position instance.\n *\n * @param {boolean} [params.active=true] - A boolean value; attached to a readable store.\n *\n * @param {number} [params.button=0] - MouseEvent button; {@link https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/button}.\n *\n * @param {Writable} [params.storeDragging] - A writable store that tracks \"dragging\" state.\n *\n * @param {boolean} [params.ease=true] - When true easing is enabled.\n *\n * @param {object} [params.easeOptions] - Gsap `to / `quickTo` vars object.\n *\n * @returns {{update: Function, destroy: Function}} The action lifecycle methods.\n */\nfunction draggable(node, { position, active = true, button = 0, storeDragging = void 0, ease = false,\n easeOptions = { duration: 0.1, ease: cubicOut } })\n{\n /**\n * Duplicate the app / Positionable starting position to track differences.\n *\n * @type {object}\n */\n let initialPosition = null;\n\n /**\n * Stores the initial X / Y on drag down.\n *\n * @type {object}\n */\n let initialDragPoint = {};\n\n /**\n * Stores the current dragging state and gates the move pointer as the dragging store is not\n * set until the first pointer move.\n *\n * @type {boolean}\n */\n let dragging = false;\n\n /**\n * Stores the quickTo callback to use for optimized tweening when easing is enabled.\n *\n * @type {quickToCallback}\n */\n let quickTo = position.animate.quickTo(['top', 'left'], easeOptions);\n\n /**\n * Remember event handlers associated with this action so they may be later unregistered.\n *\n * @type {object}\n */\n const handlers = {\n dragDown: ['pointerdown', (e) => onDragPointerDown(e), false],\n dragMove: ['pointermove', (e) => onDragPointerChange(e), false],\n dragUp: ['pointerup', (e) => onDragPointerUp(e), false]\n };\n\n /**\n * Activates listeners.\n */\n function activateListeners()\n {\n // Drag handlers\n node.addEventListener(...handlers.dragDown);\n node.classList.add('draggable');\n }\n\n /**\n * Removes listeners.\n */\n function removeListeners()\n {\n if (typeof storeDragging?.set === 'function') { storeDragging.set(false); }\n\n // Drag handlers\n node.removeEventListener(...handlers.dragDown);\n node.removeEventListener(...handlers.dragMove);\n node.removeEventListener(...handlers.dragUp);\n node.classList.remove('draggable');\n }\n\n if (active)\n {\n activateListeners();\n }\n\n /**\n * Handle the initial pointer down that activates dragging behavior for the positionable.\n *\n * @param {PointerEvent} event - The pointer down event.\n */\n function onDragPointerDown(event)\n {\n if (event.button !== button || !event.isPrimary) { return; }\n\n event.preventDefault();\n\n dragging = false;\n\n // Record initial position.\n initialPosition = position.get();\n initialDragPoint = { x: event.clientX, y: event.clientY };\n\n // Add move and pointer up handlers.\n node.addEventListener(...handlers.dragMove);\n node.addEventListener(...handlers.dragUp);\n\n node.setPointerCapture(event.pointerId);\n }\n\n /**\n * Move the positionable.\n *\n * @param {PointerEvent} event - The pointer move event.\n */\n function onDragPointerChange(event)\n {\n // See chorded button presses for pointer events:\n // https://www.w3.org/TR/pointerevents3/#chorded-button-interactions\n // TODO: Support different button configurations for PointerEvents.\n if ((event.buttons & 1) === 0)\n {\n onDragPointerUp(event);\n return;\n }\n\n if (event.button !== -1 || !event.isPrimary) { return; }\n\n event.preventDefault();\n\n // Only set store dragging on first move event.\n if (!dragging && typeof storeDragging?.set === 'function')\n {\n dragging = true;\n storeDragging.set(true);\n }\n\n /** @type {number} */\n const newLeft = initialPosition.left + (event.clientX - initialDragPoint.x);\n /** @type {number} */\n const newTop = initialPosition.top + (event.clientY - initialDragPoint.y);\n\n if (ease)\n {\n quickTo(newTop, newLeft);\n }\n else\n {\n s_POSITION_DATA.left = newLeft;\n s_POSITION_DATA.top = newTop;\n\n position.set(s_POSITION_DATA);\n }\n }\n\n /**\n * Finish dragging and set the final position and removing listeners.\n *\n * @param {PointerEvent} event - The pointer up event.\n */\n function onDragPointerUp(event)\n {\n event.preventDefault();\n\n dragging = false;\n if (typeof storeDragging?.set === 'function') { storeDragging.set(false); }\n\n node.removeEventListener(...handlers.dragMove);\n node.removeEventListener(...handlers.dragUp);\n }\n\n return {\n // The default of active being true won't automatically add listeners twice.\n update: (options) =>\n {\n if (typeof options.active === 'boolean')\n {\n active = options.active;\n if (active) { activateListeners(); }\n else { removeListeners(); }\n }\n\n if (typeof options.button === 'number')\n {\n button = options.button;\n }\n\n if (options.position !== void 0 && options.position !== position)\n {\n position = options.position;\n quickTo = position.animate.quickTo(['top', 'left'], easeOptions);\n }\n\n if (typeof options.ease === 'boolean') { ease = options.ease; }\n\n if (typeof options.easeOptions === 'object')\n {\n easeOptions = options.easeOptions;\n quickTo.options(easeOptions);\n }\n },\n\n destroy: () => removeListeners()\n };\n}\n\nclass DraggableOptions\n{\n #ease = false;\n\n #easeOptions = { duration: 0.1, ease: cubicOut };\n\n /**\n * Stores the subscribers.\n *\n * @type {(function(DraggableOptions): void)[]}\n */\n #subscriptions = [];\n\n constructor({ ease, easeOptions } = {})\n {\n // Define the following getters directly on this instance and make them enumerable. This allows them to be\n // picked up w/ `Object.assign`.\n Object.defineProperty(this, 'ease', {\n get: () => { return this.#ease; },\n set: (newEase) =>\n {\n if (typeof newEase !== 'boolean') { throw new TypeError(`'ease' is not a boolean.`); }\n\n this.#ease = newEase;\n this.#updateSubscribers();\n },\n enumerable: true\n });\n\n Object.defineProperty(this, 'easeOptions', {\n get: () => { return this.#easeOptions; },\n set: (newEaseOptions) =>\n {\n if (newEaseOptions === null || typeof newEaseOptions !== 'object')\n {\n throw new TypeError(`'easeOptions' is not an object.`);\n }\n\n if (newEaseOptions.duration !== void 0)\n {\n if (!Number.isFinite(newEaseOptions.duration))\n {\n throw new TypeError(`'easeOptions.duration' is not a finite number.`);\n }\n\n if (newEaseOptions.duration < 0) { throw new Error(`'easeOptions.duration' is less than 0.`); }\n\n this.#easeOptions.duration = newEaseOptions.duration;\n }\n\n if (newEaseOptions.ease !== void 0)\n {\n if (typeof newEaseOptions.ease !== 'function' && typeof newEaseOptions.ease !== 'string')\n {\n throw new TypeError(`'easeOptions.ease' is not a function or string.`);\n }\n\n this.#easeOptions.ease = newEaseOptions.ease;\n }\n\n this.#updateSubscribers();\n },\n enumerable: true\n });\n\n // Set default options.\n if (ease !== void 0) { this.ease = ease; }\n if (easeOptions !== void 0) { this.easeOptions = easeOptions; }\n }\n\n\n /**\n * @returns {number} Get ease duration\n */\n get easeDuration() { return this.#easeOptions.duration; }\n\n /**\n * @returns {string|Function} Get easing function value.\n */\n get easeValue() { return this.#easeOptions.ease; }\n\n\n /**\n * @param {number} duration - Set ease duration.\n */\n set easeDuration(duration)\n {\n if (!Number.isFinite(duration))\n {\n throw new TypeError(`'duration' is not a finite number.`);\n }\n\n if (duration < 0) { throw new Error(`'duration' is less than 0.`); }\n\n this.#easeOptions.duration = duration;\n this.#updateSubscribers();\n }\n\n /**\n * @param {string|Function} value - Get easing function value.\n */\n set easeValue(value)\n {\n if (typeof value !== 'function' && typeof value !== 'string')\n {\n throw new TypeError(`'value' is not a function or string.`);\n }\n\n this.#easeOptions.ease = value;\n this.#updateSubscribers();\n }\n\n /**\n * Resets all options data to default values.\n */\n reset()\n {\n this.#ease = false;\n this.#easeOptions = { duration: 0.1, ease: cubicOut };\n this.#updateSubscribers();\n }\n\n /**\n * Resets easing options to default values.\n */\n resetEase()\n {\n this.#easeOptions = { duration: 0.1, ease: cubicOut };\n this.#updateSubscribers();\n }\n\n /**\n *\n * @param {function(DraggableOptions): void} handler - Callback function that is invoked on update / changes.\n * Receives the DraggableOptions object / instance.\n *\n * @returns {(function(): void)} Unsubscribe function.\n */\n subscribe(handler)\n {\n this.#subscriptions.push(handler); // add handler to the array of subscribers\n\n handler(this); // call handler with current value\n\n // Return unsubscribe function.\n return () =>\n {\n const index = this.#subscriptions.findIndex((sub) => sub === handler);\n if (index >= 0) { this.#subscriptions.splice(index, 1); }\n };\n }\n\n #updateSubscribers()\n {\n const subscriptions = this.#subscriptions;\n\n // Early out if there are no subscribers.\n if (subscriptions.length > 0)\n {\n for (let cntr = 0; cntr < subscriptions.length; cntr++) { subscriptions[cntr](this); }\n }\n }\n}\n\n/**\n * Define a function to get a DraggableOptions instance.\n *\n * @returns {DraggableOptions} A new options instance.\n */\ndraggable.options = (options) => new DraggableOptions(options);\n\n/**\n * Used for direct call to `position.set`.\n *\n * @type {{top: number, left: number}}\n */\nconst s_POSITION_DATA = { left: 0, top: 0 };\n\nexport { alwaysBlur, applyPosition, applyScrolltop, applyStyles, autoBlur, draggable, resizeObserver };\n//# sourceMappingURL=index.js.map\n","/**\n * A helper to create a set of radio checkbox input elements in a named set.\n * The provided keys are the possible radio values while the provided values are human readable labels.\n *\n * @param {string} name The radio checkbox field name\n *\n * @param {object} choices A mapping of radio checkbox values to human readable labels\n *\n * @param {object} options Options which customize the radio boxes creation\n *\n * @param {string} options.checked Which key is currently checked?\n *\n * @param {boolean} options.localize Pass each label through string localization?\n *\n * @returns {string} HTML for radio boxes.\n *\n * @example The provided input data \n * let groupName = \"importantChoice\";\n * let choices = {a: \"Choice A\", b: \"Choice B\"};\n * let chosen = \"a\";\n *\n * @example The template HTML structure \n * \n */\nfunction radioBoxes(name, choices, options)\n{\n const checked = options['checked'] || null;\n const localize = options['localize'] || false;\n let html = '';\n\n for (let [key, label] of Object.entries(choices)) // eslint-disable-line prefer-const\n {\n if (localize) { label = game.i18n.localize(label); }\n const isChecked = checked === key;\n html += ` ${label} `;\n }\n\n return html;\n}\n\n/**\n * Converts the `selectOptions` Handlebars helper to be Svelte compatible. This is useful when initially converting\n * over an app to Svelte and for essential usage to several dialogs that mirror the core Foundry experience. For\n * an example of usage see {@link TJSFolderPermissions}.\n *\n * A helper to create a set of elements in a block based on a provided dictionary.\n * The provided keys are the option values while the provided values are human-readable labels.\n * This helper supports both single-select as well as multi-select input fields.\n *\n * @param {object} choices A mapping of radio checkbox values to human readable labels\n *\n * @param {object} options Helper options\n *\n * @param {string|string[]} [options.selected] Which key or array of keys that are currently selected?\n *\n * @param {boolean} [options.localize=false] Pass each label through string localization?\n *\n * @param {string} [options.blank] Add a blank option as the first option with this label\n *\n * @param {string} [options.nameAttr] Look up a property in the choice object values to use as the option value\n *\n * @param {string} [options.labelAttr] Look up a property in the choice object values to use as the option label\n *\n * @param {boolean} [options.inverted=false] Use the choice object value as the option value, and the key as the label\n * instead of vice-versa\n *\n * @returns {string} The HTML element(s).\n *\n * @example The provided input data \n * let choices = {a: 'Choice A', b: 'Choice B'};\n * let value = 'a';\n *\n * @example The template HTML structure \n * \n * {@html selectOptions(choices { selected: value, localize: true })}\n * \n *\n * @example The resulting HTML \n * \n * Choice A \n * Choice B \n * \n *\n * @example Using inverted \n * let choices = {'Choice A': 'a', 'Choice B': 'b'};\n * let value = 'a';\n *\n * @example The template HTML structure \n * \n * {@html selectOptions(choices, { selected: value, inverted: true })}\n * \n *\n * @example Using nameAttr and labelAttr with objects \n * let choices = {foo: {key: 'a', label: 'Choice A'}, bar: {key: 'b', label: 'Choice B'}};\n * let value = 'b';\n *\n * @example The template HTML structure \n * \n * {@html selectOptions(choices, { selected: value, nameAttr: 'key', labelAttr: 'label' })}\n * \n *\n * @example Using nameAttr and labelAttr with arrays \n * let choices = [{key: 'a', label: 'Choice A'}, {key: 'b', label: 'Choice B'}];\n * let value = 'b';\n *\n * @example The template HTML structure \n * \n * {@html selectOptions(choices, { selected: value, nameAttr: 'key', labelAttr: 'label' })}\n * \n */\nfunction selectOptions(choices, options)\n{\n const localize = options['localize'] ?? false;\n let selected = options['selected'] ?? null;\n const blank = options['blank'] ?? null;\n const nameAttr = options['nameAttr'];\n const labelAttr = options['labelAttr'];\n const inverted = !!options['inverted'];\n\n selected = selected instanceof Array ? selected.map(String) : [String(selected)];\n\n // Create an option\n const option = (name, label) =>\n {\n if (localize) { label = game.i18n.localize(label); }\n const isSelected = selected.includes(String(name));\n\n html += `${label} `;\n };\n\n // Create the options\n let html = '';\n if (blank !== null) { option('', blank); }\n\n // Options as an Array\n if (choices instanceof Array)\n {\n for (const choice of choices) { option(choice[nameAttr], choice[labelAttr]); }\n }\n\n // Choices as an Object\n else\n {\n for (const choice of Object.entries(choices))\n {\n let [key, value] = inverted ? choice.reverse() : choice;\n if (nameAttr) { key = value[nameAttr]; }\n if (labelAttr) { value = value[labelAttr]; }\n option(key, value);\n }\n }\n\n return html;\n}\n\n/**\n * Localize a string including variable formatting for input arguments. Provide a string ID which defines the localized\n * template. Variables can be included in the template enclosed in braces and will be substituted using those named\n * keys.\n *\n * @param {string} stringId - The string ID to translate.\n *\n * @param {object} [data] - Provided input data.\n *\n * @returns {string} The translated and formatted string\n */\nfunction localize(stringId, data)\n{\n const result = typeof data !== 'object' ? game.i18n.localize(stringId) : game.i18n.format(stringId, data);\n return result !== void 0 ? result : '';\n}\n\nexport { localize, radioBoxes, selectOptions };\n//# sourceMappingURL=index.js.map\n","\n\n\n\n\nnull}\n on:mousedown|capture|preventDefault|stopPropagation={()=>null}\n on:dblclick|capture|preventDefault|stopPropagation={()=>null}\n use:applyStyles={styles}\n class=\"header-button {button.class}\">\n {@html icon}{label}\n \n","\n\n{#key draggable}\n \n{/key}\n\n\n","\n\n\n \n
\n","\n\n\n\n\n \n \n {#if Array.isArray(allChildren)}\n \n {:else}\n \n {/if}\n \n \n
\n\n\n","\n\n \n\n\n {#if typeof content === 'string'}\n {@html content}\n {:else if dialogComponent}\n \n {/if}\n
\n\n{#if buttons.length}\n\n {#each buttons as button (button.id)}\n onClick(button)}\n class:default={button.id === currentButtonId}\n use:applyStyles={button.styles}>\n {#if button.icon}{@html button.icon}{/if}{button.label} \n \n {/each}\n
\n{/if}\n\n\n","\n\n\n\n{#if modal}\n \n \n \n \n \n{:else}\n \n \n \n{/if}\n","import {\n deepMerge,\n safeAccess,\n safeSet } from '@typhonjs-fvtt/runtime/svelte/util';\n\nexport class DialogData\n{\n /**\n * @type {SvelteApplication}\n */\n #application;\n\n /**\n * @param {SvelteApplication} application - The host Foundry application.\n */\n constructor(application)\n {\n this.#application = application;\n }\n\n /**\n * Provides a way to safely get this dialogs data given an accessor string which describes the\n * entries to walk. To access deeper entries into the object format the accessor string with `.` between entries\n * to walk.\n *\n * // TODO DOCUMENT the accessor in more detail.\n *\n * @param {string} accessor - The path / key to set. You can set multiple levels.\n *\n * @param {*} [defaultValue] - A default value returned if the accessor is not found.\n *\n * @returns {*} Value at the accessor.\n */\n get(accessor, defaultValue)\n {\n return safeAccess(this, accessor, defaultValue);\n }\n\n /**\n * @param {object} data - Merge provided data object into Dialog data.\n */\n merge(data)\n {\n deepMerge(this, data);\n\n const component = this.#application.svelte.component(0);\n if (component?.data) { component.data = this; }\n }\n\n /**\n * Provides a way to safely set this dialogs data given an accessor string which describes the\n * entries to walk. To access deeper entries into the object format the accessor string with `.` between entries\n * to walk.\n *\n * Automatically the dialog data will be updated in the associated DialogShell Svelte component.\n *\n * // TODO DOCUMENT the accessor in more detail.\n *\n * @param {string} accessor - The path / key to set. You can set multiple levels.\n *\n * @param {*} value - Value to set.\n *\n * @returns {boolean} True if successful.\n */\n set(accessor, value)\n {\n const success = safeSet(this, accessor, value);\n\n // If `this.options` modified then update the app options store.\n if (success)\n {\n const component = this.#application.svelte.component(0);\n if (component?.data) { component.data = this; }\n }\n\n return success;\n }\n}\n","import { DialogShell } from '@typhonjs-fvtt/runtime/svelte/component/core';\nimport { deepMerge } from '@typhonjs-fvtt/runtime/svelte/util';\n\nimport { DialogData } from './internal/DialogData.js';\nimport { SvelteApplication } from './SvelteApplication.js';\n\n/**\n * Provides a Foundry API compatible dialog alternative implemented w/ Svelte. There are several features including\n * a glasspane / modal option with various styling and transition capabilities.\n *\n * TODO: document all dialog data parameters; keep track of newly added like button -> styles, title; modal,\n * draggable, transition options, modal transitions\n */\nexport class TJSDialog extends SvelteApplication\n{\n /**\n * @type {DialogData}\n */\n #data;\n\n /**\n * @param {object} data - Dialog data.\n *\n * @param {object} [options] - SvelteApplication options.\n */\n constructor(data, options = {})\n {\n super(options);\n\n this.#data = new DialogData(this);\n this.data = data;\n\n /**\n * @member {object} dialogComponent - A getter to SvelteData to retrieve any mounted Svelte component as the\n * dialog content.\n *\n * @memberof GetSvelteData#\n * @readonly\n */\n Object.defineProperty(this.svelte, 'dialogComponent', {\n get: () => this.svelte?.applicationShell?.dialogComponent,\n });\n }\n\n /**\n * Default options\n *\n * @returns {object} Default options\n */\n static get defaultOptions()\n {\n return deepMerge(super.defaultOptions, {\n classes: ['dialog'],\n width: 400,\n height: 'auto',\n jQuery: true,\n svelte: {\n class: DialogShell,\n intro: true,\n target: document.body,\n props: function() { return { data: this.#data }; } // this context is the SvelteApplication when invoked.\n }\n });\n }\n\n /**\n * Returns the dialog data.\n *\n * @returns {DialogData} Dialog data.\n */\n get data() { return this.#data; }\n\n /**\n * Sets the dialog data; this is reactive.\n *\n * @param {object} data - Dialog data.\n */\n set data(data)\n {\n const descriptors = Object.getOwnPropertyDescriptors(this.#data);\n\n // Remove old data for all configurable descriptors.\n for (const descriptor in descriptors)\n {\n if (descriptors[descriptor].configurable) { delete this.#data[descriptor]; }\n }\n\n // Merge new data and perform a reactive update.\n this.#data.merge(data);\n }\n\n /**\n * Implemented only for backwards compatibility w/ default Foundry {@link Dialog} API.\n *\n * @param {JQuery} html - JQuery element for content area.\n */\n activateListeners(html)\n {\n super.activateListeners(html);\n\n if (this.data.render instanceof Function)\n {\n const actualHTML = typeof this.options.template === 'string' ? html :\n this.options.jQuery ? $(this.elementContent) : this.elementContent;\n\n this.data.render(this.options.jQuery ? actualHTML : actualHTML[0]);\n }\n }\n\n /**\n * Close the dialog and un-register references to it within UI mappings.\n * This function returns a Promise which resolves once the window closing animation concludes.\n *\n * @param {object} [options] - Optional parameters.\n *\n * @param {boolean} [options.force] - Force close regardless of render state.\n *\n * @returns {Promise} A Promise which resolves once the application is closed.\n */\n async close(options)\n {\n /**\n * Implemented only for backwards compatibility w/ default Foundry {@link Dialog} API.\n */\n if (this.data.close instanceof Function)\n {\n this.data.close(this.options.jQuery ? this.element : this.element[0]);\n }\n\n return super.close(options);\n }\n\n // ---------------------------------------------------------------------------------------------------------------\n\n /**\n * A helper factory method to create simple confirmation dialog windows which consist of simple yes/no prompts.\n * If you require more flexibility, a custom Dialog instance is preferred.\n *\n * @param {TJSConfirmConfig} config - Confirm dialog options.\n *\n * @returns {Promise<*>} A promise which resolves once the user makes a choice or closes the window.\n *\n * @example\n * let d = TJSDialog.confirm({\n * title: \"A Yes or No Question\",\n * content: \"Choose wisely.
\",\n * yes: () => console.log(\"You chose ... wisely\"),\n * no: () => console.log(\"You chose ... poorly\"),\n * defaultYes: false\n * });\n */\n static async confirm({ title, content, yes, no, render, defaultYes = true, rejectClose = false, options = {},\n buttons = {}, draggable = true, modal = false, modalOptions = {}, popOut = true, resizable = false, transition = {},\n zIndex } = {})\n {\n // Allow overwriting of default icon and labels.\n const mergedButtons = deepMerge({\n yes: {\n icon: ' ',\n label: game.i18n.localize('Yes')\n },\n no: {\n icon: ' ',\n label: game.i18n.localize('No'),\n }\n }, buttons);\n\n return new Promise((resolve, reject) =>\n {\n const dialog = new this({\n title,\n content,\n render,\n draggable,\n modal,\n modalOptions,\n popOut,\n resizable,\n transition,\n zIndex,\n buttons: deepMerge(mergedButtons, {\n yes: {\n callback: (html) =>\n {\n const result = yes ? yes(html) : true;\n resolve(result);\n }\n },\n no: {\n callback: (html) =>\n {\n const result = no ? no(html) : false;\n resolve(result);\n }\n }\n }),\n default: defaultYes ? \"yes\" : \"no\",\n close: () =>\n {\n if (rejectClose) { reject('The confirmation Dialog was closed without a choice being made.'); }\n else { resolve(null); }\n },\n }, options);\n dialog.render(true);\n });\n }\n\n /**\n * A helper factory method to display a basic \"prompt\" style Dialog with a single button\n *\n * @param {TJSPromptConfig} config - Prompt dialog options.\n *\n * @returns {Promise<*>} The returned value from the provided callback function, if any\n */\n static async prompt({ title, content, label, callback, render, rejectClose = false, options = {}, draggable = true,\n icon = ' ', modal = false, modalOptions = {}, popOut = true, resizable = false,\n transition = {}, zIndex } = {})\n {\n return new Promise((resolve, reject) =>\n {\n const dialog = new this({\n title,\n content,\n render,\n draggable,\n modal,\n modalOptions,\n popOut,\n resizable,\n transition,\n zIndex,\n buttons: {\n ok: {\n icon,\n label,\n callback: (html) =>\n {\n const result = callback ? callback(html) : null;\n resolve(result);\n }\n },\n },\n default: 'ok',\n close: () =>\n {\n if (rejectClose)\n {\n reject(new Error('The Dialog prompt was closed without being accepted.'));\n }\n else { resolve(null); }\n },\n }, options);\n dialog.render(true);\n });\n }\n}\n\n/**\n * @typedef TJSConfirmConfig - Configuration options for the confirm dialog.\n *\n * @property {string} title - The confirmation window title\n *\n * @property {string} content - The confirmation message\n *\n * @property {Function} [yes] - Callback function upon yes\n *\n * @property {Function} [no] - Callback function upon no\n *\n * @property {Function} [render] - A function to call when the dialog is rendered\n *\n * @property {boolean} [defaultYes=true] - Make \"yes\" the default choice?\n *\n * @property {boolean} [rejectClose=false] - Reject the Promise if the Dialog is closed without making a choice.\n *\n * @property {object} [options={}] - Additional rendering options passed to the Dialog\n *\n * @property {object} [buttons={}] - Provides a button override that is merged with default buttons.\n *\n * @property {boolean} [draggable=true] - The dialog is draggable when true.\n *\n * @property {boolean} [modal=false] - When true a modal dialog is displayed.\n *\n * @property {object} [modalOptions] - Additional options for modal dialog display.\n *\n * @property {boolean} [popOut=true] - When true the dialog is a pop out Application.\n *\n * @property {boolean} [resizable=false] - When true the dialog is resizable.\n *\n * @property {object} [transition] - Transition options for the dialog.\n *\n * @property {number|null} [zIndex] - A specific z-index for the dialog.\n */\n\n/**\n * @typedef TJSPromptConfig - Configuration options for the confirm dialog.\n *\n * @property {string} title - The confirmation window title\n *\n * @property {string} content - The confirmation message\n *\n * @property {string} [label] - The confirmation button text.\n *\n * @property {Function} [callback] - A callback function to fire when the button is clicked.\n *\n * @property {Function} [render] - A function to call when the dialog is rendered.\n *\n * @property {boolean} [rejectClose=false] - Reject the Promise if the Dialog is closed without making a choice.\n *\n * @property {object} [options={}] - Additional application options passed to the TJSDialog.\n *\n * @property {boolean} [draggable=true] - The dialog is draggable when true.\n *\n * @property {string} [icon=\" \"] - Set another icon besides `fa-check` for button.\n *\n * @property {boolean} [modal=false] - When true a modal dialog is displayed.\n *\n * @property {object} [modalOptions] - Additional options for modal dialog display.\n *\n * @property {boolean} [popOut=true] - When true the dialog is a pop out Application.\n *\n * @property {boolean} [resizable=false] - When true the dialog is resizable.\n *\n * @property {object} [transition] - Transition options for the dialog.\n *\n * @property {number|null} [zIndex] - A specific z-index for the dialog.\n */\n","\r\n\r\n\r\n {#if showImage}\r\n
\r\n
\r\n
\r\n {/if}\r\n {#if showInput}\r\n
\r\n {/if}\r\n
\r\n
\r\n\r\n","import CONSTANTS from \"../constants/constants.js\";\r\nimport * as Utilities from \"./utilities.js\"\r\nimport * as PileUtilities from \"./pile-utilities.js\"\r\nimport { setSimilarityProperties } from \"./utilities.js\";\r\n\r\n/**\r\n * Gets the players that can interact with this item pile\r\n *\r\n * @param {Actor|TokenDocument|String} target\r\n * @returns {Array}\r\n */\r\nexport function getPlayersForItemPile(target) {\r\n const targetActor = Utilities.getActor(target);\r\n if (!PileUtilities.isValidItemPile(targetActor)) return [];\r\n const pileData = PileUtilities.getActorFlagData(targetActor);\r\n return Array.from(game.users).filter(u => (u.active || !pileData.activePlayers) && u.character);\r\n}\r\n\r\n/**\r\n * Retrieves an item pile's sharing data\r\n *\r\n * @param {Actor|TokenDocument|String} target\r\n * @returns {Object}\r\n */\r\nexport function getItemPileSharingData(target) {\r\n const targetActor = Utilities.getActor(target);\r\n return foundry.utils.duplicate(getProperty(targetActor.data, CONSTANTS.FLAGS.SHARING) ?? {});\r\n}\r\n\r\n/**\r\n * Updates an item pile's sharing data\r\n *\r\n * @param {Actor|TokenDocument|String} target\r\n * @param {Object} incomingSharingData\r\n * @returns {Promise}\r\n */\r\nexport function updateItemPileSharingData(target, incomingSharingData) {\r\n const targetActor = Utilities.getActor(target);\r\n const currentSharingData = getItemPileSharingData(targetActor);\r\n const newSharingData = foundry.utils.mergeObject(currentSharingData, incomingSharingData);\r\n return targetActor.update({\r\n [CONSTANTS.FLAGS.SHARING]: newSharingData\r\n });\r\n}\r\n\r\n/**\r\n * Clears an item pile's sharing data\r\n *\r\n * @param {Actor|TokenDocument|String} target\r\n * @returns {Promise}\r\n */\r\nexport function clearItemPileSharingData(target) {\r\n const targetActor = Utilities.getActor(target);\r\n return targetActor.update({\r\n [CONSTANTS.FLAGS.SHARING]: null\r\n });\r\n}\r\n\r\n/**\r\n * Merges and resolves existing sharing data on a given item pile\r\n *\r\n * @param {String} sourceUuid\r\n * @param {String} targetUuid\r\n * @param {Array} [items]\r\n * @param {Array} [attributes]\r\n */\r\nexport async function setItemPileSharingData(sourceUuid, targetUuid, { items = [], attributes = [] } = {}) {\r\n\r\n const sourceActor = Utilities.getActor(sourceUuid);\r\n const targetActor = Utilities.getActor(targetUuid);\r\n\r\n const sourceIsItemPile = PileUtilities.isValidItemPile(sourceActor);\r\n const targetIsItemPile = PileUtilities.isValidItemPile(targetActor);\r\n\r\n // If both the source and target are item piles, we want to ignore this execution\r\n if (sourceIsItemPile && targetIsItemPile) return;\r\n\r\n if (items.length) {\r\n items = items.map(itemData => {\r\n setProperty(itemData.item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, Math.abs(itemData.quantity));\r\n return itemData.item;\r\n })\r\n }\r\n\r\n if (!Array.isArray(attributes) && typeof attributes === \"object\") {\r\n attributes = Object.entries(attributes).map(entry => {\r\n return {\r\n path: entry[0],\r\n quantity: Math.abs(entry[1])\r\n }\r\n })\r\n }\r\n\r\n if (sourceIsItemPile) {\r\n\r\n if (PileUtilities.isItemPileEmpty(sourceIsItemPile)) {\r\n return clearItemPileSharingData(sourceIsItemPile);\r\n }\r\n\r\n const sharingData = addToItemPileSharingData(sourceActor, targetActor.uuid, { items, attributes });\r\n return updateItemPileSharingData(sourceActor, sharingData);\r\n\r\n }\r\n\r\n const sharingData = removeFromItemPileSharingData(targetActor, sourceActor.uuid, { items, attributes });\r\n return updateItemPileSharingData(targetActor, sharingData);\r\n\r\n}\r\n\r\nexport function addToItemPileSharingData(itemPile, actorUuid, {\r\n sharingData = false,\r\n items = [],\r\n attributes = []\r\n} = {}) {\r\n\r\n const pileData = PileUtilities.getActorFlagData(itemPile);\r\n\r\n let pileSharingData = {};\r\n if (!sharingData && ((pileData.shareItemsEnabled && items.length) || (pileData.shareCurrenciesEnabled && attributes.length))) {\r\n pileSharingData = getItemPileSharingData(itemPile);\r\n }\r\n\r\n if (pileData.shareItemsEnabled && items.length) {\r\n\r\n if (!pileSharingData.items) {\r\n pileSharingData.items = [];\r\n }\r\n\r\n for (const item of items) {\r\n\r\n let existingItem = Utilities.findSimilarItem(pileSharingData.items, item);\r\n\r\n if (!existingItem) {\r\n let itemIndex = pileSharingData.items.push(Utilities.setSimilarityProperties({\r\n actors: [{ uuid: actorUuid, quantity: 0 }]\r\n }, item))\r\n existingItem = pileSharingData.items[itemIndex - 1];\r\n } else if (!existingItem.actors) {\r\n existingItem.actors = [];\r\n existingItem._id = item.id;\r\n }\r\n\r\n let actorData = existingItem.actors.find(data => data.uuid === actorUuid);\r\n\r\n const itemQuantity = Utilities.getItemQuantity(item);\r\n if (!actorData) {\r\n if (itemQuantity > 0) {\r\n existingItem.actors.push({ uuid: actorUuid, quantity: itemQuantity })\r\n }\r\n } else {\r\n actorData.quantity += itemQuantity;\r\n if (actorData.quantity <= 0) {\r\n existingItem.actors.splice(existingItem.actors.indexOf(actorData), 1);\r\n }\r\n if (existingItem.actors.length === 0) {\r\n pileSharingData.items.splice(pileSharingData.items.indexOf(existingItem), 1)\r\n }\r\n }\r\n\r\n }\r\n\r\n }\r\n\r\n if (pileData.shareCurrenciesEnabled && attributes.length) {\r\n\r\n if (!pileSharingData.attributes) {\r\n pileSharingData.attributes = [];\r\n }\r\n\r\n for (const attribute of attributes) {\r\n\r\n let existingCurrency = pileSharingData.attributes.find(sharingCurrency => sharingCurrency.path === attribute.path);\r\n\r\n if (!existingCurrency) {\r\n let itemIndex = pileSharingData.attributes.push({\r\n path: attribute.path,\r\n actors: [{ uuid: actorUuid, quantity: 0 }]\r\n })\r\n existingCurrency = pileSharingData.attributes[itemIndex - 1];\r\n } else {\r\n if (!existingCurrency.actors) {\r\n existingCurrency.actors = [];\r\n }\r\n }\r\n\r\n let actorData = existingCurrency.actors.find(data => data.uuid === actorUuid);\r\n\r\n if (!actorData) {\r\n if (attribute.quantity > 0) {\r\n existingCurrency.actors.push({ uuid: actorUuid, quantity: attribute.quantity })\r\n }\r\n } else {\r\n actorData.quantity += attribute.quantity;\r\n if (actorData.quantity <= 0) {\r\n existingCurrency.actors.splice(existingCurrency.actors.indexOf(actorData), 1);\r\n }\r\n if (existingCurrency.actors.length === 0) {\r\n pileSharingData.attributes.splice(pileSharingData.attributes.indexOf(existingCurrency), 1)\r\n }\r\n }\r\n }\r\n }\r\n\r\n\r\n return pileSharingData;\r\n\r\n}\r\n\r\nexport function removeFromItemPileSharingData(itemPile, actorUuid, { items = [], attributes = [] } = {}) {\r\n\r\n items = items.map(item => {\r\n setProperty(item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, Utilities.getItemQuantity(item) * -1)\r\n return item;\r\n });\r\n\r\n attributes = attributes.map(attribute => {\r\n attribute.quantity = attribute.quantity * -1;\r\n return attribute;\r\n });\r\n\r\n return addToItemPileSharingData(itemPile, actorUuid, { items, attributes });\r\n\r\n}\r\n\r\nexport function getItemSharesLeftForActor(pile, item, recipient, { currentQuantity = null, floor = null, players = null, shareData = null }={}) {\r\n\r\n if(item instanceof String){\r\n item = pile.items.get(item);\r\n }\r\n let previouslyTaken = 0;\r\n let recipientUuid = Utilities.getUuid(recipient);\r\n currentQuantity = currentQuantity ?? Utilities.getItemQuantity(item);\r\n let totalShares = currentQuantity;\r\n\r\n shareData = shareData ?? getItemPileSharingData(pile);\r\n if (shareData?.items?.length) {\r\n const foundItem = Utilities.findSimilarItem(shareData.items, item);\r\n if (foundItem) {\r\n totalShares = foundItem.actors.reduce((acc, actor) => acc + actor.quantity, currentQuantity);\r\n const quantityTakenBefore = foundItem.actors.find(actor => actor.uuid === recipientUuid);\r\n previouslyTaken = quantityTakenBefore ? quantityTakenBefore.quantity : 0;\r\n }\r\n }\r\n\r\n players = players ?? getPlayersForItemPile(pile).length;\r\n let totalActorShare = totalShares / players;\r\n if (!Number.isInteger(totalActorShare) && !floor) {\r\n totalActorShare += 1;\r\n }\r\n\r\n return Math.max(0, Math.min(currentQuantity, Math.floor(totalActorShare - previouslyTaken)));\r\n\r\n}\r\n\r\nexport function getAttributeSharesLeftForActor(pile, path, recipient, { currentQuantity = null, floor = null, players = null, shareData = null }={}) {\r\n\r\n let previouslyTaken = 0;\r\n let recipientUuid = Utilities.getUuid(recipient);\r\n currentQuantity = currentQuantity ?? Number(getProperty(pile.data, path) ?? 0);\r\n let totalShares = currentQuantity;\r\n\r\n shareData = shareData ?? getItemPileSharingData(pile);\r\n if (shareData?.attributes?.length) {\r\n const existingCurrency = shareData.attributes.find(storedCurrency => storedCurrency.path === path);\r\n if (existingCurrency) {\r\n totalShares = existingCurrency.actors.reduce((acc, actor) => acc + actor.quantity, currentQuantity);\r\n\r\n const quantityTakenBefore = existingCurrency?.actors?.find(actor => actor.uuid === recipientUuid);\r\n previouslyTaken = quantityTakenBefore ? quantityTakenBefore.quantity : 0;\r\n }\r\n }\r\n\r\n players = players ?? getPlayersForItemPile(pile).length;\r\n let totalActorShare = totalShares / players;\r\n if (!Number.isInteger(totalActorShare) && !floor) {\r\n totalActorShare += 1;\r\n }\r\n\r\n return Math.max(0, Math.min(currentQuantity, Math.floor(totalActorShare - previouslyTaken)));\r\n\r\n}","\r\n\r\n\r\n \r\n \r\n
\r\n\r\n","\r\n\r\n\r\n\r\n\r\n\r\n \r\n\r\n \r\n\r\n\r\n","import PriceModifiersShell from './price-modifiers-editor.svelte';\r\nimport { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\n\r\nexport default class PriceModifiersEditor extends SvelteApplication {\r\n \r\n constructor(priceModifiers, options) {\r\n \r\n priceModifiers = priceModifiers.map(data => {\r\n data.actor = game.actors.get(data.actor);\r\n if (!data.actor) return false;\r\n return data;\r\n }).filter(Boolean);\r\n \r\n super({\r\n svelte: {\r\n class: PriceModifiersShell,\r\n target: document.body,\r\n props: {\r\n priceModifiers\r\n }\r\n },\r\n close: () => this.options.resolve?.(false),\r\n ...options\r\n });\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n title: game.i18n.localize(\"ITEM-PILES.Applications.PriceModifiersEditor.Title\"),\r\n width: 600,\r\n height: \"auto\",\r\n classes: [\"item-piles-app\"]\r\n })\r\n }\r\n \r\n static async show(data = false, options = {}) {\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(data, options).render(true, { focus: true });\r\n })\r\n }\r\n \r\n}","\r\n\r\n\r\n \r\n
","\r\n\r\n\r\n \r\n
Primary
\r\n
Name
\r\n
Exchange
\r\n
Short
\r\n
Icon
\r\n
Data
\r\n
\r\n
\r\n \r\n {#if isHovering}\r\n
Drop to add
\r\n {/if}\r\n {#if !currencies.length}\r\n
\r\n
\r\n Drop an item or click the plus button to get started!\r\n
\r\n
\r\n {/if}\r\n {#each currencies as item, index (item.id)}\r\n
\r\n
store.setPrimary(index)}/>
\r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n {#if item.type === \"attribute\"}\r\n \r\n {:else}\r\n store.editItem(index)}>\r\n View item\r\n \r\n {/if}\r\n
\r\n
\r\n store.removeEntry(index)}>\r\n \r\n \r\n
\r\n
\r\n {/each}\r\n
\r\n \r\n\r\n","import { writable, get } from 'svelte/store';\r\nimport * as Utilities from \"../../../helpers/utilities.js\";\r\nimport CONSTANTS from \"../../../constants/constants.js\";\r\nimport * as Helpers from \"../../../helpers/helpers.js\";\r\nimport { localize } from \"@typhonjs-fvtt/runtime/svelte/helper\";\r\n\r\nexport default class CurrencyStore {\r\n \r\n constructor(data) {\r\n this.currencies = writable(data.map((entry, index) => {\r\n return {\r\n ...entry,\r\n index,\r\n id: entry.data?.path ?? entry.data?._id ?? randomID()\r\n }\r\n }));\r\n }\r\n \r\n setPrimary(index) {\r\n const currencies = get(this.currencies);\r\n currencies.forEach((entry, entryIndex) => {\r\n entry.primary = entryIndex === index;\r\n });\r\n this.currencies.set(currencies);\r\n }\r\n \r\n sortCurrencies() {\r\n const currencies = get(this.currencies);\r\n currencies.sort((a, b) => {\r\n return b.exchangeRate - a.exchangeRate;\r\n });\r\n this.currencies.set(currencies);\r\n }\r\n \r\n addAttribute() {\r\n const currencies = get(this.currencies);\r\n this.currencies.set([...currencies, {\r\n type: \"attribute\",\r\n name: \"New Attribute\",\r\n img: \"\",\r\n abbreviation: \"{#}N\",\r\n data: {\r\n path: \"\"\r\n },\r\n primary: !currencies.length,\r\n exchangeRate: 1\r\n }]);\r\n this.sortCurrencies();\r\n }\r\n \r\n async addItem(data) {\r\n \r\n let uuid = false;\r\n if (data.pack) {\r\n uuid = \"Compendium\" + data.pack + \".\" + data.id;\r\n }\r\n \r\n let item = await Item.implementation.fromDropData(data);\r\n let itemData = item.toObject();\r\n \r\n if (!itemData) {\r\n console.error(data);\r\n throw Helpers.custom_error(\"Something went wrong when dropping this item!\")\r\n }\r\n \r\n let currencies = get(this.currencies);\r\n \r\n const itemCurrencies = currencies.map(entry => entry.data?.item ?? {});\r\n const foundItem = Utilities.findSimilarItem(itemCurrencies, itemData);\r\n \r\n if (foundItem) {\r\n const index = itemCurrencies.indexOf(foundItem);\r\n currencies[index].data = {\r\n uuid,\r\n item: itemData\r\n }\r\n Helpers.custom_notify(`Updated item data for ${localize(currencies[index].name)} (item name ${itemData.name})`)\r\n } else {\r\n currencies = [...currencies, {\r\n id: randomID(),\r\n type: \"item\",\r\n name: itemData.name,\r\n img: itemData.img,\r\n abbreviation: \"{#} \" + itemData.name,\r\n data: {\r\n uuid,\r\n item: itemData\r\n },\r\n primary: !currencies.length,\r\n exchangeRate: 1\r\n }];\r\n }\r\n this.currencies.set(currencies);\r\n this.sortCurrencies();\r\n }\r\n \r\n async editItem(index) {\r\n const currencies = get(this.currencies);\r\n const data = currencies[index].data;\r\n let item;\r\n if (data.uuid) {\r\n item = await fromUuid(data.uuid);\r\n } else {\r\n let itemData = data.itemData;\r\n if (itemData._id) delete itemData._id;\r\n if (itemData.permission) delete itemData._id;\r\n const items = Array.from(game.items);\r\n item = Utilities.findSimilarItem(items, itemData);\r\n if (!item) {\r\n setProperty(itemData, CONSTANTS.FLAGS.TEMPORARY_ITEM, true);\r\n item = await Item.implementation.create(itemData);\r\n Helpers.custom_notify(`An item has been created for ${item.name} - drag and drop it into the list to update the stored item data`)\r\n }\r\n }\r\n item.sheet.render(true);\r\n }\r\n \r\n removeEntry(index) {\r\n const currencies = get(this.currencies);\r\n currencies.splice(index, 1);\r\n this.currencies.set(currencies);\r\n }\r\n \r\n export() {\r\n return get(this.currencies);\r\n }\r\n \r\n}","\r\n\r\n\r\n\r\n\r\n\r\n \r\n\r\n \r\n\r\n\r\n","import CurrenciesEditorShell from './currencies-editor-shell.svelte';\r\nimport { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\n\r\nexport default class CurrenciesEditor extends SvelteApplication {\r\n \r\n constructor(data = false, options = {}) {\r\n super({\r\n svelte: {\r\n class: CurrenciesEditorShell,\r\n target: document.body,\r\n props: {\r\n data\r\n }\r\n },\r\n close: () => this.options.resolve?.(null),\r\n ...options\r\n });\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n title: game.i18n.localize(\"ITEM-PILES.Applications.CurrenciesEditor.Title\"),\r\n width: 630,\r\n height: \"auto\",\r\n classes: [\"item-piles-app\"]\r\n })\r\n }\r\n \r\n static async show(data = false, options = {}) {\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(data, options).render(true, { focus: true });\r\n })\r\n }\r\n}","\r\n\r\n\r\n\r\n\r\n\r\n \r\n\r\n \r\n\r\n\r\n","import ItemFiltersShell from './item-filters-editor.svelte';\r\nimport { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\n\r\nexport default class ItemFiltersEditor extends SvelteApplication {\r\n \r\n constructor(item, options) {\r\n super({\r\n title: \"ITEM-PILES.Applications.FilterEditor.Title\",\r\n svelte: {\r\n class: ItemFiltersShell,\r\n target: document.body,\r\n props: {\r\n item\r\n }\r\n },\r\n close: () => this.options.resolve(null),\r\n ...options\r\n });\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n title: game.i18n.localize(\"ITEM-PILES.Applications.FilterEditor.Title\"),\r\n width: 400,\r\n height: \"auto\",\r\n classes: [\"item-piles-app\"]\r\n })\r\n }\r\n \r\n static async show(item, options = {}) {\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(item, options).render(true, { focus: true });\r\n })\r\n }\r\n}","\r\n\r\n\r\n {#each tabs.filter(tab => !tab.hidden) as tab, index (tab.value)}\r\n {#if separateElements && index > 0}\r\n
\r\n {/if}\r\n { activeTab = tab.value}}\r\n class=\"item item-piles-flexrow item-piles-clickable-link\"\r\n class:underscore={underscore}\r\n class:active={activeTab === tab.value}\r\n data-tab=\"rest\">\r\n {#if tab.icon}
{/if}\r\n {localize(tab.label)}\r\n {#if tab.highlight}\r\n
\r\n {/if}\r\n
\r\n {/each}\r\n \r\n\r\n\r\n","import CONSTANTS from \"./constants.js\";\r\n\r\nconst prefix = (string) => (strings, ...expressions) => `${string}-${strings.reduce((a, c, i) => a + expressions[i - 1] + c)}`\r\nconst module = prefix(CONSTANTS.MODULE_NAME);\r\n\r\nconst HOOKS = {\r\n READY: module`ready`,\r\n PRE_TRANSFER_EVERYTHING: module`preTransferEverything`,\r\n TRANSFER_EVERYTHING: module`transferEverything`,\r\n PRE_OPEN_INTERFACE: module`preOpenInterface`,\r\n OPEN_INTERFACE: module`openInterface`,\r\n PRE_CLOSE_INTERFACE: module`preCloseInterface`,\r\n CLOSE_INTERFACE: module`closeInterface`,\r\n PILE: {\r\n PRE_CREATE: module`preCreateItemPile`,\r\n CREATE: module`createItemPile`,\r\n PRE_UPDATE: module`preUpdateItemPile`,\r\n UPDATE: module`updateItemPile`,\r\n PRE_DELETE: module`preDeleteItemPile`,\r\n DELETE: module`deleteItemPile`,\r\n PRE_CLOSE: module`preCloseItemPile`,\r\n CLOSE: module`closeItemPile`,\r\n PRE_OPEN: module`preOpenItemPile`,\r\n OPEN: module`openItemPile`,\r\n PRE_LOCK: module`preLockItemPile`,\r\n LOCK: module`lockItemPile`,\r\n PRE_UNLOCK: module`preUnlockItemPile`,\r\n UNLOCK: module`unlockItemPile`,\r\n PRE_RATTLE: module`preRattleItemPile`,\r\n RATTLE: module`rattleItemPile`,\r\n PRE_TURN_INTO: module`preTurnIntoItemPiles`,\r\n TURN_INTO: module`turnIntoItemPiles`,\r\n PRE_REVERT_FROM: module`preRevertFromItemPiles`,\r\n REVERT_FROM: module`revertFromItemPiles`,\r\n PRE_SPLIT_INVENTORY: module`preSplitItemPileContent`,\r\n SPLIT_INVENTORY: module`splitItemPileContent`,\r\n },\r\n ITEM: {\r\n PRE_DROP_DETERMINED: module`preDropItemDetermined`,\r\n PRE_DROP: module`preDropItem`,\r\n DROP: module`dropItem`,\r\n PRE_TRANSFER: module`preTransferItems`,\r\n TRANSFER: module`transferItems`,\r\n PRE_ADD: module`preAddItems`,\r\n ADD: module`addItems`,\r\n PRE_REMOVE: module`preRemoveItems`,\r\n REMOVE: module`removeItems`,\r\n PRE_TRANSFER_ALL: module`preTransferAllItems`,\r\n TRANSFER_ALL: module`transferAllItems`,\r\n PRE_TRADE: module`preTradeItems`,\r\n PRE_CALC_TRADE: module`preCalculateTradeItems`,\r\n TRADE: module`tradeItems`,\r\n },\r\n ATTRIBUTE: {\r\n PRE_TRANSFER: module`preTransferAttributes`,\r\n TRANSFER: module`transferAttributes`,\r\n PRE_ADD: module`preAddAttributes`,\r\n ADD: module`addAttributes`,\r\n PRE_REMOVE: module`preRemoveAttributes`,\r\n REMOVE: module`removeAttributes`,\r\n PRE_TRANSFER_ALL: module`preTransferAllAttributes`,\r\n TRANSFER_ALL: module`transferAllAttributes`,\r\n },\r\n TRADE: {\r\n STARTED: module`tradeStarted`,\r\n COMPLETE: module`tradeComplete`\r\n }\r\n}\r\n\r\nexport default HOOKS;","import CONSTANTS from \"./constants/constants.js\";\r\nimport * as Utilities from \"./helpers/utilities.js\";\r\nimport PrivateAPI from \"./API/private-api.js\";\r\n\r\nexport const hotkeyActionState = {\r\n get openPileInventory() {\r\n return (!hotkeyState.ctrlDown && !game.settings.get(CONSTANTS.MODULE_NAME, \"invertSheetOpen\"))\r\n || (hotkeyState.ctrlDown && game.settings.get(CONSTANTS.MODULE_NAME, \"invertSheetOpen\"));\r\n }\r\n}\r\n\r\nexport const hotkeyState = {\r\n ctrlDown: false,\r\n altDown: false,\r\n shiftDown: false\r\n}\r\n\r\nexport function registerHotkeysPre() {\r\n \r\n game.keybindings.register(CONSTANTS.MODULE_NAME, \"force-open-item-pile-inventory\", {\r\n name: \"Force open inventory\",\r\n uneditable: [\r\n { key: \"ControlLeft\" },\r\n ],\r\n onDown: () => {\r\n hotkeyState.ctrlDown = true;\r\n },\r\n onUp: () => {\r\n hotkeyState.ctrlDown = false;\r\n },\r\n reservedModifiers: [\"SHIFT\", \"ALT\"]\r\n });\r\n \r\n game.keybindings.register(CONSTANTS.MODULE_NAME, \"force-drop-item\", {\r\n name: \"Force drop item (GM only)\",\r\n uneditable: [\r\n { key: \"ShiftLeft\" },\r\n ],\r\n onDown: () => {\r\n hotkeyState.shiftDown = true;\r\n },\r\n onUp: () => {\r\n hotkeyState.shiftDown = false;\r\n },\r\n reservedModifiers: [\"ALT\", \"CONTROL\"]\r\n });\r\n \r\n game.keybindings.register(CONSTANTS.MODULE_NAME, \"force-drop-one-item\", {\r\n name: \"Force drop one item\",\r\n uneditable: [\r\n { key: \"AltLeft\" },\r\n ],\r\n onDown: () => {\r\n hotkeyState.altDown = true;\r\n },\r\n onUp: () => {\r\n hotkeyState.altDown = false;\r\n },\r\n reservedModifiers: [\"SHIFT\", \"CONTROL\"]\r\n });\r\n \r\n}\r\n\r\nexport function registerHotkeysPost() {\r\n \r\n if (!game.user.isGM) {\r\n let clicked = false;\r\n window.addEventListener(\"mousedown\", (event) => {\r\n if (!canvas.ready) return;\r\n if (!(canvas.activeLayer instanceof TokenLayer)) return;\r\n if (game.activeTool !== \"select\") return;\r\n const hover = document.elementFromPoint(event.clientX, event.clientY);\r\n if (!hover || (hover.id !== \"board\")) return;\r\n if (event.button !== 0) return;\r\n \r\n const pos = canvas.app.renderer.plugins.interaction.mouse.getLocalPosition(canvas.app.stage);\r\n const tokens = Utilities.getTokensAtLocation(pos)\r\n .filter(token => {\r\n const canView = token._canView(game.user);\r\n const canSee = token.visible || game.user.isGM;\r\n return !canView && canSee;\r\n });\r\n if (!tokens.length) return;\r\n tokens.sort((a, b) => b.zIndex - a.zIndex);\r\n const token = Utilities.getDocument(tokens[0]);\r\n \r\n if (clicked === token) {\r\n clicked = false;\r\n return PrivateAPI._itemPileClicked(token);\r\n }\r\n \r\n clicked = token;\r\n setTimeout(() => {\r\n clicked = false;\r\n }, 500);\r\n });\r\n }\r\n}","\n\n\n\n\n \n ","import DropItemDialogShell from \"./drop-item-dialog-shell.svelte\";\r\nimport { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\n\r\nexport default class DropItemDialog extends SvelteApplication {\r\n \r\n /**\r\n *\r\n * @param droppedItem\r\n * @param itemPile\r\n * @param options\r\n * @param dialogData\r\n */\r\n constructor(droppedItem, itemPile, options = {}) {\r\n super({\r\n id: `item-pile-drop-item-${droppedItem.id}-${itemPile.id}`,\r\n svelte: {\r\n class: DropItemDialogShell,\r\n target: document.body,\r\n props: {\r\n droppedItem,\r\n itemPile\r\n }\r\n },\r\n close: () => this.options.resolve?.(null),\r\n ...options\r\n });\r\n this.droppedItem = droppedItem;\r\n this.itemPile = itemPile;\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n title: game.i18n.localize(\"ITEM-PILES.Applications.DropItem.Title\"),\r\n width: 430,\r\n height: \"auto\",\r\n classes: [\"item-piles-app\"]\r\n })\r\n }\r\n \r\n static getActiveApps(id) {\r\n return Object.values(ui.windows).filter(app => app.id === `item-pile-drop-item-${id}`);\r\n }\r\n \r\n static async show(droppedItem, itemPile, options = {}) {\r\n const apps = this.getActiveApps(droppedItem.id + \"-\" + itemPile.id);\r\n if (apps.length) {\r\n for (let app of apps) {\r\n app.render(false, { focus: true });\r\n }\r\n return;\r\n }\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(droppedItem, itemPile, options).render(true, { focus: true });\r\n })\r\n }\r\n \r\n}","\r\n\r\n\r\n\r\n
\r\n \r\n
\r\n
\r\n\r\n
\r\n
\r\n
{entry.name}
\r\n {#if !editQuantities}\r\n
(x{$quantity}) \r\n {/if}\r\n
\r\n
\r\n\r\n
\r\n\r\n {#if editQuantities}\r\n\r\n
\r\n \r\n
\r\n\r\n {:else}\r\n\r\n {#if $quantityLeft}\r\n
\r\n \r\n\r\n \r\n / {$quantityLeft}\r\n \r\n
\r\n {:else}\r\n
\r\n {localize(`ITEM-PILES.Inspect.${entry.toShare ? \"NoShareLeft\" : \"NoneLeft\"}`)}\r\n \r\n {/if}\r\n {/if}\r\n\r\n
\r\n\r\n {#if !editQuantities}\r\n\r\n
{ entry.take() }}\r\n class=\"item-piles-item-take-button\"\r\n type=\"button\"\r\n disabled={!$quantityLeft}>\r\n {localize(\"ITEM-PILES.Inspect.Take\")}\r\n \r\n\r\n {/if}\r\n\r\n
\r\n\r\n","\r\n\r\n\r\n\r\n {#if $numItems > 0}\r\n
{localize(\"ITEM-PILES.Items\")}: \r\n\r\n {#each $items as item (item.identifier)}\r\n
\r\n {/each}\r\n\r\n {/if}\r\n\r\n ","\n\n\n\n\n\n \n\n \n","import DropCurrencyDialogShell from \"./drop-currency-dialog-shell.svelte\";\r\nimport { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\n\r\nexport default class DropCurrencyDialog extends SvelteApplication {\r\n \r\n /**\r\n *\r\n * @param sourceActor\r\n * @param targetActor\r\n * @param settings\r\n * @param options\r\n * @param dialogData\r\n */\r\n constructor(sourceActor, targetActor, settings = {}, options = {}) {\r\n super({\r\n id: `item-pile-drop-currency-${targetActor.id}-${targetActor.id}`,\r\n title: settings?.title ?? game.i18n.localize(\"ITEM-PILES.Applications.DropCurrencies.Title\"),\r\n svelte: {\r\n class: DropCurrencyDialogShell,\r\n target: document.body,\r\n props: {\r\n sourceActor,\r\n targetActor,\r\n settings\r\n }\r\n },\r\n close: () => this.options.resolve?.(null),\r\n ...options\r\n })\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n width: 430,\r\n height: \"auto\",\r\n classes: [\"item-piles-app\"]\r\n })\r\n }\r\n \r\n static getActiveApps(id) {\r\n return Object.values(ui.windows).filter(app => app.id === `item-pile-drop-currency-${id}`);\r\n }\r\n \r\n static async show(sourceActor, targetActor, settings = {}, options = {}) {\r\n const apps = this.getActiveApps(sourceActor.id + \"-\" + targetActor.id);\r\n if (apps.length) {\r\n for (let app of apps) {\r\n app.render(false, { focus: true });\r\n }\r\n return;\r\n }\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(sourceActor, targetActor, settings, options).render(true, { focus: true });\r\n })\r\n }\r\n \r\n}","\r\n\r\n\r\n\r\n
\r\n {#if $numCurrencies > 0 || editQuantities}\r\n
\r\n {#each $currencies as currency, index (currency.identifier)}\r\n \r\n {/each}\r\n
\r\n {/if}\r\n\r\n
","\r\n\r\n\r\n\r\n {#if editQuantities}\r\n
{localize(\"ITEM-PILES.Inspect.Owner\")}
\r\n {:else}\r\n
\r\n {localize(\"ITEM-PILES.Inspect.AsActor\", { actorName: store.recipient.name })}\r\n {#if playerActors.length > 1}\r\n {#if !changingActor}\r\n { changingActor = true }} class:active={!changingActor}>Change\r\n actor. \r\n {:else}\r\n \r\n {#each playerActors as actor, index (index)}\r\n {actor.name} \r\n {/each}\r\n \r\n {/if}\r\n {/if}\r\n
\r\n {/if}\r\n\r\n
","import { get, writable } from \"svelte/store\";\nimport * as Utilities from \"../helpers/utilities.js\";\nimport { TJSDocument } from '@typhonjs-fvtt/runtime/svelte/store';\nimport * as PileUtilities from \"../helpers/pile-utilities.js\";\nimport * as SharingUtilities from \"../helpers/sharing-utilities.js\";\n\nclass PileBaseItem {\n \n constructor(store, data) {\n this.store = store;\n this.subscriptions = [];\n this.setup(data);\n }\n \n setupStores() {\n this.quantity = writable(0);\n this.currentQuantity = writable(1);\n this.quantityLeft = writable(0);\n this.filtered = writable(true);\n this.presentFromTheStart = writable(false);\n }\n \n setupSubscriptions() {\n // Higher order implementation\n }\n \n setup(data) {\n this.unsubscribe();\n this.setupStores(data);\n this.setupSubscriptions(data);\n }\n \n subscribeTo(target, callback) {\n this.subscriptions.push(target.subscribe(callback));\n }\n \n unsubscribe() {\n this.subscriptions.forEach(unsubscribe => unsubscribe());\n this.subscriptions = [];\n }\n}\n\nexport class PileItem extends PileBaseItem {\n \n setupStores(item) {\n super.setupStores();\n this.item = item;\n this.itemDocument = new TJSDocument(this.item);\n this.presentFromTheStart.set(Utilities.getItemQuantity(this.item) > 0);\n this.quantity.set(Utilities.getItemQuantity(this.item));\n this.currentQuantity.set(Math.min(get(this.currentQuantity), get(this.quantityLeft), get(this.quantity)));\n this.id = this.item.id;\n this.type = this.item.type;\n this.name = writable(this.item.name);\n this.img = writable(this.item.img);\n this.abbreviation = this.item.abbreviation;\n this.identifier = this.id;\n }\n \n setupSubscriptions() {\n super.setupSubscriptions();\n \n this.subscribeTo(this.store.shareData, () => {\n if (!this.toShare) {\n this.quantityLeft.set(get(this.quantity));\n return;\n }\n const quantityLeft = SharingUtilities.getItemSharesLeftForActor(this.store.actor, this.item, this.store.recipient);\n this.quantityLeft.set(quantityLeft);\n });\n \n this.subscribeTo(this.itemDocument, () => {\n const { data } = this.itemDocument.updateOptions;\n this.name.set(this.item.name);\n this.img.set(this.item.img);\n this.similarities = Utilities.setSimilarityProperties({}, this.item);\n if (hasProperty(data, game.itempiles.ITEM_QUANTITY_ATTRIBUTE)) {\n this.quantity.set(Utilities.getItemQuantity(data));\n const quantity = Math.min(get(this.currentQuantity), get(this.quantityLeft), get(this.quantity));\n this.currentQuantity.set(quantity);\n }\n });\n \n this.subscribeTo(this.quantity, this.filter.bind(this));\n this.subscribeTo(this.store.search, this.filter.bind(this));\n this.subscribeTo(this.store.pileData, this.setupProperties.bind(this));\n }\n \n setupProperties() {\n this.isCurrency = PileUtilities.isItemCurrency(this.item, { target: this.store.actor });\n this.similarities = Utilities.setSimilarityProperties({}, this.item);\n this.toShare = this.isCurrency\n ? get(this.store.pileData).shareCurrenciesEnabled && !!this.store.recipient\n : get(this.store.pileData).shareItemsEnabled && !!this.store.recipient;\n }\n \n filter() {\n const search = get(this.store.search);\n const presentFromTheSTart = get(this.presentFromTheStart);\n const quantity = get(this.quantity);\n if (quantity === 0 && !presentFromTheSTart) {\n this.filtered.set(true);\n } else if (search) {\n this.filtered.set(!this.name.toLowerCase().includes(search.toLowerCase()));\n } else {\n this.filtered.set(!presentFromTheSTart && quantity === 0);\n }\n }\n \n \n take() {\n const quantity = Math.min(get(this.currentQuantity), get(this.quantityLeft));\n return game.itempiles.transferItems(\n this.store.actor,\n this.store.recipient,\n [{ _id: this.id, quantity }],\n { interactionId: this.store.interactionId }\n );\n }\n \n updateQuantity(quantity) {\n const roll = new Roll(quantity).evaluate({ async: false });\n this.quantity.set(roll.total);\n return this.item.update({\n [game.itempiles.ITEM_QUANTITY_ATTRIBUTE]: roll.total\n });\n }\n}\n\nexport class PileAttribute extends PileBaseItem {\n \n setupStores(attribute) {\n super.setupStores();\n this.attribute = attribute;\n this.path = this.attribute.path;\n this.name = writable(this.attribute.name);\n this.img = writable(this.attribute.img);\n this.abbreviation = this.attribute.abbreviation;\n this.identifier = this.attribute.path;\n this.presentFromTheStart.set(Number(getProperty(this.store.actor.data, this.attribute.path) ?? 0) > 0);\n this.quantity.set(Number(getProperty(this.store.actor.data, this.path) ?? 0));\n this.currentQuantity.set(Math.min(get(this.currentQuantity), get(this.quantityLeft), get(this.quantity)));\n }\n \n setupSubscriptions() {\n super.setupSubscriptions();\n \n this.subscribeTo(this.store.shareData, (val) => {\n if (!this.toShare) {\n this.quantityLeft.set(get(this.quantity));\n return;\n }\n const quantityLeft = SharingUtilities.getAttributeSharesLeftForActor(this.store.actor, this.path, this.store.recipient);\n this.quantityLeft.set(quantityLeft);\n });\n \n this.subscribeTo(this.store.document, () => {\n const { data } = this.store.document.updateOptions;\n this.path = this.attribute.path;\n this.name.set(this.attribute.name);\n this.img.set(this.attribute.img);\n if (hasProperty(data, this.path)) {\n this.quantity.set(Number(getProperty(data, this.path) ?? 0));\n this.currentQuantity.set(Math.min(get(this.currentQuantity), get(this.quantityLeft), get(this.quantity)));\n }\n });\n \n this.subscribeTo(this.quantity, this.filter.bind(this));\n this.subscribeTo(this.store.search, this.filter.bind(this));\n this.subscribeTo(this.store.pileData, this.setupProperties.bind(this));\n }\n \n setupProperties() {\n this.toShare = get(this.store.pileData).shareCurrenciesEnabled && !!this.store.recipient;\n }\n \n filter() {\n const name = get(this.name);\n const search = get(this.store.search);\n const presentFromTheSTart = get(this.presentFromTheStart);\n const quantity = get(this.quantity);\n if (quantity === 0 && !presentFromTheSTart && !this.store.editQuantities) {\n this.filtered.set(true);\n } else if (search) {\n this.filtered.set(!name.toLowerCase().includes(search.toLowerCase()));\n } else {\n this.filtered.set(!presentFromTheSTart && quantity === 0 && !this.store.editQuantities);\n }\n }\n \n take() {\n const quantity = Math.min(get(this.currentQuantity), get(this.quantityLeft));\n return game.itempiles.transferAttributes(\n this.store.actor,\n this.store.recipient,\n { [this.path]: quantity },\n { interactionId: this.interactionId }\n );\n }\n \n updateQuantity() {\n return this.store.actor.update({\n [this.path]: get(this.quantity)\n });\n }\n \n}","import { get, writable } from \"svelte/store\";\nimport { TJSDocument } from '@typhonjs-fvtt/runtime/svelte/store';\nimport CONSTANTS from \"../constants/constants.js\";\nimport * as Utilities from \"../helpers/utilities.js\";\nimport * as PileUtilities from \"../helpers/pile-utilities.js\";\nimport * as SharingUtilities from \"../helpers/sharing-utilities.js\";\nimport * as Helpers from \"../helpers/helpers.js\";\nimport { InterfaceTracker } from \"../socket.js\";\nimport { PileAttribute, PileItem } from \"./pile-item.js\";\n\nconst __STORES__ = new Map();\n\nconst __PILEDATA_STORES__ = new Map();\n\nexport default class ItemPileStore {\n \n constructor(application, source, recipient = false, { recipientPileData = false } = {}) {\n \n this.subscriptions = [];\n \n this.interactionId = randomID();\n this.application = application;\n \n this.uuid = Utilities.getUuid(source);\n this.actor = Utilities.getActor(source);\n \n this.recipient = recipient ? Utilities.getActor(recipient) : false;\n \n this.document = new TJSDocument(this.actor);\n this.recipientDocument = recipient ? new TJSDocument(this.recipient) : false;\n this.recipientPileData = recipientPileData;\n \n __STORES__.set(this.uuid, this);\n \n this.setupStores();\n this.setupSubscriptions();\n }\n \n get ItemClass() {\n return PileItem;\n };\n \n get AttributeClass() {\n return PileAttribute;\n };\n \n setupStores() {\n \n this.pileData = writable(PileUtilities.getActorFlagData(this.actor));\n this.shareData = writable(SharingUtilities.getItemPileSharingData(this.actor));\n \n this.recipientPileData = this.recipientPileData || writable(this.recipient ? PileUtilities.getActorFlagData(this.recipient) : {});\n this.recipientShareData = writable(this.recipient ? SharingUtilities.getItemPileSharingData(this.recipient) : {});\n \n this.deleted = writable(false);\n \n this.search = writable(\"\");\n this.editQuantities = !this.recipient;\n \n this.allItems = writable([]);\n this.attributes = writable([]);\n \n this.items = writable([]);\n this.currencies = writable([]);\n this.allCurrencies = writable([]);\n \n this.numItems = writable(0);\n this.numCurrencies = writable(0);\n \n this.name = writable(\"\");\n this.img = writable(\"\");\n \n }\n \n setupSubscriptions() {\n \n this.subscribeTo(this.document, () => {\n const { data } = this.document.updateOptions;\n this.name.set(this.actor.name);\n this.img.set(this.actor.img);\n if (hasProperty(data, CONSTANTS.FLAGS.SHARING)) {\n this.shareData.set(SharingUtilities.getItemPileSharingData(this.actor));\n this.refreshItems();\n }\n if (hasProperty(data, CONSTANTS.FLAGS.PILE)) {\n this.pileData.set(PileUtilities.getActorFlagData(this.actor));\n this.refreshItems();\n }\n });\n \n if (this.recipientDocument) {\n this.subscribeTo(this.recipientDocument, () => {\n const { data } = this.document.updateOptions;\n if (hasProperty(data, CONSTANTS.FLAGS.SHARING)) {\n this.recipientShareData.set(SharingUtilities.getItemPileSharingData(this.recipient));\n this.refreshItems();\n }\n if (hasProperty(data, CONSTANTS.FLAGS.PILE)) {\n this.recipientPileData.set(PileUtilities.getActorFlagData(this.recipient));\n this.refreshItems();\n }\n });\n }\n \n const items = [];\n const attributes = [];\n \n PileUtilities.getActorItems(this.actor).map(item => {\n items.push(new this.ItemClass(this, item));\n });\n \n PileUtilities.getActorCurrencies(this.actor, { forActor: this.recipient, getAll: true }).forEach(currency => {\n if (currency.type === \"item\") {\n if (!currency.item) return;\n items.push(new this.ItemClass(this, currency.item ?? currency.data));\n } else {\n attributes.push(new this.AttributeClass(this, currency));\n }\n });\n \n this.allItems.set(items);\n this.attributes.set(attributes);\n \n this.subscribeTo(this.allItems, (val) => {\n if (!val) return;\n this.refreshItems();\n });\n this.subscribeTo(this.attributes, (val) => {\n if (!val) return;\n this.refreshItems();\n });\n \n const filterDebounce = foundry.utils.debounce(() => {\n this.refreshItems();\n }, 300);\n this.subscribeTo(this.search, (val) => {\n if (!val) return;\n filterDebounce()\n });\n \n }\n \n static getStore(actor) {\n const uuid = Utilities.getUuid(actor);\n return __STORES__.get(uuid);\n }\n \n static notifyChanges(event, actor, ...args) {\n const store = this.getStore(actor);\n if (store) {\n store[event](...args);\n }\n }\n \n refreshItems() {\n const allItems = get(this.allItems);\n \n const items = allItems.filter(entry => !entry.isCurrency);\n const itemCurrencies = allItems.filter(entry => entry.isCurrency);\n \n this.numItems.set(items.filter(entry => get(entry.quantity) > 0).length);\n this.items.set(items.filter(entry => !get(entry.filtered)));\n \n const currencies = get(this.attributes).concat(itemCurrencies);\n this.numCurrencies.set(currencies.filter(entry => get(entry.quantity) > 0).length);\n this.currencies.set(currencies.filter(entry => !get(entry.filtered)));\n this.allCurrencies.set(currencies);\n }\n \n createItem(item) {\n if (PileUtilities.isItemInvalid(this.actor, item)) return;\n const items = get(this.allItems);\n const deletedItems = items\n .filter(item => item.id === null)\n .map(item => ({\n pileItem: item,\n ...item.similarities\n }));\n const previouslyDeletedItem = Utilities.findSimilarItem(deletedItems, item);\n if (previouslyDeletedItem) {\n previouslyDeletedItem.pileItem.setup(item);\n } else {\n items.push(new PileItem(this, item));\n }\n this.allItems.set(items);\n this.refreshItems();\n }\n \n deleteItem(item) {\n if (PileUtilities.isItemInvalid(this.actor, item)) return;\n const items = get(this.allItems);\n const pileItem = items.find(pileItem => pileItem.id === item.id);\n if (!pileItem) return;\n if (this.editQuantities) {\n items.splice(items.indexOf(pileItem), 1);\n this.allItems.set(items);\n } else {\n pileItem.id = null;\n pileItem.quantity.set(0);\n pileItem.quantityLeft.set(0);\n }\n pileItem.unsubscribe();\n this.refreshItems();\n }\n \n delete() {\n this.deleted.set(true);\n }\n \n async update() {\n \n const itemsToUpdate = [];\n const itemsToDelete = [];\n const attributesToUpdate = {};\n \n const items = get(this.allItems).filter(item => item.id);\n for (let item of items) {\n const itemQuantity = get(item.quantity);\n if (itemQuantity === 0) {\n itemsToDelete.push(item.id);\n } else {\n itemsToUpdate.push({\n _id: item.id,\n [game.itempiles.ITEM_QUANTITY_ATTRIBUTE]: itemQuantity\n })\n }\n }\n \n const attributes = get(this.attributes);\n for (let attribute of attributes) {\n attributesToUpdate[attribute.path] = get(attribute.quantity);\n }\n \n const pileSharingData = SharingUtilities.getItemPileSharingData(this.actor);\n \n await this.actor.update(attributesToUpdate);\n if (pileSharingData?.currencies) {\n pileSharingData.currencies = pileSharingData.currencies.map(currency => {\n if (attributesToUpdate[currency.path] !== undefined) {\n currency.actors = currency.actors.map(actor => {\n actor.quantity = Math.max(0, Math.min(actor.quantity, attributesToUpdate[currency.path]));\n return actor;\n })\n }\n return currency;\n })\n }\n \n await this.actor.updateEmbeddedDocuments(\"Item\", itemsToUpdate);\n await this.actor.deleteEmbeddedDocuments(\"Item\", itemsToDelete);\n if (pileSharingData?.items) {\n pileSharingData.items = pileSharingData.items.map(item => {\n const sharingItem = itemsToUpdate.find(item => item._id === item.id);\n if (sharingItem) {\n item.actors = item.actors.map(actor => {\n actor.quantity = Math.max(0, Math.min(actor.quantity, sharingItem.quantity));\n return actor;\n })\n }\n return item;\n })\n }\n \n await SharingUtilities.updateItemPileSharingData(this.actor, pileSharingData);\n \n Helpers.custom_notify(\"Item Pile successfully updated.\");\n \n this.refreshItems();\n \n }\n \n takeAll() {\n game.itempiles.transferEverything(\n this.actor,\n this.recipient,\n { interactionId: this.interactionId }\n );\n }\n \n splitAll() {\n return game.itempiles.splitItemPileContents(this.actor, { instigator: this.recipient });\n }\n \n closeContainer() {\n if (!InterfaceTracker.isOpened(this.application.id)) {\n return game.itempiles.closeItemPile(this.actor);\n }\n }\n \n subscribeTo(target, callback) {\n this.subscriptions.push(target.subscribe(callback));\n }\n \n unsubscribe() {\n this.subscriptions.forEach(unsubscribe => unsubscribe());\n this.subscriptions = [];\n }\n \n onDestroy() {\n this.unsubscribe();\n __STORES__.delete(this.uuid);\n }\n}","\r\n\r\n\r\n\r\n\r\n\r\n \r\n\r\n \r\n\r\n {#if $deleted}\r\n
\r\n {localize(\"ITEM-PILES.Inspect.Destroyed\")}\r\n
\r\n {:else}\r\n\r\n
\r\n\r\n {#if showSearchBar}\r\n
\r\n Search: \r\n \r\n
\r\n {/if}\r\n\r\n {#if isPileEmpty}\r\n
\r\n {localize(\"ITEM-PILES.Inspect.Empty\")}\r\n
\r\n\r\n {/if}\r\n\r\n
\r\n\r\n {#if scrolled}\r\n
\r\n
\r\n {/if}\r\n\r\n
\r\n\r\n {#if hasItems}\r\n
\r\n {/if}\r\n\r\n
\r\n\r\n
\r\n\r\n {/if}\r\n\r\n \r\n\r\n
\r\n\r\n \r\n\r\n \r\n\r\n","import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\nimport ItemPileInventoryShell from \"./item-pile-inventory-shell.svelte\";\r\nimport * as Utilities from \"../../helpers/utilities.js\";\r\nimport ItemPileConfig from \"../item-pile-config/item-pile-config.js\";\r\nimport HOOKS from \"../../constants/hooks.js\";\r\nimport * as Helpers from \"../../helpers/helpers.js\";\r\n\r\nexport class ItemPileInventoryApp extends SvelteApplication {\r\n \r\n /**\r\n *\r\n * @param actor\r\n * @param recipient\r\n * @param overrides\r\n * @param options\r\n * @param dialogData\r\n */\r\n constructor(actor, recipient, overrides = {}, options = {}, dialogData = {}) {\r\n super({\r\n id: `item-pile-inventory-${actor.id}`,\r\n title: actor.name,\r\n svelte: {\r\n class: ItemPileInventoryShell,\r\n target: document.body,\r\n props: {\r\n actor,\r\n recipient,\r\n overrides\r\n }\r\n },\r\n zIndex: 100,\r\n ...options\r\n }, dialogData);\r\n \r\n this.actor = actor;\r\n this.recipient = recipient;\r\n \r\n Helpers.hooks.callAll(HOOKS.OPEN_INTERFACE, this, actor, recipient, overrides);\r\n \r\n }\r\n \r\n /** @inheritdoc */\r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n closeOnSubmit: false,\r\n classes: [\"app window-app sheet item-pile-inventory\"],\r\n width: 550,\r\n height: \"auto\",\r\n });\r\n }\r\n \r\n static getActiveApps(id) {\r\n return Object.values(ui.windows).filter(app => app.id === `item-pile-inventory-${id}`);\r\n }\r\n \r\n static async show(source, recipient = false, overrides = {}, options = {}, dialogData = {}) {\r\n source = Utilities.getActor(source)\r\n recipient = Utilities.getActor(recipient);\r\n const result = Helpers.hooks.call(HOOKS.PRE_OPEN_INTERFACE, source, recipient, overrides);\r\n if (result === false) return;\r\n const apps = this.getActiveApps(source.id);\r\n if (apps.length) {\r\n for (let app of apps) {\r\n app.render(false, { focus: true });\r\n }\r\n return\r\n }\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(source, recipient, overrides, options, dialogData).render(true, { focus: true });\r\n })\r\n }\r\n \r\n async close(options) {\r\n const result = Helpers.hooks.call(HOOKS.PRE_CLOSE_INTERFACE, this, this.actor, this.recipient);\r\n if (result === false) return;\r\n Helpers.hooks.callAll(HOOKS.CLOSE_INTERFACE, this, this.actor, this.recipient);\r\n return super.close(options);\r\n }\r\n \r\n /* -------------------------------------------- */\r\n \r\n /** @override */\r\n _getHeaderButtons() {\r\n let buttons = super._getHeaderButtons();\r\n const canConfigure = game.user.isGM;\r\n if (canConfigure) {\r\n buttons = [\r\n {\r\n label: \"ITEM-PILES.Inspect.OpenSheet\",\r\n class: \"item-piles-open-actor-sheet\",\r\n icon: \"fas fa-user\",\r\n onclick: () => {\r\n this.actor.sheet.render(true, { focus: true });\r\n }\r\n },\r\n {\r\n label: \"ITEM-PILES.HUD.Configure\",\r\n class: \"item-piles-configure-pile\",\r\n icon: \"fas fa-box-open\",\r\n onclick: () => {\r\n ItemPileConfig.show(this.actor);\r\n }\r\n },\r\n ].concat(buttons);\r\n }\r\n return buttons\r\n }\r\n \r\n}","import * as Utilities from \"./utilities.js\";\r\nimport ItemPileSocket from \"../socket.js\";\r\nimport PrivateAPI from \"../API/private-api.js\";\r\nimport { SYSTEMS } from \"../systems.js\";\r\n\r\nexport default class Transaction {\r\n \r\n constructor(actor) {\r\n this.actor = actor;\r\n this.itemsToCreate = [];\r\n this.itemsToUpdate = [];\r\n this.itemsToDelete = [];\r\n this.itemsDeleted = new Map();\r\n this.actorUpdates = {};\r\n this.attributeDeltas = new Map();\r\n this.attributeTypeMap = new Map();\r\n this.itemDeltas = new Map();\r\n this.itemTypeMap = new Map();\r\n this.preCommitted = false;\r\n }\r\n \r\n async appendItemChanges(items, { remove = false, type = \"item\" } = {}) {\r\n for (let data of items) {\r\n let item = data.item ?? data;\r\n let itemData = item instanceof Item ? item.toObject() : item;\r\n if (SYSTEMS.DATA.ITEM_TRANSFORMER) {\r\n itemData = await SYSTEMS.DATA.ITEM_TRANSFORMER(itemData);\r\n }\r\n const incomingQuantity = Math.abs(data.quantity ?? Utilities.getItemQuantity(itemData)) * (remove ? -1 : 1);\r\n const actorExistingItem = Utilities.findSimilarItem(this.actor.items, itemData);\r\n if (actorExistingItem) {\r\n const existingItemUpdate = Utilities.findSimilarItem(this.itemsToUpdate, itemData);\r\n if (existingItemUpdate) {\r\n const newQuantity = Utilities.getItemQuantity(existingItemUpdate) + incomingQuantity;\r\n Utilities.setItemQuantity(existingItemUpdate, newQuantity);\r\n } else {\r\n const newQuantity = Utilities.getItemQuantity(actorExistingItem) + incomingQuantity;\r\n const update = Utilities.setItemQuantity({ _id: actorExistingItem.id }, newQuantity);\r\n this.itemTypeMap.set(actorExistingItem.id, type)\r\n this.itemsToUpdate.push(update)\r\n this.itemDeltas.set(actorExistingItem.id,\r\n (this.itemDeltas.has(actorExistingItem.id) ? this.itemDeltas.get(actorExistingItem.id) : 0) + incomingQuantity\r\n );\r\n }\r\n } else {\r\n const existingItemCreation = Utilities.findSimilarItem(this.itemsToCreate, itemData);\r\n if (existingItemCreation) {\r\n const newQuantity = Utilities.getItemQuantity(existingItemCreation) + incomingQuantity;\r\n Utilities.setItemQuantity(existingItemCreation, newQuantity);\r\n } else {\r\n setProperty(itemData, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, incomingQuantity);\r\n this.itemsToCreate.push(itemData);\r\n this.itemTypeMap.set(itemData._id, type)\r\n }\r\n }\r\n }\r\n }\r\n \r\n async appendActorChanges(attributes, { remove = false, type = \"attribute\" } = {}) {\r\n if (!Array.isArray(attributes)) {\r\n attributes = Object.entries(attributes).map(entry => ({ path: entry[0], quantity: entry[1] }));\r\n }\r\n this.actorUpdates = attributes.reduce((acc, attribute) => {\r\n const incomingQuantity = Math.abs(attribute.quantity) * (remove ? -1 : 1);\r\n acc[attribute.path] = acc[attribute.path] ?? Number(getProperty(this.actor.data, attribute.path));\r\n acc[attribute.path] += incomingQuantity\r\n this.attributeDeltas.set(attribute.path,\r\n (this.attributeDeltas.has(attribute.path) ? this.attributeDeltas.get(attribute.path) : 0) + incomingQuantity\r\n );\r\n this.attributeTypeMap.set(attribute.path, type)\r\n return acc;\r\n }, this.actorUpdates);\r\n }\r\n \r\n prepare() {\r\n this.actorUpdates = Object.fromEntries(Object.entries(this.actorUpdates).filter(entry => {\r\n if (this.attributeDeltas.get(entry[0]) === 0) {\r\n this.attributeDeltas.delete(entry[0]);\r\n }\r\n return Number(getProperty(this.actor.data, entry[0])) !== entry[1];\r\n }))\r\n this.itemsToCreate = this.itemsToCreate.filter(item => {\r\n return Utilities.getItemQuantity(item) > 0 || this.itemTypeMap.get(item._id) === \"currency\"\r\n });\r\n this.itemsToDelete = this.itemsToUpdate.filter(item => {\r\n return Utilities.getItemQuantity(item) <= 0 && this.itemTypeMap.get(item._id) !== \"currency\";\r\n }).map(item => item._id);\r\n this.itemDeltas = Array.from(this.itemDeltas).map(([id, quantity]) => {\r\n const item = this.actor.items.get(id).toObject();\r\n const type = this.itemTypeMap.get(id);\r\n setProperty(item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, quantity);\r\n return { item, quantity, type };\r\n });\r\n this.itemsDeleted = Array.from(this.itemsDeleted).map(([id, quantity]) => {\r\n const item = this.actor.items.get(id).toObject();\r\n const type = this.itemTypeMap.get(id);\r\n return { item, quantity, type };\r\n });\r\n this.itemsToUpdate = this.itemsToUpdate.filter(item => Utilities.getItemQuantity(item) > 0).filter(itemData => {\r\n const item = this.actor.items.get(itemData._id)\r\n return Utilities.getItemQuantity(item) !== Utilities.getItemQuantity(itemData);\r\n });\r\n this.attributeDeltas = Object.fromEntries(this.attributeDeltas);\r\n this.preCommitted = true;\r\n return {\r\n actorUpdates: this.actorUpdates,\r\n itemsToCreate: this.itemsToCreate,\r\n itemsToDelete: this.itemsToDelete,\r\n itemsToUpdate: this.itemsToUpdate,\r\n itemsDeleted: this.itemsDeleted,\r\n attributeDeltas: this.attributeDeltas,\r\n itemDeltas: this.itemDeltas,\r\n }\r\n }\r\n \r\n async commit() {\r\n \r\n if (!this.preCommitted) {\r\n this.prepare();\r\n }\r\n \r\n let itemsCreated;\r\n const actorUuid = Utilities.getUuid(this.actor);\r\n if (!this.actor.owner) {\r\n itemsCreated = await ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.COMMIT_ACTOR_CHANGES, actorUuid, this.actorUpdates, this.itemsToUpdate, this.itemsToDelete, this.itemsToCreate);\r\n } else {\r\n itemsCreated = await PrivateAPI._commitActorChanges(actorUuid, this.actorUpdates, this.itemsToUpdate, this.itemsToDelete, this.itemsToCreate)\r\n }\r\n \r\n return {\r\n attributeDeltas: this.attributeDeltas,\r\n itemDeltas: this.itemDeltas.concat(itemsCreated.map(item => {\r\n return {\r\n item,\r\n quantity: Utilities.getItemQuantity(item)\r\n }\r\n }))\r\n }\r\n }\r\n}","/**\r\n * First pass at a system to create a unique style sheet for the UI library that loads default values for all CSS\r\n * variables.\r\n */\r\nexport class StyleManager\r\n{\r\n #selector;\r\n #styleElement;\r\n #cssRule;\r\n\r\n /**\r\n *\r\n * @param selector\r\n * @param {string} docKey\r\n */\r\n constructor({ selector = ':root', docKey } = {})\r\n {\r\n if (typeof selector !== 'string') { throw new TypeError(`StyleManager error: 'selector' is not a string.`); }\r\n if (typeof docKey !== 'string') { throw new TypeError(`StyleManager error: 'docKey' is not a string.`); }\r\n\r\n this.#selector = selector;\r\n\r\n if (document[docKey] === void 0)\r\n {\r\n this.#styleElement = document.createElement('style');\r\n\r\n document.head.append(this.#styleElement);\r\n\r\n this.#styleElement.sheet.insertRule(`${selector} {}`, 0);\r\n\r\n this.#cssRule = this.#styleElement.sheet.cssRules[0];\r\n\r\n document[docKey] = this.#styleElement;\r\n }\r\n else\r\n {\r\n this.#styleElement = document[docKey];\r\n this.#cssRule = this.#styleElement.sheet.cssRules[0];\r\n }\r\n }\r\n\r\n /**\r\n * Set rules by property / value; useful for CSS variables.\r\n *\r\n * @param {Object} rules - An object with property / value string pairs to load.\r\n *\r\n * @param {boolean} [overwrite=false] - When true overwrites any existing values.\r\n */\r\n set(rules, overwrite = false)\r\n {\r\n if (overwrite)\r\n {\r\n for (const [key, value] of Object.entries(rules))\r\n {\r\n this.#cssRule.style.setProperty(key, value);\r\n }\r\n }\r\n else\r\n {\r\n // Only set property keys for entries that don't have an existing rule set.\r\n for (const [key, value] of Object.entries(rules))\r\n {\r\n if (this.#cssRule.style.getPropertyValue(key) === '')\r\n {\r\n this.#cssRule.style.setProperty(key, value);\r\n }\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Removes the property keys specified. If `keys` is a string a single property is removed. Or if `keys` is an\r\n * iterable list then all property keys in the list are removed.\r\n *\r\n * @param {string|Iterable} keys - The property keys to remove.\r\n */\r\n remove(keys)\r\n {\r\n if (Array.isArray(keys))\r\n {\r\n for (const key of keys)\r\n {\r\n if (typeof key === 'string') { this.#cssRule.style.removeProperty(key); }\r\n }\r\n }\r\n else if (typeof keys === 'string')\r\n {\r\n this.#cssRule.style.removeProperty(keys);\r\n }\r\n }\r\n}","import { StyleManager } from './StyleManager.js';\r\n\r\nconst s_STYLE_KEY = '#__tjs-root-styles';\r\n\r\nconst cssVariables = new StyleManager({ docKey: s_STYLE_KEY });\r\n\r\nexport { cssVariables };","/**\r\n * Parses the core Foundry style sheet creating an indexed object of properties by selector.\r\n */\r\nexport class FoundryStyles\r\n{\r\n static #sheet = void 0;\r\n\r\n static #sheetMap = new Map();\r\n\r\n static #initialized = false;\r\n\r\n /**\r\n * Called once on initialization / first usage. Parses the core foundry style sheet.\r\n */\r\n static #initialize()\r\n {\r\n this.#initialized = true;\r\n\r\n const styleSheets = Array.from(document.styleSheets).filter((sheet) => sheet.href !== null);\r\n\r\n let sheet;\r\n\r\n const foundryStyleSheet = foundry.utils.getRoute('/css/style.css');\r\n\r\n // Find the core Foundry stylesheet.\r\n for (const styleSheet of styleSheets)\r\n {\r\n let url;\r\n\r\n try { url = new URL(styleSheet.href); } catch (err) { continue; }\r\n\r\n if (typeof url.pathname === 'string' && url.pathname === foundryStyleSheet)\r\n {\r\n this.#sheet = sheet = styleSheet;\r\n break;\r\n }\r\n }\r\n\r\n // Quit now if the Foundry style sheet was not found.\r\n if (!sheet) { return; }\r\n\r\n // Parse each CSSStyleRule and build the map of selectors to parsed properties.\r\n for (const rule of sheet.cssRules)\r\n {\r\n if (!(rule instanceof CSSStyleRule)) { continue; }\r\n\r\n const obj = {};\r\n\r\n // Parse `cssText` into an object of properties & values.\r\n for (const entry of rule.style.cssText.split(';'))\r\n {\r\n const parts = entry.split(':');\r\n\r\n // Sanity check.\r\n if (parts.length < 2) { continue; }\r\n\r\n obj[parts[0].trim()] = parts[1].trim();\r\n }\r\n\r\n this.#sheetMap.set(rule.selectorText, obj);\r\n }\r\n }\r\n\r\n /**\r\n * Gets the properties object associated with the selector. Try and use a direct match otherwise all keys\r\n * are iterated to find a selector string that includes the `selector`.\r\n *\r\n * @param {string} selector - Selector to find.\r\n *\r\n * @returns {Object} Properties object.\r\n */\r\n static getProperties(selector)\r\n {\r\n if (!this.#initialized) { this.#initialize(); }\r\n\r\n // If there is a direct selector match then return a value immediately.\r\n if (this.#sheetMap.has(selector))\r\n {\r\n return this.#sheetMap.get(selector);\r\n }\r\n\r\n for (const key of this.#sheetMap.keys())\r\n {\r\n if (key.includes(selector)) { return this.#sheetMap.get(key); }\r\n }\r\n\r\n return void 0;\r\n }\r\n\r\n /**\r\n * Gets a specific property value from the given `selector` and `property` key. Try and use a direct selector\r\n * match otherwise all keys are iterated to find a selector string that includes `selector`.\r\n *\r\n * @param {string} selector - Selector to find.\r\n *\r\n * @param {string} property - Specific property to locate.\r\n *\r\n * @returns {string|undefined} Property value.\r\n */\r\n static getProperty(selector, property)\r\n {\r\n if (!this.#initialized) { this.#initialize(); }\r\n\r\n // If there is a direct selector match then return a value immediately.\r\n if (this.#sheetMap.has(selector))\r\n {\r\n const data = this.#sheetMap.get(selector);\r\n return typeof data === 'object' && property in data ? data[property] : void 0;\r\n }\r\n\r\n for (const key of this.#sheetMap.keys())\r\n {\r\n if (key.includes(selector))\r\n {\r\n const data = this.#sheetMap.get(key);\r\n if (typeof data === 'object' && property in data) { return data[property]; }\r\n }\r\n }\r\n\r\n return void 0;\r\n }\r\n}\r\n","\r\n\r\n\r\n
\r\n
\r\n \r\n {#if comp}\r\n \r\n {:else}\r\n {localize(text)} \r\n {/if}\r\n \r\n \r\n {#if selected}\r\n
\r\n {/if}\r\n
\r\n\r\n\r\n","\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n","import {\r\n cssVariables,\r\n FoundryStyles } from '../internal/index.js'; // TODO: Figure out better build to use #internal again.\r\n\r\nexport * from './button';\r\nexport * from './folder';\r\nexport * from './form';\r\nexport * from './label';\r\nexport * from './layers';\r\nexport * from './menu';\r\n\r\n/**\r\n * Assign all TyphonJS CSS variables to Foundry defaults.\r\n */\r\n\r\ncssVariables.set({\r\n '--tjs-action-ripple-background': 'rgba(0, 0, 0, 0.35)'\r\n});\r\n\r\n// -------------------------------------------------------------------------------------------------------------------\r\n\r\ncssVariables.set({\r\n '--tjs-icon-button-background': 'none',\r\n '--tjs-icon-button-background-hover': 'rgba(0, 0, 0, 0.10)',\r\n '--tjs-icon-button-background-selected': 'rgba(0, 0, 0, 0.20)',\r\n '--tjs-icon-button-border-radius': '50%',\r\n '--tjs-icon-button-clip-path': 'none',\r\n '--tjs-icon-button-diameter': '2em',\r\n '--tjs-icon-button-transition': 'background 200ms linear, clip-path 200ms linear'\r\n});\r\n\r\n{\r\n /**\r\n * All input related components including: TJSSelect,\r\n */\r\n const props = FoundryStyles.getProperties('input[type=\"text\"], input[type=\"number\"]');\r\n\r\n if (typeof props === 'object')\r\n {\r\n cssVariables.set({\r\n '--tjs-input-background': 'background' in props ? props.background : 'rgba(0, 0, 0, 0.05)',\r\n '--tjs-input-border': 'border' in props ? props.border : '1px solid var(--color-border-light-tertiary)',\r\n '--tjs-input-border-radius': 'border-radius' in props ? props['border-radius'] : '3px',\r\n '--tjs-input-height': 'height' in props ? props.height : 'var(--form-field-height)',\r\n '--tjs-input-min-width': 'min-width' in props ? props['min-width'] : '20px',\r\n '--tjs-input-width': 'width' in props ? props.width : 'calc(100% - 2px)'\r\n });\r\n }\r\n}\r\n\r\ncssVariables.set({\r\n '--tjs-label-transition': 'background 200ms linear'\r\n});\r\n\r\ncssVariables.set({\r\n '--tjs-menu-border': '1px solid var(--color-border-dark, #000)',\r\n '--tjs-menu-box-shadow': '0 0 2px var(--color-shadow-dark, #000)',\r\n '--tjs-menu-color': 'var(--color-text-light-primary, #EEE)',\r\n '--tjs-menu-item-hover-text-shadow-color': 'var(--color-text-hyperlink, red)',\r\n});\r\n","\r\n\r\n\r\n {#if $prices.length > 1}\r\n
\r\n 1 && !standalone}\r\n class:cant-afford={cantAfford}\r\n class:cant-afford-multiple-prices={cantAffordMultiplePrices}>\r\n
\r\n \r\n \r\n {#each $prices as priceGroup, index (index)}\r\n
\r\n {#each priceGroup.prices.filter(price => price.cost) as price (price.id)}\r\n
{\r\n $selectedPriceGroup = index;\r\n $priceSelector = \"\";\r\n }}\r\n class:cant-afford={!priceGroup.maxQuantity && item.store.recipient}>\r\n
\r\n
\r\n
\r\n
\r\n {price.baseCost} {price.name}\r\n
\r\n
\r\n {/each}\r\n
\r\n {/each}\r\n
\r\n \r\n \r\n {:else}\r\n
{ label.text } \r\n {/if}\r\n
\r\n\r\n","\n\n\n\n\n \n\n
\n
\n
\n
\n
\n
{$itemName} \n
\n\n
\n {#if maxItemQuantity}\n
\n Quantity \n \n (Max {maxItemPurchaseQuantity})\n \n
\n
{\n $quantityToBuy = Math.max(1, Math.min(currentQuantityToBuy, maxItemPurchaseQuantity));\n currentQuantityToBuy = $quantityToBuy;\n }}/>\n {/if}\n
\n
\n
\n {#if maxItemQuantity}\n {#if $quantityToBuy > 1 && paymentData.primary}\n {paymentData.basePriceString} \n {/if}\n {:else}\n You cannot afford this price \n {/if}\n
\n
\n\n
\n\n
\n {#if settings.selling}\n You receive:\n {:else}\n You pay:\n {/if}\n \n\n
\n {#if settings.selling}\n They receive:\n {:else}\n You pay:\n {/if}\n \n\n
\n {#each paymentData.finalPrices as price}\n {#if price.quantity}\n
\n
\n
\n
\n
{price.quantity} {price.name} \n
\n {/if}\n {/each}\n
\n\n
\n
\n
{$quantityToBuy > 1 ? $quantityToBuy + \" \" : \"\"}{$itemName} \n
\n
\n
\n
\n {#if paymentData.buyerChange.length}\n
\n Change:\n \n {#each paymentData.buyerChange as change}\n {#if change.quantity}\n
\n
{change.quantity} {change.name} \n
\n
\n
\n
\n {/if}\n {/each}\n {/if}\n
\n\n
\n\n \n\n
\n\n \n\n","import TradeMerchantItemDialogShell from \"./trade-merchant-item-dialog-shell.svelte\";\r\nimport { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\nimport { get } from \"svelte/store\";\r\n\r\nexport default class TradeMerchantItemDialog extends SvelteApplication {\r\n \r\n /**\r\n *\r\n * @param item\r\n * @param seller\r\n * @param buyer\r\n * @param settings\r\n * @param options\r\n */\r\n constructor(item, seller, buyer, settings = {}, options = {}) {\r\n super({\r\n id: `item-pile-buy-item-dialog-${item.id}-${seller.id}-${buyer.id}`,\r\n title: game.i18n.format(\"ITEM-PILES.Applications.TradeMerchantItem.Title\", { item_name: get(item.name) }),\r\n svelte: {\r\n class: TradeMerchantItemDialogShell,\r\n target: document.body,\r\n props: {\r\n item,\r\n seller,\r\n buyer,\r\n settings\r\n }\r\n },\r\n close: () => this.options.resolve?.(null),\r\n ...options\r\n });\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n width: 330,\r\n height: \"auto\",\r\n classes: [\"item-piles-app\"]\r\n })\r\n }\r\n \r\n static getActiveApps(id) {\r\n return Object.values(ui.windows).filter(app => app.id === `item-pile-buy-item-dialog-${id}`);\r\n }\r\n \r\n static async show(item, seller, buyer, settings = {}, options = {}) {\r\n const apps = this.getActiveApps(item.id + \"-\" + seller.id + \"-\" + buyer.id);\r\n if (apps.length) {\r\n for (let app of apps) {\r\n app.render(false, { focus: true });\r\n }\r\n return;\r\n }\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(item, seller, buyer, settings, options).render(true, { focus: true });\r\n })\r\n }\r\n \r\n}","import ItemPileStore from \"./item-pile-store.js\";\nimport { get, writable } from \"svelte/store\";\nimport { localize } from \"@typhonjs-fvtt/runtime/svelte/helper\";\nimport { PileItem } from \"./pile-item.js\";\nimport * as PileUtilities from \"../helpers/pile-utilities.js\";\nimport CONSTANTS from \"../constants/constants.js\";\nimport * as Helpers from \"../helpers/helpers.js\";\nimport TradeMerchantItemDialog from \"../applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog.js\";\n\nexport default class MerchantStore extends ItemPileStore {\n \n setupStores() {\n super.setupStores();\n this.editPrices = writable(false);\n this.itemsPerCategory = writable({});\n this.categories = writable([]);\n this.itemCategories = writable([]);\n this.typeFilter = writable(\"all\")\n this.priceModifiersPerType = writable({});\n this.priceModifiersForActor = writable({});\n this.priceSelector = writable(\"\");\n }\n \n get ItemClass() {\n return PileMerchantItem;\n }\n \n setupSubscriptions() {\n super.setupSubscriptions();\n this.subscribeTo(this.pileData, () => {\n this.updatePriceModifiers();\n });\n if (this.recipientDocument) {\n this.subscribeTo(this.recipientPileData, () => {\n this.updatePriceModifiers();\n });\n this.subscribeTo(this.recipientDocument, () => {\n this.refreshItemPrices();\n })\n }\n this.subscribeTo(this.typeFilter, () => {\n this.refreshItems();\n })\n }\n \n refreshItems() {\n super.refreshItems();\n const items = get(this.items).filter(item => {\n return game.user.isGM || !get(item.itemFlagData).hidden;\n });\n this.itemCategories.set(Array.from(new Set(get(this.allItems).filter(entry => !entry.isCurrency).map(item => item.type))).map(type => ({\n label: localize(CONFIG.Item.typeLabels[type]), type\n })));\n const itemsPerCategory = items.reduce((acc, item) => {\n if (!acc[item.type]) {\n acc[item.type] = [];\n }\n acc[item.type].push(item);\n return acc;\n }, {});\n this.itemsPerCategory.set(itemsPerCategory);\n let categories = Object.keys(itemsPerCategory);\n categories.sort()\n this.categories.set(categories.map(type => {\n return {\n label: localize(CONFIG.Item.typeLabels[type]), type\n }\n }));\n }\n \n refreshItemPrices() {\n get(this.allItems).forEach(item => {\n item.refreshPriceData();\n });\n }\n \n createItem(item) {\n if (PileUtilities.isItemInvalid(this.actor, item)) return;\n const items = get(this.allItems);\n const itemClass = new this.ItemClass(this, item);\n itemClass.refreshPriceData();\n items.push(itemClass);\n this.allItems.set(items);\n this.refreshItems();\n }\n \n deleteItem(item) {\n if (PileUtilities.isItemInvalid(this.actor, item)) return;\n const items = get(this.allItems);\n const pileItem = items.find(pileItem => pileItem.id === item.id);\n if (!pileItem) return;\n pileItem.unsubscribe();\n items.splice(items.indexOf(pileItem), 1);\n this.allItems.set(items);\n this.refreshItems();\n }\n \n updatePriceModifiers() {\n let pileData = get(this.pileData);\n this.priceModifiersPerType.set(pileData.itemTypePriceModifiers.reduce((acc, priceData) => {\n acc[priceData.type] = priceData;\n return acc;\n }, {}));\n if (this.recipient && pileData.actorPriceModifiers) {\n const actorSpecificModifiers = pileData.actorPriceModifiers?.find(data => data.actorUuid === this.recipientUuid);\n if (actorSpecificModifiers) {\n this.priceModifiersForActor.set(actorSpecificModifiers);\n }\n }\n }\n \n addOverrideTypePrice(type) {\n const pileData = get(this.pileData);\n pileData.itemTypePriceModifiers.push({\n type: type,\n override: false,\n buyPriceModifier: 1,\n sellPriceModifier: 1\n })\n this.pileData.set(pileData);\n }\n \n removeOverrideTypePrice(type) {\n const pileData = get(this.pileData);\n const priceMods = pileData.itemTypePriceModifiers;\n const typeEntry = priceMods.find(entry => entry.type === type);\n priceMods.splice(priceMods.indexOf(typeEntry), 1);\n this.pileData.set(pileData);\n }\n \n async update() {\n const pileData = get(this.pileData);\n const priceModPerType = get(this.priceModifiersPerType);\n pileData.itemTypePriceModifiers = Object.values(priceModPerType);\n await PileUtilities.updateItemPileData(this.actor, pileData);\n Helpers.custom_notify(localize(\"ITEM-PILES.Notifications.UpdateMerchantSuccess\"));\n }\n \n tradeItem(pileItem, selling) {\n if (get(pileItem.itemFlagData).notForSale && !game.user.isGM) return;\n TradeMerchantItemDialog.show(\n pileItem,\n this.actor,\n this.recipient,\n { selling }\n );\n }\n \n}\n\nclass PileMerchantItem extends PileItem {\n \n setupStores(item) {\n super.setupStores(item);\n this.itemFlagData = writable({});\n this.prices = writable({});\n this.displayQuantity = writable(false);\n this.selectedPriceGroup = writable(-1);\n this.quantityToBuy = writable(1);\n }\n \n setupSubscriptions() {\n let setup = false;\n super.setupSubscriptions();\n this.itemFlagData.set(PileUtilities.getItemFlagData(this.item));\n this.subscribeTo(this.store.pileData, () => {\n if (!setup) return;\n this.refreshPriceData();\n this.refreshDisplayQuantity();\n });\n if (this.store.recipient) {\n this.subscribeTo(this.store.recipientPileData, () => {\n if (!setup) return\n this.refreshPriceData();\n this.refreshDisplayQuantity();\n });\n }\n this.subscribeTo(this.store.priceModifiersPerType, () => {\n if (!setup) return;\n this.refreshPriceData();\n });\n this.subscribeTo(this.quantityToBuy, () => {\n if (!setup) return;\n this.refreshPriceData();\n });\n this.subscribeTo(this.itemDocument, () => {\n if (!setup) return;\n const { data } = this.itemDocument.updateOptions;\n if (hasProperty(data, CONSTANTS.FLAGS.ITEM)) {\n this.itemFlagData.set(PileUtilities.getItemFlagData(this.item));\n this.refreshDisplayQuantity();\n }\n if (hasProperty(data, CONSTANTS.FLAGS.ITEM + \".prices\")) {\n this.refreshPriceData();\n }\n if (hasProperty(data, game.itempiles.ITEM_PRICE_ATTRIBUTE)) {\n this.refreshPriceData();\n }\n });\n setup = true;\n this.refreshDisplayQuantity();\n this.subscribeTo(this.store.typeFilter, this.filter.bind(this));\n }\n \n refreshDisplayQuantity() {\n \n const merchantDisplayQuantity = get(this.store.pileData).displayQuantity;\n \n const itemFlagDataQuantity = get(this.itemFlagData).displayQuantity;\n \n if (itemFlagDataQuantity === \"always\") {\n return this.displayQuantity.set(true);\n }\n \n const itemDisplayQuantity = {\n \"default\": merchantDisplayQuantity === \"yes\",\n \"yes\": true,\n \"no\": false\n }[itemFlagDataQuantity ?? \"default\"];\n \n if (merchantDisplayQuantity.startsWith(\"always\")) {\n return this.displayQuantity.set(merchantDisplayQuantity.endsWith(\"yes\"));\n }\n \n this.displayQuantity.set(itemDisplayQuantity)\n }\n \n refreshPriceData() {\n \n const quantityToBuy = get(this.quantityToBuy);\n const itemFlagData = get(this.itemFlagData);\n const sellerFlagData = get(this.store.pileData);\n const buyerFlagData = get(this.store.recipientPileData);\n const priceData = PileUtilities.getItemPrices(this.item, {\n seller: this.store.actor,\n buyer: this.store.recipient,\n sellerFlagData,\n buyerFlagData,\n itemFlagData,\n quantity: quantityToBuy\n });\n \n let selectedPriceGroup = get(this.selectedPriceGroup);\n if (selectedPriceGroup === -1) {\n selectedPriceGroup = Math.max(0, priceData.findIndex(price => price.maxQuantity));\n this.selectedPriceGroup.set(selectedPriceGroup)\n }\n \n this.prices.set(priceData);\n \n }\n \n filter() {\n const name = get(this.name);\n const search = get(this.store.search);\n const searchFiltered = !name.toLowerCase().includes(search.toLowerCase());\n const typeFilter = get(this.store.typeFilter);\n const typeFiltered = typeFilter !== \"all\" && typeFilter.toLowerCase() !== this.type.toLowerCase();\n this.filtered.set(searchFiltered || typeFiltered);\n }\n \n async updateItemFlagData() {\n const itemFlagData = get(this.itemFlagData);\n await PileUtilities.updateItemData(this.item, { flags: itemFlagData });\n }\n \n}","\r\n\r\n\r\n\r\n
\r\n
\r\n
\r\n\r\n
\r\n\r\n
\r\n\r\n \r\n\r\n {#if activeSidebarTab === 'description'}\r\n \r\n {/if}\r\n\r\n {#if activeSidebarTab === 'settings'}\r\n \r\n\r\n
\r\n\r\n
\r\n\r\n
\r\n\r\n
\r\n \r\n {localize(\"ITEM-PILES.Applications.ItemPileConfig.Merchant.BuyPriceModifier\")}\r\n \r\n \r\n
\r\n\r\n
\r\n \r\n {localize(\"ITEM-PILES.Applications.ItemPileConfig.Merchant.SellPriceModifier\")}\r\n \r\n \r\n
\r\n\r\n
\r\n\r\n
{ store.update(); }}>\r\n Update\r\n \r\n
\r\n {/if}\r\n\r\n \r\n\r\n \r\n\r\n
\r\n\r\n","import { TJSDocument } from \"@typhonjs-fvtt/runtime/svelte/store\";\nimport { writable, get } from \"svelte/store\";\nimport CONSTANTS from \"../../../constants/constants.js\";\nimport * as PileUtilities from \"../../../helpers/pile-utilities.js\";\n\nconst existingStores = new Map();\n\nexport default class ItemPriceStore {\n \n static make(item) {\n if (existingStores.has(item.id)) {\n return existingStores.get(item.id);\n }\n return new this(item);\n }\n \n constructor(item) {\n \n this.item = item;\n this.itemDoc = new TJSDocument(this.item);\n \n this.price = writable(0);\n \n const data = PileUtilities.getItemFlagData(this.item);\n \n data.prices.forEach(group => {\n group.forEach(price => {\n if (!price.id) {\n price.id = randomID();\n }\n });\n });\n \n this.data = writable(data);\n \n this.itemDoc.subscribe((item, changes) => {\n const { data } = changes;\n if (hasProperty(data, CONSTANTS.FLAGS.ITEM)) {\n const newData = getProperty(data, CONSTANTS.FLAGS.ITEM);\n const oldData = get(this.data);\n this.data.set(foundry.utils.mergeObject(oldData, newData));\n }\n this.price.set(getProperty(this.item.toObject(), game.itempiles.ITEM_PRICE_ATTRIBUTE));\n });\n \n }\n \n removeGroup(groupIndex) {\n const data = get(this.data);\n data.prices.splice(groupIndex, 1);\n this.data.set(data);\n }\n \n export() {\n return {\n data: {\n [game.itempiles.ITEM_PRICE_ATTRIBUTE]: get(this.price),\n },\n flags: get(this.data)\n };\n }\n \n}","import { cubicOut } from '../easing/index.mjs';\nimport { is_function } from '../internal/index.mjs';\n\nfunction flip(node, { from, to }, params = {}) {\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n const [ox, oy] = style.transformOrigin.split(' ').map(parseFloat);\n const dx = (from.left + from.width * ox / to.width) - (to.left + ox);\n const dy = (from.top + from.height * oy / to.height) - (to.top + oy);\n const { delay = 0, duration = (d) => Math.sqrt(d) * 120, easing = cubicOut } = params;\n return {\n delay,\n duration: is_function(duration) ? duration(Math.sqrt(dx * dx + dy * dy)) : duration,\n easing,\n css: (t, u) => {\n const x = u * dx;\n const y = u * dy;\n const sx = t + u * from.width / to.width;\n const sy = t + u * from.height / to.height;\n return `transform: ${transform} translate(${x}px, ${y}px) scale(${sx}, ${sy});`;\n }\n };\n}\n\nexport { flip };\n","// external events\nconst FINALIZE_EVENT_NAME = \"finalize\";\nconst CONSIDER_EVENT_NAME = \"consider\";\n\n/**\n * @typedef {Object} Info\n * @property {string} trigger\n * @property {string} id\n * @property {string} source\n * @param {Node} el\n * @param {Array} items\n * @param {Info} info\n */\nexport function dispatchFinalizeEvent(el, items, info) {\n el.dispatchEvent(\n new CustomEvent(FINALIZE_EVENT_NAME, {\n detail: {items, info}\n })\n );\n}\n\n/**\n * Dispatches a consider event\n * @param {Node} el\n * @param {Array} items\n * @param {Info} info\n */\nexport function dispatchConsiderEvent(el, items, info) {\n el.dispatchEvent(\n new CustomEvent(CONSIDER_EVENT_NAME, {\n detail: {items, info}\n })\n );\n}\n\n// internal events\nexport const DRAGGED_ENTERED_EVENT_NAME = \"draggedEntered\";\nexport const DRAGGED_LEFT_EVENT_NAME = \"draggedLeft\";\nexport const DRAGGED_OVER_INDEX_EVENT_NAME = \"draggedOverIndex\";\nexport const DRAGGED_LEFT_DOCUMENT_EVENT_NAME = \"draggedLeftDocument\";\n\nexport const DRAGGED_LEFT_TYPES = {\n LEFT_FOR_ANOTHER: \"leftForAnother\",\n OUTSIDE_OF_ANY: \"outsideOfAny\"\n};\n\nexport function dispatchDraggedElementEnteredContainer(containerEl, indexObj, draggedEl) {\n containerEl.dispatchEvent(\n new CustomEvent(DRAGGED_ENTERED_EVENT_NAME, {\n detail: {indexObj, draggedEl}\n })\n );\n}\n\n/**\n * @param containerEl - the dropzone the element left\n * @param draggedEl - the dragged element\n * @param theOtherDz - the new dropzone the element entered\n */\nexport function dispatchDraggedElementLeftContainerForAnother(containerEl, draggedEl, theOtherDz) {\n containerEl.dispatchEvent(\n new CustomEvent(DRAGGED_LEFT_EVENT_NAME, {\n detail: {draggedEl, type: DRAGGED_LEFT_TYPES.LEFT_FOR_ANOTHER, theOtherDz}\n })\n );\n}\n\nexport function dispatchDraggedElementLeftContainerForNone(containerEl, draggedEl) {\n containerEl.dispatchEvent(\n new CustomEvent(DRAGGED_LEFT_EVENT_NAME, {\n detail: {draggedEl, type: DRAGGED_LEFT_TYPES.OUTSIDE_OF_ANY}\n })\n );\n}\nexport function dispatchDraggedElementIsOverIndex(containerEl, indexObj, draggedEl) {\n containerEl.dispatchEvent(\n new CustomEvent(DRAGGED_OVER_INDEX_EVENT_NAME, {\n detail: {indexObj, draggedEl}\n })\n );\n}\nexport function dispatchDraggedLeftDocument(draggedEl) {\n window.dispatchEvent(\n new CustomEvent(DRAGGED_LEFT_DOCUMENT_EVENT_NAME, {\n detail: {draggedEl}\n })\n );\n}\n","import {DRAGGED_ENTERED_EVENT_NAME, DRAGGED_LEFT_EVENT_NAME, DRAGGED_OVER_INDEX_EVENT_NAME} from \"./helpers/dispatcher\";\n\nexport const TRIGGERS = {\n DRAG_STARTED: \"dragStarted\",\n DRAGGED_ENTERED: DRAGGED_ENTERED_EVENT_NAME,\n DRAGGED_ENTERED_ANOTHER: \"dragEnteredAnother\",\n DRAGGED_OVER_INDEX: DRAGGED_OVER_INDEX_EVENT_NAME,\n DRAGGED_LEFT: DRAGGED_LEFT_EVENT_NAME,\n DRAGGED_LEFT_ALL: \"draggedLeftAll\",\n DROPPED_INTO_ZONE: \"droppedIntoZone\",\n DROPPED_INTO_ANOTHER: \"droppedIntoAnother\",\n DROPPED_OUTSIDE_OF_ANY: \"droppedOutsideOfAny\",\n DRAG_STOPPED: \"dragStopped\"\n};\n\nexport const SOURCES = {\n POINTER: \"pointer\",\n KEYBOARD: \"keyboard\"\n};\n\nexport const SHADOW_ITEM_MARKER_PROPERTY_NAME = \"isDndShadowItem\";\nexport const SHADOW_ELEMENT_ATTRIBUTE_NAME = \"data-is-dnd-shadow-item\";\nexport const SHADOW_PLACEHOLDER_ITEM_ID = \"id:dnd-shadow-placeholder-0000\";\nexport const DRAGGED_ELEMENT_ID = \"dnd-action-dragged-el\";\n\nexport let ITEM_ID_KEY = \"id\";\nlet activeDndZoneCount = 0;\nexport function incrementActiveDropZoneCount() {\n activeDndZoneCount++;\n}\nexport function decrementActiveDropZoneCount() {\n if (activeDndZoneCount === 0) {\n throw new Error(\"Bug! trying to decrement when there are no dropzones\");\n }\n activeDndZoneCount--;\n}\n\n/**\n * Allows using another key instead of \"id\" in the items data. This is global and applies to all dndzones.\n * Has to be called when there are no rendered dndzones whatsoever.\n * @param {String} newKeyName\n * @throws {Error} if it was called when there are rendered dndzones or if it is given the wrong type (not a string)\n */\nexport function overrideItemIdKeyNameBeforeInitialisingDndZones(newKeyName) {\n if (activeDndZoneCount > 0) {\n throw new Error(\"can only override the id key before initialising any dndzone\");\n }\n if (typeof newKeyName !== \"string\") {\n throw new Error(\"item id key has to be a string\");\n }\n printDebug(() => [\"overriding item id key name\", newKeyName]);\n ITEM_ID_KEY = newKeyName;\n}\n\nexport const isOnServer = typeof window === \"undefined\";\n\nexport let printDebug = () => {};\n\n/**\n * Allows the user to show/hide console debug output\n * * @param {Boolean} isDebug\n */\nexport function setDebugMode(isDebug) {\n if (isDebug) {\n printDebug = (generateMessage, logFunction = console.debug) => {\n const message = generateMessage();\n if (Array.isArray(message)) {\n logFunction(...message);\n } else {\n logFunction(message);\n }\n };\n } else {\n printDebug = () => {};\n }\n}\n","// This is based off https://stackoverflow.com/questions/27745438/how-to-compute-getboundingclientrect-without-considering-transforms/57876601#57876601\n// It removes the transforms that are potentially applied by the flip animations\n/**\n * Gets the bounding rect but removes transforms (ex: flip animation)\n * @param {HTMLElement} el\n * @return {{top: number, left: number, bottom: number, right: number}}\n */\nexport function getBoundingRectNoTransforms(el) {\n let ta;\n const rect = el.getBoundingClientRect();\n const style = getComputedStyle(el);\n const tx = style.transform;\n\n if (tx) {\n let sx, sy, dx, dy;\n if (tx.startsWith(\"matrix3d(\")) {\n ta = tx.slice(9, -1).split(/, /);\n sx = +ta[0];\n sy = +ta[5];\n dx = +ta[12];\n dy = +ta[13];\n } else if (tx.startsWith(\"matrix(\")) {\n ta = tx.slice(7, -1).split(/, /);\n sx = +ta[0];\n sy = +ta[3];\n dx = +ta[4];\n dy = +ta[5];\n } else {\n return rect;\n }\n\n const to = style.transformOrigin;\n const x = rect.x - dx - (1 - sx) * parseFloat(to);\n const y = rect.y - dy - (1 - sy) * parseFloat(to.slice(to.indexOf(\" \") + 1));\n const w = sx ? rect.width / sx : el.offsetWidth;\n const h = sy ? rect.height / sy : el.offsetHeight;\n return {\n x: x,\n y: y,\n width: w,\n height: h,\n top: y,\n right: x + w,\n bottom: y + h,\n left: x\n };\n } else {\n return rect;\n }\n}\n\n/**\n * Gets the absolute bounding rect (accounts for the window's scroll position and removes transforms)\n * @param {HTMLElement} el\n * @return {{top: number, left: number, bottom: number, right: number}}\n */\nexport function getAbsoluteRectNoTransforms(el) {\n const rect = getBoundingRectNoTransforms(el);\n return {\n top: rect.top + window.scrollY,\n bottom: rect.bottom + window.scrollY,\n left: rect.left + window.scrollX,\n right: rect.right + window.scrollX\n };\n}\n\n/**\n * Gets the absolute bounding rect (accounts for the window's scroll position)\n * @param {HTMLElement} el\n * @return {{top: number, left: number, bottom: number, right: number}}\n */\nexport function getAbsoluteRect(el) {\n const rect = el.getBoundingClientRect();\n return {\n top: rect.top + window.scrollY,\n bottom: rect.bottom + window.scrollY,\n left: rect.left + window.scrollX,\n right: rect.right + window.scrollX\n };\n}\n\n/**\n * finds the center :)\n * @typedef {Object} Rect\n * @property {number} top\n * @property {number} bottom\n * @property {number} left\n * @property {number} right\n * @param {Rect} rect\n * @return {{x: number, y: number}}\n */\nexport function findCenter(rect) {\n return {\n x: (rect.left + rect.right) / 2,\n y: (rect.top + rect.bottom) / 2\n };\n}\n\n/**\n * @typedef {Object} Point\n * @property {number} x\n * @property {number} y\n * @param {Point} pointA\n * @param {Point} pointB\n * @return {number}\n */\nfunction calcDistance(pointA, pointB) {\n return Math.sqrt(Math.pow(pointA.x - pointB.x, 2) + Math.pow(pointA.y - pointB.y, 2));\n}\n\n/**\n * @param {Point} point\n * @param {Rect} rect\n * @return {boolean|boolean}\n */\nexport function isPointInsideRect(point, rect) {\n return point.y <= rect.bottom && point.y >= rect.top && point.x >= rect.left && point.x <= rect.right;\n}\n\n/**\n * find the absolute coordinates of the center of a dom element\n * @param el {HTMLElement}\n * @returns {{x: number, y: number}}\n */\nexport function findCenterOfElement(el) {\n return findCenter(getAbsoluteRect(el));\n}\n\n/**\n * @param {HTMLElement} elA\n * @param {HTMLElement} elB\n * @return {boolean}\n */\nexport function isCenterOfAInsideB(elA, elB) {\n const centerOfA = findCenterOfElement(elA);\n const rectOfB = getAbsoluteRectNoTransforms(elB);\n return isPointInsideRect(centerOfA, rectOfB);\n}\n\n/**\n * @param {HTMLElement|ChildNode} elA\n * @param {HTMLElement|ChildNode} elB\n * @return {number}\n */\nexport function calcDistanceBetweenCenters(elA, elB) {\n const centerOfA = findCenterOfElement(elA);\n const centerOfB = findCenterOfElement(elB);\n return calcDistance(centerOfA, centerOfB);\n}\n\n/**\n * @param {HTMLElement} el - the element to check\n * @returns {boolean} - true if the element in its entirety is off screen including the scrollable area (the normal dom events look at the mouse rather than the element)\n */\nexport function isElementOffDocument(el) {\n const rect = getAbsoluteRect(el);\n return rect.right < 0 || rect.left > document.documentElement.scrollWidth || rect.bottom < 0 || rect.top > document.documentElement.scrollHeight;\n}\n\n/**\n * If the point is inside the element returns its distances from the sides, otherwise returns null\n * @param {Point} point\n * @param {HTMLElement} el\n * @return {null|{top: number, left: number, bottom: number, right: number}}\n */\nexport function calcInnerDistancesBetweenPointAndSidesOfElement(point, el) {\n const rect = getAbsoluteRect(el);\n if (!isPointInsideRect(point, rect)) {\n return null;\n }\n return {\n top: point.y - rect.top,\n bottom: rect.bottom - point.y,\n left: point.x - rect.left,\n // TODO - figure out what is so special about right (why the rect is too big)\n right: Math.min(rect.right, document.documentElement.clientWidth) - point.x\n };\n}\n","import {isCenterOfAInsideB, calcDistanceBetweenCenters, getAbsoluteRectNoTransforms, isPointInsideRect, findCenterOfElement} from \"./intersection\";\nimport {printDebug, SHADOW_ELEMENT_ATTRIBUTE_NAME} from \"../constants\";\n\nlet dzToShadowIndexToRect;\n\n/**\n * Resets the cache that allows for smarter \"would be index\" resolution. Should be called after every drag operation\n */\nexport function resetIndexesCache() {\n printDebug(() => \"resetting indexes cache\");\n dzToShadowIndexToRect = new Map();\n}\nresetIndexesCache();\n\n/**\n * Resets the cache that allows for smarter \"would be index\" resolution for a specific dropzone, should be called after the zone was scrolled\n * @param {HTMLElement} dz\n */\nexport function resetIndexesCacheForDz(dz) {\n printDebug(() => \"resetting indexes cache for dz\");\n dzToShadowIndexToRect.delete(dz);\n}\n\n/**\n * Caches the coordinates of the shadow element when it's in a certain index in a certain dropzone.\n * Helpful in order to determine \"would be index\" more effectively\n * @param {HTMLElement} dz\n * @return {number} - the shadow element index\n */\nfunction cacheShadowRect(dz) {\n const shadowElIndex = Array.from(dz.children).findIndex(child => child.getAttribute(SHADOW_ELEMENT_ATTRIBUTE_NAME));\n if (shadowElIndex >= 0) {\n if (!dzToShadowIndexToRect.has(dz)) {\n dzToShadowIndexToRect.set(dz, new Map());\n }\n dzToShadowIndexToRect.get(dz).set(shadowElIndex, getAbsoluteRectNoTransforms(dz.children[shadowElIndex]));\n return shadowElIndex;\n }\n return undefined;\n}\n\n/**\n * @typedef {Object} Index\n * @property {number} index - the would be index\n * @property {boolean} isProximityBased - false if the element is actually over the index, true if it is not over it but this index is the closest\n */\n/**\n * Find the index for the dragged element in the list it is dragged over\n * @param {HTMLElement} floatingAboveEl\n * @param {HTMLElement} collectionBelowEl\n * @returns {Index|null} - if the element is over the container the Index object otherwise null\n */\nexport function findWouldBeIndex(floatingAboveEl, collectionBelowEl) {\n if (!isCenterOfAInsideB(floatingAboveEl, collectionBelowEl)) {\n return null;\n }\n const children = collectionBelowEl.children;\n // the container is empty, floating element should be the first\n if (children.length === 0) {\n return {index: 0, isProximityBased: true};\n }\n const shadowElIndex = cacheShadowRect(collectionBelowEl);\n\n // the search could be more efficient but keeping it simple for now\n // a possible improvement: pass in the lastIndex it was found in and check there first, then expand from there\n for (let i = 0; i < children.length; i++) {\n if (isCenterOfAInsideB(floatingAboveEl, children[i])) {\n const cachedShadowRect = dzToShadowIndexToRect.has(collectionBelowEl) && dzToShadowIndexToRect.get(collectionBelowEl).get(i);\n if (cachedShadowRect) {\n if (!isPointInsideRect(findCenterOfElement(floatingAboveEl), cachedShadowRect)) {\n return {index: shadowElIndex, isProximityBased: false};\n }\n }\n return {index: i, isProximityBased: false};\n }\n }\n // this can happen if there is space around the children so the floating element has\n //entered the container but not any of the children, in this case we will find the nearest child\n let minDistanceSoFar = Number.MAX_VALUE;\n let indexOfMin = undefined;\n // we are checking all of them because we don't know whether we are dealing with a horizontal or vertical container and where the floating element entered from\n for (let i = 0; i < children.length; i++) {\n const distance = calcDistanceBetweenCenters(floatingAboveEl, children[i]);\n if (distance < minDistanceSoFar) {\n minDistanceSoFar = distance;\n indexOfMin = i;\n }\n }\n return {index: indexOfMin, isProximityBased: true};\n}\n","import {calcInnerDistancesBetweenPointAndSidesOfElement} from \"./intersection\";\nconst SCROLL_ZONE_PX = 25;\n\nexport function makeScroller() {\n let scrollingInfo;\n function resetScrolling() {\n scrollingInfo = {directionObj: undefined, stepPx: 0};\n }\n resetScrolling();\n // directionObj {x: 0|1|-1, y:0|1|-1} - 1 means down in y and right in x\n function scrollContainer(containerEl) {\n const {directionObj, stepPx} = scrollingInfo;\n if (directionObj) {\n containerEl.scrollBy(directionObj.x * stepPx, directionObj.y * stepPx);\n window.requestAnimationFrame(() => scrollContainer(containerEl));\n }\n }\n function calcScrollStepPx(distancePx) {\n return SCROLL_ZONE_PX - distancePx;\n }\n\n /**\n * If the pointer is next to the sides of the element to scroll, will trigger scrolling\n * Can be called repeatedly with updated pointer and elementToScroll values without issues\n * @return {boolean} - true if scrolling was needed\n */\n function scrollIfNeeded(pointer, elementToScroll) {\n if (!elementToScroll) {\n return false;\n }\n const distances = calcInnerDistancesBetweenPointAndSidesOfElement(pointer, elementToScroll);\n if (distances === null) {\n resetScrolling();\n return false;\n }\n const isAlreadyScrolling = !!scrollingInfo.directionObj;\n let [scrollingVertically, scrollingHorizontally] = [false, false];\n // vertical\n if (elementToScroll.scrollHeight > elementToScroll.clientHeight) {\n if (distances.bottom < SCROLL_ZONE_PX) {\n scrollingVertically = true;\n scrollingInfo.directionObj = {x: 0, y: 1};\n scrollingInfo.stepPx = calcScrollStepPx(distances.bottom);\n } else if (distances.top < SCROLL_ZONE_PX) {\n scrollingVertically = true;\n scrollingInfo.directionObj = {x: 0, y: -1};\n scrollingInfo.stepPx = calcScrollStepPx(distances.top);\n }\n if (!isAlreadyScrolling && scrollingVertically) {\n scrollContainer(elementToScroll);\n return true;\n }\n }\n // horizontal\n if (elementToScroll.scrollWidth > elementToScroll.clientWidth) {\n if (distances.right < SCROLL_ZONE_PX) {\n scrollingHorizontally = true;\n scrollingInfo.directionObj = {x: 1, y: 0};\n scrollingInfo.stepPx = calcScrollStepPx(distances.right);\n } else if (distances.left < SCROLL_ZONE_PX) {\n scrollingHorizontally = true;\n scrollingInfo.directionObj = {x: -1, y: 0};\n scrollingInfo.stepPx = calcScrollStepPx(distances.left);\n }\n if (!isAlreadyScrolling && scrollingHorizontally) {\n scrollContainer(elementToScroll);\n return true;\n }\n }\n resetScrolling();\n return false;\n }\n\n return {\n scrollIfNeeded,\n resetScrolling\n };\n}\n","/**\n * @param {Object} object\n * @return {string}\n */\nexport function toString(object) {\n return JSON.stringify(object, null, 2);\n}\n\n/**\n * Finds the depth of the given node in the DOM tree\n * @param {HTMLElement} node\n * @return {number} - the depth of the node\n */\nexport function getDepth(node) {\n if (!node) {\n throw new Error(\"cannot get depth of a falsy node\");\n }\n return _getDepth(node, 0);\n}\nfunction _getDepth(node, countSoFar = 0) {\n if (!node.parentElement) {\n return countSoFar - 1;\n }\n return _getDepth(node.parentElement, countSoFar + 1);\n}\n\n/**\n * A simple util to shallow compare objects quickly, it doesn't validate the arguments so pass objects in\n * @param {Object} objA\n * @param {Object} objB\n * @return {boolean} - true if objA and objB are shallow equal\n */\nexport function areObjectsShallowEqual(objA, objB) {\n if (Object.keys(objA).length !== Object.keys(objB).length) {\n return false;\n }\n for (const keyA in objA) {\n if (!{}.hasOwnProperty.call(objB, keyA) || objB[keyA] !== objA[keyA]) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Shallow compares two arrays\n * @param arrA\n * @param arrB\n * @return {boolean} - whether the arrays are shallow equal\n */\nexport function areArraysShallowEqualSameOrder(arrA, arrB) {\n if (arrA.length !== arrB.length) {\n return false;\n }\n for (let i = 0; i < arrA.length; i++) {\n if (arrA[i] !== arrB[i]) {\n return false;\n }\n }\n return true;\n}\n","import {findWouldBeIndex, resetIndexesCache, resetIndexesCacheForDz} from \"./listUtil\";\nimport {findCenterOfElement, isElementOffDocument} from \"./intersection\";\nimport {\n dispatchDraggedElementEnteredContainer,\n dispatchDraggedElementLeftContainerForAnother,\n dispatchDraggedElementLeftContainerForNone,\n dispatchDraggedLeftDocument,\n dispatchDraggedElementIsOverIndex\n} from \"./dispatcher\";\nimport {makeScroller} from \"./scroller\";\nimport {getDepth} from \"./util\";\nimport {printDebug} from \"../constants\";\n\nconst INTERVAL_MS = 200;\nconst TOLERANCE_PX = 10;\nconst {scrollIfNeeded, resetScrolling} = makeScroller();\nlet next;\n\n/**\n * Tracks the dragged elements and performs the side effects when it is dragged over a drop zone (basically dispatching custom-events scrolling)\n * @param {Set} dropZones\n * @param {HTMLElement} draggedEl\n * @param {number} [intervalMs = INTERVAL_MS]\n */\nexport function observe(draggedEl, dropZones, intervalMs = INTERVAL_MS) {\n // initialization\n let lastDropZoneFound;\n let lastIndexFound;\n let lastIsDraggedInADropZone = false;\n let lastCentrePositionOfDragged;\n // We are sorting to make sure that in case of nested zones of the same type the one \"on top\" is considered first\n const dropZonesFromDeepToShallow = Array.from(dropZones).sort((dz1, dz2) => getDepth(dz2) - getDepth(dz1));\n\n /**\n * The main function in this module. Tracks where everything is/ should be a take the actions\n */\n function andNow() {\n const currentCenterOfDragged = findCenterOfElement(draggedEl);\n const scrolled = scrollIfNeeded(currentCenterOfDragged, lastDropZoneFound);\n // we only want to make a new decision after the element was moved a bit to prevent flickering\n if (\n !scrolled &&\n lastCentrePositionOfDragged &&\n Math.abs(lastCentrePositionOfDragged.x - currentCenterOfDragged.x) < TOLERANCE_PX &&\n Math.abs(lastCentrePositionOfDragged.y - currentCenterOfDragged.y) < TOLERANCE_PX\n ) {\n next = window.setTimeout(andNow, intervalMs);\n return;\n }\n if (isElementOffDocument(draggedEl)) {\n printDebug(() => \"off document\");\n dispatchDraggedLeftDocument(draggedEl);\n return;\n }\n\n lastCentrePositionOfDragged = currentCenterOfDragged;\n // this is a simple algorithm, potential improvement: first look at lastDropZoneFound\n let isDraggedInADropZone = false;\n for (const dz of dropZonesFromDeepToShallow) {\n if (scrolled) resetIndexesCacheForDz(lastDropZoneFound);\n const indexObj = findWouldBeIndex(draggedEl, dz);\n if (indexObj === null) {\n // it is not inside\n continue;\n }\n const {index} = indexObj;\n isDraggedInADropZone = true;\n // the element is over a container\n if (dz !== lastDropZoneFound) {\n lastDropZoneFound && dispatchDraggedElementLeftContainerForAnother(lastDropZoneFound, draggedEl, dz);\n dispatchDraggedElementEnteredContainer(dz, indexObj, draggedEl);\n lastDropZoneFound = dz;\n } else if (index !== lastIndexFound) {\n dispatchDraggedElementIsOverIndex(dz, indexObj, draggedEl);\n lastIndexFound = index;\n }\n // we handle looping with the 'continue' statement above\n break;\n }\n // the first time the dragged element is not in any dropzone we need to notify the last dropzone it was in\n if (!isDraggedInADropZone && lastIsDraggedInADropZone && lastDropZoneFound) {\n dispatchDraggedElementLeftContainerForNone(lastDropZoneFound, draggedEl);\n lastDropZoneFound = undefined;\n lastIndexFound = undefined;\n lastIsDraggedInADropZone = false;\n } else {\n lastIsDraggedInADropZone = true;\n }\n next = window.setTimeout(andNow, intervalMs);\n }\n andNow();\n}\n\n// assumption - we can only observe one dragged element at a time, this could be changed in the future\nexport function unobserve() {\n printDebug(() => \"unobserving\");\n clearTimeout(next);\n resetScrolling();\n resetIndexesCache();\n}\n","import {makeScroller} from \"./scroller\";\nimport {printDebug} from \"../constants\";\nimport {resetIndexesCache} from \"./listUtil\";\n\nconst INTERVAL_MS = 300;\nlet mousePosition;\n\n/**\n * Do not use this! it is visible for testing only until we get over the issue Cypress not triggering the mousemove listeners\n * // TODO - make private (remove export)\n * @param {{clientX: number, clientY: number}} e\n */\nexport function updateMousePosition(e) {\n const c = e.touches ? e.touches[0] : e;\n mousePosition = {x: c.clientX, y: c.clientY};\n}\nconst {scrollIfNeeded, resetScrolling} = makeScroller();\nlet next;\n\nfunction loop() {\n if (mousePosition) {\n const scrolled = scrollIfNeeded(mousePosition, document.documentElement);\n if (scrolled) resetIndexesCache();\n }\n next = window.setTimeout(loop, INTERVAL_MS);\n}\n\n/**\n * will start watching the mouse pointer and scroll the window if it goes next to the edges\n */\nexport function armWindowScroller() {\n printDebug(() => \"arming window scroller\");\n window.addEventListener(\"mousemove\", updateMousePosition);\n window.addEventListener(\"touchmove\", updateMousePosition);\n loop();\n}\n\n/**\n * will stop watching the mouse pointer and won't scroll the window anymore\n */\nexport function disarmWindowScroller() {\n printDebug(() => \"disarming window scroller\");\n window.removeEventListener(\"mousemove\", updateMousePosition);\n window.removeEventListener(\"touchmove\", updateMousePosition);\n mousePosition = undefined;\n window.clearTimeout(next);\n resetScrolling();\n}\n","/**\n * Fixes svelte issue when cloning node containing (or being) which will loose it's value.\n * Since svelte manages select value internally.\n * @see https://github.com/sveltejs/svelte/issues/6717\n * @see https://github.com/isaacHagoel/svelte-dnd-action/issues/306\n * \n * @param {HTMLElement} el \n * @returns \n */\nexport function svelteNodeClone(el) {\n const cloned = el.cloneNode(true);\n\n const values = [];\n const elIsSelect = el.tagName === \"SELECT\";\n const selects = elIsSelect ? [el] : [...el.querySelectorAll('select')];\n for (const select of selects) {\n values.push(select.value);\n }\n\n if (selects.length <= 0) {\n return cloned;\n }\n\n const clonedSelects = elIsSelect ? [cloned] : [...cloned.querySelectorAll('select')];\n for (let i = 0; i < clonedSelects.length; i++) {\n const select = clonedSelects[i];\n const value = values[i];\n const optionEl = select.querySelector(`option[value=\"${value}\"`);\n if (optionEl) {\n optionEl.setAttribute('selected', true);\n }\n }\n\n return cloned;\n}\n","import {SHADOW_ELEMENT_ATTRIBUTE_NAME, DRAGGED_ELEMENT_ID} from \"../constants\";\nimport {findCenter} from \"./intersection\";\nimport { svelteNodeClone } from \"./svelteNodeClone\";\n\nconst TRANSITION_DURATION_SECONDS = 0.2;\n\n/**\n * private helper function - creates a transition string for a property\n * @param {string} property\n * @return {string} - the transition string\n */\nfunction trs(property) {\n return `${property} ${TRANSITION_DURATION_SECONDS}s ease`;\n}\n/**\n * clones the given element and applies proper styles and transitions to the dragged element\n * @param {HTMLElement} originalElement\n * @param {Point} [positionCenterOnXY]\n * @return {Node} - the cloned, styled element\n */\nexport function createDraggedElementFrom(originalElement, positionCenterOnXY) {\n const rect = originalElement.getBoundingClientRect();\n const draggedEl = svelteNodeClone(originalElement);\n copyStylesFromTo(originalElement, draggedEl);\n draggedEl.id = DRAGGED_ELEMENT_ID;\n draggedEl.style.position = \"fixed\";\n let elTopPx = rect.top;\n let elLeftPx = rect.left;\n draggedEl.style.top = `${elTopPx}px`;\n draggedEl.style.left = `${elLeftPx}px`;\n if (positionCenterOnXY) {\n const center = findCenter(rect);\n elTopPx -= center.y - positionCenterOnXY.y;\n elLeftPx -= center.x - positionCenterOnXY.x;\n window.setTimeout(() => {\n draggedEl.style.top = `${elTopPx}px`;\n draggedEl.style.left = `${elLeftPx}px`;\n }, 0);\n }\n draggedEl.style.margin = \"0\";\n // we can't have relative or automatic height and width or it will break the illusion\n draggedEl.style.boxSizing = \"border-box\";\n draggedEl.style.height = `${rect.height}px`;\n draggedEl.style.width = `${rect.width}px`;\n draggedEl.style.transition = `${trs(\"top\")}, ${trs(\"left\")}, ${trs(\"background-color\")}, ${trs(\"opacity\")}, ${trs(\"color\")} `;\n // this is a workaround for a strange browser bug that causes the right border to disappear when all the transitions are added at the same time\n window.setTimeout(() => (draggedEl.style.transition += `, ${trs(\"width\")}, ${trs(\"height\")}`), 0);\n draggedEl.style.zIndex = \"9999\";\n draggedEl.style.cursor = \"grabbing\";\n\n return draggedEl;\n}\n\n/**\n * styles the dragged element to a 'dropped' state\n * @param {HTMLElement} draggedEl\n */\nexport function moveDraggedElementToWasDroppedState(draggedEl) {\n draggedEl.style.cursor = \"grab\";\n}\n\n/**\n * Morphs the dragged element style, maintains the mouse pointer within the element\n * @param {HTMLElement} draggedEl\n * @param {HTMLElement} copyFromEl - the element the dragged element should look like, typically the shadow element\n * @param {number} currentMouseX\n * @param {number} currentMouseY\n * @param {function} transformDraggedElement - function to transform the dragged element, does nothing by default.\n */\nexport function morphDraggedElementToBeLike(draggedEl, copyFromEl, currentMouseX, currentMouseY, transformDraggedElement) {\n const newRect = copyFromEl.getBoundingClientRect();\n const draggedElRect = draggedEl.getBoundingClientRect();\n const widthChange = newRect.width - draggedElRect.width;\n const heightChange = newRect.height - draggedElRect.height;\n if (widthChange || heightChange) {\n const relativeDistanceOfMousePointerFromDraggedSides = {\n left: (currentMouseX - draggedElRect.left) / draggedElRect.width,\n top: (currentMouseY - draggedElRect.top) / draggedElRect.height\n };\n draggedEl.style.height = `${newRect.height}px`;\n draggedEl.style.width = `${newRect.width}px`;\n draggedEl.style.left = `${parseFloat(draggedEl.style.left) - relativeDistanceOfMousePointerFromDraggedSides.left * widthChange}px`;\n draggedEl.style.top = `${parseFloat(draggedEl.style.top) - relativeDistanceOfMousePointerFromDraggedSides.top * heightChange}px`;\n }\n\n /// other properties\n copyStylesFromTo(copyFromEl, draggedEl);\n transformDraggedElement();\n}\n\n/**\n * @param {HTMLElement} copyFromEl\n * @param {HTMLElement} copyToEl\n */\nfunction copyStylesFromTo(copyFromEl, copyToEl) {\n const computedStyle = window.getComputedStyle(copyFromEl);\n Array.from(computedStyle)\n .filter(\n s =>\n s.startsWith(\"background\") ||\n s.startsWith(\"padding\") ||\n s.startsWith(\"font\") ||\n s.startsWith(\"text\") ||\n s.startsWith(\"align\") ||\n s.startsWith(\"justify\") ||\n s.startsWith(\"display\") ||\n s.startsWith(\"flex\") ||\n s.startsWith(\"border\") ||\n s === \"opacity\" ||\n s === \"color\" ||\n s === \"list-style-type\"\n )\n .forEach(s => copyToEl.style.setProperty(s, computedStyle.getPropertyValue(s), computedStyle.getPropertyPriority(s)));\n}\n\n/**\n * makes the element compatible with being draggable\n * @param {HTMLElement} draggableEl\n * @param {boolean} dragDisabled\n */\nexport function styleDraggable(draggableEl, dragDisabled) {\n draggableEl.draggable = false;\n draggableEl.ondragstart = () => false;\n if (!dragDisabled) {\n draggableEl.style.userSelect = \"none\";\n draggableEl.style.WebkitUserSelect = \"none\";\n draggableEl.style.cursor = \"grab\";\n } else {\n draggableEl.style.userSelect = \"\";\n draggableEl.style.WebkitUserSelect = \"\";\n draggableEl.style.cursor = \"\";\n }\n}\n\n/**\n * Hides the provided element so that it can stay in the dom without interrupting\n * @param {HTMLElement} dragTarget\n */\nexport function hideElement(dragTarget) {\n dragTarget.style.display = \"none\";\n dragTarget.style.position = \"fixed\";\n dragTarget.style.zIndex = \"-5\";\n}\n\n/**\n * styles the shadow element\n * @param {HTMLElement} shadowEl\n */\nexport function decorateShadowEl(shadowEl) {\n shadowEl.style.visibility = \"hidden\";\n shadowEl.setAttribute(SHADOW_ELEMENT_ATTRIBUTE_NAME, \"true\");\n}\n\n/**\n * undo the styles the shadow element\n * @param {HTMLElement} shadowEl\n */\nexport function unDecorateShadowElement(shadowEl) {\n shadowEl.style.visibility = \"\";\n shadowEl.removeAttribute(SHADOW_ELEMENT_ATTRIBUTE_NAME);\n}\n\n/**\n * will mark the given dropzones as visually active\n * @param {Array} dropZones\n * @param {Function} getStyles - maps a dropzone to a styles object (so the styles can be removed)\n * @param {Function} getClasses - maps a dropzone to a classList\n */\nexport function styleActiveDropZones(dropZones, getStyles = () => {}, getClasses = () => []) {\n dropZones.forEach(dz => {\n const styles = getStyles(dz);\n Object.keys(styles).forEach(style => {\n dz.style[style] = styles[style];\n });\n getClasses(dz).forEach(c => dz.classList.add(c));\n });\n}\n\n/**\n * will remove the 'active' styling from given dropzones\n * @param {Array} dropZones\n * @param {Function} getStyles - maps a dropzone to a styles object\n * @param {Function} getClasses - maps a dropzone to a classList\n */\nexport function styleInactiveDropZones(dropZones, getStyles = () => {}, getClasses = () => []) {\n dropZones.forEach(dz => {\n const styles = getStyles(dz);\n Object.keys(styles).forEach(style => {\n dz.style[style] = \"\";\n });\n getClasses(dz).forEach(c => dz.classList.contains(c) && dz.classList.remove(c));\n });\n}\n\n/**\n * will prevent the provided element from shrinking by setting its minWidth and minHeight to the current width and height values\n * @param {HTMLElement} el\n * @return {function(): void} - run this function to undo the operation and restore the original values\n */\nexport function preventShrinking(el) {\n const originalMinHeight = el.style.minHeight;\n el.style.minHeight = window.getComputedStyle(el).getPropertyValue(\"height\");\n const originalMinWidth = el.style.minWidth;\n el.style.minWidth = window.getComputedStyle(el).getPropertyValue(\"width\");\n return function undo() {\n el.style.minHeight = originalMinHeight;\n el.style.minWidth = originalMinWidth;\n };\n}\n","import {\n decrementActiveDropZoneCount,\n incrementActiveDropZoneCount,\n ITEM_ID_KEY,\n printDebug,\n SHADOW_ITEM_MARKER_PROPERTY_NAME,\n SHADOW_PLACEHOLDER_ITEM_ID,\n SOURCES,\n TRIGGERS\n} from \"./constants\";\nimport {observe, unobserve} from \"./helpers/observer\";\nimport {armWindowScroller, disarmWindowScroller} from \"./helpers/windowScroller\";\nimport {\n createDraggedElementFrom,\n decorateShadowEl,\n hideElement,\n morphDraggedElementToBeLike,\n moveDraggedElementToWasDroppedState,\n preventShrinking,\n styleActiveDropZones,\n styleDraggable,\n styleInactiveDropZones,\n unDecorateShadowElement\n} from \"./helpers/styler\";\nimport {\n dispatchConsiderEvent,\n dispatchFinalizeEvent,\n DRAGGED_ENTERED_EVENT_NAME,\n DRAGGED_LEFT_DOCUMENT_EVENT_NAME,\n DRAGGED_LEFT_EVENT_NAME,\n DRAGGED_LEFT_TYPES,\n DRAGGED_OVER_INDEX_EVENT_NAME\n} from \"./helpers/dispatcher\";\nimport {areArraysShallowEqualSameOrder, areObjectsShallowEqual, toString} from \"./helpers/util\";\nimport {getBoundingRectNoTransforms} from \"./helpers/intersection\";\n\nconst DEFAULT_DROP_ZONE_TYPE = \"--any--\";\nconst MIN_OBSERVATION_INTERVAL_MS = 100;\nconst MIN_MOVEMENT_BEFORE_DRAG_START_PX = 3;\nconst DEFAULT_DROP_TARGET_STYLE = {\n outline: \"rgba(255, 255, 102, 0.7) solid 2px\"\n};\n\nlet originalDragTarget;\nlet draggedEl;\nlet draggedElData;\nlet draggedElType;\nlet originDropZone;\nlet originIndex;\nlet shadowElData;\nlet shadowElDropZone;\nlet dragStartMousePosition;\nlet currentMousePosition;\nlet isWorkingOnPreviousDrag = false;\nlet finalizingPreviousDrag = false;\nlet unlockOriginDzMinDimensions;\nlet isDraggedOutsideOfAnyDz = false;\nlet scheduledForRemovalAfterDrop = [];\n\n// a map from type to a set of drop-zones\nconst typeToDropZones = new Map();\n// important - this is needed because otherwise the config that would be used for everyone is the config of the element that created the event listeners\nconst dzToConfig = new Map();\n// this is needed in order to be able to cleanup old listeners and avoid stale closures issues (as the listener is defined within each zone)\nconst elToMouseDownListener = new WeakMap();\n\n/* drop-zones registration management */\nfunction registerDropZone(dropZoneEl, type) {\n printDebug(() => \"registering drop-zone if absent\");\n if (!typeToDropZones.has(type)) {\n typeToDropZones.set(type, new Set());\n }\n if (!typeToDropZones.get(type).has(dropZoneEl)) {\n typeToDropZones.get(type).add(dropZoneEl);\n incrementActiveDropZoneCount();\n }\n}\nfunction unregisterDropZone(dropZoneEl, type) {\n typeToDropZones.get(type).delete(dropZoneEl);\n decrementActiveDropZoneCount();\n if (typeToDropZones.get(type).size === 0) {\n typeToDropZones.delete(type);\n }\n}\n\n/* functions to manage observing the dragged element and trigger custom drag-events */\nfunction watchDraggedElement() {\n printDebug(() => \"watching dragged element\");\n armWindowScroller();\n const dropZones = typeToDropZones.get(draggedElType);\n for (const dz of dropZones) {\n dz.addEventListener(DRAGGED_ENTERED_EVENT_NAME, handleDraggedEntered);\n dz.addEventListener(DRAGGED_LEFT_EVENT_NAME, handleDraggedLeft);\n dz.addEventListener(DRAGGED_OVER_INDEX_EVENT_NAME, handleDraggedIsOverIndex);\n }\n window.addEventListener(DRAGGED_LEFT_DOCUMENT_EVENT_NAME, handleDrop);\n // it is important that we don't have an interval that is faster than the flip duration because it can cause elements to jump bach and forth\n const observationIntervalMs = Math.max(\n MIN_OBSERVATION_INTERVAL_MS,\n ...Array.from(dropZones.keys()).map(dz => dzToConfig.get(dz).dropAnimationDurationMs)\n );\n observe(draggedEl, dropZones, observationIntervalMs * 1.07);\n}\nfunction unWatchDraggedElement() {\n printDebug(() => \"unwatching dragged element\");\n disarmWindowScroller();\n const dropZones = typeToDropZones.get(draggedElType);\n for (const dz of dropZones) {\n dz.removeEventListener(DRAGGED_ENTERED_EVENT_NAME, handleDraggedEntered);\n dz.removeEventListener(DRAGGED_LEFT_EVENT_NAME, handleDraggedLeft);\n dz.removeEventListener(DRAGGED_OVER_INDEX_EVENT_NAME, handleDraggedIsOverIndex);\n }\n window.removeEventListener(DRAGGED_LEFT_DOCUMENT_EVENT_NAME, handleDrop);\n unobserve();\n}\n\n// finds the initial placeholder that is placed there on drag start\nfunction findShadowPlaceHolderIdx(items) {\n return items.findIndex(item => item[ITEM_ID_KEY] === SHADOW_PLACEHOLDER_ITEM_ID);\n}\nfunction findShadowElementIdx(items) {\n // checking that the id is not the placeholder's for Dragula like usecases\n return items.findIndex(item => !!item[SHADOW_ITEM_MARKER_PROPERTY_NAME] && item[ITEM_ID_KEY] !== SHADOW_PLACEHOLDER_ITEM_ID);\n}\n\n/* custom drag-events handlers */\nfunction handleDraggedEntered(e) {\n printDebug(() => [\"dragged entered\", e.currentTarget, e.detail]);\n let {items, dropFromOthersDisabled} = dzToConfig.get(e.currentTarget);\n if (dropFromOthersDisabled && e.currentTarget !== originDropZone) {\n printDebug(() => \"ignoring dragged entered because drop is currently disabled\");\n return;\n }\n isDraggedOutsideOfAnyDz = false;\n // this deals with another race condition. in rare occasions (super rapid operations) the list hasn't updated yet\n items = items.filter(item => item[ITEM_ID_KEY] !== shadowElData[ITEM_ID_KEY]);\n printDebug(() => `dragged entered items ${toString(items)}`);\n\n if (originDropZone !== e.currentTarget) {\n const originZoneItems = dzToConfig.get(originDropZone).items;\n const newOriginZoneItems = originZoneItems.filter(item => !item[SHADOW_ITEM_MARKER_PROPERTY_NAME]);\n dispatchConsiderEvent(originDropZone, newOriginZoneItems, {\n trigger: TRIGGERS.DRAGGED_ENTERED_ANOTHER,\n id: draggedElData[ITEM_ID_KEY],\n source: SOURCES.POINTER\n });\n } else {\n const shadowPlaceHolderIdx = findShadowPlaceHolderIdx(items);\n if (shadowPlaceHolderIdx !== -1) {\n // only happens right after drag start, on the first drag entered event\n printDebug(() => \"removing placeholder item from origin dz\");\n items.splice(shadowPlaceHolderIdx, 1);\n }\n }\n\n const {index, isProximityBased} = e.detail.indexObj;\n const shadowElIdx = isProximityBased && index === e.currentTarget.children.length - 1 ? index + 1 : index;\n shadowElDropZone = e.currentTarget;\n items.splice(shadowElIdx, 0, shadowElData);\n dispatchConsiderEvent(e.currentTarget, items, {trigger: TRIGGERS.DRAGGED_ENTERED, id: draggedElData[ITEM_ID_KEY], source: SOURCES.POINTER});\n}\n\nfunction handleDraggedLeft(e) {\n // dealing with a rare race condition on extremely rapid clicking and dropping\n if (!isWorkingOnPreviousDrag) return;\n printDebug(() => [\"dragged left\", e.currentTarget, e.detail]);\n const {items, dropFromOthersDisabled} = dzToConfig.get(e.currentTarget);\n if (dropFromOthersDisabled && e.currentTarget !== originDropZone && e.currentTarget !== shadowElDropZone) {\n printDebug(() => \"drop is currently disabled\");\n return;\n }\n const shadowElIdx = findShadowElementIdx(items);\n const shadowItem = items.splice(shadowElIdx, 1)[0];\n shadowElDropZone = undefined;\n const {type, theOtherDz} = e.detail;\n if (\n type === DRAGGED_LEFT_TYPES.OUTSIDE_OF_ANY ||\n (type === DRAGGED_LEFT_TYPES.LEFT_FOR_ANOTHER && theOtherDz !== originDropZone && dzToConfig.get(theOtherDz).dropFromOthersDisabled)\n ) {\n printDebug(() => \"dragged left all, putting shadow element back in the origin dz\");\n isDraggedOutsideOfAnyDz = true;\n shadowElDropZone = originDropZone;\n const originZoneItems = dzToConfig.get(originDropZone).items;\n originZoneItems.splice(originIndex, 0, shadowItem);\n dispatchConsiderEvent(originDropZone, originZoneItems, {\n trigger: TRIGGERS.DRAGGED_LEFT_ALL,\n id: draggedElData[ITEM_ID_KEY],\n source: SOURCES.POINTER\n });\n }\n // for the origin dz, when the dragged is outside of any, this will be fired in addition to the previous. this is for simplicity\n dispatchConsiderEvent(e.currentTarget, items, {\n trigger: TRIGGERS.DRAGGED_LEFT,\n id: draggedElData[ITEM_ID_KEY],\n source: SOURCES.POINTER\n });\n}\nfunction handleDraggedIsOverIndex(e) {\n printDebug(() => [\"dragged is over index\", e.currentTarget, e.detail]);\n const {items, dropFromOthersDisabled} = dzToConfig.get(e.currentTarget);\n if (dropFromOthersDisabled && e.currentTarget !== originDropZone) {\n printDebug(() => \"drop is currently disabled\");\n return;\n }\n isDraggedOutsideOfAnyDz = false;\n const {index} = e.detail.indexObj;\n const shadowElIdx = findShadowElementIdx(items);\n items.splice(shadowElIdx, 1);\n items.splice(index, 0, shadowElData);\n dispatchConsiderEvent(e.currentTarget, items, {trigger: TRIGGERS.DRAGGED_OVER_INDEX, id: draggedElData[ITEM_ID_KEY], source: SOURCES.POINTER});\n}\n\n// Global mouse/touch-events handlers\nfunction handleMouseMove(e) {\n e.preventDefault();\n const c = e.touches ? e.touches[0] : e;\n currentMousePosition = {x: c.clientX, y: c.clientY};\n draggedEl.style.transform = `translate3d(${currentMousePosition.x - dragStartMousePosition.x}px, ${\n currentMousePosition.y - dragStartMousePosition.y\n }px, 0)`;\n}\n\nfunction handleDrop() {\n printDebug(() => \"dropped\");\n finalizingPreviousDrag = true;\n // cleanup\n window.removeEventListener(\"mousemove\", handleMouseMove);\n window.removeEventListener(\"touchmove\", handleMouseMove);\n window.removeEventListener(\"mouseup\", handleDrop);\n window.removeEventListener(\"touchend\", handleDrop);\n unWatchDraggedElement();\n moveDraggedElementToWasDroppedState(draggedEl);\n\n if (!shadowElDropZone) {\n printDebug(() => \"element was dropped right after it left origin but before entering somewhere else\");\n shadowElDropZone = originDropZone;\n }\n printDebug(() => [\"dropped in dz\", shadowElDropZone]);\n let {items, type} = dzToConfig.get(shadowElDropZone);\n styleInactiveDropZones(\n typeToDropZones.get(type),\n dz => dzToConfig.get(dz).dropTargetStyle,\n dz => dzToConfig.get(dz).dropTargetClasses\n );\n let shadowElIdx = findShadowElementIdx(items);\n // the handler might remove the shadow element, ex: dragula like copy on drag\n if (shadowElIdx === -1) shadowElIdx = originIndex;\n items = items.map(item => (item[SHADOW_ITEM_MARKER_PROPERTY_NAME] ? draggedElData : item));\n function finalizeWithinZone() {\n unlockOriginDzMinDimensions();\n dispatchFinalizeEvent(shadowElDropZone, items, {\n trigger: isDraggedOutsideOfAnyDz ? TRIGGERS.DROPPED_OUTSIDE_OF_ANY : TRIGGERS.DROPPED_INTO_ZONE,\n id: draggedElData[ITEM_ID_KEY],\n source: SOURCES.POINTER\n });\n if (shadowElDropZone !== originDropZone) {\n // letting the origin drop zone know the element was permanently taken away\n dispatchFinalizeEvent(originDropZone, dzToConfig.get(originDropZone).items, {\n trigger: TRIGGERS.DROPPED_INTO_ANOTHER,\n id: draggedElData[ITEM_ID_KEY],\n source: SOURCES.POINTER\n });\n }\n unDecorateShadowElement(shadowElDropZone.children[shadowElIdx]);\n cleanupPostDrop();\n }\n animateDraggedToFinalPosition(shadowElIdx, finalizeWithinZone);\n}\n\n// helper function for handleDrop\nfunction animateDraggedToFinalPosition(shadowElIdx, callback) {\n const shadowElRect = getBoundingRectNoTransforms(shadowElDropZone.children[shadowElIdx]);\n const newTransform = {\n x: shadowElRect.left - parseFloat(draggedEl.style.left),\n y: shadowElRect.top - parseFloat(draggedEl.style.top)\n };\n const {dropAnimationDurationMs} = dzToConfig.get(shadowElDropZone);\n const transition = `transform ${dropAnimationDurationMs}ms ease`;\n draggedEl.style.transition = draggedEl.style.transition ? draggedEl.style.transition + \",\" + transition : transition;\n draggedEl.style.transform = `translate3d(${newTransform.x}px, ${newTransform.y}px, 0)`;\n window.setTimeout(callback, dropAnimationDurationMs);\n}\n\nfunction scheduleDZForRemovalAfterDrop(dz, destroy) {\n scheduledForRemovalAfterDrop.push({dz, destroy});\n window.requestAnimationFrame(() => {\n hideElement(dz);\n document.body.appendChild(dz);\n });\n}\n/* cleanup */\nfunction cleanupPostDrop() {\n draggedEl.remove();\n originalDragTarget.remove();\n if (scheduledForRemovalAfterDrop.length) {\n printDebug(() => [\"will destroy zones that were removed during drag\", scheduledForRemovalAfterDrop]);\n scheduledForRemovalAfterDrop.forEach(({dz, destroy}) => {\n destroy();\n dz.remove();\n })\n scheduledForRemovalAfterDrop = [];\n }\n draggedEl = undefined;\n originalDragTarget = undefined;\n draggedElData = undefined;\n draggedElType = undefined;\n originDropZone = undefined;\n originIndex = undefined;\n shadowElData = undefined;\n shadowElDropZone = undefined;\n dragStartMousePosition = undefined;\n currentMousePosition = undefined;\n isWorkingOnPreviousDrag = false;\n finalizingPreviousDrag = false;\n unlockOriginDzMinDimensions = undefined;\n isDraggedOutsideOfAnyDz = false;\n}\n\nexport function dndzone(node, options) {\n let initialized = false;\n const config = {\n items: undefined,\n type: undefined,\n flipDurationMs: 0,\n dragDisabled: false,\n morphDisabled: false,\n dropFromOthersDisabled: false,\n dropTargetStyle: DEFAULT_DROP_TARGET_STYLE,\n dropTargetClasses: [],\n transformDraggedElement: () => {},\n centreDraggedOnCursor: false\n };\n printDebug(() => [`dndzone good to go options: ${toString(options)}, config: ${toString(config)}`, {node}]);\n let elToIdx = new Map();\n\n function addMaybeListeners() {\n window.addEventListener(\"mousemove\", handleMouseMoveMaybeDragStart, {passive: false});\n window.addEventListener(\"touchmove\", handleMouseMoveMaybeDragStart, {passive: false, capture: false});\n window.addEventListener(\"mouseup\", handleFalseAlarm, {passive: false});\n window.addEventListener(\"touchend\", handleFalseAlarm, {passive: false});\n }\n function removeMaybeListeners() {\n window.removeEventListener(\"mousemove\", handleMouseMoveMaybeDragStart);\n window.removeEventListener(\"touchmove\", handleMouseMoveMaybeDragStart);\n window.removeEventListener(\"mouseup\", handleFalseAlarm);\n window.removeEventListener(\"touchend\", handleFalseAlarm);\n }\n function handleFalseAlarm() {\n removeMaybeListeners();\n originalDragTarget = undefined;\n dragStartMousePosition = undefined;\n currentMousePosition = undefined;\n }\n\n function handleMouseMoveMaybeDragStart(e) {\n e.preventDefault();\n const c = e.touches ? e.touches[0] : e;\n currentMousePosition = {x: c.clientX, y: c.clientY};\n if (\n Math.abs(currentMousePosition.x - dragStartMousePosition.x) >= MIN_MOVEMENT_BEFORE_DRAG_START_PX ||\n Math.abs(currentMousePosition.y - dragStartMousePosition.y) >= MIN_MOVEMENT_BEFORE_DRAG_START_PX\n ) {\n removeMaybeListeners();\n handleDragStart();\n }\n }\n function handleMouseDown(e) {\n // on safari clicking on a select element doesn't fire mouseup at the end of the click and in general this makes more sense\n if (e.target !== e.currentTarget && (e.target.value !== undefined || e.target.isContentEditable)) {\n printDebug(() => \"won't initiate drag on a nested input element\");\n return;\n }\n // prevents responding to any button but left click which equals 0 (which is falsy)\n if (e.button) {\n printDebug(() => `ignoring none left click button: ${e.button}`);\n return;\n }\n if (isWorkingOnPreviousDrag) {\n printDebug(() => \"cannot start a new drag before finalizing previous one\");\n return;\n }\n e.stopPropagation();\n const c = e.touches ? e.touches[0] : e;\n dragStartMousePosition = {x: c.clientX, y: c.clientY};\n currentMousePosition = {...dragStartMousePosition};\n originalDragTarget = e.currentTarget;\n addMaybeListeners();\n }\n\n function handleDragStart() {\n printDebug(() => [`drag start config: ${toString(config)}`, originalDragTarget]);\n isWorkingOnPreviousDrag = true;\n\n // initialising globals\n const currentIdx = elToIdx.get(originalDragTarget);\n originIndex = currentIdx;\n originDropZone = originalDragTarget.parentElement;\n /** @type {ShadowRoot | HTMLDocument} */\n const rootNode = originDropZone.getRootNode();\n const originDropZoneRoot = rootNode.body || rootNode;\n const {items, type, centreDraggedOnCursor} = config;\n draggedElData = {...items[currentIdx]};\n draggedElType = type;\n shadowElData = {...draggedElData, [SHADOW_ITEM_MARKER_PROPERTY_NAME]: true};\n // The initial shadow element. We need a different id at first in order to avoid conflicts and timing issues\n const placeHolderElData = {...shadowElData, [ITEM_ID_KEY]: SHADOW_PLACEHOLDER_ITEM_ID};\n\n // creating the draggable element\n draggedEl = createDraggedElementFrom(originalDragTarget, centreDraggedOnCursor && currentMousePosition);\n // We will keep the original dom node in the dom because touch events keep firing on it, we want to re-add it after the framework removes it\n function keepOriginalElementInDom() {\n if (!draggedEl.parentElement) {\n originDropZoneRoot.appendChild(draggedEl);\n // to prevent the outline from disappearing\n draggedEl.focus();\n watchDraggedElement();\n hideElement(originalDragTarget);\n originDropZoneRoot.appendChild(originalDragTarget);\n } else {\n window.requestAnimationFrame(keepOriginalElementInDom);\n }\n }\n window.requestAnimationFrame(keepOriginalElementInDom);\n\n styleActiveDropZones(\n Array.from(typeToDropZones.get(config.type)).filter(dz => dz === originDropZone || !dzToConfig.get(dz).dropFromOthersDisabled),\n dz => dzToConfig.get(dz).dropTargetStyle,\n dz => dzToConfig.get(dz).dropTargetClasses\n );\n\n // removing the original element by removing its data entry\n items.splice(currentIdx, 1, placeHolderElData);\n unlockOriginDzMinDimensions = preventShrinking(originDropZone);\n\n dispatchConsiderEvent(originDropZone, items, {trigger: TRIGGERS.DRAG_STARTED, id: draggedElData[ITEM_ID_KEY], source: SOURCES.POINTER});\n\n // handing over to global handlers - starting to watch the element\n window.addEventListener(\"mousemove\", handleMouseMove, {passive: false});\n window.addEventListener(\"touchmove\", handleMouseMove, {passive: false, capture: false});\n window.addEventListener(\"mouseup\", handleDrop, {passive: false});\n window.addEventListener(\"touchend\", handleDrop, {passive: false});\n }\n\n function configure({\n items = undefined,\n flipDurationMs: dropAnimationDurationMs = 0,\n type: newType = DEFAULT_DROP_ZONE_TYPE,\n dragDisabled = false,\n morphDisabled = false,\n dropFromOthersDisabled = false,\n dropTargetStyle = DEFAULT_DROP_TARGET_STYLE,\n dropTargetClasses = [],\n transformDraggedElement = () => {},\n centreDraggedOnCursor = false\n }) {\n config.dropAnimationDurationMs = dropAnimationDurationMs;\n if (config.type && newType !== config.type) {\n unregisterDropZone(node, config.type);\n }\n config.type = newType;\n registerDropZone(node, newType);\n config.items = [...items];\n config.dragDisabled = dragDisabled;\n config.morphDisabled = morphDisabled;\n config.transformDraggedElement = transformDraggedElement;\n config.centreDraggedOnCursor = centreDraggedOnCursor;\n\n // realtime update for dropTargetStyle\n if (\n initialized &&\n isWorkingOnPreviousDrag &&\n !finalizingPreviousDrag &&\n (!areObjectsShallowEqual(dropTargetStyle, config.dropTargetStyle) ||\n !areArraysShallowEqualSameOrder(dropTargetClasses, config.dropTargetClasses))\n ) {\n styleInactiveDropZones(\n [node],\n () => config.dropTargetStyle,\n () => dropTargetClasses\n );\n styleActiveDropZones(\n [node],\n () => dropTargetStyle,\n () => dropTargetClasses\n );\n }\n config.dropTargetStyle = dropTargetStyle;\n config.dropTargetClasses = [...dropTargetClasses];\n\n // realtime update for dropFromOthersDisabled\n function getConfigProp(dz, propName) {\n return dzToConfig.get(dz) ? dzToConfig.get(dz)[propName] : config[propName];\n }\n if (initialized && isWorkingOnPreviousDrag && config.dropFromOthersDisabled !== dropFromOthersDisabled) {\n if (dropFromOthersDisabled) {\n styleInactiveDropZones(\n [node],\n dz => getConfigProp(dz, \"dropTargetStyle\"),\n dz => getConfigProp(dz, \"dropTargetClasses\")\n );\n } else {\n styleActiveDropZones(\n [node],\n dz => getConfigProp(dz, \"dropTargetStyle\"),\n dz => getConfigProp(dz, \"dropTargetClasses\")\n );\n }\n }\n config.dropFromOthersDisabled = dropFromOthersDisabled;\n\n dzToConfig.set(node, config);\n const shadowElIdx = findShadowElementIdx(config.items);\n for (let idx = 0; idx < node.children.length; idx++) {\n const draggableEl = node.children[idx];\n styleDraggable(draggableEl, dragDisabled);\n if (idx === shadowElIdx) {\n if (!morphDisabled) {\n morphDraggedElementToBeLike(draggedEl, draggableEl, currentMousePosition.x, currentMousePosition.y, () =>\n config.transformDraggedElement(draggedEl, draggedElData, idx)\n );\n }\n decorateShadowEl(draggableEl);\n continue;\n }\n draggableEl.removeEventListener(\"mousedown\", elToMouseDownListener.get(draggableEl));\n draggableEl.removeEventListener(\"touchstart\", elToMouseDownListener.get(draggableEl));\n if (!dragDisabled) {\n draggableEl.addEventListener(\"mousedown\", handleMouseDown);\n draggableEl.addEventListener(\"touchstart\", handleMouseDown);\n elToMouseDownListener.set(draggableEl, handleMouseDown);\n }\n // updating the idx\n elToIdx.set(draggableEl, idx);\n\n if (!initialized) {\n initialized = true;\n }\n }\n }\n configure(options);\n\n return {\n update: newOptions => {\n printDebug(() => `pointer dndzone will update newOptions: ${toString(newOptions)}`);\n configure(newOptions);\n },\n destroy: () => {\n function destroyDz() {\n printDebug(() => \"pointer dndzone will destroy\");\n unregisterDropZone(node, dzToConfig.get(node).type);\n dzToConfig.delete(node);\n }\n if (isWorkingOnPreviousDrag) {\n printDebug(() => \"pointer dndzone will be scheduled for destruction\");\n scheduleDZForRemovalAfterDrop(node, destroyDz);\n } else {\n destroyDz();\n }\n }\n };\n}\n","import {isOnServer} from \"../constants\";\n\nconst INSTRUCTION_IDs = {\n DND_ZONE_ACTIVE: \"dnd-zone-active\",\n DND_ZONE_DRAG_DISABLED: \"dnd-zone-drag-disabled\"\n};\nconst ID_TO_INSTRUCTION = {\n [INSTRUCTION_IDs.DND_ZONE_ACTIVE]: \"Tab to one the items and press space-bar or enter to start dragging it\",\n [INSTRUCTION_IDs.DND_ZONE_DRAG_DISABLED]: \"This is a disabled drag and drop list\"\n};\n\nconst ALERT_DIV_ID = \"dnd-action-aria-alert\";\nlet alertsDiv;\n\nfunction initAriaOnBrowser() {\n if (alertsDiv) {\n // it is already initialized\n return;\n }\n // setting the dynamic alerts\n alertsDiv = document.createElement(\"div\");\n (function initAlertsDiv() {\n alertsDiv.id = ALERT_DIV_ID;\n // tab index -1 makes the alert be read twice on chrome for some reason\n //alertsDiv.tabIndex = -1;\n alertsDiv.style.position = \"fixed\";\n alertsDiv.style.bottom = \"0\";\n alertsDiv.style.left = \"0\";\n alertsDiv.style.zIndex = \"-5\";\n alertsDiv.style.opacity = \"0\";\n alertsDiv.style.height = \"0\";\n alertsDiv.style.width = \"0\";\n alertsDiv.setAttribute(\"role\", \"alert\");\n })();\n document.body.prepend(alertsDiv);\n\n // setting the instructions\n Object.entries(ID_TO_INSTRUCTION).forEach(([id, txt]) => document.body.prepend(instructionToHiddenDiv(id, txt)));\n}\n\n/**\n * Initializes the static aria instructions so they can be attached to zones\n * @return {{DND_ZONE_ACTIVE: string, DND_ZONE_DRAG_DISABLED: string} | null} - the IDs for static aria instruction (to be used via aria-describedby) or null on the server\n */\nexport function initAria() {\n if (isOnServer) return null;\n if (document.readyState === \"complete\") {\n initAriaOnBrowser();\n } else {\n window.addEventListener(\"DOMContentLoaded\", initAriaOnBrowser);\n }\n return {...INSTRUCTION_IDs};\n}\n\n/**\n * Removes all the artifacts (dom elements) added by this module\n */\nexport function destroyAria() {\n if (isOnServer || !alertsDiv) return;\n Object.keys(ID_TO_INSTRUCTION).forEach(id => document.getElementById(id)?.remove());\n alertsDiv.remove();\n alertsDiv = undefined;\n}\n\nfunction instructionToHiddenDiv(id, txt) {\n const div = document.createElement(\"div\");\n div.id = id;\n div.innerHTML = `${txt}
`;\n div.style.display = \"none\";\n div.style.position = \"fixed\";\n div.style.zIndex = \"-5\";\n return div;\n}\n\n/**\n * Will make the screen reader alert the provided text to the user\n * @param {string} txt\n */\nexport function alertToScreenReader(txt) {\n if (isOnServer) return;\n if (!alertsDiv) {\n initAriaOnBrowser();\n }\n alertsDiv.innerHTML = \"\";\n const alertText = document.createTextNode(txt);\n alertsDiv.appendChild(alertText);\n // this is needed for Safari\n alertsDiv.style.display = \"none\";\n alertsDiv.style.display = \"inline\";\n}\n","import {decrementActiveDropZoneCount, incrementActiveDropZoneCount, ITEM_ID_KEY, SOURCES, TRIGGERS} from \"./constants\";\nimport {styleActiveDropZones, styleInactiveDropZones} from \"./helpers/styler\";\nimport {dispatchConsiderEvent, dispatchFinalizeEvent} from \"./helpers/dispatcher\";\nimport {initAria, alertToScreenReader, destroyAria} from \"./helpers/aria\";\nimport {toString} from \"./helpers/util\";\nimport {printDebug} from \"./constants\";\n\nconst DEFAULT_DROP_ZONE_TYPE = \"--any--\";\nconst DEFAULT_DROP_TARGET_STYLE = {\n outline: \"rgba(255, 255, 102, 0.7) solid 2px\"\n};\n\nlet isDragging = false;\nlet draggedItemType;\nlet focusedDz;\nlet focusedDzLabel = \"\";\nlet focusedItem;\nlet focusedItemId;\nlet focusedItemLabel = \"\";\nconst allDragTargets = new WeakSet();\nconst elToKeyDownListeners = new WeakMap();\nconst elToFocusListeners = new WeakMap();\nconst dzToHandles = new Map();\nconst dzToConfig = new Map();\nconst typeToDropZones = new Map();\n\n/* TODO (potentially)\n * what's the deal with the black border of voice-reader not following focus?\n * maybe keep focus on the last dragged item upon drop?\n */\n\nlet INSTRUCTION_IDs;\n\n/* drop-zones registration management */\nfunction registerDropZone(dropZoneEl, type) {\n printDebug(() => \"registering drop-zone if absent\");\n if (typeToDropZones.size === 0) {\n printDebug(() => \"adding global keydown and click handlers\");\n INSTRUCTION_IDs = initAria();\n window.addEventListener(\"keydown\", globalKeyDownHandler);\n window.addEventListener(\"click\", globalClickHandler);\n }\n if (!typeToDropZones.has(type)) {\n typeToDropZones.set(type, new Set());\n }\n if (!typeToDropZones.get(type).has(dropZoneEl)) {\n typeToDropZones.get(type).add(dropZoneEl);\n incrementActiveDropZoneCount();\n }\n}\nfunction unregisterDropZone(dropZoneEl, type) {\n printDebug(() => \"unregistering drop-zone\");\n if (focusedDz === dropZoneEl) {\n handleDrop();\n }\n typeToDropZones.get(type).delete(dropZoneEl);\n decrementActiveDropZoneCount();\n if (typeToDropZones.get(type).size === 0) {\n typeToDropZones.delete(type);\n }\n if (typeToDropZones.size === 0) {\n printDebug(() => \"removing global keydown and click handlers\");\n window.removeEventListener(\"keydown\", globalKeyDownHandler);\n window.removeEventListener(\"click\", globalClickHandler);\n INSTRUCTION_IDs = undefined;\n destroyAria();\n }\n}\n\nfunction globalKeyDownHandler(e) {\n if (!isDragging) return;\n switch (e.key) {\n case \"Escape\": {\n handleDrop();\n break;\n }\n }\n}\n\nfunction globalClickHandler() {\n if (!isDragging) return;\n if (!allDragTargets.has(document.activeElement)) {\n printDebug(() => \"clicked outside of any draggable\");\n handleDrop();\n }\n}\n\nfunction handleZoneFocus(e) {\n printDebug(() => \"zone focus\");\n if (!isDragging) return;\n const newlyFocusedDz = e.currentTarget;\n if (newlyFocusedDz === focusedDz) return;\n\n focusedDzLabel = newlyFocusedDz.getAttribute(\"aria-label\") || \"\";\n const {items: originItems} = dzToConfig.get(focusedDz);\n const originItem = originItems.find(item => item[ITEM_ID_KEY] === focusedItemId);\n const originIdx = originItems.indexOf(originItem);\n const itemToMove = originItems.splice(originIdx, 1)[0];\n const {items: targetItems, autoAriaDisabled} = dzToConfig.get(newlyFocusedDz);\n if (\n newlyFocusedDz.getBoundingClientRect().top < focusedDz.getBoundingClientRect().top ||\n newlyFocusedDz.getBoundingClientRect().left < focusedDz.getBoundingClientRect().left\n ) {\n targetItems.push(itemToMove);\n if (!autoAriaDisabled) {\n alertToScreenReader(`Moved item ${focusedItemLabel} to the end of the list ${focusedDzLabel}`);\n }\n } else {\n targetItems.unshift(itemToMove);\n if (!autoAriaDisabled) {\n alertToScreenReader(`Moved item ${focusedItemLabel} to the beginning of the list ${focusedDzLabel}`);\n }\n }\n const dzFrom = focusedDz;\n dispatchFinalizeEvent(dzFrom, originItems, {trigger: TRIGGERS.DROPPED_INTO_ANOTHER, id: focusedItemId, source: SOURCES.KEYBOARD});\n dispatchFinalizeEvent(newlyFocusedDz, targetItems, {trigger: TRIGGERS.DROPPED_INTO_ZONE, id: focusedItemId, source: SOURCES.KEYBOARD});\n focusedDz = newlyFocusedDz;\n}\n\nfunction triggerAllDzsUpdate() {\n dzToHandles.forEach(({update}, dz) => update(dzToConfig.get(dz)));\n}\n\nfunction handleDrop(dispatchConsider = true) {\n printDebug(() => \"drop\");\n if (!dzToConfig.get(focusedDz).autoAriaDisabled) {\n alertToScreenReader(`Stopped dragging item ${focusedItemLabel}`);\n }\n if (allDragTargets.has(document.activeElement)) {\n document.activeElement.blur();\n }\n if (dispatchConsider) {\n dispatchConsiderEvent(focusedDz, dzToConfig.get(focusedDz).items, {\n trigger: TRIGGERS.DRAG_STOPPED,\n id: focusedItemId,\n source: SOURCES.KEYBOARD\n });\n }\n styleInactiveDropZones(\n typeToDropZones.get(draggedItemType),\n dz => dzToConfig.get(dz).dropTargetStyle,\n dz => dzToConfig.get(dz).dropTargetClasses\n );\n focusedItem = null;\n focusedItemId = null;\n focusedItemLabel = \"\";\n draggedItemType = null;\n focusedDz = null;\n focusedDzLabel = \"\";\n isDragging = false;\n triggerAllDzsUpdate();\n}\n//////\nexport function dndzone(node, options) {\n const config = {\n items: undefined,\n type: undefined,\n dragDisabled: false,\n zoneTabIndex: 0,\n dropFromOthersDisabled: false,\n dropTargetStyle: DEFAULT_DROP_TARGET_STYLE,\n dropTargetClasses: [],\n autoAriaDisabled: false\n };\n\n function swap(arr, i, j) {\n if (arr.length <= 1) return;\n arr.splice(j, 1, arr.splice(i, 1, arr[j])[0]);\n }\n\n function handleKeyDown(e) {\n printDebug(() => [\"handling key down\", e.key]);\n switch (e.key) {\n case \"Enter\":\n case \" \": {\n // we don't want to affect nested input elements or clickable elements\n if ((e.target.disabled !== undefined || e.target.href || e.target.isContentEditable) && !allDragTargets.has(e.target)) {\n return;\n }\n e.preventDefault(); // preventing scrolling on spacebar\n e.stopPropagation();\n if (isDragging) {\n // TODO - should this trigger a drop? only here or in general (as in when hitting space or enter outside of any zone)?\n handleDrop();\n } else {\n // drag start\n handleDragStart(e);\n }\n break;\n }\n case \"ArrowDown\":\n case \"ArrowRight\": {\n if (!isDragging) return;\n e.preventDefault(); // prevent scrolling\n e.stopPropagation();\n const {items} = dzToConfig.get(node);\n const children = Array.from(node.children);\n const idx = children.indexOf(e.currentTarget);\n printDebug(() => [\"arrow down\", idx]);\n if (idx < children.length - 1) {\n if (!config.autoAriaDisabled) {\n alertToScreenReader(`Moved item ${focusedItemLabel} to position ${idx + 2} in the list ${focusedDzLabel}`);\n }\n swap(items, idx, idx + 1);\n dispatchFinalizeEvent(node, items, {trigger: TRIGGERS.DROPPED_INTO_ZONE, id: focusedItemId, source: SOURCES.KEYBOARD});\n }\n break;\n }\n case \"ArrowUp\":\n case \"ArrowLeft\": {\n if (!isDragging) return;\n e.preventDefault(); // prevent scrolling\n e.stopPropagation();\n const {items} = dzToConfig.get(node);\n const children = Array.from(node.children);\n const idx = children.indexOf(e.currentTarget);\n printDebug(() => [\"arrow up\", idx]);\n if (idx > 0) {\n if (!config.autoAriaDisabled) {\n alertToScreenReader(`Moved item ${focusedItemLabel} to position ${idx} in the list ${focusedDzLabel}`);\n }\n swap(items, idx, idx - 1);\n dispatchFinalizeEvent(node, items, {trigger: TRIGGERS.DROPPED_INTO_ZONE, id: focusedItemId, source: SOURCES.KEYBOARD});\n }\n break;\n }\n }\n }\n function handleDragStart(e) {\n printDebug(() => \"drag start\");\n setCurrentFocusedItem(e.currentTarget);\n focusedDz = node;\n draggedItemType = config.type;\n isDragging = true;\n const dropTargets = Array.from(typeToDropZones.get(config.type)).filter(dz => dz === focusedDz || !dzToConfig.get(dz).dropFromOthersDisabled);\n styleActiveDropZones(\n dropTargets,\n dz => dzToConfig.get(dz).dropTargetStyle,\n dz => dzToConfig.get(dz).dropTargetClasses\n );\n if (!config.autoAriaDisabled) {\n let msg = `Started dragging item ${focusedItemLabel}. Use the arrow keys to move it within its list ${focusedDzLabel}`;\n if (dropTargets.length > 1) {\n msg += `, or tab to another list in order to move the item into it`;\n }\n alertToScreenReader(msg);\n }\n dispatchConsiderEvent(node, dzToConfig.get(node).items, {trigger: TRIGGERS.DRAG_STARTED, id: focusedItemId, source: SOURCES.KEYBOARD});\n triggerAllDzsUpdate();\n }\n\n function handleClick(e) {\n if (!isDragging) return;\n if (e.currentTarget === focusedItem) return;\n e.stopPropagation();\n handleDrop(false);\n handleDragStart(e);\n }\n function setCurrentFocusedItem(draggableEl) {\n const {items} = dzToConfig.get(node);\n const children = Array.from(node.children);\n const focusedItemIdx = children.indexOf(draggableEl);\n focusedItem = draggableEl;\n focusedItem.tabIndex = 0;\n focusedItemId = items[focusedItemIdx][ITEM_ID_KEY];\n focusedItemLabel = children[focusedItemIdx].getAttribute(\"aria-label\") || \"\";\n }\n\n function configure({\n items = [],\n type: newType = DEFAULT_DROP_ZONE_TYPE,\n dragDisabled = false,\n zoneTabIndex = 0,\n dropFromOthersDisabled = false,\n dropTargetStyle = DEFAULT_DROP_TARGET_STYLE,\n dropTargetClasses = [],\n autoAriaDisabled = false\n }) {\n config.items = [...items];\n config.dragDisabled = dragDisabled;\n config.dropFromOthersDisabled = dropFromOthersDisabled;\n config.zoneTabIndex = zoneTabIndex;\n config.dropTargetStyle = dropTargetStyle;\n config.dropTargetClasses = dropTargetClasses;\n config.autoAriaDisabled = autoAriaDisabled;\n if (config.type && newType !== config.type) {\n unregisterDropZone(node, config.type);\n }\n config.type = newType;\n registerDropZone(node, newType);\n if (!autoAriaDisabled) {\n node.setAttribute(\"aria-disabled\", dragDisabled);\n node.setAttribute(\"role\", \"list\");\n node.setAttribute(\"aria-describedby\", dragDisabled ? INSTRUCTION_IDs.DND_ZONE_DRAG_DISABLED : INSTRUCTION_IDs.DND_ZONE_ACTIVE);\n }\n dzToConfig.set(node, config);\n\n if (isDragging) {\n node.tabIndex =\n node === focusedDz ||\n focusedItem.contains(node) ||\n config.dropFromOthersDisabled ||\n (focusedDz && config.type !== dzToConfig.get(focusedDz).type)\n ? -1\n : 0;\n } else {\n node.tabIndex = config.zoneTabIndex;\n }\n\n node.addEventListener(\"focus\", handleZoneFocus);\n\n for (let i = 0; i < node.children.length; i++) {\n const draggableEl = node.children[i];\n allDragTargets.add(draggableEl);\n draggableEl.tabIndex = isDragging ? -1 : 0;\n if (!autoAriaDisabled) {\n draggableEl.setAttribute(\"role\", \"listitem\");\n }\n draggableEl.removeEventListener(\"keydown\", elToKeyDownListeners.get(draggableEl));\n draggableEl.removeEventListener(\"click\", elToFocusListeners.get(draggableEl));\n if (!dragDisabled) {\n draggableEl.addEventListener(\"keydown\", handleKeyDown);\n elToKeyDownListeners.set(draggableEl, handleKeyDown);\n draggableEl.addEventListener(\"click\", handleClick);\n elToFocusListeners.set(draggableEl, handleClick);\n }\n if (isDragging && config.items[i][ITEM_ID_KEY] === focusedItemId) {\n printDebug(() => [\"focusing on\", {i, focusedItemId}]);\n // if it is a nested dropzone, it was re-rendered and we need to refresh our pointer\n focusedItem = draggableEl;\n focusedItem.tabIndex = 0;\n // without this the element loses focus if it moves backwards in the list\n draggableEl.focus();\n }\n }\n }\n configure(options);\n\n const handles = {\n update: newOptions => {\n printDebug(() => `keyboard dndzone will update newOptions: ${toString(newOptions)}`);\n configure(newOptions);\n },\n destroy: () => {\n printDebug(() => \"keyboard dndzone will destroy\");\n unregisterDropZone(node, config.type);\n dzToConfig.delete(node);\n dzToHandles.delete(node);\n }\n };\n dzToHandles.set(node, handles);\n return handles;\n}\n","import {dndzone as pointerDndZone} from \"./pointerAction\";\nimport {dndzone as keyboardDndZone} from \"./keyboardAction\";\nimport {ITEM_ID_KEY} from \"./constants\";\nimport {toString} from \"./helpers/util\";\n\n/**\n * A custom action to turn any container to a dnd zone and all of its direct children to draggables\n * Supports mouse, touch and keyboard interactions.\n * Dispatches two events that the container is expected to react to by modifying its list of items,\n * which will then feed back in to this action via the update function\n *\n * @typedef {object} Options\n * @property {array} items - the list of items that was used to generate the children of the given node (the list used in the #each block\n * @property {string} [type] - the type of the dnd zone. children dragged from here can only be dropped in other zones of the same type, default to a base type\n * @property {number} [flipDurationMs] - if the list animated using flip (recommended), specifies the flip duration such that everything syncs with it without conflict, defaults to zero\n * @property {boolean} [dragDisabled]\n * @property {boolean} [morphDisabled] - whether dragged element should morph to zone dimensions\n * @property {boolean} [dropFromOthersDisabled]\n * @property {number} [zoneTabIndex] - set the tabindex of the list container when not dragging\n * @property {object} [dropTargetStyle]\n * @property {string[]} [dropTargetClasses]\n * @property {function} [transformDraggedElement]\n * @param {HTMLElement} node - the element to enhance\n * @param {Options} options\n * @return {{update: function, destroy: function}}\n */\nexport function dndzone(node, options) {\n validateOptions(options);\n const pointerZone = pointerDndZone(node, options);\n const keyboardZone = keyboardDndZone(node, options);\n return {\n update: newOptions => {\n validateOptions(newOptions);\n pointerZone.update(newOptions);\n keyboardZone.update(newOptions);\n },\n destroy: () => {\n pointerZone.destroy();\n keyboardZone.destroy();\n }\n };\n}\n\nfunction validateOptions(options) {\n /*eslint-disable*/\n const {\n items,\n flipDurationMs,\n type,\n dragDisabled,\n morphDisabled,\n dropFromOthersDisabled,\n zoneTabIndex,\n dropTargetStyle,\n dropTargetClasses,\n transformDraggedElement,\n autoAriaDisabled,\n centreDraggedOnCursor,\n ...rest\n } = options;\n /*eslint-enable*/\n if (Object.keys(rest).length > 0) {\n console.warn(`dndzone will ignore unknown options`, rest);\n }\n if (!items) {\n throw new Error(\"no 'items' key provided to dndzone\");\n }\n const itemWithMissingId = items.find(item => !{}.hasOwnProperty.call(item, ITEM_ID_KEY));\n if (itemWithMissingId) {\n throw new Error(`missing '${ITEM_ID_KEY}' property for item ${toString(itemWithMissingId)}`);\n }\n if (dropTargetClasses && !Array.isArray(dropTargetClasses)) {\n throw new Error(`dropTargetClasses should be an array but instead it is a ${typeof dropTargetClasses}, ${toString(dropTargetClasses)}`);\n }\n if (zoneTabIndex && !isInt(zoneTabIndex)) {\n throw new Error(`zoneTabIndex should be a number but instead it is a ${typeof zoneTabIndex}, ${toString(zoneTabIndex)}`);\n }\n}\n\nfunction isInt(value) {\n return !isNaN(value) && (function(x) { return (x | 0) === x; })(parseFloat(value));\n}\n","\n\n\n\n \n
\n
\n
Name
\n
Cost
\n
Fixed
\n
Short
\n
Icon
\n
Data
\n
\n
\n
\n {#if isHovering}\n Drop to add
\n {/if}\n {#each prices as price, index (price.id)}\n \n
\n
\n
\n
\n
\n
\n \n
\n
\n {#if price.type === \"attribute\"}\n \n {:else}\n editItem(index)}>\n View item\n \n {/if}\n
\n
\n removeEntry(index)}> \n
\n
\n {/each}\n \n \n
\n \n\n","\r\n\r\n\r\n\r\n\r\n\r\n \r\n\r\n \r\n\r\n","import ItemEditorShell from './item-editor-shell.svelte';\r\nimport { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\n\r\nexport default class ItemEditor extends SvelteApplication {\r\n \r\n constructor(item = false, options) {\r\n super({\r\n id: `item-pile-item-editor-${item.id}`,\r\n title: game.i18n.format(\"ITEM-PILES.Applications.ItemEditor.Title\", { item_name: item.name }),\r\n svelte: {\r\n class: ItemEditorShell,\r\n target: document.body,\r\n props: {\r\n item\r\n }\r\n },\r\n close: () => this.options.resolve(null),\r\n ...options\r\n });\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n width: 500,\r\n height: \"auto\",\r\n classes: [\"item-piles-app\"]\r\n })\r\n }\r\n \r\n static getActiveApp(id) {\r\n return Object.values(ui.windows).find(app => app.id === `item-pile-item-editor-${id}`)\r\n }\r\n \r\n static async show(item = false, options = {}, dialogData = {}) {\r\n const app = this.getActiveApp(item.id);\r\n if (app) return app.render(false, { focus: true });\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(item, options, dialogData).render(true, { focus: true });\r\n })\r\n }\r\n}","\n\n\n\n
\n
\n
\n\n
\n
\n {#if $pileData.canInspectItems || game.user.isGM}\n
{$itemName} \n {:else}\n {$itemName}\n {/if}\n {#if displayQuantity}\n {#if itemFlagData.infiniteQuantity}\n
(ā) \n {:else if !showEditQuantity}\n
{ if(game.user.isGM) showEditQuantity = true; }}>(x{quantity}) \n {/if}\n {/if}\n {#if showEditQuantity}\n
\n
\n { showEditQuantity = false; item.updateQuantity(editQuantity); }}\n on:keydown={(evt) => { if(evt.key === \"Enter\") showEditQuantity = false; }}/>\n
\n
\n {/if}\n
\n
\n\n
\n\n
\n {#if displayControlButtons}\n {#if game.user.isGM}\n { ItemEditor.show(item.item); }}>\n \n \n {/if}\n { itemFlagData.hidden = !itemFlagData.hidden; item.updateItemFlagData(); }}>\n \n \n { itemFlagData.notForSale = !itemFlagData.notForSale; item.updateItemFlagData(); }}>\n \n \n {/if}\n {#if displayBuyButton}\n {\n if(quantity <= 0 || (itemFlagData.notForSale && !game.user.isGM)) return;\n store.tradeItem(item, selling)\n }}>\n \n {#if !displayControlButtons} {!selling ? \"Buy\" : \"Sell\"}{/if}\n \n {/if}\n
\n\n
\n\n\n","\r\n\r\n\r\n\r\n
\r\n \r\n \r\n {localize(\"All\")} \r\n {#each $itemCategoriesStore as category (category.type)}\r\n {category.label} \r\n {/each}\r\n \r\n
\r\n\r\n {#each $categoryStore as category, index (category.type)}\r\n
\r\n
\r\n \r\n {localize(category.label)}\r\n
\r\n \r\n \r\n {#if editPrices}\r\n {#if $priceModifiersPerType[category.type]}\r\n { store.removeOverrideTypePrice(category.type) }}> \r\n {:else}\r\n { store.addOverrideTypePrice(category.type) }}> \r\n {/if}\r\n {/if}\r\n
\r\n \r\n\r\n
\r\n {#each $itemsPerCategoryStore[category.type] as item (item.id)}\r\n \r\n {/each}\r\n
\r\n
\r\n {/each}\r\n\r\n
\r\n\r\n","\r\n\r\n\r\n\r\n {#each $categoryStore as category, index (category.type)}\r\n
\r\n
\r\n \r\n {localize(category.label)}\r\n
\r\n \r\n\r\n
\r\n {#each $itemsPerCategoryStore[category.type] as item (item.id)}\r\n \r\n {/each}\r\n
\r\n
\r\n {/each}\r\n\r\n
\r\n\r\n","\r\n\r\n\r\n\r\n
\r\n\r\n \r\n {#each tables as table (table.id)}\r\n {table.name} \r\n {/each}\r\n \r\n\r\n \r\n\r\n \r\n Roll\r\n \r\n\r\n
\r\n\r\n
\r\n\r\n
\r\n\r\n
\r\n {currentItems.length ? \"Current items:\" : \"Merchant has no items\"}\r\n
\r\n\r\n {#each currentItems as item (item.id)}\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n {item.name} x{item.quantity}\r\n
\r\n
\r\n
\r\n {/each}\r\n
\r\n\r\n
\r\n\r\n
\r\n
\r\n {#if timesRolled && $itemsRolled.length}\r\n Rolled {timesRolled} times:\r\n {:else}\r\n Click roll to start\r\n {/if}\r\n \r\n\r\n
\r\n Keep rolled: \r\n \r\n
\r\n
\r\n\r\n\r\n {#if $itemsRolled.length}\r\n {#each $itemsRolled as item (item.resultId)}\r\n
\r\n
addItem(item)}>\r\n \r\n \r\n\r\n
\r\n
\r\n
\r\n\r\n
\r\n\r\n
\r\n\r\n
removeItem(item)}>\r\n \r\n \r\n
\r\n {/each}\r\n\r\n
addAllItems()}>\r\n Add all \r\n \r\n\r\n {/if}\r\n\r\n
\r\n\r\n
\r\n\r\n
\r\n\r\n","\r\n\r\n\r\n\r\n
\r\n\r\n
\r\n\r\n {#if activeTab === \"buy\"}\r\n \r\n {:else if activeTab === \"sell\"}\r\n \r\n {:else if activeTab === \"tables\"}\r\n \r\n {/if}\r\n\r\n
\r\n\r\n
\r\n\r\n {#each $currencies as currency (currency.identifier)}\r\n\r\n
\r\n\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n {#if currency.abbreviation}\r\n {currency.abbreviation.replace(\"{#}\", get(currency.quantity))}\r\n {:else}\r\n {get(currency.name)} (x{get(currency.quantity)})\r\n {/if}\r\n
\r\n
\r\n\r\n
\r\n\r\n {/each}\r\n\r\n
\r\n\r\n
\r\n\r\n\r\n","\r\n\r\n\r\n
{$merchantName}
\r\n {#if $pileDataStore.openTimes.enabled}\r\n
\r\n Opening hours \r\n {openTimeText} \r\n
\r\n {/if}\r\n
\r\n\r\n","\r\n\r\n\r\n\r\n { $priceSelector = \"\"; }}/>\r\n\r\n\r\n \r\n \r\n \r\n \r\n \r\n
\r\n \r\n \r\n\r\n\r\n","import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\nimport ItemPileConfig from \"../item-pile-config/item-pile-config\";\r\nimport MerchantAppShell from \"./merchant-app-shell.svelte\";\r\n\r\nexport default class MerchantApp extends SvelteApplication {\r\n \r\n constructor(merchant, recipient = false, options = {}, dialogData = {}) {\r\n super({\r\n title: `Merchant: ${merchant.name}`,\r\n id: `item-pile-merchant-${merchant.id}`,\r\n svelte: {\r\n class: MerchantAppShell,\r\n target: document.body,\r\n props: {\r\n merchant,\r\n recipient\r\n }\r\n },\r\n zIndex: 100,\r\n ...options\r\n }, dialogData);\r\n this.merchant = merchant;\r\n }\r\n \r\n /** @inheritdoc */\r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n classes: [\"app window-app sheet\", \"item-piles-merchant-sheet\"],\r\n width: 800,\r\n height: 700,\r\n closeOnSubmit: false,\r\n resizable: true\r\n });\r\n }\r\n \r\n static getActiveApp(id) {\r\n return Object.values(ui.windows).find(app => app.id === `item-pile-merchant-${id}`);\r\n }\r\n \r\n static async show(merchant, recipient = false, options = {}, dialogData = {}) {\r\n merchant = merchant?.actor ?? merchant;\r\n recipient = recipient?.actor ?? recipient\r\n const app = this.getActiveApp(merchant.id);\r\n if (app) return app.render(false, { focus: true });\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(merchant, recipient, options, dialogData).render(true, { focus: true });\r\n })\r\n }\r\n \r\n refreshItems() {\r\n this.svelte.applicationShell.store.refreshItems();\r\n }\r\n \r\n /** @override */\r\n _getHeaderButtons() {\r\n let buttons = super._getHeaderButtons();\r\n const canConfigure = game.user.isGM;\r\n if (canConfigure) {\r\n buttons = [\r\n {\r\n label: \"ITEM-PILES.Inspect.OpenSheet\",\r\n class: \"item-piles-open-actor-sheet\",\r\n icon: \"fas fa-user\",\r\n onclick: () => {\r\n this.merchant.sheet.render(true, { focus: true });\r\n }\r\n },\r\n {\r\n label: \"ITEM-PILES.HUD.Configure\",\r\n class: \"item-piles-configure-pile\",\r\n icon: \"fas fa-box-open\",\r\n onclick: () => {\r\n ItemPileConfig.show(this.merchant);\r\n }\r\n },\r\n ].concat(buttons);\r\n }\r\n return buttons\r\n }\r\n \r\n async close(options) {\r\n for (const app of Object.values(ui.windows)) {\r\n if (app !== this && this.svelte.applicationShell.store === app?.svelte?.applicationShell?.store) {\r\n app.close();\r\n }\r\n }\r\n return super.close(options);\r\n }\r\n \r\n}","import * as Helpers from \"../helpers/helpers.js\";\r\nimport * as Utilities from \"../helpers/utilities.js\";\r\nimport * as PileUtilities from \"../helpers/pile-utilities.js\";\r\nimport * as SharingUtilities from \"../helpers/sharing-utilities.js\";\r\nimport HOOKS from \"../constants/hooks.js\";\r\nimport ItemPileSocket from \"../socket.js\";\r\nimport SETTINGS from \"../constants/settings.js\";\r\nimport CONSTANTS from \"../constants/constants.js\";\r\nimport { hotkeyState } from \"../hotkeys.js\";\r\nimport DropItemDialog from \"../applications/dialogs/drop-item-dialog/drop-item-dialog.js\";\r\nimport { ItemPileInventoryApp } from \"../applications/item-pile-inventory-app/item-pile-inventory-app.js\";\r\nimport Transaction from \"../helpers/transaction.js\";\r\nimport ItemPileStore from \"../stores/item-pile-store.js\";\r\nimport MerchantApp from \"../applications/merchant-app/merchant-app.js\";\r\nimport { SYSTEMS } from \"../systems.js\";\r\n\r\nconst preloadedFiles = new Set();\r\n\r\nexport default class PrivateAPI {\r\n \r\n /**\r\n * Initializes the API for Foundry's core hooks\r\n */\r\n static initialize() {\r\n Helpers.hooks.on(\"canvasReady\", this._onCanvasReady.bind(this));\r\n Helpers.hooks.on(\"createItem\", this._onCreateItem.bind(this));\r\n Helpers.hooks.on(\"updateItem\", this._onUpdateItem.bind(this));\r\n Helpers.hooks.on(\"deleteItem\", this._onDeleteItem.bind(this));\r\n Helpers.hooks.on(\"updateActor\", this._onUpdateActor.bind(this));\r\n Helpers.hooks.on(\"deleteToken\", this._onDeleteToken.bind(this));\r\n Helpers.hooks.on(\"deleteActor\", this._onDeleteActor.bind(this));\r\n Helpers.hooks.on(\"preCreateToken\", this._onPreCreateToken.bind(this))\r\n Helpers.hooks.on(\"createToken\", this._onCreateToken.bind(this))\r\n Helpers.hooks.on(\"dropCanvasData\", this._dropData.bind(this));\r\n }\r\n \r\n /**\r\n * @private\r\n */\r\n static async _onCanvasReady(canvas) {\r\n const tokens = [...canvas.tokens.placeables].map(token => token.document);\r\n for (const doc of tokens) {\r\n await this._preloadItemPileFiles(doc);\r\n }\r\n }\r\n \r\n /**\r\n * @private\r\n */\r\n static _onCreateItem(doc) {\r\n if (!doc.parent) return;\r\n ItemPileStore.notifyChanges(\"createItem\", doc.parent, doc);\r\n if (!PileUtilities.isValidItemPile(doc.parent)) return;\r\n this._evaluateItemPileChange(doc.parent);\r\n }\r\n \r\n /**\r\n * @private\r\n */\r\n static _onUpdateItem(doc) {\r\n if (!doc.parent) return;\r\n if (!PileUtilities.isValidItemPile(doc.parent)) return;\r\n this._evaluateItemPileChange(doc.parent);\r\n }\r\n \r\n /**\r\n * @private\r\n */\r\n static _onDeleteItem(doc) {\r\n if (!doc.parent) return;\r\n ItemPileStore.notifyChanges(\"deleteItem\", doc.parent, doc);\r\n if (!PileUtilities.isValidItemPile(doc.parent)) return;\r\n this._evaluateItemPileChange(doc.parent);\r\n }\r\n \r\n /**\r\n * @private\r\n */\r\n static _onUpdateActor(doc, changes) {\r\n if (!PileUtilities.isValidItemPile(doc)) return;\r\n this._evaluateItemPileChange(doc, changes);\r\n }\r\n \r\n /**\r\n * @private\r\n */\r\n static _onDeleteToken(doc) {\r\n ItemPileStore.notifyChanges(\"delete\", doc.actor)\r\n if (!PileUtilities.isValidItemPile(doc)) return;\r\n Helpers.hooks.callAll(HOOKS.PILE.DELETE, doc);\r\n }\r\n \r\n /**\r\n * @private\r\n */\r\n static _onDeleteActor(doc) {\r\n ItemPileStore.notifyChanges(\"delete\", doc)\r\n }\r\n \r\n /**\r\n * @private\r\n */\r\n static _onPreCreateToken(doc) {\r\n if (!doc.isLinked) {\r\n doc.data.update({\r\n [`actorData.flags.${CONSTANTS.MODULE_NAME}.-=sharing`]: null\r\n });\r\n }\r\n const itemPileConfig = PileUtilities.getActorFlagData(doc.actor)\r\n const targetItems = PileUtilities.getActorItems(doc.actor);\r\n const targetCurrencies = PileUtilities.getActorCurrencies(doc.actor);\r\n const data = { data: itemPileConfig, items: targetItems, currencies: targetCurrencies };\r\n doc.data.update({\r\n \"img\": PileUtilities.getItemPileTokenImage(doc, data),\r\n \"scale\": PileUtilities.getItemPileTokenScale(doc, data),\r\n \"name\": PileUtilities.getItemPileName(doc, data),\r\n [CONSTANTS.FLAGS.PILE]: itemPileConfig\r\n });\r\n }\r\n \r\n /**\r\n * @private\r\n */\r\n static _onCreateToken(doc) {\r\n if (!PileUtilities.isValidItemPile(doc)) return;\r\n const itemPileConfig = PileUtilities.getActorFlagData(doc.actor)\r\n Helpers.hooks.callAll(HOOKS.PILE.CREATE, doc, itemPileConfig);\r\n return this._preloadItemPileFiles(doc);\r\n }\r\n \r\n static async _addItems(targetUuid, items, userId, { interactionId = false } = {}) {\r\n \r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const transaction = new Transaction(targetActor);\r\n \r\n await transaction.appendItemChanges(items);\r\n \r\n const { itemsToUpdate, itemsToCreate } = transaction.prepare(); // Prepare data\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_ADD, targetActor, itemsToCreate, itemsToUpdate, userId);\r\n if (hookResult === false) return false; // Call pre-hook to allow user to interrupt it\r\n \r\n const { itemDeltas } = await transaction.commit(); // Actually add the items to the actor\r\n \r\n await ItemPileSocket.callHook(HOOKS.ITEM.ADD, targetUuid, itemDeltas, userId, interactionId);\r\n \r\n await this._executeItemPileMacro(targetUuid, {\r\n action: \"addItems\", target: targetUuid, items: itemDeltas, userId: userId, interactionId: interactionId\r\n });\r\n \r\n return itemDeltas;\r\n \r\n }\r\n \r\n static async _removeItems(targetUuid, items, userId, { interactionId = false } = {}) {\r\n \r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const transaction = new Transaction(targetActor);\r\n \r\n await transaction.appendItemChanges(items, { remove: true });\r\n \r\n const { itemsToUpdate, itemsToDelete } = transaction.prepare();\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_REMOVE, targetActor, itemsToUpdate, itemsToDelete, userId);\r\n if (hookResult === false) return false;\r\n \r\n const { itemDeltas } = await transaction.commit();\r\n \r\n await ItemPileSocket.callHook(HOOKS.ITEM.REMOVE, targetUuid, itemDeltas, userId, interactionId);\r\n \r\n await this._executeItemPileMacro(targetUuid, {\r\n action: \"removeItems\", target: targetUuid, items: itemDeltas, userId: userId, interactionId: interactionId\r\n });\r\n \r\n const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(targetUuid);\r\n if (shouldBeDeleted) {\r\n await this._deleteItemPile(targetUuid);\r\n }\r\n \r\n return itemDeltas;\r\n \r\n }\r\n \r\n static async _transferItems(sourceUuid, targetUuid, items, userId, { interactionId = false } = {}) {\r\n \r\n const sourceActor = Utilities.getActor(sourceUuid);\r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const sourceTransaction = new Transaction(sourceActor);\r\n await sourceTransaction.appendItemChanges(items, { remove: true });\r\n const sourceUpdates = sourceTransaction.prepare();\r\n \r\n const targetTransaction = new Transaction(targetActor);\r\n await targetTransaction.appendItemChanges(sourceUpdates.itemDeltas);\r\n const targetUpdates = targetTransaction.prepare();\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_TRANSFER, sourceActor, sourceUpdates, targetActor, targetUpdates, userId);\r\n if (hookResult === false) return false;\r\n \r\n await sourceTransaction.commit();\r\n const { itemDeltas } = await targetTransaction.commit();\r\n \r\n await ItemPileSocket.callHook(HOOKS.ITEM.TRANSFER, sourceUuid, targetUuid, itemDeltas, userId, interactionId);\r\n \r\n const macroData = {\r\n action: \"transferItems\",\r\n source: sourceUuid,\r\n target: targetUuid,\r\n items: itemDeltas,\r\n userId: userId,\r\n interactionId: interactionId\r\n };\r\n \r\n await this._executeItemPileMacro(sourceUuid, macroData);\r\n await this._executeItemPileMacro(targetUuid, macroData);\r\n \r\n const itemPile = Utilities.getToken(sourceUuid);\r\n \r\n const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);\r\n if (shouldBeDeleted) {\r\n await this._deleteItemPile(sourceUuid);\r\n } else if (PileUtilities.isItemPileEmpty(itemPile)) {\r\n await SharingUtilities.clearItemPileSharingData(itemPile);\r\n } else {\r\n await SharingUtilities.setItemPileSharingData(sourceUuid, targetUuid, {\r\n items: itemDeltas\r\n });\r\n }\r\n \r\n return itemDeltas;\r\n \r\n }\r\n \r\n static async _transferAllItems(sourceUuid, targetUuid, userId, { itemFilters = false, interactionId = false } = {}) {\r\n \r\n const sourceActor = Utilities.getActor(sourceUuid);\r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const itemsToTransfer = PileUtilities.getActorItems(sourceActor, { itemFilters }).map(item => item.toObject());\r\n \r\n const sourceTransaction = new Transaction(sourceActor);\r\n await sourceTransaction.appendItemChanges(itemsToTransfer, { remove: true });\r\n const sourceUpdates = sourceTransaction.prepare();\r\n \r\n const targetTransaction = new Transaction(targetActor);\r\n await targetTransaction.appendItemChanges(sourceUpdates.itemDeltas);\r\n const targetUpdates = targetTransaction.prepare();\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_TRANSFER_ALL, sourceActor, sourceUpdates, targetActor, targetUpdates, userId);\r\n if (hookResult === false) return false;\r\n \r\n await sourceTransaction.commit();\r\n const { itemDeltas } = await targetTransaction.commit();\r\n \r\n await ItemPileSocket.callHook(HOOKS.ITEM.TRANSFER_ALL, sourceUuid, targetUuid, itemDeltas, userId, interactionId);\r\n \r\n const macroData = {\r\n action: \"transferAllItems\",\r\n source: sourceUuid,\r\n target: targetUuid,\r\n items: itemDeltas,\r\n userId: userId,\r\n interactionId: interactionId\r\n };\r\n await this._executeItemPileMacro(sourceUuid, macroData);\r\n await this._executeItemPileMacro(targetUuid, macroData);\r\n \r\n const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);\r\n if (shouldBeDeleted) {\r\n await this._deleteItemPile(sourceUuid);\r\n }\r\n \r\n return itemDeltas;\r\n }\r\n \r\n static async _addAttributes(targetUuid, attributes, userId, { interactionId = false } = {}) {\r\n \r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const transaction = new Transaction(targetActor);\r\n await transaction.appendActorChanges(attributes);\r\n const { actorUpdates } = transaction.prepare();\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ATTRIBUTE.PRE_ADD, targetActor, actorUpdates, interactionId);\r\n if (hookResult === false) return false;\r\n \r\n const { attributeDeltas } = await transaction.commit();\r\n \r\n await ItemPileSocket.callHook(HOOKS.ATTRIBUTE.ADD, targetUuid, attributeDeltas, userId, interactionId);\r\n \r\n await this._executeItemPileMacro(targetUuid, {\r\n action: \"addAttributes\",\r\n target: targetUuid,\r\n attributes: attributeDeltas,\r\n userId: userId,\r\n interactionId: interactionId\r\n });\r\n \r\n return attributeDeltas;\r\n \r\n }\r\n \r\n static async _removeAttributes(targetUuid, attributes, userId, { interactionId = false } = {}) {\r\n \r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const transaction = new Transaction(targetActor);\r\n await transaction.appendActorChanges(attributes, { remove: true });\r\n const { actorUpdates } = transaction.prepare();\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ATTRIBUTE.PRE_REMOVE, targetActor, actorUpdates, interactionId);\r\n if (hookResult === false) return false;\r\n \r\n const { attributeDeltas } = await transaction.commit();\r\n \r\n await ItemPileSocket.callHook(HOOKS.ATTRIBUTE.REMOVE, targetUuid, attributeDeltas, userId, interactionId);\r\n \r\n await this._executeItemPileMacro(targetUuid, {\r\n action: \"removeAttributes\",\r\n target: targetUuid,\r\n attributes: attributeDeltas,\r\n userId: userId,\r\n interactionId: interactionId\r\n });\r\n \r\n const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(targetUuid);\r\n if (shouldBeDeleted) {\r\n await this._deleteItemPile(targetUuid);\r\n }\r\n \r\n return attributeDeltas;\r\n \r\n }\r\n \r\n static async _transferAttributes(sourceUuid, targetUuid, attributes, userId, { interactionId = false } = {}) {\r\n \r\n const sourceActor = Utilities.getActor(sourceUuid);\r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const sourceTransaction = new Transaction(sourceActor);\r\n await sourceTransaction.appendActorChanges(attributes, { remove: true });\r\n const sourceUpdates = sourceTransaction.prepare();\r\n \r\n const targetTransaction = new Transaction(targetActor);\r\n await targetTransaction.appendActorChanges(sourceUpdates.attributeDeltas);\r\n const targetUpdates = targetTransaction.prepare();\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ATTRIBUTE.PRE_TRANSFER, sourceActor, sourceUpdates.actorUpdates, targetActor, targetUpdates.actorUpdates, interactionId);\r\n if (hookResult === false) return false;\r\n \r\n await sourceTransaction.commit();\r\n const { attributeDeltas } = await targetTransaction.commit();\r\n \r\n await ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.CALL_HOOK, HOOKS.ATTRIBUTE.TRANSFER, sourceUuid, targetUuid, attributeDeltas, userId, interactionId);\r\n \r\n const macroData = {\r\n action: \"transferAttributes\",\r\n source: sourceUuid,\r\n target: targetUuid,\r\n attributes: attributeDeltas,\r\n userId: userId,\r\n interactionId: interactionId\r\n };\r\n await this._executeItemPileMacro(sourceUuid, macroData);\r\n await this._executeItemPileMacro(targetUuid, macroData);\r\n \r\n const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);\r\n \r\n const itemPile = await fromUuid(sourceUuid)\r\n \r\n if (shouldBeDeleted) {\r\n await this._deleteItemPile(sourceUuid);\r\n } else if (PileUtilities.isItemPileEmpty(itemPile)) {\r\n await SharingUtilities.clearItemPileSharingData(itemPile);\r\n } else {\r\n await SharingUtilities.setItemPileSharingData(sourceUuid, targetUuid, {\r\n attributes: attributeDeltas\r\n });\r\n }\r\n \r\n return attributeDeltas;\r\n \r\n }\r\n \r\n static async _transferAllAttributes(sourceUuid, targetUuid, userId, { interactionId = false } = {}) {\r\n \r\n const sourceActor = Utilities.getActor(sourceUuid);\r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const sourceAttributes = PileUtilities.getActorCurrencies(sourceActor).filter(entry => entry.type === \"attribute\");\r\n const attributesToTransfer = sourceAttributes.filter(attribute => {\r\n return hasProperty(targetActor.data, attribute.data.path);\r\n }).map(attribute => attribute.data.path);\r\n \r\n const sourceTransaction = new Transaction(sourceActor);\r\n await sourceTransaction.appendActorChanges(attributesToTransfer, { remove: true });\r\n const sourceUpdates = sourceTransaction.prepare();\r\n \r\n const targetTransaction = new Transaction(targetActor);\r\n await targetTransaction.appendActorChanges(sourceUpdates.attributeDeltas);\r\n const targetUpdates = targetTransaction.prepare();\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ATTRIBUTE.PRE_TRANSFER_ALL, sourceActor, sourceUpdates.actorUpdates, targetActor, targetUpdates.actorUpdates, interactionId);\r\n if (hookResult === false) return false;\r\n \r\n await sourceTransaction.commit();\r\n const { attributeDeltas } = await targetTransaction.commit();\r\n \r\n await ItemPileSocket.callHook(HOOKS.ATTRIBUTE.TRANSFER_ALL, sourceUuid, targetUuid, attributeDeltas, userId, interactionId);\r\n \r\n const macroData = {\r\n action: \"transferAllAttributes\",\r\n source: sourceUuid,\r\n target: targetUuid,\r\n attributes: attributeDeltas,\r\n userId: userId,\r\n interactionId: interactionId\r\n };\r\n await this._executeItemPileMacro(sourceUuid, macroData);\r\n await this._executeItemPileMacro(targetUuid, macroData);\r\n \r\n const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);\r\n \r\n if (shouldBeDeleted) {\r\n await this._deleteItemPile(sourceUuid);\r\n }\r\n \r\n return attributeDeltas;\r\n \r\n }\r\n \r\n static async _transferEverything(sourceUuid, targetUuid, userId, { itemFilters = false, interactionId } = {}) {\r\n \r\n const sourceActor = Utilities.getActor(sourceUuid);\r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const itemsToTransfer = PileUtilities.getActorItems(sourceActor, { itemFilters }).map(item => item.toObject());\r\n \r\n const sourceAttributes = PileUtilities.getActorCurrencies(sourceActor).filter(entry => entry.type === \"attribute\");\r\n const attributesToTransfer = sourceAttributes.filter(attribute => {\r\n return hasProperty(targetActor.data, attribute.data.path);\r\n }).map(attribute => attribute.data.path);\r\n \r\n const sourceTransaction = new Transaction(sourceActor);\r\n await sourceTransaction.appendItemChanges(itemsToTransfer, { remove: true });\r\n await sourceTransaction.appendActorChanges(attributesToTransfer, { remove: true });\r\n const sourceUpdates = sourceTransaction.prepare();\r\n \r\n const targetTransaction = new Transaction(targetActor);\r\n await targetTransaction.appendItemChanges(sourceUpdates.itemDeltas);\r\n await targetTransaction.appendActorChanges(sourceUpdates.attributeDeltas);\r\n const targetUpdates = targetTransaction.prepare();\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.PRE_TRANSFER_EVERYTHING, sourceActor, sourceUpdates, targetActor, targetUpdates, userId);\r\n if (hookResult === false) return false;\r\n \r\n await sourceTransaction.commit();\r\n const { itemDeltas, attributeDeltas } = await targetTransaction.commit();\r\n \r\n await ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.CALL_HOOK, HOOKS.TRANSFER_EVERYTHING, sourceUuid, targetUuid, itemDeltas, attributeDeltas, userId, interactionId);\r\n \r\n const macroData = {\r\n action: \"transferEverything\",\r\n source: sourceUuid,\r\n target: targetUuid,\r\n items: itemDeltas,\r\n attributes: attributeDeltas,\r\n userId: userId,\r\n interactionId: interactionId\r\n };\r\n await this._executeItemPileMacro(sourceUuid, macroData);\r\n await this._executeItemPileMacro(targetUuid, macroData);\r\n \r\n const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);\r\n if (shouldBeDeleted) {\r\n await this._deleteItemPile(sourceUuid);\r\n }\r\n \r\n return {\r\n itemsTransferred: itemDeltas, attributesTransferred: attributeDeltas\r\n };\r\n \r\n }\r\n \r\n static async _commitActorChanges(actorUuid, actorUpdates, itemsToUpdate, itemsToDelete, itemsToCreate) {\r\n const actor = Utilities.getActor(actorUuid);\r\n await actor.update(actorUpdates);\r\n await actor.updateEmbeddedDocuments(\"Item\", itemsToUpdate);\r\n await actor.deleteEmbeddedDocuments(\"Item\", itemsToDelete);\r\n const createdItems = await actor.createEmbeddedDocuments(\"Item\", itemsToCreate);\r\n return createdItems.map(item => item.toObject());\r\n }\r\n \r\n /**\r\n * If not given an actor, this method creates an item pile at a location, then adds an item to it.\r\n *\r\n * If a target was provided, it will just add the item to that target actor.\r\n *\r\n * If an actor was provided, it will transfer the item from the actor to the target actor.\r\n *\r\n * @param {String} userId\r\n * @param {String} sceneId\r\n * @param {String/Boolean} [sourceUuid=false]\r\n * @param {String/Boolean} [targetUuid=false]\r\n * @param {Object/Boolean} [position=false]\r\n * @param {Object} [itemData=false]\r\n *\r\n * @returns {sourceUuid: string/boolean, targetUuid: string/boolean, position: object/boolean, itemsDropped: array }\r\n */\r\n static async _dropItems({\r\n userId, sceneId, sourceUuid = false, targetUuid = false, itemData = false, position = false\r\n } = {}) {\r\n \r\n let itemsDropped;\r\n \r\n // If there's a source of the item (it wasn't dropped from the item bar)\r\n if (sourceUuid) {\r\n \r\n const itemsToTransfer = [{ _id: itemData.item._id, quantity: itemData.quantity }];\r\n \r\n // If there's a target token, add the item to it, otherwise create a new pile at the drop location\r\n if (targetUuid) {\r\n itemsDropped = await this._transferItems(sourceUuid, targetUuid, itemsToTransfer, userId);\r\n } else {\r\n itemsDropped = await this._removeItems(sourceUuid, itemsToTransfer, userId);\r\n targetUuid = await this._createItemPile(sceneId, position, { items: itemsDropped });\r\n }\r\n \r\n // If there's no source (it was dropped from the item bar)\r\n } else {\r\n \r\n // If there's a target token, add the item to it, otherwise create a new pile at the drop location\r\n if (targetUuid) {\r\n itemsDropped = await this._addItems(targetUuid, [itemData], userId);\r\n } else {\r\n targetUuid = await this._createItemPile(sceneId, position, { items: [itemData] });\r\n }\r\n \r\n }\r\n \r\n await ItemPileSocket.callHook(HOOKS.ITEM.DROP, sourceUuid, targetUuid, itemsDropped, position);\r\n \r\n return { sourceUuid, targetUuid, position, itemsDropped };\r\n \r\n }\r\n \r\n \r\n static async _createItemPile(sceneId, position, { pileActorName = false, items = false } = {}) {\r\n \r\n let pileActor;\r\n \r\n if (!pileActorName) {\r\n \r\n pileActor = Helpers.getSetting(SETTINGS.DEFAULT_ITEM_PILE_ACTOR_ID);\r\n \r\n if (!pileActor) {\r\n \r\n Helpers.custom_notify(\"A Default Item Pile has been added to your Actors list. You can configure the default look and behavior on it, or duplicate it to create different styles.\")\r\n \r\n const pileDataDefaults = foundry.utils.duplicate(CONSTANTS.PILE_DEFAULTS);\r\n \r\n pileDataDefaults.enabled = true;\r\n pileDataDefaults.deleteWhenEmpty = \"true\";\r\n pileDataDefaults.displayOne = true;\r\n pileDataDefaults.showItemName = true;\r\n pileDataDefaults.overrideSingleItemScale = true;\r\n pileDataDefaults.singleItemScale = 0.75;\r\n \r\n pileActor = await Actor.create({\r\n name: \"Default Item Pile\",\r\n type: Helpers.getSetting(\"actorClassType\"),\r\n img: \"icons/svg/item-bag.svg\",\r\n [CONSTANTS.FLAGS.PILE]: pileDataDefaults\r\n });\r\n \r\n await pileActor.update({\r\n \"token\": {\r\n name: \"Item Pile\",\r\n actorLink: false,\r\n bar1: { attribute: \"\" },\r\n vision: false,\r\n displayName: 50,\r\n [CONSTANTS.FLAGS.PILE]: pileDataDefaults\r\n }\r\n })\r\n \r\n await game.settings.set(CONSTANTS.MODULE_NAME, \"defaultItemPileActorID\", pileActor.id);\r\n \r\n }\r\n \r\n } else {\r\n \r\n pileActor = game.actors.getName(pileActorName);\r\n \r\n }\r\n \r\n let overrideData = { ...position };\r\n \r\n const pileData = PileUtilities.getActorFlagData(pileActor);\r\n \r\n if (!pileActor.data.token.actorLink) {\r\n \r\n if (items) {\r\n for (let i = 0; i < items.length; i++) {\r\n const itemData = items[i]?.item ?? items[i];\r\n if (SYSTEMS.DATA.ITEM_TRANSFORMER) {\r\n items[i] = await SYSTEMS.DATA.ITEM_TRANSFORMER(itemData);\r\n }\r\n }\r\n } else {\r\n items = []\r\n }\r\n \r\n items = items ? items.map(item => {\r\n let itemData = item.item ?? item;\r\n return itemData;\r\n }) : [];\r\n \r\n overrideData['actorData'] = {\r\n items: items\r\n }\r\n \r\n const data = { data: pileData, items: items };\r\n \r\n overrideData = foundry.utils.mergeObject(overrideData, {\r\n \"img\": PileUtilities.getItemPileTokenImage(pileActor, data),\r\n \"scale\": PileUtilities.getItemPileTokenScale(pileActor, data),\r\n \"name\": PileUtilities.getItemPileName(pileActor, data),\r\n });\r\n \r\n }\r\n \r\n const tokenData = await pileActor.getTokenData(overrideData);\r\n \r\n const scene = game.scenes.get(sceneId);\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_CREATE, tokenData);\r\n if (hookResult === false) return false;\r\n \r\n const [tokenDocument] = await scene.createEmbeddedDocuments(\"Token\", [tokenData]);\r\n \r\n return Utilities.getUuid(tokenDocument);\r\n \r\n }\r\n \r\n static async _turnTokensIntoItemPiles(targetUuids, pileSettings = {}, tokenSettings = {}) {\r\n \r\n const tokenUpdateGroups = {};\r\n const actorUpdateGroups = {};\r\n \r\n for (const targetUuid of targetUuids) {\r\n \r\n let target = Utilities.fromUuidFast(targetUuid);\r\n \r\n pileSettings = foundry.utils.mergeObject(PileUtilities.getActorFlagData(target), pileSettings);\r\n pileSettings.enabled = true;\r\n \r\n const targetItems = PileUtilities.getActorItems(target, { itemFilters: pileSettings.overrideItemFilters });\r\n const targetCurrencies = PileUtilities.getActorCurrencies(target, { currencyList: pileSettings.overrideCurrencies });\r\n \r\n const data = { data: pileSettings, items: targetItems, currencies: targetCurrencies };\r\n \r\n tokenSettings = foundry.utils.mergeObject(tokenSettings, {\r\n \"img\": PileUtilities.getItemPileTokenImage(target, data),\r\n \"scale\": PileUtilities.getItemPileTokenScale(target, data),\r\n \"name\": PileUtilities.getItemPileName(target, data)\r\n });\r\n \r\n const sceneId = targetUuid.split('.')[1];\r\n const tokenId = targetUuid.split('.')[3];\r\n \r\n if (!tokenUpdateGroups[sceneId]) {\r\n tokenUpdateGroups[sceneId] = []\r\n }\r\n \r\n tokenUpdateGroups[sceneId].push({\r\n \"_id\": tokenId, ...tokenSettings,\r\n [CONSTANTS.FLAGS.PILE]: pileSettings,\r\n [`actorData.${CONSTANTS.FLAGS.PILE}`]: pileSettings\r\n });\r\n \r\n if (target.isLinked) {\r\n if (actorUpdateGroups[target.actor.id]) continue;\r\n actorUpdateGroups[target.actor.id] = {\r\n \"_id\": target.actor.id, [CONSTANTS.FLAGS.PILE]: pileSettings\r\n }\r\n }\r\n }\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_TURN_INTO, tokenUpdateGroups, actorUpdateGroups);\r\n if (hookResult === false) return false;\r\n \r\n await Actor.updateDocuments(Object.values(actorUpdateGroups));\r\n \r\n for (const [sceneId, updateData] of Object.entries(tokenUpdateGroups)) {\r\n const scene = game.scenes.get(sceneId);\r\n await scene.updateEmbeddedDocuments(\"Token\", updateData);\r\n }\r\n \r\n await ItemPileSocket.callHook(HOOKS.PILE.TURN_INTO, tokenUpdateGroups, actorUpdateGroups);\r\n \r\n return targetUuids;\r\n \r\n }\r\n \r\n static async _revertTokensFromItemPiles(targetUuids, tokenSettings) {\r\n \r\n const actorUpdateGroups = {};\r\n const tokenUpdateGroups = {};\r\n \r\n for (const targetUuid of targetUuids) {\r\n \r\n let target = Utilities.fromUuidFast(targetUuid);\r\n \r\n const pileSettings = PileUtilities.getActorFlagData(target);\r\n pileSettings.enabled = false;\r\n \r\n const sceneId = targetUuid.split('.')[1];\r\n const tokenId = targetUuid.split('.')[3];\r\n \r\n if (!tokenUpdateGroups[sceneId]) {\r\n tokenUpdateGroups[sceneId] = [];\r\n }\r\n \r\n tokenUpdateGroups[sceneId].push({\r\n \"_id\": tokenId, ...tokenSettings,\r\n [CONSTANTS.FLAGS.PILE]: pileSettings,\r\n [`actorData.${CONSTANTS.FLAGS.PILE}`]: pileSettings\r\n });\r\n \r\n if (target.isLinked) {\r\n if (actorUpdateGroups[target.actor.id]) continue;\r\n actorUpdateGroups[target.actor.id] = {\r\n \"_id\": target.actor.id, [CONSTANTS.FLAGS.PILE]: pileSettings\r\n }\r\n }\r\n }\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_REVERT_FROM, tokenUpdateGroups, actorUpdateGroups);\r\n if (hookResult === false) return false;\r\n \r\n await Actor.updateDocuments(Object.values(actorUpdateGroups));\r\n \r\n for (const [sceneId, updateData] of Object.entries(tokenUpdateGroups)) {\r\n const scene = game.scenes.get(sceneId);\r\n await scene.updateEmbeddedDocuments(\"Token\", updateData);\r\n }\r\n \r\n await ItemPileSocket.callHook(HOOKS.PILE.REVERT_FROM, tokenUpdateGroups, actorUpdateGroups);\r\n \r\n return targetUuids;\r\n \r\n }\r\n \r\n static async _updateItemPile(targetUuid, newData, { interactingTokenUuid = false, tokenSettings = false } = {}) {\r\n \r\n const targetActor = Utilities.getActor(targetUuid);\r\n const interactingToken = interactingTokenUuid ? Utilities.getToken(interactingTokenUuid) : false;\r\n \r\n const oldData = PileUtilities.getActorFlagData(targetActor);\r\n \r\n const data = foundry.utils.mergeObject(foundry.utils.duplicate(oldData), foundry.utils.duplicate(newData));\r\n \r\n const diff = foundry.utils.diffObject(oldData, data);\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_UPDATE, targetActor, data, interactingToken, tokenSettings);\r\n if (hookResult === false) return false;\r\n \r\n await Helpers.wait(15);\r\n \r\n await PileUtilities.updateItemPileData(targetActor, data, tokenSettings);\r\n \r\n if (data.enabled && data.isContainer) {\r\n if (diff?.closed === true) {\r\n await this._executeItemPileMacro(targetUuid, {\r\n action: \"closeItemPile\", source: interactingTokenUuid, target: targetUuid\r\n });\r\n }\r\n if (diff?.locked === true) {\r\n await this._executeItemPileMacro(targetUuid, {\r\n action: \"lockItemPile\", source: interactingTokenUuid, target: targetUuid\r\n });\r\n }\r\n if (diff?.locked === false) {\r\n await this._executeItemPileMacro(targetUuid, {\r\n action: \"unlockItemPile\", source: interactingTokenUuid, target: targetUuid\r\n });\r\n }\r\n if (diff?.closed === false) {\r\n await this._executeItemPileMacro(targetUuid, {\r\n action: \"openItemPile\", source: interactingTokenUuid, target: targetUuid\r\n });\r\n }\r\n }\r\n \r\n return ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.UPDATED_PILE, targetUuid, diff, interactingTokenUuid);\r\n }\r\n \r\n static _updatedItemPile(targetUuid, diffData, interactingTokenUuid) {\r\n \r\n const target = Utilities.getToken(targetUuid);\r\n \r\n const interactingToken = interactingTokenUuid ? Utilities.fromUuidFast(interactingTokenUuid) : false;\r\n \r\n if (foundry.utils.isObjectEmpty(diffData)) return false;\r\n \r\n const data = PileUtilities.getActorFlagData(target);\r\n \r\n Helpers.hooks.callAll(HOOKS.PILE.UPDATE, target, diffData, interactingToken)\r\n \r\n if (data.enabled && data.isContainer) {\r\n if (diffData?.closed === true) {\r\n Helpers.hooks.callAll(HOOKS.PILE.CLOSE, target, interactingToken)\r\n }\r\n if (diffData?.locked === true) {\r\n Helpers.hooks.callAll(HOOKS.PILE.LOCK, target, interactingToken)\r\n }\r\n if (diffData?.locked === false) {\r\n Helpers.hooks.callAll(HOOKS.PILE.UNLOCK, target, interactingToken)\r\n }\r\n if (diffData?.closed === false) {\r\n Helpers.hooks.callAll(HOOKS.PILE.OPEN, target, interactingToken)\r\n }\r\n }\r\n }\r\n \r\n static async _deleteItemPile(targetUuid) {\r\n const target = Utilities.getToken(targetUuid);\r\n if (!target) return false;\r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_DELETE, target);\r\n if (hookResult === false) return false;\r\n return target.delete();\r\n }\r\n \r\n /* -------- PRIVATE ITEM PILE METHODS -------- */\r\n \r\n /**\r\n * Checks whether a given item pile would need to update its images, text, and/or scale\r\n *\r\n * @param {foundry.abstract.Document} doc\r\n * @param [changes]\r\n * @returns {*}\r\n * @private\r\n */\r\n static _evaluateItemPileChange(doc, changes) {\r\n const target = doc?.token ?? doc;\r\n if (!Helpers.isResponsibleGM()) return;\r\n if (!PileUtilities.isValidItemPile(target)) return;\r\n const targetUuid = target.uuid;\r\n return Helpers.debounceManager.setDebounce(targetUuid, async (uuid) => {\r\n const deleted = PileUtilities.shouldItemPileBeDeleted(uuid);\r\n if (deleted) return;\r\n await Helpers.hooks.runWithout(async () => {\r\n await PileUtilities.updateItemPileData(uuid);\r\n });\r\n })(targetUuid);\r\n \r\n }\r\n \r\n /**\r\n * Pre-loads all images and sounds related to a given token document on the client-side.\r\n *\r\n * @param {TokenDocument} tokenDocument\r\n * @return {Promise}\r\n */\r\n static async _preloadItemPileFiles(tokenDocument) {\r\n \r\n if (!PileUtilities.isValidItemPile(tokenDocument)) return false;\r\n \r\n const pileData = PileUtilities.getActorFlagData(tokenDocument);\r\n \r\n if (Helpers.getSetting(\"preloadFiles\")) {\r\n await Promise.allSettled(Object.entries(pileData).map(entry => {\r\n return new Promise(async (resolve) => {\r\n const [property, filePath] = entry;\r\n const isImage = property.toLowerCase().includes(\"image\");\r\n const isSound = property.toLowerCase().includes(\"sound\");\r\n if ((!isImage && !isSound) || (!filePath || preloadedFiles.has(filePath))) return resolve();\r\n preloadedFiles.add(filePath);\r\n \r\n if (isImage) {\r\n await loadTexture(filePath);\r\n Helpers.debug(`Preloaded image: ${filePath}`);\r\n } else if (isSound) {\r\n Helpers.debug(`Preloaded sound: ${filePath}`);\r\n await AudioHelper.preloadSound(filePath);\r\n }\r\n resolve();\r\n });\r\n }));\r\n }\r\n \r\n Helpers.debug(`Initialized item pile with uuid ${tokenDocument.uuid}`);\r\n }\r\n \r\n /**\r\n * This executes any macro that is configured on the item pile, providing the macro with extra data relating to the\r\n * action that prompted the execution (if the advanced-macros module is installed)\r\n *\r\n * @param {String} targetUuid\r\n * @param {Object} macroData\r\n * @return {Promise/Boolean}\r\n */\r\n static _executeItemPileMacro(targetUuid, macroData) {\r\n \r\n const target = Utilities.getToken(targetUuid);\r\n \r\n if (!PileUtilities.isValidItemPile(target)) return false;\r\n \r\n const pileData = PileUtilities.getActorFlagData(target);\r\n \r\n if (!pileData.macro) return false;\r\n \r\n const macro = game.macros.getName(pileData.macro);\r\n \r\n if (!macro) {\r\n throw Helpers.custom_error(`Could not find macro with name \"${pileData.macro}\" on target with UUID ${target.uuid}`);\r\n }\r\n \r\n // Reformat macro data to contain useful information\r\n if (macroData.source) {\r\n macroData.source = Utilities.fromUuidFast(macroData.source);\r\n }\r\n \r\n if (macroData.target) {\r\n macroData.target = Utilities.fromUuidFast(macroData.target);\r\n }\r\n \r\n const targetActor = macroData.target instanceof TokenDocument ? macroData.target.actor : macroData.target;\r\n \r\n if (macroData.item) {\r\n macroData.items = macroData.items.map(item => targetActor.items.get(item._id));\r\n }\r\n \r\n return macro.execute([macroData]);\r\n \r\n }\r\n \r\n /**\r\n * This handles any dropped data onto the canvas or a set item pile\r\n *\r\n * @param {canvas} canvas\r\n * @param {Object} data\r\n * @param {Actor/Token/TokenDocument/Boolean}[target=false]\r\n * @return {Promise/Boolean}\r\n */\r\n static async _dropData(canvas, data, { target = false } = {}) {\r\n \r\n if (data.type !== \"Item\") return false;\r\n \r\n let item = await Item.implementation.fromDropData(data);\r\n let itemData = item.toObject();\r\n \r\n if (!itemData) {\r\n console.error(data);\r\n throw Helpers.custom_error(\"Something went wrong when dropping this item!\")\r\n }\r\n \r\n const dropData = {\r\n source: false, target: target, itemData: {\r\n item: itemData, quantity: 1\r\n }, position: false\r\n }\r\n \r\n if (data.tokenId) {\r\n dropData.source = canvas.tokens.get(data.tokenId).actor;\r\n } else if (data.actorId) {\r\n dropData.source = game.actors.get(data.actorId);\r\n }\r\n \r\n if (!dropData.source && !game.user.isGM) {\r\n return Helpers.custom_warning(game.i18n.localize(\"ITEM-PILES.Errors.NoSourceDrop\"), true)\r\n }\r\n \r\n const pre_drop_determined_hook = Helpers.hooks.call(HOOKS.ITEM.PRE_DROP_DETERMINED, dropData.source, dropData.target, dropData.position, dropData.itemData);\r\n if (pre_drop_determined_hook === false) return false;\r\n \r\n let action;\r\n let droppableDocuments = [];\r\n let x;\r\n let y;\r\n \r\n if (dropData.target) {\r\n \r\n droppableDocuments.push(dropData.target);\r\n \r\n } else {\r\n \r\n const position = canvas.grid.getTopLeft(data.x, data.y);\r\n x = position[0];\r\n y = position[1];\r\n \r\n droppableDocuments = Utilities.getTokensAtLocation({ x, y })\r\n .map(token => Utilities.getDocument(token))\r\n .filter(token => PileUtilities.isValidItemPile(token));\r\n \r\n }\r\n \r\n if (droppableDocuments.length && game.modules.get(\"midi-qol\")?.active && game.settings.get(\"midi-qol\", \"DragDropTarget\")) {\r\n Helpers.custom_warning(\"You have Drag & Drop Targetting enabled in MidiQOL, which disables drag & drop items\")\r\n return false;\r\n }\r\n \r\n if (droppableDocuments.length > 0 && !game.user.isGM) {\r\n \r\n if (!(droppableDocuments[0] instanceof Actor && dropData.source instanceof Actor)) {\r\n \r\n const sourceToken = canvas.tokens.placeables.find(token => token.actor === dropData.source);\r\n \r\n if (sourceToken) {\r\n \r\n const targetToken = droppableDocuments[0];\r\n \r\n const distance = Math.floor(Utilities.distance_between_rect(sourceToken, targetToken.object) / canvas.grid.size) + 1\r\n \r\n const pileData = PileUtilities.getActorFlagData(targetToken);\r\n \r\n const maxDistance = pileData.distance ? pileData.distance : Infinity;\r\n \r\n if (distance > maxDistance) {\r\n Helpers.custom_warning(game.i18n.localize(\"ITEM-PILES.Errors.PileTooFar\"), true);\r\n return false;\r\n }\r\n }\r\n }\r\n \r\n droppableDocuments = droppableDocuments.filter(token => !game.itempiles.isItemPileLocked(token));\r\n \r\n if (!droppableDocuments.length) {\r\n Helpers.custom_warning(game.i18n.localize(\"ITEM-PILES.Errors.PileLocked\"), true);\r\n return false;\r\n }\r\n }\r\n \r\n const disallowedType = PileUtilities.isItemInvalid(droppableDocuments?.[0], dropData.itemData.item);\r\n if (disallowedType) {\r\n if (!game.user.isGM) {\r\n return Helpers.custom_warning(game.i18n.format(\"ITEM-PILES.Errors.DisallowedItemDrop\", { type: disallowedType }), true)\r\n }\r\n \r\n if (SYSTEMS.DATA.ITEM_TRANSFORMER) {\r\n dropData.itemData.item = await SYSTEMS.DATA.ITEM_TRANSFORMER(dropData.itemData.item);\r\n }\r\n \r\n const newDisallowedType = PileUtilities.isItemInvalid(droppableDocuments?.[0], dropData.itemData.item);\r\n \r\n if (newDisallowedType && !hotkeyState.shiftDown) {\r\n const force = await Dialog.confirm({\r\n title: game.i18n.localize(\"ITEM-PILES.Dialogs.TypeWarning.Title\"),\r\n content: `${game.i18n.format(\"ITEM-PILES.Dialogs.TypeWarning.DropContent\", { type: newDisallowedType })}
`,\r\n defaultYes: false\r\n });\r\n if (!force) {\r\n return false;\r\n }\r\n }\r\n } else {\r\n if (SYSTEMS.DATA.ITEM_TRANSFORMER) {\r\n dropData.itemData.item = await SYSTEMS.DATA.ITEM_TRANSFORMER(dropData.itemData.item);\r\n }\r\n }\r\n \r\n if (hotkeyState.altDown) {\r\n \r\n if (droppableDocuments.length) {\r\n action = \"addToPile\";\r\n }\r\n \r\n setProperty(dropData.itemData.item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, 1);\r\n dropData.itemData.quantity = 1;\r\n \r\n } else {\r\n \r\n const quantity = getProperty(dropData.itemData.item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE);\r\n \r\n let result = { action: \"addToPile\", quantity: 1 }\r\n if (quantity > 1) {\r\n result = await DropItemDialog.show(item, droppableDocuments[0]);\r\n if (!result) return false;\r\n }\r\n \r\n action = result.action;\r\n setProperty(dropData.itemData.item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, Number(result.quantity))\r\n dropData.itemData.quantity = Number(result.quantity);\r\n \r\n }\r\n \r\n if (action === \"addToPile\") {\r\n dropData.target = droppableDocuments[0];\r\n } else {\r\n dropData.position = { x, y };\r\n }\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_DROP, dropData.source, dropData.target, dropData.position, dropData.itemData);\r\n if (hookResult === false) return false;\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DROP_ITEMS, {\r\n userId: game.user.id,\r\n sceneId: canvas.scene.id,\r\n sourceUuid: Utilities.getUuid(dropData.source),\r\n targetUuid: Utilities.getUuid(dropData.target),\r\n position: dropData.position,\r\n itemData: dropData.itemData\r\n });\r\n \r\n }\r\n \r\n static async _itemPileClicked(pileDocument) {\r\n \r\n if (!PileUtilities.isValidItemPile(pileDocument)) return false;\r\n \r\n const pileToken = pileDocument.object;\r\n \r\n if (!Helpers.isGMConnected()) {\r\n Helpers.custom_warning(`Item Piles requires a GM to be connected for players to be able to loot item piles.`, true)\r\n return false;\r\n }\r\n \r\n Helpers.debug(`Clicked: ${pileDocument.uuid}`);\r\n \r\n const pileData = PileUtilities.getActorFlagData(pileDocument);\r\n \r\n const maxDistance = pileData.distance ? pileData.distance : Infinity;\r\n \r\n let validTokens = [];\r\n \r\n if (canvas.tokens.controlled.length > 0) {\r\n validTokens = [...canvas.tokens.controlled];\r\n validTokens = validTokens.filter(token => token.document !== pileDocument);\r\n }\r\n \r\n if (!validTokens.length && !game.user.isGM) {\r\n validTokens.push(...canvas.tokens.placeables);\r\n if (_token) {\r\n validTokens.unshift(_token);\r\n }\r\n }\r\n \r\n validTokens = validTokens.filter(token => token.owner && token.document !== pileDocument).filter(token => {\r\n return Utilities.tokens_close_enough(pileToken, token, maxDistance) || game.user.isGM;\r\n });\r\n \r\n if (!validTokens.length && !game.user.isGM && maxDistance !== Infinity) {\r\n Helpers.custom_warning(game.i18n.localize(\"ITEM-PILES.Errors.PileTooFar\"), true);\r\n return false;\r\n }\r\n \r\n let interactingActor;\r\n if (validTokens.length) {\r\n if (validTokens.includes(_token)) {\r\n interactingActor = _token.actor;\r\n } else {\r\n validTokens.sort((potentialTargetA, potentialTargetB) => {\r\n return Utilities.grids_between_tokens(pileToken, potentialTargetA) - Utilities.grids_between_tokens(pileToken, potentialTargetB);\r\n })\r\n interactingActor = validTokens[0].actor;\r\n }\r\n } else if (game.user.character && !game.user.isGM) {\r\n interactingActor = game.user.character;\r\n }\r\n \r\n if (pileData.isContainer && interactingActor) {\r\n \r\n if (pileData.locked && !game.user.isGM) {\r\n Helpers.debug(`Attempted to locked item pile with UUID ${pileDocument.uuid}`);\r\n return game.itempiles.rattleItemPile(pileDocument, interactingActor);\r\n }\r\n \r\n if (pileData.closed) {\r\n Helpers.debug(`Opened item pile with UUID ${pileDocument.uuid}`);\r\n await game.itempiles.openItemPile(pileDocument, interactingActor);\r\n }\r\n \r\n }\r\n \r\n return this._renderItemPileInterface(pileDocument.uuid, { inspectingTargetUuid: interactingActor?.uuid });\r\n \r\n }\r\n \r\n static async _splitItemPileContents(itemPileUuid, actorUuids, userId, instigator) {\r\n \r\n const itemPileActor = Utilities.getActor(itemPileUuid);\r\n \r\n const items = PileUtilities.getActorItems(itemPileActor);\r\n const currencies = PileUtilities.getActorCurrencies(itemPileActor);\r\n \r\n const pileData = PileUtilities.getActorFlagData(itemPileActor);\r\n const shareData = SharingUtilities.getItemPileSharingData(itemPileActor);\r\n \r\n const pileTransaction = new Transaction(itemPileActor);\r\n \r\n const transactionMap = actorUuids.map(uuid => {\r\n return [uuid, new Transaction(Utilities.getActor(uuid))];\r\n });\r\n \r\n if (pileData.shareItemsEnabled) {\r\n await pileTransaction.appendItemChanges(items, { remove: true });\r\n }\r\n \r\n if (pileData.shareCurrenciesEnabled) {\r\n const currencyItems = currencies.filter(entry => entry.type === \"item\");\r\n await pileTransaction.appendItemChanges(currencyItems, { remove: true, type: \"currency\" });\r\n \r\n const attributes = currencies.filter(entry => entry.type === \"attribute\");\r\n await pileTransaction.appendActorChanges(attributes, { remove: true });\r\n }\r\n \r\n const preparedData = pileTransaction.prepare();\r\n \r\n for (const [uuid, transaction] of transactionMap) {\r\n if (pileData.shareItemsEnabled) {\r\n await transaction.appendItemChanges(preparedData.itemDeltas.filter(delta => delta.type === \"item\").map(delta => {\r\n delta.quantity = SharingUtilities.getItemSharesLeftForActor(itemPileActor, delta.item, uuid, {\r\n players: actorUuids.length,\r\n shareData: shareData,\r\n floor: true\r\n });\r\n return delta;\r\n }));\r\n }\r\n \r\n if (pileData.shareCurrenciesEnabled) {\r\n await transaction.appendItemChanges(preparedData.itemDeltas.filter(delta => delta.type === \"currency\").map(delta => {\r\n delta.quantity = SharingUtilities.getItemSharesLeftForActor(itemPileActor, delta.item, uuid, {\r\n players: actorUuids.length,\r\n shareData: shareData,\r\n floor: true\r\n });\r\n return delta;\r\n }), { type: \"currency\" });\r\n \r\n await transaction.appendActorChanges(Object.entries(preparedData.attributeDeltas).map(entry => {\r\n let [path] = entry;\r\n const quantity = SharingUtilities.getAttributeSharesLeftForActor(itemPileActor, path, uuid, {\r\n players: actorUuids.length,\r\n shareData: shareData,\r\n floor: true\r\n });\r\n return { path, quantity };\r\n }));\r\n }\r\n }\r\n \r\n const actorPreparedData = Object.fromEntries(transactionMap.map(entry => [entry[0], entry[1].prepare()]));\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_SPLIT_INVENTORY, itemPileActor, preparedData, actorPreparedData, userId, instigator);\r\n if (hookResult === false) return false;\r\n \r\n const pileDeltas = await pileTransaction.commit();\r\n const actorDeltas = {};\r\n for (const [uuid, transaction] of transactionMap) {\r\n actorDeltas[uuid] = await transaction.commit();\r\n }\r\n \r\n await SharingUtilities.clearItemPileSharingData(itemPileActor);\r\n \r\n await ItemPileSocket.callHook(HOOKS.PILE.SPLIT_INVENTORY, itemPileUuid, pileDeltas, actorDeltas, userId, instigator);\r\n \r\n await this._executeItemPileMacro(itemPileUuid, {\r\n action: \"splitInventory\",\r\n source: itemPileUuid,\r\n target: actorUuids,\r\n transfers: {\r\n pileDeltas,\r\n actorDeltas\r\n },\r\n userId: userId,\r\n instigator: instigator\r\n });\r\n \r\n const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(itemPileUuid);\r\n if (shouldBeDeleted) {\r\n await this._deleteItemPile(itemPileUuid);\r\n }\r\n \r\n return {\r\n pileDeltas,\r\n actorDeltas\r\n };\r\n \r\n }\r\n \r\n static async _updateTokenHud() {\r\n if (!canvas.tokens.hud.rendered) return;\r\n return canvas.tokens.hud.render(true);\r\n }\r\n \r\n static async _renderItemPileInterface(targetUuid, {\r\n inspectingTargetUuid = false, useDefaultCharacter = false, remote = false\r\n } = {}) {\r\n \r\n const target = Utilities.getActor(targetUuid);\r\n \r\n let inspectingTarget;\r\n if (useDefaultCharacter && !game.user.isGM) {\r\n inspectingTarget = game.user.character;\r\n } else {\r\n inspectingTarget = inspectingTargetUuid ? Utilities.fromUuidFast(inspectingTargetUuid) : false;\r\n }\r\n \r\n const merchant = PileUtilities.isItemPileMerchant(target);\r\n if (merchant) {\r\n return MerchantApp.show(target, inspectingTarget)\r\n }\r\n \r\n return ItemPileInventoryApp.show(target, inspectingTarget, { remote });\r\n \r\n }\r\n \r\n static async _tradeItems(sellerUuid, buyerUuid, items, userId, {\r\n interactionId = false\r\n } = {}) {\r\n \r\n const sellingActor = Utilities.getActor(sellerUuid);\r\n const buyingActor = Utilities.getActor(buyerUuid);\r\n \r\n const itemPrices = PileUtilities.getPricesForItems(items.map(data => ({\r\n ...data,\r\n item: sellingActor.items.get(data.id)\r\n })), { seller: sellingActor, buyer: buyingActor });\r\n \r\n const preCalcHookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_CALC_TRADE, sellingActor, buyingActor, itemPrices, userId);\r\n if (preCalcHookResult === false) return false;\r\n \r\n const sellerTransaction = new Transaction(sellingActor);\r\n const sellerFlagData = PileUtilities.getActorFlagData(sellerTransaction);\r\n const sellerInfiniteQuantity = sellerFlagData.enabled && sellerFlagData.merchant && sellerFlagData.infiniteQuantity;\r\n \r\n for (const payment of itemPrices.sellerReceive) {\r\n if (!payment.quantity) continue;\r\n if (payment.type === \"attribute\") {\r\n await sellerTransaction.appendActorChanges([{\r\n path: payment.data.path,\r\n quantity: payment.quantity\r\n }], { type: payment.isCurrency ? \"currency\" : payment.type });\r\n } else {\r\n await sellerTransaction.appendItemChanges([{\r\n item: payment.item,\r\n quantity: payment.quantity\r\n }], { type: payment.isCurrency ? \"currency\" : payment.type });\r\n }\r\n }\r\n \r\n for (const entry of itemPrices.buyerReceive) {\r\n if (!entry.quantity || sellerInfiniteQuantity) continue;\r\n if (entry.type === \"attribute\") {\r\n await sellerTransaction.appendActorChanges([{\r\n path: entry.data.path,\r\n quantity: entry.quantity\r\n }], { remove: true, type: entry.isCurrency ? \"currency\" : entry.type });\r\n } else {\r\n await sellerTransaction.appendItemChanges([{\r\n item: entry.item,\r\n quantity: entry.quantity\r\n }], { remove: true, type: entry.isCurrency ? \"currency\" : entry.type });\r\n }\r\n }\r\n \r\n const buyerTransaction = new Transaction(buyingActor);\r\n const buyerFlagData = PileUtilities.getActorFlagData(buyingActor);\r\n const buyerIsMerchant = buyerFlagData.enabled && buyerFlagData.isMerchant;\r\n const buyerInfiniteCurrencies = buyerIsMerchant && buyerFlagData.infiniteCurrencies;\r\n const buyerInfiniteQuantity = buyerIsMerchant && buyerFlagData.infiniteQuantity;\r\n const buyerHidesNewItems = buyerIsMerchant && buyerFlagData.hideNewItems;\r\n \r\n for (const price of itemPrices.finalPrices) {\r\n if (!price.quantity || (buyerInfiniteCurrencies && price.isCurrency) || (buyerInfiniteQuantity && !price.isCurrency)) {\r\n continue;\r\n }\r\n if (price.type === \"attribute\") {\r\n await buyerTransaction.appendActorChanges([{\r\n path: price.data.path,\r\n quantity: price.quantity\r\n }], { remove: true, type: price.isCurrency ? \"currency\" : price.type });\r\n } else {\r\n await buyerTransaction.appendItemChanges([{\r\n item: price.item,\r\n quantity: price.quantity\r\n }], { remove: true, type: price.isCurrency ? \"currency\" : price.type });\r\n }\r\n }\r\n \r\n for (const entry of itemPrices.buyerReceive) {\r\n if (!entry.quantity) continue;\r\n if (entry.type === \"attribute\") {\r\n await buyerTransaction.appendActorChanges([{\r\n path: entry.data.path,\r\n quantity: entry.quantity\r\n }], { type: entry.type });\r\n } else {\r\n const item = entry.item.toObject();\r\n if (buyerHidesNewItems) {\r\n setProperty(item, CONSTANTS.FLAGS.ITEM + '.hidden', true);\r\n }\r\n await buyerTransaction.appendItemChanges([{\r\n item: item,\r\n quantity: entry.quantity\r\n }], { type: entry.type });\r\n }\r\n }\r\n \r\n for (const change of itemPrices.buyerChange) {\r\n if (!change.quantity) continue;\r\n if (change.type === \"attribute\") {\r\n await buyerTransaction.appendActorChanges([{\r\n path: change.data.path,\r\n quantity: change.quantity\r\n }], { type: \"currency\" });\r\n } else {\r\n await buyerTransaction.appendItemChanges([{\r\n item: change.item,\r\n quantity: change.quantity\r\n }], { type: \"currency\" });\r\n }\r\n }\r\n \r\n const sellerUpdates = sellerTransaction.prepare();\r\n const buyerUpdates = buyerTransaction.prepare();\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_TRADE, sellingActor, sellerUpdates, buyingActor, buyerUpdates, userId);\r\n if (hookResult === false) return false;\r\n \r\n await sellerTransaction.commit();\r\n const { itemDeltas, attributeDeltas } = await buyerTransaction.commit();\r\n \r\n await ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.CALL_HOOK, HOOKS.ITEM.TRADE, sellerUuid, buyerUuid, itemDeltas, attributeDeltas, userId, interactionId);\r\n \r\n return { itemDeltas, attributeDeltas, itemPrices };\r\n \r\n }\r\n \r\n}","\r\n\r\n\r\n\r\n\r\n {#if icon}\r\n \r\n {/if}\r\n \r\n {#if Array.isArray(content)}\r\n {#each content as part}\r\n
{@html part}
\r\n {/each}\r\n {:else}\r\n
{@html content}
\r\n {/if}\r\n\r\n
\r\n\r\n\r\n","\r\n\r\n\r\n\r\n
\r\n {#if hasUnlinkedTokenOwnership}\r\n
\r\n \r\n \r\n {localize(\"ITEM-PILES.Trade.Prompt.PickToken\")}\r\n \r\n
\r\n {/if}\r\n
\r\n\r\n","\r\n\r\n\r\n\r\n \r\n\r\n
\r\n\r\n
\r\n \r\n {localize(\"ITEM-PILES.Trade.Prompt.Title\")}\r\n \r\n
\r\n\r\n
{localize(\"ITEM-PILES.Trade.Prompt.User\")}
\r\n\r\n
\r\n
\r\n \r\n {#each users as potentialUser (potentialUser.id)}\r\n {potentialUser.name} \r\n {/each}\r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n {localize(\"ITEM-PILES.Trade.Private\")} \r\n \r\n {localize(\"ITEM-PILES.Trade.PrivateExplanation\")} \r\n
\r\n
\r\n\r\n {#if actor}\r\n
{localize(\"ITEM-PILES.Trade.Prompt.PickedActor\")}
\r\n {:else}\r\n
{localize(\"ITEM-PILES.Trade.Prompt.PickActor\")}
\r\n {/if}\r\n\r\n
\r\n\r\n \r\n\r\n
\r\n\r\n \r\n\r\n\r\n","import { writable } from '../store/index.mjs';\nimport { now, loop, assign } from '../internal/index.mjs';\nimport { linear } from '../easing/index.mjs';\n\nfunction is_date(obj) {\n return Object.prototype.toString.call(obj) === '[object Date]';\n}\n\nfunction tick_spring(ctx, last_value, current_value, target_value) {\n if (typeof current_value === 'number' || is_date(current_value)) {\n // @ts-ignore\n const delta = target_value - current_value;\n // @ts-ignore\n const velocity = (current_value - last_value) / (ctx.dt || 1 / 60); // guard div by 0\n const spring = ctx.opts.stiffness * delta;\n const damper = ctx.opts.damping * velocity;\n const acceleration = (spring - damper) * ctx.inv_mass;\n const d = (velocity + acceleration) * ctx.dt;\n if (Math.abs(d) < ctx.opts.precision && Math.abs(delta) < ctx.opts.precision) {\n return target_value; // settled\n }\n else {\n ctx.settled = false; // signal loop to keep ticking\n // @ts-ignore\n return is_date(current_value) ?\n new Date(current_value.getTime() + d) : current_value + d;\n }\n }\n else if (Array.isArray(current_value)) {\n // @ts-ignore\n return current_value.map((_, i) => tick_spring(ctx, last_value[i], current_value[i], target_value[i]));\n }\n else if (typeof current_value === 'object') {\n const next_value = {};\n for (const k in current_value) {\n // @ts-ignore\n next_value[k] = tick_spring(ctx, last_value[k], current_value[k], target_value[k]);\n }\n // @ts-ignore\n return next_value;\n }\n else {\n throw new Error(`Cannot spring ${typeof current_value} values`);\n }\n}\nfunction spring(value, opts = {}) {\n const store = writable(value);\n const { stiffness = 0.15, damping = 0.8, precision = 0.01 } = opts;\n let last_time;\n let task;\n let current_token;\n let last_value = value;\n let target_value = value;\n let inv_mass = 1;\n let inv_mass_recovery_rate = 0;\n let cancel_task = false;\n function set(new_value, opts = {}) {\n target_value = new_value;\n const token = current_token = {};\n if (value == null || opts.hard || (spring.stiffness >= 1 && spring.damping >= 1)) {\n cancel_task = true; // cancel any running animation\n last_time = now();\n last_value = new_value;\n store.set(value = target_value);\n return Promise.resolve();\n }\n else if (opts.soft) {\n const rate = opts.soft === true ? .5 : +opts.soft;\n inv_mass_recovery_rate = 1 / (rate * 60);\n inv_mass = 0; // infinite mass, unaffected by spring forces\n }\n if (!task) {\n last_time = now();\n cancel_task = false;\n task = loop(now => {\n if (cancel_task) {\n cancel_task = false;\n task = null;\n return false;\n }\n inv_mass = Math.min(inv_mass + inv_mass_recovery_rate, 1);\n const ctx = {\n inv_mass,\n opts: spring,\n settled: true,\n dt: (now - last_time) * 60 / 1000\n };\n const next_value = tick_spring(ctx, last_value, value, target_value);\n last_time = now;\n last_value = value;\n store.set(value = next_value);\n if (ctx.settled) {\n task = null;\n }\n return !ctx.settled;\n });\n }\n return new Promise(fulfil => {\n task.promise.then(() => {\n if (token === current_token)\n fulfil();\n });\n });\n }\n const spring = {\n set,\n update: (fn, opts) => set(fn(target_value, value), opts),\n subscribe: store.subscribe,\n stiffness,\n damping,\n precision\n };\n return spring;\n}\n\nfunction get_interpolator(a, b) {\n if (a === b || a !== a)\n return () => a;\n const type = typeof a;\n if (type !== typeof b || Array.isArray(a) !== Array.isArray(b)) {\n throw new Error('Cannot interpolate values of different type');\n }\n if (Array.isArray(a)) {\n const arr = b.map((bi, i) => {\n return get_interpolator(a[i], bi);\n });\n return t => arr.map(fn => fn(t));\n }\n if (type === 'object') {\n if (!a || !b)\n throw new Error('Object cannot be null');\n if (is_date(a) && is_date(b)) {\n a = a.getTime();\n b = b.getTime();\n const delta = b - a;\n return t => new Date(a + t * delta);\n }\n const keys = Object.keys(b);\n const interpolators = {};\n keys.forEach(key => {\n interpolators[key] = get_interpolator(a[key], b[key]);\n });\n return t => {\n const result = {};\n keys.forEach(key => {\n result[key] = interpolators[key](t);\n });\n return result;\n };\n }\n if (type === 'number') {\n const delta = b - a;\n return t => a + t * delta;\n }\n throw new Error(`Cannot interpolate ${type} values`);\n}\nfunction tweened(value, defaults = {}) {\n const store = writable(value);\n let task;\n let target_value = value;\n function set(new_value, opts) {\n if (value == null) {\n store.set(value = new_value);\n return Promise.resolve();\n }\n target_value = new_value;\n let previous_task = task;\n let started = false;\n let { delay = 0, duration = 400, easing = linear, interpolate = get_interpolator } = assign(assign({}, defaults), opts);\n if (duration === 0) {\n if (previous_task) {\n previous_task.abort();\n previous_task = null;\n }\n store.set(value = target_value);\n return Promise.resolve();\n }\n const start = now() + delay;\n let fn;\n task = loop(now => {\n if (now < start)\n return true;\n if (!started) {\n fn = interpolate(value, new_value);\n if (typeof duration === 'function')\n duration = duration(value, new_value);\n started = true;\n }\n if (previous_task) {\n previous_task.abort();\n previous_task = null;\n }\n const elapsed = now - start;\n if (elapsed > duration) {\n store.set(value = new_value);\n return false;\n }\n // @ts-ignore\n store.set(value = fn(easing(elapsed / duration)));\n return true;\n });\n return task.promise;\n }\n return {\n set,\n update: (fn, opts) => set(fn(target_value, value), opts),\n subscribe: store.subscribe\n };\n}\n\nexport { spring, tweened };\n","\r\n\r\n\r\n\r\n \r\n\r\n
\r\n\r\n
\r\n \r\n { localize(\"ITEM-PILES.Trade.Request.Title\") }\r\n \r\n
\r\n\r\n
\r\n {#if isPrivate}\r\n
{@html localize(\"ITEM-PILES.Trade.Request.PrivateContent\", {\r\n trading_user_name: tradingUser.name,\r\n trading_actor_name: tradingActor.name\r\n })}
\r\n {:else}\r\n
{localize(\"ITEM-PILES.Trade.Request.Content\", {\r\n trading_user_name: tradingUser.name,\r\n trading_actor_name: tradingActor.name\r\n })}
\r\n {/if}\r\n
{localize(\"ITEM-PILES.Trade.Request.AcceptQuery\")}
\r\n
\r\n\r\n {#if actor}\r\n
{localize(\"ITEM-PILES.Trade.Prompt.PickedActor\")}
\r\n {:else}\r\n
{localize(\"ITEM-PILES.Trade.Prompt.PickActor\")}
\r\n {/if}\r\n\r\n
\r\n\r\n \r\n\r\n
0}>\r\n \r\n
\r\n
\r\n\r\n \r\n\r\n","import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\nimport TradeDialogPrompt from './trade-dialog-prompt.svelte';\r\nimport TradeDialogRequest from './trade-dialog-request.svelte';\r\n\r\nexport class TradePromptDialog extends SvelteApplication {\r\n \r\n constructor(tradeOptions, options = {}) {\r\n super({\r\n svelte: {\r\n class: TradeDialogPrompt,\r\n target: document.body,\r\n props: {\r\n ...tradeOptions\r\n }\r\n },\r\n close: () => this.options.resolve?.(null),\r\n ...options\r\n });\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n title: game.i18n.localize(\"ITEM-PILES.Trade.Title\"),\r\n width: 400,\r\n height: \"auto\",\r\n classes: [\"dialog\"],\r\n })\r\n }\r\n \r\n static show(tradeOptions, options = {}, dialogData = {}) {\r\n return new Promise(resolve => {\r\n options.resolve = resolve;\r\n new this(tradeOptions, options, dialogData).render(true);\r\n })\r\n }\r\n}\r\n\r\nexport class TradeRequestDialog extends SvelteApplication {\r\n \r\n constructor(tradeOptions, options = {}) {\r\n \r\n super({\r\n svelte: {\r\n class: TradeDialogRequest,\r\n target: document.body,\r\n props: {\r\n ...tradeOptions\r\n }\r\n },\r\n close: () => this.options.resolve?.(null),\r\n ...options\r\n });\r\n this.tradeId = tradeOptions.tradeId;\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n title: game.i18n.localize(\"ITEM-PILES.Trade.Title\"),\r\n width: 400,\r\n height: \"auto\",\r\n classes: [\"dialog\"],\r\n })\r\n }\r\n \r\n static show(tradeOptions, options = {}) {\r\n return new Promise(resolve => {\r\n options.resolve = resolve;\r\n new this(tradeOptions, options).render(true);\r\n })\r\n }\r\n \r\n static cancel(tradeId) {\r\n for (const app of Object.values(ui.windows)) {\r\n if (app instanceof this && app.tradeId === tradeId) {\r\n app.options.resolve({ type: \"cancelled\" });\r\n return app.close();\r\n }\r\n }\r\n return false;\r\n }\r\n \r\n}","import { writable, get } from 'svelte/store';\r\nimport * as Utilities from \"../../helpers/utilities.js\";\r\n\r\nexport default class TradeStore {\r\n \r\n constructor(leftTrader, rightTrader, publicTradeId, privateTradeId = false, isPrivate = false) {\r\n \r\n this.publicTradeId = publicTradeId;\r\n this.privateTradeId = privateTradeId;\r\n this.isPrivate = isPrivate;\r\n \r\n this.leftTraderUser = leftTrader.user;\r\n this.leftTraderActor = leftTrader.actor;\r\n this.leftTraderItems = writable(leftTrader.items ?? []);\r\n this.leftTraderCurrencies = writable(leftTrader.currencies ?? []);\r\n this.leftTraderItemCurrencies = writable(leftTrader.itemCurrencies ?? []);\r\n this.leftTraderAccepted = writable(leftTrader.accepted ?? false);\r\n \r\n this.rightTraderUser = rightTrader.user;\r\n this.rightTraderActor = rightTrader.actor;\r\n this.rightTraderItems = writable(rightTrader.items ?? []);\r\n this.rightTraderCurrencies = writable(rightTrader.currencies ?? []);\r\n this.rightTraderItemCurrencies = writable(rightTrader.itemCurrencies ?? []);\r\n this.rightTraderAccepted = writable(rightTrader?.accepted ?? false);\r\n \r\n }\r\n \r\n static import(leftTraderData, rightTraderData, publicTradeId) {\r\n \r\n const leftTrader = {\r\n user: game.users.get(leftTraderData.user),\r\n actor: Utilities.fromUuidFast(leftTraderData.actorUiid),\r\n items: leftTraderData.items,\r\n currencies: leftTraderData.currencies,\r\n itemCurrencies: leftTraderData.itemCurrencies,\r\n accepted: leftTraderData.accepted\r\n };\r\n \r\n const rightTrader = {\r\n user: game.users.get(rightTraderData.user),\r\n actor: Utilities.fromUuidFast(rightTraderData.actorUiid),\r\n items: rightTraderData.items,\r\n currencies: rightTraderData.currencies,\r\n itemCurrencies: rightTraderData.itemCurrencies,\r\n accepted: rightTraderData.accepted\r\n };\r\n \r\n return new this(leftTrader, rightTrader, publicTradeId);\r\n }\r\n \r\n export() {\r\n return [{\r\n userId: this.leftTraderUser.id,\r\n actorUiid: Utilities.getUuid(this.leftTraderActor),\r\n items: get(this.leftTraderItems),\r\n currencies: get(this.leftTraderCurrencies),\r\n itemCurrencies: get(this.leftTraderItemCurrencies),\r\n accepted: get(this.leftTraderAccepted)\r\n }, {\r\n userId: this.rightTraderUser.id,\r\n actorUiid: Utilities.getUuid(this.rightTraderActor),\r\n items: get(this.rightTraderItems),\r\n currencies: get(this.rightTraderCurrencies),\r\n itemCurrencies: get(this.rightTraderItemCurrencies),\r\n accepted: get(this.rightTraderAccepted)\r\n }, this.publicTradeId]\r\n }\r\n \r\n getTradeData() {\r\n return {\r\n sourceActor: this.leftTraderActor,\r\n targetActor: this.rightTraderActor,\r\n remove: {\r\n items: get(this.leftTraderItems).concat(get(this.leftTraderItemCurrencies)),\r\n attributes: get(this.leftTraderCurrencies)\r\n }, add: {\r\n items: get(this.rightTraderItems).concat(get(this.rightTraderItemCurrencies)),\r\n attributes: get(this.rightTraderCurrencies)\r\n }\r\n };\r\n }\r\n \r\n getExistingCurrencies() {\r\n return [...get(this.leftTraderCurrencies), ...get(this.leftTraderItemCurrencies)]\r\n }\r\n \r\n get tradeIsAccepted() {\r\n return get(this.leftTraderAccepted) && get(this.rightTraderAccepted);\r\n }\r\n \r\n async toggleAccepted() {\r\n this.leftTraderAccepted.set(!get(this.leftTraderAccepted));\r\n }\r\n \r\n updateItems(userId, inItems) {\r\n if (userId === game.user.id) return;\r\n this.leftTraderAccepted.set(false);\r\n this.rightTraderAccepted.set(false);\r\n if (userId === this.leftTraderUser.id) {\r\n this.leftTraderItems.set(inItems)\r\n }\r\n if (userId === this.rightTraderUser.id) {\r\n this.rightTraderItems.set(inItems)\r\n }\r\n }\r\n \r\n updateItemCurrencies(userId, itemCurrencies) {\r\n if (userId === game.user.id) return;\r\n this.leftTraderAccepted.set(false);\r\n this.rightTraderAccepted.set(false);\r\n if (userId === this.leftTraderUser.id) {\r\n this.leftTraderItemCurrencies.set(itemCurrencies)\r\n }\r\n if (userId === this.rightTraderUser.id) {\r\n this.rightTraderItemCurrencies.set(itemCurrencies)\r\n }\r\n }\r\n \r\n updateCurrencies(userId, inCurrencies) {\r\n if (userId === game.user.id) return;\r\n this.leftTraderAccepted.set(false);\r\n this.rightTraderAccepted.set(false);\r\n if (userId === this.leftTraderUser.id) {\r\n this.leftTraderCurrencies.set(inCurrencies)\r\n }\r\n if (userId === this.rightTraderUser.id) {\r\n this.rightTraderCurrencies.set(inCurrencies)\r\n }\r\n }\r\n \r\n updateAcceptedState(userId, state) {\r\n if (userId === game.user.id) return;\r\n if (userId === this.leftTraderUser.id) {\r\n this.leftTraderAccepted.set(state);\r\n }\r\n if (userId === this.rightTraderUser.id) {\r\n this.rightTraderAccepted.set(state);\r\n }\r\n }\r\n \r\n addItem(newItem, { quantity = false, currency = false } = {}) {\r\n \r\n const items = !currency ? get(this.leftTraderItems) : get(this.leftTraderItemCurrencies);\r\n \r\n const item = Utilities.findSimilarItem(items, newItem)\r\n \r\n const maxQuantity = game.user.isGM ? Infinity : Utilities.getItemQuantity(newItem);\r\n \r\n if (!item) {\r\n items.push({\r\n id: newItem._id,\r\n name: newItem.name,\r\n img: newItem?.img ?? \"\",\r\n currency: currency,\r\n quantity: quantity ? quantity : 1,\r\n newQuantity: quantity ? quantity : 1,\r\n maxQuantity: maxQuantity,\r\n data: newItem\r\n })\r\n } else {\r\n if (item.quantity >= maxQuantity) return;\r\n item.quantity = Math.min(quantity ? quantity : item.quantity + 1, maxQuantity);\r\n item.newQuantity = item.quantity;\r\n item.maxQuantity = maxQuantity;\r\n }\r\n \r\n if (!currency) {\r\n this.leftTraderItems.set(items);\r\n } else {\r\n this.leftTraderItemCurrencies.set(items);\r\n }\r\n \r\n }\r\n \r\n addAttribute(newCurrency) {\r\n \r\n const currencies = get(this.leftTraderCurrencies);\r\n \r\n const existingCurrency = currencies.find(currency => currency.path === newCurrency.path);\r\n \r\n if (existingCurrency) {\r\n existingCurrency.quantity = newCurrency.quantity;\r\n existingCurrency.newQuantity = newCurrency.quantity;\r\n } else {\r\n currencies.push(newCurrency);\r\n }\r\n \r\n currencies.sort((a, b) => a.index - b.index);\r\n \r\n this.leftTraderCurrencies.set(currencies);\r\n \r\n }\r\n \r\n removeEntry(entry) {\r\n \r\n if (entry.id) {\r\n \r\n if (!entry.currency) {\r\n \r\n const items = get(this.leftTraderItems)\r\n .filter(item => item.id !== entry.id);\r\n \r\n this.leftTraderItems.set(items);\r\n \r\n } else {\r\n \r\n const items = get(this.leftTraderItemCurrencies)\r\n .filter(item => item.id !== entry.id);\r\n \r\n this.leftTraderItemCurrencies.set(items);\r\n \r\n }\r\n \r\n } else {\r\n \r\n const items = get(this.leftTraderCurrencies)\r\n .filter(currency => currency.path !== entry.path);\r\n \r\n this.leftTraderCurrencies.set(items);\r\n \r\n }\r\n \r\n }\r\n \r\n}","\r\n\r\n\r\n\r\n {#if editable}\r\n
\r\n {/if}\r\n\r\n
\r\n
\r\n
\r\n\r\n
\r\n\r\n
\r\n {#if data.editing}\r\n
\r\n \r\n \r\n {/if}\r\n
\r\n\r\n
\r\n {#if editable}\r\n
\r\n {#if data.editing}\r\n
\r\n \r\n
\r\n {:else}\r\n
{ data.editing = true } }\">\r\n {data.quantity}\r\n \r\n {/if}\r\n
\r\n {:else}\r\n
{data.quantity} \r\n {/if}\r\n
\r\n
","\r\n\r\n\r\n\r\n\r\n\r\n {#if $leftTraderAccepted && $rightTraderAccepted}\r\n \r\n {/if}\r\n\r\n \r\n\r\n \r\n\r\n
\r\n\r\n
\r\n\r\n \r\n\r\n
\r\n\r\n
\r\n\r\n {#if !$leftItems.length}\r\n
\r\n
{localize(\"ITEM-PILES.Trade.DragDrop\")} \r\n \r\n {/if}\r\n\r\n {#each $leftItems as item (item.id)}\r\n
\r\n {/each}\r\n\r\n \r\n\r\n {#if systemHasCurrencies}\r\n\r\n
\r\n\r\n {#if !spectator}\r\n
\r\n {/if}\r\n\r\n {#each $leftCurrencies as currency (currency.path)}\r\n
\r\n {/each}\r\n\r\n {#each $leftItemCurrencies as item (item.path)}\r\n \r\n {/each}\r\n\r\n \r\n\r\n {/if}\r\n\r\n
\r\n\r\n
{ store.toggleAccepted(store.leftTraderUser.id) }}>\r\n {#if $leftTraderAccepted}\r\n \r\n {localize(\"Cancel\")}\r\n {:else}\r\n \r\n {localize(\"ITEM-PILES.Trade.Accept\")}\r\n {/if}\r\n \r\n\r\n
\r\n\r\n
\r\n\r\n \r\n\r\n
\r\n\r\n
\r\n\r\n {#each $rightItems as item (item.id)}\r\n \r\n {/each}\r\n\r\n
\r\n\r\n {#if systemHasCurrencies}\r\n\r\n
\r\n\r\n {#if $rightCurrencies.length }\r\n
\r\n {/if}\r\n\r\n {#each $rightCurrencies as currency (currency.path)}\r\n
\r\n {/each}\r\n\r\n {#each $rightItemCurrencies as item (item.path)}\r\n \r\n {/each}\r\n\r\n \r\n\r\n {/if}\r\n\r\n
\r\n\r\n
\r\n
\r\n\r\n
\r\n\r\n \r\n\r\n \r\n\r\n\r\n","import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\nimport TradingAppShell from \"./trading-app-shell.svelte\";\r\nimport ItemPileSocket from \"../../socket.js\";\r\n\r\nexport default class TradingApp extends SvelteApplication {\r\n constructor(store, options = {}, dialogData = {}) {\r\n super({\r\n title: game.i18n.format(\"ITEM-PILES.Trade.Between\", {\r\n actor_1: store.leftTraderActor.name,\r\n actor_2: store.rightTraderActor.name\r\n }),\r\n svelte: {\r\n class: TradingAppShell,\r\n target: document.body,\r\n props: {\r\n store\r\n }\r\n },\r\n ...options\r\n }, dialogData);\r\n \r\n this.publicTradeId = store.publicTradeId;\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n zIndex: 100,\r\n classes: [\"dialog\", \"item-piles-trading-sheet\"],\r\n width: 800,\r\n height: \"auto\",\r\n closeOnSubmit: false\r\n });\r\n }\r\n \r\n async close(options = {}) {\r\n if (!options?.callback) {\r\n await ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.TRADE_CLOSED, this.publicTradeId, game.user.id);\r\n }\r\n return super.close(options)\r\n }\r\n \r\n static getActiveApp(publicTradeId) {\r\n for (const app of Object.values(ui.windows)) {\r\n if (app instanceof this && app?.publicTradeId === publicTradeId) {\r\n return app;\r\n }\r\n }\r\n return false;\r\n }\r\n}","import { TJSDialog } from \"@typhonjs-fvtt/runtime/svelte/application\";\r\nimport CustomDialog from \"../applications/components/CustomDialog.svelte\";\r\nimport { TradePromptDialog, TradeRequestDialog } from \"../applications/trade-dialogs/trade-dialogs.js\";\r\n\r\nimport ItemPileSocket from \"../socket.js\";\r\nimport * as Helpers from \"../helpers/helpers.js\";\r\nimport * as Utilities from \"../helpers/utilities.js\";\r\nimport HOOKS from \"../constants/hooks.js\";\r\nimport TradeStore from \"../applications/trading-app/trade-store.js\";\r\nimport TradingApp from \"../applications/trading-app/trading-app.js\";\r\nimport PrivateAPI from \"./private-api.js\";\r\nimport Transaction from \"../helpers/transaction.js\";\r\nimport { isGMConnected } from \"../helpers/helpers.js\";\r\n\r\nconst mutedUsers = new Set();\r\nconst ongoingTrades = new Map();\r\n\r\nexport default class TradeAPI {\r\n \r\n static initialize() {\r\n Hooks.on(\"renderPlayerList\", this._userDisconnected.bind(this));\r\n }\r\n \r\n static async _requestTrade(user = false) {\r\n \r\n // Grab all the active users (not self)\r\n const users = game.users.filter(user => user.active && user !== game.user);\r\n \r\n // No users!\r\n if (!users.length) {\r\n return TJSDialog.prompt({\r\n title: game.i18n.localize(\"ITEM-PILES.Trade.Title\"), content: {\r\n class: CustomDialog, props: {\r\n header: game.i18n.localize(\"ITEM-PILES.Trade.NoActiveUsers.Title\"),\r\n content: game.i18n.localize(\"ITEM-PILES.Trade.NoActiveUsers.Content\"),\r\n icon: \"fas fa-heart-broken\"\r\n }\r\n }, modal: true, draggable: false, options: {\r\n height: \"auto\"\r\n }\r\n });\r\n }\r\n \r\n let userId;\r\n let actor;\r\n let isPrivate;\r\n \r\n // Find actors you own\r\n const actors = game.actors.filter(actor => actor.isOwner);\r\n \r\n // If you only own one actor, and the user was already preselected (through the right click menu in the actors list)\r\n if (actors.length === 1 && user) {\r\n userId = user.id;\r\n actor = actors[0];\r\n isPrivate = false;\r\n } else {\r\n // If you have more than 1 owned actor, prompt to choose which one\r\n const result = await TradePromptDialog.show({ actors, users, user });\r\n if (!result) return;\r\n userId = result.user.id;\r\n actor = result.actor;\r\n isPrivate = result.private;\r\n }\r\n \r\n if (!actor) return false;\r\n \r\n actor = actor?.actor ?? actor;\r\n \r\n const actorOwner = game.users.find(user => user.character === actor && user !== game.user);\r\n if (actorOwner) {\r\n \r\n const doContinue = TJSDialog.confirm({\r\n title: game.i18n.localize(\"ITEM-PILES.Trade.Title\"), content: {\r\n class: CustomDialog, props: {\r\n header: game.i18n.localize(\"ITEM-PILES.Trade.Title\"),\r\n content: actorOwner.active ? game.i18n.format(\"ITEM-PILES.Trade.UserActiveCharacterWarning\", {\r\n actor_name: actor.name, player_name: actorOwner.name\r\n }) : game.i18n.format(\"ITEM-PILES.Trade.UserCharacterWarning\", {\r\n actor_name: actor.name, player_name: actorOwner.name\r\n }),\r\n icon: \"fas fa-exclamation-triangle\",\r\n }\r\n }, modal: true, draggable: false, rejectClose: false, defaultYes: true, options: {\r\n height: \"auto\"\r\n }\r\n });\r\n if (!doContinue) {\r\n return;\r\n }\r\n }\r\n \r\n const privateTradeId = randomID();\r\n const publicTradeId = randomID();\r\n \r\n // Spawn a cancel dialog\r\n const cancelDialog = new Dialog({\r\n title: game.i18n.localize(\"ITEM-PILES.Trade.Title\"),\r\n content: `${game.i18n.format(\"ITEM-PILES.Trade.OngoingRequest.Content\", { user_name: game.users.get(userId).name })}
`,\r\n buttons: {\r\n confirm: {\r\n icon: ' ',\r\n label: game.i18n.localize(\"ITEM-PILES.Trade.OngoingRequest.Label\"),\r\n callback: () => {\r\n ItemPileSocket.executeAsUser(ItemPileSocket.HANDLERS.TRADE_REQUEST_CANCELLED, userId, game.user.id, privateTradeId);\r\n }\r\n }\r\n }\r\n }, {\r\n top: 50, width: 300\r\n }).render(true);\r\n \r\n // Send out the request\r\n return ItemPileSocket.executeAsUser(ItemPileSocket.HANDLERS.TRADE_REQUEST_PROMPT, userId, game.user.id, actor.uuid, privateTradeId, publicTradeId, isPrivate)\r\n .then(async (data) => {\r\n \r\n if (data === \"cancelled\") return;\r\n cancelDialog.close();\r\n \r\n // If they declined, show warning\r\n if (!data || !data.fullPrivateTradeId.includes(privateTradeId)) {\r\n return Helpers.custom_warning(game.i18n.localize(\"ITEM-PILES.Trade.Declined\"), true);\r\n }\r\n \r\n const traderActor = Utilities.getActor(data.actorUuid);\r\n \r\n const store = new TradeStore({\r\n user: game.user, actor\r\n }, {\r\n user: game.users.get(userId), actor: traderActor\r\n }, data.fullPublicTradeId, data.fullPrivateTradeId, isPrivate);\r\n \r\n const app = new TradingApp(store, this.getAppOptions(actor).tradeApp).render(true);\r\n \r\n ongoingTrades.set(data.fullPublicTradeId, { app, store });\r\n \r\n actor.sheet.render(true, this.getAppOptions(actor).actorSheet);\r\n \r\n if (isPrivate) {\r\n return ItemPileSocket.callHookForUsers(HOOKS.TRADE.STARTED, [game.user.id, userId], {\r\n user: game.user.id, actor: actor.uuid\r\n }, { user: userId, actor: data.actorUuid }, data.fullPublicTradeId, isPrivate);\r\n }\r\n \r\n return ItemPileSocket.callHook(HOOKS.TRADE.STARTED, {\r\n user: game.user.id, actor: actor.uuid\r\n }, { user: userId, actor: data.actorUuid }, data.fullPublicTradeId, isPrivate);\r\n \r\n }).catch((err) => {\r\n console.error(err);\r\n // If the counterparty disconnected, show that and close dialog\r\n Helpers.custom_warning(game.i18n.localize(\"ITEM-PILES.Trade.Disconnected\"), true);\r\n cancelDialog.close()\r\n });\r\n \r\n }\r\n \r\n static async _respondPrompt(tradingUserId, tradingActorUuid, privateTradeId, publicTradeId, isPrivate) {\r\n \r\n // If the user was previously muted, wait for a random amount of time and respond with false\r\n if (mutedUsers.has(tradingUserId)) {\r\n await Helpers.wait(Math.random() * 15000);\r\n return false;\r\n }\r\n \r\n // Complete the private and public trade IDs\r\n const fullPrivateTradeId = privateTradeId + randomID();\r\n const fullPublicTradeId = publicTradeId + randomID();\r\n \r\n const tradingUser = game.users.get(tradingUserId);\r\n let tradingActor = Utilities.fromUuidFast(tradingActorUuid);\r\n \r\n tradingActor = tradingActor?.actor ?? tradingActor;\r\n \r\n // Make em pick an actor (if more than one) and accept/decline/mute\r\n const result = await TradeRequestDialog.show({ tradeId: privateTradeId, tradingUser, tradingActor, isPrivate });\r\n \r\n if (!result) return false;\r\n \r\n if (result === \"cancelled\") {\r\n return \"cancelled\";\r\n }\r\n \r\n // If muted, add user to blacklist locally\r\n if (result === \"mute\") {\r\n mutedUsers.push(tradingUserId);\r\n return false;\r\n }\r\n \r\n const actor = result.actor ?? result;\r\n \r\n const store = new TradeStore({ user: game.user, actor }, {\r\n user: tradingUser, actor: tradingActor\r\n }, fullPublicTradeId, fullPrivateTradeId, isPrivate);\r\n \r\n const app = new TradingApp(store, this.getAppOptions(actor).tradeApp).render(true);\r\n \r\n ongoingTrades.set(fullPublicTradeId, { app, store });\r\n \r\n actor.sheet.render(true, this.getAppOptions(actor).actorSheet);\r\n \r\n return {\r\n fullPrivateTradeId, fullPublicTradeId, actorUuid: result.uuid\r\n };\r\n \r\n }\r\n \r\n static getAppOptions(actor) {\r\n const midPoint = (window.innerWidth / 2) - 200;\r\n return {\r\n actorSheet: { left: midPoint - actor.sheet.position.width - 25 }, tradeApp: { left: midPoint + 25 }\r\n }\r\n }\r\n \r\n static async _tradeCancelled(userId, privateTradeId) {\r\n \r\n TJSDialog.prompt({\r\n title: game.i18n.localize(\"ITEM-PILES.Trade.Title\"), content: {\r\n class: CustomDialog, props: {\r\n header: game.i18n.localize(\"ITEM-PILES.Trade.Title\"),\r\n content: game.i18n.format(\"ITEM-PILES.Trade.CancelledRequest.Content\", { user_name: game.users.get(userId).name }),\r\n icon: \"fas fa-exclamation-triangle\"\r\n }\r\n }, modal: true, draggable: false, options: {\r\n height: \"auto\"\r\n }\r\n });\r\n \r\n return TradeRequestDialog.cancel(privateTradeId);\r\n \r\n }\r\n \r\n static async _requestTradeData({ tradeId, tradeUser } = {}) {\r\n \r\n const ongoingTrade = this._getOngoingTrade(tradeId);\r\n if (ongoingTrade) {\r\n return ongoingTrade.store.export();\r\n }\r\n \r\n const user = game.users.get(tradeUser);\r\n if (!user?.active) {\r\n return false;\r\n }\r\n \r\n const ongoingTradeData = await ItemPileSocket.executeAsUser(ItemPileSocket.HANDLERS.REQUEST_TRADE_DATA, tradeUser, tradeId, game.user.id);\r\n if (!ongoingTradeData) {\r\n return false;\r\n }\r\n \r\n return ongoingTradeData;\r\n \r\n }\r\n \r\n static async _spectateTrade({ tradeId, tradeUser } = {}) {\r\n \r\n const app = TradingApp.getActiveApp(tradeId);\r\n if (app) {\r\n return app.render(false, { focus: true });\r\n }\r\n \r\n const ongoingTradeData = await this._requestTradeData({ tradeId, tradeUser });\r\n if (!ongoingTradeData) {\r\n if (Helpers.isGMConnected()) {\r\n ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);\r\n }\r\n return Helpers.custom_warning(game.i18n.localize(\"ITEM-PILES.Trade.Over\"), true);\r\n }\r\n \r\n const store = TradeStore.import(...ongoingTradeData);\r\n return new TradingApp(store).render(true);\r\n \r\n }\r\n \r\n static async _respondActiveTradeData(tradeId, requesterId) {\r\n const trade = this._getOngoingTrade(tradeId, requesterId);\r\n if (!trade) return;\r\n return trade.store.export();\r\n }\r\n \r\n static _getOngoingTrade(tradeId, requesterId = game.user.id) {\r\n if (!ongoingTrades.has(tradeId)) return false;\r\n const trade = ongoingTrades.get(tradeId);\r\n if (!trade.store.isPrivate) {\r\n return trade;\r\n }\r\n if (trade.store.leftTraderUser.id !== requesterId && trade.store.rightTraderUser.id !== requesterId) return false;\r\n return trade;\r\n }\r\n \r\n static async _updateItems(tradeId, userId, items) {\r\n const trade = this._getOngoingTrade(tradeId);\r\n if (!trade) return;\r\n trade.store.updateItems(userId, items);\r\n }\r\n \r\n static async _updateItemCurrencies(tradeId, userId, items) {\r\n const trade = this._getOngoingTrade(tradeId);\r\n if (!trade) return;\r\n trade.store.updateItemCurrencies(userId, items);\r\n }\r\n \r\n static async _updateCurrencies(tradeId, userId, currencies) {\r\n const trade = this._getOngoingTrade(tradeId);\r\n if (!trade) return;\r\n trade.store.updateCurrencies(userId, currencies);\r\n }\r\n \r\n static async _updateAcceptedState(tradeId, userId, status) {\r\n const trade = this._getOngoingTrade(tradeId);\r\n if (!trade) return;\r\n trade.store.updateAcceptedState(userId, status);\r\n if (userId === game.user.id && (trade.store.leftTraderUser.id === game.user.id || trade.store.rightTraderUser.id === game.user.id)) {\r\n if (trade.store.tradeIsAccepted) {\r\n setTimeout(async () => {\r\n if (trade.store.tradeIsAccepted) {\r\n ItemPileSocket.executeForUsers(\r\n ItemPileSocket.HANDLERS.EXECUTE_TRADE,\r\n [trade.store.leftTraderUser.id, trade.store.rightTraderUser.id],\r\n trade.store.publicTradeId,\r\n trade.store.privateTradeId,\r\n userId);\r\n }\r\n }, 2000);\r\n }\r\n }\r\n }\r\n \r\n static async _userDisconnected(app, html, data) {\r\n const tradesToDelete = [];\r\n for (let [tradeId, trade] of ongoingTrades) {\r\n const foundLeft = data.users.find(u => u === trade.store.leftTraderUser);\r\n const foundRight = data.users.find(u => u === trade.store.rightTraderUser);\r\n if (foundLeft && foundRight) continue;\r\n tradesToDelete.push(tradeId);\r\n Helpers.custom_warning(game.i18n.localize(\"ITEM-PILES.Trade.Disconnected\"), true);\r\n await trade.app.close({ callback: true });\r\n if (foundLeft === game.user || foundRight === game.user) {\r\n if (Helpers.isGMConnected()) {\r\n await ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);\r\n }\r\n }\r\n }\r\n tradesToDelete.forEach(tradeId => ongoingTrades.delete(tradeId));\r\n }\r\n \r\n static async _tradeClosed(tradeId, closeUserId) {\r\n const trade = this._getOngoingTrade(tradeId);\r\n if (!trade) return;\r\n \r\n if (trade.store.leftTraderUser.id === game.user.id || trade.store.rightTraderUser.id === game.user.id) {\r\n \r\n if (closeUserId === trade.store.rightTraderUser.id) {\r\n \r\n TJSDialog.prompt({\r\n title: game.i18n.localize(\"ITEM-PILES.Trade.Closed.Title\"), content: {\r\n class: CustomDialog, props: {\r\n header: game.i18n.localize(\"ITEM-PILES.Trade.Closed.Title\"),\r\n content: game.i18n.format(\"ITEM-PILES.Trade.Closed.Them\", {\r\n user_name: trade.store.rightTraderUser.name\r\n }),\r\n icon: \"fas fa-exclamation-triangle\",\r\n }\r\n }, modal: false, draggable: true, options: {\r\n height: \"auto\"\r\n }\r\n });\r\n \r\n } else {\r\n \r\n if (trade.store.isPrivate) {\r\n const otherUserId = trade.store.leftTraderUser.id === game.user.id ? trade.store.rightTraderUser.id : trade.store.leftTraderUser.id;\r\n ItemPileSocket.executeAsUser(ItemPileSocket.HANDLERS.TRADE_CLOSED, otherUserId, tradeId, game.user.id);\r\n } else {\r\n ItemPileSocket.executeForOthers(ItemPileSocket.HANDLERS.TRADE_CLOSED, tradeId, game.user.id);\r\n }\r\n \r\n TJSDialog.prompt({\r\n title: game.i18n.localize(\"ITEM-PILES.Trade.Closed.Title\"), content: {\r\n class: CustomDialog, props: {\r\n header: game.i18n.localize(\"ITEM-PILES.Trade.Closed.Title\"),\r\n content: game.i18n.format(\"ITEM-PILES.Trade.Closed.You\"),\r\n icon: \"fas fa-exclamation-triangle\",\r\n }\r\n }, modal: false, draggable: true, options: {\r\n height: \"auto\"\r\n }\r\n });\r\n \r\n if (Helpers.isGMConnected()) {\r\n await ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);\r\n }\r\n }\r\n \r\n } else {\r\n \r\n Helpers.custom_warning(game.i18n.localize(\"ITEM-PILES.Trade.Closed.Someone\"), true);\r\n \r\n }\r\n \r\n trade.app.close({ callback: true });\r\n ongoingTrades.delete(tradeId);\r\n }\r\n \r\n static async _executeTrade(tradeId, privateId, userId) {\r\n const trade = this._getOngoingTrade(tradeId);\r\n if (!trade) return;\r\n if (trade.store.privateTradeId !== privateId) return;\r\n const updates = trade.store.getTradeData();\r\n \r\n const itemsToAdd = updates.add.items.map(entry => {\r\n const itemData = updates.targetActor.items.get(entry.id).toObject();\r\n return Utilities.setItemQuantity(itemData, entry.quantity);\r\n });\r\n \r\n const itemsToRemove = updates.remove.items.map(entry => {\r\n const itemData = updates.sourceActor.items.get(entry.id).toObject();\r\n return Utilities.setItemQuantity(itemData, entry.quantity);\r\n });\r\n \r\n const transaction = new Transaction(updates.sourceActor);\r\n transaction.appendItemChanges(itemsToAdd);\r\n transaction.appendItemChanges(itemsToRemove, { remove: true });\r\n transaction.appendActorChanges(updates.add.attributes);\r\n transaction.appendActorChanges(updates.remove.attributes, { remove: true });\r\n await transaction.commit();\r\n \r\n if (trade.store.isPrivate) {\r\n trade.app.close({ callback: true });\r\n ongoingTrades.delete(tradeId);\r\n } else if (userId === game.user.id) {\r\n if (Helpers.isGMConnected()) {\r\n await ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);\r\n }\r\n return ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.TRADE_COMPLETED, tradeId, updates);\r\n }\r\n }\r\n \r\n static async _tradeCompleted(tradeId, updates) {\r\n const trade = this._getOngoingTrade(tradeId);\r\n if (!trade) return;\r\n Helpers.hooks.callAll(HOOKS.TRADE.COMPLETE, updates, tradeId)\r\n trade.app.close({ callback: true });\r\n ongoingTrades.delete(tradeId);\r\n }\r\n \r\n}\r\n\r\n","import SETTINGS from \"../constants/settings.js\";\r\nimport * as Helpers from \"../helpers/helpers.js\";\r\nimport CONSTANTS from \"../constants/constants.js\";\r\nimport HOOKS from \"../constants/hooks.js\";\r\nimport ItemPileSocket from \"../socket.js\";\r\nimport * as PileUtilities from \"../helpers/pile-utilities.js\";\r\nimport * as Utilities from \"../helpers/utilities.js\";\r\nimport TradeAPI from \"./trade-api.js\";\r\n\r\nexport default class ChatAPI {\r\n \r\n static initialize() {\r\n \r\n Hooks.on(\"preCreateChatMessage\", this._preCreateChatMessage.bind(this));\r\n Hooks.on(\"renderChatMessage\", this._renderChatMessage.bind(this));\r\n Hooks.on(HOOKS.ITEM.TRANSFER, this._outputTransferItem.bind(this));\r\n Hooks.on(HOOKS.ATTRIBUTE.TRANSFER, this._outputTransferCurrency.bind(this));\r\n Hooks.on(HOOKS.TRANSFER_EVERYTHING, this._outputTransferEverything.bind(this));\r\n Hooks.on(HOOKS.PILE.SPLIT_INVENTORY, this._outputSplitItemPileInventory.bind(this));\r\n Hooks.on(HOOKS.TRADE.STARTED, this._outputTradeStarted.bind(this));\r\n Hooks.on(HOOKS.TRADE.COMPLETE, this._outputTradeComplete.bind(this));\r\n \r\n $(document).on(\"click\", \".item-piles-chat-card .item-piles-collapsible\", async function () {\r\n if ($(this).attr(\"open\")) return;\r\n await Helpers.wait(25);\r\n $(this).parent()[0].scrollIntoView({ behavior: 'smooth', block: 'nearest', inline: 'start' });\r\n });\r\n }\r\n \r\n static _preCreateChatMessage(chatMessage) {\r\n \r\n if (!Helpers.getSetting(SETTINGS.ENABLE_TRADING)) return;\r\n \r\n const content = chatMessage.data.content.toLowerCase();\r\n \r\n if (!(content.startsWith(\"!itempiles\") || content.startsWith(\"!ip\"))) return;\r\n \r\n const args = content.split(\" \").slice(1);\r\n \r\n if (args[0] === \"trade\") {\r\n setTimeout(() => {\r\n game.itempiles.requestTrade();\r\n });\r\n }\r\n \r\n return false;\r\n \r\n }\r\n \r\n static _renderChatMessage(app, html) {\r\n html.find(\".item-piles-specate-trade\").click(function () {\r\n game.itempiles.spectateTrade($(this).data());\r\n });\r\n }\r\n \r\n static _disableTradingButton(publicTradeId) {\r\n const message = Array.from(game.messages).find(message => {\r\n return getProperty(message.data, CONSTANTS.FLAGS.PUBLIC_TRADE_ID) === publicTradeId;\r\n });\r\n if (!message) return;\r\n const update = this._replaceChatContent(message);\r\n return message.update(update)\r\n }\r\n \r\n static async disablePastTradingButtons() {\r\n if (!game.user.isGM) return;\r\n \r\n const messages = Array.from(game.messages).filter(message => {\r\n return getProperty(message.data, CONSTANTS.FLAGS.PUBLIC_TRADE_ID);\r\n });\r\n \r\n if (!messages.length) return;\r\n const updates = [];\r\n for (let message of messages) {\r\n const update = this._replaceChatContent(message);\r\n const tradeId = getProperty(message.data, CONSTANTS.FLAGS.PUBLIC_TRADE_ID);\r\n const tradeUsers = getProperty(message.data, CONSTANTS.FLAGS.TRADE_USERS);\r\n const bothUsersActive = tradeUsers.filter(userId => game.users.get(userId).active).length === tradeUsers.length;\r\n if (!bothUsersActive) {\r\n updates.push(update);\r\n } else {\r\n const otherUsers = tradeUsers.filter(userId => userId !== game.user.id);\r\n const tradeData = await TradeAPI._requestTradeData({ tradeId, tradeUser: otherUsers[0] });\r\n if (!tradeData) {\r\n updates.push(update);\r\n }\r\n }\r\n }\r\n \r\n if (!updates.length) return;\r\n \r\n return ChatMessage.updateDocuments(updates);\r\n \r\n }\r\n \r\n static _replaceChatContent(message) {\r\n const tradeId = getProperty(message.data, CONSTANTS.FLAGS.PUBLIC_TRADE_ID);\r\n const stringToFind = `data-trade-id=\"${tradeId}\"`;\r\n let content = message.data.content;\r\n content = content.replace(stringToFind, \"\");\r\n content = content.replace(stringToFind, \"disabled\");\r\n content = content.replace(game.i18n.localize(\"ITEM-PILES.Chat.TradeSpectate\"), game.i18n.localize(\"ITEM-PILES.Chat.SpectateDisabled\"));\r\n return {\r\n _id: message.id,\r\n content,\r\n [`flags.-=${CONSTANTS.MODULE_NAME}`]: null\r\n };\r\n }\r\n \r\n \r\n /**\r\n * Outputs to chat based on transferring an item from or to an item pile\r\n *\r\n * @param source\r\n * @param target\r\n * @param items\r\n * @param userId\r\n * @param interactionId\r\n * @returns {Promise}\r\n */\r\n static async _outputTransferItem(source, target, items, userId, interactionId) {\r\n if (!PileUtilities.isValidItemPile(source)) return;\r\n if (!interactionId || game.user.id !== userId || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;\r\n const itemData = await this._formatItemData(items);\r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.PICKUP_CHAT_MESSAGE, source.uuid, target.uuid, itemData, [], userId, interactionId);\r\n }\r\n \r\n /**\r\n * Outputs to chat based on transferring a currency from or to an item pile\r\n *\r\n * @param source\r\n * @param target\r\n * @param currencies\r\n * @param userId\r\n * @param interactionId\r\n * @returns {Promise}\r\n */\r\n static async _outputTransferCurrency(source, target, currencies, userId, interactionId) {\r\n if (!PileUtilities.isValidItemPile(source)) return;\r\n if (!interactionId || game.user.id !== userId || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;\r\n const currencyData = this._formatCurrencyData(source, currencies);\r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.PICKUP_CHAT_MESSAGE, source.uuid, target.uuid, [], currencyData, userId, interactionId);\r\n }\r\n \r\n /**\r\n * Outputs to chat based on transferring everything from or to an item pile\r\n *\r\n * @param source\r\n * @param target\r\n * @param items\r\n * @param currencies\r\n * @param userId\r\n * @param interactionId\r\n * @returns {Promise}\r\n */\r\n static async _outputTransferEverything(source, target, items, currencies, userId, interactionId) {\r\n if (!PileUtilities.isValidItemPile(source)) return;\r\n if (!interactionId || game.user.id !== userId || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;\r\n const itemData = await this._formatItemData(items);\r\n const currencyData = this._formatCurrencyData(source, currencies);\r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.PICKUP_CHAT_MESSAGE, source.uuid, target.uuid, itemData, currencyData, userId, interactionId);\r\n }\r\n \r\n static _outputSplitItemPileInventory(source, transferData, userId) {\r\n if (!PileUtilities.isValidItemPile(source)) return;\r\n if (game.user.id !== userId || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;\r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.SPLIT_CHAT_MESSAGE, source.uuid, transferData, userId);\r\n }\r\n \r\n static async _outputTradeStarted(party_1, party_2, publicTradeId, isPrivate) {\r\n if (party_1.user !== game.user.id || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT) || isPrivate) return;\r\n return this._outputTradeStartedToChat(party_1, party_2, publicTradeId);\r\n }\r\n \r\n static async _outputTradeComplete(party_1, party_2, publicTradeId, isPrivate) {\r\n if (!Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;\r\n return this._outputTradeCompleteToChat(party_1, party_2, publicTradeId, isPrivate);\r\n }\r\n \r\n /**\r\n * Formats item data to a chat friendly structure\r\n *\r\n * @param items\r\n * @returns {Promise}\r\n */\r\n static async _formatItemData(items) {\r\n const formattedItems = [];\r\n for (const itemData of items) {\r\n const tempItem = await Item.implementation.create(itemData.item, { temporary: true });\r\n formattedItems.push({\r\n name: game.i18n.localize(tempItem.name),\r\n img: itemData.item.img ?? \"\",\r\n quantity: itemData.quantity\r\n });\r\n }\r\n return formattedItems;\r\n }\r\n \r\n /**\r\n * Formats currency data to a chat friendly structure\r\n *\r\n * @param itemPile\r\n * @param currencies\r\n * @returns {Array}\r\n */\r\n static _formatCurrencyData(itemPile, currencies) {\r\n const currencyList = PileUtilities.getActorCurrencies(itemPile);\r\n return Object.entries(currencies).map(entry => {\r\n const currency = currencyList.find(currency => currency.id === entry[0]);\r\n return {\r\n name: currency.name,\r\n img: currency.img ?? \"\",\r\n quantity: entry[1],\r\n index: currencyList.indexOf(currency)\r\n }\r\n });\r\n }\r\n \r\n /**\r\n * Outputs the transferred data in chat\r\n *\r\n * @param sourceUuid\r\n * @param targetUuid\r\n * @param items\r\n * @param currencies\r\n * @param userId\r\n * @param interactionId\r\n * @returns {Promise}\r\n */\r\n static async _outputPickupToChat(sourceUuid, targetUuid, items, currencies, userId, interactionId) {\r\n \r\n const sourceActor = Utilities.getActor(sourceUuid);\r\n const targetActor = Utilities.getActor(targetUuid);\r\n \r\n const now = (+new Date());\r\n \r\n // Get all messages younger than 3 hours, and grab the last 10, then reverse them (latest to oldest)\r\n const messages = Array.from(game.messages).filter(message => (now - message.data.timestamp) <= (10800000)).slice(-10);\r\n messages.reverse()\r\n \r\n for (let [index, message] of messages.entries()) {\r\n const flags = getProperty(message.data, CONSTANTS.FLAGS.PILE);\r\n if (flags && flags.source === sourceUuid && flags.target === targetUuid && (flags.interactionId === interactionId || index === 0)) {\r\n return this._updateExistingPickupMessage(message, sourceActor, targetActor, items, currencies, interactionId)\r\n }\r\n }\r\n \r\n const chatCardHtml = await renderTemplate(CONSTANTS.PATH + \"templates/chat/looted.html\", {\r\n message: game.i18n.format(\"ITEM-PILES.Chat.Pickup\", { name: targetActor.name }),\r\n itemPile: sourceActor,\r\n actor: targetActor,\r\n items: items,\r\n currencies: currencies\r\n });\r\n \r\n return this._createNewChatMessage(userId, {\r\n user: game.user.id,\r\n type: CONST.CHAT_MESSAGE_TYPES.OTHER,\r\n content: chatCardHtml,\r\n flavor: \"Item Piles\",\r\n speaker: ChatMessage.getSpeaker({ alias: game.user.name }),\r\n [CONSTANTS.FLAGS.PILE]: {\r\n source: sourceUuid,\r\n target: targetUuid,\r\n items: items,\r\n currencies: currencies,\r\n interactionId: interactionId\r\n }\r\n })\r\n \r\n }\r\n \r\n static _matchEntries(existingEntries, incomingEntries) {\r\n \r\n const combinedEntries = existingEntries.map(existingEntry => {\r\n const foundEntry = incomingEntries.find(item => item.name === existingEntry.name && existingEntry.img === item.img);\r\n if (foundEntry) {\r\n existingEntry.quantity += foundEntry.quantity;\r\n incomingEntries.splice(incomingEntries.indexOf(foundEntry), 1)\r\n }\r\n return existingEntry;\r\n });\r\n \r\n incomingEntries.forEach(item => combinedEntries.push(item));\r\n \r\n return combinedEntries;\r\n \r\n }\r\n \r\n static async _updateExistingPickupMessage(message, sourceActor, targetActor, items, currencies, interactionId) {\r\n \r\n const flags = getProperty(message.data, CONSTANTS.FLAGS.PILE);\r\n \r\n const newItems = this._matchEntries(flags.items, items);\r\n const newCurrencies = this._matchEntries(flags.currencies, currencies);\r\n \r\n newCurrencies.sort((a, b) => {\r\n return a.index - b.index;\r\n })\r\n \r\n const chatCardHtml = await renderTemplate(CONSTANTS.PATH + \"templates/chat/looted.html\", {\r\n message: game.i18n.format(\"ITEM-PILES.Chat.Pickup\", { name: targetActor.name }),\r\n itemPile: sourceActor,\r\n actor: targetActor,\r\n items: newItems,\r\n currencies: newCurrencies\r\n });\r\n \r\n return message.update({\r\n content: chatCardHtml,\r\n [`${CONSTANTS.FLAGS.PILE}.interactionId`]: interactionId,\r\n [`${CONSTANTS.FLAGS.PILE}.items`]: newItems,\r\n [`${CONSTANTS.FLAGS.PILE}.currencies`]: newCurrencies,\r\n });\r\n \r\n }\r\n \r\n static async _outputSplitToChat(sourceUuid, transferData, userId) {\r\n \r\n const source = await fromUuid(sourceUuid);\r\n \r\n const sourceActor = source?.actor ?? source;\r\n \r\n const chatCardHtml = await renderTemplate(CONSTANTS.PATH + \"templates/chat/looted.html\", {\r\n message: game.i18n.format(\"ITEM-PILES.Chat.Split\", { num_players: transferData.num_players }),\r\n itemPile: sourceActor,\r\n items: transferData.items,\r\n currencies: transferData.currencies\r\n });\r\n \r\n return this._createNewChatMessage(userId, {\r\n user: game.user.id,\r\n type: CONST.CHAT_MESSAGE_TYPES.OTHER,\r\n content: chatCardHtml,\r\n flavor: \"Item Piles\",\r\n speaker: ChatMessage.getSpeaker({ alias: game.user.name })\r\n });\r\n \r\n }\r\n \r\n static async _outputTradeStartedToChat(party_1, party_2, publicTradeId) {\r\n \r\n const party_1_actor = Utilities.getActor(party_1.actor);\r\n const party_2_actor = Utilities.getActor(party_2.actor);\r\n \r\n const chatCardHtml = await renderTemplate(CONSTANTS.PATH + \"templates/chat/trade-started.html\", {\r\n party_1_actor,\r\n party_2_actor,\r\n publicTradeId,\r\n userId: game.user.id\r\n });\r\n \r\n return this._createNewChatMessage(game.user.id, {\r\n user: game.user.id,\r\n type: CONST.CHAT_MESSAGE_TYPES.OTHER,\r\n content: chatCardHtml,\r\n flavor: \"Item Piles\",\r\n speaker: ChatMessage.getSpeaker({ alias: game.user.name }),\r\n [CONSTANTS.FLAGS.PUBLIC_TRADE_ID]: publicTradeId,\r\n [CONSTANTS.FLAGS.TRADE_USERS]: [party_1.user, party_2.user]\r\n });\r\n }\r\n \r\n static async _outputTradeCompleteToChat(party_1, party_2, publicTradeId, isPrivate) {\r\n \r\n if (party_1.user !== game.user.id) return;\r\n \r\n let party_1_actor = await fromUuid(party_1.actor);\r\n party_1_actor = party_1_actor?.actor ?? party_1_actor;\r\n const party_1_data = {\r\n actor: party_1_actor,\r\n items: party_2.items,\r\n currencies: party_2.currencies\r\n }\r\n party_1_data.got_nothing = !party_1_data.items.length && !party_1_data.currencies.length;\r\n \r\n let party_2_actor = await fromUuid(party_2.actor);\r\n party_2_actor = party_2_actor?.actor ?? party_2_actor;\r\n const party_2_data = {\r\n actor: party_2_actor,\r\n items: party_1.items,\r\n currencies: party_1.currencies\r\n }\r\n party_2_data.got_nothing = !party_2_data.items.length && !party_2_data.currencies.length;\r\n \r\n if (party_1.got_nothing && party_2.got_nothing) return;\r\n \r\n const enableCollapse = (party_1_data.items.length + party_1_data.currencies.length + party_2_data.items.length + party_2_data.currencies.length) > 6;\r\n \r\n const chatCardHtml = await renderTemplate(CONSTANTS.PATH + \"templates/chat/trade-complete.html\", {\r\n party_1: party_1_data,\r\n party_2: party_2_data,\r\n publicTradeId,\r\n isPrivate,\r\n enableCollapse\r\n });\r\n \r\n return this._createNewChatMessage(game.user.id, {\r\n user: game.user.id,\r\n type: isPrivate ? CONST.CHAT_MESSAGE_TYPES.WHISPER : CONST.CHAT_MESSAGE_TYPES.OTHER,\r\n content: chatCardHtml,\r\n flavor: \"Item Piles\" + (isPrivate ? \": \" + game.i18n.localize(\"ITEM-PILES.Chat.PrivateTrade\") : \"\"),\r\n speaker: ChatMessage.getSpeaker({ alias: game.user.name }),\r\n whisper: isPrivate ? [party_2.user] : []\r\n });\r\n \r\n }\r\n \r\n static _createNewChatMessage(userId, chatData) {\r\n \r\n if (!chatData.whisper) {\r\n \r\n const mode = Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT);\r\n \r\n if (mode > 1) {\r\n chatData.whisper = Array.from(game.users)\r\n .filter(user => user.isGM)\r\n .map(user => user.id);\r\n if (mode === 2) {\r\n chatData.whisper.push(userId);\r\n }\r\n chatData.type = CONST.CHAT_MESSAGE_TYPES.WHISPER;\r\n }\r\n \r\n }\r\n \r\n return ChatMessage.create(chatData);\r\n \r\n }\r\n \r\n}","import CONSTANTS from \"./constants/constants.js\";\r\nimport { debug } from \"./helpers/helpers.js\";\r\nimport { fromUuidFast, stringIsUuid } from \"./helpers/utilities.js\";\r\nimport PrivateAPI from \"./API/private-api.js\";\r\nimport TradeAPI from \"./API/trade-api.js\";\r\nimport ChatAPI from \"./API/chat-api.js\";\r\nimport * as Helpers from \"./helpers/helpers.js\";\r\nimport HOOKS from \"./constants/hooks.js\";\r\n\r\nexport default class ItemPileSocket {\r\n \r\n static HANDLERS = {\r\n /**\r\n * Generic sockets\r\n */\r\n CALL_HOOK: \"callHook\",\r\n \r\n /**\r\n * Chat messages\r\n */\r\n PICKUP_CHAT_MESSAGE: \"pickupChatMessage\",\r\n SPLIT_CHAT_MESSAGE: \"splitChatMessage\",\r\n DISABLE_CHAT_TRADE_BUTTON: \"disableChatTradeButton\",\r\n \r\n /**\r\n * Item pile sockets\r\n */\r\n CREATE_PILE: \"createItemPile\",\r\n UPDATE_PILE: \"updateItemPile\",\r\n UPDATED_PILE: \"updatedPile\",\r\n DELETE_PILE: \"deleteItemPile\",\r\n TURN_INTO_PILE: \"turnIntoPiles\",\r\n REVERT_FROM_PILE: \"revertFromPiles\",\r\n REFRESH_PILE: \"refreshItemPile\",\r\n SPLIT_PILE: \"splitItemPileContent\",\r\n \r\n /**\r\n * UI sockets\r\n */\r\n RENDER_INTERFACE: \"renderItemPileApplication\",\r\n RERENDER_TOKEN_HUD: \"rerenderTokenHud\",\r\n USER_OPENED_INTERFACE: \"userOpenedInterface\",\r\n USER_CLOSED_INTERFACE: \"userClosedInterface\",\r\n \r\n /**\r\n * Item & attribute sockets\r\n */\r\n DROP_ITEMS: \"dropItems\",\r\n ADD_ITEMS: \"addItems\",\r\n REMOVE_ITEMS: \"removeItems\",\r\n TRANSFER_ITEMS: \"transferItems\",\r\n TRANSFER_ALL_ITEMS: \"transferAllItems\",\r\n ADD_ATTRIBUTE: \"addAttributes\",\r\n REMOVE_ATTRIBUTES: \"removeAttributes\",\r\n TRANSFER_ATTRIBUTES: \"transferAttributes\",\r\n TRANSFER_ALL_ATTRIBUTES: \"transferAllAttributes\",\r\n TRANSFER_EVERYTHING: \"transferEverything\",\r\n COMMIT_ACTOR_CHANGES: \"commitActorChanges\",\r\n \r\n /**\r\n * Trading sockets\r\n */\r\n TRADE_REQUEST_PROMPT: \"tradePrompt\",\r\n TRADE_REQUEST_CANCELLED: \"tradeCancelled\",\r\n REQUEST_TRADE_DATA: \"requestTradeData\",\r\n TRADE_CLOSED: \"publicTradeClosed\",\r\n PUBLIC_TRADE_UPDATE_ITEMS: \"publicTradeUpdateItems\",\r\n PUBLIC_TRADE_UPDATE_ITEM_CURRENCIES: \"publicTradeUpdateItemCurrencies\",\r\n PUBLIC_TRADE_UPDATE_CURRENCIES: \"publicTradeUpdateCurrencies\",\r\n PUBLIC_TRADE_STATE: \"publicTradeAcceptedState\",\r\n PRIVATE_TRADE_UPDATE_ITEMS: \"privateTradeUpdateItems\",\r\n PRIVATE_TRADE_UPDATE_ITEM_CURRENCIES: \"privateTradeUpdateItemCurrencies\",\r\n PRIVATE_TRADE_UPDATE_CURRENCIES: \"privateTradeUpdateCurrencies\",\r\n PRIVATE_TRADE_STATE: \"privateTradeAcceptedState\",\r\n EXECUTE_TRADE: \"executeTrade\",\r\n TRADE_COMPLETED: \"tradeCompleted\",\r\n \r\n /**\r\n * Merchant sockets\r\n */\r\n TRADE_ITEMS: \"tradeItems\"\r\n }\r\n \r\n static BINDINGS = {\r\n [this.HANDLERS.CALL_HOOK]: (hook, response, ...args) => callHook(hook, response, ...args),\r\n \r\n [this.HANDLERS.DROP_ITEMS]: (args) => PrivateAPI._dropItems(args),\r\n [this.HANDLERS.ADD_ITEMS]: (...args) => PrivateAPI._addItems(...args),\r\n [this.HANDLERS.REMOVE_ITEMS]: (...args) => PrivateAPI._removeItems(...args),\r\n [this.HANDLERS.TRANSFER_ITEMS]: (...args) => PrivateAPI._transferItems(...args),\r\n [this.HANDLERS.TRANSFER_ALL_ITEMS]: (...args) => PrivateAPI._transferAllItems(...args),\r\n [this.HANDLERS.ADD_ATTRIBUTE]: (...args) => PrivateAPI._addAttributes(...args),\r\n [this.HANDLERS.REMOVE_ATTRIBUTES]: (...args) => PrivateAPI._removeAttributes(...args),\r\n [this.HANDLERS.TRANSFER_ATTRIBUTES]: (...args) => PrivateAPI._transferAttributes(...args),\r\n [this.HANDLERS.TRANSFER_ALL_ATTRIBUTES]: (...args) => PrivateAPI._transferAllAttributes(...args),\r\n [this.HANDLERS.TRANSFER_EVERYTHING]: (...args) => PrivateAPI._transferEverything(...args),\r\n [this.HANDLERS.COMMIT_ACTOR_CHANGES]: (...args) => PrivateAPI._commitActorChanges(...args),\r\n \r\n [this.HANDLERS.CREATE_PILE]: (...args) => PrivateAPI._createItemPile(...args),\r\n [this.HANDLERS.UPDATE_PILE]: (...args) => PrivateAPI._updateItemPile(...args),\r\n [this.HANDLERS.UPDATED_PILE]: (...args) => PrivateAPI._updatedItemPile(...args),\r\n [this.HANDLERS.DELETE_PILE]: (...args) => PrivateAPI._deleteItemPile(...args),\r\n [this.HANDLERS.TURN_INTO_PILE]: (...args) => PrivateAPI._turnTokensIntoItemPiles(...args),\r\n [this.HANDLERS.REVERT_FROM_PILE]: (...args) => PrivateAPI._revertTokensFromItemPiles(...args),\r\n [this.HANDLERS.SPLIT_PILE]: (...args) => PrivateAPI._splitItemPileContents(...args),\r\n \r\n [this.HANDLERS.TRADE_REQUEST_PROMPT]: (...args) => TradeAPI._respondPrompt(...args),\r\n [this.HANDLERS.TRADE_REQUEST_CANCELLED]: (...args) => TradeAPI._tradeCancelled(...args),\r\n [this.HANDLERS.EXECUTE_TRADE]: (...args) => TradeAPI._executeTrade(...args),\r\n [this.HANDLERS.TRADE_COMPLETED]: (...args) => TradeAPI._tradeCompleted(...args),\r\n [this.HANDLERS.REQUEST_TRADE_DATA]: (...args) => TradeAPI._respondActiveTradeData(...args),\r\n [this.HANDLERS.TRADE_CLOSED]: (...args) => TradeAPI._tradeClosed(...args),\r\n \r\n [this.HANDLERS.PUBLIC_TRADE_UPDATE_ITEMS]: (...args) => TradeAPI._updateItems(...args),\r\n [this.HANDLERS.PUBLIC_TRADE_UPDATE_ITEM_CURRENCIES]: (...args) => TradeAPI._updateItemCurrencies(...args),\r\n [this.HANDLERS.PUBLIC_TRADE_UPDATE_CURRENCIES]: (...args) => TradeAPI._updateCurrencies(...args),\r\n [this.HANDLERS.PUBLIC_TRADE_STATE]: (...args) => TradeAPI._updateAcceptedState(...args),\r\n \r\n [this.HANDLERS.PRIVATE_TRADE_UPDATE_ITEMS]: (...args) => TradeAPI._updateItems(...args),\r\n [this.HANDLERS.PRIVATE_TRADE_UPDATE_ITEM_CURRENCIES]: (...args) => TradeAPI._updateItemCurrencies(...args),\r\n [this.HANDLERS.PRIVATE_TRADE_UPDATE_CURRENCIES]: (...args) => TradeAPI._updateCurrencies(...args),\r\n [this.HANDLERS.PRIVATE_TRADE_STATE]: (...args) => TradeAPI._updateAcceptedState(...args),\r\n \r\n [this.HANDLERS.PICKUP_CHAT_MESSAGE]: (...args) => ChatAPI._outputPickupToChat(...args),\r\n [this.HANDLERS.SPLIT_CHAT_MESSAGE]: (...args) => ChatAPI._outputSplitToChat(...args),\r\n [this.HANDLERS.DISABLE_CHAT_TRADE_BUTTON]: (...args) => ChatAPI._disableTradingButton(...args),\r\n \r\n [this.HANDLERS.RENDER_INTERFACE]: (...args) => PrivateAPI._renderItemPileInterface(...args),\r\n [this.HANDLERS.RERENDER_TOKEN_HUD]: (...args) => PrivateAPI._updateTokenHud(...args),\r\n [this.HANDLERS.USER_OPENED_INTERFACE]: (...args) => InterfaceTracker.userOpened(...args),\r\n [this.HANDLERS.USER_CLOSED_INTERFACE]: (...args) => InterfaceTracker.userClosed(...args),\r\n \r\n [this.HANDLERS.TRADE_ITEMS]: (...args) => PrivateAPI._tradeItems(...args),\r\n }\r\n \r\n static _socket;\r\n \r\n static initialize() {\r\n InterfaceTracker.initialize();\r\n this._socket = socketlib.registerModule(CONSTANTS.MODULE_NAME);\r\n for (let [key, callback] of Object.entries(this.BINDINGS)) {\r\n this._socket.register(key, callback);\r\n debug(`Registered itemPileSocket: ${key}`);\r\n }\r\n }\r\n \r\n static executeAsGM(handler, ...args) {\r\n return this._socket.executeAsGM(handler, ...args);\r\n }\r\n \r\n static executeAsUser(handler, userId, ...args) {\r\n return this._socket.executeAsUser(handler, userId, ...args);\r\n }\r\n \r\n static executeForAllGMs(handler, ...args) {\r\n return this._socket.executeForAllGMs(handler, ...args);\r\n }\r\n \r\n static executeForOtherGMs(handler, ...args) {\r\n return this._socket.executeForOtherGMs(handler, ...args);\r\n }\r\n \r\n static executeForEveryone(handler, ...args) {\r\n return this._socket.executeForEveryone(handler, ...args);\r\n }\r\n \r\n static executeForOthers(handler, ...args) {\r\n return this._socket.executeForOthers(handler, ...args);\r\n }\r\n \r\n static executeForUsers(handler, userIds, ...args) {\r\n return this._socket.executeForUsers(handler, userIds, ...args);\r\n }\r\n \r\n static callHook(hook, ...args) {\r\n if (!Helpers.hooks.run) return;\r\n return this._socket.executeForEveryone(this.HANDLERS.CALL_HOOK, hook, ...args);\r\n }\r\n \r\n static callHookForUsers(hook, users, ...args) {\r\n if (!Helpers.hooks.run) return;\r\n return this._socket.executeForUsers(this.HANDLERS.CALL_HOOK, users, hook, ...args);\r\n }\r\n \r\n}\r\n\r\nasync function callHook(hook, ...args) {\r\n const newArgs = [];\r\n for (let arg of args) {\r\n if (stringIsUuid(arg)) {\r\n const testArg = fromUuidFast(arg);\r\n if (testArg) {\r\n arg = testArg;\r\n }\r\n }\r\n newArgs.push(arg);\r\n }\r\n return Hooks.callAll(hook, ...newArgs);\r\n}\r\n\r\nexport const InterfaceTracker = {\r\n \r\n users: {},\r\n \r\n initialize() {\r\n this.users = {};\r\n Hooks.on(\"renderPlayerList\", () => {\r\n Array.from(game.users).forEach(user => {\r\n if (!this.users[user.id] || !user.active) {\r\n this.users[user.id] = new Set();\r\n }\r\n });\r\n });\r\n Hooks.on(HOOKS.OPEN_INTERFACE, (app) => {\r\n ItemPileSocket.executeForOthers(ItemPileSocket.HANDLERS.USER_OPENED_INTERFACE, game.user.id, app.id);\r\n });\r\n Hooks.on(HOOKS.CLOSE_INTERFACE, (app) => {\r\n ItemPileSocket.executeForOthers(ItemPileSocket.HANDLERS.USER_CLOSED_INTERFACE, game.user.id, app.id);\r\n });\r\n },\r\n \r\n userOpened(userId, id) {\r\n this.users[userId].add(id);\r\n },\r\n \r\n userClosed(userId, id) {\r\n this.users[userId].delete(id);\r\n },\r\n \r\n isOpened(id) {\r\n return Object.values(this.users).find(interfaceList => {\r\n return interfaceList.has(id);\r\n })\r\n }\r\n \r\n}","import * as Helpers from \"../helpers/helpers.js\";\r\nimport * as Utilities from \"../helpers/utilities.js\";\r\nimport * as PileUtilities from \"../helpers/pile-utilities.js\";\r\nimport * as SharingUtilities from \"../helpers/sharing-utilities.js\";\r\nimport SETTINGS from \"../constants/settings.js\";\r\nimport ItemPileSocket from \"../socket.js\";\r\nimport HOOKS from \"../constants/hooks.js\";\r\nimport TradeAPI from \"./trade-api.js\";\r\nimport PrivateAPI from \"./private-api.js\";\r\nimport { isItemPileMerchant } from \"../helpers/pile-utilities.js\";\r\n\r\nconst API = {\r\n \r\n /**\r\n * The actor class type used for the original item pile actor in this system\r\n *\r\n * @returns {String}\r\n */\r\n get ACTOR_CLASS_TYPE() {\r\n return Helpers.getSetting(SETTINGS.ACTOR_CLASS_TYPE);\r\n },\r\n \r\n /**\r\n * The currencies used in this system\r\n *\r\n * @returns {Array<{primary: Boolean, name: String, data: Object, img: String, abbreviation: String, exchange: Number}>}\r\n */\r\n get CURRENCIES() {\r\n return Helpers.getSetting(SETTINGS.CURRENCIES);\r\n },\r\n \r\n /**\r\n * The attribute used to track the price of items in this system\r\n *\r\n * @returns {string}\r\n */\r\n get ITEM_PRICE_ATTRIBUTE() {\r\n return Helpers.getSetting(SETTINGS.ITEM_PRICE_ATTRIBUTE);\r\n },\r\n \r\n /**\r\n * The attribute used to track the quantity of items in this system\r\n *\r\n * @returns {String}\r\n */\r\n get ITEM_QUANTITY_ATTRIBUTE() {\r\n return Helpers.getSetting(SETTINGS.ITEM_QUANTITY_ATTRIBUTE);\r\n },\r\n \r\n /**\r\n * The filters for item types eligible for interaction within this system\r\n *\r\n * @returns {Array<{name: String, filters: String}>}\r\n */\r\n get ITEM_FILTERS() {\r\n return Helpers.getSetting(SETTINGS.ITEM_FILTERS);\r\n },\r\n \r\n /**\r\n * The attributes for detecting item similarities\r\n *\r\n * @returns {Array}\r\n */\r\n get ITEM_SIMILARITIES() {\r\n return Helpers.getSetting(SETTINGS.ITEM_SIMILARITIES);\r\n },\r\n \r\n /**\r\n * Sets the actor class type used for the original item pile actor in this system\r\n *\r\n * @param {String} inClassType\r\n * @returns {Promise|Boolean}\r\n */\r\n setActorClassType(inClassType) {\r\n if (typeof inClassType !== \"string\") {\r\n throw Helpers.custom_error(\"setActorTypeClass | inClassType must be of type string\");\r\n }\r\n return Helpers.setSetting(SETTINGS.ACTOR_CLASS_TYPE, inClassType);\r\n },\r\n \r\n /**\r\n * Sets the currencies used in this system\r\n *\r\n * @param {Array} inCurrencies\r\n * @returns {Promise}\r\n */\r\n setCurrencies(inCurrencies) {\r\n if (!Array.isArray(inCurrencies)) {\r\n throw Helpers.custom_error(\"setCurrencies | inCurrencies must be an array\");\r\n }\r\n \r\n inCurrencies.forEach(currency => {\r\n if (typeof currency !== \"object\") {\r\n throw Helpers.custom_error(\"setCurrencies | each entry in inCurrencies must be of type object\");\r\n }\r\n if (typeof currency.primary !== \"boolean\") {\r\n throw Helpers.custom_error(\"setCurrencies | currency.primary must be of type boolean\");\r\n }\r\n if (typeof currency.name !== \"string\") {\r\n throw Helpers.custom_error(\"setCurrencies | currency.name must be of type string\");\r\n }\r\n if (typeof currency.abbreviation !== \"string\") {\r\n throw Helpers.custom_error(\"setCurrencies | currency.abbreviation must be of type string\");\r\n }\r\n if (typeof currency.exchange !== \"number\") {\r\n throw Helpers.custom_error(\"setCurrencies | currency.exchange must be of type number\");\r\n }\r\n if (typeof currency.data !== \"object\") {\r\n throw Helpers.custom_error(\"setCurrencies | currency.data must be of type object\");\r\n }\r\n if (currency.img && typeof currency.img !== \"string\") {\r\n throw Helpers.custom_error(\"setCurrencies | currency.img must be of type string\");\r\n }\r\n });\r\n \r\n return Helpers.setSetting(SETTINGS.CURRENCIES, inCurrencies);\r\n },\r\n \r\n /**\r\n * Sets the attribute used to track the price of items in this system\r\n *\r\n * @param {string} inAttribute\r\n * @returns {Promise}\r\n */\r\n setItemPriceAttribute(inAttribute) {\r\n if (typeof inAttribute !== \"string\") {\r\n throw Helpers.custom_error(\"setItemPriceAttribute | inAttribute must be of type string\");\r\n }\r\n return Helpers.setSetting(SETTINGS.ITEM_PRICE_ATTRIBUTE, inAttribute);\r\n },\r\n \r\n /**\r\n * Sets the attribute used to track the quantity of items in this system\r\n *\r\n * @param {String} inAttribute\r\n * @returns {Promise}\r\n */\r\n setItemQuantityAttribute(inAttribute) {\r\n if (typeof inAttribute !== \"string\") {\r\n throw Helpers.custom_error(\"setItemQuantityAttribute | inAttribute must be of type string\");\r\n }\r\n return Helpers.setSetting(SETTINGS.ITEM_QUANTITY_ATTRIBUTE, inAttribute);\r\n },\r\n \r\n /**\r\n * Sets the items filters for interaction within this system\r\n *\r\n * @param {Array<{path: String, filters: String}>} inFilters\r\n * @returns {Promise}\r\n */\r\n setItemFilters(inFilters) {\r\n if (!Array.isArray(inFilters)) {\r\n throw Helpers.custom_error(\"setItemFilters | inFilters must be of type array\");\r\n }\r\n inFilters.forEach(filter => {\r\n if (typeof filter?.path !== \"string\") {\r\n throw Helpers.custom_error(\"setItemFilters | each entry in inFilters must have a \\\"path\\\" property with a value that is of type string\");\r\n }\r\n if (typeof filter?.filters !== \"string\") {\r\n throw Helpers.custom_error(\"setItemFilters | each entry in inFilters must have a \\\"filters\\\" property with a value that is of type string\");\r\n }\r\n });\r\n return Helpers.setSetting(SETTINGS.ITEM_FILTERS, inFilters);\r\n },\r\n \r\n /**\r\n * Sets the attributes for detecting item similarities\r\n *\r\n * @param {Array} inPaths\r\n * @returns {Promise}\r\n */\r\n setItemSimilarities(inPaths) {\r\n if (!Array.isArray(inPaths)) {\r\n throw Helpers.custom_error(\"setItemSimilarities | inPaths must be of type array\");\r\n }\r\n inPaths.forEach(path => {\r\n if (typeof path !== \"string\") {\r\n throw Helpers.custom_error(\"setItemSimilarities | each entry in inPaths must be of type string\");\r\n }\r\n });\r\n return Helpers.setSetting(SETTINGS.ITEM_SIMILARITIES, inPaths);\r\n },\r\n \r\n getPrimaryCurrency(actor = false) {\r\n if (actor && actor instanceof Actor) {\r\n return PileUtilities.getActorPrimaryCurrency(actor);\r\n }\r\n return this.CURRENCIES.find(currency => currency.primary);\r\n },\r\n \r\n /* ================= ITEM PILE METHODS ================= */\r\n \r\n /**\r\n * Creates the default item pile token at a location.\r\n *\r\n * @param {Object} position The position to create the item pile at\r\n * @param {String/Boolean} [sceneId=false] Which scene to create the item pile on\r\n * @param {Array/Boolean} [items=false] Any items to create on the item pile\r\n * @param {String/Boolean} [pileActorName=false] Whether to use an existing item pile actor as the basis of this new token\r\n *\r\n * @returns {Promise}\r\n */\r\n createItemPile(position, {\r\n sceneId = game.user.viewedScene, items = false, pileActorName = false\r\n } = {}) {\r\n \r\n if (pileActorName) {\r\n const pileActor = game.actors.getName(pileActorName);\r\n if (!pileActor) {\r\n throw Helpers.custom_error(`There is no actor of the name \"${pileActorName}\"`, true);\r\n } else if (!PileUtilities.isValidItemPile(pileActor)) {\r\n throw Helpers.custom_error(`The actor of name \"${pileActorName}\" is not a valid item pile actor.`, true);\r\n }\r\n }\r\n \r\n if (items) {\r\n items = items.map(item => {\r\n return item instanceof Item ? item.toObject() : item;\r\n })\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.CREATE_PILE, sceneId, position, { pileActorName, items });\r\n },\r\n \r\n /**\r\n * Turns tokens and its actors into item piles\r\n *\r\n * @param {Token/TokenDocument/Array} targets The targets to be turned into item piles\r\n * @param {Object} pileSettings Overriding settings to be put on the item piles' settings\r\n * @param {Object} tokenSettings Overriding settings that will update the tokens' settings\r\n *\r\n * @return {Promise} The uuids of the targets after they were turned into item piles\r\n */\r\n turnTokensIntoItemPiles(targets, { pileSettings = {}, tokenSettings = {} } = {}) {\r\n \r\n if (!Array.isArray(targets)) targets = [targets];\r\n \r\n const targetUuids = targets.map(target => {\r\n if (!(target instanceof Token || target instanceof TokenDocument)) {\r\n throw Helpers.custom_error(`turnTokensIntoItemPiles | Target must be of type Token or TokenDocument`, true)\r\n }\r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`turnTokensIntoItemPiles | Could not determine the UUID, please provide a valid target`, true)\r\n return targetUuid;\r\n })\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TURN_INTO_PILE, targetUuids, pileSettings, tokenSettings);\r\n },\r\n \r\n /**\r\n * Reverts tokens from an item pile into a normal token and actor\r\n *\r\n * @param {Token/TokenDocument/Array} targets The targets to be reverted from item piles\r\n * @param {Object} tokenSettings Overriding settings that will update the tokens\r\n *\r\n * @return {Promise} The uuids of the targets after they were reverted from being item piles\r\n */\r\n revertTokensFromItemPiles(targets, { tokenSettings = {} } = {}) {\r\n \r\n if (!Array.isArray(targets)) targets = [targets];\r\n \r\n const targetUuids = targets.map(target => {\r\n if (!(target instanceof Token || target instanceof TokenDocument)) {\r\n throw Helpers.custom_error(`revertTokensFromItemPiles | Target must be of type Token or TokenDocument`, true)\r\n }\r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`revertTokensFromItemPiles | Could not determine the UUID, please provide a valid target`, true)\r\n return targetUuid;\r\n })\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.REVERT_FROM_PILE, targetUuids, tokenSettings);\r\n },\r\n \r\n /**\r\n * Opens a pile if it is enabled and a container\r\n *\r\n * @param {Token/TokenDocument} target\r\n * @param {Token/TokenDocument/Boolean} [interactingToken=false]\r\n *\r\n * @return {Promise/Boolean}\r\n */\r\n openItemPile(target, interactingToken = false) {\r\n const targetActor = Utilities.getActor(target);\r\n const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;\r\n const data = PileUtilities.getActorFlagData(targetActor);\r\n if (!data?.enabled || !data?.isContainer) return false;\r\n const wasLocked = data.locked;\r\n const wasClosed = data.closed;\r\n data.closed = false;\r\n data.locked = false;\r\n if (wasLocked) {\r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_UNLOCK, targetActor, data, interactingTokenDocument);\r\n if (hookResult === false) return false;\r\n }\r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_OPEN, targetActor, data, interactingTokenDocument);\r\n if (hookResult === false) return false;\r\n if (wasClosed && data.openSound) {\r\n AudioHelper.play({ src: data.openSound })\r\n }\r\n return this.updateItemPile(targetActor, data, { interactingToken: interactingTokenDocument });\r\n },\r\n \r\n /**\r\n * Closes a pile if it is enabled and a container\r\n *\r\n * @param {Token/TokenDocument} target Target pile to close\r\n * @param {Token/TokenDocument/Boolean} [interactingToken=false]\r\n *\r\n * @return {Promise/Boolean}\r\n */\r\n closeItemPile(target, interactingToken = false) {\r\n const targetActor = Utilities.getActor(target);\r\n const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;\r\n const pileData = PileUtilities.getActorFlagData(targetActor);\r\n if (!pileData?.enabled || !pileData?.isContainer) return false;\r\n \r\n const wasOpen = !pileData.closed;\r\n pileData.closed = true;\r\n \r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_CLOSE, targetActor, pileData, interactingTokenDocument);\r\n if (hookResult === false) return false;\r\n \r\n if (wasOpen && pileData.closeSound) {\r\n AudioHelper.play({ src: pileData.closeSound })\r\n }\r\n \r\n return this.updateItemPile(targetActor, pileData, { interactingToken: interactingTokenDocument });\r\n },\r\n \r\n /**\r\n * Toggles a pile's closed state if it is enabled and a container\r\n *\r\n * @param {Token/TokenDocument} target Target pile to open or close\r\n * @param {Token/TokenDocument/Boolean} [interactingToken=false]\r\n *\r\n * @return {Promise/Boolean}\r\n */\r\n async toggleItemPileClosed(target, interactingToken = false) {\r\n const targetActor = Utilities.getActor(target);\r\n const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;\r\n const pileData = PileUtilities.getActorFlagData(targetActor);\r\n if (!pileData?.enabled || !pileData?.isContainer) return false;\r\n if (pileData.closed) {\r\n await this.openItemPile(targetActor, interactingTokenDocument);\r\n } else {\r\n await this.closeItemPile(targetActor, interactingTokenDocument);\r\n }\r\n return !pileData.closed;\r\n },\r\n \r\n /**\r\n * Locks a pile if it is enabled and a container\r\n *\r\n * @param {Token/TokenDocument} target Target pile to lock\r\n * @param {Token/TokenDocument/Boolean} [interactingToken=false]\r\n *\r\n * @return {Promise/Boolean}\r\n */\r\n lockItemPile(target, interactingToken = false) {\r\n const targetActor = Utilities.getActor(target);\r\n const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;\r\n const pileData = PileUtilities.getActorFlagData(targetActor);\r\n if (!pileData?.enabled || !pileData?.isContainer) return false;\r\n const wasClosed = pileData.closed;\r\n pileData.closed = true;\r\n pileData.locked = true;\r\n if (!wasClosed) {\r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_CLOSE, targetActor, pileData, interactingTokenDocument);\r\n if (hookResult === false) return false;\r\n }\r\n const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_LOCK, targetActor, pileData, interactingTokenDocument);\r\n if (hookResult === false) return false;\r\n if (!wasClosed && pileData.closeSound) {\r\n AudioHelper.play({ src: pileData.closeSound })\r\n }\r\n return this.updateItemPile(targetActor, pileData, { interactingToken: interactingTokenDocument });\r\n },\r\n \r\n /**\r\n * Unlocks a pile if it is enabled and a container\r\n *\r\n * @param {Token/TokenDocument} target Target pile to unlock\r\n * @param {Token/TokenDocument/Boolean} [interactingToken=false]\r\n *\r\n * @return {Promise/Boolean}\r\n */\r\n unlockItemPile(target, interactingToken = false) {\r\n const targetActor = Utilities.getActor(target);\r\n const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;\r\n const pileData = PileUtilities.getActorFlagData(targetActor);\r\n if (!pileData?.enabled || !pileData?.isContainer) return false;\r\n pileData.locked = false;\r\n Helpers.hooks.call(HOOKS.PILE.PRE_UNLOCK, targetActor, pileData, interactingTokenDocument);\r\n return this.updateItemPile(targetActor, pileData, { interactingToken: interactingTokenDocument });\r\n },\r\n \r\n /**\r\n * Toggles a pile's locked state if it is enabled and a container\r\n *\r\n * @param {Token/TokenDocument} target Target pile to lock or unlock\r\n * @param {Token/TokenDocument/Boolean} [interactingToken=false]\r\n *\r\n * @return {Promise/Boolean}\r\n */\r\n toggleItemPileLocked(target, interactingToken = false) {\r\n const targetActor = Utilities.getActor(target);\r\n const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;\r\n const pileData = PileUtilities.getActorFlagData(targetActor);\r\n if (!pileData?.enabled || !pileData?.isContainer) return false;\r\n if (pileData.locked) {\r\n return this.unlockItemPile(targetActor, interactingTokenDocument);\r\n }\r\n return this.lockItemPile(targetActor, interactingTokenDocument);\r\n },\r\n \r\n /**\r\n * Causes the item pile to play a sound as it was attempted to be opened, but was locked\r\n *\r\n * @param {Token/TokenDocument} target\r\n * @param {Token/TokenDocument/Boolean} [interactingToken=false]\r\n *\r\n * @return {Promise}\r\n */\r\n rattleItemPile(target, interactingToken = false) {\r\n const targetActor = Utilities.getActor(target);\r\n const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;\r\n \r\n const pileData = PileUtilities.getActorFlagData(targetActor);\r\n \r\n if (!pileData?.enabled || !pileData?.isContainer || !pileData?.locked) return false;\r\n \r\n Helpers.hooks.call(HOOKS.PILE.PRE_RATTLE, targetActor, pileData, interactingTokenDocument);\r\n \r\n if (pileData.lockedSound) {\r\n AudioHelper.play({ src: pileData.lockedSound })\r\n }\r\n \r\n return ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.CALL_HOOK, HOOKS.PILE.RATTLE, Utilities.getUuid(targetActor), pileData, Utilities.getUuid(interactingTokenDocument));\r\n },\r\n \r\n /**\r\n * Whether an item pile is locked. If it is not enabled or not a container, it is always false.\r\n *\r\n * @param {Token/TokenDocument} target\r\n *\r\n * @return {Boolean}\r\n */\r\n isItemPileLocked(target) {\r\n return PileUtilities.isItemPileLocked(target);\r\n },\r\n \r\n /**\r\n * Whether an item pile is closed. If it is not enabled or not a container, it is always false.\r\n *\r\n * @param {Token/TokenDocument} target\r\n *\r\n * @return {Boolean}\r\n */\r\n isItemPileClosed(target) {\r\n return PileUtilities.isItemPileClosed(target);\r\n },\r\n \r\n /**\r\n * Whether an item pile is a container. If it is not enabled, it is always false.\r\n *\r\n * @param {Token/TokenDocument} target\r\n *\r\n * @return {Boolean}\r\n */\r\n isItemPileContainer(target) {\r\n return PileUtilities.isItemPileContainer(target);\r\n },\r\n \r\n /**\r\n * Updates a pile with new data.\r\n *\r\n * @param {Token/TokenDocument} target\r\n * @param {Object} newData\r\n * @param {Token/TokenDocument/Boolean} [interactingToken=false]\r\n * @param {Object/Boolean} [tokenSettings=false]\r\n *\r\n * @return {Promise/Boolean}\r\n */\r\n updateItemPile(target, newData, { interactingToken = false, tokenSettings = false } = {}) {\r\n \r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`updateItemPile | Could not determine the UUID, please provide a valid target`, true);\r\n \r\n const interactingTokenUuid = interactingToken ? Utilities.getUuid(interactingToken) : false;\r\n if (interactingToken && !interactingTokenUuid) throw Helpers.custom_error(`updateItemPile | Could not determine the UUID, please provide a valid target`, true);\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.UPDATE_PILE, targetUuid, newData, {\r\n interactingTokenUuid, tokenSettings\r\n });\r\n },\r\n \r\n /**\r\n * Deletes a pile, calling the relevant hooks.\r\n *\r\n * @param {Token/TokenDocument} target\r\n *\r\n * @return {Promise/Boolean}\r\n */\r\n deleteItemPile(target) {\r\n if (!PileUtilities.isValidItemPile(target)) {\r\n throw Helpers.custom_error(`deleteItemPile | This is not an item pile, please provide a valid target`, true);\r\n }\r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`deleteItemPile | Could not determine the UUID, please provide a valid target`, true);\r\n if (!targetUuid.includes(\"Token\")) {\r\n throw Helpers.custom_error(`deleteItemPile | Please provide a Token or TokenDocument`, true);\r\n }\r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DELETE_PILE, targetUuid);\r\n },\r\n \r\n /**\r\n * Splits an item pile's content between all players (or a specified set of target actors).\r\n *\r\n * @param target {Token/TokenDocument/Actor} The item pile to split\r\n * @param targets {boolean/TokenDocument/Actor/Array} [targets=false] The targets to receive the split contents\r\n * @param instigator {boolean/TokenDocument/Actor} [instigator=false] Whether this was triggered by a specific actor\r\n * @returns {Promise/Boolean}\r\n */\r\n splitItemPileContents(target, { targets = false, instigator = false } = {}) {\r\n \r\n if (!PileUtilities.isValidItemPile(target)) return false;\r\n \r\n const itemPileUuid = Utilities.getUuid(target);\r\n if (!itemPileUuid) throw Helpers.custom_error(`SplitItemPileContents | Could not determine the UUID, please provide a valid item pile`, true)\r\n \r\n const itemPileActor = Utilities.getActor(target);\r\n \r\n if (targets) {\r\n if (!Array.isArray(targets)) {\r\n targets = [targets]\r\n }\r\n targets.forEach(actor => {\r\n if (!(actor instanceof TokenDocument || actor instanceof Actor)) {\r\n throw Helpers.custom_error(\"SplitItemPileContents | Each of the entries in targets must be of type TokenDocument or Actor\")\r\n }\r\n })\r\n targets = targets.map(target => target?.character ?? target?.actor ?? target);\r\n }\r\n \r\n if (instigator && !(instigator instanceof TokenDocument || instigator instanceof Actor)) {\r\n throw Helpers.custom_error(\"SplitItemPileContents | instigator must be of type TokenDocument or Actor\")\r\n }\r\n \r\n const actorUuids = (targets || SharingUtilities.getPlayersForItemPile(itemPileActor).map(u => u.character)).map(actor => Utilities.getUuid(actor));\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.SPLIT_PILE, itemPileUuid, actorUuids, game.user.id, instigator);\r\n \r\n },\r\n \r\n /* ================= ITEM AND ATTRIBUTE METHODS ================= */\r\n \r\n /**\r\n * Adds item to an actor, increasing item quantities if matches were found\r\n *\r\n * @param {Actor/TokenDocument/Token} target The target to add an item to\r\n * @param {Array} items An array of objects, with the key \"item\" being an item object or an Item class (the foundry class), with an optional key of \"quantity\" being the amount of the item to add\r\n * @param {Boolean} [mergeSimilarItems=true] Whether to merge similar items based on their name and type\r\n * @param {String/Boolean} [interactionId=false] The interaction ID of this action\r\n *\r\n * @returns {Promise} An array of objects, each containing the item that was added or updated, and the quantity that was added\r\n */\r\n addItems(target, items, { mergeSimilarItems = true, interactionId = false } = {}) {\r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`AddItems | Could not determine the UUID, please provide a valid target`, true)\r\n \r\n const itemsToAdd = []\r\n items.forEach(itemData => {\r\n \r\n let item = itemData;\r\n if (itemData instanceof Item) {\r\n item = itemData.toObject();\r\n } else if (itemData.item instanceof Item) {\r\n item = itemData.item.toObject();\r\n } else if (itemData.item) {\r\n item = itemData.item;\r\n }\r\n \r\n if (itemData?.quantity !== undefined) {\r\n setProperty(item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, itemData?.quantity)\r\n }\r\n \r\n const existingItems = mergeSimilarItems ? Utilities.findSimilarItem(itemsToAdd, item) : false;\r\n if (existingItems) {\r\n setProperty(existingItems, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, Utilities.getItemQuantity(existingItems) + Utilities.getItemQuantity(item))\r\n } else {\r\n itemsToAdd.push(item);\r\n }\r\n \r\n });\r\n \r\n if (interactionId) {\r\n if (typeof interactionId !== \"string\") throw Helpers.custom_error(`AddItems | interactionId must be of type string`);\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.ADD_ITEMS, targetUuid, itemsToAdd, game.user.id, { interactionId });\r\n },\r\n \r\n /**\r\n * Subtracts the quantity of items on an actor. If the quantity of an item reaches 0, the item is removed from the actor.\r\n *\r\n * @param {Actor/Token/TokenDocument} target The target to remove a items from\r\n * @param {Array} items An array of objects each containing the item id (key \"_id\") and the quantity to remove (key \"quantity\"), or Items (the foundry class) or strings of IDs to remove all quantities of\r\n * @param {String/Boolean} [interactionId=false] The interaction ID of this action\r\n *\r\n * @returns {Promise} An array of objects, each containing the item that was removed or updated, the quantity that was removed, and whether the item was deleted\r\n */\r\n removeItems(target, items, { interactionId = false } = {}) {\r\n \r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`RemoveItems | Could not determine the UUID, please provide a valid target`, true);\r\n \r\n const targetActorItems = game.itempiles.getActorItems(target);\r\n \r\n items = items.map(itemData => {\r\n \r\n let item;\r\n if (typeof itemData === \"string\" || itemData._id) {\r\n const itemId = typeof itemData === \"string\" ? itemData : itemData._id;\r\n item = targetActorItems.find(actorItem => actorItem.id === itemId);\r\n if (!item) {\r\n throw Helpers.custom_error(`RemoveItems | Could not find item with id \"${itemId}\" on target \"${targetUuid}\"`, true)\r\n }\r\n item = item.toObject();\r\n } else {\r\n if (itemData.item instanceof Item) {\r\n item = itemData.item.toObject();\r\n } else if (itemData instanceof Item) {\r\n item = itemData.toObject();\r\n } else {\r\n item = itemData.item;\r\n }\r\n let foundActorItem = targetActorItems.find(actorItem => actorItem.id === item._id);\r\n if (!foundActorItem) {\r\n throw Helpers.custom_error(`RemoveItems | Could not find item with id \"${item._id}\" on target \"${targetUuid}\"`, true)\r\n }\r\n }\r\n \r\n return {\r\n _id: item._id, quantity: itemData?.quantity ?? Utilities.getItemQuantity(item)\r\n }\r\n });\r\n \r\n if (interactionId) {\r\n if (typeof interactionId !== \"string\") throw Helpers.custom_error(`RemoveItems | interactionId must be of type string`);\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.REMOVE_ITEMS, targetUuid, items, game.user.id, { interactionId });\r\n },\r\n \r\n /**\r\n * Transfers items from the source to the target, subtracting a number of quantity from the source's item and adding it to the target's item, deleting items from the source if their quantity reaches 0\r\n *\r\n * @param {Actor/Token/TokenDocument} source The source to transfer the items from\r\n * @param {Actor/Token/TokenDocument} target The target to transfer the items to\r\n * @param {Array} items An array of objects each containing the item id (key \"_id\") and the quantity to transfer (key \"quantity\"), or Items (the foundry class) or strings of IDs to transfer all quantities of\r\n * @param {String/Boolean} [interactionId=false] The interaction ID of this action\r\n *\r\n * @returns {Promise} An array of objects, each containing the item that was added or updated, and the quantity that was transferred\r\n */\r\n transferItems(source, target, items, { interactionId = false } = {}) {\r\n \r\n const sourceUuid = Utilities.getUuid(source);\r\n if (!sourceUuid) throw Helpers.custom_error(`TransferItems | Could not determine the UUID, please provide a valid source`, true)\r\n \r\n const sourceActorItems = PileUtilities.getActorItems(source);\r\n \r\n items = items.map(itemData => {\r\n \r\n let item;\r\n if (typeof itemData === \"string\" || itemData._id) {\r\n const itemId = typeof itemData === \"string\" ? itemData : itemData._id;\r\n item = sourceActorItems.find(actorItem => actorItem.id === itemId);\r\n if (!item) {\r\n throw Helpers.custom_error(`TransferItems | Could not find item with id \"${itemId}\" on target \"${sourceUuid}\"`, true)\r\n }\r\n item = item.toObject();\r\n } else if (itemData instanceof Item) {\r\n item = itemData.toObject();\r\n } else if (itemData.item instanceof Item) {\r\n item = itemData.item.toObject();\r\n } else {\r\n item = itemData.item;\r\n }\r\n \r\n let foundActorItem = sourceActorItems.find(actorItem => actorItem.id === item._id);\r\n if (!foundActorItem) {\r\n throw Helpers.custom_error(`TransferItems | Could not find item with id \"${item._id}\" on target \"${sourceUuid}\"`, true)\r\n }\r\n \r\n return {\r\n _id: item._id, quantity: Math.max((itemData?.quantity ?? 0) ?? Utilities.getItemQuantity(itemData))\r\n }\r\n });\r\n \r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`TransferItems | Could not determine the UUID, please provide a valid target`, true)\r\n \r\n if (interactionId) {\r\n if (typeof interactionId !== \"string\") throw Helpers.custom_error(`TransferItems | interactionId must be of type string`);\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_ITEMS, sourceUuid, targetUuid, items, game.user.id, { interactionId });\r\n \r\n },\r\n \r\n /**\r\n * Transfers all items between the source and the target.\r\n *\r\n * @param {Actor/Token/TokenDocument} source The actor to transfer all items from\r\n * @param {Actor/Token/TokenDocument} target The actor to receive all the items\r\n * @param {Array/Boolean} [itemFilters=false] Array of item types disallowed - will default to module settings if none provided\r\n * @param {String/Boolean} [interactionId=false] The interaction ID of this action\r\n *\r\n * @returns {Promise} An array containing all of the items that were transferred to the target\r\n */\r\n transferAllItems(source, target, { itemFilters = false, interactionId = false } = {}) {\r\n \r\n const sourceUuid = Utilities.getUuid(source);\r\n if (!sourceUuid) throw Helpers.custom_error(`TransferAllItems | Could not determine the UUID, please provide a valid source`, true)\r\n \r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`TransferAllItems | Could not determine the UUID, please provide a valid target`, true)\r\n \r\n if (itemFilters) {\r\n if (!Array.isArray(itemFilters)) throw Helpers.custom_error(`TransferAllItems | itemFilters must be of type array`);\r\n itemFilters.forEach(entry => {\r\n if (typeof entry?.path !== \"string\") throw Helpers.custom_error(`TransferAllItems | each entry in the itemFilters must have a \"path\" property that is of type string`);\r\n if (typeof entry?.filter !== \"string\") throw Helpers.custom_error(`TransferAllItems | each entry in the itemFilters must have a \"filter\" property that is of type string`);\r\n })\r\n }\r\n \r\n if (interactionId) {\r\n if (typeof interactionId !== \"string\") throw Helpers.custom_error(`TransferAllItems | interactionId must be of type string`);\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_ALL_ITEMS, sourceUuid, targetUuid, game.user.id, {\r\n itemFilters, interactionId\r\n });\r\n },\r\n \r\n /**\r\n * Adds attributes on an actor\r\n *\r\n * @param {Actor/Token/TokenDocument} target The target whose attribute will have a set quantity added to it\r\n * @param {Object} attributes An object with each key being an attribute path, and its value being the quantity to add\r\n * @param {String/Boolean} [interactionId=false] The interaction ID of this action\r\n *\r\n * @returns {Promise} An array containing a key value pair of the attribute path and the quantity of that attribute that was removed\r\n *\r\n */\r\n addAttributes(target, attributes, { interactionId = false } = {}) {\r\n \r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`AddAttributes | Could not determine the UUID, please provide a valid target`, true)\r\n \r\n const targetActor = Utilities.getActor(target);\r\n \r\n Object.entries(attributes).forEach(entry => {\r\n const [attribute, quantity] = entry;\r\n if (!hasProperty(targetActor.data, attribute)) {\r\n throw Helpers.custom_error(`AddAttributes | Could not find attribute ${attribute} on target's actor with UUID \"${targetUuid}\"`, true)\r\n }\r\n if (!Helpers.isRealNumber(quantity) && quantity > 0) {\r\n throw Helpers.custom_error(`AddAttributes | Attribute \"${attribute}\" must be of type number and greater than 0`, true)\r\n }\r\n });\r\n \r\n if (interactionId) {\r\n if (typeof interactionId !== \"string\") throw Helpers.custom_error(`AddAttributes | interactionId must be of type string`);\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.ADD_ATTRIBUTE, targetUuid, attributes, game.user.id, { interactionId });\r\n \r\n },\r\n \r\n /**\r\n * Subtracts attributes on the target\r\n *\r\n * @param {Token/TokenDocument} target The target whose attributes will be subtracted from\r\n * @param {Array/object} attributes This can be either an array of attributes to subtract (to zero out a given attribute), or an object with each key being an attribute path, and its value being the quantity to subtract\r\n * @param {String/Boolean} [interactionId=false] The interaction ID of this action\r\n *\r\n * @returns {Promise} An array containing a key value pair of the attribute path and the quantity of that attribute that was removed\r\n */\r\n removeAttributes(target, attributes, { interactionId = false } = {}) {\r\n \r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`RemoveAttributes | Could not determine the UUID, please provide a valid target`, true)\r\n \r\n const targetActor = Utilities.getActor(target);\r\n \r\n if (Array.isArray(attributes)) {\r\n attributes.forEach(attribute => {\r\n if (typeof attribute !== \"string\") {\r\n throw Helpers.custom_error(`RemoveAttributes | Each attribute in the array must be of type string`, true)\r\n }\r\n if (!hasProperty(targetActor.data, attribute)) {\r\n throw Helpers.custom_error(`RemoveAttributes | Could not find attribute ${attribute} on target's actor with UUID \"${targetUuid}\"`, true)\r\n }\r\n });\r\n } else {\r\n Object.entries(attributes).forEach(entry => {\r\n const [attribute, quantity] = entry;\r\n if (!hasProperty(targetActor.data, attribute)) {\r\n throw Helpers.custom_error(`RemoveAttributes | Could not find attribute ${attribute} on target's actor with UUID \"${targetUuid}\"`, true)\r\n }\r\n if (!is_real_number(quantity) && quantity > 0) {\r\n throw Helpers.custom_error(`RemoveAttributes | Attribute \"${attribute}\" must be of type number and greater than 0`, true)\r\n }\r\n });\r\n }\r\n \r\n if (interactionId) {\r\n if (typeof interactionId !== \"string\") throw Helpers.custom_error(`RemoveAttributes | interactionId must be of type string`);\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.REMOVE_ATTRIBUTES, targetUuid, attributes, game.user.id, { interactionId });\r\n \r\n },\r\n \r\n /**\r\n * Transfers a set quantity of an attribute from a source to a target, removing it or subtracting from the source and adds it the target\r\n *\r\n * @param {Actor/Token/TokenDocument} source The source to transfer the attribute from\r\n * @param {Actor/Token/TokenDocument} target The target to transfer the attribute to\r\n * @param {Array/object} attributes This can be either an array of attributes to transfer (to transfer all of a given attribute), or an object with each key being an attribute path, and its value being the quantity to transfer\r\n * @param {String/Boolean} [interactionId=false] The interaction ID of this action\r\n *\r\n * @returns {Promise} An object containing a key value pair of each attribute transferred, the key being the attribute path and its value being the quantity that was transferred\r\n */\r\n transferAttributes(source, target, attributes, { interactionId = false } = {}) {\r\n \r\n const sourceUuid = Utilities.getUuid(source);\r\n if (!sourceUuid) throw Helpers.custom_error(`TransferAttributes | Could not determine the UUID, please provide a valid source`, true)\r\n const sourceActor = Utilities.getActor(source);\r\n \r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`TransferAttributes | Could not determine the UUID, please provide a valid target`, true)\r\n const targetActor = Utilities.getActor(target);\r\n \r\n if (Array.isArray(attributes)) {\r\n attributes.forEach(attribute => {\r\n if (typeof attribute !== \"string\") {\r\n throw Helpers.custom_error(`TransferAttributes | Each attribute in the array must be of type string`, true)\r\n }\r\n if (!hasProperty(sourceActor.data, attribute)) {\r\n throw Helpers.custom_error(`TransferAttributes | Could not find attribute ${attribute} on source's actor with UUID \"${targetUuid}\"`, true)\r\n }\r\n if (!hasProperty(targetActor.data, attribute)) {\r\n throw Helpers.custom_error(`TransferAttributes | Could not find attribute ${attribute} on target's actor with UUID \"${targetUuid}\"`, true)\r\n }\r\n });\r\n } else {\r\n Object.entries(attributes).forEach(entry => {\r\n const [attribute, quantity] = entry;\r\n if (!hasProperty(sourceActor.data, attribute)) {\r\n throw Helpers.custom_error(`TransferAttributes | Could not find attribute ${attribute} on source's actor with UUID \"${targetUuid}\"`, true)\r\n }\r\n if (!hasProperty(targetActor.data, attribute)) {\r\n throw Helpers.custom_error(`TransferAttributes | Could not find attribute ${attribute} on target's actor with UUID \"${targetUuid}\"`, true)\r\n }\r\n if (!Helpers.isRealNumber(quantity) && quantity > 0) {\r\n throw Helpers.custom_error(`TransferAttributes | Attribute \"${attribute}\" must be of type number and greater than 0`, true)\r\n }\r\n });\r\n }\r\n \r\n if (interactionId) {\r\n if (typeof interactionId !== \"string\") throw Helpers.custom_error(`TransferAttributes | interactionId must be of type string`);\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_ATTRIBUTES, sourceUuid, targetUuid, attributes, game.user.id, { interactionId });\r\n \r\n },\r\n \r\n /**\r\n * Transfers all dynamic attributes from a source to a target, removing it or subtracting from the source and adding them to the target\r\n *\r\n * @param {Actor/Token/TokenDocument} source The source to transfer the attributes from\r\n * @param {Actor/Token/TokenDocument} target The target to transfer the attributes to\r\n * @param {String/Boolean} [interactionId=false] The interaction ID of this action\r\n *\r\n * @returns {Promise} An object containing a key value pair of each attribute transferred, the key being the attribute path and its value being the quantity that was transferred\r\n */\r\n transferAllAttributes(source, target, { interactionId = false } = {}) {\r\n \r\n const sourceUuid = Utilities.getUuid(source);\r\n if (!sourceUuid) throw Helpers.custom_error(`TransferAllAttributes | Could not determine the UUID, please provide a valid source`, true);\r\n \r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`TransferAllAttributes | Could not determine the UUID, please provide a valid target`, true);\r\n \r\n if (interactionId) {\r\n if (typeof interactionId !== \"string\") throw Helpers.custom_error(`TransferAllAttributes | interactionId must be of type string`);\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_ALL_ATTRIBUTES, sourceUuid, targetUuid, game.user.id, { interactionId });\r\n \r\n },\r\n \r\n /**\r\n * Transfers all items and attributes between the source and the target.\r\n *\r\n * @param {Actor/Token/TokenDocument} source The actor to transfer all items and attributes from\r\n * @param {Actor/Token/TokenDocument} target The actor to receive all the items and attributes\r\n * @param {Array/Boolean} [itemFilters=false] Array of item types disallowed - will default to module settings if none provided\r\n * @param {String/Boolean} [interactionId=false] The ID of this interaction\r\n *\r\n * @returns {Promise} An object containing all items and attributes transferred to the target\r\n */\r\n transferEverything(source, target, { itemFilters = false, interactionId = false } = {}) {\r\n \r\n const sourceUuid = Utilities.getUuid(source);\r\n if (!sourceUuid) throw Helpers.custom_error(`TransferEverything | Could not determine the UUID, please provide a valid source`, true)\r\n \r\n const targetUuid = Utilities.getUuid(target);\r\n if (!targetUuid) throw Helpers.custom_error(`TransferEverything | Could not determine the UUID, please provide a valid target`, true)\r\n \r\n if (itemFilters) {\r\n if (!Array.isArray(itemFilters)) throw Helpers.custom_error(`TransferEverything | itemFilters must be of type array`);\r\n itemFilters.forEach(entry => {\r\n if (typeof entry?.path !== \"string\") throw Helpers.custom_error(`TransferEverything | each entry in the itemFilters must have a \"path\" property that is of type string`);\r\n if (typeof entry?.filter !== \"string\") throw Helpers.custom_error(`TransferEverything | each entry in the itemFilters must have a \"filter\" property that is of type string`);\r\n })\r\n }\r\n \r\n if (interactionId) {\r\n if (typeof interactionId !== \"string\") throw Helpers.custom_error(`TransferEverything | interactionId must be of type string`);\r\n }\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_EVERYTHING, sourceUuid, targetUuid, game.user.id, {\r\n itemFilters, interactionId\r\n });\r\n \r\n },\r\n \r\n updateTokenHud() {\r\n return ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.RERENDER_TOKEN_HUD);\r\n },\r\n \r\n requestTrade(user) {\r\n return TradeAPI._requestTrade(user);\r\n },\r\n \r\n spectateTrade(tradeId) {\r\n return TradeAPI._spectateTrade(tradeId);\r\n },\r\n \r\n renderItemPileInterface(target, {\r\n userIds = null, inspectingTarget = null, useDefaultCharacter = null\r\n } = {}) {\r\n \r\n const targetDocument = Utilities.getDocument(target);\r\n const targetUuid = Utilities.getUuid(targetDocument);\r\n if (!targetUuid) throw Helpers.custom_error(`renderItemPileInterface | Could not determine the UUID, please provide a valid target item pile`);\r\n \r\n if (!PileUtilities.isValidItemPile(targetDocument)) {\r\n throw Helpers.custom_error(\"renderItemPileInterface | This target is not a valid item pile\")\r\n }\r\n \r\n if (!inspectingTarget && !useDefaultCharacter) {\r\n useDefaultCharacter = true;\r\n }\r\n \r\n if (inspectingTarget && useDefaultCharacter) {\r\n throw Helpers.custom_error(\"renderItemPileInterface | You cannot force users to use both their default character and a specific character to inspect the pile\")\r\n }\r\n \r\n const inspectingTargetUuid = inspectingTarget ? Utilities.getUuid(inspectingTarget) : false;\r\n if (inspectingTarget && !inspectingTargetUuid) throw Helpers.custom_error(`renderItemPileInterface | Could not determine the UUID, please provide a valid inspecting target`);\r\n \r\n if (!Array.isArray(userIds)) userIds = [game.user.id];\r\n \r\n if (!game.user.isGM) {\r\n if (userIds.length > 1 || !userIds.includes(game.user.id)) {\r\n throw Helpers.custom_error(`renderItemPileInterface | You are not a GM, so you cannot force others to render an item pile's interface`);\r\n }\r\n userIds = [game.user.id];\r\n }\r\n \r\n if (userIds.length === 1 && userIds[0] === game.user.id) {\r\n return PrivateAPI._renderItemPileInterface(targetUuid, {\r\n inspectingTargetUuid,\r\n useDefaultCharacter,\r\n remote: true\r\n })\r\n }\r\n \r\n for (const userId of userIds) {\r\n const user = game.users.get(userId);\r\n if (!user) throw Helpers.custom_error(`renderItemPileInterface | No user with ID \"${userId}\" exists`);\r\n if (useDefaultCharacter) {\r\n if (!user.character) {\r\n Helpers.custom_warning(`renderItemPileInterface | User \"${user.name}\" has no default character`, true);\r\n return;\r\n }\r\n }\r\n }\r\n \r\n return ItemPileSocket.executeForUsers(ItemPileSocket.HANDLERS.RENDER_INTERFACE, userIds, targetUuid, {\r\n inspectingTargetUuid,\r\n useDefaultCharacter,\r\n remote: true\r\n });\r\n \r\n },\r\n \r\n getPricesForItem(item, { seller = false, buyer = false, quantity = 1 } = {}) {\r\n \r\n if (!(item instanceof Item)) {\r\n throw Helpers.custom_error(\"getPricesForItem | The given item must be of type Item\");\r\n }\r\n \r\n if (seller) {\r\n seller = Utilities.getActor(seller);\r\n if (!seller) {\r\n throw Helpers.custom_error(\"getPricesForItem | Could not determine actor for the seller\");\r\n }\r\n } else {\r\n if (!item.parent) {\r\n throw Helpers.custom_error(\"getPricesForItem | If no seller was given, the item must belong to an actor\");\r\n }\r\n seller = Utilities.getActor(item.parent);\r\n }\r\n \r\n if (buyer) {\r\n buyer = Utilities.getActor(buyer);\r\n if (!buyer) {\r\n throw Helpers.custom_error(`getPricesForItem | Could not determine the actor for the buyer`);\r\n }\r\n }\r\n \r\n return PileUtilities.getItemPrices(item, { seller, buyer, quantity });\r\n \r\n },\r\n \r\n /**\r\n * Trades a single item between one actor to another, and currencies and/or change is exchanged between them\r\n *\r\n * @param {Actor/Token/TokenDocument} seller The actor that is selling the item\r\n * @param {Actor/Token/TokenDocument} buyer The actor that is buying the item\r\n * @param {Array>} items An array of objects containing the item or the id of the\r\n * item to be sold, the quantity to be sold, and the payment\r\n * index to be used\r\n * @param {String/Boolean} [interactionId=false] The ID of this interaction\r\n *\r\n * @returns {Promise} The items that were created and the attributes that were changed\r\n */\r\n tradeItems(seller, buyer, items, { interactionId = false } = {}) {\r\n \r\n const sellerActor = Utilities.getActor(seller);\r\n const sellerUuid = Utilities.getUuid(sellerActor);\r\n if (!sellerUuid) {\r\n throw Helpers.custom_error(`tradeItems | Could not determine the UUID of the seller, please provide a valid actor or token`, true);\r\n }\r\n \r\n const buyerActor = Utilities.getActor(buyer);\r\n const buyerUuid = Utilities.getUuid(buyer);\r\n if (!buyerUuid) {\r\n throw Helpers.custom_error(`tradeItems | Could not determine the UUID of the buyer, please provide a valid actor or token`, true);\r\n }\r\n \r\n const itemsToSell = items.map(data => {\r\n \r\n data = foundry.utils.mergeObject({\r\n item: \"\",\r\n quantity: 1,\r\n paymentIndex: 0\r\n }, data);\r\n \r\n if (!data.item) {\r\n throw Helpers.custom_error(`tradeItems | You must provide an item!`, true);\r\n }\r\n \r\n let actorItem;\r\n if (typeof data.item === \"string\") {\r\n actorItem = sellerActor.items.get(data.item) || sellerActor.items.getName(data.item);\r\n if (!actorItem) {\r\n throw Helpers.custom_error(`tradeItems | Could not find item on seller with identifier \"${data.item}\"`);\r\n }\r\n } else {\r\n actorItem = sellerActor.items.get(data.item instanceof Item ? data.item.id : data.item._id) || sellerActor.items.getName(data.item.name);\r\n if (!actorItem) {\r\n throw Helpers.custom_error(`tradeItems | Could not find provided item on seller`);\r\n }\r\n }\r\n \r\n const itemPrices = PileUtilities.getItemPrices(actorItem, {\r\n seller: sellerActor,\r\n buyer: buyerActor,\r\n quantity: data.quantity\r\n });\r\n if (itemPrices.length) {\r\n if (data.paymentIndex >= itemPrices.length || data.paymentIndex < 0) {\r\n throw Helpers.custom_error(`tradeItems | That payment index does not exist on ${actorItem.name}`, true);\r\n }\r\n \r\n const selectedPrice = itemPrices[data.paymentIndex];\r\n if (data.quantity > selectedPrice.maxQuantity) {\r\n throw Helpers.custom_error(`tradeItems | The buyer actor cannot afford ${data.quantity} of ${actorItem.name} (max ${selectedPrice.maxQuantity})`, true);\r\n }\r\n }\r\n \r\n return {\r\n id: actorItem.id,\r\n quantity: data.quantity,\r\n paymentIndex: data.paymentIndex\r\n };\r\n \r\n });\r\n \r\n return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRADE_ITEMS, sellerUuid, buyerUuid, itemsToSell, game.user.id, { interactionId });\r\n \r\n },\r\n \r\n}\r\n\r\nexport default API;","\r\n\r\n\r\n\r\n\r\n \r\n \r\n\r\n\r\n","import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\nimport ItemTypePriceModifiersShell from './item-type-price-modifiers-editor.svelte';\r\n\r\nexport default class ItemTypePriceModifiersEditor extends SvelteApplication {\r\n \r\n constructor(itemTypePriceModifiers, options) {\r\n \r\n super({\r\n svelte: {\r\n class: ItemTypePriceModifiersShell,\r\n target: document.body,\r\n props: {\r\n itemTypePriceModifiers\r\n }\r\n },\r\n close: () => this.options.resolve?.(false),\r\n ...options\r\n });\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n title: game.i18n.localize(\"ITEM-PILES.Applications.ItemTypePriceModifiersEditor.Title\"),\r\n width: 600,\r\n height: \"auto\",\r\n classes: [\"item-piles-app\"]\r\n })\r\n }\r\n \r\n static async show(data = false, options = {}) {\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(data, options).render(true, { focus: true });\r\n })\r\n }\r\n \r\n}","\r\n\r\n\r\n\r\n\r\n\r\n \r\n\r\n ","import * as Utilities from \"../../helpers/utilities.js\";\r\nimport { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\nimport ItemPileConfigShell from './item-pile-config.svelte';\r\n\r\nexport default class ItemPileConfig extends SvelteApplication {\r\n \r\n constructor(pileActor, options = {}) {\r\n \r\n super({\r\n id: `item-pile-config-${pileActor.id}`,\r\n title: game.i18n.format(\"ITEM-PILES.Applications.ItemPileConfig.Title\", { actor_name: pileActor.name }),\r\n svelte: {\r\n class: ItemPileConfigShell,\r\n target: document.body,\r\n props: {\r\n pileActor\r\n }\r\n },\r\n close: () => this.options.resolve?.(null),\r\n ...options\r\n });\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n width: 430,\r\n height: 617,\r\n classes: [\"item-piles-config\"],\r\n })\r\n }\r\n \r\n static getActiveApp(id) {\r\n return Object.values(ui.windows).find(app => app.id === `item-pile-config-${id}`)\r\n }\r\n \r\n static async show(target, options = {}, dialogData = {}) {\r\n const targetActor = Utilities.getActor(target);\r\n const app = this.getActiveApp(targetActor.id);\r\n if (app) return app.render(false, { focus: true });\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(targetActor, options, dialogData).render(true);\r\n })\r\n }\r\n \r\n async close(options) {\r\n Object.values(ui.windows).forEach(app => {\r\n if (app !== this && app.rendered && app.options?.parentApp === this) {\r\n app.close();\r\n }\r\n })\r\n return super.close(options);\r\n }\r\n}","import SETTINGS from \"./constants/settings.js\";\r\nimport * as Helpers from \"./helpers/helpers.js\";\r\nimport * as PileUtilities from \"./helpers/pile-utilities.js\";\r\nimport ItemPileConfig from \"./applications/item-pile-config/item-pile-config.js\";\r\nimport ItemEditor from \"./applications/editors/item-editor/item-editor.js\";\r\nimport CONSTANTS from \"./constants/constants.js\";\r\n\r\nexport default function registerUIOverrides() {\r\n Hooks.on(\"renderPlayerList\", addTradeButton);\r\n Hooks.on(\"getActorDirectoryEntryContext\", insertActorContextMenuItems);\r\n Hooks.on(\"getActorSheetHeaderButtons\", insertActorHeaderButtons);\r\n Hooks.on(\"getItemSheetHeaderButtons\", insertItemHeaderButtons);\r\n Hooks.on(\"renderSidebarTab\", hideTemporaryItems);\r\n}\r\n\r\nfunction hideTemporaryItems(sidebar) {\r\n if (sidebar.tabName !== \"items\") return;\r\n Array.from(game.items).filter(item => {\r\n return getProperty(item.toObject(), CONSTANTS.FLAGS.TEMPORARY_ITEM);\r\n })\r\n .forEach(item => {\r\n const element = sidebar.element.find(`.directory-item[data-document-id=\"${item.id}\"]`);\r\n if (!element.length) return;\r\n if (element.parent().children().length === 1) {\r\n return element.parent().empty();\r\n }\r\n element.find(`.directory-item[data-document-id=\"${item.id}\"]`).remove();\r\n });\r\n}\r\n\r\nfunction addTradeButton(app, html) {\r\n if (!Helpers.getSetting(SETTINGS.ENABLE_TRADING) || !Helpers.getSetting(SETTINGS.SHOW_TRADE_BUTTON)) return;\r\n\r\n const minimalUI = game.modules.get('minimal-ui')?.active;\r\n const classes = \"item-piles-player-list-trade-button\" + (minimalUI ? \" item-piles-minimal-ui\" : \"\")\r\n const text = !minimalUI ? \" Request Trade\" : \"\"\r\n const button = $(` ${text} `)\r\n\r\n button.click(() => {\r\n game.itempiles.requestTrade();\r\n });\r\n html.append(button);\r\n}\r\n\r\nfunction insertActorContextMenuItems(html, menuItems) {\r\n\r\n menuItems.push({\r\n name: \"ITEM-PILES.ContextMenu.ShowToPlayers\",\r\n icon: ` `,\r\n callback: (html) => {\r\n const actorId = html[0].dataset.documentId;\r\n const actor = game.actors.get(actorId);\r\n const users = Array.from(game.users).filter(u => u.active).map(u => u.id);\r\n return game.itempiles.renderItemPileInterface(actor, { users, useDefaultCharacter: true });\r\n },\r\n condition: (html) => {\r\n const actorId = html[0].dataset.documentId;\r\n const actor = game.actors.get(actorId);\r\n return game.user.isGM && PileUtilities.isValidItemPile(actor);\r\n }\r\n }, {\r\n name: \"ITEM-PILES.ContextMenu.RequestTrade\",\r\n icon: ` `,\r\n callback: (html) => {\r\n const actorId = html[0].dataset.documentId;\r\n const actor = game.actors.get(actorId);\r\n const user = Array.from(game.users).find(u => u.character === actor && u.active);\r\n return game.itempiles.requestTrade(user);\r\n },\r\n condition: (html) => {\r\n const actorId = html[0].dataset.documentId;\r\n const actor = game.actors.get(actorId);\r\n return Helpers.getSetting(SETTINGS.ENABLE_TRADING)\r\n && (game.user?.character !== actor || Array.from(game.users).find(u => u.character === actor && u.active));\r\n }\r\n });\r\n}\r\n\r\nfunction insertActorHeaderButtons(actorSheet, buttons) {\r\n\r\n if (!game.user.isGM) return;\r\n\r\n let obj = actorSheet.object;\r\n\r\n buttons.unshift({\r\n label: Helpers.getSetting(SETTINGS.HIDE_ACTOR_HEADER_TEXT) ? \"\" : \"Configure\",\r\n icon: \"fas fa-box-open\",\r\n class: \"item-piles-config-button\",\r\n onclick: () => {\r\n ItemPileConfig.show(obj);\r\n }\r\n })\r\n}\r\n\r\nfunction insertItemHeaderButtons(itemSheet, buttons) {\r\n\r\n if (!game.user.isGM) return;\r\n\r\n let obj = itemSheet.object;\r\n\r\n buttons.unshift({\r\n label: Helpers.getSetting(SETTINGS.HIDE_ACTOR_HEADER_TEXT) ? \"\" : \"Configure\",\r\n icon: \"fas fa-box-open\",\r\n class: \"item-piles-config-button\",\r\n onclick: () => {\r\n ItemEditor.show(obj);\r\n }\r\n })\r\n}","import CONSTANTS from \"./constants/constants.js\";\r\nimport { hotkeyActionState } from \"./hotkeys.js\";\r\nimport * as PileUtilities from \"./helpers/pile-utilities.js\";\r\nimport PrivateAPI from \"./API/private-api.js\";\r\n\r\nexport default function registerLibwrappers() {\r\n \r\n libWrapper.register(CONSTANTS.MODULE_NAME, 'Token.prototype._onClickLeft2', function (wrapped, ...args) {\r\n if (PileUtilities.isValidItemPile(this.document) && hotkeyActionState.openPileInventory) {\r\n return PrivateAPI._itemPileClicked(this.document);\r\n }\r\n return wrapped(...args);\r\n }, \"MIXED\");\r\n \r\n libWrapper.register(CONSTANTS.MODULE_NAME, `SidebarDirectory.prototype._onClickDocumentName`, function (wrapped, event) {\r\n \r\n event.preventDefault();\r\n const element = event.currentTarget;\r\n const documentId = element.parentElement.dataset.documentId;\r\n const document = this.constructor.collection.get(documentId);\r\n \r\n if (PileUtilities.isValidItemPile(document) && hotkeyActionState.openPileInventory) {\r\n return game.itempiles.renderItemPileInterface(document, { useDefaultCharacter: true });\r\n }\r\n return wrapped(event);\r\n }, \"MIXED\");\r\n \r\n}\r\n","\r\n\r\n\r\n\r\n
\r\n\r\n
\r\n\r\n
\r\n\r\n\r\n","\r\n\r\n\r\n\r\n\r\n \r\n \r\n\r\n\r\n","import ItemSimilaritiesShell from './item-similarities-editor.svelte';\r\nimport { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\n\r\nexport default class ItemSimilaritiesEditor extends SvelteApplication {\r\n \r\n constructor(options) {\r\n super({\r\n svelte: {\r\n class: ItemSimilaritiesShell,\r\n target: document.body\r\n },\r\n close: () => this.options.resolve(null),\r\n ...options\r\n });\r\n }\r\n \r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n title: game.i18n.localize(\"ITEM-PILES.Applications.SimilaritiesEditor.Title\"),\r\n width: 400,\r\n height: \"auto\",\r\n classes: [\"item-piles-app\"]\r\n })\r\n }\r\n \r\n static async show(options = {}) {\r\n return new Promise(resolve => {\r\n options.resolve = resolve;\r\n return new this(options).render(true, { focus: true });\r\n });\r\n }\r\n}","import CurrenciesEditor from \"./currencies-editor/currencies-editor.js\";\r\nimport ItemFiltersEditor from \"./item-filters-editor/item-filters-editor.js\";\r\nimport ItemSimilaritiesEditor from \"./item-similarities-editor/item-similarities-editor.js\";\r\nimport PriceModifiersEditor from \"./price-modifiers-editor/price-modifiers-editor.js\";\r\n\r\nexport default {\r\n \"currencies\": CurrenciesEditor,\r\n \"item-filters\": ItemFiltersEditor,\r\n \"item-similarities\": ItemSimilaritiesEditor,\r\n \"price-modifiers\": PriceModifiersEditor\r\n}","\r\n\r\n\r\n\r\n
\r\n\r\n
\r\n\r\n
\r\n\r\n\r\n","\r\n\r\n\r\n\r\n\r\n \r\n \r\n\r\n","import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';\r\nimport SettingsShell from './settings-shell.svelte';\r\n\r\nclass SettingsApp extends SvelteApplication {\r\n\r\n static get defaultOptions() {\r\n return foundry.utils.mergeObject(super.defaultOptions, {\r\n id: `item-piles-application-system-settings`,\r\n title: \"Item Piles Module Configuration\",\r\n width: 600,\r\n svelte: {\r\n class: SettingsShell,\r\n target: document.body\r\n },\r\n zIndex: 100,\r\n });\r\n }\r\n\r\n static getActiveApp() {\r\n return Object.values(ui.windows).find(app => app.id === \"item-piles-application-system-settings\");\r\n }\r\n\r\n static async show(options = {}, dialogData = {}) {\r\n const app = this.getActiveApp()\r\n if (app) return app.render(false, { focus: true });\r\n return new Promise((resolve) => {\r\n options.resolve = resolve;\r\n new this(options, dialogData).render(true, { focus: true });\r\n })\r\n }\r\n}\r\n\r\nexport default class SettingsShim extends FormApplication {\r\n\r\n /**\r\n * @inheritDoc\r\n */\r\n constructor() {\r\n super({});\r\n SettingsApp.show();\r\n }\r\n\r\n async _updateObject(event, formData) {\r\n }\r\n\r\n render() {\r\n this.close();\r\n }\r\n\r\n}","import CONSTANTS from \"./constants/constants.js\";\r\nimport SETTINGS from \"./constants/settings.js\";\r\nimport * as Helpers from \"./helpers/helpers.js\";\r\nimport { SYSTEMS } from \"./systems.js\";\r\nimport SettingsShim from \"./applications/settings-app/settings-app.js\";\r\n\r\nexport function registerSettings() {\r\n \r\n game.settings.registerMenu(CONSTANTS.MODULE_NAME, \"configure-settings\", {\r\n name: \"ITEM-PILES.Settings.Configure.Title\",\r\n label: \"ITEM-PILES.Settings.Configure.Label\",\r\n hint: \"ITEM-PILES.Settings.Configure.Hint\",\r\n icon: \"fas fa-cog\",\r\n type: SettingsShim,\r\n restricted: false\r\n });\r\n \r\n for (let [name, data] of Object.entries(SETTINGS.GET_DEFAULT())) {\r\n game.settings.register(CONSTANTS.MODULE_NAME, name, data);\r\n }\r\n \r\n}\r\n\r\nasync function applyDefaultSettings() {\r\n const settings = SETTINGS.GET_SYSTEM_DEFAULTS();\r\n for (const [name, data] of Object.entries(settings)) {\r\n await Helpers.setSetting(name, data.default);\r\n }\r\n await Helpers.setSetting(SETTINGS.SYSTEM_VERSION, SYSTEMS.DATA.VERSION);\r\n await patchCurrencySettings();\r\n}\r\n\r\nexport async function patchCurrencySettings() {\r\n const currencies = Helpers.getSetting(SETTINGS.CURRENCIES);\r\n for (let currency of currencies) {\r\n if (currency.type !== \"item\" || !currency.data.uuid || currency.data.item) continue;\r\n const item = await fromUuid(currency.data.uuid);\r\n if (!item) continue;\r\n currency.data.item = item.toObject();\r\n }\r\n await Helpers.setSetting(SETTINGS.CURRENCIES, currencies);\r\n}\r\n\r\nexport async function checkSystem() {\r\n \r\n if (Helpers.getSetting(SETTINGS.PRECONFIGURED_SYSTEM)) return;\r\n \r\n if (!SYSTEMS.HAS_SYSTEM_SUPPORT) {\r\n \r\n if (Helpers.getSetting(SETTINGS.SYSTEM_NOT_FOUND_WARNING_SHOWN)) return;\r\n \r\n let settingsValid = true;\r\n for (const [name, data] of Object.entries(SETTINGS.GET_DEFAULT())) {\r\n settingsValid = settingsValid && Helpers.getSetting(name).length !== (new data.type).length\r\n }\r\n \r\n if (settingsValid) return;\r\n \r\n Dialog.prompt({\r\n title: game.i18n.localize(\"ITEM-PILES.Dialogs.NoSystemFound.Title\"),\r\n content: Helpers.dialogLayout({ message: game.i18n.localize(\"ITEM-PILES.Dialogs.NoSystemFound.Content\") }),\r\n callback: () => {\r\n }\r\n });\r\n \r\n return Helpers.setSetting(SETTINGS.SYSTEM_NOT_FOUND_WARNING_SHOWN, true);\r\n \r\n }\r\n \r\n if (Helpers.getSetting(SETTINGS.SYSTEM_FOUND)) {\r\n const currentVersion = Helpers.getSetting(SETTINGS.SYSTEM_VERSION);\r\n const newVersion = SYSTEMS.DATA.VERSION;\r\n if (isNewerVersion(newVersion, currentVersion)) {\r\n return new Dialog({\r\n title: game.i18n.localize(\"ITEM-PILES.Dialogs.NewSystemVersion.Title\"),\r\n content: Helpers.dialogLayout({\r\n message: game.i18n.localize(\"ITEM-PILES.Dialogs.NewSystemVersion.Content\"),\r\n }),\r\n buttons: {\r\n confirm: {\r\n icon: ' ',\r\n label: game.i18n.localize(\"ITEM-PILES.Dialogs.NewSystemVersion.Confirm\"),\r\n callback: () => {\r\n applyDefaultSettings();\r\n }\r\n },\r\n cancel: {\r\n icon: ' ',\r\n label: game.i18n.localize(\"No\")\r\n }\r\n },\r\n default: \"cancel\"\r\n }).render(true);\r\n }\r\n return;\r\n }\r\n \r\n await Helpers.setSetting(SETTINGS.SYSTEM_FOUND, true);\r\n \r\n if (Helpers.getSetting(SETTINGS.SYSTEM_NOT_FOUND_WARNING_SHOWN)) {\r\n \r\n return new Dialog({\r\n title: game.i18n.localize(\"ITEM-PILES.Dialogs.SystemFound.Title\"),\r\n content: Helpers.dialogLayout({\r\n message: game.i18n.localize(\"ITEM-PILES.Dialogs.SystemFound.Content\"),\r\n icon: \"fas fa-search\"\r\n }),\r\n buttons: {\r\n confirm: {\r\n icon: ' ',\r\n label: game.i18n.localize(\"ITEM-PILES.Dialogs.SystemFound.Confirm\"),\r\n callback: () => {\r\n applyDefaultSettings();\r\n }\r\n },\r\n cancel: {\r\n icon: ' ',\r\n label: game.i18n.localize(\"No\")\r\n }\r\n },\r\n default: \"cancel\"\r\n }).render(true);\r\n \r\n }\r\n \r\n return applyDefaultSettings();\r\n}","import \"./styles/styles.scss\";\n\nimport registerUIOverrides from \"./foundry-ui-overrides.js\";\nimport registerLibwrappers from \"./libwrapper.js\";\nimport { registerSettings, checkSystem, patchCurrencySettings } from \"./settings.js\";\nimport { registerHotkeysPost, registerHotkeysPre } from \"./hotkeys.js\";\nimport Socket from \"./socket.js\";\nimport API from \"./API/api.js\";\nimport TradeAPI from \"./API/trade-api.js\";\nimport ChatAPI from \"./API/chat-api.js\";\nimport PrivateAPI from \"./API/private-api.js\";\nimport HOOKS from \"./constants/hooks.js\";\nimport * as Helpers from \"./helpers/helpers.js\";\nimport MerchantApp from \"./applications/merchant-app/merchant-app.js\";\nimport ItemEditor from \"./applications/editors/item-editor/item-editor.js\";\nimport { getItemPrices, getPricesForItems } from \"./helpers/pile-utilities.js\";\nimport { SYSTEMS } from \"./systems.js\";\n\nHooks.once(\"init\", async () => {\n registerSettings();\n registerHotkeysPre();\n registerUIOverrides();\n registerLibwrappers();\n \n PrivateAPI.initialize();\n TradeAPI.initialize();\n ChatAPI.initialize();\n \n game.itempiles = API;\n window.ItemPiles = {\n API: API\n };\n});\n\nHooks.once(\"ready\", async () => {\n \n if (!game.modules.get('lib-wrapper')?.active && game.user.isGM) {\n let word = \"install and activate\";\n if (game.modules.get('lib-wrapper')) word = \"activate\";\n throw Helpers.custom_error(`Item Piles requires the 'libWrapper' module. Please ${word} it.`)\n }\n if (!game.modules.get('socketlib')?.active && game.user.isGM) {\n let word = \"install and activate\";\n if (game.modules.get('socketlib')) word = \"activate\";\n throw Helpers.custom_error(`Item Piles requires the 'socketlib' module. Please ${word} it.`)\n }\n \n if (!Helpers.isGMConnected()) {\n Helpers.custom_warning(`Item Piles requires a GM to be connected for players to be able to loot item piles.`, true)\n }\n \n if (game.user.isGM) {\n patchCurrencySettings();\n checkSystem();\n }\n registerHotkeysPost();\n Hooks.callAll(HOOKS.READY);\n \n ChatAPI.disablePastTradingButtons();\n \n // const merchant = game.actors.get(\"4jh4e6K5TobGeoni\");\n // const actor = game.actors.getName(\"Player Token\");\n \n // game.itempiles.tradeItems(actor, merchant, [{\n // item: actor.items.getName(\"Scimitar\")\n // }]);\n \n // console.log(getPricesForItems([{\n // item: actor.items.getName(\"Alms Box\"),\n // quantity: 1,\n // paymentIndex: 0\n // }], {\n // seller: actor,\n // buyer: merchant\n // }))\n \n // game.itempiles.renderItemPileInterface(merchant, { inspectingTarget: actor });\n \n // ItemEditor.show(source.items.getName(\"Antitoxin\"));\n \n});\n\nHooks.once(\"socketlib.ready\", () => {\n Socket.initialize();\n});\n\nHooks.on(\"reset-item-pile-settings\", async () => {\n for (let setting of game.settings.storage.get(\"world\").filter(setting => setting.data.key.includes('item-piles'))) {\n await setting.delete();\n }\n})"],"names":["wait","Utilities.getDocument","Utilities.getActor","Utilities.fromUuidFast","Helpers.getSetting","Utilities.findSimilarItem","Utilities.getItemQuantity","Utilities.getUuid","Helpers.roundToDecimals","loop","get","writable$2","constants.animateKeys","constants.relativeRegex","lerp","linear","constants.transformOriginDefault","constants.transformKeysBitwise","constants.transformKeys","s_VALIDATION_DATA","constants.transformOrigins","constants.numericDefaults","constants.setNumericDefaults","s_REGEX_HTML","draggable","dragDefault","create_if_block_1","create_if_block","PileUtilities.isValidItemPile","PileUtilities.getActorFlagData","PileUtilities.isItemPileEmpty","Utilities.setSimilarityProperties","preventDefault","PriceModifiersShell","create_if_block_2","Helpers.custom_error","Helpers.custom_notify","CurrenciesEditorShell","ItemFiltersShell","func","Utilities.getTokensAtLocation","DropItemDialogShell","create_if_block_3","PileUtilities.getActorCurrencyList","PileUtilities.getActorCurrencies","DropCurrencyDialogShell","SharingUtilities.getItemSharesLeftForActor","PileUtilities.isItemCurrency","SharingUtilities.getAttributeSharesLeftForActor","SharingUtilities.getItemPileSharingData","PileUtilities.getActorItems","PileUtilities.isItemInvalid","SharingUtilities.updateItemPileSharingData","create_if_block_8","create_if_block_7","create_if_block_4","create_if_block_5","SharingUtilities.getPlayersForItemPile","ItemPileInventoryShell","Helpers.hooks","Utilities.setItemQuantity","create_if_block_6","PileUtilities.getPricesForItems","TradeMerchantItemDialogShell","PileUtilities.updateItemPileData","PileUtilities.getItemFlagData","PileUtilities.getItemPrices","PileUtilities.updateItemData","INTERVAL_MS","scrollIfNeeded","resetScrolling","next","DEFAULT_DROP_ZONE_TYPE","DEFAULT_DROP_TARGET_STYLE","typeToDropZones","dzToConfig","registerDropZone","unregisterDropZone","handleDrop","dndzone","INSTRUCTION_IDs","pointerDndZone","keyboardDndZone","ItemEditorShell","Helpers.custom_warning","MerchantAppShell","PileUtilities.getItemPileTokenImage","PileUtilities.getItemPileTokenScale","PileUtilities.getItemPileName","PileUtilities.shouldItemPileBeDeleted","Utilities.getToken","SharingUtilities.clearItemPileSharingData","SharingUtilities.setItemPileSharingData","Helpers.wait","Helpers.isResponsibleGM","Helpers.debounceManager","Helpers.debug","Utilities.distance_between_rect","Helpers.isGMConnected","Utilities.tokens_close_enough","Utilities.grids_between_tokens","PileUtilities.isItemPileMerchant","TradeDialogPrompt","TradeDialogRequest","TradingAppShell","Helpers.setSetting","PileUtilities.getActorPrimaryCurrency","PileUtilities.isItemPileLocked","PileUtilities.isItemPileClosed","PileUtilities.isItemPileContainer","Helpers.isRealNumber","ItemTypePriceModifiersShell","PileAPI","Helpers.dialogLayout","ItemPileConfigShell","ItemSimilaritiesShell","helpers.getSetting","helpers.setSetting","SettingsShell","Socket"],"mappings":";;;AAAA,MAAe,QAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,wBAAwB;AAAA,EAGxB,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,IACD;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAED,oBAAoB,OAAO,aAAa;AACtC,KAAC,YAAY,cAAc,UAAU,EAAE,QAAQ,SAAO,OAAO,SAAS,KAAK,IAAI;AAC/E,aAAS,KAAK,aAAa,KAAK,IAAI,OAAO,MAAM,gBAAgB,UAAU,SAAS,KAAK,UAAU;AACnG,QAAI,SAAS,SAAS,SAAS;AAC7B,YAAM,SAAS,MAAM,KAAK,eAAe,sBAAsB,QAAQ;AACvE,iBAAW,OAAO;AAAA,IACnB;AACD,WAAO;AAAA,EACR;AAAA,EAGD,qBAAqB,CAAC,QAAQ,MAAM;AAAA,EAKpC,cAAc;AAAA,IACZ;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,EACF;AACH;AClGA,MAAe,MAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAGD,qBAAqB,CAAC,QAAQ,MAAM;AAAA,EAKpC,cAAc;AAAA,IACZ;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,EACF;AACH;ACtEA,MAAe,OAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,wBAAwB;AAAA,EAGxB,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAGD,qBAAqB,CAAC,QAAQ,QAAQ,sBAAsB;AAAA,EAK5D,cAAc;AAAA,IACZ;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,EACF;AACH;ACvEA,MAAe,MAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAGD,qBAAqB,CAAC,QAAQ,MAAM;AAAA,EAKpC,cAAc;AAAA,IACZ;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,EACF;AACH;AC7DA,MAAe,OAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAGD,qBAAqB,CAAC,QAAQ,MAAM;AAAA,EAKpC,cAAc;AAAA,IACZ;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,EACF;AACH;ACtEA,MAAe,QAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAGD,qBAAqB,CAAC,QAAQ,MAAM;AAAA,EAEpC,cAAc;AAAA,IACZ,WAAW;AAAA,MACT;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,KAAK;AAAA,QACL,cAAc;AAAA,QACd,MAAM;AAAA,UACJ,MAAM;AAAA,QACP;AAAA,QACD,SAAS;AAAA,QACT,cAAc;AAAA,MACf;AAAA,IACF;AAAA,IACD,0BAA0B;AAAA,MACxB;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,KAAK;AAAA,QACL,cAAc;AAAA,QACd,MAAM;AAAA,UACJ,MAAM;AAAA,QACP;AAAA,QACD,SAAS;AAAA,QACT,cAAc;AAAA,MACf;AAAA,IACF;AAAA,EACF;AACH;ACjDA,MAAe,QAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAKD,cAAc;AAAA,IACZ;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,EACF;AACH;AClCA,MAAe,aAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,IACD;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAGD,qBAAqB,CAAC,QAAQ,MAAM;AAAA,EAKpC,cAAc;AAAA,IACZ;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,EACF;AACH;AC/DA,MAAe,SAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAGD,qBAAqB,CAAC,QAAQ,MAAM;AAAA,EAKpC,cAAc,CAAE;AAClB;ACzBA,MAAe,eAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAGD,qBAAqB,CAAC,QAAQ,QAAQ,uBAAuB,cAAc;AAAA,EAK3E,cAAc;AAAA,IACZ;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,IACD;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,EACF;AACH;AC3DA,MAAe,UAAA;AAAA,EAEb,WAAW;AAAA,EAGX,oBAAoB;AAAA,EAGpB,2BAA2B;AAAA,EAG3B,wBAAwB;AAAA,EAGxB,gBAAgB;AAAA,IACd;AAAA,MACE,QAAQ;AAAA,MACR,WAAW;AAAA,IACZ;AAAA,EACF;AAAA,EAGD,qBAAqB,CAAC,QAAQ,QAAQ,WAAW;AAAA,EAKjD,cAAc;AAAA,IACZ;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS;AAAA,MACT,cAAc;AAAA,IACf;AAAA,EACF;AACH;ACrBO,MAAM,UAAU;AAAA,EAErB,mBAAmB;AAAA,IACjB;AAAA,IAEA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAED;AAAA,EAED,kBAAkB;AAAA,IAChB,kBAAkB;AAAA,IAClB,yBAAyB;AAAA,IACzB,sBAAsB;AAAA,IACtB,cAAc,CAAE;AAAA,IAChB,mBAAmB,CAAE;AAAA,IACrB,YAAY;AAAA,MACV,aAAa;AAAA,MACb,QAAQ,CAAE;AAAA,IACX;AAAA,EACF;AAAA,EAED,IAAI,qBAAqB;AACvB,WAAO,CAAC,CAAC,KAAK,oBAAoB,KAAK,OAAO;AAAA,EAC/C;AAAA,EAED,IAAI,OAAO;AACT,WAAO,KAAK,oBAAoB,KAAK,OAAO,OAAO,KAAK;AAAA,EACzD;AACH;ACtDA,MAAM,WAAW;AAAA,EAGf,gBAAgB;AAAA,EAChB,mBAAmB;AAAA,EACnB,wBAAwB;AAAA,EACxB,eAAe;AAAA,EACf,OAAO;AAAA,EACP,aAAa;AAAA,EAGb,uBAAuB;AAAA,EACvB,gBAAgB;AAAA,EAChB,mBAAmB;AAAA,EACnB,oBAAoB;AAAA,EACpB,wBAAwB;AAAA,EAGxB,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,kBAAkB;AAAA,EAClB,yBAAyB;AAAA,EACzB,sBAAsB;AAAA,EACtB,mBAAmB;AAAA,EAGnB,8BAA8B;AAAA,EAC9B,4BAA4B;AAAA,EAC5B,cAAc;AAAA,EACd,gCAAgC;AAAA,EAChC,sBAAsB;AAAA,EACtB,gBAAgB;AAAA,EAEhB,cAAc;AACZ,WAAO,QAAQ,MAAM,UAAU,SAAS,SAAQ,CAAE;AAAA,EACnD;AAAA,EAED,sBAAsB;AACpB,WAAO,OAAO,YAAY,OAAO,QAAQ,SAAS,YAAa,CAAA,EAAE,OAAO,WAAS;AAC/E,aAAO,MAAM,GAAG;AAAA,IACjB,CAAA,CAAC;AAAA,EACH;AAAA,EAED,UAAU,MAAO;AAAA,IAEf,CAAC,SAAS,aAAa;AAAA,MACrB,MAAM;AAAA,MACN,OAAO;AAAA,MACP,MAAM;AAAA,MACN,MAAM;AAAA,MACN,aAAa;AAAA,MACb,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,SAAS,QAAQ,KAAK;AAAA,MACtB,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,eAAe;AAAA,MACvB,MAAM;AAAA,MACN,OAAO;AAAA,MACP,MAAM;AAAA,MACN,MAAM;AAAA,MACN,aAAa;AAAA,MACb,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,SAAS,QAAQ,KAAK;AAAA,MACtB,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,oBAAoB;AAAA,MAC5B,MAAM;AAAA,MACN,OAAO;AAAA,MACP,MAAM;AAAA,MACN,MAAM;AAAA,MACN,aAAa;AAAA,MACb,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,SAAS,QAAQ,KAAK;AAAA,MACtB,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,mBAAmB;AAAA,MAC3B,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,SAAS,QAAQ,KAAK;AAAA,MACtB,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,0BAA0B;AAAA,MAClC,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,SAAS,QAAQ,KAAK;AAAA,MACtB,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,uBAAuB;AAAA,MAC/B,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,SAAS,QAAQ,KAAK;AAAA,MACtB,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,iBAAiB;AAAA,MACzB,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,6BAA6B;AAAA,MACrC,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,+BAA+B;AAAA,MACvC,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,eAAe;AAAA,MACvB,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,iCAAiC;AAAA,MACzC,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,uBAAuB;AAAA,MAC/B,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,iBAAiB;AAAA,MACzB,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,SAAS;AAAA,QACP;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACD;AAAA,MACD,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,yBAAyB;AAAA,MACjC,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,qBAAqB;AAAA,MAC7B,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,wBAAwB;AAAA,MAChC,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,iBAAiB;AAAA,MACzB,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,oBAAoB;AAAA,MAC5B,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,oBAAoB;AAAA,MAC5B,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,yBAAyB;AAAA,MACjC,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,gBAAgB;AAAA,MACxB,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAED,CAAC,SAAS,QAAQ;AAAA,MAChB,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,IAGD,CAAC,SAAS,cAAc;AAAA,MACtB,MAAM;AAAA,MACN,MAAM;AAAA,MACN,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,MAAM;AAAA,IACP;AAAA,EAEL;AACA;ACzQA,MAAM,cAAc;AACpB,MAAM,cAAc,WAAW;AAC/B,MAAM,WAAW,SAAS;AAE1B,MAAM,YAAY;AAAA,EAEhB,aAAa;AAAA,EACb,MAAM;AAAA,EAEN,OAAO;AAAA,IACL,MAAM,WAAW;AAAA,IACjB,SAAS,WAAW;AAAA,IACpB,MAAM,WAAW;AAAA,IACjB,iBAAiB,WAAW;AAAA,IAC5B,aAAa,WAAW;AAAA,IACxB,gBAAgB,WAAW;AAAA,EAC5B;AAAA,EAED,eAAe;AAAA,IACb,QAAQ;AAAA,IACR,YAAY;AAAA,IACZ,kBAAkB;AAAA,IAClB,iBAAiB;AAAA,IACjB,MAAM;AAAA,IACN,mBAAmB;AAAA,IACnB,QAAQ,CAAE;AAAA,EACX;AAAA,EAED,eAAe;AAAA,IAEb,SAAS;AAAA,IACT,UAAU;AAAA,IACV,OAAO;AAAA,IACP,iBAAiB;AAAA,IACjB,iBAAiB;AAAA,IAGjB,qBAAqB;AAAA,IACrB,oBAAoB;AAAA,IAGpB,YAAY;AAAA,IACZ,cAAc;AAAA,IACd,yBAAyB;AAAA,IACzB,iBAAiB;AAAA,IAGjB,mBAAmB;AAAA,IACnB,wBAAwB;AAAA,IACxB,gBAAgB;AAAA,IAChB,iBAAiB;AAAA,IACjB,eAAe;AAAA,IAGf,aAAa;AAAA,IACb,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,aAAa;AAAA,IACb,YAAY;AAAA,IACZ,aAAa;AAAA,IACb,aAAa;AAAA,IACb,YAAY;AAAA,IACZ,WAAW;AAAA,IACX,aAAa;AAAA,IACb,eAAe;AAAA,IAGf,YAAY;AAAA,IACZ,UAAU;AAAA,IACV,kBAAkB;AAAA,IAClB,oBAAoB;AAAA,IACpB,cAAc;AAAA,IACd,cAAc;AAAA,IACd,iBAAiB;AAAA,IACjB,kBAAkB;AAAA,IAClB,mBAAmB;AAAA,IACnB,wBAAwB,CAAE;AAAA,IAC1B,qBAAqB,CAAE;AAAA,IACvB,WAAW;AAAA,MACT,SAAS;AAAA,MACT,MAAM;AAAA,QACJ,MAAM;AAAA,QACN,QAAQ;AAAA,MACT;AAAA,MACD,OAAO;AAAA,QACL,MAAM;AAAA,QACN,QAAQ;AAAA,MACT;AAAA,IACF;AAAA,EACF;AACH;ACxFO,MAAM,kBAAkB;AAAA,EAE7B,WAAW,CAAE;AAAA,EAEb,YAAY,IAAI,QAAQ;AACtB,QAAI,KAAK,UAAU,KAAK;AACtB,aAAO,KAAK,UAAU;AAAA,IACvB;AACD,SAAK,UAAU,MAAM,SAAS,YAAa,MAAM;AAC/C,aAAO,gBAAgB,UAAU;AACjC,aAAO,OAAO,GAAG,IAAI;AAAA,IACtB,GAAE,EAAE;AACL,WAAO,KAAK,UAAU;AAAA,EACvB;AACH;AAEO,MAAM,QAAQ;AAAA,EACnB,KAAK;AAAA,EACL,QAAQ,CAAE;AAAA,EAEV,MAAM,WAAW,UAAU;AACzB,SAAK,MAAM;AACX,UAAM,SAAQ;AACd,SAAK,MAAM;AAAA,EACZ;AAAA,EAED,KAAK,SAAS,MAAM;AAClB,QAAI,CAAC,KAAK;AAAK;AACf,WAAO,MAAM,KAAK,MAAM,GAAG,IAAI;AAAA,EAChC;AAAA,EAED,QAAQ,SAAS,MAAM;AACrB,QAAI,CAAC,KAAK;AAAK;AACf,WAAO,MAAM,QAAQ,MAAM,GAAG,IAAI;AAAA,EACnC;AAAA,EAED,GAAG,MAAM,UAAU;AACjB,UAAM,GAAG,MAAM,IAAI,SAAS;AAC1B,UAAI,CAAC,KAAK;AAAK;AACf,eAAS,GAAG,IAAI;AAAA,IACtB,CAAK;AAAA,EACF;AACH;AAEO,gBAAc,IAAI;AACvB,SAAO,IAAI,QAAQ,aAAW,WAAW,SAAS,EAAE,CAAC;AACvD;AAFgBA;AAIT,oBAAoB,KAAK;AAC9B,SAAO,KAAK,SAAS,IAAI,UAAU,aAAa,GAAG;AACrD;AAFgB;AAIT,oBAAoB,KAAK,OAAO;AACrC,MAAI,UAAU;AAAW,UAAM,IAAI,MAAM,2CAA2C;AACpF,SAAO,KAAK,SAAS,IAAI,UAAU,aAAa,KAAK,KAAK;AAC5D;AAHgB;AAKT,eAAe,KAAK,OAAO,IAAI;AACpC,MAAI,KAAK,SAAS,IAAI,UAAU,aAAa,OAAO,GAAG;AACrD,YAAQ,IAAI,wBAAwB,OAAO,IAAI;AAAA,EAChD;AACH;AAJgB;AAMT,uBAAuB,SAAS;AACrC,YAAU,gBAAgB;AAC1B,KAAG,cAAc,OAAO,OAAO;AAC/B,UAAQ,IAAI,QAAQ,QAAQ,QAAQ,IAAI,CAAC;AAC3C;AAJgB;AAMT,wBAAwB,SAAS,SAAS,OAAO;AACtD,YAAU,gBAAgB;AAC1B,MAAI,QAAQ;AACV,OAAG,cAAc,KAAK,OAAO;AAAA,EAC9B;AACD,UAAQ,KAAK,QAAQ,QAAQ,QAAQ,IAAI,CAAC;AAC5C;AANgB;AAQT,sBAAsB,OAAO,SAAS,MAAM;AACjD,UAAQ,gBAAgB;AACxB,MAAI,QAAQ;AACV,OAAG,cAAc,MAAM,KAAK;AAAA,EAC7B;AACD,SAAO,IAAI,MAAM,MAAM,QAAQ,QAAQ,IAAI,CAAC;AAC9C;AANgB;AAQT,sBAAsB;AAAA,EACE,QAAQ;AAAA,EACR;AAAA,EACA,OAAO;AAAA,EACP,YAAY;AAAA,IACV,IAAI;AACnC,SAAO;AAAA;AAAA,+CAEsC;AAAA,2EAC4B;AAAA,aAC9D;AAAA,UACH;AAAA;AAAA;AAGV;AAdgB;AAiBT,sBAAsB,UAAU;AACrC,SAAO,CAAC,MAAM,QAAQ,KACjB,OAAO,aAAa,YACpB,SAAS,QAAQ;AACxB;AAJgB;AAMT,oBAAoB,MAAM;AAC/B,SAAO,KAAK,UAAU,KAAK;AAC7B;AAFgB;AAIT,wBAAwB;AAC7B,SAAO,KAAK,MAAM,OAAO,UAAU;AACrC;AAFgB;AAIT,2BAA2B;AAChC,MAAI,CAAC,KAAK,KAAK,MAAM;AACnB,WAAO;AAAA,EACR;AACD,SAAO,CAAC,aAAY,EAAG,KAAK,WAAS,MAAM,KAAK,MAAM,KAAK,KAAK,KAAK,GAAG;AAC1E;AALgB;AAOT,yBAAyB;AAC9B,SAAO,CAAC,CAAC,MAAM,KAAK,KAAK,KAAK,EAAE,KAAK,UAAQ,KAAK,QAAQ,KAAK,MAAM;AACvE;AAFgB;AAIT,yBAAyB,KAAK,UAAU;AAC7C,SAAO,OAAO,IAAI,QAAQ,QAAQ,CAAC;AACrC;AAFgB;ACjIT,kBAAkB,QAAQ;AAC/B,MAAI,kBAAkB;AAAO,WAAO;AACpC,MAAI,aAAa,MAAM,GAAG;AACxB,aAAS,aAAa,MAAM;AAAA,EAC7B;AACD,WAAS,YAAY,MAAM;AAC3B,SAAO,QAAQ,SAAS;AAC1B;AAPgB;AAST,kBAAkB,cAAc;AACrC,QAAM,YAAW,aAAa,YAAY;AAC1C,SAAO,WAAU,SAAS;AAC5B;AAHgB;AAKT,qBAAqB,QAAQ;AAClC,MAAI,aAAa,MAAM,GAAG;AACxB,aAAS,aAAa,MAAM;AAAA,EAC7B;AACD,SAAO,QAAQ,YAAY;AAC7B;AALgB;AAOT,sBAAsB,MAAM;AACjC,SAAO,OAAO,SAAS,YACjB,MAAK,MAAM,KAAK,KAAK,CAAE,GAAE,UAC1B,CAAC,KAAK,SAAS,GAAG;AACzB;AAJgB;AAYT,sBAAsB,MAAM;AACjC,MAAI,QAAQ,KAAK,MAAM,GAAG;AAC1B,MAAI;AAEJ,QAAM,CAAC,SAAS,SAAS,MAAM,MAAM,GAAG,CAAC;AACzC,UAAQ,MAAM,MAAM,CAAC;AACrB,QAAM,aAAa,OAAO,SAAS,WAAW;AAC9C,QAAM,WAAW,IAAI,KAAK;AAG1B,SAAO,OAAQ,MAAM,SAAS,GAAI;AAChC,UAAM,CAAC,cAAc,cAAc,MAAM,MAAM,GAAG,CAAC;AACnD,UAAM,IAAI,oBAAoB,cAAc,UAAU;AACtD,YAAQ,MAAM,MAAM,CAAC;AAAA,EACtB;AACD,SAAO,OAAO;AAChB;AAhBgB;AAkBT,iBAAiB,QAAQ;AAC9B,MAAG,aAAa,MAAM;AAAG,WAAO;AAChC,QAAM,YAAW,YAAY,MAAM;AACnC,SAAO,WAAU,QAAQ;AAC3B;AAJgB;AAaT,yBAAyB,OAAO,UAAU;AAE/C,QAAM,mBAAmB,KAAK,UAAU;AAExC,QAAM,aAAa,oBAAoB,OAAO,SAAS,KAAK,SAAS;AAErE,SAAO,MAAM,KAAK,UAAQ;AACxB,UAAM,SAAS,gBAAgB,OAAO,KAAK,KAAK,KAAK;AACrD,QAAI,UAAU,cAAc,WAAW,YAAY;AACjD,aAAO;AAAA,IACR;AAED,UAAM,WAAW,gBAAgB,OAAO,KAAK,SAAU,IAAG;AAC1D,eAAW,QAAQ,kBAAkB;AACnC,UAAI,YAAY,UAAU,IAAI,MAAM,YAAY,UAAU,IAAI,GAAG;AAC/D,eAAO;AAAA,MACR;AAAA,IACF;AAED,WAAO;AAAA,EACX,CAAG;AACH;AArBgB;AAuBT,iCAAiC,KAAK,MAAK;AAChD,QAAM,WAAW,gBAAgB,OAAO,KAAK,SAAU,IAAG;AAC1D,cAAY,KAAK,OAAO,SAAS,GAAG;AACpC,OAAK,UAAU,kBAAkB,QAAQ,UAAQ;AAC/C,gBAAY,KAAK,MAAM,YAAY,UAAU,IAAI,CAAC;AAAA,EACtD,CAAG;AACD,SAAO;AACT;AAPgB;AAeT,yBAAyB,MAAM;AACpC,QAAM,WAAW,gBAAgB,OAAO,KAAK,SAAU,IAAG;AAC1D,SAAO,OAAO,YAAY,UAAU,KAAK,UAAU,uBAAuB,KAAK,CAAC;AAClF;AAHgB;AAYT,yBAAyB,UAAU,UAAU;AAClD,cAAY,UAAU,KAAK,UAAU,yBAAyB,QAAQ;AACtE,SAAO;AACT;AAHgB;AAWT,6BAA6B,UAAU;AAC5C,QAAM,SAAS,CAAC,GAAG,OAAO,OAAO,UAAU,EAAE,OAAO,WAAS,MAAM,OAAO;AAC1E,SAAO,OAAO,OAAO,WAAS;AAC5B,WAAO,SAAS,KAAK,MAAM,KAAK,SAAS,IAAK,MAAM,IAAK,MAAM,KAAK,QAAQ,OAAO,KAAK,QACnF,SAAS,KAAK,MAAM,KAAK,SAAS,IAAK,MAAM,IAAK,MAAM,KAAK,SAAS,OAAO,KAAK;AAAA,EAC3F,CAAG;AACH;AANgB;AAQT,+BAA+B,IAAI,IAAI;AAE5C,QAAM,KAAK,GAAG;AACd,QAAM,KAAK,GAAG;AACd,QAAM,MAAM,GAAG,IAAI,GAAG;AACtB,QAAM,MAAM,GAAG,IAAI,GAAG;AAEtB,QAAM,KAAK,GAAG;AACd,QAAM,KAAK,GAAG;AACd,QAAM,MAAM,GAAG,IAAI,GAAG;AACtB,QAAM,MAAM,GAAG,IAAI,GAAG;AAEtB,QAAM,OAAO,MAAM;AACnB,QAAM,QAAQ,MAAM;AACpB,QAAM,SAAS,MAAM;AACrB,QAAM,MAAM,MAAM;AAElB,MAAI,OAAO,MAAM;AACf,WAAO,iBAAiB,EAAE,GAAG,IAAI,GAAG,OAAO,EAAE,GAAG,KAAK,GAAG,GAAI,CAAA;AAAA,EAChE,WAAa,QAAQ,QAAQ;AACzB,WAAO,iBAAiB,EAAE,GAAG,IAAI,GAAG,MAAM,EAAE,GAAG,KAAK,GAAG,IAAK,CAAA;AAAA,EAChE,WAAa,UAAU,OAAO;AAC1B,WAAO,iBAAiB,EAAE,GAAG,KAAK,GAAG,MAAM,EAAE,GAAG,IAAI,GAAG,IAAK,CAAA;AAAA,EAChE,WAAa,SAAS,KAAK;AACvB,WAAO,iBAAiB,EAAE,GAAG,KAAK,GAAG,OAAO,EAAE,GAAG,IAAI,GAAG,GAAI,CAAA;AAAA,EAC7D,WAAU,MAAM;AACf,WAAO,KAAK;AAAA,EACb,WAAU,OAAO;AAChB,WAAO,KAAK;AAAA,EACb,WAAU,QAAQ;AACjB,WAAO,KAAK;AAAA,EACb,WAAU,KAAK;AACd,WAAO,KAAK;AAAA,EACb;AAED,SAAO;AAET;AArCgB;AAuCT,0BAA0B,GAAG,GAAG;AACrC,SAAO,IAAI,IAAI,GAAG,CAAC,EAAE;AACvB;AAFgB;AAIT,8BAA8B,GAAG,GAAG;AACzC,SAAO,KAAK,MAAM,sBAAsB,GAAG,CAAC,IAAI,OAAO,KAAK,IAAI,IAAI;AACtE;AAFgB;AAIT,6BAA6B,GAAG,GAAG,aAAa;AACrD,QAAM,WAAW,qBAAqB,GAAG,CAAC;AAC1C,SAAO,eAAe;AACxB;AAHgB;AChLhB,qBAAqB,YAAY,MAAM,UAAU,WAAW,OAAO;AACjE,QAAM,eAAe,QAAQ,MAAM,UAAU,QAAQ;AACrD,QAAM,QAAQ,YAAa,aAAY,WAAW,MAAM,IAAI,KAAK,CAAA;AACjE,QAAM,OAAO,QAAQ,MAAM,UAAU,KAAK;AAC1C,SAAO,QAAQ,MAAM,YAAY,cAAc,IAAI;AACrD;AALS;AAOF,yBAAyB,MAAM;AACpC,SAAO,YAAYC,YAAsB,IAAI,GAAG,UAAU,MAAM,MAAM,UAAU,aAAa;AAC/F;AAFgB;AAIT,0BAA0B,QAAQ,OAAO,OAAO;AACrD,SAAO,YAAYC,SAAmB,MAAM,GAAG,UAAU,MAAM,MAAM,UAAU,eAAe,IAAI;AACpG;AAFgB;AAIT,yBAAyB,QAAQ,OAAO,OAAO;AACpD,QAAM,cAAcA,SAAmB,MAAM;AAC7C,QAAM,WAAW,iBAAiB,aAAa,IAAI;AACnD,SAAO,eAAe,UAAU;AAClC;AAJgB;AAMT,6BAA6B,QAAQ,OAAO,OAAO;AACxD,QAAM,cAAcA,SAAmB,MAAM;AAC7C,QAAM,WAAW,iBAAiB,aAAa,IAAI;AACnD,SAAO,UAAU,WAAW,UAAU;AACxC;AAJgB;AAMT,4BAA4B,QAAQ,OAAO,OAAO;AACvD,QAAM,cAAcA,SAAmB,MAAM;AAC7C,QAAM,WAAW,iBAAiB,aAAa,IAAI;AACnD,SAAO,UAAU,WAAW,UAAU;AACxC;AAJgB;AAMT,0BAA0B,QAAQ,OAAO,OAAO;AACrD,QAAM,cAAcA,SAAmB,MAAM;AAC7C,QAAM,WAAW,iBAAiB,aAAa,IAAI;AACnD,MAAI,CAAC,UAAU,WAAW,CAAC,UAAU;AAAa,WAAO;AACzD,SAAO,SAAS;AAClB;AALgB;AAOT,0BAA0B,QAAQ,OAAO,OAAO;AACrD,QAAM,cAAcA,SAAmB,MAAM;AAC7C,QAAM,WAAW,iBAAiB,aAAa,IAAI;AACnD,MAAI,CAAC,UAAU,WAAW,CAAC,UAAU;AAAa,WAAO;AACzD,SAAO,SAAS;AAClB;AALgB;AAOT,yBAAyB,QAAQ;AAEtC,QAAM,cAAcA,SAAmB,MAAM;AAC7C,MAAI,CAAC;AAAa,WAAO;AAEzB,QAAM,gBAAgB,gBAAgB,WAAW;AACjD,MAAI,CAAC;AAAe,WAAO;AAE3B,QAAM,aAAa,cAAc,WAAW,EAAE,WAAW;AACzD,QAAM,kBAAkB,mBAAmB,WAAW,EAAE,WAAW;AAEnE,SAAO,iBAAiB,cAAc;AAExC;AAbgB;AAeT,iCAAiC,YAAY;AAElD,QAAM,SAASC,aAAuB,UAAU;AAEhD,MAAI,CAAE,mBAAkB;AAAgB,WAAO;AAE/C,MAAI,CAAC,gBAAgB,MAAM;AAAG,WAAO;AAErC,QAAM,WAAW,iBAAiB,MAAM;AAExC,SAAO;AAAA,IACL,WAAWC,WAAmB,kBAAkB;AAAA,IAAG,QAAQ;AAAA,IAAM,SAAS;AAAA,EAC9E,EAAI,UAAU,mBAAmB;AAEjC;AAdgB;AAgBT,uBAAuB,QAAQ,EAAE,cAAc,UAAU,CAAA,GAAI;AAClE,QAAM,QAAQF,SAAmB,MAAM;AACvC,QAAM,mBAAmB,cAAc,iBAAiB,WAAW,IAAI,oBAAoB,KAAK;AAChG,QAAM,aAAa,mBAAmB,KAAK,EAAE,IAAI,WAAS,MAAM,EAAE;AAClE,SAAO,MAAM,MAAM,OAAO,UAAQ,WAAW,QAAQ,KAAK,EAAE,MAAM,MAAM,CAAC,cAAc,OAAO,MAAM,gBAAgB,CAAC;AACvH;AALgB;AAOT,4BAA4B,QAAQ,EAAE,WAAW,OAAO,eAAe,OAAO,SAAS,UAAU,IAAI;AAC1G,QAAM,QAAQA,SAAmB,MAAM;AACvC,QAAM,aAAa,MAAM,KAAK,MAAM,KAAK;AACzC,iBAAe,gBAAgB,qBAAqB,YAAY,KAAK;AACrE,MAAI,aAAa,aAAa,IAAI,CAAC,UAAU,UAAU;AACrD,QAAI,SAAS,SAAS,aAAa;AACjC,aAAO;AAAA,QACL,GAAG;AAAA,QACH,UAAU,YAAY,MAAM,MAAM,SAAS,KAAK,IAAI,KAAK;AAAA,QACzD,MAAM,SAAS,KAAK;AAAA,QACpB,IAAI,SAAS,KAAK;AAAA,QAClB;AAAA,MACD;AAAA,IACF;AACD,UAAM,OAAOG,gBAA0B,YAAY,SAAS,KAAK,IAAI;AACrE,WAAO;AAAA,MACL,GAAG;AAAA,MAAU,UAAU,OAAOC,gBAA0B,IAAI,IAAI;AAAA,MAAG,IAAI,MAAM,MAAM;AAAA,MAAM;AAAA,MAAM;AAAA,IAChG;AAAA,EACL,CAAG;AACD,MAAI,CAAC,QAAQ;AACX,iBAAa,WAAW,OAAO,cAAY,SAAS,QAAQ;AAAA,EAC7D;AACD,SAAO;AACT;AAvBgB;AAyBT,iCAAiC,QAAQ;AAC9C,QAAM,QAAQJ,SAAmB,MAAM;AACvC,SAAO,mBAAmB,KAAK,EAAE,KAAK,cAAY,SAAS,OAAO;AACpE;AAHgB;AAKT,8BAA8B,QAAQ,WAAW,OAAO;AAC7D,QAAM,cAAcA,SAAmB,MAAM;AAC7C,aAAW,iBAAiB,aAAa,QAAQ;AACjD,SAAQ,UAAS,sBAAsB,KAAK,UAAU,YAAY,IAAI,cAAY;AAChF,aAAS,OAAO,KAAK,KAAK,SAAS,SAAS,IAAI;AAChD,WAAO;AAAA,EACX,CAAG;AACH;AAPgB;AAUT,6BAA6B,QAAQ,WAAW,OAAO;AAC5D,MAAI,CAAC;AAAQ,WAAO,iBAAiB,KAAK,UAAU,YAAY;AAChE,QAAM,cAAcA,SAAmB,MAAM;AAC7C,aAAW,iBAAiB,aAAa,QAAQ;AACjD,SAAO,gBAAgB,aAAa,QAAQ,KAAK,UAAU,sBAAsB,iBAAiB,SAAS,mBAAmB,IAAI,iBAAiB,KAAK,UAAU,YAAY;AAChL;AALgB;AAOT,0BAA0B,aAAa;AAC5C,SAAO,cAAc,QAAQ,MAAM,UAAU,WAAW,EAAE,IAAI,YAAU;AACtE,WAAO,OAAO,OAAO,KAAK,KAAI;AAC9B,WAAO,UAAU,MAAM,QAAQ,OAAO,OAAO,IAAI,OAAO,UAAU,OAAO,QAAQ,MAAM,GAAG,EAAE,IAAI,YAAU,OAAO,KAAI,CAAE;AACvH,WAAO,UAAU,IAAI,IAAI,OAAO,OAAO;AACvC,WAAO;AAAA,EACR,CAAA,IAAI,CAAA;AACP;AAPgB;AAST,uBAAuB,aAAa,MAAM,cAAc,OAAO;AACpE,QAAM,kBAAkB,cAAc,cAAc,oBAAoB,WAAW;AACnF,QAAM,WAAW,gBAAgB,OAAO,KAAK,SAAU,IAAG;AAC1D,aAAW,UAAU,iBAAiB;AACpC,QAAI,CAAC,YAAY,UAAU,OAAO,IAAI;AAAG;AACzC,UAAM,iBAAiB,YAAY,UAAU,OAAO,IAAI;AACxD,QAAI,OAAO,QAAQ,IAAI,cAAc,GAAG;AACtC,aAAO;AAAA,IACR;AAAA,EACF;AACD,SAAO;AACT;AAXgB;AAaT,wBAAwB,MAAM,EAAE,SAAS,UAAU,CAAA,GAAI;AAC5D,QAAM,QAAQA,SAAmB,SAAS,SAAS,KAAK,MAAM;AAC9D,QAAM,aAAa,mBAAmB,OAAO,EAAE,QAAQ,KAAI,CAAE,EAC1D,OAAO,cAAY,SAAS,SAAS,MAAM,EAC3C,IAAI,WAAQ,MAAK,KAAK,IAAI;AAC7B,SAAO,CAAC,CAACG,gBAA0B,YAAY,IAAI;AACrD;AANgB;AAST,+BAA+B,OAAO,EAAE,OAAO,OAAO,QAAQ,OAAO,aAAa,UAAU,IAAI;AAErG,QAAM,gBAAgBJ,YAAsB,KAAK;AAEjD,QAAM,eAAe,iBAAiB,eAAe,IAAI;AAEzD,MAAI;AACJ,MAAI,yBAAyB,eAAe;AAC1C,kBAAc,cAAc,KAAK;AAAA,EACrC,OAAS;AACL,kBAAc,cAAc,KAAK,MAAM;AAAA,EACxC;AAED,MAAI,CAAC,gBAAgB,aAAa;AAAG,WAAO;AAE5C,UAAQ,SAAS,cAAc,aAAa,EAAE,IAAI,UAAQ,KAAK,SAAQ,CAAE;AACzE,eAAa,cAAc,mBAAmB,aAAa;AAE3D,QAAM,WAAW,MAAM,SAAS,WAAW;AAE3C,MAAI;AAEJ,MAAI,aAAa,cAAc,aAAa,GAAG;AAC7C,UAAM,MAAM,SAAS,IAAI,MAAM,GAAG,MAAM,WAAW,GAAG;AAAA,EACvD,WAAU,aAAa,cAAc,WAAW,GAAG;AAClD,UAAO,eAAc,SAAS,eAAe,KAAK,MAAM;AAAA,EACzD;AAED,MAAI,aAAa,aAAa;AAE5B,UAAM,aAAa,eAAe,aAAa,eAAe,aAAa,eAAe,aAAa;AAEvG,QAAI,aAAa,UAAU,aAAa,aAAa;AACnD,YAAM,aAAa;AAAA,IACpB,WAAU,aAAa,UAAU,aAAa,aAAa;AAC1D,YAAM,aAAa;AAAA,IACpB,WAAU,aAAa,cAAc,gBAAgB,aAAa,GAAG;AACpE,YAAM,aAAa;AAAA,IACzB,WAAe,aAAa,aAAa;AACnC,YAAM,aAAa;AAAA,IACpB;AAAA,EAEF;AAED,SAAO,OAAO;AAEhB;AA9CgB;AAgDT,+BAA+B,QAAQ,EAAE,OAAO,OAAO,QAAQ,OAAO,aAAa,UAAU,IAAI;AAEtG,QAAM,eAAeA,YAAsB,MAAM;AAEjD,MAAI,eAAe,iBAAiB,cAAc,IAAI;AAEtD,MAAI;AACJ,MAAI,wBAAwB,eAAe;AACzC,gBAAY,aAAa,KAAK;AAAA,EAClC,OAAS;AACL,gBAAY,aAAa,KAAK,MAAM;AAAA,EACrC;AAED,MAAI,CAAC,gBAAgB,cAAc,YAAY,GAAG;AAChD,WAAO;AAAA,EACR;AAED,UAAQ,SAAS,cAAc,YAAY;AAC3C,eAAa,cAAc,mBAAmB,YAAY;AAE1D,QAAM,WAAW,MAAM,SAAS,WAAW;AAE3C,MAAI,aAAa,eAAe,CAAC,aAAa,cAAc,CAAC,aAAa,2BAA2B,WAAW,KAAK,aAAa,GAAG;AACnI,WAAO;AAAA,EACR;AAED,SAAO,aAAa;AAEtB;AA5BgB;AA8BT,yBAAyB,QAAQ,EAAE,OAAO,OAAO,QAAQ,OAAO,aAAa,UAAU,IAAI;AAEhG,QAAM,eAAeA,YAAsB,MAAM;AAEjD,QAAM,eAAe,iBAAiB,cAAc,IAAI;AAExD,MAAI,OAAO,wBAAwB,gBAAgB,aAAa,KAAK,OAAO,aAAa,KAAK,MAAM;AAEpG,MAAI,CAAC,gBAAgB,cAAc,YAAY,GAAG;AAChD,WAAO;AAAA,EACR;AAED,UAAQ,SAAS,cAAc,YAAY;AAC3C,eAAa,cAAc,mBAAmB,YAAY;AAE1D,QAAM,WAAW,MAAM,SAAS,WAAW;AAE3C,MAAI,aAAa,eAAe,CAAC,aAAa,cAAc,CAAC,aAAa,gBAAgB,WAAW,KAAK,aAAa,GAAG;AACxH,WAAO;AAAA,EACR;AAED,QAAM,OAAO,MAAM,SAAS,IAAI,MAAM,KAAK,WAAW;AAEtD,SAAO,KAAK;AAEd;AAzBgB;AA2BhB,mCAAmC,QAAQ;AAEzC,QAAM,mBAAmBA,YAAsB,MAAM;AAErD,MAAI;AACJ,MAAI,iBAAiB,CAAA;AAErB,MAAI,4BAA4B,OAAO;AACrC,oBAAgB;AAChB,QAAI,iBAAiB,OAAO;AAC1B,qBAAe,KAAK,kBAAkB,KAAK;AAAA,IACjD,OAAW;AACL,uBAAiB,OAAO,OAAO,WAAW,OAAO,WAAS,MAAM,SAAS,UAAU,aAAa,EAAE,IAAI,WAAS,MAAM,QAAQ;AAAA,IAC9H;AAAA,EACL,OAAS;AACL,oBAAgB,iBAAiB;AACjC,QAAI,iBAAiB,UAAU;AAC7B,uBAAiB,OAAO,OAAO,WAAW,OAAO,WAAS,MAAM,SAAS,UAAU,aAAa,EAAE,IAAI,WAAS,MAAM,QAAQ;AAAA,IACnI,OAAW;AACL,qBAAe,KAAK,gBAAgB;AAAA,IACrC;AAAA,EACF;AAED,SAAO,CAAC,eAAe,cAAc;AAEvC;AAzBS;AA2BF,kCAAkC,QAAQ,UAAU,WAAW;AAEpE,MAAI,CAAC;AAAU,eAAW,iBAAiB,MAAM;AACjD,MAAI,CAAC;AAAW,gBAAY;AAE5B,QAAM,CAAC,eAAe,kBAAkB,0BAA0B,MAAM;AAExE,QAAM,QAAQ,cAAc,eAAe,EAAE,aAAa,SAAS,oBAAmB,CAAE;AACxF,QAAM,aAAa,mBAAmB,eAAe,EAAE,cAAc,SAAS,mBAAkB,CAAE;AAElG,QAAM,WAAW,EAAE,MAAM,UAAU,OAAO,WAAU;AAEpD,QAAM,UAAU,eAAe,IAAI,mBAAiB;AAClD,UAAM,eAAe,QAAQ,MAAM,YAAY,WAAW;AAAA,MACxD,OAAO,sBAAsB,eAAe,QAAQ;AAAA,MACpD,SAAS,sBAAsB,eAAe,QAAQ;AAAA,MACtD,QAAQ,gBAAgB,eAAe,QAAQ;AAAA,IACrD,CAAK;AACD,UAAM,OAAO;AAAA,MACX,OAAO,cAAc;AAAA,MAAI,GAAG;AAAA,IAClC;AACI,QAAI,CAAC,QAAQ,MAAM,cAAc,QAAQ,GAAG;AAC1C,WAAK,UAAU,MAAM,QAAQ;AAAA,IAC9B;AACD,WAAO;AAAA,EACX,CAAG;AAED,QAAM,OAAO,MAAM,wBAAwB,SAAS,OAAO;AAE3D,MAAI,CAAC,QAAQ,MAAM,cAAc,QAAQ,GAAG;AAC1C,UAAM,cAAc,OAAO;AAAA,MACzB,CAAC,UAAU,MAAM,OAAO;AAAA,MAAU,CAAC,SAAS,UAAU,MAAM,SAAS;AAAA,IAC3E,CAAK;AAAA,EACF;AAED,SAAO;AACT;AApCsB;AAsCf,8BAA8B,MAAM,SAAQ;AACjD,QAAM,WAAW,QAAQ,MAAM,YAAY,gBAAgB,IAAI,GAAG,QAAO,SAAS,CAAA,CAAE;AACpF,SAAO,KAAK,OAAO;AAAA,IACjB,GAAG,SAAQ,QAAQ,CAAE;AAAA,IAAE,CAAC,UAAU,MAAM,OAAO;AAAA,EACnD,CAAG;AACH;AALsB;AASf,sCAAsC,UAAU,EAAE,OAAO,OAAO,QAAQ,OAAO,eAAe,UAAU,IAAI;AAEjH,MAAI;AAAA,IACF;AAAA,IAAkB;AAAA,IAAmB;AAAA,IAAwB;AAAA,MAC3D,iBAAiB,UAAU,YAAY;AAE3C,MAAI,MAAM;AACR,UAAM,wBAAwB,uBAAuB,KAAK,eAAa,UAAU,SAAS,KAAK,IAAI;AACnG,QAAI,uBAAuB;AACzB,yBAAmB,sBAAsB,WAAW,sBAAsB,mBAAmB,mBAAmB,sBAAsB;AACtI,0BAAoB,sBAAsB,WAAW,sBAAsB,oBAAoB,oBAAoB,sBAAsB;AAAA,IAC1I;AAAA,EACF;AAED,MAAI,SAAS,qBAAqB;AAChC,UAAM,yBAAyB,qBAAqB,KAAK,UAAQ,KAAK,cAAcM,QAAkB,KAAK,CAAC;AAC5G,QAAI,wBAAwB;AAC1B,yBAAmB,uBAAuB,WAAW,uBAAuB,mBAAmB,mBAAmB,uBAAuB;AACzI,0BAAoB,uBAAuB,WAAW,uBAAuB,oBAAoB,oBAAoB,uBAAuB;AAAA,IAC7I;AAAA,EACF;AAED,SAAO;AAAA,IACL;AAAA,IAAkB;AAAA,EACnB;AACH;AAzBgB;AA2BhB,uBAAuB,WAAW,YAAY;AAE5C,QAAM,uBAAuB,KAAK,IAAI,GAAG,WAAW,IAAI,cAAY,SAAS,YAAY,CAAC;AAC1F,QAAM,WAAW,qBAAqB,SAAU,EAAC,MAAM,GAAG,EAAE,GAAG;AAE/D,MAAI,WAAWC,gBAAwB,YAAY,GAAG,QAAQ;AAC9D,MAAI,OAAO,KAAK,MAAM,YAAY,QAAQ;AAE1C,QAAM,SAAS,CAAA;AAEf,MAAI,cAAc;AAClB,QAAM,kBAAkB,WAAW,KAAK,cAAY,SAAS,OAAO;AACpE,MAAI,MAAM;AACR,kBAAc;AACd,WAAO,KAAK;AAAA,MACV,GAAG;AAAA,MACH;AAAA,MACA,UAAU;AAAA,MACV,iBAAiB;AAAA,MACjB,QAAQ,gBAAgB,aAAa,QAAQ,OAAO,IAAI;AAAA,IAC9D,CAAK;AAAA,EACF;AAED,aAAW,YAAY,YAAY;AAEjC,QAAI,aAAa,mBAAmB;AAAa;AAEjD,UAAM,cAAc,KAAK,MAAMA,gBAAwB,WAAW,SAAS,cAAc,QAAQ,CAAC;AAElG,eAAWA,gBAAwB,WAAY,cAAc,SAAS,cAAe,QAAQ;AAE7F,WAAO,KAAK;AAAA,MACV,GAAG;AAAA,MACH,MAAM,KAAK,MAAM,WAAW;AAAA,MAC5B,UAAU,KAAK,MAAM,WAAW;AAAA,MAChC,iBAAiB,KAAK,KAAK,YAAY,SAAS,YAAY;AAAA,MAC5D,QAAQ,SAAS,aAAa,QAAQ,OAAO,WAAW;AAAA,IAC9D,CAAK;AAAA,EACF;AAED,SAAO,KAAK,CAAC,GAAG,MAAM,EAAE,eAAe,EAAE,YAAY;AAErD,SAAO;AACT;AA3CS;AA6CF,uBAAuB,MAAM;AAAA,EAClC,SAAS;AAAA,EAAO,QAAQ;AAAA,EAAO,iBAAiB;AAAA,EAAO,gBAAgB;AAAA,EAAO,eAAe;AAAA,EAAO,WAAW;AAAA,IAC7G,IAAI;AAEN,MAAI,YAAY,CAAA;AAEhB,kBAAgB,iBAAiB,OAAO,aAAa;AACrD,MAAI,CAAC,eAAe,WAAW,CAAC,eAAe,YAAY;AACzD,oBAAgB;AAAA,EACjB;AAED,mBAAiB,iBAAiB,QAAQ,cAAc;AACxD,MAAI,CAAC,gBAAgB,WAAW,CAAC,gBAAgB,YAAY;AAC3D,qBAAiB;AAAA,EAClB;AAED,iBAAe,gBAAgB,gBAAgB,IAAI;AAEnD,MAAI,cAAc,MAAM;AACtB,WAAO;AAAA,EACR;AAED,MAAI,WAAW,iBAAiB,SAAS;AAGzC,MAAI,WAAW;AACf,MAAI,gBAAgB;AAElB,eAAW,6BAA6B,QAAQ;AAAA,MAC9C;AAAA,MAAM,OAAO;AAAA,MAAO,cAAc;AAAA,IACnC,CAAA,EAAE;AAAA,EAEJ,WAAU,eAAe;AAExB,eAAW,6BAA6B,OAAO;AAAA,MAC7C;AAAA,MAAM,OAAO;AAAA,MAAQ,cAAc;AAAA,IACpC,CAAA,EAAE;AAAA,EAEJ;AAED,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACR;AAED,QAAM,eAAe,qBAAqB,QAAQ;AAClD,QAAM,aAAa,mBAAmB,UAAU,EAAE,cAAc,QAAQ,KAAI,CAAE;AAI9E,QAAM,uBAAuB,KAAK,IAAI,GAAG,WAAW,IAAI,cAAY,SAAS,YAAY,CAAC;AAC1F,QAAM,WAAW,qBAAqB,SAAU,EAAC,MAAM,GAAG,EAAE,GAAG;AAG/D,MAAI,CAAC,aAAa,mBAAmB;AAEnC,UAAM,cAAc,YAAY,KAAK,SAAU,GAAE,KAAK,UAAU,oBAAoB;AAGpF,UAAM,WAAWA,gBAAwB,cAAc,UAAU,QAAQ;AACzE,UAAM,aAAa,cAAc,UAAU,UAAU;AAIrD,QAAI,YAAYA,gBAAwB,cAAc,WAAW,UAAU,QAAQ;AACnF,QAAI,SAAS,cAAc,WAAW,UAAU;AAEhD,QAAI,UAAU;AAEZ,gBAAU,KAAK;AAAA,QACb;AAAA,QACA,iBAAiB,WAAW,OAAO,WAAS,MAAM,IAAI,EAAE,IAAI,WAAS,MAAM,MAAM,EAAE,KAAK,GAAG;AAAA,QAC3F;AAAA,QACA,aAAa,OAAO,OAAO,WAAS,MAAM,IAAI,EAAE,IAAI,WAAS,MAAM,MAAM,EAAE,KAAK,GAAG;AAAA,QACnF;AAAA,QACA;AAAA,QACA,SAAS;AAAA,QACT,aAAa;AAAA,QACb;AAAA,MACR,CAAO;AAAA,IAEF;AAAA,EACF;AAGD,MAAI,aAAa,OAAO,QAAQ;AAE9B,gBAAY,UAAU,OAAO,aAAa,OAAO,IAAI,gBAAc;AACjE,YAAM,SAAS,WAAW,IAAI,WAAS;AACrC,cAAM,eAAe,MAAM,QAAQ,IAAI;AACvC,cAAM,OAAO,KAAK,MAAM,MAAM,WAAW,eAAe,QAAQ;AAChE,cAAM,WAAW,KAAK,MAAM,MAAM,WAAW,YAAY;AACzD,cAAM,OAAO,KAAK,KAAK,SAAS,MAAM,IAAI;AAC1C,eAAO;AAAA,UACL,GAAG;AAAA,UACH;AAAA,UACA;AAAA,UACA,aAAa,OAAO,MAAM,aAAa,QAAQ,OAAO,IAAI,IAAI;AAAA,UAC9D,iBAAiB,WAAW,MAAM,aAAa,QAAQ,OAAO,QAAQ,IAAI;AAAA,QACpF;AAAA,MACA,CAAO;AAED,aAAO;AAAA,QACL;AAAA,QACA,aAAa,OAAO,OAAO,WAAS,MAAM,WAAW,EAAE,IAAI,WAAS,MAAM,WAAW,EAAE,KAAK,GAAG;AAAA,QAC/F,iBAAiB,OAAO,OAAO,WAAS,MAAM,eAAe,EAAE,IAAI,WAAS,MAAM,eAAe,EAAE,KAAK,GAAG;AAAA,QAC3G,aAAa;AAAA,QACb;AAAA,MACD;AAAA,IACF,CAAA,CAAC;AAAA,EACH;AAED,QAAM,0BAA0B,eAAe;AAC/C,QAAM,wBAAwB,eAAe;AAG7C,MAAI,CAAC;AAAO,WAAO;AAEnB,QAAM,sBAAsB,mBAAmB,OAAO,EAAE,aAAc,CAAA;AACtE,QAAM,kBAAkB,oBAAoB,IAAI,cAAY,SAAS,WAAW,SAAS,YAAY,EAAE,OAAO,CAAC,KAAK,QAAQ,MAAM,KAAK,CAAC;AAGxI,aAAW,cAAc,WAAW;AAClC,eAAW,cAAc;AACzB,QAAI,WAAW,aAAa,QAAW;AACrC,UAAI;AAAyB;AAC7B,iBAAW,cAAc,KAAK,MAAM,kBAAkB,WAAW,QAAQ;AACzE,iBAAW,OAAO,QAAQ,WAAS;AACjC,cAAM,cAAc,WAAW;AAAA,MACvC,CAAO;AAAA,IACP,OAAW;AACL,UAAI;AAAuB;AAC3B,iBAAW,SAAS,WAAW,QAAQ;AACrC,YAAI,MAAM,SAAS,aAAa;AAC9B,gBAAM,oBAAoB,OAAO,YAAY,MAAM,MAAM,MAAM,KAAK,IAAI,CAAC;AACzE,gBAAM,gBAAgB;AACtB,gBAAM,cAAc,KAAK,MAAM,oBAAoB,MAAM,QAAQ;AACjE,qBAAW,cAAc,KAAK,IAAI,WAAW,aAAa,MAAM,WAAW;AAAA,QACrF,OAAe;AACL,gBAAM,YAAYH,gBAA0B,MAAM,OAAO,MAAM,KAAK,IAAI;AACxE,gBAAM,eAAe,YAAYC,gBAA0B,SAAS,IAAI;AACxE,gBAAM,gBAAgB;AACtB,gBAAM,cAAc,KAAK,MAAM,eAAe,MAAM,QAAQ;AAC5D,qBAAW,cAAc,KAAK,IAAI,WAAW,aAAa,MAAM,WAAW;AAAA,QAC5E;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAED,SAAO;AACT;AArJgB;AAuJT,2BAA2B,YAAY;AAAA,EAC5C,SAAS;AAAA,EAAO,QAAQ;AAAA,EAAO,iBAAiB;AAAA,EAAO,gBAAgB;AAAA,IACrE,IAAI;AAEN,mBAAiB,iBAAiB,QAAQ,cAAc;AACxD,MAAI,CAAC,gBAAgB,WAAW,CAAC,gBAAgB,YAAY;AAC3D,qBAAiB;AAAA,EAClB;AAED,kBAAgB,iBAAiB,OAAO,aAAa;AACrD,MAAI,CAAC,eAAe,WAAW,CAAC,eAAe,YAAY;AACzD,oBAAgB;AAAA,EACjB;AAED,QAAM,WAAW,iBAAiB,SAAS;AAC3C,QAAM,eAAe,qBAAqB,QAAQ;AAClD,QAAM,aAAa,mBAAmB,UAAU,EAAE,cAAc,QAAQ,KAAI,CAAE;AAC9E,QAAM,uBAAuB,KAAK,IAAI,GAAG,WAAW,IAAI,cAAY,SAAS,YAAY,CAAC;AAC1F,QAAM,WAAW,qBAAqB,SAAU,EAAC,MAAM,GAAG,EAAE,GAAG;AAE/D,QAAM,sBAAsB,mBAAmB,OAAO,EAAE,cAAc,QAAQ,KAAI,CAAE;AAEpF,QAAM,0BAA0B,eAAe;AAE/C,QAAM,cAAc,WAAW,IAAI,UAAQ;AACvC,UAAM,SAAS,cAAc,KAAK,MAAM;AAAA,MACtC;AAAA,MAAQ;AAAA,MAAO;AAAA,MAAgB;AAAA,MAAe,cAAc,KAAK;AAAA,MAAc,UAAU,KAAK,YAAY;AAAA,IAC3G,CAAA,EAAE,KAAK,gBAAgB;AACxB,WAAO;AAAA,MACL,GAAG;AAAA,MAAQ,MAAM,KAAK;AAAA,IAC9B;AAAA,EACA,CAAK,EACA,OAAO,CAAC,WAAW,eAAe;AAEjC,QAAI,CAAC,WAAW;AAAa,aAAO;AAEpC,QAAI,WAAW,SAAS;AAEtB,gBAAU,oBAAoBE,gBAAwB,UAAU,oBAAoB,WAAW,WAAW,QAAQ;AAClH,gBAAU,UAAU;AAAA,IAE5B,OAAa;AAEL,iBAAW,SAAS,WAAW,QAAQ;AAErC,YAAI,gBAAgB,UAAU,YAAY,KAAK,gBAAc;AAC3D,iBAAO,WAAW,OAAO,MAAM,MAAO,WAAW,SAAS,MAAM,QAAQ,WAAW,QAAQ,MAAM,OAAO,WAAW,SAAS,MAAM;AAAA,QAC9I,CAAW;AAED,YAAI,eAAe;AACjB,wBAAc,QAAQ,MAAM;AAAA,QACxC,OAAiB;AACL,gBAAM,QAAQ,UAAU,YAAY,KAAK,KAAK;AAC9C,0BAAgB,UAAU,YAAY,QAAQ;AAC9C,wBAAc,WAAW;AAAA,QAC1B;AAED,sBAAc,YAAY,MAAM;AAChC,sBAAc,iBAAiB,MAAM;AAErC,YAAI,cAAc,gBAAgB,GAAG;AACnC,oBAAU,SAAS;AAAA,QACpB;AAAA,MACF;AAAA,IACF;AAED,cAAU,aAAa,KAAK;AAAA,MAC1B,MAAM;AAAA,MACN,MAAM,WAAW,KAAK;AAAA,MACtB,KAAK,WAAW,KAAK;AAAA,MACrB,UAAU,WAAW;AAAA,MACrB,MAAM,WAAW;AAAA,IAEzB,CAAO;AAED,WAAO;AAAA,EAEb,GAAO;AAAA,IACD,mBAAmB;AAAA,IAAG,QAAQ;AAAA,IAAM,SAAS;AAAA,IAAO,aAAa;IAAI,aAAa,CAAE;AAAA,IAEpF,cAAc,CAAA;AAAA,IAAI,aAAa,CAAE;AAAA,IAAE,eAAe,CAAE;AAAA,EAC1D,CAAK;AAEH,MAAI,YAAY,mBAAmB;AAGjC,UAAM,SAAS,cAAc,YAAY,mBAAmB,mBAAmB;AAG/E,QAAI,YAAY,YAAY;AAG5B,aAAS,IAAI,OAAO,SAAS,GAAG,KAAK,GAAG,KAAK;AAE3C,YAAM,QAAQ,OAAO;AAErB,YAAM,aAAa;AAAA,QACjB,GAAG;AAAA,QAAO,eAAe,0BAA0B,WAAW,MAAM;AAAA,QAAU,UAAU;AAAA,QAAG,YAAY;AAAA,MACxG;AAED,UAAI,MAAM,SAAS,QAAQ;AACzB,mBAAW,OAAO,MAAM,KAAK;AAAA,MAC9B;AAGD,UAAI,aAAa,KAAK,CAAC,MAAM,MAAM;AACjC,oBAAY,YAAY,KAAK,UAAU;AACvC;AAAA,MACD;AAGD,iBAAW,WAAW,WAAW,gBAAgB,MAAM,OAAO,WAAW,gBAAgB,MAAM;AAG/F,UAAI,MAAM,SAAS;AAEjB,cAAM,qBAAqBA,gBAAwB,WAAW,gBAAgB,MAAM,cAAc,QAAQ;AAC1G,YAAI,qBAAqB,WAAW;AAClC,qBAAW,WAAW,KAAK,KAAK,SAAS;AAAA,QAC1C;AAAA,MACF;AAED,kBAAY,YAAY,KAAK,UAAU;AAGvC,kBAAYA,gBAAwB,YAAa,WAAW,WAAW,MAAM,cAAe,QAAQ;AAAA,IAErG;AAID,WAAO,YAAY,GAAG;AAGpB,iBAAW,cAAc,YAAY,aAAa;AAGhD,YAAI,wBAAwB,WAAW,gBAAgB,WAAW;AAClE,YAAI,CAAC;AAAuB;AAG5B,cAAM,cAAc,KAAK,KAAK,KAAK,IAAI,uBAAuB,YAAY,WAAW,YAAY,CAAC;AAClG,mBAAW,YAAY;AACvB,oBAAYA,gBAAwB,YAAa,cAAc,WAAW,cAAe,QAAQ;AAEjG,YAAI,aAAa;AAAG;AAAA,MAErB;AAED,UAAI,YAAY,GAAG;AACjB,oBAAY,cAAc,YAAY,YAAY,KAAK,CAAC,GAAG,MAAM,EAAE,eAAe,EAAE,YAAY;AAAA,MACxG,OAAa;AACL;AAAA,MACD;AAAA,IACF;AAED,gBAAY,cAAc,YAAY,YAAY,KAAK,CAAC,GAAG,MAAM,EAAE,eAAe,EAAE,YAAY;AAGhG,QAAI,SAAS,KAAK,IAAI,SAAS;AAC/B,eAAW,YAAY,YAAY;AAEjC,UAAI,CAAC;AAAQ;AAGb,UAAI,cAAc,KAAK,MAAMA,gBAAwB,SAAS,SAAS,cAAc,QAAQ,CAAC;AAC9F,eAASA,gBAAwB,SAAU,cAAc,SAAS,cAAe,QAAQ;AAGzF,UAAI,aAAa;AAEf,cAAM,UAAU,YAAY,YAAY,KAAK,cAAW;AACtD,iBAAO,SAAQ,OAAO,SAAS,MAAO,SAAQ,SAAS,SAAS,QAAQ,SAAQ,QAAQ,SAAS,OAAO,SAAQ,SAAS,SAAS;AAAA,QAC5I,CAAS;AACD,YAAI,CAAC;AAAS;AAGd,YAAK,QAAQ,WAAW,eAAgB,GAAG;AAGzC,kBAAQ,YAAY;AAAA,QAC9B,OAAe;AAEL,sBAAY,YAAY,KAAK;AAAA,YAC3B,GAAG;AAAA,YAAU,YAAY;AAAA,YAAM,UAAU,cAAc,QAAQ;AAAA,UAC3E,CAAW;AACD,kBAAQ,WAAW;AAAA,QACpB;AAAA,MACF;AAAA,IACF;AAGD,gBAAY,gBAAgB,YAAY,YAAY,IAAI,WAAS;AAC/D,aAAO,EAAE,GAAG;IAClB,CAAK;AAID,QAAI,eAAe,YAAY,YAAY,OAAO,CAAC,KAAK,YAAW;AACjE,YAAM,WAAW,WAAW,KAAK,eAAY;AAC3C,eAAO,QAAO,OAAO,UAAS,MAAO,QAAO,SAAS,UAAS,QAAQ,QAAO,QAAQ,UAAS,OAAO,QAAO,SAAS,UAAS;AAAA,MACtI,CAAO;AACD,aAAO,MAAM,SAAS,YAAY,QAAO,WAAW,IAAK,SAAO,WAAW,SAAS,YAAY,QAAO;AAAA,IACxG,GAAE,CAAC;AAGJ,QAAI,cAAc;AAGhB,YAAM,kBAAkB,YAAY,cAAc,KAAK,WAAS,MAAM,WAAY,MAAM,WAAW,MAAM,eAAgB,YAAY;AACrI,UAAI,iBAAiB;AACnB,wBAAgB;AAChB,wBAAgB,IAAI,gBAAgB;AAAA,MAC5C,OAAa;AAEL,cAAM,kBAAkB,YAAY,cAAc,KAAK,WAAS,MAAM,YAAa,MAAM,WAAW,MAAM,eAAgB,YAAY;AACtI,wBAAgB;AAChB,wBAAgB,IAAI,gBAAgB;AAAA,MACrC;AAED,qBAAe,KAAK,IAAI,YAAY;AAGpC,iBAAW,YAAY,YAAY,eAAe;AAChD,YAAI,CAAC;AAAc;AACnB,YAAI,cAAc,KAAK,MAAMA,gBAAwB,eAAe,SAAS,cAAc,QAAQ,CAAC;AACpG,uBAAeA,gBAAwB,eAAgB,cAAc,SAAS,cAAe,QAAQ;AACrG,iBAAS,YAAY;AAAA,MACtB;AAAA,IACF;AAAA,EACF;AAED,cAAY,cAAc,YAAY,YAAY,OAAO,YAAY,WAAW;AAChF,cAAY,gBAAgB,YAAY,cAAc,OAAO,YAAY,WAAW;AAEpF,cAAY,kBAAkB,YAAY,YACvC,OAAO,WAAS,MAAM,IAAI,EAC1B,IAAI,WAAS;AACZ,WAAO,MAAM,aAAa,QAAQ,OAAO,MAAM,IAAI;AAAA,EACzD,CAAK,EAAE,KAAK,GAAG;AAEb,SAAO,YAAY;AAEnB,SAAO;AAET;AArPgB;ACzjBhB,gBAAgB;AAAG;AAAV;AACT,MAAM,WAAW,8BAAK,GAAL;AACjB,gBAAgB,KAAK,KAAK;AAEtB,aAAW,KAAK;AACZ,QAAI,KAAK,IAAI;AACjB,SAAO;AACX;AALS;AAcT,aAAa,IAAI;AACb,SAAO,GAAE;AACb;AAFS;AAGT,wBAAwB;AACpB,SAAO,uBAAO,OAAO,IAAI;AAC7B;AAFS;AAGT,iBAAiB,KAAK;AAClB,MAAI,QAAQ,GAAG;AACnB;AAFS;AAGT,qBAAqB,OAAO;AACxB,SAAO,OAAO,UAAU;AAC5B;AAFS;AAGT,wBAAwB,GAAG,GAAG;AAC1B,SAAO,KAAK,IAAI,KAAK,IAAI,MAAM,KAAO,MAAK,OAAO,MAAM,YAAa,OAAO,MAAM;AACtF;AAFS;AAGT,IAAI;AACJ,uBAAuB,aAAa,KAAK;AACrC,MAAI,CAAC,sBAAsB;AACvB,2BAAuB,SAAS,cAAc,GAAG;AAAA,EACpD;AACD,uBAAqB,OAAO;AAC5B,SAAO,gBAAgB,qBAAqB;AAChD;AANS;AAUT,kBAAkB,KAAK;AACnB,SAAO,OAAO,KAAK,GAAG,EAAE,WAAW;AACvC;AAFS;AAQT,mBAAmB,UAAU,WAAW;AACpC,MAAI,SAAS,MAAM;AACf,WAAO;AAAA,EACV;AACD,QAAM,QAAQ,MAAM,UAAU,GAAG,SAAS;AAC1C,SAAO,MAAM,cAAc,MAAM,MAAM,YAAW,IAAK;AAC3D;AANS;AAOT,yBAAyB,OAAO;AAC5B,MAAI;AACJ,YAAU,OAAO,OAAK,QAAQ,CAAC,EAAC;AAChC,SAAO;AACX;AAJS;AAKT,6BAA6B,WAAW,OAAO,UAAU;AACrD,YAAU,GAAG,WAAW,KAAK,UAAU,OAAO,QAAQ,CAAC;AAC3D;AAFS;AAGT,qBAAqB,YAAY,KAAK,SAAS,IAAI;AAC/C,MAAI,YAAY;AACZ,UAAM,WAAW,iBAAiB,YAAY,KAAK,SAAS,EAAE;AAC9D,WAAO,WAAW,GAAG,QAAQ;AAAA,EAChC;AACL;AALS;AAMT,0BAA0B,YAAY,KAAK,SAAS,IAAI;AACpD,SAAO,WAAW,MAAM,KAClB,OAAO,QAAQ,IAAI,MAAO,GAAE,WAAW,GAAG,GAAG,GAAG,CAAC,CAAC,IAClD,QAAQ;AAClB;AAJS;AAKT,0BAA0B,YAAY,SAAS,OAAO,IAAI;AACtD,MAAI,WAAW,MAAM,IAAI;AACrB,UAAM,OAAO,WAAW,GAAG,GAAG,KAAK,CAAC;AACpC,QAAI,QAAQ,UAAU,QAAW;AAC7B,aAAO;AAAA,IACV;AACD,QAAI,OAAO,SAAS,UAAU;AAC1B,YAAM,SAAS,CAAA;AACf,YAAM,MAAM,KAAK,IAAI,QAAQ,MAAM,QAAQ,KAAK,MAAM;AACtD,eAAS,IAAI,GAAG,IAAI,KAAK,KAAK,GAAG;AAC7B,eAAO,KAAK,QAAQ,MAAM,KAAK,KAAK;AAAA,MACvC;AACD,aAAO;AAAA,IACV;AACD,WAAO,QAAQ,QAAQ;AAAA,EAC1B;AACD,SAAO,QAAQ;AACnB;AAjBS;AAkBT,0BAA0B,MAAM,iBAAiB,KAAK,SAAS,cAAc,qBAAqB;AAC9F,MAAI,cAAc;AACd,UAAM,eAAe,iBAAiB,iBAAiB,KAAK,SAAS,mBAAmB;AACxF,SAAK,EAAE,cAAc,YAAY;AAAA,EACpC;AACL;AALS;AAUT,kCAAkC,SAAS;AACvC,MAAI,QAAQ,IAAI,SAAS,IAAI;AACzB,UAAM,QAAQ,CAAA;AACd,UAAM,SAAS,QAAQ,IAAI,SAAS;AACpC,aAAS,IAAI,GAAG,IAAI,QAAQ,KAAK;AAC7B,YAAM,KAAK;AAAA,IACd;AACD,WAAO;AAAA,EACV;AACD,SAAO;AACX;AAVS;AAWT,gCAAgC,OAAO;AACnC,QAAM,SAAS,CAAA;AACf,aAAW,KAAK;AACZ,QAAI,EAAE,OAAO;AACT,aAAO,KAAK,MAAM;AAC1B,SAAO;AACX;AANS;AA+BT,uBAAuB,OAAO;AAC1B,SAAO,SAAS,OAAO,KAAK;AAChC;AAFS;AAGT,yBAAyB,OAAO,KAAK,OAAO;AACxC,QAAM,IAAI,KAAK;AACf,SAAO;AACX;AAHS;AAKT,0BAA0B,eAAe;AACrC,SAAO,iBAAiB,YAAY,cAAc,OAAO,IAAI,cAAc,UAAU;AACzF;AAFS;AAIT,MAAM,YAAY,OAAO,WAAW;AACpC,IAAI,MAAM,YACJ,MAAM,OAAO,YAAY,IAAK,IAC9B,MAAM,KAAK;AACjB,IAAI,MAAM,YAAY,QAAM,sBAAsB,EAAE,IAAI;AASxD,MAAM,QAAQ,oBAAI;AAClB,mBAAmB,MAAK;AACpB,QAAM,QAAQ,UAAQ;AAClB,QAAI,CAAC,KAAK,EAAE,IAAG,GAAG;AACd,YAAM,OAAO,IAAI;AACjB,WAAK,EAAC;AAAA,IACT;AAAA,EACT,CAAK;AACD,MAAI,MAAM,SAAS;AACf,QAAI,SAAS;AACrB;AATS;AAoBT,gBAAc,UAAU;AACpB,MAAI;AACJ,MAAI,MAAM,SAAS;AACf,QAAI,SAAS;AACjB,SAAO;AAAA,IACH,SAAS,IAAI,QAAQ,aAAW;AAC5B,YAAM,IAAI,OAAO,EAAE,GAAG,UAAU,GAAG,QAAO,CAAE;AAAA,IACxD,CAAS;AAAA,IACD,QAAQ;AACJ,YAAM,OAAO,IAAI;AAAA,IACpB;AAAA,EACT;AACA;AAZSC;AAmHT,gBAAgB,QAAQ,MAAM;AAC1B,SAAO,YAAY,IAAI;AAC3B;AAFS;AAYT,4BAA4B,MAAM;AAC9B,MAAI,CAAC;AACD,WAAO;AACX,QAAM,OAAO,KAAK,cAAc,KAAK,YAAa,IAAG,KAAK;AAC1D,MAAI,QAAQ,KAAK,MAAM;AACnB,WAAO;AAAA,EACV;AACD,SAAO,KAAK;AAChB;AARS;AAST,iCAAiC,MAAM;AACnC,QAAM,gBAAgB,QAAQ,OAAO;AACrC,oBAAkB,mBAAmB,IAAI,GAAG,aAAa;AACzD,SAAO,cAAc;AACzB;AAJS;AAKT,2BAA2B,MAAM,OAAO;AACpC,SAAO,KAAK,QAAQ,MAAM,KAAK;AACnC;AAFS;AA2BT,gBAAgB,QAAQ,MAAM,QAAQ;AAClC,SAAO,aAAa,MAAM,UAAU,IAAI;AAC5C;AAFS;AAWT,gBAAgB,MAAM;AAClB,OAAK,WAAW,YAAY,IAAI;AACpC;AAFS;AAGT,sBAAsB,YAAY,WAAW;AACzC,WAAS,IAAI,GAAG,IAAI,WAAW,QAAQ,KAAK,GAAG;AAC3C,QAAI,WAAW;AACX,iBAAW,GAAG,EAAE,SAAS;AAAA,EAChC;AACL;AALS;AAMT,iBAAiB,MAAM;AACnB,SAAO,SAAS,cAAc,IAAI;AACtC;AAFS;AAkBT,qBAAqB,MAAM;AACvB,SAAO,SAAS,gBAAgB,8BAA8B,IAAI;AACtE;AAFS;AAGT,cAAc,MAAM;AAChB,SAAO,SAAS,eAAe,IAAI;AACvC;AAFS;AAGT,iBAAiB;AACb,SAAO,KAAK,GAAG;AACnB;AAFS;AAGT,iBAAiB;AACb,SAAO,KAAK,EAAE;AAClB;AAFS;AAGT,gBAAgB,MAAM,OAAO,SAAS,SAAS;AAC3C,OAAK,iBAAiB,OAAO,SAAS,OAAO;AAC7C,SAAO,MAAM,KAAK,oBAAoB,OAAO,SAAS,OAAO;AACjE;AAHS;AAIT,yBAAyB,IAAI;AACzB,SAAO,SAAU,OAAO;AACpB,UAAM,eAAc;AAEpB,WAAO,GAAG,KAAK,MAAM,KAAK;AAAA,EAClC;AACA;AANS;AAOT,0BAA0B,IAAI;AAC1B,SAAO,SAAU,OAAO;AACpB,UAAM,gBAAe;AAErB,WAAO,GAAG,KAAK,MAAM,KAAK;AAAA,EAClC;AACA;AANS;AAqBT,cAAc,MAAM,WAAW,OAAO;AAClC,MAAI,SAAS;AACT,SAAK,gBAAgB,SAAS;AAAA,WACzB,KAAK,aAAa,SAAS,MAAM;AACtC,SAAK,aAAa,WAAW,KAAK;AAC1C;AALS;AAsDT,mBAAmB,OAAO;AACtB,SAAO,UAAU,KAAK,OAAO,CAAC;AAClC;AAFS;AAUT,kBAAkB,UAAS;AACvB,SAAO,MAAM,KAAK,SAAQ,UAAU;AACxC;AAFS;AAyHT,kBAAkB,OAAM,MAAM;AAC1B,SAAO,KAAK;AACZ,MAAI,MAAK,cAAc;AACnB,UAAK,OAAO;AACpB;AAJS;AAKT,yBAAyB,OAAO,OAAO;AACnC,QAAM,QAAQ,SAAS,OAAO,KAAK;AACvC;AAFS;AAWT,mBAAmB,MAAM,KAAK,OAAO,WAAW;AAC5C,MAAI,UAAU,MAAM;AAChB,SAAK,MAAM,eAAe,GAAG;AAAA,EAChC,OACI;AACD,SAAK,MAAM,YAAY,KAAK,OAAO,YAAY,cAAc,EAAE;AAAA,EAClE;AACL;AAPS;AAQT,uBAAuB,QAAQ,OAAO;AAClC,WAAS,IAAI,GAAG,IAAI,OAAO,QAAQ,QAAQ,KAAK,GAAG;AAC/C,UAAM,SAAS,OAAO,QAAQ;AAC9B,QAAI,OAAO,YAAY,OAAO;AAC1B,aAAO,WAAW;AAClB;AAAA,IACH;AAAA,EACJ;AACD,SAAO,gBAAgB;AAC3B;AATS;AAgBT,sBAAsB,QAAQ;AAC1B,QAAM,kBAAkB,OAAO,cAAc,UAAU,KAAK,OAAO,QAAQ;AAC3E,SAAO,mBAAmB,gBAAgB;AAC9C;AAHS;AA4DT,sBAAsB,UAAS,MAAM,QAAQ;AACzC,WAAQ,UAAU,SAAS,QAAQ,UAAU,IAAI;AACrD;AAFS;AAGT,sBAAsB,MAAM,QAAQ,EAAE,UAAU,OAAO,aAAa,UAAU,IAAI;AAC9E,QAAM,IAAI,SAAS,YAAY,aAAa;AAC5C,IAAE,gBAAgB,MAAM,SAAS,YAAY,MAAM;AACnD,SAAO;AACX;AAJS;AAQT,MAAM,QAAQ;AAAA,EACV,YAAY,SAAS,OAAO;AACxB,SAAK,SAAS;AACd,SAAK,SAAS;AACd,SAAK,IAAI,KAAK,IAAI;AAAA,EACrB;AAAA,EACD,EAAE,MAAM;AACJ,SAAK,EAAE,IAAI;AAAA,EACd;AAAA,EACD,EAAE,MAAM,QAAQ,SAAS,MAAM;AAC3B,QAAI,CAAC,KAAK,GAAG;AACT,UAAI,KAAK;AACL,aAAK,IAAI,YAAY,OAAO,QAAQ;AAAA;AAEpC,aAAK,IAAI,QAAQ,OAAO,QAAQ;AACpC,WAAK,IAAI;AACT,WAAK,EAAE,IAAI;AAAA,IACd;AACD,SAAK,EAAE,MAAM;AAAA,EAChB;AAAA,EACD,EAAE,MAAM;AACJ,SAAK,EAAE,YAAY;AACnB,SAAK,IAAI,MAAM,KAAK,KAAK,EAAE,UAAU;AAAA,EACxC;AAAA,EACD,EAAE,QAAQ;AACN,aAAS,IAAI,GAAG,IAAI,KAAK,EAAE,QAAQ,KAAK,GAAG;AACvC,aAAO,KAAK,GAAG,KAAK,EAAE,IAAI,MAAM;AAAA,IACnC;AAAA,EACJ;AAAA,EACD,EAAE,MAAM;AACJ,SAAK,EAAC;AACN,SAAK,EAAE,IAAI;AACX,SAAK,EAAE,KAAK,CAAC;AAAA,EAChB;AAAA,EACD,IAAI;AACA,SAAK,EAAE,QAAQ,MAAM;AAAA,EACxB;AACL;AArCM;AA2EN,MAAM,iBAAiB,oBAAI;AAC3B,IAAI,SAAS;AAEb,cAAc,KAAK;AACf,MAAI,QAAO;AACX,MAAI,IAAI,IAAI;AACZ,SAAO;AACH,YAAS,UAAQ,KAAK,QAAQ,IAAI,WAAW,CAAC;AAClD,SAAO,UAAS;AACpB;AANS;AAOT,kCAAkC,KAAK,MAAM;AACzC,QAAM,OAAO,EAAE,YAAY,wBAAwB,IAAI,GAAG,OAAO,CAAA;AACjE,iBAAe,IAAI,KAAK,IAAI;AAC5B,SAAO;AACX;AAJS;AAKT,qBAAqB,MAAM,GAAG,GAAG,UAAU,OAAO,MAAM,IAAI,MAAM,GAAG;AACjE,QAAM,OAAO,SAAS;AACtB,MAAI,YAAY;AAChB,WAAS,IAAI,GAAG,KAAK,GAAG,KAAK,MAAM;AAC/B,UAAM,IAAI,IAAK,KAAI,KAAK,KAAK,CAAC;AAC9B,iBAAa,IAAI,MAAM,KAAK,GAAG,GAAG,IAAI,CAAC;AAAA;AAAA,EAC1C;AACD,QAAM,OAAO,YAAY,SAAS,GAAG,GAAG,IAAI,CAAC;AAAA;AAC7C,QAAM,OAAO,YAAY,KAAK,IAAI,KAAK;AACvC,QAAM,MAAM,mBAAmB,IAAI;AACnC,QAAM,EAAE,YAAY,UAAU,eAAe,IAAI,GAAG,KAAK,yBAAyB,KAAK,IAAI;AAC3F,MAAI,CAAC,MAAM,OAAO;AACd,UAAM,QAAQ;AACd,eAAW,WAAW,cAAc,QAAQ,QAAQ,WAAW,SAAS,MAAM;AAAA,EACjF;AACD,QAAM,YAAY,KAAK,MAAM,aAAa;AAC1C,OAAK,MAAM,YAAY,GAAG,YAAY,GAAG,gBAAgB,KAAK,QAAQ,qBAAqB;AAC3F,YAAU;AACV,SAAO;AACX;AAnBS;AAoBT,qBAAqB,MAAM,MAAM;AAC7B,QAAM,WAAY,MAAK,MAAM,aAAa,IAAI,MAAM,IAAI;AACxD,QAAM,QAAO,SAAS,OAAO,OACvB,UAAQ,KAAK,QAAQ,IAAI,IAAI,IAC7B,UAAQ,KAAK,QAAQ,UAAU,MAAM,EAC/C;AACI,QAAM,UAAU,SAAS,SAAS,MAAK;AACvC,MAAI,SAAS;AACT,SAAK,MAAM,YAAY,MAAK,KAAK,IAAI;AACrC,cAAU;AACV,QAAI,CAAC;AACD;EACP;AACL;AAbS;AAcT,uBAAuB;AACnB,MAAI,MAAM;AACN,QAAI;AACA;AACJ,mBAAe,QAAQ,UAAQ;AAC3B,YAAM,EAAE,eAAe;AACvB,UAAI,IAAI,WAAW,SAAS;AAC5B,aAAO;AACH,mBAAW,WAAW,CAAC;AAC3B,WAAK,QAAQ;IACzB,CAAS;AACD,mBAAe,MAAK;AAAA,EAC5B,CAAK;AACL;AAbS;AAeT,0BAA0B,MAAM,MAAM,IAAI,QAAQ;AAC9C,MAAI,CAAC;AACD,WAAO;AACX,QAAM,KAAK,KAAK;AAChB,MAAI,KAAK,SAAS,GAAG,QAAQ,KAAK,UAAU,GAAG,SAAS,KAAK,QAAQ,GAAG,OAAO,KAAK,WAAW,GAAG;AAC9F,WAAO;AACX,QAAM;AAAA,IAAE,QAAQ;AAAA,IAAG,WAAW;AAAA,IAAK,SAAS;AAAA,IAE5C,OAAO,aAAa,IAAG,IAAK;AAAA,IAE5B,MAAM,aAAa;AAAA,IAAU,OAAO;AAAA,IAAM;AAAA,MAAQ,GAAG,MAAM,EAAE,MAAM,GAAI,GAAE,MAAM;AAC/E,MAAI,UAAU;AACd,MAAI,UAAU;AACd,MAAI;AACJ,mBAAiB;AACb,QAAI,KAAK;AACL,aAAO,YAAY,MAAM,GAAG,GAAG,UAAU,OAAO,QAAQ,GAAG;AAAA,IAC9D;AACD,QAAI,CAAC,OAAO;AACR,gBAAU;AAAA,IACb;AAAA,EACJ;AAPQ;AAQT,kBAAgB;AACZ,QAAI;AACA,kBAAY,MAAM,IAAI;AAC1B,cAAU;AAAA,EACb;AAJQ;AAKTA,SAAK,UAAO;AACR,QAAI,CAAC,WAAW,QAAO,YAAY;AAC/B,gBAAU;AAAA,IACb;AACD,QAAI,WAAW,QAAO,KAAK;AACvB,WAAK,GAAG,CAAC;AACT;IACH;AACD,QAAI,CAAC,SAAS;AACV,aAAO;AAAA,IACV;AACD,QAAI,SAAS;AACT,YAAM,IAAI,OAAM;AAChB,YAAM,IAAI,IAAI,IAAI,OAAO,IAAI,QAAQ;AACrC,WAAK,GAAG,IAAI,CAAC;AAAA,IAChB;AACD,WAAO;AAAA,EACf,CAAK;AACD;AACA,OAAK,GAAG,CAAC;AACT,SAAO;AACX;AAhDS;AAiDT,sBAAsB,MAAM;AACxB,QAAM,QAAQ,iBAAiB,IAAI;AACnC,MAAI,MAAM,aAAa,cAAc,MAAM,aAAa,SAAS;AAC7D,UAAM,EAAE,OAAO,WAAW;AAC1B,UAAM,IAAI,KAAK;AACf,SAAK,MAAM,WAAW;AACtB,SAAK,MAAM,QAAQ;AACnB,SAAK,MAAM,SAAS;AACpB,kBAAc,MAAM,CAAC;AAAA,EACxB;AACL;AAVS;AAWT,uBAAuB,MAAM,GAAG;AAC5B,QAAM,IAAI,KAAK;AACf,MAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK;AACtC,UAAM,QAAQ,iBAAiB,IAAI;AACnC,UAAM,YAAY,MAAM,cAAc,SAAS,KAAK,MAAM;AAC1D,SAAK,MAAM,YAAY,GAAG,uBAAuB,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE;AAAA,EACpF;AACL;AAPS;AAST,IAAI;AACJ,+BAA+B,WAAW;AACtC,sBAAoB;AACxB;AAFS;AAGT,iCAAiC;AAC7B,MAAI,CAAC;AACD,UAAM,IAAI,MAAM,kDAAkD;AACtE,SAAO;AACX;AAJS;AAcT,mBAAmB,IAAI;AACnB,wBAAuB,EAAC,GAAG,WAAW,KAAK,EAAE;AACjD;AAFS;AAmBT,oBAAoB,KAAK,SAAS;AAC9B,wBAAqB,EAAG,GAAG,QAAQ,IAAI,KAAK,OAAO;AACnD,SAAO;AACX;AAHS;AAIT,oBAAoB,KAAK;AACrB,SAAO,sBAAuB,EAAC,GAAG,QAAQ,IAAI,GAAG;AACrD;AAFS;AAYT,gBAAgB,WAAW,OAAO;AAC9B,QAAM,YAAY,UAAU,GAAG,UAAU,MAAM;AAC/C,MAAI,WAAW;AAEX,cAAU,QAAQ,QAAQ,QAAM,GAAG,KAAK,MAAM,KAAK,CAAC;AAAA,EACvD;AACL;AANS;AAQT,MAAM,mBAAmB,CAAA;AAEzB,MAAM,oBAAoB,CAAA;AAC1B,MAAM,mBAAmB,CAAA;AACzB,MAAM,kBAAkB,CAAA;AACxB,MAAM,mBAAmB,QAAQ;AACjC,IAAI,mBAAmB;AACvB,2BAA2B;AACvB,MAAI,CAAC,kBAAkB;AACnB,uBAAmB;AACnB,qBAAiB,KAAK,KAAK;AAAA,EAC9B;AACL;AALS;AAUT,6BAA6B,IAAI;AAC7B,mBAAiB,KAAK,EAAE;AAC5B;AAFS;AAGT,4BAA4B,IAAI;AAC5B,kBAAgB,KAAK,EAAE;AAC3B;AAFS;AAqBT,MAAM,iBAAiB,oBAAI;AAC3B,IAAI,WAAW;AACf,iBAAiB;AACb,QAAM,kBAAkB;AACxB,KAAG;AAGC,WAAO,WAAW,iBAAiB,QAAQ;AACvC,YAAM,YAAY,iBAAiB;AACnC;AACA,4BAAsB,SAAS;AAC/B,aAAO,UAAU,EAAE;AAAA,IACtB;AACD,0BAAsB,IAAI;AAC1B,qBAAiB,SAAS;AAC1B,eAAW;AACX,WAAO,kBAAkB;AACrB,wBAAkB,IAAG;AAIzB,aAAS,IAAI,GAAG,IAAI,iBAAiB,QAAQ,KAAK,GAAG;AACjD,YAAM,WAAW,iBAAiB;AAClC,UAAI,CAAC,eAAe,IAAI,QAAQ,GAAG;AAE/B,uBAAe,IAAI,QAAQ;AAC3B;MACH;AAAA,IACJ;AACD,qBAAiB,SAAS;AAAA,EAClC,SAAa,iBAAiB;AAC1B,SAAO,gBAAgB,QAAQ;AAC3B,oBAAgB,IAAG;EACtB;AACD,qBAAmB;AACnB,iBAAe,MAAK;AACpB,wBAAsB,eAAe;AACzC;AAnCS;AAoCT,gBAAgB,IAAI;AAChB,MAAI,GAAG,aAAa,MAAM;AACtB,OAAG,OAAM;AACT,YAAQ,GAAG,aAAa;AACxB,UAAM,QAAQ,GAAG;AACjB,OAAG,QAAQ,CAAC,EAAE;AACd,OAAG,YAAY,GAAG,SAAS,EAAE,GAAG,KAAK,KAAK;AAC1C,OAAG,aAAa,QAAQ,mBAAmB;AAAA,EAC9C;AACL;AATS;AAWT,IAAI;AACJ,gBAAgB;AACZ,MAAI,CAAC,SAAS;AACV,cAAU,QAAQ;AAClB,YAAQ,KAAK,MAAM;AACf,gBAAU;AAAA,IACtB,CAAS;AAAA,EACJ;AACD,SAAO;AACX;AARS;AAST,kBAAkB,MAAM,WAAW,MAAM;AACrC,OAAK,cAAc,aAAa,GAAG,YAAY,UAAU,UAAU,MAAM,CAAC;AAC9E;AAFS;AAGT,MAAM,WAAW,oBAAI;AACrB,IAAI;AACJ,wBAAwB;AACpB,WAAS;AAAA,IACL,GAAG;AAAA,IACH,GAAG,CAAE;AAAA,IACL,GAAG;AAAA,EACX;AACA;AANS;AAOT,wBAAwB;AACpB,MAAI,CAAC,OAAO,GAAG;AACX,YAAQ,OAAO,CAAC;AAAA,EACnB;AACD,WAAS,OAAO;AACpB;AALS;AAMT,uBAAuB,OAAO,OAAO;AACjC,MAAI,SAAS,MAAM,GAAG;AAClB,aAAS,OAAO,KAAK;AACrB,UAAM,EAAE,KAAK;AAAA,EAChB;AACL;AALS;AAMT,wBAAwB,OAAO,OAAO,SAAQ,UAAU;AACpD,MAAI,SAAS,MAAM,GAAG;AAClB,QAAI,SAAS,IAAI,KAAK;AAClB;AACJ,aAAS,IAAI,KAAK;AAClB,WAAO,EAAE,KAAK,MAAM;AAChB,eAAS,OAAO,KAAK;AACrB,UAAI,UAAU;AACV,YAAI;AACA,gBAAM,EAAE,CAAC;AACb;MACH;AAAA,IACb,CAAS;AACD,UAAM,EAAE,KAAK;AAAA,EAChB,WACQ,UAAU;AACf;EACH;AACL;AAlBS;AAmBT,MAAM,kBAAkB,EAAE,UAAU;AACpC,8BAA8B,MAAM,IAAI,QAAQ;AAC5C,MAAI,SAAS,GAAG,MAAM,MAAM;AAC5B,MAAI,UAAU;AACd,MAAI;AACJ,MAAI;AACJ,MAAI,MAAM;AACV,qBAAmB;AACf,QAAI;AACA,kBAAY,MAAM,cAAc;AAAA,EACvC;AAHQ;AAIT,gBAAc;AACV,UAAM,EAAE,QAAQ,GAAG,WAAW,KAAK,SAAS,UAAU,OAAO,MAAM,QAAQ,UAAU;AACrF,QAAI;AACA,uBAAiB,YAAY,MAAM,GAAG,GAAG,UAAU,OAAO,QAAQ,KAAK,KAAK;AAChF,SAAK,GAAG,CAAC;AACT,UAAM,aAAa,IAAK,IAAG;AAC3B,UAAM,WAAW,aAAa;AAC9B,QAAI;AACA,WAAK,MAAK;AACd,cAAU;AACV,wBAAoB,MAAM,SAAS,MAAM,MAAM,OAAO,CAAC;AACvD,WAAOA,OAAK,UAAO;AACf,UAAI,SAAS;AACT,YAAI,QAAO,UAAU;AACjB,eAAK,GAAG,CAAC;AACT,mBAAS,MAAM,MAAM,KAAK;AAC1B;AACA,iBAAO,UAAU;AAAA,QACpB;AACD,YAAI,QAAO,YAAY;AACnB,gBAAM,IAAI,OAAQ,QAAM,cAAc,QAAQ;AAC9C,eAAK,GAAG,IAAI,CAAC;AAAA,QAChB;AAAA,MACJ;AACD,aAAO;AAAA,IACnB,CAAS;AAAA,EACJ;AA1BQ;AA2BT,MAAI,UAAU;AACd,SAAO;AAAA,IACH,QAAQ;AACJ,UAAI;AACA;AACJ,gBAAU;AACV,kBAAY,IAAI;AAChB,UAAI,YAAY,MAAM,GAAG;AACrB,iBAAS,OAAM;AACf,aAAM,EAAC,KAAK,EAAE;AAAA,MACjB,OACI;AACD;MACH;AAAA,IACJ;AAAA,IACD,aAAa;AACT,gBAAU;AAAA,IACb;AAAA,IACD,MAAM;AACF,UAAI,SAAS;AACT;AACA,kBAAU;AAAA,MACb;AAAA,IACJ;AAAA,EACT;AACA;AA9DS;AA+DT,+BAA+B,MAAM,IAAI,QAAQ;AAC7C,MAAI,SAAS,GAAG,MAAM,MAAM;AAC5B,MAAI,UAAU;AACd,MAAI;AACJ,QAAM,QAAQ;AACd,QAAM,KAAK;AACX,gBAAc;AACV,UAAM,EAAE,QAAQ,GAAG,WAAW,KAAK,SAAS,UAAU,OAAO,MAAM,QAAQ,UAAU;AACrF,QAAI;AACA,uBAAiB,YAAY,MAAM,GAAG,GAAG,UAAU,OAAO,QAAQ,GAAG;AACzE,UAAM,aAAa,IAAK,IAAG;AAC3B,UAAM,WAAW,aAAa;AAC9B,wBAAoB,MAAM,SAAS,MAAM,OAAO,OAAO,CAAC;AACxDA,WAAK,UAAO;AACR,UAAI,SAAS;AACT,YAAI,QAAO,UAAU;AACjB,eAAK,GAAG,CAAC;AACT,mBAAS,MAAM,OAAO,KAAK;AAC3B,cAAI,CAAC,EAAE,MAAM,GAAG;AAGZ,oBAAQ,MAAM,CAAC;AAAA,UAClB;AACD,iBAAO;AAAA,QACV;AACD,YAAI,QAAO,YAAY;AACnB,gBAAM,IAAI,OAAQ,QAAM,cAAc,QAAQ;AAC9C,eAAK,IAAI,GAAG,CAAC;AAAA,QAChB;AAAA,MACJ;AACD,aAAO;AAAA,IACnB,CAAS;AAAA,EACJ;AA1BQ;AA2BT,MAAI,YAAY,MAAM,GAAG;AACrB,SAAI,EAAG,KAAK,MAAM;AAEd,eAAS,OAAM;AACf;IACZ,CAAS;AAAA,EACJ,OACI;AACD;EACH;AACD,SAAO;AAAA,IACH,IAAI,OAAO;AACP,UAAI,SAAS,OAAO,MAAM;AACtB,eAAO,KAAK,GAAG,CAAC;AAAA,MACnB;AACD,UAAI,SAAS;AACT,YAAI;AACA,sBAAY,MAAM,cAAc;AACpC,kBAAU;AAAA,MACb;AAAA,IACJ;AAAA,EACT;AACA;AAvDS;AAwDT,yCAAyC,MAAM,IAAI,QAAQ,OAAO;AAC9D,MAAI,SAAS,GAAG,MAAM,MAAM;AAC5B,MAAI,IAAI,QAAQ,IAAI;AACpB,MAAI,kBAAkB;AACtB,MAAI,kBAAkB;AACtB,MAAI,iBAAiB;AACrB,6BAA2B;AACvB,QAAI;AACA,kBAAY,MAAM,cAAc;AAAA,EACvC;AAHQ;AAIT,iBAAc,SAAS,UAAU;AAC7B,UAAM,IAAK,QAAQ,IAAI;AACvB,gBAAY,KAAK,IAAI,CAAC;AACtB,WAAO;AAAA,MACH,GAAG;AAAA,MACH,GAAG,QAAQ;AAAA,MACX;AAAA,MACA;AAAA,MACA,OAAO,QAAQ;AAAA,MACf,KAAK,QAAQ,QAAQ;AAAA,MACrB,OAAO,QAAQ;AAAA,IAC3B;AAAA,EACK;AAZQ;AAaT,cAAY,GAAG;AACX,UAAM,EAAE,QAAQ,GAAG,WAAW,KAAK,SAAS,UAAU,OAAO,MAAM,QAAQ,UAAU;AACrF,UAAM,UAAU;AAAA,MACZ,OAAO,IAAG,IAAK;AAAA,MACf;AAAA,IACZ;AACQ,QAAI,CAAC,GAAG;AAEJ,cAAQ,QAAQ;AAChB,aAAO,KAAK;AAAA,IACf;AACD,QAAI,mBAAmB,iBAAiB;AACpC,wBAAkB;AAAA,IACrB,OACI;AAGD,UAAI,KAAK;AACL;AACA,yBAAiB,YAAY,MAAM,GAAG,GAAG,UAAU,OAAO,QAAQ,GAAG;AAAA,MACxE;AACD,UAAI;AACA,aAAK,GAAG,CAAC;AACb,wBAAkB,MAAK,SAAS,QAAQ;AACxC,0BAAoB,MAAM,SAAS,MAAM,GAAG,OAAO,CAAC;AACpDA,aAAK,UAAO;AACR,YAAI,mBAAmB,OAAM,gBAAgB,OAAO;AAChD,4BAAkB,MAAK,iBAAiB,QAAQ;AAChD,4BAAkB;AAClB,mBAAS,MAAM,gBAAgB,GAAG,OAAO;AACzC,cAAI,KAAK;AACL;AACA,6BAAiB,YAAY,MAAM,GAAG,gBAAgB,GAAG,gBAAgB,UAAU,GAAG,QAAQ,OAAO,GAAG;AAAA,UAC3G;AAAA,QACJ;AACD,YAAI,iBAAiB;AACjB,cAAI,QAAO,gBAAgB,KAAK;AAC5B,iBAAK,IAAI,gBAAgB,GAAG,IAAI,CAAC;AACjC,qBAAS,MAAM,gBAAgB,GAAG,KAAK;AACvC,gBAAI,CAAC,iBAAiB;AAElB,kBAAI,gBAAgB,GAAG;AAEnB;cACH,OACI;AAED,oBAAI,CAAC,EAAE,gBAAgB,MAAM;AACzB,0BAAQ,gBAAgB,MAAM,CAAC;AAAA,cACtC;AAAA,YACJ;AACD,8BAAkB;AAAA,UACrB,WACQ,QAAO,gBAAgB,OAAO;AACnC,kBAAM,IAAI,OAAM,gBAAgB;AAChC,gBAAI,gBAAgB,IAAI,gBAAgB,IAAI,OAAO,IAAI,gBAAgB,QAAQ;AAC/E,iBAAK,GAAG,IAAI,CAAC;AAAA,UAChB;AAAA,QACJ;AACD,eAAO,CAAC,CAAE,oBAAmB;AAAA,MAC7C,CAAa;AAAA,IACJ;AAAA,EACJ;AA9DQ;AA+DT,SAAO;AAAA,IACH,IAAI,GAAG;AACH,UAAI,YAAY,MAAM,GAAG;AACrB,aAAI,EAAG,KAAK,MAAM;AAEd,mBAAS,OAAM;AACf,aAAG,CAAC;AAAA,QACxB,CAAiB;AAAA,MACJ,OACI;AACD,WAAG,CAAC;AAAA,MACP;AAAA,IACJ;AAAA,IACD,MAAM;AACF;AACA,wBAAkB,kBAAkB;AAAA,IACvC;AAAA,EACT;AACA;AAxGS;AAkMT,uBAAuB,OAAO,QAAQ;AAClC,QAAM,EAAE,CAAC;AACT,SAAO,OAAO,MAAM,GAAG;AAC3B;AAHS;AAIT,iCAAiC,OAAO,QAAQ;AAC5C,iBAAe,OAAO,GAAG,GAAG,MAAM;AAC9B,WAAO,OAAO,MAAM,GAAG;AAAA,EAC/B,CAAK;AACL;AAJS;AAST,yCAAyC,OAAO,QAAQ;AACpD,QAAM,EAAC;AACP,0BAAwB,OAAO,MAAM;AACzC;AAHS;AAIT,2BAA2B,YAAY,OAAO,SAAS,SAAS,KAAK,MAAM,QAAQ,MAAM,SAAS,oBAAmB,OAAM,aAAa;AACpI,MAAI,IAAI,WAAW;AACnB,MAAI,IAAI,KAAK;AACb,MAAI,IAAI;AACR,QAAM,cAAc,CAAA;AACpB,SAAO;AACH,gBAAY,WAAW,GAAG,OAAO;AACrC,QAAM,aAAa,CAAA;AACnB,QAAM,aAAa,oBAAI;AACvB,QAAM,SAAS,oBAAI;AACnB,MAAI;AACJ,SAAO,KAAK;AACR,UAAM,YAAY,YAAY,KAAK,MAAM,CAAC;AAC1C,UAAM,MAAM,QAAQ,SAAS;AAC7B,QAAI,QAAQ,OAAO,IAAI,GAAG;AAC1B,QAAI,CAAC,OAAO;AACR,cAAQ,mBAAkB,KAAK,SAAS;AACxC,YAAM,EAAC;AAAA,IACV,WACQ,SAAS;AACd,YAAM,EAAE,WAAW,KAAK;AAAA,IAC3B;AACD,eAAW,IAAI,KAAK,WAAW,KAAK,KAAK;AACzC,QAAI,OAAO;AACP,aAAO,IAAI,KAAK,KAAK,IAAI,IAAI,YAAY,IAAI,CAAC;AAAA,EACrD;AACD,QAAM,YAAY,oBAAI;AACtB,QAAM,WAAW,oBAAI;AACrB,mBAAgB,OAAO;AACnB,kBAAc,OAAO,CAAC;AACtB,UAAM,EAAE,MAAM,KAAI;AAClB,WAAO,IAAI,MAAM,KAAK,KAAK;AAC3B,YAAO,MAAM;AACb;AAAA,EACH;AANQ;AAOT,SAAO,KAAK,GAAG;AACX,UAAM,YAAY,WAAW,IAAI;AACjC,UAAM,YAAY,WAAW,IAAI;AACjC,UAAM,UAAU,UAAU;AAC1B,UAAM,UAAU,UAAU;AAC1B,QAAI,cAAc,WAAW;AAEzB,cAAO,UAAU;AACjB;AACA;AAAA,IACH,WACQ,CAAC,WAAW,IAAI,OAAO,GAAG;AAE/B,cAAQ,WAAW,MAAM;AACzB;AAAA,IACH,WACQ,CAAC,OAAO,IAAI,OAAO,KAAK,UAAU,IAAI,OAAO,GAAG;AACrD,cAAO,SAAS;AAAA,IACnB,WACQ,SAAS,IAAI,OAAO,GAAG;AAC5B;AAAA,IACH,WACQ,OAAO,IAAI,OAAO,IAAI,OAAO,IAAI,OAAO,GAAG;AAChD,eAAS,IAAI,OAAO;AACpB,cAAO,SAAS;AAAA,IACnB,OACI;AACD,gBAAU,IAAI,OAAO;AACrB;AAAA,IACH;AAAA,EACJ;AACD,SAAO,KAAK;AACR,UAAM,YAAY,WAAW;AAC7B,QAAI,CAAC,WAAW,IAAI,UAAU,GAAG;AAC7B,cAAQ,WAAW,MAAM;AAAA,EAChC;AACD,SAAO;AACH,YAAO,WAAW,IAAI,EAAE;AAC5B,SAAO;AACX;AA1ES;AAsFT,2BAA2B,QAAQ,SAAS;AACxC,QAAM,UAAS,CAAA;AACf,QAAM,cAAc,CAAA;AACpB,QAAM,gBAAgB,EAAE,SAAS;AACjC,MAAI,IAAI,OAAO;AACf,SAAO,KAAK;AACR,UAAM,IAAI,OAAO;AACjB,UAAM,IAAI,QAAQ;AAClB,QAAI,GAAG;AACH,iBAAW,OAAO,GAAG;AACjB,YAAI,CAAE,QAAO;AACT,sBAAY,OAAO;AAAA,MAC1B;AACD,iBAAW,OAAO,GAAG;AACjB,YAAI,CAAC,cAAc,MAAM;AACrB,kBAAO,OAAO,EAAE;AAChB,wBAAc,OAAO;AAAA,QACxB;AAAA,MACJ;AACD,aAAO,KAAK;AAAA,IACf,OACI;AACD,iBAAW,OAAO,GAAG;AACjB,sBAAc,OAAO;AAAA,MACxB;AAAA,IACJ;AAAA,EACJ;AACD,aAAW,OAAO,aAAa;AAC3B,QAAI,CAAE,QAAO;AACT,cAAO,OAAO;AAAA,EACrB;AACD,SAAO;AACX;AAhCS;AAiCT,2BAA2B,cAAc;AACrC,SAAO,OAAO,iBAAiB,YAAY,iBAAiB,OAAO,eAAe;AACtF;AAFS;AAmNT,cAAc,WAAW,MAAM,UAAU;AACrC,QAAM,QAAQ,UAAU,GAAG,MAAM;AACjC,MAAI,UAAU,QAAW;AACrB,cAAU,GAAG,MAAM,SAAS;AAC5B,aAAS,UAAU,GAAG,IAAI,MAAM;AAAA,EACnC;AACL;AANS;AAOT,0BAA0B,OAAO;AAC7B,WAAS,MAAM;AACnB;AAFS;AAMT,yBAAyB,WAAW,QAAQ,QAAQ,eAAe;AAC/D,QAAM,EAAE,UAAU,UAAU,YAAY,iBAAiB,UAAU;AACnE,cAAY,SAAS,EAAE,QAAQ,MAAM;AACrC,MAAI,CAAC,eAAe;AAEhB,wBAAoB,MAAM;AACtB,YAAM,iBAAiB,SAAS,IAAI,GAAG,EAAE,OAAO,WAAW;AAC3D,UAAI,YAAY;AACZ,mBAAW,KAAK,GAAG,cAAc;AAAA,MACpC,OACI;AAGD,gBAAQ,cAAc;AAAA,MACzB;AACD,gBAAU,GAAG,WAAW;IACpC,CAAS;AAAA,EACJ;AACD,eAAa,QAAQ,mBAAmB;AAC5C;AAnBS;AAoBT,2BAA2B,WAAW,WAAW;AAC7C,QAAM,KAAK,UAAU;AACrB,MAAI,GAAG,aAAa,MAAM;AACtB,YAAQ,GAAG,UAAU;AACrB,OAAG,YAAY,GAAG,SAAS,EAAE,SAAS;AAGtC,OAAG,aAAa,GAAG,WAAW;AAC9B,OAAG,MAAM;EACZ;AACL;AAVS;AAWT,oBAAoB,WAAW,GAAG;AAC9B,MAAI,UAAU,GAAG,MAAM,OAAO,IAAI;AAC9B,qBAAiB,KAAK,SAAS;AAC/B;AACA,cAAU,GAAG,MAAM,KAAK,CAAC;AAAA,EAC5B;AACD,YAAU,GAAG,MAAO,IAAI,KAAM,MAAO,KAAM,IAAI;AACnD;AAPS;AAQT,cAAc,WAAW,SAAS,WAAU,kBAAiB,WAAW,OAAO,eAAe,QAAQ,CAAC,EAAE,GAAG;AACxG,QAAM,mBAAmB;AACzB,wBAAsB,SAAS;AAC/B,QAAM,KAAK,UAAU,KAAK;AAAA,IACtB,UAAU;AAAA,IACV,KAAK;AAAA,IAEL;AAAA,IACA,QAAQ;AAAA,IACR;AAAA,IACA,OAAO,aAAc;AAAA,IAErB,UAAU,CAAE;AAAA,IACZ,YAAY,CAAE;AAAA,IACd,eAAe,CAAE;AAAA,IACjB,eAAe,CAAE;AAAA,IACjB,cAAc,CAAE;AAAA,IAChB,SAAS,IAAI,IAAI,QAAQ,WAAY,oBAAmB,iBAAiB,GAAG,UAAU,CAAA,EAAG;AAAA,IAEzF,WAAW,aAAc;AAAA,IACzB;AAAA,IACA,YAAY;AAAA,IACZ,MAAM,QAAQ,UAAU,iBAAiB,GAAG;AAAA,EACpD;AACI,mBAAiB,cAAc,GAAG,IAAI;AACtC,MAAI,QAAQ;AACZ,KAAG,MAAM,YACH,UAAS,WAAW,QAAQ,SAAS,CAAE,GAAE,CAAC,GAAG,QAAQ,SAAS;AAC5D,UAAM,QAAQ,KAAK,SAAS,KAAK,KAAK;AACtC,QAAI,GAAG,OAAO,UAAU,GAAG,IAAI,IAAI,GAAG,IAAI,KAAK,KAAK,GAAG;AACnD,UAAI,CAAC,GAAG,cAAc,GAAG,MAAM;AAC3B,WAAG,MAAM,GAAG,KAAK;AACrB,UAAI;AACA,mBAAW,WAAW,CAAC;AAAA,IAC9B;AACD,WAAO;AAAA,EACnB,CAAS,IACC;AACN,KAAG,OAAM;AACT,UAAQ;AACR,UAAQ,GAAG,aAAa;AAExB,KAAG,WAAW,mBAAkB,iBAAgB,GAAG,GAAG,IAAI;AAC1D,MAAI,QAAQ,QAAQ;AAChB,QAAI,QAAQ,SAAS;AAEjB,YAAM,QAAQ,SAAS,QAAQ,MAAM;AAErC,SAAG,YAAY,GAAG,SAAS,EAAE,KAAK;AAClC,YAAM,QAAQ,MAAM;AAAA,IACvB,OACI;AAED,SAAG,YAAY,GAAG,SAAS,EAAC;AAAA,IAC/B;AACD,QAAI,QAAQ;AACR,oBAAc,UAAU,GAAG,QAAQ;AACvC,oBAAgB,WAAW,QAAQ,QAAQ,QAAQ,QAAQ,QAAQ,aAAa;AAEhF;EACH;AACD,wBAAsB,gBAAgB;AAC1C;AA9DS;AA+GT,MAAM,gBAAgB;AAAA,EAClB,WAAW;AACP,sBAAkB,MAAM,CAAC;AACzB,SAAK,WAAW;AAAA,EACnB;AAAA,EACD,IAAI,MAAM,UAAU;AAChB,UAAM,YAAa,KAAK,GAAG,UAAU,SAAU,MAAK,GAAG,UAAU,QAAQ,CAAA;AACzE,cAAU,KAAK,QAAQ;AACvB,WAAO,MAAM;AACT,YAAM,QAAQ,UAAU,QAAQ,QAAQ;AACxC,UAAI,UAAU;AACV,kBAAU,OAAO,OAAO,CAAC;AAAA,IACzC;AAAA,EACK;AAAA,EACD,KAAK,SAAS;AACV,QAAI,KAAK,SAAS,CAAC,SAAS,OAAO,GAAG;AAClC,WAAK,GAAG,aAAa;AACrB,WAAK,MAAM,OAAO;AAClB,WAAK,GAAG,aAAa;AAAA,IACxB;AAAA,EACJ;AACL;AArBM;ACn7DN,MAAM,mBAAmB,CAAA;AAMzB,kBAAkB,OAAO,OAAO;AAC5B,SAAO;AAAA,IACH,WAAW,SAAS,OAAO,KAAK,EAAE;AAAA,EAC1C;AACA;AAJS;AAUT,kBAAkB,OAAO,QAAQ,MAAM;AACnC,MAAI;AACJ,QAAM,cAAc,oBAAI;AACxB,eAAa,WAAW;AACpB,QAAI,eAAe,OAAO,SAAS,GAAG;AAClC,cAAQ;AACR,UAAI,MAAM;AACN,cAAM,YAAY,CAAC,iBAAiB;AACpC,mBAAW,cAAc,aAAa;AAClC,qBAAW;AACX,2BAAiB,KAAK,YAAY,KAAK;AAAA,QAC1C;AACD,YAAI,WAAW;AACX,mBAAS,IAAI,GAAG,IAAI,iBAAiB,QAAQ,KAAK,GAAG;AACjD,6BAAiB,GAAG,GAAG,iBAAiB,IAAI,EAAE;AAAA,UACjD;AACD,2BAAiB,SAAS;AAAA,QAC7B;AAAA,MACJ;AAAA,IACJ;AAAA,EACJ;AAjBQ;AAkBT,mBAAgB,IAAI;AAChB,QAAI,GAAG,KAAK,CAAC;AAAA,EAChB;AAFQ;AAGT,sBAAmB,MAAK,aAAa,MAAM;AACvC,UAAM,aAAa,CAAC,MAAK,UAAU;AACnC,gBAAY,IAAI,UAAU;AAC1B,QAAI,YAAY,SAAS,GAAG;AACxB,aAAO,MAAM,GAAG,KAAK;AAAA,IACxB;AACD,SAAI,KAAK;AACT,WAAO,MAAM;AACT,kBAAY,OAAO,UAAU;AAC7B,UAAI,YAAY,SAAS,GAAG;AACxB;AACA,eAAO;AAAA,MACV;AAAA,IACb;AAAA,EACK;AAdQ;AAeT,SAAO,EAAE,KAAK,iBAAQ;AAC1B;AAxCS;AAyCT,iBAAiB,QAAQ,IAAI,eAAe;AACxC,QAAM,SAAS,CAAC,MAAM,QAAQ,MAAM;AACpC,QAAM,eAAe,SACf,CAAC,MAAM,IACP;AACN,QAAM,OAAO,GAAG,SAAS;AACzB,SAAO,SAAS,eAAe,CAAC,QAAQ;AACpC,QAAI,SAAS;AACb,UAAM,SAAS,CAAA;AACf,QAAI,UAAU;AACd,QAAI,UAAU;AACd,UAAM,OAAO,6BAAM;AACf,UAAI,SAAS;AACT;AAAA,MACH;AACD;AACA,YAAM,SAAS,GAAG,SAAS,OAAO,KAAK,QAAQ,GAAG;AAClD,UAAI,MAAM;AACN,YAAI,MAAM;AAAA,MACb,OACI;AACD,kBAAU,YAAY,MAAM,IAAI,SAAS;AAAA,MAC5C;AAAA,IACb,GAZqB;AAab,UAAM,gBAAgB,aAAa,IAAI,CAAC,OAAO,MAAM,UAAU,OAAO,CAAC,UAAU;AAC7E,aAAO,KAAK;AACZ,iBAAW,CAAE,MAAK;AAClB,UAAI,QAAQ;AACR;MACH;AAAA,IACb,GAAW,MAAM;AACL,iBAAY,KAAK;AAAA,IACpB,CAAA,CAAC;AACF,aAAS;AACT;AACA,WAAO,uCAAgB;AACnB,cAAQ,aAAa;AACrB;IACZ,GAHe;AAAA,EAIf,CAAK;AACL;AAxCS;AC5BT,MAAM,iBAAiB;AAavB,kBACA;AACG,SAAQ,EAAC,GAAG,IAAI,OAAO,OAAO,OAAO,OAAO,QAAQ,UAAU,CAAC,MAC7D,KAAK,YAAW,UAAU,WAAW,UAAU,gBAAgB,IAAI,WAAW,CAAC,CAAC,EAAE,KAAK,MAAM,IAAI,GAAG,SAAS,EAAE,CAAC;AACrH;AAJS;AAaT,OAAO,UAAU,CAAC,SAAS,eAAe,KAAK,IAAI;AA4BnD,4BAA4B,MAC5B;AAEG,MAAI,CAAC,QAAQ,KAAK,aAAa,QAC/B;AACG,WAAO,EAAE,MAAM,SAAS,iBAAiB,QAAQ,OAAM;AAAA,EACzD;AAGD,MAAI,KAAK,aAAa,sBACtB;AACG,WAAO,mBAAmB,KAAK,IAAI;AAAA,EACrC;AAED,QAAM,gBAAgB,WAAW,iBAAiB,IAAI;AAGtD,MAAI,cAAc,aAAa,WAAW,cAAc,aAAa,UACrE;AACG,WAAO,EAAE,MAAY,QAAQ,aAAa,cAAc;EAC1D;AAGD,MAAI,cAAc,WAAW,UAAU,cAAc,aAAa,UAClE;AACG,WAAO,EAAE,MAAY,QAAQ,aAAa,cAAc,sBAAsB,cAAc,SAAQ;AAAA,EACtG;AAGD,MAAI,cAAc,YAAY,KAC9B;AACG,WAAO,EAAE,MAAY,QAAQ,YAAY,cAAc;EACzD;AAGD,MAAI,cAAc,cAAc,QAChC;AACG,WAAO,EAAE,MAAY,QAAQ,cAAc,cAAc;EAC3D;AAGD,MAAI,cAAc,iBAAiB,UACnC;AACG,WAAO,EAAE,MAAY,QAAQ,iBAAiB,cAAc;EAC9D;AAGD,MAAI,cAAc,WAAW,QAC7B;AACG,WAAO,EAAE,MAAY,QAAQ,WAAW,cAAc;EACxD;AAGD,MAAI,cAAc,gBAAgB,QAClC;AACG,WAAO,EAAE,MAAY,QAAQ,gBAAgB,cAAc;EAC7D;AAGD,MAAI,cAAc,aAAa,QAC/B;AACG,WAAO,EAAE,MAAY,QAAQ,cAAc,cAAc;EAC3D;AAGD,QAAM,OAAO,cAAc,QAAQ,cAAc;AACjD,MAAI,SAAS,UAAU,SAAS,QAChC;AACG,WAAO,EAAE,MAAY,QAAQ,UAAU;EACzC;AAGD,QAAM,YAAY,cAAc,aAAa,cAAc;AAC3D,MAAI,cAAc,UAAU,cAAc,QAC1C;AACG,WAAO,EAAE,MAAY,QAAQ,eAAe;EAC9C;AAGD,QAAM,aAAa,cAAc,cAAc,cAAc;AAC7D,MAAI,eAAe,UAAU,eAAe,QAC5C;AACG,WAAO,EAAE,MAAY,QAAQ,gBAAgB;EAC/C;AAGD,MAAI,cAAc,cAAc,WAChC;AACG,WAAO,EAAE,MAAY,QAAQ,cAAc,cAAc;EAC3D;AAGD,MAAI,cAAc,eAAe,eAAe,cAAc,eAAe,WAC7E;AACG,WAAO,EAAE,MAAY,QAAQ,eAAe,cAAc;EAC5D;AAGD,MAAI,cAAc,4BAA4B,SAC9C;AACG,WAAO,EAAE,MAAY,QAAQ,oCAAmC;AAAA,EAClE;AAGD,MAAI,cAAc,WAAW,QAC7B;AACG,UAAM,cAAc,WAAW,iBAAiB,KAAK,UAAU;AAE/D,QAAI,YAAY,YAAY,UAAU,YAAY,YAAY,eAC9D;AACG,aAAO;AAAA,QACJ;AAAA,QACA,QAAQ,uBAAuB,cAAc;AAAA,MACzD;AAAA,IAEO,WACQ,YAAY,SAAS,0CAC9B;AACG,aAAO;AAAA,QACJ;AAAA,QACA,QAAQ,qCAAqC,cAAc;AAAA,MACvE;AAAA,IACO;AAAA,EACH;AAGD,QAAM,UAAU,cAAc;AAC9B,MAAI,CAAC,UAAU,SAAS,UAAU,SAAS,EAAE,QAAQ,OAAO,IAAI,MAC/D,QAAQ,QAAQ,OAAO,IAAI,MAC3B,QAAQ,QAAQ,QAAQ,IAAI,IAE7B;AACG,WAAO;AAAA,MACJ;AAAA,MACA,QAAQ,YAAY;AAAA,IAC7B;AAAA,EACI;AAED,SAAO,mBAAmB,KAAK,UAAU;AAC5C;AA3IS;AAoJT,MAAM,UAAU;AAShB,0BAA0B,OAC1B;AACG,MAAI,OAAO,UAAU,UAAU;AAAE,WAAO;AAAA,EAAS;AAEjD,QAAM,WAAW,QAAQ,KAAK,KAAK;AACnC,QAAM,SAAS,SAAS,KAAK;AAE7B,SAAO,YAAY,OAAO,SAAS,MAAM,IAAI,SAAS;AACzD;AARS;AAgBT,MAAM,2BAA2B,CAAC,aAAa;AAE/C,OAAO,OAAO,wBAAwB;AActC,4BAA4B,WAC5B;AACG,MAAI,cAAc,QAAQ,cAAc,QAAQ;AAAE,WAAO;AAAA,EAAQ;AAEjE,MAAI,kBAAkB;AACtB,MAAI,mBAAmB;AAGvB,aAAW,YAAY,0BACvB;AACG,UAAM,aAAa,OAAO,yBAAyB,WAAW,QAAQ;AACtE,QAAI,eAAe,UAAU,WAAW,QAAQ,UAAU,WAAW,QAAQ,QAAQ;AAAE,wBAAkB;AAAA,IAAQ;AAAA,EACnH;AAGD,QAAM,YAAY,OAAO,eAAe,SAAS;AAIjD,aAAW,YAAY,0BACvB;AACG,UAAM,aAAa,OAAO,yBAAyB,WAAW,QAAQ;AACtE,QAAI,eAAe,UAAU,WAAW,QAAQ,UAAU,WAAW,QAAQ,QAAQ;AAAE,yBAAmB;AAAA,IAAQ;AAAA,EACpH;AAED,SAAO,mBAAmB;AAC7B;AA1BS;AAmCT,oBAAoB,MACpB;AACG,QAAM,eAAe,MAAM,aAAa;AACxC,MAAI,OAAO,iBAAiB,YAAa,cAAa,WAAW,QAAQ,KAAK,iBAAiB,mBAC/F;AACG,WAAO;AAAA,EACT;AAED,QAAM,gBAAgB,MAAM,WAAW,aAAa;AACpD,SAAO,OAAO,kBAAkB,YAAa,eAAc,WAAW,QAAQ,KAC7E,kBAAkB;AACtB;AAXS;AAoBT,2BAA2B,MAC3B;AACG,MAAI,SAAS,QAAQ,SAAS,UAAU,OAAO,SAAS,YAAY;AAAE,WAAO;AAAA,EAAQ;AAKrF,QAAM,gBAAgB,MAAM,WAAW,aAAa;AACpD,MAAI,OAAO,kBAAkB,YAAa,eAAc,WAAW,QAAQ,KAAK,kBAAkB,mBAClG;AACG,WAAO;AAAA,EACT;AAED,SAAO,OAAO,WAAW,SACxB,OAAO,KAAK,UAAU,aAAa,cAAc,OAAO,KAAK,UAAU,QAAQ,aAC9E,OAAO,KAAK,WAAW;AAC5B;AAhBS;AAyBT,+BAA+B,WAC/B;AACG,SAAO,IAAI,QAAQ,CAAC,YACpB;AACG,QAAI,UAAS,GAAG,YAAY,UAAS,GAAG,SAAS,GACjD;AACG;AACA,qBAAe,UAAS,GAAG,UAAU,GAAG,GAAG,MAC3C;AACG,kBAAS,SAAQ;AACjB;MACZ,CAAU;AACD;IACF,OAED;AACG,gBAAS,SAAQ;AACjB;IACF;AAAA,EACP,CAAI;AACJ;AApBe;AAgCf,2BAA2B,QAAQ,UAAU,QAC7C;AACG,MAAI,OAAO,WAAW,UACtB;AACG,UAAM,IAAI,UAAU;AAAA,EAAmD,KAAK,UAAU,MAAM,IAAI;AAAA,EAClG;AAED,MAAI,CAAC,kBAAkB,OAAO,KAAK,GACnC;AACG,UAAM,IAAI,UACT;AAAA,EAAkF,KAAK,UAAU,MAAM,IAAI;AAAA,EAC9G;AAED,MAAI,OAAO,YAAY,UAAU,OAAO,OAAO,YAAY,WAC3D;AACG,UAAM,IAAI,UACT;AAAA,EAA+D,KAAK,UAAU,MAAM,IAAI;AAAA,EAC3F;AAED,MAAI,OAAO,UAAU,UAAU,OAAO,OAAO,UAAU,WACvD;AACG,UAAM,IAAI,UACT;AAAA,EAA6D,KAAK,UAAU,MAAM,IAAI;AAAA,EACzF;AAED,MAAI,OAAO,WAAW,UAAU,OAAO,OAAO,WAAW,YAAY,CAAE,QAAO,kBAAkB,gBAC/F,CAAE,QAAO,kBAAkB,eAAe,CAAE,QAAO,kBAAkB,mBACtE;AACG,UAAM,IAAI,UACT;AAAA,EACC,KAAK,UAAU,MAAM,IAAI;AAAA,EAC7B;AAED,MAAI,OAAO,WAAW,UAAU,OAAO,OAAO,WAAW,YAAY,CAAE,QAAO,kBAAkB,gBAC/F,CAAE,QAAO,kBAAkB,eAAe,CAAE,QAAO,kBAAkB,mBACtE;AACG,UAAM,IAAI,UACT;AAAA,EACC,KAAK,UAAU,MAAM,IAAI;AAAA,EAC7B;AAED,MAAI,OAAO,YAAY,UAAU,OAAO,OAAO,YAAY,cAAc,CAAE,QAAO,mBAAmB,QACpG,OAAO,OAAO,YAAY,UAC3B;AACG,UAAM,IAAI,UACT;AAAA,EAA+E,KAAK,UAAU,MAAM,IAAI;AAAA,EAC3G;AAKD,MAAI,OAAO,mBAAmB,UAAU,OAAO,OAAO,mBAAmB,UACzE;AACG,UAAM,IAAI,UACT;AAAA,EAAqE,KAAK,UAAU,MAAM,IAAI;AAAA,EACjG;AAGD,MAAI,OAAO,YAAY,UAAU,OAAO,OAAO,YAAY,UAC3D;AACG,UAAM,IAAI,UACT;AAAA,EAA+D,KAAK,UAAU,MAAM,IAAI;AAAA,EAC3F;AAGD,MAAI,OAAO,YAAY,QACvB;AACG,QAAI,OAAO,QAAQ,cAAc,UAAU,OAAO,OAAO,QAAQ,cAAc,WAC/E;AACG,YAAM,IAAI,UACT;AAAA,EAAyE,KAAK,UAAU,MAAM,IAAI;AAAA,IACrG;AAED,QAAI,OAAO,QAAQ,mBAAmB,UAAU,OAAO,OAAO,QAAQ,mBAAmB,WACzF;AACG,YAAM,IAAI,UACT;AAAA,EAA8E,KAAK,UAAU,MAAM,IAAI;AAAA,IAC1G;AAGD,QAAI,OAAO,QAAQ,oBAAoB,UAAU,OAAO,OAAO,QAAQ,oBAAoB,UAC3F;AACG,YAAM,IAAI,UACT;AAAA,EAAsE,KAAK,UAAU,MAAM,IAAI;AAAA,IAClG;AAAA,EACH;AAED,QAAM,eAAe,EAAE,GAAG;AAG1B,SAAO,aAAa;AAEpB,MAAI,kBAAkB,CAAA;AAItB,MAAI,OAAO,aAAa,YAAY,YACpC;AACG,UAAM,cAAc,aAAa;AACjC,WAAO,aAAa;AAEpB,UAAM,SAAS,YAAY,KAAK,OAAO;AACvC,QAAI,OAAO,WAAW,UACtB;AACG,wBAAkB,EAAE,GAAG;IACzB,OAED;AACG,YAAM,IAAI,MAAM;AAAA,EACf,KAAK,UAAU,MAAM,GAAG;AAAA,IAC3B;AAAA,EACH,WACQ,aAAa,mBAAmB,KACzC;AACG,sBAAkB,OAAO,YAAY,aAAa,OAAO;AACzD,WAAO,aAAa;AAAA,EACtB,WACQ,OAAO,aAAa,YAAY,UACzC;AACG,sBAAkB,aAAa;AAC/B,WAAO,aAAa;AAAA,EACtB;AAID,eAAa,QAAQ,gBAAgB,aAAa,OAAO,SAAS,MAAM;AAGxE,MAAI,MAAM,QAAQ,aAAa,QAAQ,GACvC;AACG,UAAM,YAAW,CAAA;AAEjB,aAAS,OAAO,GAAG,OAAO,aAAa,SAAS,QAAQ,QACxD;AACG,YAAM,QAAQ,aAAa,SAAS;AAEpC,UAAI,CAAC,kBAAkB,MAAM,KAAK,GAClC;AACG,cAAM,IAAI,MAAM,mEAAmE;AAAA,EAClF,KAAK,UAAU,MAAM,GAAG;AAAA,MAC3B;AAED,YAAM,QAAQ,gBAAgB,MAAM,OAAO,SAAS,MAAM;AAE1D,gBAAS,KAAK,KAAK;AAAA,IACrB;AAED,QAAI,UAAS,SAAS,GACtB;AACG,sBAAgB,WAAW;AAAA,IAC7B;AAED,WAAO,aAAa;AAAA,EACtB,WACQ,OAAO,aAAa,aAAa,UAC1C;AACG,QAAI,CAAC,kBAAkB,aAAa,SAAS,KAAK,GAClD;AACG,YAAM,IAAI,MAAM;AAAA,EACf,KAAK,UAAU,MAAM,GAAG;AAAA,IAC3B;AAED,iBAAa,SAAS,QAAQ,gBAAgB,aAAa,SAAS,OAAO,SAAS,MAAM;AAE1F,oBAAgB,WAAW,CAAC,aAAa,QAAQ;AACjD,WAAO,aAAa;AAAA,EACtB;AAED,MAAI,CAAE,cAAa,mBAAmB,MACtC;AACG,iBAAa,UAAU,oBAAI;EAC7B;AAED,eAAa,QAAQ,IAAI,YAAY,eAAe;AAEpD,SAAO;AACV;AAhLS;AA6LT,yBAAyB,OAAO,SAAS,QACzC;AAGG,MAAI,OAAO,UAAU,YACrB;AACG,UAAM,SAAS,MAAM,KAAK,OAAO;AACjC,QAAI,OAAO,WAAW,UACtB;AACG,aAAO;AAAA,IACT,OAED;AACG,YAAM,IAAI,MAAM;AAAA,EACf,KAAK,UAAU,MAAM,GAAG;AAAA,IAC3B;AAAA,EACH,WACQ,OAAO,UAAU,UAC1B;AACG,WAAO;AAAA,EACT,WACQ,UAAU,QACnB;AACG,UAAM,IAAI,MACT;AAAA,EAA2E,KAAK,UAAU,MAAM,GAAG;AAAA,EACtG;AAED,SAAO;AACV;AA5BS;AA6DT,mBAAmB,QAAQ,UAC3B;AACG,MAAI,WAAW,QAAQ,WAAW,QAAQ;AAAE,WAAO;AAAA,EAAQ;AAG3D,QAAM,cAAc,OAAO,yBAAyB,QAAQ,QAAQ;AACpE,MAAI,gBAAgB,UAAU,YAAY,QAAQ,QAAQ;AAAE,WAAO;AAAA,EAAO;AAG1E,WAAS,IAAI,OAAO,eAAe,MAAM,GAAG,GAAG,IAAI,OAAO,eAAe,CAAC,GAC1E;AACG,UAAM,aAAa,OAAO,yBAAyB,GAAG,QAAQ;AAC9D,QAAI,eAAe,UAAU,WAAW,QAAQ,QAAQ;AAAE,aAAO;AAAA,IAAO;AAAA,EAC1E;AAED,SAAO;AACV;AAhBS;AAiFT,sBAAsB,QAAQ,WAC9B;AAEG,MAAI,OAAO,WAAW,YAAY;AAAE,WAAO;AAAA,EAAQ;AAEnD,MAAI,WAAW,WAAW;AAAE,WAAO;AAAA,EAAO;AAG1C,WAAS,QAAQ,OAAO,eAAe,MAAM,GAAG,OAAO,QAAQ,OAAO,eAAe,KAAK,GAC1F;AACG,QAAI,UAAU,WAAW;AAAE,aAAO;AAAA,IAAO;AAAA,EAC3C;AAED,SAAO;AACV;AAdS;AA2ET,MAAM,eAAe;AAarB,mBAAmB,SAAS,CAAE,MAAK,WACnC;AACG,MAAI,OAAO,UAAU,SAAS,KAAK,MAAM,MAAM,cAC/C;AACG,UAAM,IAAI,UAAU,+CAA+C;AAAA,EACrE;AAED,WAAS,OAAO,GAAG,OAAO,UAAU,QAAQ,QAC5C;AACG,QAAI,OAAO,UAAU,SAAS,KAAK,UAAU,KAAK,MAAM,cACxD;AACG,YAAM,IAAI,UAAU,+BAA+B,4BAA4B;AAAA,IACjF;AAAA,EACH;AAED,SAAO,WAAW,QAAQ,GAAG,SAAS;AACzC;AAhBS;AAyBT,oBAAoB,OACpB;AACG,MAAI,UAAU,QAAQ,UAAU,UAAU,OAAO,UAAU,UAAU;AAAE,WAAO;AAAA,EAAQ;AAEtF,SAAO,OAAO,MAAM,OAAO,cAAc;AAC5C;AALS;AA4BT,kBAAkB,OAClB;AACG,SAAO,UAAU,QAAQ,OAAO,UAAU;AAC7C;AAHS;AAcT,uBAAuB,OACvB;AACG,MAAI,OAAO,UAAU,SAAS,KAAK,KAAK,MAAM,cAAc;AAAE,WAAO;AAAA,EAAQ;AAE7E,QAAM,YAAY,OAAO,eAAe,KAAK;AAC7C,SAAO,cAAc,QAAQ,cAAc,OAAO;AACrD;AANS;AAqBT,oBAAoB,MAAM,UAAU,eAAe,QACnD;AACG,MAAI,OAAO,SAAS,UAAU;AAAE,WAAO;AAAA,EAAe;AACtD,MAAI,OAAO,aAAa,UAAU;AAAE,WAAO;AAAA,EAAe;AAE1D,QAAM,SAAS,SAAS,MAAM,GAAG;AAGjC,WAAS,OAAO,GAAG,OAAO,OAAO,QAAQ,QACzC;AAEG,QAAI,OAAO,KAAK,OAAO,WAAW,eAAe,KAAK,OAAO,WAAW,MAAM;AAAE,aAAO;AAAA,IAAe;AAEtG,WAAO,KAAK,OAAO;AAAA,EACrB;AAED,SAAO;AACV;AAjBS;AAsCT,iBAAiB,MAAM,UAAU,OAAO,YAAY,OAAO,gBAAgB,MAC3E;AACG,MAAI,OAAO,SAAS,UAAU;AAAE,UAAM,IAAI,UAAU,2CAA2C;AAAA,EAAI;AACnG,MAAI,OAAO,aAAa,UAAU;AAAE,UAAM,IAAI,UAAU,8CAA8C;AAAA,EAAI;AAE1G,QAAM,SAAS,SAAS,MAAM,GAAG;AAGjC,WAAS,OAAO,GAAG,OAAO,OAAO,QAAQ,QACzC;AAEG,QAAI,MAAM,QAAQ,IAAI,GACtB;AACG,YAAM,SAAU,CAAC,OAAO;AAExB,UAAI,CAAC,OAAO,UAAU,MAAM,KAAK,SAAS,GAAG;AAAE,eAAO;AAAA,MAAQ;AAAA,IAChE;AAED,QAAI,SAAS,OAAO,SAAS,GAC7B;AACG,cAAQ;AAAA,aAEA;AACF,eAAK,OAAO,UAAU;AACtB;AAAA,aAEE;AACF,eAAK,OAAO,UAAU;AACtB;AAAA,aAEE;AACF,eAAK,OAAO,UAAU;AACtB;AAAA,aAEE;AACF,eAAK,OAAO,SAAS;AACrB;AAAA,aAEE;AACF,cAAI,OAAO,KAAK,OAAO,WAAW,aAAa;AAAE,iBAAK,OAAO,SAAS;AAAA,UAAQ;AAC9E;AAAA,aAEE;AACF,eAAK,OAAO,UAAU;AACtB;AAAA;AAAA,IAER,OAED;AAEG,UAAI,iBAAiB,OAAO,KAAK,OAAO,WAAW,aAAa;AAAE,aAAK,OAAO,SAAS,CAAE;AAAA,MAAG;AAG5F,UAAI,KAAK,OAAO,WAAW,QAAQ,OAAO,KAAK,OAAO,WAAW,UAAU;AAAE,eAAO;AAAA,MAAQ;AAE5F,aAAO,KAAK,OAAO;AAAA,IACrB;AAAA,EACH;AAED,SAAO;AACV;AA5DS;AAuET,oBAAoB,SAAS,CAAE,MAAK,WACpC;AAEG,WAAS,OAAO,GAAG,OAAO,UAAU,QAAQ,QAC5C;AACG,UAAM,MAAM,UAAU;AAEtB,eAAW,QAAQ,KACnB;AACG,UAAI,OAAO,UAAU,eAAe,KAAK,KAAK,IAAI,GAClD;AAEG,YAAI,KAAK,WAAW,IAAI,GACxB;AACG,iBAAO,OAAO,KAAK,MAAM,CAAC;AAC1B;AAAA,QACF;AAID,eAAO,QAAQ,OAAO,UAAU,eAAe,KAAK,QAAQ,IAAI,KAAK,OAAO,OAAO,gBAAgB,UACnG,IAAI,OAAO,gBAAgB,SAAS,WAAW,CAAA,GAAI,OAAO,OAAO,IAAI,KAAK,IAAI,IAAI;AAAA,MACpF;AAAA,IACH;AAAA,EACH;AAED,SAAO;AACV;AA3BS;AAsCT,iCAAiC,MAAM,EAAE,QAAQ,MAAM,aAAa,MAAM,QAAQ,MAAM,QAAQ,WAAW,CAAE,GAC7G;AACG,MAAI,OAAO,SAAS,UAAU;AAAE,WAAO;AAAA,EAAS;AAChD,MAAI,MAAM,QAAQ,KAAK,KAAK,CAAC,MAAM,SAAS,KAAK,IAAI,GAAG;AAAE,WAAO;AAAA,EAAS;AAE1E,MAAI,OAAO;AAEX,MAAI,OAAO,KAAK,SAAS,UACzB;AACG,UAAM,eAAe,KAAK,KAAK,WAAW,YAAY;AAEtD,QAAI,gBAAgB,YACpB;AACG,aAAO,KAAK;AAAA,IACd,WACQ,OACT;AACG,aAAO,KAAK;AAAA,IACd;AAAA,EACH,OAED;AACG,QAAI,SAAS,SAAS,KAAK,WAAW,KAAK,MAC3C;AACG,aAAO,SAAS,KAAK,WAAW,KAAK,QAAQ,KAAK,KAAK;AAAA,IACzD,WACQ,OAAO,KAAK,OAAO,UAC5B;AACG,UAAI,cAAc,OAAO,KAAK,SAAS,UACvC;AACG,eAAO,cAAc,KAAK,QAAQ,KAAK;AAAA,MACzC,WACQ,OACT;AACG,eAAO,GAAG,KAAK,QAAQ,KAAK;AAAA,MAC9B;AAAA,IACH;AAAA,EACH;AAED,SAAO;AACV;AAxCS;AC7gCT,MAAM,gBAAgB;AAAA,EAUlB,OAAO,YAAY,GAAG,GAAG;AACrB,QAAI,MAAM,GAAG;AACT,aAAO;AAAA,IACV;AACD,QAAI,MAAM,QAAQ,MAAM,MAAM;AAC1B,aAAO;AAAA,IACV;AAED,QAAI,EAAE,WAAW,EAAE,QAAQ;AACvB,aAAO;AAAA,IACV;AACD,aAAS,OAAO,EAAE,QAAQ,EAAE,QAAQ,KAAI;AAEpC,UAAI,EAAE,UAAU,EAAE,OAAO;AACrB,eAAO;AAAA,MACV;AAAA,IACJ;AACD,WAAO;AAAA,EACV;AAAA,EAYD,OAAO,WAAW,KAAK,OAAO,GAAG;AAC7B,QAAI,KAAK,aAAa,MAAM,KAAK,aAAa;AAC9C,aAAS,IAAI,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACrC,WAAK,IAAI,WAAW,CAAC;AACrB,WAAK,KAAK,KAAK,KAAK,IAAI,UAAU;AAClC,WAAK,KAAK,KAAK,KAAK,IAAI,UAAU;AAAA,IACrC;AACD,SAAK,KAAK,KAAK,KAAM,OAAO,IAAK,UAAU,IAAI,KAAK,KAAK,KAAM,OAAO,IAAK,UAAU;AACrF,SAAK,KAAK,KAAK,KAAM,OAAO,IAAK,UAAU,IAAI,KAAK,KAAK,KAAM,OAAO,IAAK,UAAU;AACrF,WAAO,aAAc,WAAU,MAAO,QAAO;AAAA,EAChD;AAAA,EASD,OAAO,YAAY,OAAO;AACtB,QAAI,UAAU,QAAQ,UAAU,QAAQ;AACpC,aAAO;AAAA,IACV;AACD,QAAI,SAAS;AACb,YAAQ,OAAO;AAAA,WACN;AACD,iBAAS,QAAQ,IAAI;AACrB;AAAA,WACC;AACD,iBAAS,OAAO,OAAO,OAAO,IAAI,KAAK,CAAC;AACxC;AAAA,WACC;AACD,iBAAS,KAAK,WAAW,MAAM,IAAI;AACnC;AAAA,WACC;AACD,iBAAS,OAAO,SAAS,KAAK,IAAI,QAAQ;AAC1C;AAAA,WACC;AAED;AAAA,WACC;AACD,iBAAS,KAAK,WAAW,KAAK;AAC9B;AAAA,WACC;AACD,iBAAS,KAAK,WAAW,OAAO,OAAO,KAAK,CAAC;AAC7C;AAAA;AAER,WAAO;AAAA,EACV;AAAA,EAQD,OAAO,aAAa,QAAQ,WAAW;AAEnC,QAAI,OAAO,WAAW,YAAY;AAC9B,aAAO;AAAA,IACV;AACD,QAAI,WAAW,WAAW;AACtB,aAAO;AAAA,IACV;AAED,aAAS,QAAQ,OAAO,eAAe,MAAM,GAAG,OAAO,QAAQ,OAAO,eAAe,KAAK,GAAG;AACzF,UAAI,UAAU,WAAW;AACrB,eAAO;AAAA,MACV;AAAA,IACJ;AACD,WAAO;AAAA,EACV;AAAA,EAQD,OAAO,WAAW,MAAM;AACpB,WAAO,SAAS,QAAQ,SAAS,UAAU,OAAO,SAAS,YACvD,OAAO,KAAK,OAAO,cAAc;AAAA,EACxC;AACL;AA3HM;AAgIN,MAAM,eAAe;AAAA,EACjB;AAAA,EACA;AAAA,EACA;AAAA,EACA,WAAW,oBAAI;EACf,aAAa;AAAA,EAQb,YAAY,UAAU,aAAa,oBAAoB;AACnD,SAAK,YAAY;AACjB,SAAK,eAAe;AACpB,SAAK,sBAAsB;AAC3B,WAAO,OAAO,IAAI;AAAA,EACrB;AAAA,EAQD,OAAO,SAAS;AACZ,QAAI,KAAK,YAAY;AACjB,YAAM,MAAM,gEAAgE;AAAA,IAC/E;AACD,QAAI;AACJ,QAAI,OAAO,CAAA;AACX,QAAI;AACJ,UAAM,qBAAqB,KAAK;AAChC,QAAI,OAAO,YAAY,UAAU;AAC7B,aAAO;AACP,aAAO;AAAA,IACV,WACQ,OAAO,YAAY,cAAc,gBAAgB,aAAa,SAAS,kBAAkB,GAAG;AACjG,aAAO;AAAA,IACV,WACQ,OAAO,YAAY,YAAY,YAAY,MAAM;AACtD,MAAC,GAAE,MAAM,OAAO,oBAAoB,GAAG,KAAM,IAAG;AAAA,IACnD,OACI;AACD,YAAM,IAAI,UAAU,gFAAgF;AAAA,IACvG;AACD,QAAI,CAAC,gBAAgB,aAAa,MAAM,kBAAkB,GAAG;AACzD,YAAM,IAAI,UAAU,iDAAiD,oBAAoB,QAAQ;AAAA,IACpG;AACD,WAAO,QAAQ,MAAM;AACrB,QAAI,OAAO,SAAS,UAAU;AAC1B,YAAM,IAAI,UAAU,sDAAsD;AAAA,IAC7E;AACD,UAAM,iBAAiB,IAAI,KAAK,KAAK,WAAW,KAAK,cAAc,IAAI;AACvE,SAAK,SAAS,IAAI,MAAM,cAAc;AACtC,WAAO;AAAA,EACV;AAAA,EAID,QAAQ;AACJ,QAAI,KAAK,YAAY;AACjB;AAAA,IACH;AACD,eAAW,WAAW,KAAK,SAAS,OAAM,GAAI;AAC1C,cAAQ,QAAO;AAAA,IAClB;AACD,SAAK,SAAS;EACjB;AAAA,EAMD,OAAO,MAAM;AACT,QAAI,KAAK,YAAY;AACjB,YAAM,MAAM,gEAAgE;AAAA,IAC/E;AACD,UAAM,UAAU,KAAK,SAAS,IAAI,IAAI;AACtC,QAAI,SAAS;AACT,cAAQ,QAAO;AAAA,IAClB;AACD,WAAO,KAAK,SAAS,OAAO,IAAI;AAAA,EACnC;AAAA,EAID,UAAU;AACN,QAAI,KAAK,YAAY;AACjB;AAAA,IACH;AACD,SAAK,MAAK;AACV,SAAK,YAAY,CAAC,IAAI;AACtB,SAAK,eAAe;AACpB,SAAK,aAAa;AAAA,EACrB;AAAA,EAMD,IAAI,MAAM;AACN,QAAI,KAAK,YAAY;AACjB,YAAM,MAAM,6DAA6D;AAAA,IAC5E;AACD,WAAO,KAAK,SAAS,IAAI,IAAI;AAAA,EAChC;AAAA,EAMD,OAAO,QAAQ,OAAO;AAClB,QAAI,KAAK,YAAY;AACjB;AAAA,IACH;AACD,eAAW,WAAW,KAAK,SAAS,OAAM,GAAI;AAC1C,cAAQ,MAAM,OAAO,KAAK;AAAA,IAC7B;AAAA,EACJ;AACL;AAzHM;AAoJN,MAAM,eAAe;AAAA,EACjB;AAAA,EACA;AAAA,EACA,kBAAkB,oBAAI;EAMtB,YAAY,aAAa,gBAAgB;AACrC,SAAK,eAAe;AACpB,SAAK,eAAe;AACpB,WAAO,OAAO,IAAI;AAAA,EACrB;AAAA,EAID,IAAI,SAAS;AAAE,WAAO,KAAK,aAAa,QAAQ;AAAA,EAAS;AAAA,EAOzD,EAAE,OAAO,YAAY;AACjB,QAAI,KAAK,aAAa,QAAQ,WAAW,GAAG;AACxC;AAAA,IACH;AACD,eAAW,SAAS,KAAK,aAAa,SAAS;AAC3C,YAAM,EAAE,GAAG;IACd;AAAA,EACJ;AAAA,EAID,OAAO,SAAS;AAIZ,QAAI,iBAAiB;AACrB,eAAW,UAAU,SAAS;AAC1B,YAAM,aAAa,OAAO;AAC1B,UAAI,eAAe,cAAe,gBAAe,YAAY,WAAW,OAAO;AAC3E,cAAM,IAAI,UAAU,6DAA6D;AAAA,MACpF;AACD,UAAI,OAAO;AACX,UAAI,cAAc;AAClB,UAAI,eAAe,YAAY;AAC3B,eAAO;AAAA,UACH,IAAI;AAAA,UACJ;AAAA,UACA,QAAQ;AAAA,QAC5B;AACgB,sBAAc,OAAO;AAAA,MACxB,WACQ,eAAe,UAAU;AAC9B,YAAI,YAAY,QAAQ;AACpB,cAAI,OAAO,OAAO,WAAW,YAAY;AACrC,kBAAM,IAAI,UAAU,6DAA6D;AAAA,UACpF;AACD,cAAI,OAAO,WAAW,UAAU,OAAO,OAAO,WAAW,YACpD,QAAO,SAAS,KAAK,OAAO,SAAS,IAAI;AAC1C,kBAAM,IAAI,UAAU,qFAAqF;AAAA,UAC5G;AACD,iBAAO;AAAA,YACH,IAAI,OAAO,OAAO,SAAS,OAAO,KAAK;AAAA,YACvC,QAAQ,OAAO;AAAA,YACf,QAAQ,OAAO,UAAU;AAAA,UACjD;AACoB,wBAAc,OAAO,OAAO,aAAa,OAAO;AAAA,QACnD,OACI;AACD,gBAAM,IAAI,UAAU,6DAA6D;AAAA,QACpF;AAAA,MACJ;AAED,YAAM,QAAQ,KAAK,aAAa,QAAQ,UAAU,CAAC,UAAU;AACzD,eAAO,KAAK,SAAS,MAAM;AAAA,MAC3C,CAAa;AAED,UAAI,SAAS,GAAG;AACZ,aAAK,aAAa,QAAQ,OAAO,OAAO,GAAG,IAAI;AAAA,MAClD,OAEA;AACG,aAAK,aAAa,QAAQ,KAAK,IAAI;AAAA,MACtC;AACD,UAAI,OAAO,gBAAgB,YAAY;AACnC,cAAM,cAAc,YAAY,KAAK,YAAY;AAEjD,YAAI,OAAO,gBAAgB,YAAY;AACnC,gBAAM,IAAI,UAAU,+FAA+F;AAAA,QACtH;AAED,YAAI,KAAK,gBAAgB,IAAI,KAAK,MAAM,GAAG;AACvC,gBAAM,IAAI,MAAM,oFAAoF;AAAA,QACvG;AACD,aAAK,gBAAgB,IAAI,KAAK,QAAQ,WAAW;AACjD;AAAA,MACH;AAAA,IACJ;AAGD,QAAI,iBAAiB,QAAQ,QAAQ;AACjC,WAAK,aAAY;AAAA,IACpB;AAAA,EACJ;AAAA,EAID,QAAQ;AACJ,SAAK,aAAa,QAAQ,SAAS;AAEnC,eAAW,eAAe,KAAK,gBAAgB,OAAM,GAAI;AACrD;IACH;AACD,SAAK,gBAAgB;AACrB,SAAK,aAAY;AAAA,EACpB;AAAA,EAID,UAAU,SAAS;AACf,UAAM,SAAS,KAAK,aAAa,QAAQ;AACzC,QAAI,WAAW,GAAG;AACd;AAAA,IACH;AACD,eAAW,QAAQ,SAAS;AAExB,YAAM,eAAe,OAAO,SAAS,aAAa,OAAO,SAAS,QAAQ,OAAO,SAAS,WACtF,KAAK,SAAS;AAClB,UAAI,CAAC,cAAc;AACf;AAAA,MACH;AACD,eAAS,OAAO,KAAK,aAAa,QAAQ,QAAQ,EAAE,QAAQ,KAAI;AAC5D,YAAI,KAAK,aAAa,QAAQ,MAAM,WAAW,cAAc;AACzD,eAAK,aAAa,QAAQ,OAAO,MAAM,CAAC;AAExC,cAAI,cAAc;AAClB,cAAI,OAAQ,eAAc,KAAK,gBAAgB,IAAI,YAAY,OAAO,YAAY;AAC9E;AACA,iBAAK,gBAAgB,OAAO,YAAY;AAAA,UAC3C;AAAA,QACJ;AAAA,MACJ;AAAA,IACJ;AAED,QAAI,WAAW,KAAK,aAAa,QAAQ,QAAQ;AAC7C,WAAK,aAAY;AAAA,IACpB;AAAA,EACJ;AAAA,EAOD,SAAS,UAAU;AACf,UAAM,SAAS,KAAK,aAAa,QAAQ;AACzC,QAAI,WAAW,GAAG;AACd;AAAA,IACH;AACD,QAAI,OAAO,aAAa,YAAY;AAChC,YAAM,IAAI,UAAU,qDAAqD;AAAA,IAC5E;AACD,SAAK,aAAa,UAAU,KAAK,aAAa,QAAQ,OAAO,CAAC,SAAS;AACnE,YAAM,SAAS,SAAS,KAAK,UAAU,EAAE,GAAG,KAAI,CAAE;AAClD,UAAI,QAAQ;AACR,YAAI;AACJ,YAAI,OAAQ,eAAc,KAAK,gBAAgB,IAAI,KAAK,MAAM,OAAO,YAAY;AAC7E;AACA,eAAK,gBAAgB,OAAO,KAAK,MAAM;AAAA,QAC1C;AAAA,MACJ;AAED,aAAO,CAAC;AAAA,IACpB,CAAS;AACD,QAAI,WAAW,KAAK,aAAa,QAAQ,QAAQ;AAC7C,WAAK,aAAY;AAAA,IACpB;AAAA,EACJ;AAAA,EAID,cAAc,KAAK;AACf,UAAM,SAAS,KAAK,aAAa,QAAQ;AACzC,QAAI,WAAW,GAAG;AACd;AAAA,IACH;AACD,SAAK,aAAa,UAAU,KAAK,aAAa,QAAQ,OAAO,CAAC,SAAS;AACnE,UAAI,SAAS;AACb,iBAAW,MAAM,KAAK;AAClB,kBAAW,KAAK,OAAO,KAAK,IAAI;AAAA,MACnC;AAED,UAAI,CAAC,CAAC,QAAQ;AACV,YAAI;AACJ,YAAI,OAAQ,eAAc,KAAK,gBAAgB,IAAI,KAAK,MAAM,OAAO,YAAY;AAC7E;AACA,eAAK,gBAAgB,OAAO,KAAK,MAAM;AAAA,QAC1C;AAAA,MACJ;AACD,aAAO,CAAC;AAAA,IACpB,CAAS;AACD,QAAI,WAAW,KAAK,aAAa,QAAQ,QAAQ;AAC7C,WAAK,aAAY;AAAA,IACpB;AAAA,EACJ;AACL;AAhNM;AAsNN,MAAM,eAAe;AAAA,EACjB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,YAAY;AAAA,EAUZ,YAAY,UAAU,YAAY,eAAe;AAC7C,SAAK,WAAW;AAChB,SAAK,aAAa;AAClB,SAAK,YAAY,EAAE,OAAO,MAAM,MAAM,MAAM,UAAU,OAAO,QAAQ,cAAa;AAAA,EACrF;AAAA,EAID,IAAI,SAAS;AACT,WAAO,KAAK,YAAY,QAAQ,SAAS,KAAK,KAAK,SAAS,cAAc,QACtE,KAAK,UAAU,QAAQ,WAAW;AAAA,EACzC;AAAA,EAID,IAAI,SAAS;AACT,WAAO,KAAK,UAAU,QAAQ,KAAK,UAAU,MAAM,SAAS;AAAA,EAC/D;AAAA,EAKD,IAAI,WAAW;AAAE,WAAO,KAAK,UAAU;AAAA,EAAW;AAAA,EAKlD,IAAI,SAAS,UAAU;AAAE,SAAK,UAAU,WAAW;AAAA,EAAW;AAAA,EAe9D,eAAe,UAAU,SAAS,QAAQ,OAAO;AAE7C,UAAM,cAAc,OAAO,UAAU,YAAY,QAA6B;AAC9E,QAAI,UAAU;AACd,UAAM,WAAW,KAAK,UAAU;AAChC,QAAI,UAAU;AACV,eAAS,OAAO,SAAS,QAAQ,EAAE,QAAQ,KAAI;AAC3C,mBAAW,gBAAgB,YAAY,SAAS,KAAK,IAAI,aAAc,YAAW,KAAM,YAAW;AAAA,MACtG;AAAA,IACJ;AACD,SAAK,UAAU,OAAO;AACtB,QAAI,eAAgB,aAAY,UAAU,CAAC,gBAAgB,YAAY,UAAU,QAAQ,IAAI,OAAO;AAChG,WAAK,WAAU;AAAA,IAClB;AAAA,EACJ;AAAA,EAID,UAAU;AACN,QAAI,KAAK,WAAW;AAChB;AAAA,IACH;AACD,SAAK,UAAU,QAAQ;AACvB,SAAK,UAAU,OAAO;AACtB,SAAK,UAAU,WAAW;AAC1B,SAAK,UAAU,SAAS;AACxB,SAAK,YAAY;AAAA,EACpB;AAAA,EAUD,aAAa,aAAa,UAAU,gBAAgB;AAChD,SAAK,cAAc;AACnB,SAAK,WAAW;AAChB,SAAK,iBAAiB;AACtB,SAAK,SAAS,KAAK;EACtB;AACL;AAvGM;AAyHN,MAAM,YAAY;AAAA,EACd;AAAA,EACA;AAAA,EACA;AAAA,EAMA,YAAY,aAAa,UAAU;AAC/B,SAAK,eAAe;AACpB,SAAK,YAAY;AACjB,WAAO,OAAO,IAAI;AAAA,EACrB;AAAA,EAID,QAAQ;AACJ,UAAM,eAAe,KAAK,UAAU;AACpC,SAAK,UAAU,YAAY;AAC3B,QAAI,OAAO,KAAK,iBAAiB,YAAY;AACzC,WAAK,aAAY;AACjB,WAAK,eAAe;AAAA,IACvB;AAED,QAAI,OAAO,iBAAiB,YAAY;AACpC,WAAK,aAAY;AAAA,IACpB;AAAA,EACJ;AAAA,EASD,IAAI,MAAM;AACN,QAAI,OAAO,KAAK,iBAAiB,YAAY;AACzC,WAAK,aAAY;AACjB,WAAK,eAAe;AAAA,IACvB;AACD,QAAI,YAAY;AAChB,QAAI,cAAc;AAClB,YAAQ,OAAO;AAAA,WACN;AACD,oBAAY;AACZ,sBAAc,KAAK;AACnB;AAAA,WACC;AAED,YAAI,SAAS,MAAM;AACf;AAAA,QACH;AACD,YAAI,OAAO,KAAK,YAAY,YAAY;AACpC,gBAAM,IAAI,UAAU,2DAA2D;AAAA,QAClF;AACD,oBAAY,KAAK;AACjB,sBAAc,KAAK,QAAQ,aAAa,KAAK;AAC7C;AAAA;AAER,QAAI,OAAO,cAAc,YAAY;AACjC,WAAK,UAAU,YAAY;AAAA,IAC9B,OACI;AACD,YAAM,eAAe,KAAK,UAAU;AACpC,WAAK,UAAU,YAAY;AAE3B,UAAI,OAAO,iBAAiB,YAAY;AACpC,aAAK,aAAY;AAAA,MACpB;AACD;AAAA,IACH;AACD,QAAI,OAAO,gBAAgB,YAAY;AACnC,WAAK,eAAe,YAAY,KAAK,YAAY;AAEjD,UAAI,OAAO,KAAK,iBAAiB,YAAY;AACzC,cAAM,IAAI,MAAM,8FAA8F;AAAA,MACjH;AAAA,IACJ,OACI;AAGD,WAAK,aAAY;AAAA,IACpB;AAAA,EACJ;AACL;AAtFM;AAoGN,MAAM,WAAW;AAAA,EACb;AAAA,EAIA;AAAA,EAIA;AAAA,EAMA;AAAA,EACA,YAAY,gBAAgB;AACxB,SAAK,aAAa,eAAe;AACjC,SAAK,SAAS,eAAe,OAAO,KAAK,cAAc;AAEvD,WAAO,iBAAiB,MAAM;AAAA,MAC1B,QAAQ,EAAE,KAAK,MAAM,eAAe,OAAQ;AAAA,MAC5C,QAAQ,EAAE,KAAK,MAAM,eAAe,OAAQ;AAAA,IACxD,CAAS;AACD,WAAO,OAAO,IAAI;AAAA,EACrB;AAAA,EAID,IAAI,OAAO;AACP,WAAO,KAAK,WAAW;AAAA,EAC1B;AAAA,EAOD,EAAE,OAAO,YAAY;AACjB,UAAM,YAAY,KAAK;AACvB,QAAI,CAAC,UAAU,OAAO;AAClB;AAAA,IACH;AACD,UAAM,WAAW,UAAU;AAC3B,UAAM,SAAS,UAAU,MAAM;AAC/B,QAAI,UAAU;AACV,eAAS,OAAO,QAAQ,EAAE,QAAQ,KAAI;AAClC,cAAM,UAAU,MAAM;AAAA,MACzB;AAAA,IACJ,OACI;AACD,eAAS,OAAO,GAAG,OAAO,QAAQ,QAAQ;AACtC,cAAM,UAAU,MAAM;AAAA,MACzB;AAAA,IACJ;AAAA,EACJ;AACL;AAxDM;AAwEN,MAAM,WAAW;AAAA,EAIb;AAAA,EAMA;AAAA,EAMA;AAAA,EAIA;AAAA,EAMA;AAAA,EACA,YAAY,gBAAgB;AACxB,SAAK,QAAQ,eAAe,MAAM,KAAK,cAAc;AACrD,SAAK,SAAS,eAAe,OAAO,KAAK,cAAc;AACvD,SAAK,SAAS,eAAe,OAAO,KAAK,cAAc;AACvD,SAAK,UAAU,eAAe,QAAQ,KAAK,cAAc;AACzD,SAAK,MAAM,eAAe,IAAI,KAAK,cAAc;AACjD,WAAO,OAAO,IAAI;AAAA,EACrB;AACL;AAnCM;AAwlBN,MAAM,gBAAgB,eAAe;AAAA,EAIjC,eAAe;AACX,WAAO,CAAC,GAAG,MAAM,KAAK,SAAS,UAAU,KAAK,SAAS,GAAG,IAAI,CAAC,GAAG,KAAK,SAAS,GAAG,IAAI,CAAC,CAAC;AAAA,EAC5F;AAAA,EASD,aAAa;AACT,UAAM,OAAO,CAAA;AACb,UAAM,MAAM,KAAK,SAAS;AAC1B,QAAI,CAAC,KAAK;AACN,aAAO;AAAA,IACV;AACD,UAAM,UAAU,KAAK,YAAY;AACjC,QAAI,UAAU;AACd,UAAM,cAAc,KAAK,UAAU;AAEnC,QAAI,gBAAgB,WAAW,WAAW,KAAK,YAAY,QAAQ;AAC/D,iBAAW,OAAO,aAAa;AAC3B,cAAM,QAAQ,IAAI,IAAI,GAAG;AACzB,kBAAU;AACV,iBAAS,UAAU,GAAG,YAAY,QAAQ,QAAQ,UAAU,WAAW,WAAW;AAC9E,cAAI,CAAC,QAAQ,SAAS,OAAO,KAAK,GAAG;AACjC,sBAAU;AACV;AAAA,UACH;AAAA,QACJ;AACD,YAAI,SAAS;AACT,eAAK,KAAK,GAAG;AAAA,QAChB;AAAA,MACJ;AAAA,IACJ,OACI;AACD,iBAAW,OAAO,IAAI,QAAQ;AAC1B,kBAAU;AACV,cAAM,QAAQ,IAAI,IAAI,GAAG;AACzB,iBAAS,UAAU,GAAG,YAAY,QAAQ,QAAQ,UAAU,WAAW,WAAW;AAC9E,cAAI,CAAC,QAAQ,SAAS,OAAO,KAAK,GAAG;AACjC,sBAAU;AACV;AAAA,UACH;AAAA,QACJ;AACD,YAAI,SAAS;AACT,eAAK,KAAK,GAAG;AAAA,QAChB;AAAA,MACJ;AAAA,IACJ;AACD,WAAO;AAAA,EACV;AAAA,EAOD,OAAO,QAAQ,OAAO;AAClB,QAAI,KAAK,WAAW;AAChB;AAAA,IACH;AACD,UAAM,WAAW,KAAK,UAAU;AAChC,UAAM,UAAU,KAAK,UAAU;AAC/B,UAAM,MAAM,KAAK,SAAS;AAC1B,UAAM,cAAc,KAAK,UAAU;AAEnC,QAAK,KAAK,YAAY,QAAQ,WAAW,KAAK,CAAC,KAAK,SAAS,aACxD,KAAK,UAAU,SAAS,KAAK,SAAS,KAAK,UAAU,MAAM,QAAS;AACrE,WAAK,UAAU,QAAQ;AAAA,IAC1B;AAED,QAAI,KAAK,YAAY,QAAQ,SAAS,GAAG;AACrC,WAAK,UAAU,QAAQ,KAAK,WAAU;AAAA,IACzC;AAED,QAAI,CAAC,KAAK,UAAU,SAAS,aAAa,QAAQ;AAC9C,WAAK,UAAU,QAAQ,CAAC,GAAG,WAAW;AAAA,IACzC;AACD,QAAI,KAAK,SAAS,aAAa,eAAe,KAAK;AAE/C,UAAI,CAAC,KAAK,UAAU,OAAO;AACvB,aAAK,UAAU,QAAQ,KAAK,UAAU,QAAQ,CAAC,GAAG,IAAI,KAAI,CAAE;AAAA,MAC/D;AACD,WAAK,UAAU,MAAM,KAAK,KAAK,MAAM;AAAA,IACxC;AACD,SAAK,eAAe,UAAU,SAAS,KAAK;AAE5C,SAAK,gBAAgB,OAAO,KAAK;AAAA,EACpC;AACL;AA/FM;AAoGN,MAAM,kBAAkB;AAAA,EACpB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,eAAe,EAAE,SAAS,CAAA;EAC1B;AAAA,EACA;AAAA,EACA,YAAY;AAAA,EACZ;AAAA,EACA,YAAY,EAAE,WAAW;EACzB,iBAAiB,CAAA;AAAA,EACjB,aAAa;AAAA,EAQb,YAAY,KAAK,aAAa,SAAS;AACnC,SAAK,OAAO;AACZ,SAAK,SAAS,IAAI,QAAQ,KAAK,MAAM,KAAK,mBAAmB,KAAK,IAAI,GAAG,WAAW;AACpF,SAAK,kBAAkB,IAAI,WAAW,KAAK,MAAM;AACjD,SAAK,WAAW,IAAI,eAAe,KAAK,gBAAgB,QAAQ,KAAK,YAAY;AACjF,SAAK,QAAQ,IAAI,YAAY,KAAK,gBAAgB,QAAQ,KAAK,SAAS;AACxE,SAAK,WAAW,IAAI,eAAe,KAAK,MAAM,KAAK,iBAAiB,iBAAiB;AACrF,SAAK,oBAAoB,IAAI,WAAW,KAAK,QAAQ;AACrD,SAAK,OAAO,aAAa,KAAK,cAAc,KAAK,WAAW,KAAK,QAAQ;AACzE,QAAI,UAAU;AACd,QAAI,OAAO;AACX,QAAI,YAAY,UAAW,cAAa,WAAW,UAAU,UAAU;AACnE,UAAI,QAAQ,YAAY,QAAQ;AAC5B,YAAI,gBAAgB,WAAW,QAAQ,OAAO,GAAG;AAC7C,oBAAU,QAAQ;AAAA,QACrB,OACI;AACD,gBAAM,IAAI,UAAU,oFAAoF;AAAA,QAC3G;AAAA,MACJ;AACD,UAAI,QAAQ,SAAS,QAAQ;AACzB,YAAI,OAAO,QAAQ,SAAS,YAAY;AACpC,iBAAO,QAAQ;AAAA,QAClB,WACQ,OAAO,QAAQ,SAAS,YAAY,QAAQ,SAAS,MAAM;AAChE,iBAAO,QAAQ;AAAA,QAClB,OACI;AACD,gBAAM,IAAI,UAAU,6FAA6F;AAAA,QACpH;AAAA,MACJ;AAAA,IACJ;AAED,QAAI,SAAS;AACT,WAAK,QAAQ,IAAI,GAAG,OAAO;AAAA,IAC9B;AACD,QAAI,MAAM;AACN,WAAK,KAAK,IAAI,IAAI;AAAA,IACrB;AAED,SAAK,WAAU;AAAA,EAClB;AAAA,EASD,IAAI,OAAO;AAAE,WAAO,KAAK,KAAK;AAAA,EAAK;AAAA,EAInC,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAoB;AAAA,EAIhD,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAW;AAAA,EAMvC,IAAI,QAAQ;AAAE,WAAO,KAAK;AAAA,EAAkB;AAAA,EAI5C,IAAI,YAAY;AAAE,WAAO,KAAK;AAAA,EAAa;AAAA,EAI3C,IAAI,SAAS;AACT,UAAM,MAAM,KAAK,KAAK;AACtB,WAAO,KAAK,OAAO,SAAS,KAAK,MAAM,SACnC,MAAM,IAAI,OAAO;AAAA,EACxB;AAAA,EAID,IAAI,WAAW;AAAE,WAAO,KAAK;AAAA,EAAY;AAAA,EAIzC,IAAI,OAAO;AAAE,WAAO,KAAK;AAAA,EAAQ;AAAA,EAMjC,IAAI,SAAS,UAAU;AACnB,QAAI,OAAO,aAAa,WAAW;AAC/B,YAAM,IAAI,UAAU,gEAAgE;AAAA,IACvF;AACD,SAAK,YAAY;AACjB,SAAK,OAAO,WAAW;AAEvB,SAAK,MAAM,OAAO,IAAI;AAAA,EACzB;AAAA,EAID,UAAU;AACN,SAAK,aAAa;AAElB,SAAK,OAAO,CAAC,IAAI;AACjB,SAAK,OAAO,OAAO,IAAI;AAEvB,SAAK,eAAe,SAAS;AAC7B,SAAK,SAAS;AACd,SAAK,OAAO;AACZ,SAAK,SAAS;AACd,SAAK,MAAM;EACd;AAAA,EAOD,aAAa;AAAA,EAAG;AAAA,EAMhB,EAAE,OAAO,YAAY;AACjB,UAAM,MAAM,KAAK,KAAK;AACtB,QAAI,KAAK,cAAc,QAAQ,QAAQ,KAAK,SAAS,GAAG;AACpD;AAAA,IACH;AACD,QAAI,KAAK,OAAO,QAAQ;AACpB,iBAAW,OAAO,KAAK,OAAO;AAC1B,cAAM,IAAI,IAAI,GAAG;AAAA,MACpB;AAAA,IACJ,OACI;AACD,UAAI,KAAK,UAAU;AAEf,cAAM,SAAS,CAAC,GAAG,IAAI,OAAQ,CAAA;AAC/B,iBAAS,OAAO,OAAO,QAAQ,EAAE,QAAQ,KAAI;AACzC,gBAAM,OAAO;AAAA,QAChB;AAAA,MACJ,OACI;AACD,mBAAW,SAAS,IAAI,UAAU;AAC9B,gBAAM;AAAA,QACT;AAAA,MACJ;AAAA,IACJ;AAAA,EACJ;AAAA,EASD,UAAU,SAAS;AACf,SAAK,eAAe,KAAK,OAAO;AAChC,YAAQ,IAAI;AAEZ,WAAO,MAAM;AACT,YAAM,QAAQ,KAAK,eAAe,UAAU,CAAC,QAAQ,QAAQ,OAAO;AACpE,UAAI,SAAS,GAAG;AACZ,aAAK,eAAe,OAAO,OAAO,CAAC;AAAA,MACtC;AAAA,IACb;AAAA,EACK;AAAA,EAID,qBAAqB;AACjB,aAAS,OAAO,GAAG,OAAO,KAAK,eAAe,QAAQ,QAAQ;AAC1D,WAAK,eAAe,MAAM,IAAI;AAAA,IACjC;AAAA,EACJ;AACL;AAtMM;AA4MN,MAAM,cAAc;AAAA,EAChB,OAAO,CAAC,IAAI;AAAA,EACZ;AAAA,EACA;AAAA,EACA;AAAA,EACA,eAAe,EAAE,SAAS,CAAA;EAC1B;AAAA,EACA;AAAA,EACA,YAAY;AAAA,EACZ;AAAA,EACA,YAAY,EAAE,WAAW;EACzB,iBAAiB,CAAA;AAAA,EACjB,aAAa;AAAA,EAOb,YAAY,MAAM;AACd,QAAI,UAAU;AACd,QAAI,UAAU;AACd,QAAI,OAAO;AACX,QAAI,SAAS,MAAM;AACf,YAAM,IAAI,UAAU,sDAAsD;AAAA,IAC7E;AACD,QAAI,SAAS,UAAU,OAAO,SAAS,YAAY,CAAE,iBAAgB,MAAM;AACvE,YAAM,IAAI,UAAU,sDAAsD;AAAA,IAC7E;AACD,QAAI,SAAS,UAAU,gBAAgB,KAAK;AACxC,gBAAU;AAAA,IACb,WACQ,SAAS,UAAW,WAAU,QAAQ,aAAa,QAAQ,UAAU,OAAO;AACjF,UAAI,KAAK,SAAS,UAAU,CAAE,MAAK,gBAAgB,MAAM;AACrD,cAAM,IAAI,UAAU,kEAAkE;AAAA,MACzF;AACD,gBAAU,KAAK;AACf,UAAI,KAAK,YAAY,QAAQ;AACzB,YAAI,gBAAgB,WAAW,KAAK,OAAO,GAAG;AAC1C,oBAAU,KAAK;AAAA,QAClB,OACI;AACD,gBAAM,IAAI,UAAU,wEAAwE;AAAA,QAC/F;AAAA,MACJ;AACD,UAAI,KAAK,SAAS,QAAQ;AACtB,YAAI,OAAO,KAAK,SAAS,YAAY;AACjC,iBAAO,KAAK;AAAA,QACf,WACQ,OAAO,KAAK,SAAS,YAAY,KAAK,SAAS,MAAM;AAC1D,iBAAO,KAAK;AAAA,QACf,OACI;AACD,gBAAM,IAAI,UAAU,iFAAiF;AAAA,QACxG;AAAA,MACJ;AAAA,IACJ;AAED,QAAI,SAAS;AACT,WAAK,KAAK,KAAK;AAAA,IAClB;AACD,SAAK,SAAS,IAAI,QAAQ,KAAK,MAAM,KAAK,mBAAmB,KAAK,IAAI,CAAC;AACvE,SAAK,kBAAkB,IAAI,WAAW,KAAK,MAAM;AACjD,SAAK,WAAW,IAAI,eAAe,KAAK,gBAAgB,QAAQ,KAAK,YAAY;AACjF,SAAK,QAAQ,IAAI,YAAY,KAAK,gBAAgB,QAAQ,KAAK,SAAS;AACxE,SAAK,WAAW,IAAI,eAAe,KAAK,MAAM,KAAK,iBAAiB,iBAAiB;AACrF,SAAK,oBAAoB,IAAI,WAAW,KAAK,QAAQ;AACrD,SAAK,OAAO,aAAa,KAAK,cAAc,KAAK,WAAW,KAAK,QAAQ;AAEzE,QAAI,SAAS;AACT,WAAK,QAAQ,IAAI,GAAG,OAAO;AAAA,IAC9B;AACD,QAAI,MAAM;AACN,WAAK,KAAK,IAAI,IAAI;AAAA,IACrB;AAED,SAAK,WAAU;AAAA,EAClB;AAAA,EAUD,IAAI,OAAO;AAAE,WAAO,KAAK,KAAK;AAAA,EAAK;AAAA,EAInC,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAoB;AAAA,EAIhD,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAW;AAAA,EAIvC,IAAI,QAAQ;AAAE,WAAO,KAAK;AAAA,EAAkB;AAAA,EAI5C,IAAI,YAAY;AAAE,WAAO,KAAK;AAAA,EAAa;AAAA,EAM3C,IAAI,SAAS;AACT,UAAM,MAAM,KAAK,KAAK;AACtB,WAAO,KAAK,OAAO,SAAS,KAAK,gBAAgB,SAC7C,MAAM,IAAI,OAAO;AAAA,EACxB;AAAA,EAMD,IAAI,WAAW;AAAE,WAAO,KAAK;AAAA,EAAY;AAAA,EAIzC,IAAI,OAAO;AAAE,WAAO,KAAK;AAAA,EAAQ;AAAA,EAMjC,IAAI,SAAS,UAAU;AACnB,QAAI,OAAO,aAAa,WAAW;AAC/B,YAAM,IAAI,UAAU,4DAA4D;AAAA,IACnF;AACD,SAAK,YAAY;AACjB,SAAK,OAAO,WAAW;AAEvB,SAAK,MAAM,OAAO,IAAI;AAAA,EACzB;AAAA,EAID,UAAU;AACN,QAAI,KAAK,YAAY;AACjB;AAAA,IACH;AACD,SAAK,aAAa;AAClB,SAAK,SAAS;AAEd,SAAK,OAAO,CAAC,IAAI;AACjB,SAAK,MAAM,OAAO,IAAI;AAEtB,SAAK,eAAe,SAAS;AAC7B,SAAK,OAAO;AACZ,SAAK,SAAS;AACd,SAAK,MAAM;EACd;AAAA,EAOD,aAAa;AAAA,EAAG;AAAA,EAShB,QAAQ,MAAM,UAAU,OAAO;AAC3B,QAAI,SAAS,QAAQ,CAAE,iBAAgB,MAAM;AACzC,YAAM,IAAI,UAAU,sDAAsD;AAAA,IAC7E;AACD,QAAI,OAAO,YAAY,WAAW;AAC9B,YAAM,IAAI,UAAU,0DAA0D;AAAA,IACjF;AACD,UAAM,MAAM,KAAK,KAAK;AAGtB,QAAI,CAAE,gBAAe,QAAQ,SAAS;AAClC,WAAK,KAAK,KAAK,gBAAgB,MAAM,OAAO;AAAA,IAC/C,WACQ,gBAAgB,OAAO,eAAe,KAAK;AAEhD,YAAM,eAAe,IAAI,IAAI,IAAI,KAAM,CAAA;AACvC,iBAAW,OAAO,KAAK,QAAQ;AAC3B,YAAI,IAAI,KAAK,KAAK,IAAI,GAAG,CAAC;AAC1B,YAAI,aAAa,IAAI,GAAG,GAAG;AACvB,uBAAa,OAAO,GAAG;AAAA,QAC1B;AAAA,MACJ;AAED,iBAAW,OAAO,cAAc;AAC5B,YAAI,OAAO,GAAG;AAAA,MACjB;AAAA,IACJ,WACQ,SAAS,MAAM;AACpB,WAAK,KAAK,KAAK;AAAA,IAClB;AAED,SAAK,MAAM,OAAO,IAAI;AAAA,EACzB;AAAA,EAQD,UAAU,SAAS;AACf,SAAK,eAAe,KAAK,OAAO;AAChC,YAAQ,IAAI;AAEZ,WAAO,MAAM;AACT,YAAM,QAAQ,KAAK,eAAe,UAAU,CAAC,QAAQ,QAAQ,OAAO;AACpE,UAAI,SAAS,GAAG;AACZ,aAAK,eAAe,OAAO,OAAO,CAAC;AAAA,MACtC;AAAA,IACb;AAAA,EACK;AAAA,EAID,qBAAqB;AACjB,aAAS,OAAO,GAAG,OAAO,KAAK,eAAe,QAAQ,QAAQ;AAC1D,WAAK,eAAe,MAAM,IAAI;AAAA,IACjC;AAAA,EACJ;AAAA,EAOD,EAAE,OAAO,YAAY;AACjB,UAAM,MAAM,KAAK,KAAK;AACtB,QAAI,KAAK,cAAc,QAAQ,QAAQ,KAAK,SAAS,GAAG;AACpD;AAAA,IACH;AACD,QAAI,KAAK,OAAO,QAAQ;AACpB,iBAAW,OAAO,KAAK,OAAO;AAC1B,cAAM,IAAI,IAAI,GAAG;AAAA,MACpB;AAAA,IACJ,OACI;AACD,UAAI,KAAK,UAAU;AAEf,cAAM,SAAS,CAAC,GAAG,IAAI,OAAQ,CAAA;AAC/B,iBAAS,OAAO,OAAO,QAAQ,EAAE,QAAQ,KAAI;AACzC,gBAAM,OAAO;AAAA,QAChB;AAAA,MACJ,OACI;AACD,mBAAW,SAAS,IAAI,UAAU;AAC9B,gBAAM;AAAA,QACT;AAAA,MACJ;AAAA,IACJ;AAAA,EACJ;AACL;AArQM;AAySN,0BAA0B,OAC1B;AACG,MAAI,UAAU,QAAQ,UAAU,QAAQ;AAAE,WAAO;AAAA,EAAQ;AAEzD,UAAQ,OAAO;AAAA,SAEP;AAAA,SACA;AACF,aAAO,OAAO,MAAM,cAAc,cAAc,OAAO,MAAM,WAAW;AAAA;AAG9E,SAAO;AACV;AAZS;AAwBT,yBAAyB,OACzB;AACG,MAAI,UAAU,QAAQ,UAAU,QAAQ;AAAE,WAAO;AAAA,EAAQ;AAEzD,UAAQ,OAAO;AAAA,SAEP;AAAA,SACA;AACF,aAAO,OAAO,MAAM,cAAc,cAAc,OAAO,MAAM,QAAQ;AAAA;AAG3E,SAAO;AACV;AAZS;AAyBT,8BAA8B,OAAO,SACrC;AACG,MAAI,aAAa;AAEjB,SAAO,MAAM,UAAU,CAAC,UAAU;AAC/B,QAAI,CAAC,YACL;AACG,mBAAa;AAAA,IACf,OACI;AACF,cAAO,KAAK;AAAA,IACd;AAAA,EACP,CAAI;AACJ;AAbS;AAsdT,yBAAyB,SAAS,QAAQ,SAAS,SAAS;AAC3D,MAAI,oBAAoB,cAAc,kBAAkB;AACxD,MAAI,mBAAmB,aAAa;AACpC,MAAI,gBAAgB,wBAAC,KAAK,QAAQ;AACjC,yBAAqB;AACrB,QAAI,kBAAkB;AACrB,qBAAe;AAAA,IACf;AACD,QAAI,CAAC,iBAAiB;AACrB,UAAI,WAAW,OAAO,KAAK,GAAG;AAC9B,UAAI,OAAO,SAAS,GAAG;AACtB,YAAI,QAAQ;AAAA,MAChB,OAAU;AACN,eAAO;AAAA,MACP;AAAA,IACD;AACD,sBAAkB;AAAA,EACpB,GAdqB;AAepB,MAAI,eAAe,QAAQ,SAAS,eAAe,OAAO;AAE1D,MAAI,eAAe,CAAC,MAAM,QAAQ,OAAO;AACzC,MAAI,eAAe,wBAAC,YAAY;AAC/B,QAAI,cAAc;AACjB,wBAAkB;AAClB,cAAQ,IAAI,OAAO;AAAA,IACtB,OAAS;AACN,cAAQ,QAAS,CAAC,OAAO,MAAM;AAC9B,0BAAkB;AAClB,gBAAQ,GAAG,IAAI,KAAK;AAAA,MACxB;IACG;AACD,sBAAkB;AAAA,EACpB,GAXoB;AAYnB,MAAI,kBAAkB;AACrB,cAAU,QAAQ;AAAA,EAClB;AACD,MAAI,iBAAiB,QAAQ,UAAW,oBAAmB,IAAI;AAC/D,MAAI,UAAU;AACd,qBAAmB,YAAY;AAC9B,QAAI,SAAS;AACZ;AACA,gBAAU;AAAA,IACV;AAED,QAAI,kBAAkB;AACrB,UAAI,WAAW,QAAQ,YAAY,cAAc,YAAY;AAAA,IAChE,OAAS;AACN,UAAI,WAAW,QAAQ,YAAY,YAAY;AAAA,IAC/C;AACD,QAAI,gBAAgB;AACnB,UAAI,OAAO,YAAY,YAAY;AAClC,kBAAU;AAAA,MACV;AAAA,IACJ,OAAS;AACN,mBAAa,QAAQ;AAAA,IACrB;AAAA,EACD;AAlBQ;AAoBT,MAAI,YAAY;AAChB,mBAAgB,IAAI;AACnB,QAAI,WAAW,wBAAwB,UAAU;AACjD,QAAI,WAAW;AACd,iBAAW,GAAIC,gBAAI,YAAY,CAAC;AAChC,yBAAmB,QAAQ;AAC3B;AAAA,IACA;AACD,QAAI,cAAc,aAAa,UAAW,CAAC,UAAU;AACpD,UAAI,CAAC,WAAW;AACf,mBAAW;AAAA,MACf,WAAc,CAAC,WAAW;AACtB,oBAAY;AAAA,MAChB,OAAU;AACN,iCAAyB;AAAA,MACzB;AAAA,IACJ;AACE,eAAW,GAAG,QAAQ;AACtB,gBAAY;AACZ,uBAAmB,QAAQ;AAC3B;AACA,gBAAY;AACZ,QAAI,wBAAwB;AAC3B,iBAAWA,gBAAI,YAAY;AAAA,IAC3B;AACD,QAAI,WAAW;AACd,gBAAU,QAAQ;AAAA,IAClB;AAAA,EACD;AA3BQ;AA4BT,SAAO;AAAA,IACN,WAAW,aAAa;AAAA,IACxB,IAAI,OAAO;AAAE,cAAQ,MAAM,KAAO;AAAA,IAAG;AAAA,IACrC;AAAA,EACF;AACA;AA5FS;AAwGT,uBAAuB,QAAQ,UAAU;AACxC,MAAI,CAAC,MAAM,QAAQ,QAAQ,GAAG;AAC7B,WAAO,gBACN,QACA,CAAC,WAAW,OAAO,WACnB,EAAE,QAAQ,YAAY,QAAQ;AAC7B,aAAO,YAAY;AACnB,aAAO;AAAA,IACX,EAAM,CACN;AAAA,EACA,OAAQ;AACN,QAAI,QAAQ,SAAS;AACrB,WAAO,gBACN,QACA,CAAC,UAAU;AACV,eAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,EAAE,GAAG;AACtC,gBAAQ,MAAO,MAAM;AAAA,MACrB;AACD,aAAO;AAAA,IACP,GACD,EAAE,QAAQ,YAAY,QAAQ;AAC7B,UAAI,SAAS;AACb,eAAS,IAAI,GAAG,IAAI,MAAM,SAAS,GAAG,EAAE,GAAG;AAC1C,iBAAS,OAAQ,MAAM;AAAA,MACvB;AACD,aAAQ,MAAM,MAAM,SAAS,MAAO;AACpC,aAAO;AAAA,IACX,EAAM,CACN;AAAA,EACE;AACF;AA9BS;AAkCT,MAAM,qBACN;AAAA,EAMG,OAAO,sBAAsB;AAAA,EAK7B,QAAQ,oBAAI;EAKZ;AAAA,EAKA,iBAAiB,oBAAI;EAKrB,YAAY,WACZ;AACG,SAAK,YAAY;AAEjB,SAAK,gBAAe;AAAA,EACtB;AAAA,EAWD,OAAO,cAAc,SACrB;AAEG,UAAM,MAAM,KAAK,UAAU;AAE3B,QAAI,aAAa;AAEjB,QAAI,KACJ;AACG,UACA;AACG,qBAAa,IAAI,sBAAsB,YAAY;AAAA,MACrD,SACM,KAAP;AAEG,gBAAQ,KAAK,wEAAwE,cAAc;AAAA,MACrG;AAAA,IACH;AAED,QAAI;AAEJ,QAAI,CAAC,KAAK,MAAM,IAAI,YAAY,GAChC;AACG,qBAAe;AAAA,QACZ;AAAA,QACA,QAAQ,oBAAI,IAAK;AAAA,MAC7B;AAES,WAAK,MAAM,IAAI,cAAc,YAAY;AAAA,IAC3C,OAED;AACG,qBAAe,KAAK,MAAM,IAAI,YAAY;AAAA,IAC5C;AAGD,QAAI;AAGJ,QAAI,OAAO,CAAA;AAGX,QAAI;AAEJ,QAAI,OAAO,YAAY,UACvB;AACG,aAAO;AACP,aAAO;AAAA,IACT,WACQ,OAAO,YAAY,cAAc,aAAa,SAAS,aAAa,GAC7E;AACG,aAAO;AAAA,IACT,WACQ,OAAO,YAAY,YAAY,YAAY,MACpD;AACG,MAAC,GAAE,MAAM,OAAO,eAAe,GAAG,KAAM,IAAG;AAAA,IAC7C,OAED;AACG,YAAM,IAAI,UAAU,sFAAsF;AAAA,IAC5G;AAED,QAAI,CAAC,aAAa,MAAM,aAAa,GACrC;AACG,YAAM,IAAI,UAAU,qEAAqE;AAAA,IAC3F;AAED,WAAO,QAAQ,MAAM;AAErB,QAAI,OAAO,SAAS,UAAU;AAAE,YAAM,IAAI,UAAU,4DAA4D;AAAA,IAAI;AAEpH,QAAI,aAAa,OAAO,IAAI,IAAI,GAChC;AACG,aAAO,aAAa,OAAO,IAAI,IAAI;AAAA,IACrC,OAED;AACG,YAAM,eAAe,aAAa,EAAE,MAAM,YAAY,GAAG,KAAM,IAAG,EAAE,GAAG;AACvE,YAAM,QAAQ,IAAI,KAAK,YAAY;AACnC,mBAAa,OAAO,IAAI,MAAM,KAAK;AACnC,aAAO;AAAA,IACT;AAAA,EACH;AAAA,EAaD,QAAQ,cAAc,WACtB;AACG,QAAI,QAAQ;AAGZ,QAAI,iBAAiB,QACrB;AACG,iBAAW,gBAAgB,KAAK,MAAM,OAAQ,GAC9C;AACG,qBAAa,aAAa;AAC1B,mBAAW,SAAS,aAAa,OAAO,OAAQ,GAChD;AACG,gBAAM,QAAO;AACb;AAAA,QACF;AAAA,MACH;AAED,WAAK,MAAM;IACb,WACQ,OAAO,iBAAiB,YAAY,cAAc,QAC3D;AACG,YAAM,eAAe,KAAK,MAAM,IAAI,YAAY;AAChD,UAAI,cACJ;AACG,qBAAa,aAAa;AAC1B,mBAAW,SAAS,aAAa,OAAO,OAAQ,GAChD;AACG,gBAAM,QAAO;AACb;AAAA,QACF;AAAA,MACH;AAED,WAAK,MAAM,OAAO,YAAY;AAAA,IAChC,WACQ,OAAO,iBAAiB,YAAY,cAAc,UAC3D;AACG,YAAM,eAAe,KAAK,MAAM,IAAI,YAAY;AAChD,UAAI,cACJ;AACG,cAAM,QAAQ,aAAa,OAAO,IAAI,SAAS;AAC/C,YAAI,OACJ;AACG,gBAAM,QAAO;AACb;AAAA,QACF;AAAA,MACH;AAAA,IACH;AAED,WAAO,QAAQ;AAAA,EACjB;AAAA,EAWD,IAAI,cAAc,WAClB;AACG,QAAI,CAAC,KAAK,MAAM,IAAI,YAAY,GAAG;AAAE,aAAO;AAAA,IAAS;AAErD,WAAO,KAAK,MAAM,IAAI,YAAY,EAAE,OAAO,IAAI,SAAS;AAAA,EAC1D;AAAA,EAKD,kBACA;AACG,UAAM,MAAM,KAAK,UAAU;AAE3B,QAAI,eAAe,QAAQ,SAAS,UACpC;AACG,YAAM,wBAAwB,IAAI,IAAI,KAAK,MAAM,KAAI,CAAE;AAGvD,YAAM,gBAAgB,OAAO,KAAK,IAAI,aAAa,UAAU,YAAY,CAAA,CAAE;AAG3E,WAAK,eAAe;AAEpB,iBAAW,gBAAgB,eAC3B;AAEG,8BAAsB,OAAO,YAAY;AAGzC,aAAK,eAAe,IAAI,SAAS,cAAc;AAC/C,aAAK,eAAe,IAAI,SAAS,cAAc;AAC/C,aAAK,eAAe,IAAI,SAAS,cAAc;AAE/C,YAAI,aAAa;AAEjB,YACA;AAEG,uBAAa,IAAI,sBAAsB,YAAY;AAAA,QACrD,SACM,KAAP;AAEG,kBAAQ,KAAK,iFACZ,cAAc;AAAA,QACjB;AAGD,cAAM,eAAe,KAAK,MAAM,IAAI,YAAY;AAChD,YAAI,cACJ;AACG,uBAAa,aAAa;AAG1B,qBAAW,SAAS,aAAa,OAAO,OAAM,GAAI;AAAE,kBAAM,QAAQ,YAAY,IAAI;AAAA,UAAI;AAAA,QACxF;AAAA,MACH;AAGD,iBAAW,gBAAgB,uBAC3B;AACG,cAAM,eAAe,KAAK,MAAM,IAAI,YAAY;AAChD,YAAI,cACJ;AACG,uBAAa,aAAa;AAE1B,qBAAW,SAAS,aAAa,OAAO,OAAM,GAAI;AAAE,kBAAM,QAAQ,MAAM,IAAI;AAAA,UAAI;AAAA,QAClF;AAAA,MACH;AAAA,IACH,OAED;AACG,WAAK,eAAe;AAEpB,iBAAW,gBAAgB,KAAK,MAAM,OAAQ,GAC9C;AACG,qBAAa,aAAa;AAE1B,mBAAW,SAAS,aAAa,OAAO,OAAM,GAAI;AAAE,gBAAM,QAAQ,MAAM,IAAI;AAAA,QAAI;AAAA,MAClF;AAAA,IACH;AAAA,EACH;AAAA,EASD,aAAa,eACb;AACG,QAAI,CAAC,KAAK,eAAe,IAAI,aAAa,GAAG;AAAE;AAAA,IAAS;AAExD,UAAM,QAAQ,qBAAqB,oBAAoB,KAAK,aAAa;AAEzE,QAAI,OACJ;AACG,YAAM,eAAe,MAAM;AAC3B,UAAI,CAAC,KAAK,MAAM,IAAI,YAAY,GAAG;AAAE;AAAA,MAAS;AAE9C,iBAAW,SAAS,KAAK,MAAM,IAAI,YAAY,EAAE,OAAO,OAAQ,GAChE;AACG,cAAM,MAAM,OAAO,IAAI;AAAA,MACzB;AAAA,IACH;AAAA,EACH;AACJ;AAjTM;AAgUN,MAAM,YACN;AAAA,EAIG,YAAY,CAAC,MAAM;AAAA,EAKnB;AAAA,EACA;AAAA,EAKA;AAAA,EAKA,WAAW,EAAE,QAAQ;EAErB,iBAAiB,CAAA;AAAA,EACjB;AAAA,EAOA,YAAY,WAAU,UAAU,CAAE,GAClC;AACG,SAAK,UAAU,gBAAgB,OAAM;AAErC,QAAI,cAAc,SAAQ,GAC1B;AACG,WAAK,WAAW,SAAQ;AAAA,IAC1B,OAED;AACG,WAAK,WAAW,OAAO;AACvB,WAAK,IAAI,SAAQ;AAAA,IACnB;AAAA,EACH;AAAA,EAKD,IAAI,WACJ;AACG,QAAI,CAAC,KAAK,cACV;AACG,WAAK,wBAAwB,IAAI,qBAAqB,KAAK,SAAS;AACpE,WAAK,eAAe;AAAA,QACjB,QAAQ,CAAC,cAAc,YAAY,KAAK,sBAAsB,OAAO,cAAc,OAAO;AAAA,QAC1F,SAAS,CAAC,cAAc,cAAc,KAAK,sBAAsB,QAAQ,cAAc,SAAS;AAAA,QAChG,KAAK,CAAC,cAAc,cAAc,KAAK,sBAAsB,IAAI,cAAc,SAAS;AAAA,MACpG;AAAA,IACO;AAED,WAAO,KAAK;AAAA,EACd;AAAA,EAOD,IAAI,gBAAgB;AAAE,WAAO,KAAK,kBAAkB,CAAE;AAAA,EAAG;AAAA,EAOzD,IAAI,SAAS;AAAE,WAAO,KAAK;AAAA,EAAU;AAAA,EAOrC,MAAM,WACN;AACG,UAAM,MAAM,KAAK,UAAU;AAG3B,QAAI,eAAe,QAAQ,SAAS,YAAY,CAAC,KAAK,YAAY,IAAI,IAAI,EAAE,GAC5E;AACG,aAAO,KAAK,KAAK,KAAK;AACtB,WAAK,aAAa,MAAM;AAExB,WAAK,mBAAmB,OAAO,EAAE,QAAQ,UAAU,MAAM,OAAM,CAAE;AAEjE,UAAI,OAAO,KAAK,SAAS,WAAW,YAAY;AAAE,cAAM,KAAK,SAAS,OAAM;AAAA,MAAK;AAEjF,WAAK,iBAAiB;AAAA,IACxB;AAAA,EACH;AAAA,EAMD,UACA;AACG,UAAM,MAAM,KAAK,UAAU;AAE3B,QAAI,KAAK,uBACT;AACG,WAAK,sBAAsB;AAC3B,WAAK,wBAAwB;AAC7B,WAAK,eAAe;AAAA,IACtB;AAED,QAAI,eAAe,QAAQ,SAAS,UACpC;AACG,aAAO,KAAK,KAAK,KAAK;AACtB,WAAK,aAAa,MAAM;AAAA,IAC1B;AAED,SAAK,SAAS,SAAS;AACvB,SAAK,eAAe,SAAS;AAAA,EAC/B;AAAA,EAOD,mBAAmB,QAAQ,OAAO,UAAU,CAAE,GAC9C;AACG,SAAK,iBAAiB;AAEtB,UAAM,MAAM,KAAK,UAAU;AAE3B,aAAS,OAAO,GAAG,OAAO,KAAK,eAAe,QAAQ,QAAQ;AAAE,WAAK,eAAe,MAAM,KAAK,OAAO;AAAA,IAAI;AAE1G,QAAI,KAAK,uBACT;AACG,WAAK,sBAAsB,aAAa,QAAQ,aAAa;AAAA,IAC/D;AAAA,EACH;AAAA,EAKD,MAAM;AAAE,WAAO,KAAK,UAAU;AAAA,EAAK;AAAA,EAOnC,IAAI,WAAU,UAAU,CAAE,GAC1B;AACG,QAAI,KAAK,UAAU,IACnB;AACG,aAAO,KAAK,UAAU,GAAG,KAAK,KAAK;AAAA,IACrC;AAED,QAAI,cAAa,UAAU,CAAE,sBAAoB,QAAQ,SAAS,WAClE;AACG,YAAM,IAAI,UAAU,yEAAyE;AAAA,IAC/F;AAED,QAAI,YAAY,QAAQ,OAAO,YAAY,UAC3C;AACG,YAAM,IAAI,UAAU,oDAAoD;AAAA,IAC1E;AAED,QAAI,qBAAoB,QAAQ,SAAS,UACzC;AACG,gBAAS,KAAK,KAAK,WAAW;AAAA,QAC3B,OAAO,KAAK,SAAS,KAAK,IAAI;AAAA,QAC9B,QAAQ,KAAK,mBAAmB,KAAK,IAAI;AAAA,MACrD;AAAA,IACO;AAED,SAAK,aAAa,SAAQ;AAC1B,SAAK,iBAAiB;AACtB,SAAK,mBAAkB;AAAA,EACzB;AAAA,EAMD,aAAa,KACb;AACG,SAAK,UAAU,KAAK;AAEpB,QAAI,KAAK,uBAAuB;AAAE,WAAK,sBAAsB,gBAAe;AAAA,IAAK;AAAA,EACnF;AAAA,EAWD,MAAM,oBAAoB,MAAM,SAChC;AACG,WAAO,KAAK,YAAY,wBAAwB,MAAM,OAAO,GAAG,OAAO;AAAA,EACzE;AAAA,EAWD,MAAM,YAAY,MAAM,UAAU,CAAE,GACpC;AACG,QAAI,OAAO,SAAS,YAAY,KAAK,WAAW,GAAG;AAAE,aAAO;AAAA,IAAQ;AAEpE,QACA;AACG,YAAM,MAAM,MAAM,WAAW,SAAS,IAAI;AAE1C,UAAI,KACJ;AACG,aAAK,IAAI,KAAK,OAAO;AACrB,eAAO;AAAA,MACT;AAAA,IACH,SACM,KAAP;AAAA,IAAoB;AAEpB,WAAO;AAAA,EACT;AAAA,EAOD,WAAW,SACX;AACG,QAAI,CAAC,SAAS,OAAO,GACrB;AACG,YAAM,IAAI,UAAU,qDAAqD;AAAA,IAC3E;AAED,QAAI,QAAQ,WAAW,UAAU,OAAO,QAAQ,WAAW,YAC3D;AACG,YAAM,IAAI,UAAU,qEAAqE;AAAA,IAC3F;AAED,QAAI,QAAQ,WAAW,UAAU,OAAO,QAAQ,WAAW,YAC3D;AACG,WAAK,SAAS,SAAS,QAAQ;AAAA,IACjC;AAAA,EACH;AAAA,EAOD,UAAU,SACV;AACG,SAAK,eAAe,KAAK,OAAO;AAEhC,UAAM,gBAAgB,EAAE,QAAQ,aAAa,MAAM;AAEnD,YAAQ,KAAK,UAAU,IAAI,aAAa;AAGxC,WAAO,MACP;AACG,YAAM,QAAQ,KAAK,eAAe,UAAU,CAAC,QAAQ,QAAQ,OAAO;AACpE,UAAI,SAAS,GAAG;AAAE,aAAK,eAAe,OAAO,OAAO,CAAC;AAAA,MAAI;AAAA,IAClE;AAAA,EACI;AACJ;AAzRM;AAogBN,MAAM,aAAaC,SAAW,MAAM;AAKpC,MAAM,YAAY;AAAA,EACf,WAAW,WAAW;AAAA,EACtB,KAAK,MAAM;AACd;AAEA,OAAO,OAAO,SAAS;AAEvB,MAAM,KAAK,SAAS,MAAM,WAAW,IAAI,IAAI,CAAC;ACx2G9C,kBAAkB,GAAG;AACjB,QAAM,IAAI,IAAI;AACd,SAAO,IAAI,IAAI,IAAI;AACvB;AAHS;AAiET,kBAAkB,GAAG;AACjB,SAAO,EAAE,IAAI,IAAI,IAAI,IAAI,IAAI;AACjC;AAFS;ACnHT,gBAAgB,OAAO,KAAK,QAC5B;AACG,SAAQ,KAAI,UAAU,QAAQ,SAAS;AAC1C;AAHS;AAYT,kBAAkB,KAClB;AACG,SAAO,MAAO,MAAK,KAAK;AAC3B;AAHS;AAsBT,IAAI,UAAU;AACd,IAAI,aAAa,OAAO,iBAAiB,cAAc,eAAe;AACtE,IAAI,SAAS,KAAK;AAiClB,IAAI,CAAC,KAAK;AAAO,OAAK,QAAQ,WAAY;AACxC,QAAI,IAAI,GACJ,IAAI,UAAU;AAElB,WAAO,KAAK;AACV,WAAK,UAAU,KAAK,UAAU;AAAA,IAC/B;AAED,WAAO,KAAK,KAAK,CAAC;AAAA,EACpB;AAw+BA,oBAAoB;AAClB,MAAI,MAAM,IAAI,WAAW,CAAC;AAE1B,MAAI,cAAc,cAAc;AAC9B,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AAAA,EACV;AAED,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,SAAO;AACT;AAhBS;AA8yBT,oBAAoB;AAClB,MAAI,MAAM,IAAI,WAAW,EAAE;AAE3B,MAAI,cAAc,cAAc;AAC9B,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,MAAM;AACV,QAAI,MAAM;AACV,QAAI,MAAM;AACV,QAAI,MAAM;AAAA,EACX;AAED,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AAvBS;AA+BT,iBAAiB,GAAG;AAClB,MAAI,MAAM,IAAI,WAAW,EAAE;AAC3B,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,SAAO;AACT;AAnBS;AA4BT,gBAAgB,KAAK,GAAG;AACtB,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,SAAO;AACT;AAlBS;AAyCT,sBAAsB,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK;AACpG,MAAI,MAAM,IAAI,WAAW,EAAE;AAC3B,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AAnBS;AA2CT,eAAe,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK;AAClG,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AAlBS;AA0BT,oBAAoB,KAAK;AACvB,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AAlBS;AA2BT,mBAAmB,KAAK,GAAG;AAEzB,MAAI,QAAQ,GAAG;AACb,QAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK;AACT,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM;AACV,QAAI,MAAM;AACV,QAAI,MAAM;AAAA,EACd,OAAS;AACL,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AAAA,EACb;AAED,SAAO;AACT;AAzCS;AAkDT,kBAAkB,KAAK,GAAG;AACxB,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAE5B,MAAI,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM;AAE5E,MAAI,CAAC,KAAK;AACR,WAAO;AAAA,EACR;AAED,QAAM,IAAM;AACZ,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,KAAM,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAC/C,MAAI,MAAO,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAChD,MAAI,MAAO,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAChD,MAAI,MAAO,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAChD,MAAI,MAAO,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAChD,MAAI,MAAO,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAChD,MAAI,MAAO,OAAM,MAAM,MAAM,MAAM,MAAM,OAAO;AAChD,SAAO;AACT;AAtDS;AA+DT,iBAAiB,KAAK,GAAG;AACvB,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,KAAK,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AAClG,MAAI,KAAK,CAAE,OAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACpG,MAAI,KAAK,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AAClG,MAAI,KAAK,CAAE,OAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACpG,MAAI,KAAK,CAAE,OAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACpG,MAAI,KAAK,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AAClG,MAAI,KAAK,CAAE,OAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACpG,MAAI,KAAK,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AAClG,MAAI,KAAK,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AAClG,MAAI,KAAK,CAAE,OAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACpG,MAAI,MAAM,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACnG,MAAI,MAAM,CAAE,OAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACrG,MAAI,MAAM,CAAE,OAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACrG,MAAI,MAAM,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACnG,MAAI,MAAM,CAAE,OAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACrG,MAAI,MAAM,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM,OAAO,MAAO,OAAM,MAAM,MAAM;AACnG,SAAO;AACT;AAlCS;AA0CT,qBAAqB,GAAG;AACtB,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAC5B,MAAI,MAAM,MAAM,MAAM,MAAM;AAE5B,SAAO,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM;AAC3E;AA/BS;AAyCT,oBAAoB,KAAK,GAAG,GAAG;AAC7B,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,IACR,MAAM,EAAE,IACR,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE;AAEZ,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,OAAK,EAAE;AACP,OAAK,EAAE;AACP,OAAK,EAAE;AACP,OAAK,EAAE;AACP,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,OAAK,EAAE;AACP,OAAK,EAAE;AACP,OAAK,EAAE;AACP,OAAK,EAAE;AACP,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,MAAI,KAAK,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAC/C,MAAI,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAChD,MAAI,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAChD,OAAK,EAAE;AACP,OAAK,EAAE;AACP,OAAK,EAAE;AACP,OAAK,EAAE;AACP,MAAI,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAChD,MAAI,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAChD,MAAI,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAChD,MAAI,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK,MAAM,KAAK;AAChD,SAAO;AACT;AAnDS;AA6DT,qBAAqB,KAAK,GAAG,GAAG;AAC9B,MAAI,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE;AACV,MAAI,KAAK,KAAK,KAAK;AACnB,MAAI,KAAK,KAAK,KAAK;AACnB,MAAI,KAAK,KAAK,KAAK;AAEnB,MAAI,MAAM,KAAK;AACb,QAAI,MAAM,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE;AAC7C,QAAI,MAAM,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE;AAC7C,QAAI,MAAM,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,MAAM,IAAI,EAAE;AAC9C,QAAI,MAAM,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,MAAM,IAAI,EAAE;AAAA,EAClD,OAAS;AACL,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,UAAM,EAAE;AACR,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,MAAM;AACV,QAAI,MAAM;AACV,QAAI,MAAM,MAAM,IAAI,MAAM,IAAI,MAAM,IAAI,EAAE;AAC1C,QAAI,MAAM,MAAM,IAAI,MAAM,IAAI,MAAM,IAAI,EAAE;AAC1C,QAAI,MAAM,MAAM,IAAI,MAAM,IAAI,MAAM,IAAI,EAAE;AAC1C,QAAI,MAAM,MAAM,IAAI,MAAM,IAAI,MAAM,IAAI,EAAE;AAAA,EAC3C;AAED,SAAO;AACT;AA7CS;AAuDT,iBAAiB,KAAK,GAAG,GAAG;AAC1B,MAAI,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE;AACV,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,MAAM,EAAE,MAAM;AAClB,MAAI,MAAM,EAAE,MAAM;AAClB,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,SAAO;AACT;AArBS;AAgCT,kBAAkB,KAAK,GAAG,KAAK,MAAM;AACnC,MAAI,IAAI,KAAK,IACT,IAAI,KAAK,IACT,IAAI,KAAK;AACb,MAAI,MAAM,KAAK,MAAM,GAAG,GAAG,CAAC;AAC5B,MAAI,GAAG,GAAG;AACV,MAAI,KAAK,KAAK,KAAK;AACnB,MAAI,KAAK,KAAK,KAAK;AACnB,MAAI,KAAK,KAAK,KAAK;AACnB,MAAI,KAAK,KAAK;AACd,MAAI,KAAK,KAAK;AACd,MAAI,KAAK,KAAK;AAEd,MAAI,MAAM,SAAS;AACjB,WAAO;AAAA,EACR;AAED,QAAM,IAAI;AACV,OAAK;AACL,OAAK;AACL,OAAK;AACL,MAAI,KAAK,IAAI,GAAG;AAChB,MAAI,KAAK,IAAI,GAAG;AAChB,MAAI,IAAI;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AACR,QAAM,EAAE;AAER,QAAM,IAAI,IAAI,IAAI;AAClB,QAAM,IAAI,IAAI,IAAI,IAAI;AACtB,QAAM,IAAI,IAAI,IAAI,IAAI;AACtB,QAAM,IAAI,IAAI,IAAI,IAAI;AACtB,QAAM,IAAI,IAAI,IAAI;AAClB,QAAM,IAAI,IAAI,IAAI,IAAI;AACtB,QAAM,IAAI,IAAI,IAAI,IAAI;AACtB,QAAM,IAAI,IAAI,IAAI,IAAI;AACtB,QAAM,IAAI,IAAI,IAAI;AAElB,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,KAAK,MAAM,MAAM,MAAM,MAAM,MAAM;AACvC,MAAI,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM;AACxC,MAAI,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM;AAExC,MAAI,MAAM,KAAK;AAEb,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AAAA,EACb;AAED,SAAO;AACT;AArES;AA+ET,mBAAmB,KAAK,GAAG,KAAK;AAC9B,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AAEZ,MAAI,MAAM,KAAK;AAEb,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AAAA,EACb;AAGD,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,MAAM,MAAM,IAAI,MAAM;AAC1B,MAAI,MAAM,MAAM,IAAI,MAAM;AAC1B,SAAO;AACT;AAlCS;AA4CT,mBAAmB,KAAK,GAAG,KAAK;AAC9B,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AAEZ,MAAI,MAAM,KAAK;AAEb,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AAAA,EACb;AAGD,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,MAAM,MAAM,IAAI,MAAM;AAC1B,MAAI,MAAM,MAAM,IAAI,MAAM;AAC1B,SAAO;AACT;AAlCS;AA4CT,mBAAmB,KAAK,GAAG,KAAK;AAC9B,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AAEZ,MAAI,MAAM,KAAK;AAEb,QAAI,KAAK,EAAE;AACX,QAAI,KAAK,EAAE;AACX,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AACZ,QAAI,MAAM,EAAE;AAAA,EACb;AAGD,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,MAAI,KAAK,MAAM,IAAI,MAAM;AACzB,SAAO;AACT;AAlCS;AA+CT,2BAA2B,KAAK,GAAG;AACjC,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM;AACV,SAAO;AACT;AAlBS;AA+BT,qBAAqB,KAAK,GAAG;AAC3B,MAAI,KAAK,EAAE;AACX,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK,EAAE;AACX,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AAlBS;AAgCT,wBAAwB,KAAK,KAAK,MAAM;AACtC,MAAI,IAAI,KAAK,IACT,IAAI,KAAK,IACT,IAAI,KAAK;AACb,MAAI,MAAM,KAAK,MAAM,GAAG,GAAG,CAAC;AAC5B,MAAI,GAAG,GAAG;AAEV,MAAI,MAAM,SAAS;AACjB,WAAO;AAAA,EACR;AAED,QAAM,IAAI;AACV,OAAK;AACL,OAAK;AACL,OAAK;AACL,MAAI,KAAK,IAAI,GAAG;AAChB,MAAI,KAAK,IAAI,GAAG;AAChB,MAAI,IAAI;AAER,MAAI,KAAK,IAAI,IAAI,IAAI;AACrB,MAAI,KAAK,IAAI,IAAI,IAAI,IAAI;AACzB,MAAI,KAAK,IAAI,IAAI,IAAI,IAAI;AACzB,MAAI,KAAK;AACT,MAAI,KAAK,IAAI,IAAI,IAAI,IAAI;AACzB,MAAI,KAAK,IAAI,IAAI,IAAI;AACrB,MAAI,KAAK,IAAI,IAAI,IAAI,IAAI;AACzB,MAAI,KAAK;AACT,MAAI,KAAK,IAAI,IAAI,IAAI,IAAI;AACzB,MAAI,KAAK,IAAI,IAAI,IAAI,IAAI;AACzB,MAAI,MAAM,IAAI,IAAI,IAAI;AACtB,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AApCS;AAiDT,uBAAuB,KAAK,KAAK;AAC/B,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,IAAI,KAAK,IAAI,GAAG;AAEpB,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK,CAAC;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AArBS;AAkCT,uBAAuB,KAAK,KAAK;AAC/B,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,IAAI,KAAK,IAAI,GAAG;AAEpB,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK,CAAC;AACV,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AArBS;AAkCT,uBAAuB,KAAK,KAAK;AAC/B,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,IAAI,KAAK,IAAI,GAAG;AAEpB,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK,CAAC;AACV,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AArBS;AAsCT,mCAAmC,KAAK,GAAG,GAAG;AAE5C,MAAI,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE;AACV,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAK,MAAK;AACnB,MAAI,KAAK,KAAK;AACd,MAAI,KAAK,KAAK;AACd,MAAI,KAAK;AACT,MAAI,KAAK,KAAK;AACd,MAAI,KAAK,IAAK,MAAK;AACnB,MAAI,KAAK,KAAK;AACd,MAAI,KAAK;AACT,MAAI,KAAK,KAAK;AACd,MAAI,KAAK,KAAK;AACd,MAAI,MAAM,IAAK,MAAK;AACpB,MAAI,MAAM;AACV,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM;AACV,SAAO;AACT;AAnCS;AA4CT,mBAAmB,KAAK,GAAG;AACzB,MAAI,cAAc,IAAI,WAAW,CAAC;AAClC,MAAI,KAAK,CAAC,EAAE,IACR,KAAK,CAAC,EAAE,IACR,KAAK,CAAC,EAAE,IACR,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,YAAY,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK;AAEnD,MAAI,YAAY,GAAG;AACjB,gBAAY,KAAM,MAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,MAAM,IAAI;AAC/D,gBAAY,KAAM,MAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,MAAM,IAAI;AAC/D,gBAAY,KAAM,MAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,MAAM,IAAI;AAAA,EACnE,OAAS;AACL,gBAAY,KAAM,MAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,MAAM;AAC3D,gBAAY,KAAM,MAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,MAAM;AAC3D,gBAAY,KAAM,MAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,MAAM;AAAA,EAC5D;AAED,4BAA0B,KAAK,GAAG,WAAW;AAC7C,SAAO;AACT;AAxBS;AAmCT,0BAA0B,KAAK,KAAK;AAClC,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,SAAO;AACT;AALS;AAiBT,oBAAoB,KAAK,KAAK;AAC5B,MAAI,MAAM,IAAI;AACd,MAAI,MAAM,IAAI;AACd,MAAI,MAAM,IAAI;AACd,MAAI,MAAM,IAAI;AACd,MAAI,MAAM,IAAI;AACd,MAAI,MAAM,IAAI;AACd,MAAI,MAAM,IAAI;AACd,MAAI,MAAM,IAAI;AACd,MAAI,MAAM,IAAI;AACd,MAAI,KAAK,KAAK,MAAM,KAAK,KAAK,GAAG;AACjC,MAAI,KAAK,KAAK,MAAM,KAAK,KAAK,GAAG;AACjC,MAAI,KAAK,KAAK,MAAM,KAAK,KAAK,GAAG;AACjC,SAAO;AACT;AAdS;AAyBT,qBAAqB,KAAK,KAAK;AAC7B,MAAI,UAAU,IAAI,WAAW,CAAC;AAC9B,aAAW,SAAS,GAAG;AACvB,MAAI,MAAM,IAAI,QAAQ;AACtB,MAAI,MAAM,IAAI,QAAQ;AACtB,MAAI,MAAM,IAAI,QAAQ;AACtB,MAAI,OAAO,IAAI,KAAK;AACpB,MAAI,OAAO,IAAI,KAAK;AACpB,MAAI,OAAO,IAAI,KAAK;AACpB,MAAI,OAAO,IAAI,KAAK;AACpB,MAAI,OAAO,IAAI,KAAK;AACpB,MAAI,OAAO,IAAI,KAAK;AACpB,MAAI,OAAO,IAAI,KAAK;AACpB,MAAI,OAAO,IAAI,KAAK;AACpB,MAAI,OAAO,IAAI,MAAM;AACrB,MAAI,QAAQ,OAAO,OAAO;AAC1B,MAAI,IAAI;AAER,MAAI,QAAQ,GAAG;AACb,QAAI,KAAK,KAAK,QAAQ,CAAG,IAAI;AAC7B,QAAI,KAAK,OAAO;AAChB,QAAI,KAAM,QAAO,QAAQ;AACzB,QAAI,KAAM,QAAO,QAAQ;AACzB,QAAI,KAAM,QAAO,QAAQ;AAAA,EAC1B,WAAU,OAAO,QAAQ,OAAO,MAAM;AACrC,QAAI,KAAK,KAAK,IAAM,OAAO,OAAO,IAAI,IAAI;AAC1C,QAAI,KAAM,QAAO,QAAQ;AACzB,QAAI,KAAK,OAAO;AAChB,QAAI,KAAM,QAAO,QAAQ;AACzB,QAAI,KAAM,QAAO,QAAQ;AAAA,EAC7B,WAAa,OAAO,MAAM;AACtB,QAAI,KAAK,KAAK,IAAM,OAAO,OAAO,IAAI,IAAI;AAC1C,QAAI,KAAM,QAAO,QAAQ;AACzB,QAAI,KAAM,QAAO,QAAQ;AACzB,QAAI,KAAK,OAAO;AAChB,QAAI,KAAM,QAAO,QAAQ;AAAA,EAC7B,OAAS;AACL,QAAI,KAAK,KAAK,IAAM,OAAO,OAAO,IAAI,IAAI;AAC1C,QAAI,KAAM,QAAO,QAAQ;AACzB,QAAI,KAAM,QAAO,QAAQ;AACzB,QAAI,KAAM,QAAO,QAAQ;AACzB,QAAI,KAAK,OAAO;AAAA,EACjB;AAED,SAAO;AACT;AA7CS;AAgET,sCAAsC,KAAK,GAAG,GAAG,GAAG;AAElD,MAAI,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE;AACV,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAM,KAAK,MAAK,OAAO;AAC3B,MAAI,KAAM,MAAK,MAAM;AACrB,MAAI,KAAM,MAAK,MAAM;AACrB,MAAI,KAAK;AACT,MAAI,KAAM,MAAK,MAAM;AACrB,MAAI,KAAM,KAAK,MAAK,OAAO;AAC3B,MAAI,KAAM,MAAK,MAAM;AACrB,MAAI,KAAK;AACT,MAAI,KAAM,MAAK,MAAM;AACrB,MAAI,KAAM,MAAK,MAAM;AACrB,MAAI,MAAO,KAAK,MAAK,OAAO;AAC5B,MAAI,MAAM;AACV,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE;AACZ,MAAI,MAAM;AACV,SAAO;AACT;AAtCS;AA4DT,4CAA4C,KAAK,GAAG,GAAG,GAAG,GAAG;AAE3D,MAAI,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE;AACV,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,OAAQ,KAAK,MAAK,OAAO;AAC7B,MAAI,OAAQ,MAAK,MAAM;AACvB,MAAI,OAAQ,MAAK,MAAM;AACvB,MAAI,OAAQ,MAAK,MAAM;AACvB,MAAI,OAAQ,KAAK,MAAK,OAAO;AAC7B,MAAI,OAAQ,MAAK,MAAM;AACvB,MAAI,OAAQ,MAAK,MAAM;AACvB,MAAI,OAAQ,MAAK,MAAM;AACvB,MAAI,QAAS,KAAK,MAAK,OAAO;AAC9B,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM,EAAE,KAAK,KAAM,QAAO,KAAK,OAAO,KAAK,OAAO;AACtD,MAAI,MAAM,EAAE,KAAK,KAAM,QAAO,KAAK,OAAO,KAAK,OAAO;AACtD,MAAI,MAAM,EAAE,KAAK,KAAM,QAAO,KAAK,OAAO,KAAK,QAAQ;AACvD,MAAI,MAAM;AACV,SAAO;AACT;AAlDS;AA4DT,kBAAkB,KAAK,GAAG;AACxB,MAAI,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE;AACV,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI,KAAK;AAClB,MAAI,KAAK,KAAK;AACd,MAAI,KAAK,KAAK;AACd,MAAI,KAAK;AACT,MAAI,KAAK,KAAK;AACd,MAAI,KAAK,IAAI,KAAK;AAClB,MAAI,KAAK,KAAK;AACd,MAAI,KAAK;AACT,MAAI,KAAK,KAAK;AACd,MAAI,KAAK,KAAK;AACd,MAAI,MAAM,IAAI,KAAK;AACnB,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AAlCS;AAgDT,iBAAiB,KAAK,MAAM,OAAO,QAAQ,KAAK,MAAM,KAAK;AACzD,MAAI,KAAK,IAAK,SAAQ;AACtB,MAAI,KAAK,IAAK,OAAM;AACpB,MAAI,KAAK,IAAK,QAAO;AACrB,MAAI,KAAK,OAAO,IAAI;AACpB,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK,OAAO,IAAI;AACpB,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAM,SAAQ,QAAQ;AAC1B,MAAI,KAAM,OAAM,UAAU;AAC1B,MAAI,MAAO,OAAM,QAAQ;AACzB,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM,MAAM,OAAO,IAAI;AAC3B,MAAI,MAAM;AACV,SAAO;AACT;AArBS;AAoCT,uBAAuB,KAAK,MAAM,QAAQ,MAAM,KAAK;AACnD,MAAI,IAAI,IAAM,KAAK,IAAI,OAAO,CAAC,GAC3B;AACJ,MAAI,KAAK,IAAI;AACb,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AAEV,MAAI,OAAO,QAAQ,QAAQ,UAAU;AACnC,SAAK,IAAK,QAAO;AACjB,QAAI,MAAO,OAAM,QAAQ;AACzB,QAAI,MAAM,IAAI,MAAM,OAAO;AAAA,EAC/B,OAAS;AACL,QAAI,MAAM;AACV,QAAI,MAAM,KAAK;AAAA,EAChB;AAED,SAAO;AACT;AA5BS;AAkCT,IAAI,cAAc;AAelB,uBAAuB,KAAK,MAAM,QAAQ,MAAM,KAAK;AACnD,MAAI,IAAI,IAAM,KAAK,IAAI,OAAO,CAAC,GAC3B;AACJ,MAAI,KAAK,IAAI;AACb,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AAEV,MAAI,OAAO,QAAQ,QAAQ,UAAU;AACnC,SAAK,IAAK,QAAO;AACjB,QAAI,MAAM,MAAM;AAChB,QAAI,MAAM,MAAM,OAAO;AAAA,EAC3B,OAAS;AACL,QAAI,MAAM;AACV,QAAI,MAAM,CAAC;AAAA,EACZ;AAED,SAAO;AACT;AA5BS;AAyCT,oCAAoC,KAAK,KAAK,MAAM,KAAK;AACvD,MAAI,QAAQ,KAAK,IAAI,IAAI,YAAY,KAAK,KAAK,GAAK;AACpD,MAAI,UAAU,KAAK,IAAI,IAAI,cAAc,KAAK,KAAK,GAAK;AACxD,MAAI,UAAU,KAAK,IAAI,IAAI,cAAc,KAAK,KAAK,GAAK;AACxD,MAAI,WAAW,KAAK,IAAI,IAAI,eAAe,KAAK,KAAK,GAAK;AAC1D,MAAI,SAAS,IAAO,WAAU;AAC9B,MAAI,SAAS,IAAO,SAAQ;AAC5B,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK,CAAG,YAAU,YAAY,SAAS;AAC3C,MAAI,KAAM,SAAQ,WAAW,SAAS;AACtC,MAAI,MAAM,MAAO,QAAO;AACxB,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM,MAAM,OAAQ,QAAO;AAC/B,MAAI,MAAM;AACV,SAAO;AACT;AAxBS;AAwCT,iBAAiB,KAAK,MAAM,OAAO,QAAQ,KAAK,MAAM,KAAK;AACzD,MAAI,KAAK,IAAK,QAAO;AACrB,MAAI,KAAK,IAAK,UAAS;AACvB,MAAI,KAAK,IAAK,QAAO;AACrB,MAAI,KAAK,KAAK;AACd,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK,KAAK;AACd,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM,IAAI;AACd,MAAI,MAAM;AACV,MAAI,MAAO,QAAO,SAAS;AAC3B,MAAI,MAAO,OAAM,UAAU;AAC3B,MAAI,MAAO,OAAM,QAAQ;AACzB,MAAI,MAAM;AACV,SAAO;AACT;AArBS;AA2BT,IAAI,QAAQ;AAgBZ,iBAAiB,KAAK,MAAM,OAAO,QAAQ,KAAK,MAAM,KAAK;AACzD,MAAI,KAAK,IAAK,QAAO;AACrB,MAAI,KAAK,IAAK,UAAS;AACvB,MAAI,KAAK,IAAK,QAAO;AACrB,MAAI,KAAK,KAAK;AACd,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK,KAAK;AACd,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAO,QAAO,SAAS;AAC3B,MAAI,MAAO,OAAM,UAAU;AAC3B,MAAI,MAAM,OAAO;AACjB,MAAI,MAAM;AACV,SAAO;AACT;AArBS;AAiCT,gBAAgB,KAAK,KAAK,QAAQ,IAAI;AACpC,MAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI;AACxC,MAAI,OAAO,IAAI;AACf,MAAI,OAAO,IAAI;AACf,MAAI,OAAO,IAAI;AACf,MAAI,MAAM,GAAG;AACb,MAAI,MAAM,GAAG;AACb,MAAI,MAAM,GAAG;AACb,MAAI,UAAU,OAAO;AACrB,MAAI,UAAU,OAAO;AACrB,MAAI,UAAU,OAAO;AAErB,MAAI,KAAK,IAAI,OAAO,OAAO,IAAI,WAAW,KAAK,IAAI,OAAO,OAAO,IAAI,WAAW,KAAK,IAAI,OAAO,OAAO,IAAI,SAAS;AAClH,WAAO,WAAW,GAAG;AAAA,EACtB;AAED,OAAK,OAAO;AACZ,OAAK,OAAO;AACZ,OAAK,OAAO;AACZ,QAAM,IAAI,KAAK,MAAM,IAAI,IAAI,EAAE;AAC/B,QAAM;AACN,QAAM;AACN,QAAM;AACN,OAAK,MAAM,KAAK,MAAM;AACtB,OAAK,MAAM,KAAK,MAAM;AACtB,OAAK,MAAM,KAAK,MAAM;AACtB,QAAM,KAAK,MAAM,IAAI,IAAI,EAAE;AAE3B,MAAI,CAAC,KAAK;AACR,SAAK;AACL,SAAK;AACL,SAAK;AAAA,EACT,OAAS;AACL,UAAM,IAAI;AACV,UAAM;AACN,UAAM;AACN,UAAM;AAAA,EACP;AAED,OAAK,KAAK,KAAK,KAAK;AACpB,OAAK,KAAK,KAAK,KAAK;AACpB,OAAK,KAAK,KAAK,KAAK;AACpB,QAAM,KAAK,MAAM,IAAI,IAAI,EAAE;AAE3B,MAAI,CAAC,KAAK;AACR,SAAK;AACL,SAAK;AACL,SAAK;AAAA,EACT,OAAS;AACL,UAAM,IAAI;AACV,UAAM;AACN,UAAM;AACN,UAAM;AAAA,EACP;AAED,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM,CAAE,MAAK,OAAO,KAAK,OAAO,KAAK;AACzC,MAAI,MAAM,CAAE,MAAK,OAAO,KAAK,OAAO,KAAK;AACzC,MAAI,MAAM,CAAE,MAAK,OAAO,KAAK,OAAO,KAAK;AACzC,MAAI,MAAM;AACV,SAAO;AACT;AAxES;AAmFT,kBAAkB,KAAK,KAAK,QAAQ,IAAI;AACtC,MAAI,OAAO,IAAI,IACX,OAAO,IAAI,IACX,OAAO,IAAI,IACX,MAAM,GAAG,IACT,MAAM,GAAG,IACT,MAAM,GAAG;AACb,MAAI,KAAK,OAAO,OAAO,IACnB,KAAK,OAAO,OAAO,IACnB,KAAK,OAAO,OAAO;AACvB,MAAI,MAAM,KAAK,KAAK,KAAK,KAAK,KAAK;AAEnC,MAAI,MAAM,GAAG;AACX,UAAM,IAAI,KAAK,KAAK,GAAG;AACvB,UAAM;AACN,UAAM;AACN,UAAM;AAAA,EACP;AAED,MAAI,KAAK,MAAM,KAAK,MAAM,IACtB,KAAK,MAAM,KAAK,MAAM,IACtB,KAAK,MAAM,KAAK,MAAM;AAC1B,QAAM,KAAK,KAAK,KAAK,KAAK,KAAK;AAE/B,MAAI,MAAM,GAAG;AACX,UAAM,IAAI,KAAK,KAAK,GAAG;AACvB,UAAM;AACN,UAAM;AACN,UAAM;AAAA,EACP;AAED,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK,KAAK,KAAK,KAAK;AACxB,MAAI,KAAK,KAAK,KAAK,KAAK;AACxB,MAAI,KAAK,KAAK,KAAK,KAAK;AACxB,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,MAAI,MAAM;AACV,SAAO;AACT;AAhDS;AAwDT,eAAe,GAAG;AAChB,SAAO,UAAU,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,OAAO,EAAE,MAAM,OAAO,EAAE,MAAM,OAAO,EAAE,MAAM,OAAO,EAAE,MAAM,OAAO,EAAE,MAAM;AAClP;AAFS;AAUT,cAAc,GAAG;AACf,SAAO,KAAK,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG;AACxH;AAFS;AAYT,eAAe,KAAK,GAAG,GAAG;AACxB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,SAAO;AACT;AAlBS;AA4BT,oBAAoB,KAAK,GAAG,GAAG;AAC7B,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,MAAI,MAAM,EAAE,MAAM,EAAE;AACpB,SAAO;AACT;AAlBS;AA4BT,wBAAwB,KAAK,GAAG,GAAG;AACjC,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,MAAM,EAAE,MAAM;AAClB,MAAI,MAAM,EAAE,MAAM;AAClB,MAAI,MAAM,EAAE,MAAM;AAClB,MAAI,MAAM,EAAE,MAAM;AAClB,MAAI,MAAM,EAAE,MAAM;AAClB,MAAI,MAAM,EAAE,MAAM;AAClB,SAAO;AACT;AAlBS;AA6BT,8BAA8B,KAAK,GAAG,GAAG,OAAO;AAC9C,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,MAAM,EAAE,MAAM,EAAE,MAAM;AAC1B,MAAI,MAAM,EAAE,MAAM,EAAE,MAAM;AAC1B,MAAI,MAAM,EAAE,MAAM,EAAE,MAAM;AAC1B,MAAI,MAAM,EAAE,MAAM,EAAE,MAAM;AAC1B,MAAI,MAAM,EAAE,MAAM,EAAE,MAAM;AAC1B,MAAI,MAAM,EAAE,MAAM,EAAE,MAAM;AAC1B,SAAO;AACT;AAlBS;AA2BT,uBAAuB,GAAG,GAAG;AAC3B,SAAO,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE;AAC9R;AAFS;AAWT,kBAAkB,GAAG,GAAG;AACtB,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,MAAI,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE,KACR,MAAM,EAAE;AACZ,SAAO,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,MAAM,GAAG,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC,KAAK,KAAK,IAAI,MAAM,GAAG,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC,KAAK,KAAK,IAAI,MAAM,GAAG,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC,KAAK,KAAK,IAAI,MAAM,GAAG,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC,KAAK,KAAK,IAAI,MAAM,GAAG,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC,KAAK,KAAK,IAAI,MAAM,GAAG,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC;AAC5tC;AAlCS;AAwCT,IAAI,QAAQ;AAMZ,IAAI,QAAQ;AAEZ,IAAI,OAAoB,uBAAO,OAAO;AAAA,EACnC,WAAW;AAAA,EACX,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,MAAM;AAAA,EACN,YAAY;AAAA,EACZ,KAAK;AAAA,EACL,UAAU;AAAA,EACV;AAAA,EACA,QAAQ;AAAA,EACR;AAAA,EACA;AAAA,EACA,UAAU;AAAA,EACV,WAAW;AAAA,EACX,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,SAAS;AAAA,EACT,SAAS;AAAA,EACT,iBAAiB;AAAA,EACjB;AAAA,EACA,cAAc;AAAA,EACd;AAAA,EACA;AAAA,EACA;AAAA,EACA,yBAAyB;AAAA,EACzB;AAAA,EACA,gBAAgB;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,KAAK;AAAA,EACL;AAAA,EACA,KAAK;AAAA,EACL,UAAU;AAAA,EACV;AAAA,EACA;AAAA,EACA,aAAa;AAAA,EACb,QAAQ;AAAA,EACR,KAAK;AAAA,EACL,KAAK;AACR,CAAC;AAaD,oBAAoB;AAClB,MAAI,MAAM,IAAI,WAAW,CAAC;AAE1B,MAAI,cAAc,cAAc;AAC9B,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AAAA,EACV;AAED,SAAO;AACT;AAVS;AAkBT,iBAAiB,GAAG;AAClB,MAAI,MAAM,IAAI,WAAW,CAAC;AAC1B,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,SAAO;AACT;AANS;AAcT,kBAAkB,GAAG;AACnB,MAAI,IAAI,EAAE;AACV,MAAI,IAAI,EAAE;AACV,MAAI,IAAI,EAAE;AACV,SAAO,KAAK,MAAM,GAAG,GAAG,CAAC;AAC3B;AALS;AAeT,sBAAsB,GAAG,GAAG,GAAG;AAC7B,MAAI,MAAM,IAAI,WAAW,CAAC;AAC1B,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,SAAO;AACT;AANS;AAeT,gBAAgB,KAAK,GAAG;AACtB,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,SAAO;AACT;AALS;AAgBT,eAAe,KAAK,GAAG,GAAG,GAAG;AAC3B,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,SAAO;AACT;AALS;AAeT,eAAe,KAAK,GAAG,GAAG;AACxB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,SAAO;AACT;AALS;AAeT,oBAAoB,KAAK,GAAG,GAAG;AAC7B,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,SAAO;AACT;AALS;AAeT,oBAAoB,KAAK,GAAG,GAAG;AAC7B,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,SAAO;AACT;AALS;AAeT,kBAAkB,KAAK,GAAG,GAAG;AAC3B,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,SAAO;AACT;AALS;AAcT,gBAAgB,KAAK,GAAG;AACtB,MAAI,KAAK,KAAK,KAAK,EAAE,EAAE;AACvB,MAAI,KAAK,KAAK,KAAK,EAAE,EAAE;AACvB,MAAI,KAAK,KAAK,KAAK,EAAE,EAAE;AACvB,SAAO;AACT;AALS;AAcT,iBAAiB,KAAK,GAAG;AACvB,MAAI,KAAK,KAAK,MAAM,EAAE,EAAE;AACxB,MAAI,KAAK,KAAK,MAAM,EAAE,EAAE;AACxB,MAAI,KAAK,KAAK,MAAM,EAAE,EAAE;AACxB,SAAO;AACT;AALS;AAeT,eAAe,KAAK,GAAG,GAAG;AACxB,MAAI,KAAK,KAAK,IAAI,EAAE,IAAI,EAAE,EAAE;AAC5B,MAAI,KAAK,KAAK,IAAI,EAAE,IAAI,EAAE,EAAE;AAC5B,MAAI,KAAK,KAAK,IAAI,EAAE,IAAI,EAAE,EAAE;AAC5B,SAAO;AACT;AALS;AAeT,eAAe,KAAK,GAAG,GAAG;AACxB,MAAI,KAAK,KAAK,IAAI,EAAE,IAAI,EAAE,EAAE;AAC5B,MAAI,KAAK,KAAK,IAAI,EAAE,IAAI,EAAE,EAAE;AAC5B,MAAI,KAAK,KAAK,IAAI,EAAE,IAAI,EAAE,EAAE;AAC5B,SAAO;AACT;AALS;AAcT,iBAAiB,KAAK,GAAG;AACvB,MAAI,KAAK,KAAK,MAAM,EAAE,EAAE;AACxB,MAAI,KAAK,KAAK,MAAM,EAAE,EAAE;AACxB,MAAI,KAAK,KAAK,MAAM,EAAE,EAAE;AACxB,SAAO;AACT;AALS;AAeT,iBAAiB,KAAK,GAAG,GAAG;AAC1B,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,SAAO;AACT;AALS;AAgBT,uBAAuB,KAAK,GAAG,GAAG,OAAO;AACvC,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,MAAI,KAAK,EAAE,KAAK,EAAE,KAAK;AACvB,SAAO;AACT;AALS;AAcT,oBAAoB,GAAG,GAAG;AACxB,MAAI,IAAI,EAAE,KAAK,EAAE;AACjB,MAAI,IAAI,EAAE,KAAK,EAAE;AACjB,MAAI,IAAI,EAAE,KAAK,EAAE;AACjB,SAAO,KAAK,MAAM,GAAG,GAAG,CAAC;AAC3B;AALS;AAcT,2BAA2B,GAAG,GAAG;AAC/B,MAAI,IAAI,EAAE,KAAK,EAAE;AACjB,MAAI,IAAI,EAAE,KAAK,EAAE;AACjB,MAAI,IAAI,EAAE,KAAK,EAAE;AACjB,SAAO,IAAI,IAAI,IAAI,IAAI,IAAI;AAC7B;AALS;AAaT,yBAAyB,GAAG;AAC1B,MAAI,IAAI,EAAE;AACV,MAAI,IAAI,EAAE;AACV,MAAI,IAAI,EAAE;AACV,SAAO,IAAI,IAAI,IAAI,IAAI,IAAI;AAC7B;AALS;AAcT,kBAAkB,KAAK,GAAG;AACxB,MAAI,KAAK,CAAC,EAAE;AACZ,MAAI,KAAK,CAAC,EAAE;AACZ,MAAI,KAAK,CAAC,EAAE;AACZ,SAAO;AACT;AALS;AAcT,mBAAmB,KAAK,GAAG;AACzB,MAAI,KAAK,IAAM,EAAE;AACjB,MAAI,KAAK,IAAM,EAAE;AACjB,MAAI,KAAK,IAAM,EAAE;AACjB,SAAO;AACT;AALS;AAcT,qBAAqB,KAAK,GAAG;AAC3B,MAAI,IAAI,EAAE;AACV,MAAI,IAAI,EAAE;AACV,MAAI,IAAI,EAAE;AACV,MAAI,MAAM,IAAI,IAAI,IAAI,IAAI,IAAI;AAE9B,MAAI,MAAM,GAAG;AAEX,UAAM,IAAI,KAAK,KAAK,GAAG;AAAA,EACxB;AAED,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,MAAI,KAAK,EAAE,KAAK;AAChB,SAAO;AACT;AAfS;AAwBT,eAAe,GAAG,GAAG;AACnB,SAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;AAC9C;AAFS;AAYT,iBAAiB,KAAK,GAAG,GAAG;AAC1B,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,KAAK,KAAK,KAAK,KAAK;AACxB,MAAI,KAAK,KAAK,KAAK,KAAK;AACxB,MAAI,KAAK,KAAK,KAAK,KAAK;AACxB,SAAO;AACT;AAXS;AAsBT,gBAAgB,KAAK,GAAG,GAAG,GAAG;AAC5B,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,EAAE;AACX,MAAI,KAAK,KAAK,IAAK,GAAE,KAAK;AAC1B,MAAI,KAAK,KAAK,IAAK,GAAE,KAAK;AAC1B,MAAI,KAAK,KAAK,IAAK,GAAE,KAAK;AAC1B,SAAO;AACT;AARS;AAqBT,iBAAiB,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG;AACnC,MAAI,eAAe,IAAI;AACvB,MAAI,UAAU,eAAgB,KAAI,IAAI,KAAK;AAC3C,MAAI,UAAU,eAAgB,KAAI,KAAK;AACvC,MAAI,UAAU,eAAgB,KAAI;AAClC,MAAI,UAAU,eAAgB,KAAI,IAAI;AACtC,MAAI,KAAK,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK;AACnE,MAAI,KAAK,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK;AACnE,MAAI,KAAK,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK;AACnE,SAAO;AACT;AAVS;AAuBT,gBAAgB,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG;AAClC,MAAI,gBAAgB,IAAI;AACxB,MAAI,wBAAwB,gBAAgB;AAC5C,MAAI,eAAe,IAAI;AACvB,MAAI,UAAU,wBAAwB;AACtC,MAAI,UAAU,IAAI,IAAI;AACtB,MAAI,UAAU,IAAI,eAAe;AACjC,MAAI,UAAU,eAAe;AAC7B,MAAI,KAAK,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK;AACnE,MAAI,KAAK,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK;AACnE,MAAI,KAAK,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK,UAAU,EAAE,KAAK;AACnE,SAAO;AACT;AAZS;AAqBT,kBAAkB,KAAK,OAAO;AAC5B,UAAQ,SAAS;AACjB,MAAI,IAAI,OAAM,IAAK,IAAM,KAAK;AAC9B,MAAI,IAAI,WAAW,IAAM;AACzB,MAAI,SAAS,KAAK,KAAK,IAAM,IAAI,CAAC,IAAI;AACtC,MAAI,KAAK,KAAK,IAAI,CAAC,IAAI;AACvB,MAAI,KAAK,KAAK,IAAI,CAAC,IAAI;AACvB,MAAI,KAAK,IAAI;AACb,SAAO;AACT;AATS;AAoBT,yBAAyB,KAAK,GAAG,GAAG;AAClC,MAAI,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE;AACV,MAAI,IAAI,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,MAAM,IAAI,EAAE;AAC5C,MAAI,KAAK;AACT,MAAI,KAAM,GAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,OAAO;AACpD,MAAI,KAAM,GAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,OAAO;AACpD,MAAI,KAAM,GAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,MAAM,IAAI,EAAE,OAAO;AACrD,SAAO;AACT;AAVS;AAoBT,yBAAyB,KAAK,GAAG,GAAG;AAClC,MAAI,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE;AACV,MAAI,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE;AACrC,MAAI,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE;AACrC,MAAI,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE,KAAK,IAAI,EAAE;AACrC,SAAO;AACT;AARS;AAmBT,yBAAyB,KAAK,GAAG,GAAG;AAElC,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,IAAI,EAAE,IACN,IAAI,EAAE,IACN,IAAI,EAAE;AAGV,MAAI,MAAM,KAAK,IAAI,KAAK,GACpB,MAAM,KAAK,IAAI,KAAK,GACpB,MAAM,KAAK,IAAI,KAAK;AAExB,MAAI,OAAO,KAAK,MAAM,KAAK,KACvB,OAAO,KAAK,MAAM,KAAK,KACvB,OAAO,KAAK,MAAM,KAAK;AAE3B,MAAI,KAAK,KAAK;AACd,SAAO;AACP,SAAO;AACP,SAAO;AAEP,UAAQ;AACR,UAAQ;AACR,UAAQ;AAER,MAAI,KAAK,IAAI,MAAM;AACnB,MAAI,KAAK,IAAI,MAAM;AACnB,MAAI,KAAK,IAAI,MAAM;AACnB,SAAO;AACT;AAhCS;AA0CT,mBAAmB,KAAK,GAAG,GAAG,KAAK;AACjC,MAAI,IAAI,CAAE,GACN,IAAI,CAAA;AAER,IAAE,KAAK,EAAE,KAAK,EAAE;AAChB,IAAE,KAAK,EAAE,KAAK,EAAE;AAChB,IAAE,KAAK,EAAE,KAAK,EAAE;AAEhB,IAAE,KAAK,EAAE;AACT,IAAE,KAAK,EAAE,KAAK,KAAK,IAAI,GAAG,IAAI,EAAE,KAAK,KAAK,IAAI,GAAG;AACjD,IAAE,KAAK,EAAE,KAAK,KAAK,IAAI,GAAG,IAAI,EAAE,KAAK,KAAK,IAAI,GAAG;AAEjD,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,SAAO;AACT;AAhBS;AA0BT,mBAAmB,KAAK,GAAG,GAAG,KAAK;AACjC,MAAI,IAAI,CAAE,GACN,IAAI,CAAA;AAER,IAAE,KAAK,EAAE,KAAK,EAAE;AAChB,IAAE,KAAK,EAAE,KAAK,EAAE;AAChB,IAAE,KAAK,EAAE,KAAK,EAAE;AAEhB,IAAE,KAAK,EAAE,KAAK,KAAK,IAAI,GAAG,IAAI,EAAE,KAAK,KAAK,IAAI,GAAG;AACjD,IAAE,KAAK,EAAE;AACT,IAAE,KAAK,EAAE,KAAK,KAAK,IAAI,GAAG,IAAI,EAAE,KAAK,KAAK,IAAI,GAAG;AAEjD,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,SAAO;AACT;AAhBS;AA0BT,mBAAmB,KAAK,GAAG,GAAG,KAAK;AACjC,MAAI,IAAI,CAAE,GACN,IAAI,CAAA;AAER,IAAE,KAAK,EAAE,KAAK,EAAE;AAChB,IAAE,KAAK,EAAE,KAAK,EAAE;AAChB,IAAE,KAAK,EAAE,KAAK,EAAE;AAEhB,IAAE,KAAK,EAAE,KAAK,KAAK,IAAI,GAAG,IAAI,EAAE,KAAK,KAAK,IAAI,GAAG;AACjD,IAAE,KAAK,EAAE,KAAK,KAAK,IAAI,GAAG,IAAI,EAAE,KAAK,KAAK,IAAI,GAAG;AACjD,IAAE,KAAK,EAAE;AAET,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,MAAI,KAAK,EAAE,KAAK,EAAE;AAClB,SAAO;AACT;AAhBS;AAwBT,iBAAiB,GAAG,GAAG;AACrB,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,OAAO,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,EAAE,GAC5C,OAAO,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,EAAE,GAC5C,MAAM,OAAO,MACb,SAAS,OAAO,MAAM,GAAG,CAAC,IAAI;AAClC,SAAO,KAAK,KAAK,KAAK,IAAI,KAAK,IAAI,QAAQ,EAAE,GAAG,CAAC,CAAC;AACpD;AAZS;AAoBT,gBAAgB,KAAK;AACnB,MAAI,KAAK;AACT,MAAI,KAAK;AACT,MAAI,KAAK;AACT,SAAO;AACT;AALS;AAaT,eAAe,GAAG;AAChB,SAAO,UAAU,EAAE,KAAK,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK;AACtD;AAFS;AAWT,uBAAuB,GAAG,GAAG;AAC3B,SAAO,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE;AACtD;AAFS;AAWT,kBAAkB,GAAG,GAAG;AACtB,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,SAAO,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,EAAE,KAAK,UAAU,KAAK,IAAI,GAAK,KAAK,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,CAAC;AACxO;AARS;AAcT,IAAI,QAAQ;AAMZ,IAAI,QAAQ;AAMZ,IAAI,QAAQ;AAMZ,IAAI,SAAS;AAMb,IAAI,YAAY;AAMhB,IAAI,QAAQ;AAMZ,IAAI,WAAW;AAcf,IAAI,YAAY,WAAY;AAC1B,MAAI,MAAM;AACV,SAAO,SAAU,GAAG,QAAQ,QAAQ,OAAO,IAAI,KAAK;AAClD,QAAI,GAAG;AAEP,QAAI,CAAC,QAAQ;AACX,eAAS;AAAA,IACV;AAED,QAAI,CAAC,QAAQ;AACX,eAAS;AAAA,IACV;AAED,QAAI,OAAO;AACT,UAAI,KAAK,IAAI,QAAQ,SAAS,QAAQ,EAAE,MAAM;AAAA,IACpD,OAAW;AACL,UAAI,EAAE;AAAA,IACP;AAED,SAAK,IAAI,QAAQ,IAAI,GAAG,KAAK,QAAQ;AACnC,UAAI,KAAK,EAAE;AACX,UAAI,KAAK,EAAE,IAAI;AACf,UAAI,KAAK,EAAE,IAAI;AACf,SAAG,KAAK,KAAK,GAAG;AAChB,QAAE,KAAK,IAAI;AACX,QAAE,IAAI,KAAK,IAAI;AACf,QAAE,IAAI,KAAK,IAAI;AAAA,IAChB;AAED,WAAO;AAAA,EACX;AACA;AAEA,IAAI,OAAoB,uBAAO,OAAO;AAAA,EACnC,WAAW;AAAA,EACX,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,MAAM;AAAA,EACN,KAAK;AAAA,EACL,KAAK;AAAA,EACL,UAAU;AAAA,EACV,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,MAAM;AAAA,EACN,OAAO;AAAA,EACP,KAAK;AAAA,EACL,KAAK;AAAA,EACL,OAAO;AAAA,EACP,OAAO;AAAA,EACP,aAAa;AAAA,EACb,UAAU;AAAA,EACV,iBAAiB;AAAA,EACjB,eAAe;AAAA,EACf,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,WAAW;AAAA,EACX,KAAK;AAAA,EACL,OAAO;AAAA,EACP,MAAM;AAAA,EACN;AAAA,EACA;AAAA,EACA,QAAQ;AAAA,EACR,eAAe;AAAA,EACf,eAAe;AAAA,EACf,eAAe;AAAA,EACf,SAAS;AAAA,EACT,SAAS;AAAA,EACT,SAAS;AAAA,EACT,OAAO;AAAA,EACP,MAAM;AAAA,EACN,KAAK;AAAA,EACL,aAAa;AAAA,EACb,QAAQ;AAAA,EACR,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,MAAM;AAAA,EACN,SAAS;AAAA,EACT,KAAK;AAAA,EACL,QAAQ;AAAA,EACR,SAAS;AACZ,CAAC;AAaD,oBAAoB;AAClB,MAAI,MAAM,IAAI,WAAW,CAAC;AAE1B,MAAI,cAAc,cAAc;AAC9B,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AAAA,EACV;AAED,SAAO;AACT;AAXS;AA4VT,qBAAqB,KAAK,GAAG;AAC3B,MAAI,IAAI,EAAE;AACV,MAAI,IAAI,EAAE;AACV,MAAI,IAAI,EAAE;AACV,MAAI,IAAI,EAAE;AACV,MAAI,MAAM,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI;AAEtC,MAAI,MAAM,GAAG;AACX,UAAM,IAAI,KAAK,KAAK,GAAG;AAAA,EACxB;AAED,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,MAAI,KAAK,IAAI;AACb,SAAO;AACT;AAhBS;AA6QO,YAAY;AAC1B,MAAI,MAAM;AACV,SAAO,SAAU,GAAG,QAAQ,QAAQ,OAAO,IAAI,KAAK;AAClD,QAAI,GAAG;AAEP,QAAI,CAAC,QAAQ;AACX,eAAS;AAAA,IACV;AAED,QAAI,CAAC,QAAQ;AACX,eAAS;AAAA,IACV;AAED,QAAI,OAAO;AACT,UAAI,KAAK,IAAI,QAAQ,SAAS,QAAQ,EAAE,MAAM;AAAA,IACpD,OAAW;AACL,UAAI,EAAE;AAAA,IACP;AAED,SAAK,IAAI,QAAQ,IAAI,GAAG,KAAK,QAAQ;AACnC,UAAI,KAAK,EAAE;AACX,UAAI,KAAK,EAAE,IAAI;AACf,UAAI,KAAK,EAAE,IAAI;AACf,UAAI,KAAK,EAAE,IAAI;AACf,SAAG,KAAK,KAAK,GAAG;AAChB,QAAE,KAAK,IAAI;AACX,QAAE,IAAI,KAAK,IAAI;AACf,QAAE,IAAI,KAAK,IAAI;AACf,QAAE,IAAI,KAAK,IAAI;AAAA,IAChB;AAED,WAAO;AAAA,EACX;AACA,GAAI;AA0DJ,oBAAoB;AAClB,MAAI,MAAM,IAAI,WAAW,CAAC;AAE1B,MAAI,cAAc,cAAc;AAC9B,QAAI,KAAK;AACT,QAAI,KAAK;AACT,QAAI,KAAK;AAAA,EACV;AAED,MAAI,KAAK;AACT,SAAO;AACT;AAXS;AAoCT,sBAAsB,KAAK,MAAM,KAAK;AACpC,QAAM,MAAM;AACZ,MAAI,IAAI,KAAK,IAAI,GAAG;AACpB,MAAI,KAAK,IAAI,KAAK;AAClB,MAAI,KAAK,IAAI,KAAK;AAClB,MAAI,KAAK,IAAI,KAAK;AAClB,MAAI,KAAK,KAAK,IAAI,GAAG;AACrB,SAAO;AACT;AARS;AAyOT,eAAe,KAAK,GAAG,GAAG,GAAG;AAG3B,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE,IACP,KAAK,EAAE;AACX,MAAI,OAAO,OAAO,OAAO,QAAQ;AAEjC,UAAQ,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK,KAAK;AAE3C,MAAI,QAAQ,GAAK;AACf,YAAQ,CAAC;AACT,SAAK,CAAC;AACN,SAAK,CAAC;AACN,SAAK,CAAC;AACN,SAAK,CAAC;AAAA,EACP;AAGD,MAAI,IAAM,QAAQ,SAAS;AAEzB,YAAQ,KAAK,KAAK,KAAK;AACvB,YAAQ,KAAK,IAAI,KAAK;AACtB,aAAS,KAAK,IAAK,KAAM,KAAK,KAAK,IAAI;AACvC,aAAS,KAAK,IAAI,IAAI,KAAK,IAAI;AAAA,EACnC,OAAS;AAGL,aAAS,IAAM;AACf,aAAS;AAAA,EACV;AAGD,MAAI,KAAK,SAAS,KAAK,SAAS;AAChC,MAAI,KAAK,SAAS,KAAK,SAAS;AAChC,MAAI,KAAK,SAAS,KAAK,SAAS;AAChC,MAAI,KAAK,SAAS,KAAK,SAAS;AAChC,SAAO;AACT;AA3CS;AAmHT,kBAAkB,KAAK,GAAG;AAGxB,MAAI,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE;AAC7B,MAAI;AAEJ,MAAI,SAAS,GAAK;AAEhB,YAAQ,KAAK,KAAK,SAAS,CAAG;AAE9B,QAAI,KAAK,MAAM;AACf,YAAQ,MAAM;AAEd,QAAI,KAAM,GAAE,KAAK,EAAE,MAAM;AACzB,QAAI,KAAM,GAAE,KAAK,EAAE,MAAM;AACzB,QAAI,KAAM,GAAE,KAAK,EAAE,MAAM;AAAA,EAC7B,OAAS;AAEL,QAAI,IAAI;AACR,QAAI,EAAE,KAAK,EAAE;AAAI,UAAI;AACrB,QAAI,EAAE,KAAK,EAAE,IAAI,IAAI;AAAI,UAAI;AAC7B,QAAI,IAAK,KAAI,KAAK;AAClB,QAAI,IAAK,KAAI,KAAK;AAClB,YAAQ,KAAK,KAAK,EAAE,IAAI,IAAI,KAAK,EAAE,IAAI,IAAI,KAAK,EAAE,IAAI,IAAI,KAAK,CAAG;AAClE,QAAI,KAAK,MAAM;AACf,YAAQ,MAAM;AACd,QAAI,KAAM,GAAE,IAAI,IAAI,KAAK,EAAE,IAAI,IAAI,MAAM;AACzC,QAAI,KAAM,GAAE,IAAI,IAAI,KAAK,EAAE,IAAI,IAAI,MAAM;AACzC,QAAI,KAAM,GAAE,IAAI,IAAI,KAAK,EAAE,IAAI,IAAI,MAAM;AAAA,EAC1C;AAED,SAAO;AACT;AAhCS;AA2MT,IAAI,cAAc;AA+BD,YAAY;AAC3B,MAAI,UAAU;AACd,MAAI,YAAY,aAAa,GAAG,GAAG,CAAC;AACpC,MAAI,YAAY,aAAa,GAAG,GAAG,CAAC;AACpC,SAAO,SAAU,KAAK,GAAG,GAAG;AAC1B,QAAI,MAAM,MAAM,GAAG,CAAC;AAEpB,QAAI,MAAM,WAAW;AACnB,cAAQ,SAAS,WAAW,CAAC;AAC7B,UAAI,MAAM,OAAO,IAAI;AAAU,gBAAQ,SAAS,WAAW,CAAC;AAC5D,kBAAY,SAAS,OAAO;AAC5B,mBAAa,KAAK,SAAS,KAAK,EAAE;AAClC,aAAO;AAAA,IACb,WAAe,MAAM,UAAU;AACzB,UAAI,KAAK;AACT,UAAI,KAAK;AACT,UAAI,KAAK;AACT,UAAI,KAAK;AACT,aAAO;AAAA,IACb,OAAW;AACL,cAAQ,SAAS,GAAG,CAAC;AACrB,UAAI,KAAK,QAAQ;AACjB,UAAI,KAAK,QAAQ;AACjB,UAAI,KAAK,QAAQ;AACjB,UAAI,KAAK,IAAI;AACb,aAAO,YAAY,KAAK,GAAG;AAAA,IAC5B;AAAA,EACL;AACA,GAAI;AAaS,YAAY;AACvB,MAAI,QAAQ;AACZ,MAAI,QAAQ;AACZ,SAAO,SAAU,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG;AACnC,UAAM,OAAO,GAAG,GAAG,CAAC;AACpB,UAAM,OAAO,GAAG,GAAG,CAAC;AACpB,UAAM,KAAK,OAAO,OAAO,IAAI,IAAK,KAAI,EAAE;AACxC,WAAO;AAAA,EACX;AACA,GAAI;AAYU,YAAY;AACxB,MAAI,OAAO;AACX,SAAO,SAAU,KAAK,MAAM,OAAO,IAAI;AACrC,SAAK,KAAK,MAAM;AAChB,SAAK,KAAK,MAAM;AAChB,SAAK,KAAK,MAAM;AAChB,SAAK,KAAK,GAAG;AACb,SAAK,KAAK,GAAG;AACb,SAAK,KAAK,GAAG;AACb,SAAK,KAAK,CAAC,KAAK;AAChB,SAAK,KAAK,CAAC,KAAK;AAChB,SAAK,KAAK,CAAC,KAAK;AAChB,WAAO,YAAY,KAAK,SAAS,KAAK,IAAI,CAAC;AAAA,EAC/C;AACA,GAAI;AAo6BJ,kBAAkB;AAChB,MAAI,MAAM,IAAI,WAAW,CAAC;AAE1B,MAAI,cAAc,cAAc;AAC9B,QAAI,KAAK;AACT,QAAI,KAAK;AAAA,EACV;AAED,SAAO;AACT;AATS;AAskBK,YAAY;AACxB,MAAI,MAAM;AACV,SAAO,SAAU,GAAG,QAAQ,QAAQ,OAAO,IAAI,KAAK;AAClD,QAAI,GAAG;AAEP,QAAI,CAAC,QAAQ;AACX,eAAS;AAAA,IACV;AAED,QAAI,CAAC,QAAQ;AACX,eAAS;AAAA,IACV;AAED,QAAI,OAAO;AACT,UAAI,KAAK,IAAI,QAAQ,SAAS,QAAQ,EAAE,MAAM;AAAA,IACpD,OAAW;AACL,UAAI,EAAE;AAAA,IACP;AAED,SAAK,IAAI,QAAQ,IAAI,GAAG,KAAK,QAAQ;AACnC,UAAI,KAAK,EAAE;AACX,UAAI,KAAK,EAAE,IAAI;AACf,SAAG,KAAK,KAAK,GAAG;AAChB,QAAE,KAAK,IAAI;AACX,QAAE,IAAI,KAAK,IAAI;AAAA,IAChB;AAED,WAAO;AAAA,EACX;AACA,GAAC;ACj+OM,MAAM,iBACb;AAAA,EAEG;AAAA,EAGA;AAAA,EAEA;AAAA,EAOA,OAAO,eAAe,IAAI,iBAAiB,IAAI;AAAA,EAO/C,WAAW,cAAc;AAAE,WAAO,KAAK;AAAA,EAAe;AAAA,EAOtD,YAAY,eAAe,aAAa,OACxC;AACG,SAAK,iBAAiB;AACtB,SAAK,cAAc;AAGnB,QAAI,kBAAkB,QAAQ,OAAO,kBAAkB,UACvD;AACG,oBAAc,UAAU;AAAA,IAC1B;AAAA,EACH;AAAA,EAOD,IAAI,WACJ;AACG,QAAI,CAAE,MAAK,4BAA4B,UACvC;AACG,WAAK,mBAAmB,KAAK,cAAc,IAAI,QAAQ,CAAC,YAAY,KAAK,eAAe,UAAU,OAAO,IACxG,QAAQ,QAAO;AAAA,IAClB;AAED,WAAO,KAAK;AAAA,EACd;AAAA,EAUD,IAAI,WAAW;AAAE,WAAO,KAAK,eAAe;AAAA,EAAS;AAAA,EAOrD,IAAI,aAAa;AAAE,WAAO,KAAK,eAAe;AAAA,EAAW;AAAA,EAKzD,SACA;AACG,UAAM,gBAAgB,KAAK;AAE3B,QAAI,kBAAkB,QAAQ,kBAAkB,QAAQ;AAAE;AAAA,IAAS;AAInE,kBAAc,YAAY;AAAA,EAC5B;AACJ;AAvFa;ACAN,MAAM,iBACb;AAAA,EAIG,OAAO,aAAa,CAAA;AAAA,EAKpB,OAAO,UAAU,CAAA;AAAA,EAKjB,OAAO;AAAA,EAOP,OAAO,IAAI,MACX;AACG,UAAM,OAAM,YAAY;AAKxB,SAAK,QAAQ,OAAO,kBAAiB,UAAU;AAE/C,qBAAiB,QAAQ,KAAK,IAAI;AAAA,EACpC;AAAA,EAKD,OAAO,UACP;AACG,UAAM,UAAU,iBAAiB,UAAU,YAAY,IAAG;AAG1D,QAAI,iBAAiB,WAAW,WAAW,KAAK,iBAAiB,QAAQ,WAAW,GACpF;AACG,iBAAW,sBAAsB,iBAAiB,OAAO;AACzD;AAAA,IACF;AAED,QAAI,iBAAiB,QAAQ,QAC7B;AAEG,eAAS,OAAO,iBAAiB,QAAQ,QAAQ,EAAE,QAAQ,KAC3D;AACG,cAAM,OAAO,iBAAiB,QAAQ;AAGtC,YAAI,KAAK,WACT;AACG,2BAAiB,QAAQ,OAAO,MAAM,CAAC;AACvC,eAAK,QAAQ,IAAI;AAAA,QACnB;AAGD,YAAI,KAAK,QACT;AAEG,2BAAiB,QAAQ,OAAO,MAAM,CAAC;AACvC,2BAAiB,WAAW,KAAK,IAAI;AAAA,QACvC;AAAA,MACH;AAAA,IACH;AAGD,aAAS,OAAO,iBAAiB,WAAW,QAAQ,EAAE,QAAQ,KAC9D;AACG,YAAM,OAAO,iBAAiB,WAAW;AAIzC,UAAI,KAAK,aAAc,KAAK,OAAO,UAAU,CAAC,KAAK,GAAG,aACtD;AACG,yBAAiB,WAAW,OAAO,MAAM,CAAC;AAC1C,aAAK,QAAQ,IAAI;AACjB;AAAA,MACF;AAED,WAAK,UAAU,UAAU,KAAK;AAG9B,UAAI,KAAK,WAAW,KAAK,UACzB;AAEG,iBAAS,WAAW,KAAK,KAAK,QAAQ,EAAE,YAAY,KACpD;AACG,gBAAM,MAAM,KAAK,KAAK;AACtB,eAAK,QAAQ,OAAO,KAAK,YAAY;AAAA,QACvC;AAED,aAAK,SAAS,IAAI,KAAK,OAAO;AAE9B,yBAAiB,WAAW,OAAO,MAAM,CAAC;AAC1C,aAAK,QAAQ,IAAI;AAEjB;AAAA,MACF;AAGD,YAAM,YAAY,KAAK,KAAK,KAAK,UAAU,KAAK,QAAQ;AAExD,eAAS,WAAW,KAAK,KAAK,QAAQ,EAAE,YAAY,KACpD;AACG,cAAM,MAAM,KAAK,KAAK;AACtB,aAAK,QAAQ,OAAO,KAAK,YAAY,KAAK,QAAQ,MAAM,KAAK,YAAY,MAAM,SAAS;AAAA,MAC1F;AAED,WAAK,SAAS,IAAI,KAAK,OAAO;AAAA,IAChC;AAED,eAAW,sBAAsB,iBAAiB,OAAO;AAAA,EAC3D;AAAA,EAOD,OAAO,OAAO,UACd;AACG,aAAS,OAAO,iBAAiB,WAAW,QAAQ,EAAE,QAAQ,KAC9D;AACG,YAAM,OAAO,iBAAiB,WAAW;AACzC,UAAI,KAAK,aAAa,UACtB;AACG,yBAAiB,WAAW,OAAO,MAAM,CAAC;AAC1C,aAAK,YAAY;AACjB,aAAK,QAAQ,IAAI;AAAA,MACnB;AAAA,IACH;AAED,aAAS,OAAO,iBAAiB,QAAQ,QAAQ,EAAE,QAAQ,KAC3D;AACG,YAAM,OAAO,iBAAiB,QAAQ;AACtC,UAAI,KAAK,aAAa,UACtB;AACG,yBAAiB,QAAQ,OAAO,MAAM,CAAC;AACvC,aAAK,YAAY;AACjB,aAAK,QAAQ,IAAI;AAAA,MACnB;AAAA,IACH;AAAA,EACH;AAAA,EAKD,OAAO,YACP;AACG,aAAS,OAAO,iBAAiB,WAAW,QAAQ,EAAE,QAAQ,KAC9D;AACG,YAAM,OAAO,iBAAiB,WAAW;AACzC,WAAK,YAAY;AACjB,WAAK,QAAQ,IAAI;AAAA,IACnB;AAED,aAAS,OAAO,iBAAiB,QAAQ,QAAQ,EAAE,QAAQ,KAC3D;AACG,YAAM,OAAO,iBAAiB,QAAQ;AACtC,WAAK,YAAY;AACjB,WAAK,QAAQ,IAAI;AAAA,IACnB;AAED,qBAAiB,WAAW,SAAS;AACrC,qBAAiB,QAAQ,SAAS;AAAA,EACpC;AAAA,EASD,OAAO,aAAa,UACpB;AACG,UAAM,UAAU,CAAA;AAEhB,aAAS,OAAO,iBAAiB,WAAW,QAAQ,EAAE,QAAQ,KAC9D;AACG,YAAM,OAAO,iBAAiB,WAAW;AACzC,UAAI,KAAK,aAAa,UACtB;AACG,gBAAQ,KAAK,KAAK,OAAO;AAAA,MAC3B;AAAA,IACH;AAED,aAAS,OAAO,iBAAiB,QAAQ,QAAQ,EAAE,QAAQ,KAC3D;AACG,YAAM,OAAO,iBAAiB,QAAQ;AACtC,UAAI,KAAK,aAAa,UACtB;AACG,gBAAQ,KAAK,KAAK,OAAO;AAAA,MAC3B;AAAA,IACH;AAED,WAAO;AAAA,EACT;AACJ;AA7Ma;AAgNb,iBAAiB,QAAS;AC9M1B,MAAM,cAAc,oBAAI,IAAI;AAAA,EAEzB;AAAA,EAAQ;AAAA,EAAO;AAAA,EAAY;AAAA,EAAa;AAAA,EAAY;AAAA,EAAa;AAAA,EAAS;AAAA,EAC1E;AAAA,EAAW;AAAA,EAAW;AAAA,EAAW;AAAA,EAAS;AAAA,EAAc;AAAA,EAAc;AAAA,EAAc;AAAA,EAGpF;AACH,CAAC;AAOD,MAAM,gBAAgB,CAAC,WAAW,WAAW,WAAW,SAAS,cAAc,cAAc,YAAY;AAEzG,OAAO,OAAO,aAAa;AAO3B,MAAM,gBAAgB;AAQtB,MAAM,kBAAkB;AAAA,EAErB,QAAQ;AAAA,EACR,MAAM;AAAA,EACN,WAAW;AAAA,EACX,UAAU;AAAA,EACV,WAAW;AAAA,EACX,UAAU;AAAA,EACV,KAAK;AAAA,EACL,iBAAiB;AAAA,EACjB,OAAO;AAAA,EACP,QAAQ;AAAA,EAER,SAAS;AAAA,EACT,SAAS;AAAA,EACT,SAAS;AAAA,EACT,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,YAAY;AAAA,EAEZ,UAAU;AACb;AAEA,OAAO,OAAO,eAAe;AAO7B,4BAA4B,MAC5B;AAEG,MAAI,KAAK,YAAY,MAAM;AAAE,SAAK,UAAU;AAAA,EAAI;AAChD,MAAI,KAAK,YAAY,MAAM;AAAE,SAAK,UAAU;AAAA,EAAI;AAChD,MAAI,KAAK,YAAY,MAAM;AAAE,SAAK,UAAU;AAAA,EAAI;AAChD,MAAI,KAAK,eAAe,MAAM;AAAE,SAAK,aAAa;AAAA,EAAI;AACtD,MAAI,KAAK,eAAe,MAAM;AAAE,SAAK,aAAa;AAAA,EAAI;AACtD,MAAI,KAAK,eAAe,MAAM;AAAE,SAAK,aAAa;AAAA,EAAI;AACtD,MAAI,KAAK,UAAU,MAAM;AAAE,SAAK,QAAQ;AAAA,EAAI;AAG5C,MAAI,KAAK,aAAa,MAAM;AAAE,SAAK,WAAW;AAAA,EAAI;AACrD;AAbS;AAoBT,MAAM,uBAAuB;AAAA,EAC1B,SAAS;AAAA,EACT,SAAS;AAAA,EACT,SAAS;AAAA,EACT,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,YAAY;AACf;AAEA,OAAO,OAAO,oBAAoB;AAOlC,MAAM,yBAAyB;AAO/B,MAAM,mBAAmB;AAAA,EAAC;AAAA,EAAY;AAAA,EAAc;AAAA,EAAa;AAAA,EAAe;AAAA,EAAU;AAAA,EAAgB;AAAA,EACzG;AAAA,EAAiB;AAAc;AAEhC,OAAO,OAAO,gBAAgB;ACzGvB,yBAAyB,cAAc,UAC9C;AACG,aAAW,OAAO,cAClB;AAEG,QAAIC,YAAsB,IAAI,GAAG,GACjC;AACG,YAAM,QAAQ,aAAa;AAE3B,UAAI,OAAO,UAAU,UAAU;AAAE;AAAA,MAAW;AAG5C,UAAI,UAAU,UAAU,UAAU,WAAW;AAAE;AAAA,MAAW;AAE1D,YAAM,eAAeC,cAAwB,KAAK,KAAK;AAEvD,UAAI,CAAC,cACL;AACG,cAAM,IAAI,MACT,kDAAkD,oBAAoB,QAAQ;AAAA,MACjF;AAED,YAAM,UAAU,SAAS;AAEzB,cAAQ,aAAa;AAAA,aAEb;AACF,uBAAa,OAAO,UAAU,WAAW,aAAa,EAAE;AACxD;AAAA,aAEE;AACF,uBAAa,OAAO,UAAU,WAAW,aAAa,EAAE;AACxD;AAAA,aAEE;AACF,uBAAa,OAAO,UAAU,WAAW,aAAa,EAAE;AACxD;AAAA;AAAA,IAER;AAAA,EACH;AACJ;AAxCgB;ACOT,MAAM,aACb;AAAA,EAEG;AAAA,EAGA;AAAA,EAOA,iBAAiB;AAAA,EAQjB;AAAA,EAEA,YAAY,UAAU,MACtB;AACG,SAAK,YAAY;AACjB,SAAK,QAAQ;AAEb,SAAK,WAAW,KAAK,iBAAiB,KAAK,IAAI;AAAA,EACjD;AAAA,EAOD,IAAI,cACJ;AACG,WAAO,KAAK,iBAAiB;AAAA,EAC/B;AAAA,EAqBD,cAAc,SAAS,aAAa,UAAU,IAAI,OAAO,MAAM,aAC/D;AAEG,uBAAmB,OAAO;AAC1B,uBAAmB,WAAW;AAG9B,eAAW,OAAO,SAClB;AACG,UAAI,CAAC,OAAO,SAAS,QAAQ,IAAI,GAAG;AAAE,eAAO,QAAQ;AAAA,MAAO;AAAA,IAC9D;AAED,UAAM,OAAO,OAAO,KAAK,OAAO;AAChC,UAAM,UAAU,OAAO,OAAO,EAAE,wBAAwB,KAAI,GAAI,OAAO;AAGvE,QAAI,KAAK,WAAW,GAAG;AAAE,aAAO,iBAAiB;AAAA,IAAc;AAE/D,UAAM,gBAAgB;AAAA,MACnB,QAAQ;AAAA,MACR,SAAS,KAAK;AAAA,MACd,WAAW;AAAA,MACX,SAAS;AAAA,MACT,SAAS;AAAA,MACT;AAAA,MACA,UAAU,WAAW;AAAA,MACrB;AAAA,MACA;AAAA,MACA,UAAU;AAAA,MACV;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,UAAU,KAAK;AAAA,MACf,SAAS;AAAA,MACT,OAAO;AAAA,IAChB;AAEM,QAAI,QAAQ,GACZ;AACG,oBAAc,SAAS;AAGvB,iBAAW,MACX;AACG,YAAI,CAAC,cAAc,WACnB;AACG,wBAAc,SAAS;AAEvB,gBAAM,OAAM,YAAY;AAIxB,wBAAc,QAAQ,OAAO,kBAAiB,UAAU;AAAA,QAC1D;AAAA,MACb,GAAY,QAAQ,GAAI;AAAA,IACjB;AAGD,SAAK;AACL,qBAAiB,IAAI,aAAa;AAGlC,WAAO,IAAI,iBAAiB,eAAe,IAAI;AAAA,EACjD;AAAA,EAKD,SACA;AACG,qBAAiB,OAAO,KAAK,SAAS;AAAA,EACxC;AAAA,EAOD,iBAAiB,MACjB;AACG,SAAK;AAEL,SAAK,SAAS;AACd,SAAK,WAAW;AAEhB,QAAI,OAAO,KAAK,YAAY,YAAY;AAAE,WAAK,QAAQ,KAAK,SAAS;AAAA,IAAI;AAAA,EAC3E;AAAA,EAOD,eACA;AACG,WAAO,iBAAiB,aAAa,KAAK,SAAS;AAAA,EACrD;AAAA,EAmBD,KAAK,UAAU,EAAE,QAAQ,GAAG,WAAW,GAAG,OAAO,UAAU,cAAcC,WAAS,CAAE,GACpF;AACG,QAAI,CAAC,SAAS,QAAQ,GACtB;AACG,YAAM,IAAI,UAAU,uDAAuD;AAAA,IAC7E;AAED,UAAM,WAAW,KAAK;AACtB,UAAM,SAAS,SAAS;AAGxB,QAAI,WAAW,UAAU,OAAO,QAAQ,SAAS,iBAAiB,aAAa,CAAC,QAAQ,SAAS,cACjG;AACG,aAAO,iBAAiB;AAAA,IAC1B;AAGD,UAAM,WAAW,kBAAkB,cAAc,SAAS,QAAQ;AAClE,UAAM,KAAK,oBAAoB,eAAe,SAAS,cAAc,WAAW;AAEhF,QAAI,CAAC,OAAO,SAAS,KAAK,KAAK,QAAQ,GACvC;AACG,YAAM,IAAI,UAAU,4DAA4D;AAAA,IAClF;AAED,QAAI,CAAC,OAAO,SAAS,QAAQ,KAAK,WAAW,GAC7C;AACG,YAAM,IAAI,UAAU,+DAA+D;AAAA,IACrF;AAED,QAAI,OAAO,SAAS,YACpB;AACG,YAAM,IAAI,UAAU,oDAAoD;AAAA,IAC1E;AAED,QAAI,OAAO,gBAAgB,YAC3B;AACG,YAAM,IAAI,UAAU,2DAA2D;AAAA,IACjF;AAED,UAAM,UAAU,CAAA;AAChB,UAAM,cAAc,CAAA;AAEpB,UAAM,OAAO,KAAK;AAGlB,eAAW,OAAO,UAClB;AACG,UAAI,KAAK,SAAS,UAAU,SAAS,SAAS,KAAK,MACnD;AACG,gBAAQ,OAAO,SAAS;AACxB,oBAAY,OAAO,KAAK;AAAA,MAC1B;AAAA,IACH;AAED,oBAAgB,SAAS,IAAI;AAE7B,WAAO,KAAK,cAAc,SAAS,aAAa,UAAU,IAAI,OAAO,MAAM,WAAW;AAAA,EACxF;AAAA,EAqBD,OAAO,UAAU,QAAQ,EAAE,QAAQ,GAAG,WAAW,GAAG,OAAO,UAAU,cAAcA,WAAS,CAAE,GAC9F;AACG,QAAI,CAAC,SAAS,QAAQ,GACtB;AACG,YAAM,IAAI,UAAU,yDAAyD;AAAA,IAC/E;AAED,QAAI,CAAC,SAAS,MAAM,GACpB;AACG,YAAM,IAAI,UAAU,uDAAuD;AAAA,IAC7E;AAED,UAAM,SAAS,KAAK,UAAU;AAG9B,QAAI,WAAW,UAAU,OAAO,QAAQ,SAAS,iBAAiB,aAAa,CAAC,QAAQ,SAAS,cACjG;AACG,aAAO,iBAAiB;AAAA,IAC1B;AAGD,UAAM,WAAW,kBAAkB,cAAc,SAAS,QAAQ;AAClE,UAAM,KAAK,oBAAoB,eAAe,SAAS,cAAc,WAAW;AAEhF,QAAI,CAAC,OAAO,SAAS,KAAK,KAAK,QAAQ,GACvC;AACG,YAAM,IAAI,UAAU,8DAA8D;AAAA,IACpF;AAED,QAAI,CAAC,OAAO,SAAS,QAAQ,KAAK,WAAW,GAC7C;AACG,YAAM,IAAI,UAAU,iEAAiE;AAAA,IACvF;AAED,QAAI,OAAO,SAAS,YACpB;AACG,YAAM,IAAI,UAAU,sDAAsD;AAAA,IAC5E;AAED,QAAI,OAAO,gBAAgB,YAC3B;AACG,YAAM,IAAI,UAAU,6DAA6D;AAAA,IACnF;AAED,UAAM,UAAU,CAAA;AAChB,UAAM,cAAc,CAAA;AAEpB,UAAM,OAAO,KAAK;AAGlB,eAAW,OAAO,UAClB;AACG,UAAI,OAAO,SAAS,QACpB;AACG,gBAAQ,KACP,sCAAsC,+DAA+D;AACtG;AAAA,MACF;AAED,UAAI,KAAK,SAAS,QAClB;AACG,gBAAQ,OAAO,SAAS;AACxB,oBAAY,OAAO,OAAO;AAAA,MAC5B;AAAA,IACH;AAED,oBAAgB,SAAS,IAAI;AAC7B,oBAAgB,aAAa,IAAI;AAEjC,WAAO,KAAK,cAAc,SAAS,aAAa,UAAU,IAAI,OAAO,MAAM,WAAW;AAAA,EACxF;AAAA,EAmBD,GAAG,QAAQ,EAAE,QAAQ,GAAG,WAAW,GAAG,OAAO,UAAU,cAAcA,WAAS,CAAE,GAChF;AACG,QAAI,CAAC,SAAS,MAAM,GACpB;AACG,YAAM,IAAI,UAAU,mDAAmD;AAAA,IACzE;AAED,UAAM,SAAS,KAAK,UAAU;AAG9B,QAAI,WAAW,UAAU,OAAO,QAAQ,SAAS,iBAAiB,aAAa,CAAC,QAAQ,SAAS,cACjG;AACG,aAAO,iBAAiB;AAAA,IAC1B;AAGD,UAAM,WAAW,kBAAkB,cAAc,SAAS,QAAQ;AAClE,UAAM,KAAK,oBAAoB,eAAe,SAAS,cAAc,WAAW;AAEhF,QAAI,CAAC,OAAO,SAAS,KAAK,KAAK,QAAQ,GACvC;AACG,YAAM,IAAI,UAAU,0DAA0D;AAAA,IAChF;AAED,QAAI,CAAC,OAAO,SAAS,QAAQ,KAAK,WAAW,GAC7C;AACG,YAAM,IAAI,UAAU,6DAA6D;AAAA,IACnF;AAED,QAAI,OAAO,SAAS,YACpB;AACG,YAAM,IAAI,UAAU,kDAAkD;AAAA,IACxE;AAED,QAAI,OAAO,gBAAgB,YAC3B;AACG,YAAM,IAAI,UAAU,yDAAyD;AAAA,IAC/E;AAED,UAAM,UAAU,CAAA;AAChB,UAAM,cAAc,CAAA;AAEpB,UAAM,OAAO,KAAK;AAGlB,eAAW,OAAO,QAClB;AACG,UAAI,KAAK,SAAS,UAAU,OAAO,SAAS,KAAK,MACjD;AACG,oBAAY,OAAO,OAAO;AAC1B,gBAAQ,OAAO,KAAK;AAAA,MACtB;AAAA,IACH;AAED,oBAAgB,aAAa,IAAI;AAEjC,WAAO,KAAK,cAAc,SAAS,aAAa,UAAU,IAAI,OAAO,MAAM,WAAW;AAAA,EACxF;AAAA,EAiBD,QAAQ,MAAM,EAAE,WAAW,GAAG,OAAO,UAAU,cAAcA,WAAS,CAAE,GACxE;AACG,QAAI,CAAC,WAAW,IAAI,GACpB;AACG,YAAM,IAAI,UAAU,6DAA6D;AAAA,IACnF;AAED,UAAM,SAAS,KAAK,UAAU;AAG9B,QAAI,WAAW,UAAU,OAAO,QAAQ,SAAS,iBAAiB,aAAa,CAAC,QAAQ,SAAS,cACjG;AACG,YAAM,IAAI,MAAM,2DAA2D;AAAA,IAC7E;AAED,QAAI,CAAC,OAAO,SAAS,QAAQ,KAAK,WAAW,GAC7C;AACG,YAAM,IAAI,UAAU,kEAAkE;AAAA,IACxF;AAED,QAAI,OAAO,SAAS,YACpB;AACG,YAAM,IAAI,UAAU,uDAAuD;AAAA,IAC7E;AAED,QAAI,OAAO,gBAAgB,YAC3B;AACG,YAAM,IAAI,UAAU,8DAA8D;AAAA,IACpF;AAED,UAAM,UAAU,CAAA;AAChB,UAAM,cAAc,CAAA;AAEpB,UAAM,OAAO,KAAK;AAGlB,eAAW,OAAO,MAClB;AACG,UAAI,OAAO,QAAQ,UACnB;AACG,cAAM,IAAI,UAAU,kDAAkD;AAAA,MACxE;AAED,UAAI,CAAC,YAAY,IAAI,GAAG,GACxB;AACG,cAAM,IAAI,MAAM,qCAAqC,0BAA0B;AAAA,MACjF;AAED,UAAI,KAAK,SAAS,QAClB;AACG,oBAAY,OAAO,KAAK;AACxB,gBAAQ,OAAO,KAAK;AAAA,MACtB;AAAA,IACH;AAED,UAAM,YAAY,CAAC,GAAG,IAAI;AAE1B,WAAO,OAAO,SAAS;AAEvB,UAAM,UAAU,OAAO,OAAO,EAAE,wBAAwB,KAAI,GAAI,OAAO;AAEvE,UAAM,gBAAgB;AAAA,MACnB,QAAQ;AAAA,MACR,SAAS,KAAK;AAAA,MACd,WAAW;AAAA,MACX,SAAS;AAAA,MACT,SAAS;AAAA,MACT;AAAA,MACA,UAAU,WAAW;AAAA,MACrB;AAAA,MACA,IAAI;AAAA,MACJ,UAAU;AAAA,MACV;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,UAAU,KAAK;AAAA,MACf,SAAS;AAAA,MACT,OAAO;AAAA,IAChB;AAEM,UAAM,YAAY,2BAAI,SACtB;AACG,YAAM,aAAa,KAAK;AAExB,UAAI,eAAe,GAAG;AAAE;AAAA,MAAS;AAEjC,eAAS,OAAO,UAAU,QAAQ,EAAE,QAAQ,KAC5C;AACG,cAAM,MAAM,UAAU;AACtB,YAAI,KAAK,SAAS,QAAQ;AAAE,kBAAQ,OAAO,KAAK;AAAA,QAAO;AAAA,MACzD;AAGD,UAAI,SAAS,KAAK,EAAE,GACpB;AACG,cAAM,UAAU,KAAK;AAErB,mBAAW,OAAO,SAClB;AACG,cAAI,YAAY,SAAS,QAAQ;AAAE,wBAAY,OAAO,QAAQ;AAAA,UAAO;AAAA,QACvE;AAAA,MACH,OAED;AACG,iBAAS,OAAO,GAAG,OAAO,cAAc,OAAO,UAAU,QAAQ,QACjE;AACG,gBAAM,MAAM,UAAU;AACtB,cAAI,YAAY,SAAS,QAAQ;AAAE,wBAAY,OAAO,KAAK;AAAA,UAAQ;AAAA,QACrE;AAAA,MACH;AAED,sBAAgB,aAAa,IAAI;AAGjC,yBAAmB,OAAO;AAC1B,yBAAmB,WAAW;AAG9B,YAAM,WAAW,kBAAkB,cAAc,SAAS,QAAQ;AAClE,oBAAc,KAAK,oBAAoB,eAAe,SAAS,cAAc,WAAW;AAGxF,UAAI,cAAc,UAClB;AACG,sBAAc,WAAW;AACzB,sBAAc,SAAS;AACvB,sBAAc,UAAU;AAExB,aAAK;AACL,yBAAiB,IAAI,aAAa;AAAA,MACpC,OAED;AACG,cAAM,OAAM,YAAY;AAIxB,sBAAc,QAAQ,OAAO,kBAAiB,UAAU;AACxD,sBAAc,UAAU;AAAA,MAC1B;AAAA,IACV,GA5DwB;AA8DlB,cAAU,OAAO;AAejB,cAAU,UAAU,CAAC,EAAE,qBAAU,aAAM,8BAAgB,CAAE,MACzD;AACG,UAAI,cAAa,UAAW,EAAC,OAAO,SAAS,SAAQ,KAAK,YAAW,IACrE;AACG,cAAM,IAAI,UAAU,0EAA0E;AAAA,MAChG;AAED,UAAI,UAAS,UAAU,OAAO,UAAS,YACvC;AACG,cAAM,IAAI,UAAU,+DAA+D;AAAA,MACrF;AAED,UAAI,iBAAgB,UAAU,OAAO,iBAAgB,YACrD;AACG,cAAM,IAAI,UAAU,sEAAsE;AAAA,MAC5F;AAED,UAAI,aAAY,GAAG;AAAE,sBAAc,WAAW,YAAW;AAAA,MAAO;AAChE,UAAI,OAAM;AAAE,sBAAc,OAAO;AAAA,MAAO;AACxC,UAAI,cAAa;AAAE,sBAAc,cAAc;AAAA,MAAc;AAE7D,aAAO;AAAA,IAChB;AAEM,WAAO;AAAA,EACT;AACJ;AA1lBa;ACbN,MAAM,sBACb;AAAA,EAEG;AAAA,EAGA;AAAA,EAOA,OAAO,eAAe,IAAI,sBAAsB,IAAI;AAAA,EAOpD,WAAW,cAAc;AAAE,WAAO,KAAK;AAAA,EAAe;AAAA,EAKtD,YAAY,mBACZ;AACG,SAAK,qBAAqB;AAAA,EAC5B;AAAA,EAOD,IAAI,WACJ;AACG,UAAM,oBAAoB,KAAK;AAE/B,QAAI,sBAAsB,QAAQ,sBAAsB,QAAQ;AAAE,aAAO,QAAQ,QAAO;AAAA,IAAK;AAE7F,QAAI,CAAE,MAAK,4BAA4B,UACvC;AACG,YAAM,WAAW,CAAA;AACjB,eAAS,OAAO,kBAAkB,QAAQ,EAAE,QAAQ,KACpD;AACG,iBAAS,KAAK,kBAAkB,MAAM,QAAQ;AAAA,MAChD;AAED,WAAK,mBAAmB,QAAQ,IAAI,QAAQ;AAAA,IAC9C;AAED,WAAO,KAAK;AAAA,EACd;AAAA,EAUD,IAAI,WACJ;AACG,UAAM,oBAAoB,KAAK;AAE/B,QAAI,sBAAsB,QAAQ,sBAAsB,QAAQ;AAAE,aAAO;AAAA,IAAQ;AAEjF,aAAS,OAAO,kBAAkB,QAAQ,EAAE,QAAQ,KACpD;AACG,UAAI,kBAAkB,MAAM,UAAU;AAAE,eAAO;AAAA,MAAO;AAAA,IACxD;AAED,WAAO;AAAA,EACT;AAAA,EAOD,IAAI,aACJ;AACG,UAAM,oBAAoB,KAAK;AAE/B,QAAI,sBAAsB,QAAQ,sBAAsB,QAAQ;AAAE,aAAO;AAAA,IAAO;AAEhF,aAAS,OAAO,kBAAkB,QAAQ,EAAE,QAAQ,KACpD;AACG,UAAI,CAAC,kBAAkB,MAAM,YAAY;AAAE,eAAO;AAAA,MAAQ;AAAA,IAC5D;AAED,WAAO;AAAA,EACT;AAAA,EAKD,SACA;AACG,UAAM,oBAAoB,KAAK;AAE/B,QAAI,sBAAsB,QAAQ,sBAAsB,QAAQ;AAAE;AAAA,IAAS;AAE3E,aAAS,OAAO,KAAK,mBAAmB,QAAQ,EAAE,QAAQ,KAC1D;AACG,WAAK,mBAAmB,MAAM,OAAM;AAAA,IACtC;AAAA,EACH;AACJ;AA9Ga;ACcN,MAAM,kBACb;AAAA,EAQG,OAAO,YAAY,QACnB;AACG,WAAO,WAAW,QAAQ,OAAO,WAAW,YAAY,OAAO,mBAAmB;AAAA,EACpF;AAAA,EAOD,OAAO,OAAO,UACd;AACG,QAAI,WAAW,QAAQ,GACvB;AACG,UAAI,QAAQ;AAEZ,iBAAW,SAAS,UACpB;AACG;AAEA,cAAM,iBAAiB,KAAK,YAAY,KAAK,IAAI,QAAQ,MAAM;AAE/D,YAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,kBAAQ,KAAK,0EAA0E,QAAQ;AAC/F;AAAA,QACF;AAED,yBAAiB,OAAO,cAAc;AAAA,MACxC;AAAA,IACH,OAED;AACG,YAAM,iBAAiB,KAAK,YAAY,QAAQ,IAAI,WAAW,SAAS;AAExE,UAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,gBAAQ,KAAK,+DAA+D;AAC5E;AAAA,MACF;AAED,uBAAiB,OAAO,cAAc;AAAA,IACxC;AAAA,EACH;AAAA,EAKD,OAAO,YAAY;AAAE,qBAAiB,UAAW;AAAA,EAAG;AAAA,EASpD,OAAO,aAAa,UACpB;AACG,UAAM,UAAU,CAAA;AAEhB,QAAI,WAAW,QAAQ,GACvB;AACG,UAAI,QAAQ;AAEZ,iBAAW,SAAS,UACpB;AACG;AAEA,cAAM,aAAa,KAAK,YAAY,KAAK;AACzC,cAAM,iBAAiB,aAAa,QAAQ,MAAM;AAElD,YAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,kBAAQ,KAAK,gFAAgF,QAAQ;AACrG;AAAA,QACF;AAED,cAAM,WAAW,iBAAiB,aAAa,cAAc;AAE7D,gBAAQ,KAAK,EAAE,UAAU,gBAAgB,MAAM,aAAa,SAAS,OAAO,SAAU,CAAA;AAAA,MACxF;AAAA,IACH,OAED;AACG,YAAM,aAAa,KAAK,YAAY,QAAQ;AAC5C,YAAM,iBAAiB,aAAa,WAAW,SAAS;AAExD,UAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,gBAAQ,KAAK,qEAAqE;AAClF,eAAO;AAAA,MACT;AAED,YAAM,WAAW,iBAAiB,aAAa,cAAc;AAE7D,cAAQ,KAAK,EAAE,UAAU,gBAAgB,MAAM,aAAa,SAAS,UAAU,SAAU,CAAA;AAAA,IAC3F;AAED,WAAO;AAAA,EACT;AAAA,EAaD,OAAO,KAAK,UAAU,UAAU,SAChC;AACG,QAAI,CAAC,SAAS,QAAQ,KAAK,OAAO,aAAa,YAC/C;AACG,YAAM,IAAI,UAAU,wEAAwE;AAAA,IAC9F;AAED,QAAI,YAAY,UAAU,CAAC,SAAS,OAAO,KAAK,OAAO,YAAY,YACnE;AACG,YAAM,IAAI,UAAU,uEAAuE;AAAA,IAC7F;AAKD,UAAM,oBAAoB,CAAA;AAE1B,QAAI,QAAQ;AACZ,QAAI;AAEJ,UAAM,kBAAkB,OAAO,aAAa;AAC5C,UAAM,oBAAoB,OAAO,YAAY;AAC7C,UAAM,cAAc,mBAAmB;AAEvC,QAAI,aAAa;AAAE,wBAAkB,EAAE,OAAO,UAAU,QAAQ,MAAM,OAAM;AAAA,IAAK;AAEjF,QAAI,iBAAiB;AACrB,QAAI,gBAAgB;AAEpB,QAAI,WAAW,QAAQ,GACvB;AACG,iBAAW,SAAS,UACpB;AACG;AAEA,cAAM,aAAa,KAAK,YAAY,KAAK;AACzC,cAAM,iBAAiB,aAAa,QAAQ,MAAM;AAElD,YAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,kBAAQ,KAAK,wEAAwE,QAAQ;AAC7F;AAAA,QACF;AAED,YAAI,aACJ;AACG,0BAAgB,QAAQ;AACxB,0BAAgB,WAAW;AAC3B,0BAAgB,OAAO,aAAa,SAAS;AAAA,QAC/C;AAED,YAAI,iBACJ;AACG,2BAAiB,SAAS,eAAe;AAGzC,cAAI,mBAAmB,QAAQ,mBAAmB,QAAQ;AAAE;AAAA,UAAW;AAEvE,cAAI,OAAO,mBAAmB,UAC9B;AACG,kBAAM,IAAI,UAAU,sEACnB,oCAAoC;AAAA,UACvC;AAAA,QACH;AAED,YAAI,mBACJ;AACG,0BAAgB,QAAQ,eAAe;AAGvC,cAAI,kBAAkB,QAAQ,kBAAkB,QAAQ;AAAE;AAAA,UAAW;AAErE,cAAI,OAAO,kBAAkB,UAC7B;AACG,kBAAM,IAAI,UAAU,qEACnB,oCAAoC;AAAA,UACvC;AAAA,QACH;AAED,0BAAkB,KAAK,eAAe,QAAQ,KAAK,gBAAgB,aAAa,CAAC;AAAA,MACnF;AAAA,IACH,OAED;AACG,YAAM,aAAa,KAAK,YAAY,QAAQ;AAC5C,YAAM,iBAAiB,aAAa,WAAW,SAAS;AAExD,UAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,gBAAQ,KAAK,6DAA6D;AAC1E,eAAO,sBAAsB;AAAA,MAC/B;AAED,UAAI,aACJ;AACG,wBAAgB,QAAQ;AACxB,wBAAgB,WAAW;AAC3B,wBAAgB,OAAO,aAAa,SAAS;AAAA,MAC/C;AAED,UAAI,iBACJ;AACG,yBAAiB,SAAS,eAAe;AAEzC,YAAI,OAAO,mBAAmB,UAC9B;AACG,gBAAM,IAAI,UACT,sFAAsF;AAAA,QACzF;AAAA,MACH;AAED,UAAI,mBACJ;AACG,wBAAgB,QAAQ,eAAe;AAEvC,YAAI,OAAO,kBAAkB,UAC7B;AACG,gBAAM,IAAI,UACT,qFAAqF;AAAA,QACxF;AAAA,MACH;AAED,wBAAkB,KAAK,eAAe,QAAQ,KAAK,gBAAgB,aAAa,CAAC;AAAA,IACnF;AAED,WAAO,IAAI,sBAAsB,iBAAiB;AAAA,EACpD;AAAA,EAeD,OAAO,OAAO,UAAU,UAAU,QAAQ,SAC1C;AACG,QAAI,CAAC,SAAS,QAAQ,KAAK,OAAO,aAAa,YAC/C;AACG,YAAM,IAAI,UAAU,0EAA0E;AAAA,IAChG;AAED,QAAI,CAAC,SAAS,MAAM,KAAK,OAAO,WAAW,YAC3C;AACG,YAAM,IAAI,UAAU,wEAAwE;AAAA,IAC9F;AAED,QAAI,YAAY,UAAU,CAAC,SAAS,OAAO,KAAK,OAAO,YAAY,YACnE;AACG,YAAM,IAAI,UAAU,yEAAyE;AAAA,IAC/F;AAKD,UAAM,oBAAoB,CAAA;AAE1B,QAAI,QAAQ;AACZ,QAAI;AAEJ,UAAM,kBAAkB,OAAO,aAAa;AAC5C,UAAM,gBAAgB,OAAO,WAAW;AACxC,UAAM,oBAAoB,OAAO,YAAY;AAC7C,UAAM,cAAc,mBAAmB,iBAAiB;AAExD,QAAI,aAAa;AAAE,wBAAkB,EAAE,OAAO,UAAU,QAAQ,MAAM,OAAM;AAAA,IAAK;AAEjF,QAAI,iBAAiB;AACrB,QAAI,eAAe;AACnB,QAAI,gBAAgB;AAEpB,QAAI,WAAW,QAAQ,GACvB;AACG,iBAAW,SAAS,UACpB;AACG;AAEA,cAAM,aAAa,KAAK,YAAY,KAAK;AACzC,cAAM,iBAAiB,aAAa,QAAQ,MAAM;AAElD,YAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,kBAAQ,KAAK,0EAA0E,QAAQ;AAC/F;AAAA,QACF;AAED,YAAI,aACJ;AACG,0BAAgB,QAAQ;AACxB,0BAAgB,WAAW;AAC3B,0BAAgB,OAAO,aAAa,SAAS;AAAA,QAC/C;AAED,YAAI,iBACJ;AACG,2BAAiB,SAAS,eAAe;AAGzC,cAAI,mBAAmB,QAAQ,mBAAmB,QAAQ;AAAE;AAAA,UAAW;AAEvE,cAAI,OAAO,mBAAmB,UAC9B;AACG,kBAAM,IAAI,UAAU,wEACnB,oCAAoC;AAAA,UACvC;AAAA,QACH;AAED,YAAI,eACJ;AACG,yBAAe,OAAO,eAAe;AAGrC,cAAI,iBAAiB,QAAQ,iBAAiB,QAAQ;AAAE;AAAA,UAAW;AAEnE,cAAI,OAAO,iBAAiB,UAC5B;AACG,kBAAM,IAAI,UAAU,sEACnB,oCAAoC;AAAA,UACvC;AAAA,QACH;AAED,YAAI,mBACJ;AACG,0BAAgB,QAAQ,eAAe;AAGvC,cAAI,kBAAkB,QAAQ,kBAAkB,QAAQ;AAAE;AAAA,UAAW;AAErE,cAAI,OAAO,kBAAkB,UAC7B;AACG,kBAAM,IAAI,UAAU,uEACnB,oCAAoC;AAAA,UACvC;AAAA,QACH;AAED,0BAAkB,KAAK,eAAe,QAAQ,OAAO,gBAAgB,cAAc,aAAa,CAAC;AAAA,MACnG;AAAA,IACH,OAED;AACG,YAAM,aAAa,KAAK,YAAY,QAAQ;AAC5C,YAAM,iBAAiB,aAAa,WAAW,SAAS;AAExD,UAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,gBAAQ,KAAK,+DAA+D;AAC5E,eAAO,sBAAsB;AAAA,MAC/B;AAED,UAAI,aACJ;AACG,wBAAgB,QAAQ;AACxB,wBAAgB,WAAW;AAC3B,wBAAgB,OAAO,aAAa,SAAS;AAAA,MAC/C;AAED,UAAI,iBACJ;AACG,yBAAiB,SAAS,eAAe;AAEzC,YAAI,OAAO,mBAAmB,UAC9B;AACG,gBAAM,IAAI,UACT,wFAAwF;AAAA,QAC3F;AAAA,MACH;AAED,UAAI,eACJ;AACG,uBAAe,OAAO,eAAe;AAErC,YAAI,OAAO,iBAAiB,UAC5B;AACG,gBAAM,IAAI,UACT,sFAAsF;AAAA,QACzF;AAAA,MACH;AAED,UAAI,mBACJ;AACG,wBAAgB,QAAQ,eAAe;AAEvC,YAAI,OAAO,kBAAkB,UAC7B;AACG,gBAAM,IAAI,UACT,uFAAuF;AAAA,QAC1F;AAAA,MACH;AAED,wBAAkB,KAAK,eAAe,QAAQ,OAAO,gBAAgB,cAAc,aAAa,CAAC;AAAA,IACnG;AAED,WAAO,IAAI,sBAAsB,iBAAiB;AAAA,EACpD;AAAA,EAaD,OAAO,GAAG,UAAU,QAAQ,SAC5B;AACG,QAAI,CAAC,SAAS,MAAM,KAAK,OAAO,WAAW,YAC3C;AACG,YAAM,IAAI,UAAU,oEAAoE;AAAA,IAC1F;AAED,QAAI,YAAY,UAAU,CAAC,SAAS,OAAO,KAAK,OAAO,YAAY,YACnE;AACG,YAAM,IAAI,UAAU,qEAAqE;AAAA,IAC3F;AAKD,UAAM,oBAAoB,CAAA;AAE1B,QAAI,QAAQ;AACZ,QAAI;AAEJ,UAAM,kBAAkB,OAAO,WAAW;AAC1C,UAAM,oBAAoB,OAAO,YAAY;AAC7C,UAAM,cAAc,mBAAmB;AAEvC,QAAI,aAAa;AAAE,wBAAkB,EAAE,OAAO,UAAU,QAAQ,MAAM,OAAM;AAAA,IAAK;AAEjF,QAAI,eAAe;AACnB,QAAI,gBAAgB;AAEpB,QAAI,WAAW,QAAQ,GACvB;AACG,iBAAW,SAAS,UACpB;AACG;AAEA,cAAM,aAAa,KAAK,YAAY,KAAK;AACzC,cAAM,iBAAiB,aAAa,QAAQ,MAAM;AAElD,YAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,kBAAQ,KAAK,sEAAsE,QAAQ;AAC3F;AAAA,QACF;AAED,YAAI,aACJ;AACG,0BAAgB,QAAQ;AACxB,0BAAgB,WAAW;AAC3B,0BAAgB,OAAO,aAAa,SAAS;AAAA,QAC/C;AAED,YAAI,iBACJ;AACG,yBAAe,OAAO,eAAe;AAGrC,cAAI,iBAAiB,QAAQ,iBAAiB,QAAQ;AAAE;AAAA,UAAW;AAEnE,cAAI,OAAO,iBAAiB,UAC5B;AACG,kBAAM,IAAI,UAAU,kEACnB,oCAAoC;AAAA,UACvC;AAAA,QACH;AAED,YAAI,mBACJ;AACG,0BAAgB,QAAQ,eAAe;AAGvC,cAAI,kBAAkB,QAAQ,kBAAkB,QAAQ;AAAE;AAAA,UAAW;AAErE,cAAI,OAAO,kBAAkB,UAC7B;AACG,kBAAM,IAAI,UAAU,mEACnB,oCAAoC;AAAA,UACvC;AAAA,QACH;AAED,0BAAkB,KAAK,eAAe,QAAQ,GAAG,cAAc,aAAa,CAAC;AAAA,MAC/E;AAAA,IACH,OAED;AACG,YAAM,aAAa,KAAK,YAAY,QAAQ;AAC5C,YAAM,iBAAiB,aAAa,WAAW,SAAS;AAExD,UAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,gBAAQ,KAAK,2DAA2D;AACxE,eAAO,sBAAsB;AAAA,MAC/B;AAED,UAAI,aACJ;AACG,wBAAgB,QAAQ;AACxB,wBAAgB,WAAW;AAC3B,wBAAgB,OAAO,aAAa,SAAS;AAAA,MAC/C;AAED,UAAI,iBACJ;AACG,uBAAe,OAAO,eAAe;AAErC,YAAI,OAAO,iBAAiB,UAC5B;AACG,gBAAM,IAAI,UACT,kFAAkF;AAAA,QACrF;AAAA,MACH;AAED,UAAI,mBACJ;AACG,wBAAgB,QAAQ,eAAe;AAEvC,YAAI,OAAO,kBAAkB,UAC7B;AACG,gBAAM,IAAI,UACT,mFAAmF;AAAA,QACtF;AAAA,MACH;AAED,wBAAkB,KAAK,eAAe,QAAQ,GAAG,cAAc,aAAa,CAAC;AAAA,IAC/E;AAED,WAAO,IAAI,sBAAsB,iBAAiB;AAAA,EACpD;AAAA,EAaD,OAAO,QAAQ,UAAU,MAAM,SAC/B;AACG,QAAI,CAAC,WAAW,IAAI,GACpB;AACG,YAAM,IAAI,UAAU,kEAAkE;AAAA,IACxF;AAED,QAAI,YAAY,UAAU,CAAC,SAAS,OAAO,KAAK,OAAO,YAAY,YACnE;AACG,YAAM,IAAI,UAAU,0EAA0E;AAAA,IAChG;AAKD,UAAM,mBAAmB,CAAA;AAEzB,QAAI,QAAQ;AAEZ,UAAM,oBAAoB,OAAO,YAAY;AAE7C,UAAM,kBAAkB,EAAE,OAAO,UAAU,QAAQ,MAAM;AAEzD,QAAI,gBAAgB;AAEpB,QAAI,WAAW,QAAQ,GACvB;AACG,iBAAW,SAAS,UACpB;AACG;AAEA,cAAM,aAAa,KAAK,YAAY,KAAK;AACzC,cAAM,iBAAiB,aAAa,QAAQ,MAAM;AAElD,YAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,kBAAQ,KAAK,2EAA2E,QAAQ;AAChG;AAAA,QACF;AAED,wBAAgB,QAAQ;AACxB,wBAAgB,WAAW;AAC3B,wBAAgB,OAAO,aAAa,SAAS;AAE7C,YAAI,mBACJ;AACG,0BAAgB,QAAQ,eAAe;AAGvC,cAAI,kBAAkB,QAAQ,kBAAkB,QAAQ;AAAE;AAAA,UAAW;AAErE,cAAI,OAAO,kBAAkB,UAC7B;AACG,kBAAM,IAAI,UAAU,wEACnB,oCAAoC;AAAA,UACvC;AAAA,QACH;AAED,yBAAiB,KAAK,eAAe,QAAQ,QAAQ,MAAM,aAAa,CAAC;AAAA,MAC3E;AAAA,IACH,OAED;AACG,YAAM,aAAa,KAAK,YAAY,QAAQ;AAC5C,YAAM,iBAAiB,aAAa,WAAW,SAAS;AAExD,UAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,gBAAQ,KAAK,gEAAgE;AAC7E,eAAO,MAAM;AAAA,MACf;AAED,sBAAgB,QAAQ;AACxB,sBAAgB,WAAW;AAC3B,sBAAgB,OAAO,aAAa,SAAS;AAE7C,UAAI,mBACJ;AACG,wBAAgB,QAAQ,eAAe;AAEvC,YAAI,OAAO,kBAAkB,UAC7B;AACG,gBAAM,IAAI,UACT,wFAAwF;AAAA,QAC3F;AAAA,MACH;AAED,uBAAiB,KAAK,eAAe,QAAQ,QAAQ,MAAM,aAAa,CAAC;AAAA,IAC3E;AAED,UAAM,YAAY,CAAC,GAAG,IAAI;AAE1B,WAAO,OAAO,SAAS;AAEvB,UAAM,YAAY,2BAAI,SACtB;AACG,YAAM,aAAa,KAAK;AAExB,UAAI,eAAe,GAAG;AAAE;AAAA,MAAS;AAEjC,UAAI,OAAO,KAAK,OAAO,YACvB;AACG,cAAM,eAAe,KAAK;AAE1B,gBAAQ;AACR,YAAI,OAAO;AAEX,YAAI,WAAW,QAAQ,GACvB;AACG,qBAAW,SAAS,UACpB;AACG;AAEA,kBAAM,aAAa,KAAK,YAAY,KAAK;AACzC,kBAAM,iBAAiB,aAAa,QAAQ,MAAM;AAElD,gBAAI,CAAC,KAAK,YAAY,cAAc,GAAG;AAAE;AAAA,YAAW;AAEpD,4BAAgB,QAAQ;AACxB,4BAAgB,WAAW;AAC3B,4BAAgB,OAAO,aAAa,SAAS;AAE7C,kBAAM,SAAS,aAAa,eAAe;AAG3C,gBAAI,WAAW,QAAQ,WAAW,QAAQ;AAAE;AAAA,YAAW;AAKvD,kBAAM,iBAAiB,WAAW,MAAM;AAExC,gBAAI,CAAC,OAAO,SAAS,MAAM,KAAK,CAAC,kBAAkB,OAAO,WAAW,UACrE;AACG,oBAAM,IAAI,UAAU,uEACnB,oEAAoE;AAAA,YACvE;AAED,gBAAI,gBACJ;AACG,+BAAiB,QAAQ,GAAG,MAAM;AAAA,YACpC,OAED;AACG,+BAAiB,QAAQ,MAAM;AAAA,YACjC;AAAA,UACH;AAAA,QACH,OAED;AACG,gBAAM,aAAa,KAAK,YAAY,QAAQ;AAC5C,gBAAM,iBAAiB,aAAa,WAAW,SAAS;AAExD,cAAI,CAAC,KAAK,YAAY,cAAc,GAAG;AAAE;AAAA,UAAS;AAElD,0BAAgB,QAAQ;AACxB,0BAAgB,WAAW;AAC3B,0BAAgB,OAAO,aAAa,SAAS;AAE7C,gBAAM,SAAS,aAAa,eAAe;AAG3C,cAAI,WAAW,QAAQ,WAAW,QAAQ;AAAE;AAAA,UAAS;AAErD,gBAAM,iBAAiB,WAAW,MAAM;AAExC,cAAI,CAAC,OAAO,SAAS,MAAM,KAAK,CAAC,kBAAkB,OAAO,WAAW,UACrE;AACG,kBAAM,IAAI,UAAU,uEACnB,oEAAoE;AAAA,UACvE;AAED,cAAI,gBACJ;AACG,6BAAiB,QAAQ,GAAG,MAAM;AAAA,UACpC,OAED;AACG,6BAAiB,QAAQ,MAAM;AAAA,UACjC;AAAA,QACH;AAAA,MACH,OAED;AACG,iBAAS,OAAO,iBAAiB,QAAQ,EAAE,QAAQ,KACnD;AACG,2BAAiB,MAAM,GAAG,IAAI;AAAA,QAChC;AAAA,MACH;AAAA,IACV,GA/FwB;AAiGlB,cAAU,OAAO;AAejB,cAAU,UAAU,CAAC,aACrB;AACG,UAAI,aAAY,UAAU,CAAC,SAAS,QAAO,KAAK,OAAO,aAAY,YACnE;AACG,cAAM,IAAI,UAAU,0EAA0E;AAAA,MAChG;AAGD,UAAI,SAAS,QAAO,GACpB;AACG,iBAAS,OAAO,iBAAiB,QAAQ,EAAE,QAAQ,KAAI;AAAE,2BAAiB,MAAM,QAAQ,QAAO;AAAA,QAAI;AAAA,MACrG,WACQ,OAAO,aAAY,YAC5B;AACG,YAAI,WAAW,QAAQ,GACvB;AACG,kBAAQ;AACR,cAAI,OAAO;AAEX,qBAAW,SAAS,UACpB;AACG;AAEA,kBAAM,aAAa,KAAK,YAAY,KAAK;AACzC,kBAAM,iBAAiB,aAAa,QAAQ,MAAM;AAElD,gBAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,sBAAQ,KACP,mFAAmF,QAAQ;AAC5F;AAAA,YACF;AAED,4BAAgB,QAAQ;AACxB,4BAAgB,WAAW;AAC3B,4BAAgB,OAAO,aAAa,SAAS;AAE7C,4BAAgB,SAAQ,eAAe;AAGvC,gBAAI,kBAAkB,QAAQ,kBAAkB,QAAQ;AAAE;AAAA,YAAW;AAErE,gBAAI,OAAO,kBAAkB,UAC7B;AACG,oBAAM,IAAI,UACT,gFACC,oCAAoC;AAAA,YACxC;AAED,6BAAiB,QAAQ,QAAQ,aAAa;AAAA,UAChD;AAAA,QACH,OAED;AACG,gBAAM,aAAa,KAAK,YAAY,QAAQ;AAC5C,gBAAM,iBAAiB,aAAa,WAAW,SAAS;AAExD,cAAI,CAAC,KAAK,YAAY,cAAc,GACpC;AACG,oBAAQ,KAAK,wEAAwE;AACrF,mBAAO;AAAA,UACT;AAED,0BAAgB,QAAQ;AACxB,0BAAgB,WAAW;AAC3B,0BAAgB,OAAO,aAAa,SAAS;AAE7C,0BAAgB,SAAQ,eAAe;AAEvC,cAAI,OAAO,kBAAkB,UAC7B;AACG,kBAAM,IAAI,UACT,wFAAwF;AAAA,UAC3F;AAED,2BAAiB,GAAG,QAAQ,aAAa;AAAA,QAC3C;AAAA,MACH;AAED,aAAO;AAAA,IAChB;AAEM,WAAO;AAAA,EACT;AACJ;AA/1Ba;ACjBN,MAAM,SACb;AAAA,EAIG;AAAA,EAQA;AAAA,EAKA;AAAA,EAQA;AAAA,EAEA,YAAY,EAAE,mBAAS,OAAO,OAAO,OAAO,WAAW,CAAE,GACzD;AACG,SAAK,UAAU;AACf,SAAK,QAAQ;AACb,SAAK,SAAS;AAEd,SAAK,QAAQ,OAAO,SAAS,YAAY,OAAO;AAAA,EAClD;AAAA,EAED,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAW;AAAA,EAEvC,IAAI,SAAS;AAAE,WAAO,KAAK;AAAA,EAAU;AAAA,EAErC,IAAI,QAAQ;AAAE,WAAO,KAAK;AAAA,EAAS;AAAA,EAEnC,IAAI,QAAQ,UACZ;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,aAAY,UAAW,aAAY,QAAQ,oBAAmB,aAClE;AACG,WAAK,WAAW;AAAA,IAClB,OAED;AACG,YAAM,IAAI,UAAU,qDAAqD;AAAA,IAC3E;AAAA,EACH;AAAA,EAED,IAAI,OAAO,QACX;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,WAAW,UAAU,OAAO,SAAS,MAAM,GAC/C;AACG,WAAK,UAAU;AAAA,IACjB,OAED;AACG,YAAM,IAAI,UAAU,+CAA+C;AAAA,IACrE;AAAA,EACH;AAAA,EAED,IAAI,MAAM,OACV;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,UAAU,UAAU,OAAO,SAAS,KAAK,GAC7C;AACG,WAAK,SAAS;AAAA,IAChB,OAED;AACG,YAAM,IAAI,UAAU,8CAA8C;AAAA,IACpE;AAAA,EACH;AAAA,EAED,aAAa,OAAO,QACpB;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,UAAU,UAAU,OAAO,SAAS,KAAK,GAC7C;AACG,WAAK,SAAS;AAAA,IAChB,OAED;AACG,YAAM,IAAI,UAAU,8CAA8C;AAAA,IACpE;AAED,QAAI,WAAW,UAAU,OAAO,SAAS,MAAM,GAC/C;AACG,WAAK,UAAU;AAAA,IACjB,OAED;AACG,YAAM,IAAI,UAAU,+CAA+C;AAAA,IACrE;AAAA,EACH;AAAA,EAED,QAAQ,OACR;AAEG,UAAM,cAAc,KAAK,UAAU,KAAK,UAAU,eAAe,WAAW;AAE5E,WAAQ,eAAc,SAAS;AAAA,EACjC;AAAA,EAED,OAAO,QACP;AACG,UAAM,eAAe,KAAK,WAAW,KAAK,UAAU,gBAAgB,WAAW;AAE/E,WAAQ,gBAAe,UAAU;AAAA,EACnC;AACJ;AA1Ha;ACEb,MAAM,kBAAkB,IAAI,SAAU;;;;;;ACF/B,MAAM,kBACb;AAAA,EACG,cACA;AACG,SAAK,OAAO;AACZ,SAAK,MAAM;AACX,SAAK,QAAQ;AACb,SAAK,SAAS;AACd,SAAK,YAAY;AACjB,SAAK,WAAW;AAChB,SAAK,YAAY;AACjB,SAAK,WAAW;AAChB,SAAK,SAAS;AACd,SAAK,YAAY;AACjB,SAAK,kBAAkB;AAAA,EACzB;AAAA,EAED,YACA;AACG,WAAO,KAAK,QAAQ,KAAK,OAAO,KAAK,SAAS,KAAK,UAAU,KAAK,aAAa,KAAK,YAAY,KAAK,aACpG,KAAK,YAAY,KAAK,UAAU,KAAK,aAAa,KAAK;AAAA,EAC1D;AAAA,EAED,IAAI,OACJ;AACG,SAAK,OAAO;AACZ,SAAK,MAAM;AACX,SAAK,QAAQ;AACb,SAAK,SAAS;AACd,SAAK,YAAY;AACjB,SAAK,WAAW;AAChB,SAAK,YAAY;AACjB,SAAK,WAAW;AAChB,SAAK,SAAS;AACd,SAAK,YAAY;AACjB,SAAK,kBAAkB;AAAA,EACzB;AACJ;AArCa;ACGN,MAAM,aACb;AAAA,EACG,YAAY;AAAA,IAAE,SAAS;AAAA,IAAM,OAAO;AAAA,IAAM,YAAY;AAAA,IAAM,WAAW;AAAA,IAAM,YAAY;AAAA,IAAM,WAAW;AAAA,IACzG,UAAU;AAAA,IAAM,UAAU;AAAA,IAAM,UAAU;AAAA,IAAM,QAAQ;AAAA,IAAM,aAAa;AAAA,IAAM,aAAa;AAAA,IAC7F,aAAa;AAAA,IAAM,MAAM;AAAA,IAAM,kBAAkB;AAAA,IAAM,QAAQ;AAAA,IAAM,SAAS;AAAA,MAAS,CAAE,GAC3F;AAIG,SAAK,SAAS;AAKd,SAAK,OAAO;AAKZ,SAAK,YAAY;AAKjB,SAAK,WAAW;AAKhB,SAAK,YAAY;AAKjB,SAAK,WAAW;AAKhB,SAAK,UAAU;AAKf,SAAK,UAAU;AAKf,SAAK,UAAU;AAKf,SAAK,QAAQ;AAKb,SAAK,MAAM;AAKX,SAAK,kBAAkB;AAKvB,SAAK,aAAa;AAKlB,SAAK,aAAa;AAKlB,SAAK,aAAa;AAKlB,SAAK,QAAQ;AAKb,SAAK,SAAS;AAEd,WAAO,KAAK,IAAI;AAAA,EAClB;AAAA,EASD,KAAK,MACL;AACG,SAAK,SAAS,KAAK;AACnB,SAAK,OAAO,KAAK;AACjB,SAAK,YAAY,KAAK;AACtB,SAAK,WAAW,KAAK;AACrB,SAAK,YAAY,KAAK;AACtB,SAAK,WAAW,KAAK;AACrB,SAAK,UAAU,KAAK;AACpB,SAAK,UAAU,KAAK;AACpB,SAAK,UAAU,KAAK;AACpB,SAAK,QAAQ,KAAK;AAClB,SAAK,MAAM,KAAK;AAChB,SAAK,kBAAkB,KAAK;AAC5B,SAAK,aAAa,KAAK;AACvB,SAAK,aAAa,KAAK;AACvB,SAAK,aAAa,KAAK;AACvB,SAAK,QAAQ,KAAK;AAClB,SAAK,SAAS,KAAK;AAEnB,WAAO;AAAA,EACT;AACJ;AA3Ha;ACEN,MAAM,iBACb;AAAA,EAEG;AAAA,EAKA,aAAa,oBAAI;EAGjB;AAAA,EAGA;AAAA,EAEA,YAAY,UAAU,MAAM,YAC5B;AACG,SAAK,YAAY;AACjB,SAAK,QAAQ;AACb,SAAK,cAAc;AAAA,EACrB;AAAA,EASD,IAAI,EAAE,QACN;AACG,QAAI,OAAO,SAAS,UAAU;AAAE,YAAM,IAAI,UAAU,mDAAmD;AAAA,IAAI;AAE3G,WAAO,KAAK,WAAW,IAAI,IAAI;AAAA,EACjC;AAAA,EAOD,aACA;AACG,WAAO,KAAK,WAAW,IAAI,cAAc;AAAA,EAC3C;AAAA,EAWD,OAAO,EAAE,QACT;AACG,QAAI,OAAO,SAAS,UAAU;AAAE,YAAM,IAAI,UAAU,4CAA4C;AAAA,IAAI;AAEpG,UAAM,OAAO,KAAK,WAAW,IAAI,IAAI;AACrC,SAAK,WAAW,OAAO,IAAI;AAE3B,WAAO;AAAA,EACT;AAAA,EAaD,MAAM,EAAE,aAAa,OAAO,YAAY,SAAS,CAAE,GACnD;AACG,UAAM,cAAc,KAAK,WAAW,IAAI,cAAc;AAGtD,QAAI,OAAO,gBAAgB,UAAU;AAAE,aAAO;AAAA,IAAQ;AAGtD,QAAI,KAAK,UAAU,QAAQ,aAC3B;AACG,WAAK,UAAU,QAAQ;IACzB;AAED,UAAM,SAAS,KAAK,UAAU;AAE9B,UAAM,OAAO,OAAO,OAAO,CAAE,GAAE,WAAW;AAE1C,QAAI,YAAY;AAAE,WAAK,SAAS;AAAA,IAAS;AAGzC,SAAK,YAAY,MAAM,IAAI;AAG3B,QAAI,KAAK,UAAU,QAAQ,UAAU,WACrC;AACG,WAAK,UAAU,QAAQ,WAAW,EAAE,SAAS,OAAO,UAAU,EAAC,CAAE;AAAA,IACnE;AAGD,QAAI,WAAW;AAAE,iBAAW,MAAM,KAAK,UAAU,IAAI,IAAI,GAAG,CAAC;AAAA,IAAI;AAEjE,WAAO;AAAA,EACT;AAAA,EA+BD,QAAQ;AAAA,IAAE;AAAA,IAAM,SAAS;AAAA,IAAO;AAAA,IAAY,SAAS;AAAA,IAAO,QAAQ;AAAA,IAAO,YAAY;AAAA,IAAO,WAAW;AAAA,IACxG,OAAOC;AAAAA,IAAQ,cAAcD;AAAAA,KAC9B;AACG,QAAI,OAAO,SAAS,UAAU;AAAE,YAAM,IAAI,UAAU,mDAAmD;AAAA,IAAI;AAE3G,UAAM,YAAY,KAAK,WAAW,IAAI,IAAI;AAE1C,QAAI,WACJ;AACG,UAAI,QAAQ;AAAE,aAAK,WAAW,OAAO,IAAI;AAAA,MAAI;AAE7C,UAAI,OAAO;AAEX,UAAI,WAAW,UAAU,GACzB;AACG,eAAO,CAAA;AACP,mBAAW,YAAY,YAAY;AAAE,eAAK,YAAY,UAAU;AAAA,QAAY;AAAA,MAC9E;AAGD,UAAI,QACJ;AACG,mBAAW,YAAY,MAAM;AAAE,eAAK,MAAM,YAAY,KAAK;AAAA,QAAY;AACvE,eAAO;AAAA,MACT,WACQ,WACT;AAEG,YAAI,KAAK,oBAAoB,KAAK,UAAU,iBAC5C;AACG,eAAK,UAAU,kBAAkB,KAAK;AAAA,QACxC;AAGD,YAAI,OACJ;AACG,iBAAO,KAAK,UAAU,QAAQ,GAAG,MAAM,EAAE,UAAU,MAAM,YAAa,CAAA,EAAE,SAAS,KAAK,MAAM,SAAS;AAAA,QACvG,OAED;AACG,eAAK,UAAU,QAAQ,GAAG,MAAM,EAAE,UAAU,MAAM,YAAW,CAAE;AAAA,QACjE;AAAA,MACH,OAED;AAEG,aAAK,UAAU,IAAI,IAAI;AAAA,MACzB;AAAA,IACH;AAED,WAAO;AAAA,EACT;AAAA,EAaD,KAAK,EAAE,SAAS,SAChB;AACG,QAAI,OAAO,SAAS,UAAU;AAAE,YAAM,IAAI,UAAU,gDAAgD;AAAA,IAAI;AAExG,UAAM,OAAO,KAAK,UAAU,IAAI,KAAK;AAErC,SAAK,WAAW,IAAI,MAAM,IAAI;AAE9B,WAAO;AAAA,EACT;AAAA,EAWD,IAAI,EAAE,SAAS,QACf;AACG,QAAI,OAAO,SAAS,UAAU;AAAE,YAAM,IAAI,UAAU,+CAA+C;AAAA,IAAI;AAEvG,SAAK,WAAW,IAAI,MAAM,IAAI;AAAA,EAChC;AACJ;AAtOa;ACAN,MAAM,WACb;AAAA,EACG,cACA;AAEG,SAAK,KAAK;AAGV,SAAK,WAAW;AAGhB,SAAK,aAAa;AAGlB,SAAK,YAAY;AAGjB,SAAK,YAAY;AAGjB,SAAK,WAAW;AAGhB,SAAK,YAAY;AAGjB,SAAK,WAAW;AAGhB,SAAK,gBAAgB;AAKrB,SAAK,iBAAiB;AAAA,MACnB,eAAe;AAAA,MACf,cAAc;AAAA,MACd,cAAc;AAAA,MACd,aAAa;AAAA,IACtB;AAOM,UAAM,sBAAsB,SAAS,KAAK,cAAc;AAExD,SAAK,SAAS;AAAA,MACX,SAAS,SAAS,KAAK,EAAE;AAAA,MACzB,qBAAqB,cAAc,qBAAqB,eAAe;AAAA,MACvE,oBAAoB,cAAc,qBAAqB,cAAc;AAAA,MACrE,gBAAgB;AAAA,MAChB,oBAAoB,cAAc,qBAAqB,cAAc;AAAA,MACrE,mBAAmB,cAAc,qBAAqB,aAAa;AAAA,IAC5E;AAAA,EACI;AAAA,EASD,IAAI,eACJ;AACG,QAAI,KAAK,cAAc,aACvB;AACG,aAAO,KAAK,eAAe,iBAAiB,SAAS,KAAK,eAAe,eAAe,KAAK,GAAG;AAAA,IAClG;AAED,UAAM,IAAI,MAAM,2DAA2D;AAAA,EAC7E;AAAA,EASD,IAAI,cACJ;AACG,QAAI,KAAK,cAAc,aACvB;AACG,aAAO,KAAK,eAAe,gBAAgB,SAAS,KAAK,eAAe,cAAc,KAAK,GAAG;AAAA,IAChG;AAED,UAAM,IAAI,MAAM,0DAA0D;AAAA,EAC5E;AAAA,EAOD,QAAQ,IAAI;AAAE,WAAO,KAAK,OAAO;AAAA,EAAK;AAAA,EAKtC,QACA;AAEG,QAAI,KAAK,cAAc,eAAe,KAAK,GAAG,eAAe,CAAC,KAAK,eACnE;AACG,WAAK,GAAG,MAAM,aAAa;AAAA,IAC7B;AAED,SAAK,KAAK;AACV,SAAK,WAAW;AAChB,SAAK,aAAa;AAClB,SAAK,YAAY;AACjB,SAAK,YAAY;AACjB,SAAK,WAAW;AAChB,SAAK,YAAY;AACjB,SAAK,WAAW;AAEhB,SAAK,gBAAgB;AAGrB,SAAK,eAAe,gBAAgB;AACpC,SAAK,eAAe,eAAe;AACnC,SAAK,eAAe,eAAe;AACnC,SAAK,eAAe,cAAc;AAGlC,SAAK,OAAO,QAAQ,IAAI,MAAM;AAAA,EAChC;AAAA,EAOD,OAAO,IACP;AACG,SAAK,KAAK;AAEV,SAAK,WAAW,WAAW,iBAAiB,EAAE;AAE9C,SAAK,aAAa,iBAAiB,GAAG,MAAM,UAAU,KAAK,iBAAiB,KAAK,SAAS,UAAU;AACpG,SAAK,YAAY,iBAAiB,GAAG,MAAM,SAAS,KAAK,iBAAiB,KAAK,SAAS,SAAS;AACjG,SAAK,YAAY,iBAAiB,GAAG,MAAM,SAAS,KAAK,iBAAiB,KAAK,SAAS,SAAS;AACjG,SAAK,WAAW,iBAAiB,GAAG,MAAM,QAAQ,KAAK,iBAAiB,KAAK,SAAS,QAAQ;AAG9F,SAAK,YAAY,iBAAiB,GAAG,MAAM,SAAS,KAAK,iBAAiB,KAAK,SAAS,SAAS;AACjG,SAAK,WAAW,iBAAiB,GAAG,MAAM,QAAQ,KAAK,iBAAiB,KAAK,SAAS,QAAQ;AAG9F,UAAM,aAAa,GAAG,MAAM,eAAe,KAAK,GAAG,MAAM,aAAuB,KAAK,SAAS;AAE9F,SAAK,gBAAgB,eAAe,MAAM,eAAe;AAGzD,SAAK,OAAO,QAAQ,IAAI,EAAE;AAAA,EAC5B;AACJ;AA/Ja;ACAN,MAAM,cACb;AAAA,EACG,cACA;AACG,WAAO,KAAK,IAAI;AAAA,EAClB;AAAA,EAOD,gBAAgB,IAAI;EAQpB,WAAW,CAAC,KAAK,OAAM,GAAI,KAAK,UAAU,KAAK,OAAQ,GAAE,KAAK,OAAQ,CAAA;AAAA,EAOtE,QAAQ,KAAK;EAOb,sBAAsB,CAAC,KAAK,OAAQ,GAAE,KAAK,OAAM,CAAE;AAAA,EAKnD,IAAI,eAAe;AAAE,WAAO,KAAK;AAAA,EAAgB;AAAA,EAKjD,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAW;AAAA,EAKvC,IAAI,MAAM;AAAE,WAAO,YAAY,KAAK,KAAK,KAAK,GAAG;AAAA,EAAO;AAAA,EAKxD,IAAI,OAAO;AAAE,WAAO,KAAK;AAAA,EAAQ;AAAA,EAKjC,IAAI,qBAAqB;AAAE,WAAO,KAAK;AAAA,EAAsB;AAChE;AA5Da;ACmBN,MAAM,kBACb;AAAA,EAIG;AAAA,EAEA,kBAAkB,oBAAI;EAKtB,cACA;AACG,SAAK,iBAAiB;AAEtB,WAAO,KAAK,IAAI;AAEhB,WAAO,CAAC,MAAM,KAAK,cAAc;AAAA,EACnC;AAAA,EAKD,IAAI,SAAS;AAAE,WAAO,KAAK,eAAe;AAAA,EAAS;AAAA,EAQnD,EAAE,OAAO,YACT;AACG,QAAI,KAAK,eAAe,WAAW,GAAG;AAAE;AAAA,IAAS;AAEjD,eAAW,SAAS,KAAK,gBACzB;AACG,YAAM,EAAE,GAAG;IACb;AAAA,EACH;AAAA,EAKD,OAAO,YACP;AAQG,eAAW,aAAa,YACxB;AACG,YAAM,gBAAgB,OAAO;AAE7B,UAAI,kBAAkB,cAAc,kBAAkB,YAAY,cAAc,MAChF;AACG,cAAM,IAAI,UAAU,kEAAkE;AAAA,MACxF;AAED,UAAI,OAAO;AACX,UAAI,cAAc;AAElB,cAAQ;AAAA,aAEA;AACF,iBAAO;AAAA,YACJ,IAAI;AAAA,YACJ;AAAA,YACA,QAAQ;AAAA,UAC1B;AAEe,wBAAc,UAAU;AACxB;AAAA,aAEE;AACF,cAAI,OAAO,UAAU,cAAc,YACnC;AACG,kBAAM,IAAI,UAAU,kEAAkE;AAAA,UACxF;AAED,cAAI,UAAU,WAAW,UAAU,OAAO,UAAU,WAAW,YAC7D,WAAU,SAAS,KAAK,UAAU,SAAS,IAC7C;AACG,kBAAM,IAAI,UACT,uFAAuF;AAAA,UAC1F;AAED,iBAAO;AAAA,YACJ,IAAI,UAAU,OAAO,SAAS,UAAU,KAAK;AAAA,YAC7C,WAAW,UAAU,UAAU,KAAK,SAAS;AAAA,YAC7C,QAAQ,UAAU,UAAU;AAAA,YAC5B,UAAU;AAAA,UAC5B;AAEe,wBAAc,UAAU,UAAU,aAAa,UAAU;AACzD;AAAA;AAIN,YAAM,QAAQ,KAAK,eAAe,UAAU,CAAC,UAC7C;AACG,eAAO,KAAK,SAAS,MAAM;AAAA,MACvC,CAAU;AAGD,UAAI,SAAS,GACb;AACG,aAAK,eAAe,OAAO,OAAO,GAAG,IAAI;AAAA,MAC3C,OAED;AACG,aAAK,eAAe,KAAK,IAAI;AAAA,MAC/B;AAED,UAAI,OAAO,gBAAgB,YAC3B;AAEG,cAAM,cAAc;AAGpB,YAAI,OAAO,gBAAgB,YAC3B;AACG,gBAAM,IAAI,UACT,iGAAiG;AAAA,QACpG;AAGD,YAAI,KAAK,gBAAgB,IAAI,KAAK,SAAS,GAC3C;AACG,gBAAM,IAAI,MACT,sFAAsF;AAAA,QACzF;AAED,aAAK,gBAAgB,IAAI,KAAK,WAAW,WAAW;AAAA,MAEtD;AAAA,IACH;AAAA,EAOH;AAAA,EAED,QACA;AACG,SAAK,eAAe,SAAS;AAG7B,eAAW,eAAe,KAAK,gBAAgB,OAAQ,GACvD;AACG;IACF;AAED,SAAK,gBAAgB;EAIvB;AAAA,EAKD,UAAU,YACV;AACG,UAAM,SAAS,KAAK,eAAe;AAEnC,QAAI,WAAW,GAAG;AAAE;AAAA,IAAS;AAE7B,eAAW,QAAQ,YACnB;AAEG,YAAM,kBAAkB,OAAO,SAAS,aAAa,OAAO,SAAS,QAAQ,OAAO,SAAS,WAC5F,KAAK,YAAY;AAElB,UAAI,CAAC,iBAAiB;AAAE;AAAA,MAAW;AAEnC,eAAS,OAAO,KAAK,eAAe,QAAQ,EAAE,QAAQ,KACtD;AACG,YAAI,KAAK,eAAe,MAAM,cAAc,iBAC5C;AACG,eAAK,eAAe,OAAO,MAAM,CAAC;AAGlC,cAAI,cAAc;AAClB,cAAI,OAAQ,eAAc,KAAK,gBAAgB,IAAI,eAAe,OAAO,YACzE;AACG;AACA,iBAAK,gBAAgB,OAAO,eAAe;AAAA,UAC7C;AAAA,QACH;AAAA,MACH;AAAA,IACH;AAAA,EAKH;AAAA,EASD,SAAS,UACT;AACG,UAAM,SAAS,KAAK,eAAe;AAEnC,QAAI,WAAW,GAAG;AAAE;AAAA,IAAS;AAE7B,QAAI,OAAO,aAAa,YACxB;AACG,YAAM,IAAI,UAAU,uDAAuD;AAAA,IAC7E;AAED,SAAK,iBAAiB,KAAK,eAAe,OAAO,CAAC,SAClD;AACG,YAAM,SAAS,SAAS,KAAK,UAAU,EAAE,GAAG,KAAI,CAAE;AAElD,UAAI,QACJ;AACG,YAAI;AACJ,YAAI,OAAQ,eAAc,KAAK,gBAAgB,IAAI,KAAK,SAAS,OAAO,YACxE;AACG;AACA,eAAK,gBAAgB,OAAO,KAAK,SAAS;AAAA,QAC5C;AAAA,MACH;AAGD,aAAO,CAAC;AAAA,IACjB,CAAO;AAAA,EAIH;AAAA,EAED,cAAc,KACd;AACG,UAAM,SAAS,KAAK,eAAe;AAEnC,QAAI,WAAW,GAAG;AAAE;AAAA,IAAS;AAE7B,SAAK,iBAAiB,KAAK,eAAe,OAAO,CAAC,SAClD;AACG,UAAI,SAAS;AAEb,iBAAW,MAAM,KAAK;AAAE,kBAAU,KAAK,OAAO;AAAA,MAAK;AAGnD,UAAI,QACJ;AACG,YAAI;AACJ,YAAI,OAAQ,eAAc,KAAK,gBAAgB,IAAI,KAAK,SAAS,OAAO,YACxE;AACG;AACA,eAAK,gBAAgB,OAAO,KAAK,SAAS;AAAA,QAC5C;AAAA,MACH;AAED,aAAO,CAAC;AAAA,IACjB,CAAO;AAAA,EAIH;AACJ;AAjRa;ACxBN,MAAM,YACb;AAAA,EAMG;AAAA,EAKA;AAAA,EAOA;AAAA,EAQA;AAAA,EAKA;AAAA,EAQA;AAAA,EAEA,YAAY,EAAE,YAAY,MAAM,mBAAS,UAAU,MAAM,OAAO,OAAO,OAAO,WAAW,CAAE,GAC3F;AACG,SAAK,UAAU;AACf,SAAK,YAAY;AACjB,SAAK,UAAU;AACf,SAAK,QAAQ;AACb,SAAK,SAAS;AAEd,SAAK,QAAQ,OAAO,SAAS,YAAY,OAAO;AAAA,EAClD;AAAA,EAED,IAAI,YAAY;AAAE,WAAO,KAAK;AAAA,EAAa;AAAA,EAE3C,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAW;AAAA,EAEvC,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAW;AAAA,EAEvC,IAAI,SAAS;AAAE,WAAO,KAAK;AAAA,EAAU;AAAA,EAErC,IAAI,QAAQ;AAAE,WAAO,KAAK;AAAA,EAAS;AAAA,EAEnC,IAAI,UAAU,WACd;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,OAAO,cAAc,WAAW;AAAE,YAAM,IAAI,UAAU,+BAA+B;AAAA,IAAI;AAE7F,SAAK,aAAa;AAAA,EACpB;AAAA,EAED,IAAI,QAAQ,UACZ;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,aAAY,UAAW,aAAY,QAAQ,oBAAmB,aAClE;AACG,WAAK,WAAW;AAAA,IAClB,OAED;AACG,YAAM,IAAI,UAAU,qDAAqD;AAAA,IAC3E;AAAA,EACH;AAAA,EAED,IAAI,QAAQ,SACZ;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,OAAO,YAAY,WAAW;AAAE,YAAM,IAAI,UAAU,6BAA6B;AAAA,IAAI;AAEzF,SAAK,WAAW;AAAA,EAClB;AAAA,EAED,IAAI,OAAO,QACX;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,WAAW,UAAU,OAAO,SAAS,MAAM,GAC/C;AACG,WAAK,UAAU;AAAA,IACjB,OAED;AACG,YAAM,IAAI,UAAU,+CAA+C;AAAA,IACrE;AAAA,EACH;AAAA,EAED,IAAI,MAAM,OACV;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,UAAU,UAAU,OAAO,SAAS,KAAK,GAC7C;AACG,WAAK,SAAS;AAAA,IAChB,OAED;AACG,YAAM,IAAI,UAAU,8CAA8C;AAAA,IACpE;AAAA,EACH;AAAA,EAED,aAAa,OAAO,QACpB;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,UAAU,UAAU,OAAO,SAAS,KAAK,GAC7C;AACG,WAAK,SAAS;AAAA,IAChB,OAED;AACG,YAAM,IAAI,UAAU,8CAA8C;AAAA,IACpE;AAED,QAAI,WAAW,UAAU,OAAO,SAAS,MAAM,GAC/C;AACG,WAAK,UAAU;AAAA,IACjB,OAED;AACG,YAAM,IAAI,UAAU,+CAA+C;AAAA,IACrE;AAAA,EACH;AAAA,EAUD,UAAU,SACV;AAEG,QAAI,CAAC,KAAK,UAAU;AAAE,aAAO,QAAQ;AAAA,IAAW;AAGhD,UAAM,cAAc,KAAK,UAAU,KAAK,UAAU,eAAe,WAAW;AAC5E,UAAM,eAAe,KAAK,WAAW,KAAK,UAAU,gBAAgB,WAAW;AAE/E,QAAI,OAAO,QAAQ,SAAS,UAAU,UACtC;AACG,YAAM,OAAO,QAAQ,YAAa,MAAK,aAAa,cAAc,OAAO;AACzE,cAAQ,SAAS,QAAQ,QAAQ,QAAQ,KAAK,QAAQ,QAAQ,SAAS,OAAO,QAAQ,UAAU,IAAI;AAEpG,UAAK,QAAQ,QAAQ,QAAQ,SAAS,OAAO,QAAQ,aAAc,aACnE;AACG,gBAAQ,SAAS,OAAO,cAAc,QAAQ,QAAQ,QAAQ;AAAA,MAChE;AAAA,IACH;AAED,QAAI,OAAO,QAAQ,SAAS,WAAW,UACvC;AACG,YAAM,OAAO,QAAQ,aAAc,MAAK,aAAa,eAAe,OAAO;AAC3E,cAAQ,SAAS,SAAS,QAAQ,SAAS,KAAK,QAAQ,QAAQ,SAAS,QAAQ,QAAQ,WAAW,IAAI;AAExG,UAAK,QAAQ,SAAS,QAAQ,SAAS,MAAM,QAAQ,YAAa,cAClE;AACG,gBAAQ,SAAS,MAAM,eAAe,QAAQ,SAAS,QAAQ;AAAA,MACjE;AAAA,IACH;AAED,UAAM,OAAO,KAAK,IAAI,cAAc,QAAQ,QAAQ,QAAQ,YAAY,CAAC;AACzE,YAAQ,SAAS,OAAO,KAAK,MAAM,KAAK,QAAQ,QAAQ,SAAS,MAAM,GAAG,IAAI,CAAC;AAE/E,UAAM,OAAO,KAAK,IAAI,eAAe,QAAQ,SAAS,QAAQ,WAAW,CAAC;AAC1E,YAAQ,SAAS,MAAM,KAAK,MAAM,KAAK,QAAQ,QAAQ,SAAS,KAAK,GAAG,IAAI,CAAC;AAE7E,WAAO,QAAQ;AAAA,EACjB;AACJ;AAjMa;ACEb,MAAM,mBAAmB,IAAI;AAEtB,MAAM,gBACb;AAAA,EAMG;AAAA,EAKA;AAAA,EAOA;AAAA,EAQA;AAAA,EAKA;AAAA,EAQA;AAAA,EAEA,YAAY,EAAE,YAAY,MAAM,mBAAS,UAAU,MAAM,OAAO,OAAO,OAAO,WAAW,CAAE,GAC3F;AACG,SAAK,UAAU;AACf,SAAK,YAAY;AACjB,SAAK,UAAU;AACf,SAAK,QAAQ;AACb,SAAK,SAAS;AAEd,SAAK,QAAQ,OAAO,SAAS,YAAY,OAAO;AAAA,EAClD;AAAA,EAED,IAAI,YAAY;AAAE,WAAO,KAAK;AAAA,EAAa;AAAA,EAE3C,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAW;AAAA,EAEvC,IAAI,UAAU;AAAE,WAAO,KAAK;AAAA,EAAW;AAAA,EAEvC,IAAI,SAAS;AAAE,WAAO,KAAK;AAAA,EAAU;AAAA,EAErC,IAAI,QAAQ;AAAE,WAAO,KAAK;AAAA,EAAS;AAAA,EAEnC,IAAI,UAAU,WACd;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,OAAO,cAAc,WAAW;AAAE,YAAM,IAAI,UAAU,+BAA+B;AAAA,IAAI;AAE7F,SAAK,aAAa;AAAA,EACpB;AAAA,EAED,IAAI,QAAQ,UACZ;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,aAAY,UAAU,aAAY,QAAQ,oBAAmB,aACjE;AACG,WAAK,WAAW;AAAA,IAClB,OAED;AACG,YAAM,IAAI,UAAU,qDAAqD;AAAA,IAC3E;AAAA,EACH;AAAA,EAED,IAAI,QAAQ,SACZ;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,OAAO,YAAY,WAAW;AAAE,YAAM,IAAI,UAAU,6BAA6B;AAAA,IAAI;AAEzF,SAAK,WAAW;AAAA,EAClB;AAAA,EAED,IAAI,OAAO,QACX;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,WAAW,UAAU,OAAO,SAAS,MAAM,GAC/C;AACG,WAAK,UAAU;AAAA,IACjB,OAED;AACG,YAAM,IAAI,UAAU,+CAA+C;AAAA,IACrE;AAAA,EACH;AAAA,EAED,IAAI,MAAM,OACV;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,UAAU,UAAU,OAAO,SAAS,KAAK,GAC7C;AACG,WAAK,SAAS;AAAA,IAChB,OAED;AACG,YAAM,IAAI,UAAU,8CAA8C;AAAA,IACpE;AAAA,EACH;AAAA,EAED,aAAa,OAAO,QACpB;AACG,QAAI,KAAK,OAAO;AAAE;AAAA,IAAS;AAE3B,QAAI,UAAU,UAAU,OAAO,SAAS,KAAK,GAC7C;AACG,WAAK,SAAS;AAAA,IAChB,OAED;AACG,YAAM,IAAI,UAAU,8CAA8C;AAAA,IACpE;AAED,QAAI,WAAW,UAAU,OAAO,SAAS,MAAM,GAC/C;AACG,WAAK,UAAU;AAAA,IACjB,OAED;AACG,YAAM,IAAI,UAAU,+CAA+C;AAAA,IACrE;AAAA,EACH;AAAA,EAUD,UAAU,SACV;AAEG,QAAI,CAAC,KAAK,UAAU;AAAE,aAAO,QAAQ;AAAA,IAAW;AAGhD,UAAM,cAAc,KAAK,UAAU,KAAK,UAAU,eAAe,WAAW;AAC5E,UAAM,eAAe,KAAK,WAAW,KAAK,UAAU,gBAAgB,WAAW;AAI/E,QAAI,OAAO,QAAQ,SAAS,UAAU,UACtC;AACG,YAAM,OAAO,QAAQ,YAAa,MAAK,aAAa,cAAc,OAAO;AACzE,cAAQ,SAAS,QAAQ,KAAK,QAAQ,QAAQ,OAAO,QAAQ,UAAU,IAAI;AAAA,IAC7E;AAID,QAAI,OAAO,QAAQ,SAAS,WAAW,UACvC;AACG,YAAM,OAAO,QAAQ,aAAc,MAAK,aAAa,eAAe,OAAO;AAC3E,cAAQ,SAAS,SAAS,KAAK,QAAQ,QAAQ,QAAQ,QAAQ,WAAW,IAAI;AAAA,IAChF;AAID,UAAM,OAAO,QAAQ,WAAW,QAAQ,QAAQ,UAAU,kBAAkB,OAAO;AAMnF,UAAM,WAAW,KAAK,aAAa;AACnC,UAAM,WAAW,KAAK,aAAa;AAEnC,QAAI,KAAK,aAAa,SAAS,QAAQ,YAAY,cACnD;AACG,WAAK,aAAa,KAAK,eAAe,KAAK,aAAa,SAAS,QAAQ;AAAA,IAC3E;AAED,QAAI,KAAK,aAAa,QAAQ,QAAQ,aAAa,aACnD;AACG,WAAK,aAAa,KAAK,cAAc,KAAK,aAAa,QAAQ,QAAQ;AAAA,IACzE;AAED,QAAI,KAAK,aAAa,MAAM,QAAQ,YAAY,GAChD;AACG,WAAK,aAAa,KAAK,KAAK,IAAI,KAAK,aAAa,MAAM,QAAQ,SAAS;AAAA,IAC3E;AAED,QAAI,KAAK,aAAa,OAAO,QAAQ,aAAa,GAClD;AACG,WAAK,aAAa,KAAK,KAAK,IAAI,KAAK,aAAa,OAAO,QAAQ,UAAU;AAAA,IAC7E;AAED,YAAQ,SAAS,QAAQ,WAAW,KAAK,aAAa;AACtD,YAAQ,SAAS,OAAO,WAAW,KAAK,aAAa;AAErD,WAAO,QAAQ;AAAA,EACjB;AACJ;AAvNa;ACDb,MAAM,cAAc,IAAI,YAAY,EAAE,MAAM,KAAM,CAAA;AAClD,MAAM,kBAAkB,IAAI,gBAAgB,EAAE,MAAM,KAAI,CAAE;;;;;;;;ACG1D,MAAM,iBAAiB,CAAC,GAAG,GAAG,CAAC;AAG/B,MAAM,qBAAqB,CAAC,GAAG,GAAG,CAAC;AAGnC,MAAM,gBAAgB,KAAK;AAG3B,MAAM,cAAc,KAAK;AAGzB,MAAM,cAAc,KAAK;AAElB,MAAM,WACb;AAAA,EAMG,aAAa,CAAA;AAAA,EAEb,cACA;AACG,SAAK,QAAQ;EACf;AAAA,EAKD,IAAI,WAAW;AAAE,WAAO,KAAK,WAAW,SAAS;AAAA,EAAI;AAAA,EAKrD,IAAI,UAAU;AAAE,WAAO,KAAK,MAAM;AAAA,EAAU;AAAA,EAK5C,IAAI,UAAU;AAAE,WAAO,KAAK,MAAM;AAAA,EAAU;AAAA,EAK5C,IAAI,UAAU;AAAE,WAAO,KAAK,MAAM;AAAA,EAAU;AAAA,EAK5C,IAAI,QAAQ;AAAE,WAAO,KAAK,MAAM;AAAA,EAAQ;AAAA,EAKxC,IAAI,aAAa;AAAE,WAAO,KAAK,MAAM;AAAA,EAAa;AAAA,EAKlD,IAAI,aAAa;AAAE,WAAO,KAAK,MAAM;AAAA,EAAa;AAAA,EAKlD,IAAI,aAAa;AAAE,WAAO,KAAK,MAAM;AAAA,EAAa;AAAA,EAOlD,IAAI,QAAQ,OACZ;AACG,QAAI,OAAO,SAAS,KAAK,GACzB;AACG,UAAI,KAAK,MAAM,YAAY,QAAQ;AAAE,aAAK,WAAW,KAAK,SAAS;AAAA,MAAI;AAEvE,WAAK,MAAM,UAAU;AAAA,IACvB,OAED;AACG,UAAI,KAAK,MAAM,YAAY,QAC3B;AACG,cAAM,QAAQ,KAAK,WAAW,UAAU,CAAC,UAAU,UAAU,SAAS;AACtE,YAAI,SAAS,GAAG;AAAE,eAAK,WAAW,OAAO,OAAO,CAAC;AAAA,QAAI;AAAA,MACvD;AAED,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACH;AAAA,EAOD,IAAI,QAAQ,OACZ;AACG,QAAI,OAAO,SAAS,KAAK,GACzB;AACG,UAAI,KAAK,MAAM,YAAY,QAAQ;AAAE,aAAK,WAAW,KAAK,SAAS;AAAA,MAAI;AAEvE,WAAK,MAAM,UAAU;AAAA,IACvB,OAED;AACG,UAAI,KAAK,MAAM,YAAY,QAC3B;AACG,cAAM,QAAQ,KAAK,WAAW,UAAU,CAAC,UAAU,UAAU,SAAS;AACtE,YAAI,SAAS,GAAG;AAAE,eAAK,WAAW,OAAO,OAAO,CAAC;AAAA,QAAI;AAAA,MACvD;AAED,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACH;AAAA,EAOD,IAAI,QAAQ,OACZ;AACG,QAAI,OAAO,SAAS,KAAK,GACzB;AACG,UAAI,KAAK,MAAM,YAAY,QAAQ;AAAE,aAAK,WAAW,KAAK,SAAS;AAAA,MAAI;AAEvE,WAAK,MAAM,UAAU;AAAA,IACvB,OAGD;AACG,UAAI,KAAK,MAAM,YAAY,QAC3B;AACG,cAAM,QAAQ,KAAK,WAAW,UAAU,CAAC,UAAU,UAAU,SAAS;AACtE,YAAI,SAAS,GAAG;AAAE,eAAK,WAAW,OAAO,OAAO,CAAC;AAAA,QAAI;AAAA,MACvD;AAED,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACH;AAAA,EAOD,IAAI,MAAM,OACV;AACG,QAAI,OAAO,SAAS,KAAK,GACzB;AACG,UAAI,KAAK,MAAM,UAAU,QAAQ;AAAE,aAAK,WAAW,KAAK,OAAO;AAAA,MAAI;AAEnE,WAAK,MAAM,QAAQ;AAAA,IACrB,OAED;AACG,UAAI,KAAK,MAAM,UAAU,QACzB;AACG,cAAM,QAAQ,KAAK,WAAW,UAAU,CAAC,UAAU,UAAU,OAAO;AACpE,YAAI,SAAS,GAAG;AAAE,eAAK,WAAW,OAAO,OAAO,CAAC;AAAA,QAAI;AAAA,MACvD;AAED,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACH;AAAA,EAOD,IAAI,WAAW,OACf;AACG,QAAI,OAAO,SAAS,KAAK,GACzB;AACG,UAAI,KAAK,MAAM,eAAe,QAAQ;AAAE,aAAK,WAAW,KAAK,YAAY;AAAA,MAAI;AAE7E,WAAK,MAAM,aAAa;AAAA,IAC1B,OAGD;AACG,UAAI,KAAK,MAAM,eAAe,QAC9B;AACG,cAAM,QAAQ,KAAK,WAAW,UAAU,CAAC,UAAU,UAAU,YAAY;AACzE,YAAI,SAAS,GAAG;AAAE,eAAK,WAAW,OAAO,OAAO,CAAC;AAAA,QAAI;AAAA,MACvD;AAED,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACH;AAAA,EAOD,IAAI,WAAW,OACf;AACG,QAAI,OAAO,SAAS,KAAK,GACzB;AACG,UAAI,KAAK,MAAM,eAAe,QAAQ;AAAE,aAAK,WAAW,KAAK,YAAY;AAAA,MAAI;AAE7E,WAAK,MAAM,aAAa;AAAA,IAC1B,OAGD;AACG,UAAI,KAAK,MAAM,eAAe,QAC9B;AACG,cAAM,QAAQ,KAAK,WAAW,UAAU,CAAC,UAAU,UAAU,YAAY;AACzE,YAAI,SAAS,GAAG;AAAE,eAAK,WAAW,OAAO,OAAO,CAAC;AAAA,QAAI;AAAA,MACvD;AAED,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACH;AAAA,EAOD,IAAI,WAAW,OACf;AACG,QAAI,OAAO,SAAS,KAAK,GACzB;AACG,UAAI,KAAK,MAAM,eAAe,QAAQ;AAAE,aAAK,WAAW,KAAK,YAAY;AAAA,MAAI;AAE7E,WAAK,MAAM,aAAa;AAAA,IAC1B,OAGD;AACG,UAAI,KAAK,MAAM,eAAe,QAC9B;AACG,cAAM,QAAQ,KAAK,WAAW,UAAU,CAAC,UAAU,UAAU,YAAY;AACzE,YAAI,SAAS,GAAG;AAAE,eAAK,WAAW,OAAO,OAAO,CAAC;AAAA,QAAI;AAAA,MACvD;AAED,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACH;AAAA,EASD,OAAO,OAAO,KAAK,OACnB;AACG,WAAO,YAAY,KAAK,QAAQ,MAAM,aAAa,EAAE,KAAK,GAAG;AAAA,EAC/D;AAAA,EASD,YAAY,OAAO,KAAK,OACxB;AACG,WAAO,YAAY,KAAK,aAAa,MAAM,aAAa,EAAE,KAAK,GAAG;AAAA,EACpE;AAAA,EAcD,QAAQ,UAAU,SAAS,IAAI,cAAe,GAAE,iBAAiB,CAAE,GACnE;AACG,UAAM,WAAW,eAAe,SAAS;AACzC,UAAM,YAAY,eAAe,UAAU;AAC3C,UAAM,eAAe,eAAe,aAAa,eAAe,aAAa;AAC7E,UAAM,gBAAgB,eAAe,cAAc,eAAe,cAAc;AAEhF,aAAS,OAAO;AAChB,aAAS,QAAQ;AAEjB,UAAM,QAAQ,OAAO,SAAS,SAAS,KAAK,IAAI,SAAS,QAAQ;AACjE,UAAM,SAAS,OAAO,SAAS,SAAS,MAAM,IAAI,SAAS,SAAS;AAEpE,UAAM,OAAO,OAAO;AAEpB,QAAI,KAAK,aAAa,QAAQ,GAC9B;AACG,WAAK,GAAG,KAAK,KAAK,GAAG,KAAK,KAAK,GAAG,KAAK;AACvC,WAAK,GAAG,KAAK;AACb,WAAK,GAAG,KAAK,KAAK,GAAG,KAAK;AAC1B,WAAK,GAAG,KAAK;AACb,WAAK,GAAG,KAAK;AACb,WAAK,GAAG,KAAK;AACb,WAAK,GAAG,KAAK;AACb,WAAK,GAAG,KAAK;AACb,WAAK,GAAG,KAAK;AAEb,YAAM,SAAS,KAAK,QAAQ,UAAU,OAAO,IAAI;AAEjD,YAAM,YAAY,yBAAyB,SAAS,iBAAiB,OAAO,QAAQ,OAAO,kBAAkB;AAE7G,UAAIE,2BAAqC,SAAS,iBAClD;AACG,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,MAAM;AAC3C,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,MAAM;AAC3C,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,MAAM;AAC3C,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,MAAM;AAAA,MAC7C,OAED;AACG,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE;AACjD,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,MAAM;AAC3C,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE;AAEjD,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE;AACjD,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,MAAM;AAC3C,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE;AAEjD,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE;AACjD,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,MAAM;AAC3C,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE;AAEjD,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE;AACjD,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,MAAM;AAC3C,aAAK,cAAc,KAAK,IAAI,KAAK,IAAI,UAAU,EAAE;AAAA,MACnD;AAED,WAAK,GAAG,KAAK,SAAS,OAAO,KAAK,GAAG;AACrC,WAAK,GAAG,KAAK,SAAS,MAAM,KAAK,GAAG;AACpC,WAAK,GAAG,KAAK,SAAS,OAAO,KAAK,GAAG;AACrC,WAAK,GAAG,KAAK,SAAS,MAAM,KAAK,GAAG;AACpC,WAAK,GAAG,KAAK,SAAS,OAAO,KAAK,GAAG;AACrC,WAAK,GAAG,KAAK,SAAS,MAAM,KAAK,GAAG;AACpC,WAAK,GAAG,KAAK,SAAS,OAAO,KAAK,GAAG;AACrC,WAAK,GAAG,KAAK,SAAS,MAAM,KAAK,GAAG;AAAA,IACtC,OAED;AACG,WAAK,GAAG,KAAK,SAAS;AACtB,WAAK,GAAG,KAAK,SAAS;AACtB,WAAK,GAAG,KAAK,SAAS,OAAO;AAC7B,WAAK,GAAG,KAAK,SAAS;AACtB,WAAK,GAAG,KAAK,SAAS,OAAO;AAC7B,WAAK,GAAG,KAAK,SAAS,MAAM;AAC5B,WAAK,GAAG,KAAK,SAAS;AACtB,WAAK,GAAG,KAAK,SAAS,MAAM;AAE5B,WAAK,SAAS,OAAO,IAAI;AAAA,IAC3B;AAED,QAAI,OAAO,OAAO;AAClB,QAAI,OAAO,OAAO;AAClB,QAAI,OAAO,OAAO;AAClB,QAAI,OAAO,OAAO;AAElB,aAAS,OAAO,GAAG,EAAE,QAAQ,KAC7B;AACG,UAAI,KAAK,MAAM,KAAK,MAAM;AAAE,eAAO,KAAK,MAAM;AAAA,MAAK;AACnD,UAAI,KAAK,MAAM,KAAK,MAAM;AAAE,eAAO,KAAK,MAAM;AAAA,MAAK;AACnD,UAAI,KAAK,MAAM,KAAK,MAAM;AAAE,eAAO,KAAK,MAAM;AAAA,MAAK;AACnD,UAAI,KAAK,MAAM,KAAK,MAAM;AAAE,eAAO,KAAK,MAAM;AAAA,MAAK;AAAA,IACrD;AAED,UAAM,eAAe,OAAO;AAC5B,iBAAa,IAAI;AACjB,iBAAa,IAAI;AACjB,iBAAa,QAAQ,OAAO;AAC5B,iBAAa,SAAS,OAAO;AAE7B,aAAS,OAAO;AAChB,aAAS,QAAQ;AAEjB,WAAO;AAAA,EACT;AAAA,EAeD,QAAQ,OAAO,KAAK,OAAO,SAAS,KAAK,OAAQ,GACjD;AACG,UAAM,SAAS,KAAK,SAAS,MAAM;AAGnC,QAAI,WAAW;AAEf,UAAM,YAAY,KAAK;AAGvB,aAAS,OAAO,GAAG,OAAO,UAAU,QAAQ,QAC5C;AACG,YAAM,MAAM,UAAU;AAEtB,cAAQ;AAAA,aAEA;AACF,sBAAYC,qBAA+B;AAC3C,eAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,aAEE;AACF,sBAAYA,qBAA+B;AAC3C,eAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,aAEE;AACF,sBAAYA,qBAA+B;AAC3C,eAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,aAEE;AACF,sBAAYA,qBAA+B;AAC3C,yBAAe,KAAK,eAAe,KAAK,KAAK;AAC7C,eAAK,SAAS,QAAQ,QAAQ,KAAK,YAAY,aAAa,cAAc,CAAC;AAC3E;AAAA,aAEE;AACF,sBAAYA,qBAA+B;AAC3C,6BAAmB,KAAK,KAAK;AAC7B,6BAAmB,KAAK;AACxB,6BAAmB,KAAK;AACxB,eAAK,SAAS,QAAQ,QAAQ,KAAK,gBAAgB,aAAa,kBAAkB,CAAC;AACnF;AAAA,aAEE;AACF,sBAAYA,qBAA+B;AAC3C,6BAAmB,KAAK;AACxB,6BAAmB,KAAK,KAAK;AAC7B,6BAAmB,KAAK;AACxB,eAAK,SAAS,QAAQ,QAAQ,KAAK,gBAAgB,aAAa,kBAAkB,CAAC;AACnF;AAAA,aAEE;AACF,sBAAYA,qBAA+B;AAC3C,6BAAmB,KAAK;AACxB,6BAAmB,KAAK;AACxB,6BAAmB,KAAK,KAAK;AAC7B,eAAK,SAAS,QAAQ,QAAQ,KAAK,gBAAgB,aAAa,kBAAkB,CAAC;AACnF;AAAA;AAAA,IAER;AAGD,QAAI,SAAS,KAAK,OAClB;AACG,eAAS,OAAO,GAAG,OAAOC,cAAwB,QAAQ,QAC1D;AACG,cAAM,MAAMA,cAAwB;AAGpC,YAAI,KAAK,SAAS,QAAS,YAAWD,qBAA+B,QAAQ,GAAG;AAAE;AAAA,QAAW;AAE7F,gBAAQ;AAAA,eAEA;AACF,iBAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,eAEE;AACF,iBAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,eAEE;AACF,iBAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,eAEE;AACF,2BAAe,KAAK,eAAe,KAAK,KAAK;AAC7C,iBAAK,SAAS,QAAQ,QAAQ,KAAK,YAAY,aAAa,cAAc,CAAC;AAC3E;AAAA,eAEE;AACF,+BAAmB,KAAK,KAAK;AAC7B,+BAAmB,KAAK;AACxB,+BAAmB,KAAK;AACxB,iBAAK,SAAS,QAAQ,QAAQ,KAAK,gBAAgB,aAAa,kBAAkB,CAAC;AACnF;AAAA,eAEE;AACF,+BAAmB,KAAK;AACxB,+BAAmB,KAAK,KAAK;AAC7B,+BAAmB,KAAK;AACxB,iBAAK,SAAS,QAAQ,QAAQ,KAAK,gBAAgB,aAAa,kBAAkB,CAAC;AACnF;AAAA,eAEE;AACF,+BAAmB,KAAK;AACxB,+BAAmB,KAAK;AACxB,+BAAmB,KAAK,KAAK;AAC7B,iBAAK,SAAS,QAAQ,QAAQ,KAAK,gBAAgB,aAAa,kBAAkB,CAAC;AACnF;AAAA;AAAA,MAER;AAAA,IACH;AAED,WAAO;AAAA,EACT;AAAA,EAkBD,aAAa,OAAO,KAAK,OAAO,SAAS,KAAK,OAAQ,GACtD;AACG,UAAM,SAAS,KAAK,SAAS,MAAM;AAKnC,uBAAmB,KAAM,MAAK,QAAQ,KAAM,MAAK,cAAc;AAC/D,uBAAmB,KAAM,MAAK,OAAO,KAAM,MAAK,cAAc;AAC9D,uBAAmB,KAAK,KAAK,cAAc;AAC3C,SAAK,SAAS,QAAQ,QAAQ,KAAK,gBAAgB,aAAa,kBAAkB,CAAC;AAGnF,QAAI,KAAK,UAAU,MACnB;AACG,qBAAe,KAAK,eAAe,KAAK,KAAK;AAC7C,WAAK,SAAS,QAAQ,QAAQ,KAAK,YAAY,aAAa,cAAc,CAAC;AAAA,IAC7E;AAGD,QAAI,KAAK,YAAY,QAAQ,KAAK,YAAY,QAAQ,KAAK,YAAY,MAAM;AAAE,aAAO;AAAA,IAAS;AAK/F,QAAI,WAAW;AAEf,UAAM,YAAY,KAAK;AAGvB,aAAS,OAAO,GAAG,OAAO,UAAU,QAAQ,QAC5C;AACG,YAAM,MAAM,UAAU;AAEtB,cAAQ;AAAA,aAEA;AACF,sBAAYA,qBAA+B;AAC3C,eAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,aAEE;AACF,sBAAYA,qBAA+B;AAC3C,eAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,aAEE;AACF,sBAAYA,qBAA+B;AAC3C,eAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA;AAAA,IAER;AAGD,QAAI,SAAS,KAAK,OAClB;AACG,eAAS,OAAO,GAAG,OAAOC,cAAwB,QAAQ,QAC1D;AACG,cAAM,MAAMA,cAAwB;AAGpC,YAAI,KAAK,SAAS,QAAS,YAAWD,qBAA+B,QAAQ,GAAG;AAAE;AAAA,QAAW;AAE7F,gBAAQ;AAAA,eAEA;AACF,iBAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,eAEE;AACF,iBAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA,eAEE;AACF,iBAAK,SAAS,QAAQ,QAAQ,KAAK,cAAc,aAAa,SAAS,KAAK,IAAI,CAAC,CAAC;AAClF;AAAA;AAAA,MAER;AAAA,IACH;AAED,WAAO;AAAA,EACT;AAAA,EASD,aAAa,MACb;AACG,eAAW,OAAOC,eAClB;AACG,UAAI,OAAO,SAAS,KAAK,IAAI,GAAG;AAAE,eAAO;AAAA,MAAO;AAAA,IAClD;AAED,WAAO;AAAA,EACT;AAAA,EAOD,MAAM,MACN;AACG,eAAW,OAAO,MAClB;AACG,UAAIA,cAAwB,SAAS,GAAG,GACxC;AACG,YAAI,OAAO,SAAS,KAAK,IAAI,GAC7B;AACG,eAAK,MAAM,OAAO,KAAK;AAAA,QACzB,OAED;AACG,gBAAM,QAAQ,KAAK,WAAW,UAAU,CAAC,UAAU,UAAU,GAAG;AAChE,cAAI,SAAS,GAAG;AAAE,iBAAK,WAAW,OAAO,OAAO,CAAC;AAAA,UAAI;AAErD,iBAAO,KAAK,MAAM;AAAA,QACpB;AAAA,MACH;AAAA,IACH;AAAA,EACH;AACJ;AAvoBa;AA2pBb,kCAAkC,iBAAiB,OAAO,QAAQ,QAClE;AACG,QAAM,SAAS;AAEf,UAAQ;AAAA,SAEA;AACF,aAAO,KAAK,OAAO,KAAK;AACxB,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC;AAAA,SAEE;AACF,aAAO,KAAK,CAAC,QAAQ;AACrB,aAAO,KAAK;AACZ,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC,aAAO,KAAK,QAAQ;AACpB,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC;AAAA,SAEE;AACF,aAAO,KAAK,CAAC;AACb,aAAO,KAAK;AACZ,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC,aAAO,KAAK;AACZ,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC;AAAA,SAEE;AACF,aAAO,KAAK;AACZ,aAAO,KAAK,CAAC,SAAS;AACtB,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC,aAAO,KAAK,SAAS;AACrB,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC;AAAA,SAEE;AAAA,SACA;AACF,aAAO,KAAK,CAAC,QAAQ;AACrB,aAAO,KAAK,CAAC,SAAS;AACtB,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC,aAAO,KAAK,QAAQ;AACpB,aAAO,KAAK,SAAS;AACrB,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC;AAAA,SAEE;AACF,aAAO,KAAK,CAAC;AACb,aAAO,KAAK,CAAC,SAAS;AACtB,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC,aAAO,KAAK;AACZ,aAAO,KAAK,SAAS;AACrB,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC;AAAA,SAEE;AACF,aAAO,KAAK;AACZ,aAAO,KAAK,CAAC;AACb,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC,aAAO,KAAK;AACZ,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC;AAAA,SAEE;AACF,aAAO,KAAK,CAAC,QAAQ;AACrB,aAAO,KAAK,CAAC;AACb,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC,aAAO,KAAK,QAAQ;AACpB,aAAO,KAAK;AACZ,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC;AAAA,SAEE;AACF,aAAO,KAAK,CAAC;AACb,aAAO,KAAK,CAAC;AACb,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC,aAAO,KAAK;AACZ,aAAO,KAAK;AACZ,WAAK,gBAAgB,OAAO,IAAI,MAAM;AACtC;AAAA;AAIA,WAAK,SAAS,OAAO,EAAE;AACvB,WAAK,SAAS,OAAO,EAAE;AACvB;AAAA;AAGN,SAAO;AACV;AAzFS;AC3qBF,MAAM,kBACb;AAAA,EACG,cACA;AAMG,SAAK,OAAO;AAOZ,SAAK,kBAAkB,IAAI;AAO3B,SAAK,gBAAgB,EAAE,OAAO,GAAG,QAAQ;AAKzC,SAAK,YAAY;AAKjB,SAAK,UAAU;AAOf,SAAK,SAAS;AAKd,SAAK,aAAa;AAKlB,SAAK,aAAa;AAQlB,SAAK,gBAAgB,IAAI;AAKzB,SAAK,gBAAgB;AAKrB,SAAK,iBAAiB,SAAS,KAAK,aAAa;AAOjD,SAAK,iBAAiB,SAAS,KAAK,eAAe,MACnD;AACG,WAAK,QAAQ,sBAAsB;AACnC,aAAO,MAAM,KAAK,QAAQ,sBAAsB;AAAA,IACzD,CAAO;AAOD,SAAK,SAAS;AAGd,WAAO,KAAK,KAAK,aAAa;AAAA,EAChC;AACJ;AA3Fa;AC2Fb,kCAAkC,OAAO,GACzC;AACG,MAAI,CAAC,OAAO,UAAU,IAAI,KAAK,OAAO,GACtC;AACG,UAAM,IAAI,UAAU,6EAA6E;AAAA,EACnG;AAED,MAAI,cAAc,YAAY;AAC9B,SAAM,EAAE,QAAQ,KAChB;AACG,kBAAc,MAAM,IAAI,QAAQ,CAAC,YAAY,sBAAsB,OAAO,CAAC;AAAA,EAC7E;AAED,SAAO;AACV;AAde;ACtFR,MAAM,qBACb;AAAA,EACG,OAAO,OAAO,CAAA;AAAA,EACd,OAAO,WAAW;AAAA,EAElB,OAAO;AAAA,EAEP,WAAW,UAAU;AAAE,WAAO,KAAK;AAAA,EAAgB;AAAA,EAWnD,OAAO,IAAI,IAAI,YACf;AACG,QAAI,KAAK,WAAW,KAAK,KAAK,QAC9B;AACG,YAAM,QAAQ,KAAK,KAAK,KAAK;AAC7B,YAAM,KAAK;AACX,YAAM,KAAK;AAAA,IACb,OAED;AACG,WAAK,KAAK,KAAK,CAAC,IAAI,UAAU,CAAC;AAAA,IACjC;AAED,SAAK;AACL,eAAW,SAAS;AAEpB,QAAI,CAAC,KAAK,eAAe;AAAE,WAAK,gBAAgB,KAAK,KAAI;AAAA,IAAK;AAE9D,WAAO,KAAK;AAAA,EACd;AAAA,EAOD,aAAa,OACb;AAEG,UAAM,cAAc,MAAM;AAE1B,SAAK,gBAAgB;AAErB,aAAS,OAAO,KAAK,UAAU,EAAE,QAAQ,KACzC;AAEG,YAAM,QAAQ,KAAK,KAAK;AACxB,YAAM,KAAK,MAAM;AACjB,YAAM,aAAa,MAAM;AAGzB,YAAM,KAAK;AACX,YAAM,KAAK;AAGX,iBAAW,SAAS;AAIpB,UAAI,CAAC,GAAG,aAAa;AAAE;AAAA,MAAW;AAElC,UAAI,WAAW,QAAQ,OACvB;AACG,+BAAuB,IAAI,UAAU;AAAA,MACvC,OAED;AACG,yBAAiB,IAAI,UAAU;AAAA,MACjC;AAGD,UAAI,WAAW,QAAQ,sBAAsB,WAAW,QAAQ,qBAChE;AACG,2BAAmB,IAAI,UAAU;AAAA,MACnC;AAGD,WAAK,kBAAkB,UAAU;AAAA,IACnC;AAED,SAAK,WAAW;AAEhB,WAAO;AAAA,EACT;AAAA,EASD,OAAO,UAAU,IAAI,YACrB;AAGG,QAAI,CAAC,GAAG,aAAa;AAAE;AAAA,IAAS;AAEhC,QAAI,WAAW,QAAQ,OACvB;AACG,6BAAuB,IAAI,UAAU;AAAA,IACvC,OAED;AACG,uBAAiB,IAAI,UAAU;AAAA,IACjC;AAGD,QAAI,WAAW,QAAQ,sBAAsB,WAAW,QAAQ,qBAChE;AACG,yBAAmB,IAAI,UAAU;AAAA,IACnC;AAGD,SAAK,kBAAkB,UAAU;AAAA,EACnC;AAAA,EAKD,OAAO,kBAAkB,YACzB;AACG,UAAM,OAAO,WAAW;AACxB,UAAM,YAAY,WAAW;AAE7B,QAAI,CAAC,UAAU,UAAW,GAAE;AAAE;AAAA,IAAS;AAGvC,UAAM,SAAS,WAAW,gBAAgB,KAAK,IAAI;AAEnD,UAAM,gBAAgB,WAAW;AAGjC,QAAI,cAAc,SAAS,GAC3B;AACG,eAAS,OAAO,GAAG,OAAO,cAAc,QAAQ,QAAQ;AAAE,sBAAc,MAAM,MAAM;AAAA,MAAI;AAAA,IAC1F;AAGD,QAAI,UAAU,SAAS,UAAU,QACjC;AACG,iBAAW,cAAc,QAAQ,KAAK;AACtC,iBAAW,cAAc,SAAS,KAAK;AACvC,iBAAW,eAAe,IAAI,WAAW,aAAa;AAAA,IACxD;AAED,cAAU,IAAI,KAAK;AAAA,EACrB;AACJ;AA5Ja;AAwKb,0BAA0B,IAAI,YAC9B;AACG,QAAM,YAAY,WAAW;AAC7B,QAAM,OAAO,WAAW;AAExB,MAAI,UAAU,MACd;AACG,OAAG,MAAM,OAAO,GAAG,KAAK;AAAA,EAC1B;AAED,MAAI,UAAU,KACd;AACG,OAAG,MAAM,MAAM,GAAG,KAAK;AAAA,EACzB;AAED,MAAI,UAAU,QACd;AACG,OAAG,MAAM,SAAS,OAAO,KAAK,WAAW,WAAW,GAAG,KAAK,WAAW;AAAA,EACzE;AAED,MAAI,UAAU,OACd;AACG,OAAG,MAAM,QAAQ,OAAO,KAAK,UAAU,WAAW,GAAG,KAAK,YAAY,KAAK;AAAA,EAC7E;AAED,MAAI,UAAU,QACd;AACG,OAAG,MAAM,SAAS,OAAO,KAAK,WAAW,WAAW,GAAG,KAAK,aAAa,KAAK;AAAA,EAChF;AAED,MAAI,UAAU,iBACd;AAEG,OAAG,MAAM,kBAAkB,KAAK,oBAAoB,WAAW,OAAO,KAAK;AAAA,EAC7E;AAGD,MAAI,UAAU,WACd;AACG,OAAG,MAAM,YAAY,WAAW,WAAW,WAAW,WAAW,WAAW,OAAQ,IAAG;AAAA,EACzF;AACJ;AAzCS;AAqDT,gCAAgC,IAAI,YACpC;AACG,QAAM,YAAY,WAAW;AAC7B,QAAM,OAAO,WAAW;AAExB,MAAI,UAAU,QACd;AACG,OAAG,MAAM,SAAS,OAAO,KAAK,WAAW,WAAW,GAAG,KAAK,WAAW;AAAA,EACzE;AAED,MAAI,UAAU,OACd;AACG,OAAG,MAAM,QAAQ,OAAO,KAAK,UAAU,WAAW,GAAG,KAAK,YAAY,KAAK;AAAA,EAC7E;AAED,MAAI,UAAU,QACd;AACG,OAAG,MAAM,SAAS,OAAO,KAAK,WAAW,WAAW,GAAG,KAAK,aAAa,KAAK;AAAA,EAChF;AAED,MAAI,UAAU,iBACd;AAEG,OAAG,MAAM,kBAAkB,KAAK,oBAAoB,WAAW,OAAO,KAAK;AAAA,EAC7E;AAGD,MAAI,UAAU,QAAQ,UAAU,OAAO,UAAU,WACjD;AACG,OAAG,MAAM,YAAY,WAAW,WAAW,YAAY,IAAI;AAAA,EAC7D;AACJ;AA/BS;AAwCT,4BAA4B,IAAI,YAChC;AACGC,sBAAkB,SAAS,WAAW,KAAK,WAAW,SAAS,WAAW,KAAK,SAC9E,WAAW,WAAW;AAEvBA,sBAAkB,QAAQ,WAAW,KAAK,UAAU,SAAS,WAAW,KAAK,QAC5E,WAAW,WAAW;AAEvBA,sBAAkB,aAAa,WAAW,WAAW;AAErDA,sBAAkB,YAAY,WAAW,WAAW;AAIpD,aAAW,WAAW,QAAQ,WAAW,MAAM,WAAW,eAAeA,mBAAiB;AAE1F,aAAW,eAAe,IAAI,WAAW,aAAa;AACzD;AAjBS;AAmBT,MAAMA,sBAAoB;AAAA,EACvB,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,WAAW;AACd;AC1QO,MAAM,SACb;AAAA,EAIG,QAAQ,IAAI;EAOZ,WAAW,IAAI,aAAa,MAAM,KAAK,KAAK;AAAA,EAO5C,qBAAqB,IAAI;EAOzB,WAAW;AAAA,IACR,oBAAoB;AAAA,IACpB,eAAe;AAAA,IACf,OAAO;AAAA,IACP,qBAAqB;AAAA,EAC3B;AAAA,EAOG;AAAA,EAKA;AAAA,EAOA;AAAA,EAOA,iBAAiB,CAAA;AAAA,EAKjB,cAAc,IAAI;EAKlB;AAAA,EAOA;AAAA,EAKA;AAAA,EAKA;AAAA,EAKA,SAAS,IAAI,iBAAiB,MAAM,KAAK,OAAO,KAAK,WAAW;AAAA,EAKhE,WAAW,UAAU;AAAE,WAAO;AAAA,EAAoB;AAAA,EAKlD,WAAW,UAAU;AAAE,WAAO;AAAA,EAAkB;AAAA,EAOhD,WAAW,gBAAgB;AAAE,WAAO;AAAA,EAAgB;AAAA,EAUpD,WAAW,aAAa;AAAE,WAAO;AAAA,EAAqB;AAAA,EAatD,OAAO,UAAU,UAAU,SAC3B;AACG,QAAI,CAAE,qBAAoB,WAAW;AAAE,YAAM,IAAI,UAAU,4CAA4C;AAAA,IAAI;AAE3G,UAAM,cAAc,IAAI,SAAS,OAAO;AAExC,gBAAY,WAAW,OAAO,OAAO,CAAE,GAAE,SAAS,UAAU,OAAO;AACnE,gBAAY,YAAY,IAAI,GAAG,SAAS,WAAW;AAEnD,gBAAY,IAAI,SAAS,KAAK;AAE9B,WAAO;AAAA,EACT;AAAA,EAQD,YAAY,QAAQ,SACpB;AAEG,QAAI,cAAc,MAAM,GACxB;AACG,gBAAU;AAAA,IACZ,OAED;AACG,WAAK,UAAU;AAAA,IACjB;AAED,UAAM,OAAO,KAAK;AAClB,UAAM,aAAa,KAAK;AAExB,SAAK,cAAc,IAAI;AAEvB,UAAM,aAAa,IAAI;AAEvB,eAAW,YAAY,KAAK;AAC5B,eAAW,OAAO,KAAK;AACvB,eAAW,UAAU,KAAK;AAC1B,eAAW,aAAa,KAAK;AAC7B,eAAW,gBAAgB,KAAK;AAChC,eAAW,aAAa,KAAK;AAE7B,SAAK,qBAAqB;AAE1B,QAAI,OAAO,YAAY,UACvB;AAEG,UAAI,OAAO,QAAQ,uBAAuB,WAC1C;AACG,aAAK,SAAS,qBAAqB,QAAQ;AAAA,MAC7C;AAED,UAAI,OAAO,QAAQ,UAAU,WAC7B;AACG,aAAK,SAAS,QAAQ,QAAQ;AAAA,MAChC;AAID,UAAI,OAAO,SAAS,QAAQ,MAAM,KAAK,QAAQ,WAAW,UAAU,QAAQ,WAAW,aACtF,QAAQ,WAAW,MACpB;AACG,aAAK,SAAS,WAAW,cAAc,SAAS,OAAO,QAAQ,WAAW,WACzE,KAAK,MAAM,QAAQ,MAAM,IAAI,QAAQ;AAAA,MACxC;AAED,UAAI,OAAO,SAAS,QAAQ,IAAI,KAAK,QAAQ,SAAS,MACtD;AACG,aAAK,OAAO,OAAO,QAAQ,SAAS,WAAW,KAAK,MAAM,QAAQ,IAAI,IAAI,QAAQ;AAAA,MACpF;AAED,UAAI,OAAO,SAAS,QAAQ,SAAS,KAAK,QAAQ,cAAc,MAChE;AACG,aAAK,YAAY,OAAO,QAAQ,cAAc,WAAW,KAAK,MAAM,QAAQ,SAAS,IAAI,QAAQ;AAAA,MACnG;AAED,UAAI,OAAO,SAAS,QAAQ,QAAQ,KAAK,QAAQ,aAAa,MAC9D;AACG,aAAK,WAAW,OAAO,QAAQ,aAAa,WAAW,KAAK,MAAM,QAAQ,QAAQ,IAAI,QAAQ;AAAA,MAChG;AAED,UAAI,OAAO,SAAS,QAAQ,SAAS,KAAK,QAAQ,cAAc,MAChE;AACG,aAAK,YAAY,OAAO,QAAQ,cAAc,WAAW,KAAK,MAAM,QAAQ,SAAS,IAAI,QAAQ;AAAA,MACnG;AAED,UAAI,OAAO,SAAS,QAAQ,QAAQ,KAAK,QAAQ,aAAa,MAC9D;AACG,aAAK,WAAW,OAAO,QAAQ,aAAa,WAAW,KAAK,MAAM,QAAQ,QAAQ,IAAI,QAAQ;AAAA,MAChG;AAED,UAAI,OAAO,SAAS,QAAQ,OAAO,KAAK,QAAQ,YAAY,MAC5D;AACG,mBAAW,UAAU,KAAK,UAAU,QAAQ;AAAA,MAC9C;AAED,UAAI,OAAO,SAAS,QAAQ,OAAO,KAAK,QAAQ,YAAY,MAC5D;AACG,mBAAW,UAAU,KAAK,UAAU,QAAQ;AAAA,MAC9C;AAED,UAAI,OAAO,SAAS,QAAQ,OAAO,KAAK,QAAQ,YAAY,MAC5D;AACG,mBAAW,UAAU,KAAK,UAAU,QAAQ;AAAA,MAC9C;AAED,UAAI,OAAO,SAAS,QAAQ,KAAK,KAAK,QAAQ,UAAU,MACxD;AACG,mBAAW,QAAQ,KAAK,QAAQ,QAAQ;AAAA,MAC1C;AAED,UAAI,OAAO,SAAS,QAAQ,GAAG,KAAK,QAAQ,QAAQ,MACpD;AACG,aAAK,MAAM,OAAO,QAAQ,QAAQ,WAAW,KAAK,MAAM,QAAQ,GAAG,IAAI,QAAQ;AAAA,MACjF;AAED,UAAI,OAAO,QAAQ,oBAAoB,YAAY,QAAQ,oBAAoB,MAC/E;AACG,aAAK,kBAAkBC,iBAA2B,SAAS,QAAQ,eAAe,IACjF,QAAQ,kBAAkB;AAAA,MAC7B;AAED,UAAI,OAAO,SAAS,QAAQ,UAAU,KAAK,QAAQ,eAAe,MAClE;AACG,mBAAW,aAAa,KAAK,aAAa,QAAQ;AAAA,MACpD;AAED,UAAI,OAAO,SAAS,QAAQ,UAAU,KAAK,QAAQ,eAAe,MAClE;AACG,mBAAW,aAAa,KAAK,aAAa,QAAQ;AAAA,MACpD;AAED,UAAI,OAAO,SAAS,QAAQ,UAAU,KAAK,QAAQ,eAAe,MAClE;AACG,mBAAW,aAAa,KAAK,aAAa,QAAQ;AAAA,MACpD;AAED,UAAI,OAAO,SAAS,QAAQ,KAAK,KAAK,QAAQ,UAAU,UAAU,QAAQ,UAAU,aACnF,QAAQ,UAAU,MACnB;AACG,aAAK,QAAQ,WAAW,cAAc,QAAQ,OAAO,QAAQ,UAAU,WACtE,KAAK,MAAM,QAAQ,KAAK,IAAI,QAAQ;AAAA,MACvC;AAED,UAAI,OAAO,SAAS,QAAQ,MAAM,KAAK,QAAQ,WAAW,MAC1D;AACG,aAAK,SAAS,OAAO,QAAQ,WAAW,WAAW,KAAK,MAAM,QAAQ,MAAM,IAAI,QAAQ;AAAA,MAC1F;AAAA,IACH;AAED,SAAK,UAAU;AAAA,MAEZ,QAAQ,cAAc,MAAM,QAAQ;AAAA,MACpC,MAAM,cAAc,MAAM,MAAM;AAAA,MAChC,SAAS,cAAc,MAAM,SAAS;AAAA,MACtC,SAAS,cAAc,MAAM,SAAS;AAAA,MACtC,SAAS,cAAc,MAAM,SAAS;AAAA,MACtC,OAAO,cAAc,MAAM,OAAO;AAAA,MAClC,KAAK,cAAc,MAAM,KAAK;AAAA,MAC9B,iBAAiB,cAAc,MAAM,iBAAiB;AAAA,MACtD,YAAY,cAAc,MAAM,YAAY;AAAA,MAC5C,YAAY,cAAc,MAAM,YAAY;AAAA,MAC5C,YAAY,cAAc,MAAM,YAAY;AAAA,MAC5C,OAAO,cAAc,MAAM,OAAO;AAAA,MAClC,QAAQ,cAAc,MAAM,QAAQ;AAAA,MAGpC,WAAW,cAAc,MAAM,WAAW;AAAA,MAC1C,UAAU,cAAc,MAAM,UAAU;AAAA,MACxC,WAAW,cAAc,MAAM,WAAW;AAAA,MAC1C,UAAU,cAAc,MAAM,UAAU;AAAA,MAGxC,WAAW,EAAE,WAAW,WAAW,eAAe,UAAW;AAAA,MAC7D,SAAS,EAAE,WAAW,KAAK,YAAY,OAAO,QAAQ,UAAW;AAAA,MACjE,qBAAqB,EAAE,WAAW,KAAK,YAAY,OAAO,oBAAoB,UAAW;AAAA,MACzF,oBAAoB,EAAE,WAAW,KAAK,YAAY,OAAO,mBAAmB,UAAW;AAAA,MACvF,oBAAoB,EAAE,WAAW,KAAK,YAAY,OAAO,mBAAmB,UAAW;AAAA,MACvF,mBAAmB,EAAE,WAAW,KAAK,YAAY,OAAO,kBAAkB,UAAW;AAAA,MACrF,WAAW,EAAE,WAAW,WAAW,eAAe,UAAW;AAAA,MAG7D,gBAAgB,KAAK,YAAY,OAAO;AAAA,IACjD;AAKM,yBAAqB,KAAK,QAAQ,gBAAgB,CAAC,eACnD;AACG,YAAM,UAAS,KAAK;AACpB,YAAM,KAAK,mBAAkB,cAAc,UAAS,SAAQ;AAG5D,UAAI,cAAc,eAAe,OAAO,SAAS,YAAY,WAAW,KACvE,OAAO,SAAS,YAAY,YAAY,GACzC;AACG,aAAK,IAAI,IAAI;AAAA,MACf;AAAA,IACV,CAAO;AAED,SAAK,QAAQ,gBAAgB,SAASA;AAEtC,KAAC,KAAK,aAAa,KAAK,cAAc,IAAI,IAAI;AAE9C,QAAI,SAAS,WAAW,SAAS,iBACjC;AACG,YAAM,gBAAgB,QAAQ,WAAW,QAAQ;AAEjD,UAAI,OAAO,eAAe,YAAY,cAAc,OAAO,eAAe,WAAW,YACrF;AACG,cAAM,IAAI,MACT,2FAA2F;AAAA,MAC9F;AAED,WAAK,SAAS,gBAAgB,QAAQ;AAAA,IACxC;AAED,QAAI,SAAS,WACb;AACG,UAAI,WAAW,SAAS,SAAS,GAAG;AAAE,aAAK,WAAW,IAAI,GAAG,QAAQ,SAAS;AAAA,MAAI,OAC7E;AAAE,aAAK,WAAW,IAAI,QAAQ,SAAS;AAAA,MAAI;AAAA,IAClD;AAAA,EACH;AAAA,EAOD,IAAI,UACJ;AACG,WAAO,KAAK;AAAA,EACd;AAAA,EAOD,IAAI,YACJ;AACG,WAAO,KAAK,mBAAmB;AAAA,EACjC;AAAA,EAOD,IAAI,UACJ;AACG,WAAO,KAAK,YAAY;AAAA,EAC1B;AAAA,EAOD,IAAI,iBACJ;AACG,WAAO,KAAK;AAAA,EACd;AAAA,EAOD,IAAI,SAAS;AAAE,WAAO,KAAK;AAAA,EAAU;AAAA,EAOrC,IAAI,QAAQ;AAAE,WAAO,KAAK;AAAA,EAAS;AAAA,EAOnC,IAAI,SAAS;AAAE,WAAO,KAAK;AAAA,EAAU;AAAA,EAOrC,IAAI,YACJ;AACG,WAAO,KAAK,mBAAmB;AAAA,EACjC;AAAA,EAOD,IAAI,aAAa;AAAE,WAAO,KAAK;AAAA,EAAc;AAAA,EAO7C,IAAI,OAAO,QACX;AACG,QAAI,WAAW,UAAU,CAAE,mBAAkB,gBAAgB,CAAC,SAAS,MAAM,GAC7E;AACG,YAAM,IAAI,UAAU,uDAAuD;AAAA,IAC7E;AAED,SAAK,UAAU;AAGf,SAAK,OAAO,OAAO,EAAE,MAAM,eAAgB,CAAA;AAC3C,SAAK,YAAY;AAGjB,QAAI,QAAQ;AAAE,WAAK,IAAI,KAAK,KAAK;AAAA,IAAI;AAAA,EACvC;AAAA,EAOD,IAAI,SAAS;AAAE,WAAO,KAAK,MAAM;AAAA,EAAS;AAAA,EAK1C,IAAI,OAAO;AAAE,WAAO,KAAK,MAAM;AAAA,EAAO;AAAA,EAKtC,IAAI,YAAY;AAAE,WAAO,KAAK,MAAM;AAAA,EAAY;AAAA,EAKhD,IAAI,WAAW;AAAE,WAAO,KAAK,MAAM;AAAA,EAAW;AAAA,EAK9C,IAAI,YAAY;AAAE,WAAO,KAAK,MAAM;AAAA,EAAY;AAAA,EAKhD,IAAI,WAAW;AAAE,WAAO,KAAK,MAAM;AAAA,EAAW;AAAA,EAK9C,IAAI,UAAU;AAAE,WAAO,KAAK,MAAM;AAAA,EAAU;AAAA,EAK5C,IAAI,UAAU;AAAE,WAAO,KAAK,MAAM;AAAA,EAAU;AAAA,EAK5C,IAAI,UAAU;AAAE,WAAO,KAAK,MAAM;AAAA,EAAU;AAAA,EAK5C,IAAI,WAAW;AAAE,WAAO,KAAK,MAAM;AAAA,EAAU;AAAA,EAK7C,IAAI,QAAQ;AAAE,WAAO,KAAK,MAAM;AAAA,EAAQ;AAAA,EAKxC,IAAI,MAAM;AAAE,WAAO,KAAK,MAAM;AAAA,EAAM;AAAA,EAKpC,IAAI,kBAAkB;AAAE,WAAO,KAAK,MAAM;AAAA,EAAkB;AAAA,EAK5D,IAAI,aAAa;AAAE,WAAO,KAAK,MAAM;AAAA,EAAa;AAAA,EAKlD,IAAI,aAAa;AAAE,WAAO,KAAK,MAAM;AAAA,EAAa;AAAA,EAKlD,IAAI,aAAa;AAAE,WAAO,KAAK,MAAM;AAAA,EAAa;AAAA,EAKlD,IAAI,QAAQ;AAAE,WAAO,KAAK,MAAM;AAAA,EAAQ;AAAA,EAKxC,IAAI,SAAS;AAAE,WAAO,KAAK,MAAM;AAAA,EAAS;AAAA,EAK1C,IAAI,OAAO,QACX;AACG,SAAK,QAAQ,OAAO,IAAI,MAAM;AAAA,EAChC;AAAA,EAKD,IAAI,KAAK,MACT;AACG,SAAK,QAAQ,KAAK,IAAI,IAAI;AAAA,EAC5B;AAAA,EAKD,IAAI,UAAU,WACd;AACG,SAAK,QAAQ,UAAU,IAAI,SAAS;AAAA,EACtC;AAAA,EAKD,IAAI,SAAS,UACb;AACG,SAAK,QAAQ,SAAS,IAAI,QAAQ;AAAA,EACpC;AAAA,EAKD,IAAI,UAAU,WACd;AACG,SAAK,QAAQ,UAAU,IAAI,SAAS;AAAA,EACtC;AAAA,EAKD,IAAI,SAAS,UACb;AACG,SAAK,QAAQ,SAAS,IAAI,QAAQ;AAAA,EACpC;AAAA,EAKD,IAAI,QAAQ,SACZ;AACG,SAAK,QAAQ,QAAQ,IAAI,OAAO;AAAA,EAClC;AAAA,EAKD,IAAI,QAAQ,SACZ;AACG,SAAK,QAAQ,QAAQ,IAAI,OAAO;AAAA,EAClC;AAAA,EAKD,IAAI,QAAQ,SACZ;AACG,SAAK,QAAQ,QAAQ,IAAI,OAAO;AAAA,EAClC;AAAA,EAKD,IAAI,SAAS,SACb;AACG,SAAK,QAAQ,QAAQ,IAAI,OAAO;AAAA,EAClC;AAAA,EAKD,IAAI,MAAM,OACV;AACG,SAAK,QAAQ,MAAM,IAAI,KAAK;AAAA,EAC9B;AAAA,EAKD,IAAI,IAAI,KACR;AACG,SAAK,QAAQ,IAAI,IAAI,GAAG;AAAA,EAC1B;AAAA,EAKD,IAAI,gBAAgB,iBACpB;AACG,QAAIA,iBAA2B,SAAS,eAAe,GAAG;AAAE,WAAK,QAAQ,gBAAgB,IAAI,eAAe;AAAA,IAAI;AAAA,EAClH;AAAA,EAKD,IAAI,WAAW,YACf;AACG,SAAK,QAAQ,WAAW,IAAI,UAAU;AAAA,EACxC;AAAA,EAKD,IAAI,WAAW,YACf;AACG,SAAK,QAAQ,WAAW,IAAI,UAAU;AAAA,EACxC;AAAA,EAKD,IAAI,WAAW,YACf;AACG,SAAK,QAAQ,WAAW,IAAI,UAAU;AAAA,EACxC;AAAA,EAKD,IAAI,MAAM,OACV;AACG,SAAK,QAAQ,MAAM,IAAI,KAAK;AAAA,EAC9B;AAAA,EAKD,IAAI,OAAO,QACX;AACG,SAAK,QAAQ,OAAO,IAAI,MAAM;AAAA,EAChC;AAAA,EAYD,IAAI,WAAW,CAAA,GAAI,SACnB;AACG,UAAM,OAAO,SAAS;AACtB,UAAM,cAAc,SAAS;AAC7B,UAAM,UAAU,SAAS,WAAW;AAEpC,QAAI,WAAW,IAAI,GACnB;AAEG,UAAI,SACJ;AACG,mBAAW,OAAO,MAAM;AAAE,mBAAS,OAAO,KAAK,QAAQC,gBAA0B;AAAA,QAAO;AAAA,MAC1F,OAED;AACG,mBAAW,OAAO,MAAM;AAAE,mBAAS,OAAO,KAAK;AAAA,QAAO;AAAA,MACxD;AAGD,UAAI,WAAW,WAAW,GAC1B;AACG,mBAAW,OAAO,aAAa;AAAE,iBAAO,SAAS;AAAA,QAAO;AAAA,MAC1D;AAED,aAAO;AAAA,IACT,OAED;AACG,YAAM,OAAO,OAAO,OAAO,UAAU,KAAK,KAAK;AAG/C,UAAI,WAAW,WAAW,GAC1B;AACG,mBAAW,OAAO,aAAa;AAAE,iBAAO,KAAK;AAAA,QAAO;AAAA,MACtD;AAGD,UAAI,SAAS;AAAEC,2BAA6B,IAAI;AAAA,MAAI;AAEpD,aAAO;AAAA,IACT;AAAA,EACH;AAAA,EAKD,SACA;AACG,WAAO,OAAO,OAAO,CAAE,GAAE,KAAK,KAAK;AAAA,EACrC;AAAA,EAyBD,IAAI,WAAW,CAAE,GACjB;AACG,QAAI,OAAO,aAAa,UAAU;AAAE,YAAM,IAAI,UAAU,oDAAoD;AAAA,IAAI;AAEhH,UAAM,SAAS,KAAK;AAGpB,QAAI,WAAW,UAAU,OAAO,QAAQ,SAAS,iBAAiB,aAAa,CAAC,QAAQ,SAAS,cACjG;AACG,aAAO;AAAA,IACT;AAID,UAAM,yBAAyB,SAAS,2BAA2B;AAEnE,UAAM,OAAO,KAAK;AAClB,UAAM,aAAa,KAAK;AAGxB,UAAM,WAAW,kBAAkB,cAAc,SAAS,QAAQ;AAClE,UAAM,KAAK,oBAAoB,eAAe,SAAS,cAAc,WAAW;AAEhF,UAAM,YAAY,KAAK;AACvB,UAAM,aAAa,KAAK;AAExB,QAAI,IACJ;AAEG,UAAI,CAAC,WAAW,QAAQ,EAAE,GAC1B;AACG,mBAAW,OAAO,EAAE;AAGpB,YAAI,CAAC,WAAW,eAChB;AACG,aAAG,MAAM,aAAa,KAAK,SAAS,QAAQ,cAAc;AAAA,QAC5D;AAGD,kBAAU,IAAI,IAAI;AAClB,aAAK,mBAAmB,SAAS;AAAA,MACnC;AAGD,sBAAgB,UAAU,IAAI;AAE9B,iBAAW,KAAK,gBAAgB,UAAU,QAAQ,IAAI,UAAU;AAGhE,UAAI,aAAa,MAAM;AAAE,eAAO;AAAA,MAAO;AAAA,IACzC;AAED,QAAI,OAAO,SAAS,SAAS,IAAI,GACjC;AACG,eAAS,OAAO,KAAK,MAAM,SAAS,IAAI;AAExC,UAAI,KAAK,SAAS,SAAS,MAAM;AAAE,aAAK,OAAO,SAAS;AAAM,kBAAU,OAAO;AAAA,MAAO;AAAA,IACxF;AAED,QAAI,OAAO,SAAS,SAAS,GAAG,GAChC;AACG,eAAS,MAAM,KAAK,MAAM,SAAS,GAAG;AAEtC,UAAI,KAAK,QAAQ,SAAS,KAAK;AAAE,aAAK,MAAM,SAAS;AAAK,kBAAU,MAAM;AAAA,MAAO;AAAA,IACnF;AAED,QAAI,OAAO,SAAS,SAAS,SAAS,KAAK,SAAS,cAAc,MAClE;AACG,eAAS,YAAY,OAAO,SAAS,cAAc,WAAW,KAAK,MAAM,SAAS,SAAS,IAAI;AAE/F,UAAI,KAAK,cAAc,SAAS,WAAW;AAAE,aAAK,YAAY,SAAS;AAAW,kBAAU,YAAY;AAAA,MAAO;AAAA,IACjH;AAED,QAAI,OAAO,SAAS,SAAS,QAAQ,KAAK,SAAS,aAAa,MAChE;AACG,eAAS,WAAW,OAAO,SAAS,aAAa,WAAW,KAAK,MAAM,SAAS,QAAQ,IAAI;AAE5F,UAAI,KAAK,aAAa,SAAS,UAAU;AAAE,aAAK,WAAW,SAAS;AAAU,kBAAU,WAAW;AAAA,MAAO;AAAA,IAC5G;AAED,QAAI,OAAO,SAAS,SAAS,SAAS,KAAK,SAAS,cAAc,MAClE;AACG,eAAS,YAAY,OAAO,SAAS,cAAc,WAAW,KAAK,MAAM,SAAS,SAAS,IAAI;AAE/F,UAAI,KAAK,cAAc,SAAS,WAAW;AAAE,aAAK,YAAY,SAAS;AAAW,kBAAU,YAAY;AAAA,MAAO;AAAA,IACjH;AAED,QAAI,OAAO,SAAS,SAAS,QAAQ,KAAK,SAAS,aAAa,MAChE;AACG,eAAS,WAAW,OAAO,SAAS,aAAa,WAAW,KAAK,MAAM,SAAS,QAAQ,IAAI;AAE5F,UAAI,KAAK,aAAa,SAAS,UAAU;AAAE,aAAK,WAAW,SAAS;AAAU,kBAAU,WAAW;AAAA,MAAO;AAAA,IAC5G;AAED,QAAI,OAAO,SAAS,SAAS,OAAO,KAAK,SAAS,YAAY,MAC9D;AACG,UAAI,KAAK,YAAY,SAAS,SAC9B;AACG,aAAK,UAAU,WAAW,UAAU,SAAS;AAC7C,kBAAU,YAAY;AAAA,MACxB;AAAA,IACH;AAED,QAAI,OAAO,SAAS,SAAS,OAAO,KAAK,SAAS,YAAY,MAC9D;AACG,UAAI,KAAK,YAAY,SAAS,SAC9B;AACG,aAAK,UAAU,WAAW,UAAU,SAAS;AAC7C,kBAAU,YAAY;AAAA,MACxB;AAAA,IACH;AAED,QAAI,OAAO,SAAS,SAAS,OAAO,KAAK,SAAS,YAAY,MAC9D;AACG,UAAI,KAAK,YAAY,SAAS,SAC9B;AACG,aAAK,UAAU,WAAW,UAAU,SAAS;AAC7C,kBAAU,YAAY;AAAA,MACxB;AAAA,IACH;AAED,QAAI,OAAO,SAAS,SAAS,KAAK,KAAK,SAAS,UAAU,MAC1D;AACG,eAAS,QAAQ,OAAO,SAAS,UAAU,WAAW,KAAK,IAAI,GAAG,KAAK,IAAI,SAAS,OAAO,GAAI,CAAC,IAAI;AAEpG,UAAI,KAAK,UAAU,SAAS,OAC5B;AACG,aAAK,QAAQ,WAAW,QAAQ,SAAS;AACzC,kBAAU,YAAY;AAAA,MACxB;AAAA,IACH;AAED,QAAK,OAAO,SAAS,oBAAoB,YAAYF,iBAA2B,SAC/E,SAAS,eAAe,KAAM,SAAS,oBAAoB,MAC5D;AACG,UAAI,KAAK,oBAAoB,SAAS,iBACtC;AACG,aAAK,kBAAkB,SAAS;AAChC,kBAAU,kBAAkB;AAAA,MAC9B;AAAA,IACH;AAED,QAAI,OAAO,SAAS,SAAS,UAAU,KAAK,SAAS,eAAe,MACpE;AACG,UAAI,KAAK,eAAe,SAAS,YACjC;AACG,aAAK,aAAa,WAAW,aAAa,SAAS;AACnD,kBAAU,YAAY;AAAA,MACxB;AAAA,IACH;AAED,QAAI,OAAO,SAAS,SAAS,UAAU,KAAK,SAAS,eAAe,MACpE;AACG,UAAI,KAAK,eAAe,SAAS,YACjC;AACG,aAAK,aAAa,WAAW,aAAa,SAAS;AACnD,kBAAU,YAAY;AAAA,MACxB;AAAA,IACH;AAED,QAAI,OAAO,SAAS,SAAS,UAAU,KAAK,SAAS,eAAe,MACpE;AACG,UAAI,KAAK,eAAe,SAAS,YACjC;AACG,aAAK,aAAa,WAAW,aAAa,SAAS;AACnD,kBAAU,YAAY;AAAA,MACxB;AAAA,IACH;AAED,QAAI,OAAO,SAAS,SAAS,MAAM,GACnC;AACG,eAAS,SAAS,KAAK,MAAM,SAAS,MAAM;AAE5C,UAAI,KAAK,WAAW,SAAS,QAAQ;AAAE,aAAK,SAAS,SAAS;AAAQ,kBAAU,SAAS;AAAA,MAAO;AAAA,IAClG;AAED,QAAI,OAAO,SAAS,SAAS,KAAK,KAAK,SAAS,UAAU,UAAU,SAAS,UAAU,aACtF,SAAS,UAAU,MACpB;AACG,eAAS,QAAQ,OAAO,SAAS,UAAU,WAAW,KAAK,MAAM,SAAS,KAAK,IAAI,SAAS;AAE5F,UAAI,KAAK,UAAU,SAAS,OAAO;AAAE,aAAK,QAAQ,SAAS;AAAO,kBAAU,QAAQ;AAAA,MAAO;AAAA,IAC7F;AAED,QAAI,OAAO,SAAS,SAAS,MAAM,KAAK,SAAS,WAAW,UAAU,SAAS,WAAW,aACzF,SAAS,WAAW,MACrB;AACG,eAAS,SAAS,OAAO,SAAS,WAAW,WAAW,KAAK,MAAM,SAAS,MAAM,IAAI,SAAS;AAE/F,UAAI,KAAK,WAAW,SAAS,QAAQ;AAAE,aAAK,SAAS,SAAS;AAAQ,kBAAU,SAAS;AAAA,MAAO;AAAA,IAClG;AAED,QAAI,IACJ;AACG,YAAM,cAAc,KAAK,OAAO,WAAU;AAG1C,UAAI,OAAO,gBAAgB,UAC3B;AACG,aAAK,OAAO,KAAK,EAAE,MAAM,gBAAgB,GAAG,OAAO,OAAO,CAAA,GAAI,IAAI,EAAG,CAAA;AAAA,MACvE;AAID,UAAI,wBACJ;AACG,6BAAqB,UAAU,IAAI,KAAK,kBAAkB;AAC1D,aAAK,wBAAwB,QAAQ,QAAQ,YAAY,IAAG,CAAE;AAAA,MAChE,WAEQ,CAAC,KAAK,mBAAmB,QAClC;AACG,aAAK,wBAAwB,qBAAqB,IAAI,IAAI,KAAK,kBAAkB;AAAA,MACnF;AAAA,IACH,OAED;AAEG,2BAAqB,kBAAkB,KAAK,kBAAkB;AAAA,IAChE;AAED,WAAO;AAAA,EACT;AAAA,EASD,UAAU,SACV;AACG,SAAK,eAAe,KAAK,OAAO;AAEhC,YAAQ,OAAO,OAAO,CAAE,GAAE,KAAK,KAAK,CAAC;AAGrC,WAAO,MACP;AACG,YAAM,QAAQ,KAAK,eAAe,UAAU,CAAC,QAAQ,QAAQ,OAAO;AACpE,UAAI,SAAS,GAAG;AAAE,aAAK,eAAe,OAAO,OAAO,CAAC;AAAA,MAAI;AAAA,IAClE;AAAA,EACI;AAAA,EAmDD,gBAAgB;AAAA,IAEb;AAAA,IAAM;AAAA,IAAK;AAAA,IAAU;AAAA,IAAW;AAAA,IAAU;AAAA,IAAW;AAAA,IAAO;AAAA,IAAQ;AAAA,IAAS;AAAA,IAAS;AAAA,IAAS;AAAA,IAC9F;AAAA,IAAiB;AAAA,IAAY;AAAA,IAAY;AAAA,IAAY;AAAA,IAGtD;AAAA,OAEG;AAAA,MACF,CAAE,GAAE,QAAQ,IAAI,YACpB;AACG,QAAI,kBAAkB,cAAc,KAAK,KAAK,KAAK;AAGnD,QAAI,GAAG,MAAM,UAAU,MAAM,UAAU,QACvC;AACG,UAAI,UAAU,UAAW,gBAAgB,UAAU,UAAU,UAAU,MACvE;AACG,wBAAgB,QAAQ;AACxB,gBAAQ,WAAW;AAAA,MACrB,WACQ,UAAU,aAAc,gBAAgB,UAAU,aAAa,UAAU,MAClF;AACG,wBAAgB,QAAQ;AACxB,gBAAQ,WAAW;AAAA,MACrB,OAED;AACG,cAAM,WAAW,OAAO,SAAS,KAAK,IAAI,QAAQ,gBAAgB;AAClE,wBAAgB,QAAQ,QAAQ,OAAO,SAAS,QAAQ,IAAI,KAAK,MAAM,QAAQ,IAAI,WAAW;AAAA,MAChG;AAAA,IACH,OAED;AACG,cAAQ,OAAO,SAAS,gBAAgB,KAAK,IAAI,gBAAgB,QAAQ,WAAW;AAAA,IACtF;AAGD,QAAI,GAAG,MAAM,WAAW,MAAM,WAAW,QACzC;AACG,UAAI,WAAW,UAAW,gBAAgB,WAAW,UAAU,WAAW,MAC1E;AACG,wBAAgB,SAAS;AACzB,iBAAS,WAAW;AAAA,MACtB,WACQ,WAAW,aAAc,gBAAgB,WAAW,aAAa,WAAW,MACrF;AACG,wBAAgB,SAAS;AACzB,iBAAS,WAAW;AAAA,MACtB,OAED;AACG,cAAM,YAAY,OAAO,SAAS,MAAM,IAAI,SAAS,gBAAgB;AACrE,wBAAgB,SAAS,SAAS,OAAO,SAAS,SAAS,IAAI,KAAK,MAAM,SAAS,IAClF,WAAW;AAAA,MACd;AAAA,IACH,OAED;AACG,eAAS,OAAO,SAAS,gBAAgB,MAAM,IAAI,gBAAgB,SAAS,WAAW;AAAA,IACzF;AAGD,QAAI,OAAO,SAAS,IAAI,GACxB;AACG,sBAAgB,OAAO;AAAA,IACzB,WACQ,CAAC,OAAO,SAAS,gBAAgB,IAAI,GAC9C;AAEG,sBAAgB,OAAO,OAAO,KAAK,SAAS,eAAe,YAAY,aACtE,KAAK,SAAS,cAAc,QAAQ,KAAK,IAAI;AAAA,IAChD;AAGD,QAAI,OAAO,SAAS,GAAG,GACvB;AACG,sBAAgB,MAAM;AAAA,IACxB,WACQ,CAAC,OAAO,SAAS,gBAAgB,GAAG,GAC7C;AAEG,sBAAgB,MAAM,OAAO,KAAK,SAAS,eAAe,WAAW,aACpE,KAAK,SAAS,cAAc,OAAO,MAAM,IAAI;AAAA,IAChD;AAED,QAAI,OAAO,SAAS,SAAS,KAAK,cAAc,MAChD;AACG,sBAAgB,YAAY,OAAO,SAAS,SAAS,IAAI,KAAK,MAAM,SAAS,IAAI;AAAA,IACnF;AAED,QAAI,OAAO,SAAS,QAAQ,KAAK,aAAa,MAC9C;AACG,sBAAgB,WAAW,OAAO,SAAS,QAAQ,IAAI,KAAK,MAAM,QAAQ,IAAI;AAAA,IAChF;AAED,QAAI,OAAO,SAAS,SAAS,KAAK,cAAc,MAChD;AACG,sBAAgB,YAAY,OAAO,SAAS,SAAS,IAAI,KAAK,MAAM,SAAS,IAAI;AAAA,IACnF;AAED,QAAI,OAAO,SAAS,QAAQ,KAAK,aAAa,MAC9C;AACG,sBAAgB,WAAW,OAAO,SAAS,QAAQ,IAAI,KAAK,MAAM,QAAQ,IAAI;AAAA,IAChF;AAGD,QAAI,OAAO,SAAS,OAAO,KAAK,YAAY,MAAM;AAAE,sBAAgB,UAAU;AAAA,IAAU;AACxF,QAAI,OAAO,SAAS,OAAO,KAAK,YAAY,MAAM;AAAE,sBAAgB,UAAU;AAAA,IAAU;AAIxF,QAAI,YAAY,gBAAgB,WAAY,QAAO,SAAS,OAAO,KAAK,YAAY,OACpF;AACG,sBAAgB,UAAU;AAAA,IAC5B,WACQ,aAAa,gBAAgB,WAAY,QAAO,SAAS,QAAQ,KAAK,aAAa,OAC5F;AACG,sBAAgB,UAAU;AAAA,IAC5B;AAED,QAAI,OAAO,SAAS,UAAU,KAAK,eAAe,MAAM;AAAE,sBAAgB,aAAa;AAAA,IAAa;AACpG,QAAI,OAAO,SAAS,UAAU,KAAK,eAAe,MAAM;AAAE,sBAAgB,aAAa;AAAA,IAAa;AACpG,QAAI,OAAO,SAAS,UAAU,KAAK,eAAe,MAAM;AAAE,sBAAgB,aAAa;AAAA,IAAa;AAEpG,QAAI,OAAO,SAAS,KAAK,KAAK,UAAU,MACxC;AACG,sBAAgB,QAAQ,OAAO,UAAU,WAAW,KAAK,IAAI,GAAG,KAAK,IAAI,OAAO,GAAI,CAAC,IAAI;AAAA,IAC3F;AAED,QAAI,OAAO,oBAAoB,YAAY,oBAAoB,MAC/D;AACG,sBAAgB,kBAAkBA,iBAA2B,SAAS,eAAe,IAAI,kBACxF;AAAA,IACH;AAED,QAAI,OAAO,SAAS,MAAM,KAAK,WAAW,MAC1C;AACG,sBAAgB,SAAS,OAAO,WAAW,WAAW,KAAK,MAAM,MAAM,IAAI;AAAA,IAC7E;AAED,UAAM,gBAAgB,KAAK;AAG3B,QAAI,cAAc,QAClB;AACG,wBAAkB,SAAS;AAE3B,wBAAkB,KAAK;AAEvB,wBAAkB,WAAW,WAAW;AAExC,wBAAkB,aAAa,KAAK;AAEpC,wBAAkB,SAAS;AAE3B,wBAAkB,QAAQ;AAE1B,wBAAkB,aAAa,WAAW;AAE1C,wBAAkB,YAAY,WAAW;AAEzC,wBAAkB,YAAY,WAAW,aAAa,gBAAgB;AAEtE,wBAAkB,WAAW,WAAW,YAAY,gBAAgB;AAGpE,YAAM,cAAc,QAAQ,UAAU,aAAa;AAGnD,wBAAkB,YAAY,cAAc,gBAAgB,aAAa,IACxE,WAAW,aAAc,iBAAgB,aAAa;AAEvD,wBAAkB,WAAW,cAAc,gBAAgB,YAAY,IACtE,WAAW,YAAa,iBAAgB,YAAY;AAErD,eAAS,OAAO,GAAG,OAAO,cAAc,QAAQ,QAChD;AACG,0BAAkB,WAAW;AAC7B,0BAAkB,OAAO;AACzB,0BAAkB,cAAc,MAAM,UAAU,iBAAiB;AAEjE,YAAI,oBAAoB,MAAM;AAAE,iBAAO;AAAA,QAAO;AAAA,MAChD;AAAA,IACH;AAGD,WAAO;AAAA,EACT;AACJ;AA9uCa;AAgvCb,MAAM,gBAAgB,IAAI;AAK1B,MAAM,oBAAoB;AAAA,EACvB,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,IAAI;AAAA,EACJ,UAAU;AAAA,EACV,YAAY;AAAA,EACZ,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,WAAW;AAAA,EACX,UAAU;AAAA,EACV,WAAW;AAAA,EACX,UAAU;AAAA,EACV,MAAM;AACT;AAEA,OAAO,KAAK,iBAAiB;AC/xCtB,MAAM,iBACb;AAAA,EAEG;AAAA,EAGA,aAAa,oBAAI;EAKjB,YAAY,aACZ;AACG,SAAK,eAAe;AAAA,EACtB;AAAA,EASD,IAAI,QAAQ,CAAE,GACd;AACG,WAAO,OAAO,OAAO,OAAO;AAAA,MACzB,UAAU,KAAK,cAAc,UAAU,IAAK;AAAA,MAC5C,iBAAiB,KAAK,cAAc,UAAU,MAAM,IAAI,EAAE,MAAM,oBAAoB;AAAA,MACpF,SAAS,OAAO,OAAO,CAAE,GAAE,KAAK,cAAc,OAAO;AAAA,MACrD,IAAI,EAAE,WAAW,KAAK,cAAc,UAAU,UAAW;AAAA,IAClE,CAAO;AAAA,EACH;AAAA,EASD,QAAQ,EAAE,QACV;AACG,QAAI,OAAO,SAAS,UACpB;AACG,YAAM,IAAI,UAAU,2DAA2D;AAAA,IACjF;AAED,WAAO,KAAK,WAAW,IAAI,IAAI;AAAA,EACjC;AAAA,EAWD,OAAO,EAAE,QACT;AACG,QAAI,OAAO,SAAS,UAAU;AAAE,YAAM,IAAI,UAAU,oDAAoD;AAAA,IAAI;AAE5G,UAAM,OAAO,KAAK,WAAW,IAAI,IAAI;AACrC,SAAK,WAAW,OAAO,IAAI;AAE3B,WAAO;AAAA,EACT;AAAA,EA2BD,QAAQ;AAAA,IAAE;AAAA,IAAM,SAAS;AAAA,IAAO,QAAQ;AAAA,IAAO,YAAY;AAAA,IAAO,WAAW;AAAA,IAAK,OAAOL;AAAAA,IACxF,cAAcD;AAAAA,KACf;AACG,QAAI,OAAO,SAAS,UACpB;AACG,YAAM,IAAI,UAAU,2DAA2D;AAAA,IACjF;AAED,UAAM,YAAY,KAAK,WAAW,IAAI,IAAI;AAE1C,QAAI,WACJ;AACG,UAAI,QAAQ;AAAE,aAAK,WAAW,OAAO,IAAI;AAAA,MAAI;AAE7C,UAAI,OACJ;AACG,eAAO,KAAK,IAAI,WAAW,EAAE,OAAO,WAAW,UAAU,MAAM,YAAa,CAAA,EAAE,KAAK,MAAM,SAAS;AAAA,MACpG,OAED;AACG,aAAK,IAAI,WAAW,EAAE,OAAO,WAAW,UAAU,MAAM,YAAW,CAAE;AAAA,MACvE;AAAA,IACH;AAED,WAAO;AAAA,EACT;AAAA,EAaD,KAAK,EAAE,SAAS,SAChB;AACG,QAAI,OAAO,SAAS,UAAU;AAAE,YAAM,IAAI,UAAU,wDAAwD;AAAA,IAAI;AAEhH,UAAM,OAAO,KAAK,IAAI,KAAK;AAE3B,SAAK,WAAW,IAAI,MAAM,IAAI;AAE9B,WAAO;AAAA,EACT;AAAA,EA+BD,IAAI,MAAM,EAAE,QAAQ,OAAO,YAAY,OAAO,WAAW,KAAK,OAAOC,UAAQ,cAAcD,WAAS,CAAE,GACtG;AACG,QAAI,CAAC,SAAS,IAAI,GAClB;AACG,YAAM,IAAI,UAAU,4DAA4D;AAAA,IAClF;AAED,UAAM,cAAc,KAAK;AAEzB,QAAI,CAAC,SAAS,MAAM,QAAQ,GAC5B;AACG,cAAQ,KAAK,iEAAiE;AAC9E,aAAO;AAAA,IACT;AAID,UAAM,WAAW,YAAY;AAE7B,QAAI,aAAa,CAAC,UAClB;AACG,cAAQ,KAAK,oFAAoF;AACjG,aAAO;AAAA,IACT;AAGD,QAAI,WACJ;AAEG,UAAI,KAAK,SAAS,oBAAoB,YAAY,SAAS,iBAC3D;AACG,oBAAY,SAAS,kBAAkB,KAAK,SAAS;AAAA,MACvD;AAED,UAAI,SAAS,MAAM,EAAE,GACrB;AACG,cAAM,YAAY,OAAO,KAAK,IAAI,cAAc,YAAY,KAAK,GAAG,YAAY;AAEhF,YAAI,aAAa,UAAU,aAAa,CAAC,WACzC;AACG,sBAAY,SAAS,EAAE,SAAS,OAAO,UAAU,EAAC,CAAE;AAAA,QACtD;AAAA,MACH;AAED,YAAM,WAAU,YAAY,SAAS,QAAQ,GAAG,KAAK,UACpD,EAAE,UAAU,MAAM,YAAW,CAAE,EAAE,SAAS,KAAK,CAAC,cACjD;AACG,YAAI,WAAW;AAAE,iBAAO;AAAA,QAAc;AAGtC,YAAI,SAAS,MAAM,OAAO,GAC1B;AACG,uBAAa,SAAS,aAAa,KAAK,OAAO;AAAA,QACjD;AAED,YAAI,SAAS,MAAM,EAAE,GACrB;AACG,gBAAM,YAAY,OAAO,KAAK,IAAI,cAAc,YAAY,KAAK,GAAG,YAAY;AAIhF,cAAI,CAAC,aAAa,UAAU,aAAa,WACzC;AACG,wBAAY,SAAS,EAAE,SAAS,OAAO,UAAU,EAAC,CAAE;AAAA,UACtD;AAAA,QACH;AAED,YAAI,SAAS,MAAM,eAAe,GAClC;AACG,sBAAY,SAAS,MAAM,IAAI,EAAE,MAAM,oBAAoB,GAAG,KAAK,gBAAe,CAAE;AAAA,QACtF;AAED,eAAO;AAAA,MACnB,CAAU;AAGD,UAAI,OAAO;AAAE,eAAO;AAAA,MAAU;AAAA,IAChC,OAED;AACG,UAAI,UACJ;AAEG,YAAI,SAAS,MAAM,OAAO,GAC1B;AACG,uBAAa,SAAS,aAAa,KAAK,OAAO;AAAA,QACjD;AAED,YAAI,SAAS,MAAM,EAAE,GACrB;AACG,gBAAM,YAAY,OAAO,KAAK,IAAI,cAAc,YAAY,KAAK,GAAG,YAAY;AAIhF,cAAI,aAAa,UAAU,aAAa,CAAC,WACzC;AACG,wBAAY,SAAS,EAAE,SAAS,OAAO,UAAU,EAAC,CAAE;AAAA,UACtD,WACQ,CAAC,aAAa,UAAU,aAAa,WAC9C;AACG,wBAAY,SAAS,EAAE,SAAS,OAAO,SAAU,CAAA;AAAA,UACnD;AAAA,QACH;AAED,YAAI,SAAS,MAAM,eAAe,GAClC;AACG,sBAAY,SAAS,MAAM,IAAI,EAAE,MAAM,oBAAoB,GAAG,KAAK,gBAAe,CAAE;AAAA,QACtF;AAGD,oBAAY,SAAS,IAAI,KAAK,QAAQ;AAAA,MACxC,OAED;AAKG,YAAI,eAAe,KAAK;AAExB,YAAI,SAAS,KAAK,eAAe,GACjC;AAEG,yBAAe,KAAK;AAKpB,uBAAa,OAAO,KAAK,SAAS;AAClC,uBAAa,MAAM,KAAK,SAAS;AAAA,QACnC;AAED,oBAAY,SAAS,IAAI,YAAY;AAAA,MACvC;AAAA,IACH;AAED,WAAO;AAAA,EACT;AACJ;AAtTa;ACAN,MAAM,cACb;AAAA,EAIG;AAAA,EAKA;AAAA,EASA,YAAY,wBAAwB,YACpC;AACG,SAAK,0BAA0B;AAC/B,SAAK,cAAc;AAAA,EACrB;AAAA,EAOD,IAAI,mBAAmB;AAAE,WAAO,KAAK,wBAAwB;AAAA,EAAK;AAAA,EASlE,UAAU,OACV;AACG,UAAM,OAAO,KAAK,YAAY;AAC9B,WAAO,OAAO,SAAS,WAAW,MAAM,YAAY;AAAA,EACtD;AAAA,EAQD,CAAC,mBACD;AACG,aAAS,OAAO,GAAG,OAAO,KAAK,YAAY,QAAQ,QACnD;AACG,YAAM,CAAC,MAAM,KAAK,YAAY,MAAM,SAAS;AAAA,IAC/C;AAAA,EACH;AAAA,EAQD,CAAC,kBACD;AACG,aAAS,OAAO,GAAG,OAAO,KAAK,YAAY,QAAQ,QACnD;AACG,YAAM,KAAK,YAAY,MAAM;AAAA,IAC/B;AAAA,EACH;AAAA,EASD,KAAK,OACL;AACG,WAAO,KAAK,YAAY;AAAA,EAC1B;AAAA,EASD,gBAAgB,WAChB;AACG,eAAW,QAAQ,KAAK,aACxB;AACG,UAAI,KAAK,cAAc,WAAW;AAAE,eAAO;AAAA,MAAO;AAAA,IACpD;AAED,WAAO;AAAA,EACT;AAAA,EAOD,cACA;AACG,WAAO,KAAK,YAAY;EAC1B;AAAA,EAOD,aACA;AACG,WAAO,KAAK,YAAY;EAC1B;AAAA,EAOD,IAAI,SACJ;AACG,WAAO,KAAK,YAAY;AAAA,EAC1B;AACJ;AAnIa;ACeN,0BAA0B,EAAE,KAAK,UAAU,QAAQ,sBAAsB,CAAE,GAClF;AACG,QAAM,gBAAgB,OAAO,OAAO,YAAY,WAAW,OAAO,UAAU;AAE5E,MAAI;AAGJ,MAAI,OAAO,kBAAkB,aAC7B;AACG,aAAS,OAAO;AAAA,EAClB,WAEQ,oBAAoB,eAAe,OAAO,OAAO,WAAW,UACrE;AACG,aAAS,SAAS,cAAc,OAAO,MAAM;AAAA,EAC/C,OAED;AACG,aAAS,SAAS;EACpB;AAED,MAAI,WAAW,QACf;AACG,YAAQ,IACP,qEAAqE,OAAO;AAAA,GAC5E,6BAA6B,MAAM;AAEpC,UAAM,IAAI,MAAK;AAAA,EACjB;AAED,QAAM,qBAAqB,OAAO;AAElC,QAAM,eAAe,kBAAkB,EAAE,GAAG,QAAQ,OAAM,GAAI,GAAG;AAEjE,QAAM,kBAAkB,aAAa,QAAQ,IAAI,UAAU;AAG3D,kBAAgB,cAAc;AAC9B,kBAAgB,oBAAoB;AAEpC,MAAI;AAGJ,MAAI,OAAO,IAAI,cAAc,YAAY,OAAO,IAAI,UAAU,gBAAgB,YAC9E;AACG,eAAW,IAAI,UAAU;AACzB,oBAAgB,WAAW;AAAA,EAC7B;AAMD,QAAM,YAAY,IAAI,mBAAmB,YAAY;AAGrD,eAAa,WAAW;AAKxB,MAAI;AAGJ,MAAI,mBAAmB,SAAS,GAChC;AACG,eAAU,UAAU;AAAA,EACtB;AAID,MAAI,kBAAkB,oBAAoB,OAAO,mBACjD;AACG,QAAI,aAAY,QAAQ;AAAE,iBAAU,OAAO;AAAA,IAAoB;AAC/D,aAAS,OAAO,MAAM;AAAA,EACxB,WACQ,OAAO,kBAAkB,eAAe,aAAY,QAC7D;AACG,QAAI,OAAO,kBAAkB,eAAe,OAAO,cAAc,oBAAoB,UACrF;AACG,cAAQ,IACP;AAAA;AAAA;AAAA;AAAA;AAAA,GAGyB,6BAA6B,MAAM;AAE7D,YAAM,IAAI,MAAK;AAAA,IACjB;AAGD,eAAU,OAAO,cAAc,cAAc,eAAe;AAE5D,QAAI,aAAY,QAAQ,aAAY,QACpC;AACG,cAAQ,IACP,gFACC,cAAc;AAAA,GACf,6BAA6B,MAAM;AAEpC,YAAM,IAAI,MAAK;AAAA,IACjB;AAAA,EACH;AAGD,QAAM,aAAa,CAAE,QAAO,kBAAkB;AAE9C,SAAO,EAAE,QAAQ,cAAc,WAAW,mBAAS,WAAU;AAChE;AA3GgB;ACLT,MAAM,eACb;AAAA,EAIG;AAAA,EAKA,eAAe;AAAA,EAOf;AAAA,EAOA;AAAA,EAOA;AAAA,EAOA;AAAA,EAOA;AAAA,EAOA,oBAAoB,CAAA;AAAA,EAKpB,YAAY,aACZ;AACG,SAAK,eAAe;AAAA,EACtB;AAAA,EAQD,aACA;AACG,QAAI,KAAK,cAAc;AAAE;AAAA,IAAS;AAElC,SAAK,eAAe;AAEpB,SAAK,kBAAiB;AAEtB,WAAO;AAAA,MACJ,kBAAkB,KAAK;AAAA,MACvB,iBAAiB,KAAK;AAAA,MACtB,WAAW,KAAK,iBAAiB,KAAK,IAAI;AAAA,MAC1C,aAAa,KAAK,mBAAmB,KAAK,IAAI;AAAA,IACvD;AAAA,EACI;AAAA,EASD,IAAI,WAAW;AAAE,WAAO,KAAK,aAAa;AAAA,EAAW;AAAA,EAOrD,IAAI,YAAY;AAAE,WAAO,KAAK,aAAa;AAAA,EAAY;AAAA,EAOvD,IAAI,WAAW;AAAE,WAAO,KAAK,aAAa;AAAA,EAAW;AAAA,EASrD,IAAI,YAAY;AAAE,WAAO,KAAK,cAAc,SAAS;AAAA,EAAY;AAAA,EAOjE,IAAI,sBAAsB;AAAE,WAAO,KAAK,cAAc,SAAS;AAAA,EAAsB;AAAA,EAOrF,IAAI,sBAAsB;AAAE,WAAO,KAAK,cAAc,SAAS;AAAA,EAAsB;AAAA,EAOrF,IAAI,yBAAyB;AAAE,WAAO,KAAK,cAAc,SAAS;AAAA,EAAyB;AAAA,EAO3F,IAAI,cAAc;AAAE,WAAO,KAAK,cAAc,SAAS;AAAA,EAAc;AAAA,EAKrE,IAAI,SAAS;AAAE,WAAO,KAAK,aAAa;AAAA,EAAS;AAAA,EAOjD,IAAI,YAAY;AAAE,WAAO,KAAK,cAAc,SAAS;AAAA,EAAY;AAAA,EAOjE,IAAI,kBAAkB;AAAE,WAAO,KAAK;AAAA,EAAmB;AAAA,EAOvD,IAAI,eAAe;AAAE,WAAO,KAAK;AAAA,EAAgB;AAAA,EAQjD,IAAI,QAAQ;AAAE,WAAO,KAAK,aAAa;AAAA,EAAQ;AAAA,EAO/C,IAAI,UAAU,YACd;AACG,QAAI,OAAO,eAAc,WAAW;AAAE,WAAK,WAAW,aAAa,UAAS;AAAA,IAAI;AAAA,EAClF;AAAA,EAOD,IAAI,oBAAoB,qBACxB;AACG,QAAI,OAAO,wBAAwB,WAAW;AAAE,WAAK,WAAW,uBAAuB,mBAAmB;AAAA,IAAI;AAAA,EAChH;AAAA,EAOD,IAAI,oBAAoB,qBACxB;AACG,QAAI,OAAO,wBAAwB,WAAW;AAAE,WAAK,WAAW,uBAAuB,mBAAmB;AAAA,IAAI;AAAA,EAChH;AAAA,EAOD,IAAI,uBAAuB,wBAC3B;AACG,QAAI,OAAO,2BAA2B,WACtC;AACG,WAAK,WAAW,0BAA0B,sBAAsB;AAAA,IAClE;AAAA,EACH;AAAA,EAOD,IAAI,YAAY,aAChB;AACG,QAAI,OAAO,gBAAgB,WAAW;AAAE,WAAK,WAAW,eAAe,WAAW;AAAA,IAAI;AAAA,EACxF;AAAA,EAQD,IAAI,OAAO,QACX;AACG,QAAI,OAAO,WAAW,WAAW;AAAE,WAAK,WAAW,UAAU,MAAM;AAAA,IAAI;AAAA,EACzE;AAAA,EAOD,IAAI,UAAU,WACd;AACG,QAAI,OAAO,cAAc,WAAW;AAAE,WAAK,WAAW,aAAa,SAAS;AAAA,IAAI;AAAA,EAClF;AAAA,EASD,IAAI,MAAM,OACV;AACG,QAAI,OAAO,UAAU,UACrB;AACG,WAAK,WAAW,SAAS,KAAK;AAAA,IAChC,WACQ,UAAU,UAAU,UAAU,MACvC;AACG,WAAK,WAAW,SAAS,EAAE;AAAA,IAC7B;AAAA,EACH;AAAA,EAeD,WAAW,UAAU,cACrB;AACG,WAAO,WAAW,KAAK,aAAa,SAAS,UAAU,YAAY;AAAA,EACrE;AAAA,EAOD,aAAa,SACb;AACG,SAAK,uBAAuB,CAAC,oBAAoB,UAAU,iBAAiB,OAAO,CAAC;AAAA,EACtF;AAAA,EAgBD,WAAW,UAAU,OACrB;AACG,UAAM,UAAU,QAAQ,KAAK,aAAa,SAAS,UAAU,KAAK;AAGlE,QAAI,SACJ;AACG,WAAK,uBAAuB,MAAM,KAAK,aAAa,OAAO;AAAA,IAC7D;AAAA,EACH;AAAA,EAWD,oBACA;AACG,UAAM,qBAAqB,SAAS,KAAK,aAAa,OAAO;AAG7D,SAAK,yBAAyB,mBAAmB;AAQjD,UAAM,kBAAkB;AAAA,MACrB,WAAW,mBAAmB;AAAA,MAE9B,WAAW,cAAc,oBAAoB,WAAW;AAAA,MACxD,qBAAqB,cAAc,oBAAoB,qBAAqB;AAAA,MAC5E,qBAAqB,cAAc,oBAAoB,qBAAqB;AAAA,MAC5E,wBAAwB,cAAc,oBAAoB,wBAAwB;AAAA,MAClF,aAAa,cAAc,oBAAoB,aAAa;AAAA,MAC5D,QAAQ,cAAc,oBAAoB,QAAQ;AAAA,MAClD,WAAW,cAAc,oBAAoB,WAAW;AAAA,MACxD,OAAO,cAAc,oBAAoB,OAAO;AAAA,IACzD;AAEM,WAAO,OAAO,eAAe;AAE7B,SAAK,mBAAmB;AAExB,SAAK,eAAe;AAAA,MACjB,UAAU;AAAA,MACV,eAAe,CAAE;AAAA,MACjB,WAAW,KAAK,aAAa;AAAA,MAC7B,UAAU;AAAA,IACnB;AAGM,UAAM,oBAAoB,SAAS,KAAK,YAAY;AAGpD,SAAK,sBAAsB,kBAAkB;AAK7C,UAAM,eAAe;AAAA,MAClB,WAAW,kBAAkB;AAAA,MAE7B,UAAU,cAAc,mBAAmB,UAAU;AAAA,MACrD,eAAe,QAAQ,mBAAmB,CAAC,UAAU,QAAQ,IAAI,SAAS,aAAa,CAAC;AAAA,MACxF,WAAW,QAAQ,mBAAmB,CAAC,UAAU,QAAQ,IAAI,SAAS,SAAS,CAAC;AAAA,MAChF,UAAU,cAAc,mBAAmB,UAAU;AAAA,IAC9D;AAEM,WAAO,OAAO,YAAY;AAG1B,SAAK,gBAAgB;AAAA,EACvB;AAAA,EAQD,mBACA;AAIG,SAAK,kBAAkB,KAAK,qBAAqB,KAAK,iBAAiB,qBAAqB,CAAC,UAC7F;AACG,WAAK,oBAAoB,EAAE,qBAAqB,MAAO,CAAA;AAAA,IACzD,CAAA,CAAC;AAGF,SAAK,kBAAkB,KAAK,qBAAqB,KAAK,iBAAiB,qBAAqB,CAAC,UAC7F;AACG,WAAK,oBAAoB,EAAE,qBAAqB,MAAO,CAAA;AAAA,IACzD,CAAA,CAAC;AAGF,SAAK,kBAAkB,KAAK,qBAAqB,KAAK,iBAAiB,QAAQ,CAAC,UAChF;AACG,UAAI,SAAS,KAAK,aAAa,UAC/B;AACG,WAAG,QAAQ,KAAK,aAAa,SAAS,KAAK;AAAA,MAC7C,OAED;AACG,eAAO,GAAG,QAAQ,KAAK,aAAa;AAAA,MACtC;AAAA,IACH,CAAA,CAAC;AAAA,EACJ;AAAA,EAOD,qBACA;AACG,SAAK,kBAAkB,QAAQ,CAAC,gBAAgB,YAAa,CAAA;AAC7D,SAAK,oBAAoB;EAC3B;AAAA,EAiBD,oBAAoB;AAAA,IAAE,sBAAsB,KAAK,aAAa,QAAQ;AAAA,IACrE,sBAAsB,KAAK,aAAa,QAAQ;AAAA,MAAwB,CAAE,GAC3E;AACG,QAAI,UAAU,KAAK,aAAa,kBAAiB;AAGjD,QAAI,OAAO,wBAAwB,aAAa,qBAChD;AACG,gBAAU,QAAQ,OAAO,CAAC,WAAW,OAAO,UAAU,OAAO;AAAA,IAC/D;AAGD,QAAI,OAAO,wBAAwB,aAAa,qBAChD;AACG,iBAAW,UAAU,SAAS;AAAE,eAAO,QAAQ;AAAA,MAAS;AAAA,IAC1D;AAED,SAAK,oBAAoB,CAAC,YAC1B;AACG,cAAQ,gBAAgB;AACxB,aAAO;AAAA,IAChB,CAAO;AAAA,EACH;AACJ;AA/da;ACMN,MAAM,0BAA0B,YACvC;AAAA,EAMG,0BAA0B,CAAC,IAAI;AAAA,EAO/B;AAAA,EAOA,iBAAiB;AAAA,EAOjB,kBAAkB;AAAA,EAOlB,iBAAiB;AAAA,EAOjB,WAAW;AAAA,EAOX;AAAA,EAOA;AAAA,EAOA,cAAc,CAAA;AAAA,EAQd,iBAAiB,IAAI,cAAc,KAAK,yBAAyB,KAAK,WAAW;AAAA,EAOjF;AAAA,EAKA,YAAY,UAAU,CAAE,GACxB;AACG,UAAM,OAAO;AAEb,SAAK,oBAAoB,IAAI,iBAAiB,IAAI;AAGlD,SAAK,YAAY,IAAI,SAAS,MAAM;AAAA,MACjC,GAAG,KAAK;AAAA,MACR,GAAG,KAAK;AAAA,MACR,SAAS,KAAK,QAAQ;AAAA,MACtB,OAAO,KAAK,QAAQ;AAAA,MACpB,WAAW,KAAK,QAAQ;AAAA,IACjC,CAAO;AAGD,WAAO,KAAK;AASZ,WAAO,eAAe,MAAM,YAAY;AAAA,MACrC,KAAK,MAAM,KAAK;AAAA,MAChB,KAAK,CAAC,aAAa;AAAE,YAAI,OAAO,aAAa,UAAU;AAAE,eAAK,UAAU,IAAI,QAAQ;AAAA,QAAE;AAAA,MAAI;AAAA,IACnG,CAAO;AAED,SAAK,YAAY,IAAI,eAAe,IAAI;AAExC,SAAK,UAAU,KAAK,UAAU,WAAU;AAAA,EAC1C;AAAA,EAQD,WAAW,iBACX;AACG,WAAO,UAAU,MAAM,gBAAgB;AAAA,MACpC,uBAAuB;AAAA,MACvB,WAAW;AAAA,MACX,qBAAqB;AAAA,MACrB,qBAAqB;AAAA,MACrB,wBAAwB;AAAA,MACxB,WAAW;AAAA,MACX,UAAU;AAAA,MACV,cAAc;AAAA,MACd,iBAAiB,SAAS,QAAQ;AAAA,MAClC,eAAe;AAAA,MACf,mBAAmB,SAAS,WAAW;AAAA,MACvC,iBAAiB;AAAA,IAC1B,CAAO;AAAA,EACH;AAAA,EAOD,IAAI,iBAAiB;AAAE,WAAO,KAAK;AAAA,EAAkB;AAAA,EAOrD,IAAI,gBAAgB;AAAE,WAAO,KAAK;AAAA,EAAiB;AAAA,EAOnD,IAAI,WAAW;AAAE,WAAO,KAAK;AAAA,EAAY;AAAA,EAOzC,IAAI,QAAQ;AAAE,WAAO,KAAK;AAAA,EAAoB;AAAA,EAO9C,IAAI,SAAS;AAAE,WAAO,KAAK;AAAA,EAAiB;AAAA,EAW5C,uBAAuB,MACvB;AACG,UAAM,uBAAuB,OAAO,KAAK,QAAQ,aAAa,WAAW,OAAO,CAAC,KAAK,cAAc,CAAC;AAAA,EACvG;AAAA,EAWD,WAAW,EAAE,QAAQ,UAAU,CAAE,GACjC;AACG,QAAI,SAAS,KAAK,QAAQ;AAAE,YAAM,WAAU;AAAA,IAAK;AAIjD,QAAI,SAAS,kBAAkB,SAAS,QAAQ,CAAC,KAAK,cAAc,SAAS,SAAS,aAAa,GACnG;AAEG,UAAI,SAAS,yBAAyB,aAAa;AAAE,iBAAS,cAAc,KAAI;AAAA,MAAK;AAGrF,eAAS,KAAK;IAChB;AAED,OAAG,eAAe;AAAA,EACpB;AAAA,EAqBD,MAAM,MAAM,UAAU,CAAE,GACxB;AACG,UAAM,SAAS,YAAY;AAC3B,QAAI,CAAC,QAAQ,SAAS,CAAC,CAAC,OAAO,UAAU,OAAO,KAAK,EAAE,SAAS,KAAK,MAAM,GAAG;AAAE;AAAA,IAAS;AAGzF,SAAK,QAAQ;AAKb,SAAK,SAAS,OAAO;AAOrB,UAAM,KAAK,KAAK;AAChB,QAAI,CAAC,IAAI;AAAE,aAAO,KAAK,SAAS,OAAO;AAAA,IAAS;AAIhD,UAAM,UAAU,GAAG,cAAc,iBAAiB;AAClD,QAAI,SACJ;AACG,cAAQ,MAAM,WAAW;AAIzB,eAAS,OAAO,QAAQ,SAAS,QAAQ,EAAE,QAAQ,KACnD;AACG,gBAAQ,SAAS,MAAM,MAAM,WAAW;AAAA,MAC1C;AAAA,IACH;AAGD,eAAW,OAAO,KAAK,YAAY,qBAAsB,GACzD;AAYG,YAAM,KAAK,QAAQ,IAAI,QAAQ,MAAM,EAAE;AAAA,IACzC;AAKD,UAAM,UAAU,OAAO,KAAK,QAAQ,0BAA0B,YAAY,KAAK,QAAQ,wBACtF;AAED,QAAI,SACJ;AAEG,SAAG,MAAM,YAAY;AAErB,YAAM,EAAE,eAAe,eAAe,WAAW,iBAAiB,EAAE;AAGpE,YAAM,GAAG,QAAQ;AAAA,QACd,EAAE,WAAW,GAAG,GAAG,kBAAkB,YAAY,cAAe;AAAA,QAChE,EAAE,WAAW,GAAG,YAAY,GAAG,eAAe,EAAG;AAAA,MAC7D,GAAY,EAAE,UAAU,KAAK,QAAQ,WAAW,MAAM,YAAY,EAAE;AAAA,IAC7D;AAGD,UAAM,wBAAwB,CAAA;AAG9B,eAAW,SAAS,KAAK,aACzB;AAEG,4BAAsB,KAAK,gBAAgB,MAAM,SAAS,CAAC;AAG3D,YAAM,WAAW,MAAM,OAAO;AAC9B,UAAI,OAAO,aAAa,YAAY,OAAO,SAAS,QAAQ,YAC5D;AACG,iBAAS,IAAG;AACZ,cAAM,OAAO,WAAW;AAAA,MAC1B;AAAA,IACH;AAGD,UAAM,QAAQ,IAAI,qBAAqB;AAGvC,SAAK,YAAY,SAAS;AAG1B,OAAG,OAAM;AAGT,SAAK,SAAS,MAAM,QAAQ;AAAA,MACzB,MAAM;AAAA,MACN,YAAY,CAAC,SAAS,QAAQ;AAAA,MAC9B,QAAQ;AAAA,MACR,QAAQ;AAAA,IACjB,CAAO;AAGD,SAAK,wBAAwB,KAAK;AAIlC,SAAK,WAAW;AAChB,SAAK,kBAAkB;AACvB,SAAK,iBAAiB;AACtB,WAAO,GAAG,QAAQ,KAAK;AAIvB,SAAK,aAAa;AAIlB,SAAK,mBAAmB;AACxB,SAAK,SAAS,OAAO;AAErB,SAAK,WAAW;AAGhB,SAAK,QAAQ,gBAAgB,CAAC,iBAAiB,UAAU,cAAc,EAAE,WAAW,KAAK,WAAU,CAAE,CAAC;AAAA,EACxG;AAAA,EAYD,YAAY,MACZ;AACG,QAAI,KAAK,UAAU,KAAK,WAAW,KAAK,MAAM,QAAQ,KAAK,QAAQ,MAAM,GACzE;AACG,YAAM,IAAI,MACT,wGAAwG;AAAA,IAC3G;AAGD,SAAK,SAAS;AAKd,UAAM,oBAAoB,6BAC1B;AACG,UAAI,OAAO;AAEX,aAAO,CAAC,gBACR;AACG,YAAI,gBAAgB,QAAQ,gBAAgB,UAAU,SAAS,GAC/D;AACG,eAAK,wBAAuB;AAC5B,iBAAO;AAAA,QACT;AAED,eAAO;AAAA,MACnB;AAAA,IACA,GAdgC;AAgB1B,QAAI,MAAM,QAAQ,KAAK,QAAQ,MAAM,GACrC;AACG,iBAAW,gBAAgB,KAAK,QAAQ,QACxC;AACG,cAAM,aAAa,iBAAiB;AAAA,UACjC,KAAK;AAAA,UACL,UAAU,KAAK;AAAA,UACf,QAAQ;AAAA,UACR;AAAA,QACf,CAAa;AAED,YAAI,mBAAmB,WAAW,SAAS,GAC3C;AACG,cAAI,KAAK,OAAO,qBAAqB,MACrC;AACG,kBAAM,IAAI,MACT;AAAA,sBACG,KAAK,UAAU,YAAY,GAAG;AAAA,UACpC;AAED,eAAK,wBAAwB,KAAK,WAAW;AAM7C,cAAI,WAAW,WAAW,SAAS,KAAK,MAAM,QAAQ,WAAW,WAAW,IAAI,MAAM,GACtF;AACG,uBAAW,UAAU,GAAG,OAAO,KAAK,MAAM,MAAM,KAAK,wBAAuB,CAAE;AAAA,UAChF;AAAA,QACH;AAED,aAAK,YAAY,KAAK,UAAU;AAAA,MAClC;AAAA,IACH,WACQ,OAAO,KAAK,QAAQ,WAAW,UACxC;AACG,YAAM,aAAa,iBAAiB;AAAA,QACjC,KAAK;AAAA,QACL,UAAU,KAAK;AAAA,QACf,QAAQ,KAAK,QAAQ;AAAA,QACrB;AAAA,MACZ,CAAU;AAED,UAAI,mBAAmB,WAAW,SAAS,GAC3C;AAEG,YAAI,KAAK,OAAO,qBAAqB,MACrC;AACG,gBAAM,IAAI,MACT;AAAA,mBACG,KAAK,UAAU,KAAK,QAAQ,MAAM,GAAG;AAAA,QAC3C;AAED,aAAK,wBAAwB,KAAK,WAAW;AAM7C,YAAI,WAAW,WAAW,SAAS,KAAK,MAAM,QAAQ,WAAW,WAAW,IAAI,MAAM,GACtF;AACG,qBAAW,UAAU,GAAG,OAAO,KAAK,MAAM,MAAM,KAAK,wBAAuB,CAAE;AAAA,QAChF;AAAA,MACH;AAED,WAAK,YAAY,KAAK,UAAU;AAAA,IAClC;AAGD,UAAM,qBAAqB,KAAK,UAAU,KAAK,cAAc;AAG7D,QAAI,aAAa;AACjB,eAAW,cAAc,KAAK,aAC9B;AACG,UAAI,CAAC,WAAW,YAAY;AAAE,qBAAa;AAAO;AAAA,MAAQ;AAAA,IAC5D;AACD,QAAI,YAAY;AAAE,YAAM,YAAY,IAAI;AAAA,IAAI;AAE5C,QAAI,KAAK,OAAO,qBAAqB,MACrC;AACG,WAAK,WAAW,EAAE,KAAK,OAAO,iBAAiB,WAAW;AAG1D,WAAK,kBAAkB,UAAU,KAAK,OAAO,kBAAkB,gBAAgB,IAC9E,KAAK,OAAO,iBAAiB,iBAAiB;AAG/C,WAAK,iBAAiB,UAAU,KAAK,OAAO,kBAAkB,eAAe,IAC5E,KAAK,OAAO,iBAAiB,gBAAgB;AAAA,IAChD,WACQ,oBACT;AACG,iBAAW,cAAc,KAAK,aAC9B;AACG,YAAI,WAAW,mBAAmB,aAClC;AACG,eAAK,WAAW,EAAE,WAAW,OAAO;AACpC;AAAA,QACF;AAAA,MACH;AAAA,IACH;AAID,QAAI,KAAK,mBAAmB,MAC5B;AACG,YAAM,WAAU,OAAO,KAAK,QAAQ,mBAAmB,WACtD,KAAK,SAAS,KAAK,KAAK,QAAQ,cAAc,IAAI,KAAK;AAExD,WAAK,iBAAiB,SAAQ;AAAA,IAChC;AAGD,QAAI,KAAK,mBAAmB,QAAQ,KAAK,mBAAmB,UAAU,KAAK,eAAe,WAAW,GACrG;AACG,YAAM,IAAI,MAAM,oDAAoD,KAAK,QAAQ,4BAA4B;AAAA,IAC/G;AAID,QAAI,OAAO,KAAK,QAAQ,iBAAiB,aAAa,KAAK,QAAQ,cACnE;AACG,WAAK,eAAe,MAAM,SAAS,OAAO,KAAK,QAAQ,WAAW,WAAW,KAAK,QAAQ,SACzF,KAAK,kBAAkB;AAAA,IAC1B;AAGD,SAAK,QAAQ;EACf;AAAA,EAgBD,MAAM,SAAS,EAAE,UAAU,MAAM,WAAW,QAAQ,CAAE,GACtD;AACG,QAAI,CAAC,KAAK,UAAU,CAAC,OAAO,IAAI,EAAE,SAAS,KAAK,UAAU,GAAG;AAAE;AAAA,IAAS;AAExE,SAAK,aAAa;AAElB,UAAM,aAAa,WAAW;AAG9B,UAAM,WAAU,KAAK;AACrB,UAAM,SAAS,SAAQ,cAAc,gBAAgB;AACrD,UAAM,UAAU,SAAQ,cAAc,iBAAiB;AAGvD,UAAM,iBAAiB,KAAK,SAAS,MAAM,IAAI,EAAE,MAAM,mBAAkB,CAAE;AAG3E,QAAI,SACJ;AACG,YAAM,KAAK,SAAS,MAAM,QAAQ;AAAA,QAC/B,MAAM;AAAA,QACN,OAAO;AAAA,QACP,WAAW;AAAA,QACX,YAAY,CAAC,OAAO;AAAA,QACpB,UAAU;AAAA,MACtB,CAAU;AAAA,IACH;AAGD,aAAS,OAAO,OAAO,SAAS,QAAQ,EAAE,QAAQ,KAAI;AAAE,aAAO,SAAS,MAAM,MAAM,UAAU;AAAA,IAAO;AAErG,YAAQ,MAAM,UAAU;AAExB,QAAI;AAEJ,QAAI,SACJ;AAGG,MAAC,GAAE,YAAW,IAAK,KAAK,SAAS,MAAM,QAAQ;AAAA,QAC5C,MAAM;AAAA,QACN,WAAW;AAAA,QACX,YAAY,CAAC,QAAQ;AAAA,QACrB,QAAQ;AAAA,QACR;AAAA,MACZ,CAAU;AAAA,IACH,OAED;AACG,MAAC,GAAE,gBAAgB,KAAK,SAAS,MAAM,OAAO,EAAE,MAAM,mBAAkB,CAAE;AAAA,IAC5E;AAGD,UAAM,QAAQ,QAAQ;AAAA,MACnB,EAAE,WAAW,GAAG,YAAY,GAAG,eAAe,GAAG,QAAQ,EAAG;AAAA,MAC5D,EAAE,GAAG,aAAa,QAAQ,EAAG;AAAA,MAC7B,EAAE,WAAW,QAAQ,QAAQ,EAAG;AAAA,IACzC,GAAS,EAAE,UAAU,YAAY,MAAM,WAAU,CAAE,EAAE;AAG/C,SAAK,SAAS,IAAI;AAAA,MACf,WAAW,eAAe,aAAa,KAAK,SAAS,aAAa;AAAA,MAClE,UAAU,eAAe,YAAY,KAAK,SAAS,YAAY;AAAA,IACxE,CAAO;AAGD,aAAQ,MAAM,WAAW;AACzB,aAAQ,MAAM,YAAY;AAE1B,aAAQ,UAAU,OAAO,WAAW;AAEpC,SAAK,aAAa;AAGlB,eAAW,MACX;AACG,cAAQ,MAAM,WAAW;AAGzB,eAAS,OAAO,QAAQ,SAAS,QAAQ,EAAE,QAAQ,KACnD;AACG,gBAAQ,SAAS,MAAM,MAAM,WAAW;AAAA,MAC1C;AAAA,IACH,GAAE,EAAE;AAEL,SAAK,QAAQ,gBAAgB,CAAC,YAAY,UAAU,SAAS,EAAE,WAAW,MAAO,CAAA,CAAC;AAAA,EACpF;AAAA,EAgBD,MAAM,SAAS,EAAE,UAAU,MAAM,WAAW,QAAQ,CAAE,GACtD;AACG,QAAI,CAAC,KAAK,YAAY,CAAC,KAAK,UAAU,CAAC,MAAM,IAAI,EAAE,SAAS,KAAK,UAAU,GAAG;AAAE;AAAA,IAAS;AAEzF,SAAK,QAAQ,gBAAgB,CAAC,YAAY,UAAU,SAAS,EAAE,WAAW,KAAM,CAAA,CAAC;AAEjF,SAAK,aAAa;AAElB,UAAM,aAAa,WAAW;AAE9B,UAAM,WAAU,KAAK;AAGrB,UAAM,SAAS,SAAQ,cAAc,gBAAgB;AACrD,UAAM,UAAU,SAAQ,cAAc,iBAAiB;AAGvD,UAAM,iBAAiB,KAAK,SAAS;AACrC,UAAM,kBAAkB,KAAK,SAAS;AAGtC,SAAK,SAAS,IAAI,EAAE,UAAU,KAAK,WAAW,GAAE,CAAE;AAGlD,aAAQ,MAAM,WAAW;AACzB,aAAQ,MAAM,YAAY;AAE1B,QAAI,SACJ;AACG,cAAQ,MAAM,WAAW;AAIzB,eAAS,OAAO,QAAQ,SAAS,QAAQ,EAAE,QAAQ,KACnD;AACG,gBAAQ,SAAS,MAAM,MAAM,WAAW;AAAA,MAC1C;AAAA,IACH;AAED,UAAM,EAAE,eAAe,eAAe,WAAW,iBAAiB,OAAO;AAGzE,UAAM,cAAc;AAAA,MACjB,WAAW,GAAG,QAAQ;AAAA,MACtB;AAAA,MACA;AAAA,IACT;AAGM,QAAI,SACJ;AACG,YAAM,YAAY,QAAQ,QAAQ;AAAA,QAC/B;AAAA,QACA,EAAE,WAAW,GAAG,YAAY,GAAG,eAAe,EAAG;AAAA,MACnD,GAAE,EAAE,UAAU,YAAY,MAAM,WAAY,CAAA;AAG7C,gBAAU,SAAS,KAAK,MAAM,QAAQ,MAAM,UAAU,MAAM;AAAA,IAC9D,OAED;AACG,iBAAW,MAAM,QAAQ,MAAM,UAAU,QAAQ,UAAU;AAAA,IAC7D;AAGD,UAAM,QAAQ,KAAK,SAAS,MAAM,KAAK,EAAE,MAAM,oBAAoB,YAAW,CAAE;AAGhF,UAAM,WAAW;AACjB,UAAM,YAAY;AAElB,UAAM,qBAAqB,OAAO;AAGlC,SAAK,SAAS,YAAY;AAE1B,QAAI,SACJ;AAEG,YAAM,KAAK,SAAS,QAAQ,GAAG,EAAE,QAAQ,sBAAsB,EAAE,SAAU,CAAA,EAAE;AAAA,IAC/E;AAGD,aAAS,OAAO,OAAO,SAAS,QAAQ,EAAE,QAAQ,KAClD;AACG,YAAM,YAAY,OAAO,SAAS,MAAM;AAExC,UAAI,UAAU,SAAS,cAAc,KAAK,UAAU,SAAS,OAAO,GAAG;AAAE;AAAA,MAAW;AAIpF,UAAI,UAAU,SAAS,gBAAgB,GACvC;AACG,eAAO,SAAS,MAAM,MAAM,UAAU;AACtC;AAAA,MACF;AAED,aAAO,SAAS,MAAM,MAAM,UAAU;AAAA,IACxC;AAED,QAAI,SACJ;AAEG,YAAM,KAAK,SAAS,QAAQ,GAAG,EAAE,OAAO,iBAAgB,GAAI,EAAE,UAAU,IAAK,CAAA,EAAE;AAAA,IACjF;AAED,aAAQ,UAAU,IAAI,WAAW;AAEjC,SAAK,aAAa;AAAA,EACpB;AAAA,EAaD,cAAc,EAAE,mBAAS,gBAAgB,kBAAkB,CAAE,GAAE;AAAA,EAAE;AAAA,EAejE,gBAAgB,EAAE,mBAAS,gBAAgB,kBAAkB,CAAE,GAAE;AAAA,EAAE;AAAA,EASnE,aAAa,UAAS,MACtB;AACG,QAAI,CAAC,SAAQ,QAAQ;AAAE;AAAA,IAAS;AAEhC,SAAK,SAAS;EAChB;AAAA,EAeD,MAAM,QAAQ,QAAQ,OAAO,UAAU,CAAE,GACzC;AACG,QAAI,KAAK,WAAW,YAAY,cAAc,QAC7C,SAAS,cAAc,IAAI,KAAK,IAAI,aAAa,aAClD;AACG,cAAQ,KAAK,yEAAyE,KAAK,kEAC3B,KAAK,SAAS;AAE9E;AAAA,IACF;AAED,UAAM,MAAM,QAAQ,OAAO,OAAO;AAElC,QAAI,CAAC,KAAK,UACV;AACG,WAAK,cAAc,EAAE,SAAS,KAAK,SAAS,IAAI,gBAAgB,KAAK,iBAAiB,eACrF,KAAK,eAAc,CAAE;AAEtB,WAAK,WAAW;AAAA,IAClB;AAAA,EACH;AAAA,EAaD,MAAM,aAAa,MACnB;AACG,UAAM,OAAO,OAAO,KAAK,aAAa,WAAW,MAAM,eAAe,KAAK,UAAU,IAAI,IACxF,SAAS,uBAAsB;AAEhC,WAAO,EAAE,IAAI;AAAA,EACf;AAAA,EAUD,MAAM,eACN;AACG,UAAM,OAAO,MAAM,MAAM;AACzB,SAAK,iBAAiB,KAAK,GAAG,MAAM;AACpC,WAAO;AAAA,EACT;AAAA,EAaD,YAAY,UACZ;AACG,WAAO,KAAK,SAAS,IAAI,QAAQ;AAAA,EACnC;AAAA,EAQD,0BACA;AACG,UAAM,mBAAmB,KAAK,OAAO;AAErC,QAAI,qBAAqB,MACzB;AACG,WAAK,WAAW,EAAE,iBAAiB,WAAW;AAG9C,WAAK,kBAAkB,UAAU,kBAAkB,gBAAgB,IAClE,iBAAiB,iBAAiB;AAGnC,WAAK,iBAAiB,UAAU,kBAAkB,eAAe,IAChE,iBAAiB,gBAAgB;AAElC,UAAI,KAAK,mBAAmB,MAC5B;AACG,cAAM,WAAU,OAAO,KAAK,QAAQ,mBAAmB,WACtD,KAAK,SAAS,KAAK,KAAK,QAAQ,cAAc,IAAI,KAAK;AAExD,aAAK,iBAAiB,SAAQ;AAAA,MAChC;AAID,UAAI,OAAO,KAAK,QAAQ,iBAAiB,aAAa,KAAK,QAAQ,cACnE;AACG,aAAK,eAAe,MAAM,SAAS,OAAO,KAAK,QAAQ,WAAW,WAAW,KAAK,QAAQ,SACzF,KAAK,kBAAkB;AAExB,cAAM,WAAU;AAGhB,aAAK,SAAS,IAAI,KAAK,SAAS,IAAG,CAAE;AAAA,MACvC;AAED,YAAM,uBAAuB,CAAC,KAAK,cAAc,CAAC;AAElD,WAAK,gBAAgB,EAAE,SAAS,KAAK,SAAS,IAAI,gBAAgB,KAAK,iBAAiB,eACvF,KAAK,eAAc,CAAE;AAAA,IACxB;AAAA,EACH;AACJ;AAj7Ba;;;;;;;;;;;;;;;;;ACRT,aAAqC,QAAA,GAAA,MAAA;AAAA;;;;;;;;;;;;;;mBAJ9B,IAAQ;;iCAAb,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;qBAAC,KAAQ;;mCAAb,QAAI,KAAA,GAAA;;;;;;;;;;;;;4BAAJ,QAAI,IAAA,YAAA,QAAA,KAAA,GAAA;;;;;;;;;qCAAJ,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;AACuC,QAAA,gCAAA,CAAA,OAAM,KAAK;AAA5B,MAAA,eAAA,OAAM;;;;;;;;;;;;;;;;;;;;;;;;;;kDAAW,kBAAA,+BAAA,CAAA,kBAAA,QAAM,KAAK,CAAA,CAAA;AAA5B,UAAA,iBAAA,gBAAA,QAAM,QAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAFtC,MAAM,QAAQ,KAAQ,EAAA;;;QAIjB,KAAI;AAAA,aAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAVA,MAAA,EAAA,OAAO,UAAK;AACZ,MAAA,EAAA,iCAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACwC/B,cAAc,MAAM,EAAE,QAAQ,GAAG,WAAW,KAAK,SAASC,aAAW,IAAI;AACrE,QAAM,IAAI,CAAC,iBAAiB,IAAI,EAAE;AAClC,SAAO;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA,KAAK,OAAK,YAAY,IAAI;AAAA,EAClC;AACA;AARS;AAuBT,eAAe,MAAM,EAAE,QAAQ,GAAG,WAAW,KAAK,SAAS,aAAa,IAAI;AACxE,QAAM,QAAQ,iBAAiB,IAAI;AACnC,QAAM,UAAU,CAAC,MAAM;AACvB,QAAM,SAAS,WAAW,MAAM,MAAM;AACtC,QAAM,cAAc,WAAW,MAAM,UAAU;AAC/C,QAAM,iBAAiB,WAAW,MAAM,aAAa;AACrD,QAAM,aAAa,WAAW,MAAM,SAAS;AAC7C,QAAM,gBAAgB,WAAW,MAAM,YAAY;AACnD,QAAM,mBAAmB,WAAW,MAAM,cAAc;AACxD,QAAM,sBAAsB,WAAW,MAAM,iBAAiB;AAC9D,SAAO;AAAA,IACH;AAAA,IACA;AAAA,IACA;AAAA,IACA,KAAK,OAAK,6BACM,KAAK,IAAI,IAAI,IAAI,CAAC,IAAI,mBACvB,IAAI,yBACC,IAAI,iCACD,IAAI,gCACR,IAAI,+BACD,IAAI,qCACD,IAAI,2CACD,IAAI;AAAA,EACxC;AACA;AAxBS;ACuDT,mBAAmB,MAAM,SACzB;AACG,QAAM,aAAa,QAAQ,cAAc,QAAQ,UAAUA;AAC3D,QAAM,cAAc,QAAQ,eAAe,QAAQ,UAAUA;AAE7D,QAAM,iBAAiB,KAAK,IAAI;AAChC,QAAM,kBAAkB,MAAM,IAAI;AAElC,SAAO;AAAA,IACJ,OAAO,QAAQ,SAAS;AAAA,IACxB,UAAU,QAAQ,YAAY;AAAA,IAC9B,QAAQA;AAAAA,IACR,KAAK,CAAC,MACN;AACG,YAAM,QAAQ,WAAW,CAAC;AAC1B,YAAM,SAAS,YAAY,CAAC;AAC5B,aAAO,GAAG,gBAAgB,IAAI,QAAQ,IAAI,MAAM,MAAM,eAAe,IAAI,OAAO,IAAI,KAAK;AAAA,IAC3F;AAAA,EACP;AACA;AAnBS;AAmCT,MAAM,uBAAuB,6BAAM,QAAN;AAC7B,MAAM,+BAA+B,CAAE;;;;;;;;;;;;;;;;sBCtD9B,IAAE,EAAA;;;;;AAAX,aAQK,QAAA,KAAA,MAAA;;;;;;;yCAFY,IAAO,EAAA;;;;;;;;;;;;wBANf,IAAE,EAAA;AAAA;;;;;;;;;sDAIW,IAAmB,EAAA;;;;;;;;;qDACjB,IAAoB,EAAA;;;;;;;;;;;;;;;;;;;AAtG9B,MAAA,EAAA,gBAAW;QACX,SAAS,OAAO,qBAAgB;AAChC,MAAA,EAAA,aAAa,gBAAW;AACxB,MAAA,EAAA,eAAe,SAAI;AACnB,MAAA,EAAA,kCAAiB,SAAI;AACrB,MAAA,EAAA,kBAAkB,SAAI;MAE7B;AAyBO,MAAA,EAAA,wBAAmB;AACnB,MAAA,EAAA,eAAe,yBAAoB;AACnC,MAAA,EAAA,gBAAgB,yBAAoB;AAGpC,MAAA,EAAA,+BAA0B;AAC1B,MAAA,EAAA,sBAAsB,iCAA4B;AAClD,MAAA,EAAA,uBAAuB,iCAA4B;AAG1D,MAAA;AACA,MAAA;AA0CK,mBAAQ,OAAK;QAEf,cAAY;UAET,iBAAc;AAAI,cAAM,eAAc;AAAA;UACtC,iBAAe;AAAI,cAAM,gBAAe;AAAA;;;AALzC;;;AAaI,kBAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAzFf,WAAS;AAEb,qBAAA,GAAA,UAAU,MAAM,WAAW,QAAM,SAAA;AACjC,qBAAA,GAAA,UAAU,MAAM,YAAY,QAAM,SAAA;AAClC,qBAAA,GAAA,UAAU,MAAM,QAAQ,QAAM,SAAA;AAC9B,qBAAA,GAAA,UAAU,MAAM,SAAS,QAAM,SAAA;AAAA;;;UAG3B,WAAS;YAET,cAAY;AAAI,oBAAU,MAAK;AAAA;wBACnC,UAAU,MAAM,gBAAgB,eAAe,SAAS,QAAM,SAAA;AAAA;;;UAG1D,WAAS;AAAI,qBAAA,GAAA,UAAU,MAAM,aAAa,YAAU,SAAA;AAAA;;;UACpD,WAAS;AAAI,qBAAA,GAAA,UAAU,MAAM,SAAS,QAAM,SAAA;AAAA;;;AAsBlD,UAAM,kBAAkB,YAAU;AAI1B,cAAA,gBAAgB,yBAAyB,cAAqB,OAAA,eAAe,aAAa,aAC/F;AAED,qBAAA,GAAA,eAAe,aAAa;AAC5B,qBAAA,GAAA,gBAAgB,aAAa;AAE7B,qBAAA,IAAA,gBAAgB,aAAa;AAAA;;;AAI/B,UAAM,yBAAyB,mBAAiB;AAExC,cAAA,aAAa,sBAAsB,gCAAuC,OAAA,sBAAsB,WACrG,oBAAoB;AAErB,qBAAA,GAAA,sBAAsB,UAAU;AAChC,qBAAA,GAAA,uBAAuB,UAAU;AAEjC,qBAAA,IAAA,uBAAuB,UAAU;AAAA;;;AAInC,UAAA,OAAa,iBAAiB,YAAU;AAAI,qBAAA,GAAA,eAAe,oBAAoB;AAAA;;;AAG/E,UAAA,OAAa,kBAAkB,YAAU;AAAI,qBAAA,GAAA,gBAAgB,oBAAoB;AAAA;;;AAGjF,UAAA,OAAa,wBAAwB,UAAQ;AAAI,qBAAA,GAAA,sBAAsB,4BAA4B;AAAA;;;AAGnG,UAAA,OAAa,yBAAyB,UAAQ;AAAI,qBAAA,GAAA,uBAAuB,4BAA4B;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACpCzG,wBAAwB,MAAM,QAC9B;AACG,wBAAsB,IAAI,MAAM,MAAM;AAEtC,SAAO;AAAA,IACJ,QAAQ,CAAC,cACT;AACG,4BAAsB,OAAO,MAAM,MAAM;AACzC,eAAS;AACT,4BAAsB,IAAI,MAAM,MAAM;AAAA,IACxC;AAAA,IAED,SAAS,MACT;AACG,4BAAsB,OAAO,MAAM,MAAM;AAAA,IAC3C;AAAA,EACP;AACA;AAjBS;AA2BT,eAAe,cAAc,SAAS,IACtC;AACG,MAAI,CAAE,eAAc,cAAc;AAAE,UAAM,IAAI,UAAU,yDAAyD;AAAA,EAAI;AAErH,QAAM,cAAc,MAAM,IAAI,EAAE;AAEhC,MAAI,MAAM,QAAQ,WAAW,GAC7B;AACG,UAAM,WAAW,WAAW,iBAAiB,EAAE;AAI/C,UAAM,eAAe,iBAAiB,GAAG,MAAM,YAAY,KAAK,iBAAiB,SAAS,YAAY,KAAK;AAC3G,UAAM,aAAa,iBAAiB,GAAG,MAAM,UAAU,KAAK,iBAAiB,SAAS,UAAU,KAAK;AACrG,UAAM,cAAc,iBAAiB,GAAG,MAAM,WAAW,KAAK,iBAAiB,SAAS,WAAW,KAAK;AACxG,UAAM,YAAY,iBAAiB,GAAG,MAAM,SAAS,KAAK,iBAAiB,SAAS,SAAS,KAAK;AAClG,UAAM,gBAAgB,iBAAiB,GAAG,MAAM,aAAa,KAAK,iBAAiB,SAAS,aAAa,KAAK;AAC9G,UAAM,cAAc,iBAAiB,GAAG,MAAM,WAAW,KAAK,iBAAiB,SAAS,WAAW,KAAK;AACxG,UAAM,eAAe,iBAAiB,GAAG,MAAM,YAAY,KAAK,iBAAiB,SAAS,YAAY,KAAK;AAC3G,UAAM,aAAa,iBAAiB,GAAG,MAAM,UAAU,KAAK,iBAAiB,SAAS,UAAU,KAAK;AAErG,UAAM,kBAAkB,aAAa,cAAc,cAAc;AACjE,UAAM,mBAAmB,YAAY,eAAe,aAAa;AAEjE,eAAW,cAAc,aACzB;AACG,iBAAW,OAAO,kBAAkB;AACpC,iBAAW,OAAO,mBAAmB;AACrC,0BAAoB,YAAY,WAAW,cAAc,WAAW,aAAa;AAAA,IACnF;AAAA,EACH;AACJ;AAIA,MAAM,QAAQ,oBAAI;AAQlB,MAAM,sBACN;AAAA,EASG,OAAO,IAAI,IAAI,QACf;AACG,UAAM,aAAa,kBAAkB,MAAM;AAE3C,QAAI,eAAe,GACnB;AACG,YAAM,IAAI,MAAM,4EAA4E;AAAA,IAC9F;AAED,UAAM,WAAW,WAAW,iBAAiB,EAAE;AAI/C,UAAM,eAAe,iBAAiB,GAAG,MAAM,YAAY,KAAK,iBAAiB,SAAS,YAAY,KAAK;AAC3G,UAAM,aAAa,iBAAiB,GAAG,MAAM,UAAU,KAAK,iBAAiB,SAAS,UAAU,KAAK;AACrG,UAAM,cAAc,iBAAiB,GAAG,MAAM,WAAW,KAAK,iBAAiB,SAAS,WAAW,KAAK;AACxG,UAAM,YAAY,iBAAiB,GAAG,MAAM,SAAS,KAAK,iBAAiB,SAAS,SAAS,KAAK;AAClG,UAAM,gBAAgB,iBAAiB,GAAG,MAAM,aAAa,KAAK,iBAAiB,SAAS,aAAa,KAAK;AAC9G,UAAM,cAAc,iBAAiB,GAAG,MAAM,WAAW,KAAK,iBAAiB,SAAS,WAAW,KAAK;AACxG,UAAM,eAAe,iBAAiB,GAAG,MAAM,YAAY,KAAK,iBAAiB,SAAS,YAAY,KAAK;AAC3G,UAAM,aAAa,iBAAiB,GAAG,MAAM,UAAU,KAAK,iBAAiB,SAAS,UAAU,KAAK;AAErG,UAAM,OAAO;AAAA,MACV;AAAA,MACA;AAAA,MAGA,cAAc;AAAA,MACd,eAAe;AAAA,MAGf,QAAQ;AAAA,QACL,iBAAiB,aAAa,cAAc,cAAc;AAAA,QAC1D,kBAAkB,YAAY,eAAe,aAAa;AAAA,MAC5D;AAAA,IACV;AAEM,QAAI,MAAM,IAAI,EAAE,GAChB;AACG,YAAM,cAAc,MAAM,IAAI,EAAE;AAChC,kBAAY,KAAK,IAAI;AAAA,IACvB,OAED;AACG,YAAM,IAAI,IAAI,CAAC,IAAI,CAAC;AAAA,IACtB;AAED,sBAAkB,QAAQ,EAAE;AAAA,EAC9B;AAAA,EAUD,OAAO,OAAO,IAAI,SAAS,QAC3B;AACG,UAAM,cAAc,MAAM,IAAI,EAAE;AAChC,QAAI,MAAM,QAAQ,WAAW,GAC7B;AACG,YAAM,QAAQ,YAAY,UAAU,CAAC,UAAU,MAAM,WAAW,MAAM;AACtE,UAAI,SAAS,GACb;AAEG,4BAAoB,YAAY,QAAQ,QAAQ,MAAM;AAEtD,oBAAY,OAAO,OAAO,CAAC;AAAA,MAC7B;AAGD,UAAI,YAAY,WAAW,GAC3B;AACG,cAAM,OAAO,EAAE;AACf,0BAAkB,UAAU,EAAE;AAAA,MAChC;AAAA,IACH;AAAA,EACH;AACJ;AA1FM;AAiGN,MAAM,iBAAiB;AAAA,EACpB,MAAM;AAAA,EACN,WAAW;AAAA,EACX,UAAU;AAAA,EACV,gBAAgB;AAAA,EAChB,kBAAkB;AAAA,EAClB,cAAc;AAAA,EACd,aAAa;AAAA,EACb,cAAc;AACjB;AAEA,MAAM,oBAAoB,IAAI,eAAe,CAAC,YAC9C;AACG,aAAW,SAAS,SACpB;AACG,UAAM,cAAc,MAAM,IAAI,OAAO,MAAM;AAE3C,QAAI,MAAM,QAAQ,WAAW,GAC7B;AACG,YAAM,eAAe,MAAM,YAAY;AACvC,YAAM,gBAAgB,MAAM,YAAY;AAExC,iBAAW,cAAc,aACzB;AACG,4BAAoB,YAAY,cAAc,aAAa;AAAA,MAC7D;AAAA,IACH;AAAA,EACH;AACJ,CAAC;AASD,2BAA2B,QAC3B;AACG,MAAI,QAAQ,0BAA0B,UAAU;AAAE,WAAO,eAAe;AAAA,EAAiB;AACzF,MAAI,QAAQ,wBAAwB,UAAU;AAAE,WAAO,eAAe;AAAA,EAAe;AACrF,MAAI,QAAQ,4BAA4B,UAAU;AAAE,WAAO,eAAe;AAAA,EAAmB;AAE7F,QAAM,aAAa,OAAO;AAG1B,MAAK,eAAe,YAAY,eAAe,YAC/C;AACG,QAAI,iBAAiB,OAAO,cAAc,GAC1C;AACG,aAAO,eAAe;AAAA,IACxB;AAGD,UAAM,SAAS,QAAQ;AACvB,QAAI,OAAO,WAAW,YAAY,OAAO,WAAW,YACpD;AACG,UAAI,iBAAiB,OAAO,cAAc,GAC1C;AACG,eAAO,eAAe;AAAA,MACxB;AAAA,IACH;AAAA,EACH;AAED,MAAI,eAAe,UAAU;AAAE,WAAO,eAAe;AAAA,EAAY;AAEjE,MAAI,eAAe,YAAY;AAAE,WAAO,eAAe;AAAA,EAAW;AAElE,SAAO,eAAe;AACzB;AAhCS;AA4CT,6BAA6B,YAAY,cAAc,eACvD;AACG,QAAM,UAAS,WAAW;AAE1B,aAAW,eAAe;AAC1B,aAAW,gBAAgB;AAE3B,QAAM,cAAc,OAAO,SAAS,YAAY,IAAI,eAAe,QAAO,kBAAkB;AAC5F,QAAM,eAAe,OAAO,SAAS,aAAa,IAAI,gBAAgB,QAAO,mBAAmB;AAEhG,QAAM,SAAS,WAAW;AAE1B,UAAQ,WAAW;AAAA,SAEX,eAAe;AACjB,aAAO,eAAe;AACtB,aAAO,gBAAgB;AACvB,aAAO,cAAc;AACrB,aAAO,eAAe;AACtB;AAAA,SAEE,eAAe;AACjB,eAAS,aAAa,cAAc,cAAc,aAAa;AAC/D;AAAA,SAEE,eAAe;AACjB,aAAO,iBAAiB,aAAa,cAAc,cAAc,aAAa;AAC9E;AAAA,SAEE,eAAe;AACjB,aAAO,mBAAmB,cAAc,aAAa;AACrD;AAAA,SAEE,eAAe;AACjB,aAAO,eAAe,aAAa,YAAY;AAC/C;AAAA,SAEE,eAAe;AACjB,aAAO,eAAe,OAAO,CAAC,WAC9B;AACG,eAAO,gBAAgB;AACvB,eAAO,eAAe;AACtB,eAAO,eAAe;AACtB,eAAO,cAAc;AAErB,eAAO;AAAA,MACnB,CAAU;AACD;AAAA,SAEE,eAAe;AACjB,aAAO,OAAO,eAAe,OAAO,CAAC,WACrC;AACG,eAAO,gBAAgB;AACvB,eAAO,eAAe;AACtB,eAAO,eAAe;AACtB,eAAO,cAAc;AAErB,eAAO;AAAA,MACnB,CAAU;AACD;AAAA;AAET;AA7DS;AAgKT,qBAAqB,MAAM,YAC3B;AAEG,2BACA;AACG,QAAI,OAAO,eAAe,UAAU;AAAE;AAAA,IAAS;AAE/C,eAAW,QAAQ,OAAO,KAAK,UAAU,GACzC;AACG,WAAK,MAAM,YAAY,GAAG,QAAQ,WAAW,KAAK;AAAA,IACpD;AAAA,EACH;AARQ;AAUT;AAEA,SAAO;AAAA,IACJ,OAAO,eACP;AACG,mBAAa;AACb;IACF;AAAA,EACP;AACA;AAtBS;AA+GT,mBAAmB,MAAM;AAAA,EAAE;AAAA,EAAU,kBAAS;AAAA,EAAM,SAAS;AAAA,EAAG,gBAAgB;AAAA,EAAQ,OAAO;AAAA,EAC9F,cAAc,EAAE,UAAU,KAAK,MAAM,SAAQ;AAAA,GAC9C;AAMG,MAAI,kBAAkB;AAOtB,MAAI,mBAAmB,CAAA;AAQvB,MAAI,WAAW;AAOf,MAAI,UAAU,SAAS,QAAQ,QAAQ,CAAC,OAAO,MAAM,GAAG,WAAW;AAOnE,QAAM,WAAW;AAAA,IACd,UAAU,CAAC,eAAe,CAAC,MAAM,kBAAkB,CAAC,GAAG,KAAK;AAAA,IAC5D,UAAU,CAAC,eAAe,CAAC,MAAM,oBAAoB,CAAC,GAAG,KAAK;AAAA,IAC9D,QAAQ,CAAC,aAAa,CAAC,MAAM,gBAAgB,CAAC,GAAG,KAAK;AAAA,EAC5D;AAKG,+BACA;AAEG,SAAK,iBAAiB,GAAG,SAAS,QAAQ;AAC1C,SAAK,UAAU,IAAI,WAAW;AAAA,EAChC;AALQ;AAUT,6BACA;AACG,QAAI,OAAO,eAAe,QAAQ,YAAY;AAAE,oBAAc,IAAI,KAAK;AAAA,IAAI;AAG3E,SAAK,oBAAoB,GAAG,SAAS,QAAQ;AAC7C,SAAK,oBAAoB,GAAG,SAAS,QAAQ;AAC7C,SAAK,oBAAoB,GAAG,SAAS,MAAM;AAC3C,SAAK,UAAU,OAAO,WAAW;AAAA,EACnC;AATQ;AAWT,MAAI,SACJ;AACG;EACF;AAOD,6BAA2B,OAC3B;AACG,QAAI,MAAM,WAAW,UAAU,CAAC,MAAM,WAAW;AAAE;AAAA,IAAS;AAE5D,UAAM,eAAc;AAEpB,eAAW;AAGX,sBAAkB,SAAS;AAC3B,uBAAmB,EAAE,GAAG,MAAM,SAAS,GAAG,MAAM;AAGhD,SAAK,iBAAiB,GAAG,SAAS,QAAQ;AAC1C,SAAK,iBAAiB,GAAG,SAAS,MAAM;AAExC,SAAK,kBAAkB,MAAM,SAAS;AAAA,EACxC;AAjBQ;AAwBT,+BAA6B,OAC7B;AAIG,QAAK,OAAM,UAAU,OAAO,GAC5B;AACG,sBAAgB,KAAK;AACrB;AAAA,IACF;AAED,QAAI,MAAM,WAAW,MAAM,CAAC,MAAM,WAAW;AAAE;AAAA,IAAS;AAExD,UAAM,eAAc;AAGpB,QAAI,CAAC,YAAY,OAAO,eAAe,QAAQ,YAC/C;AACG,iBAAW;AACX,oBAAc,IAAI,IAAI;AAAA,IACxB;AAGD,UAAM,UAAU,gBAAgB,OAAQ,OAAM,UAAU,iBAAiB;AAEzE,UAAM,SAAS,gBAAgB,MAAO,OAAM,UAAU,iBAAiB;AAEvE,QAAI,MACJ;AACG,cAAQ,QAAQ,OAAO;AAAA,IACzB,OAED;AACG,sBAAgB,OAAO;AACvB,sBAAgB,MAAM;AAEtB,eAAS,IAAI,eAAe;AAAA,IAC9B;AAAA,EACH;AAtCQ;AA6CT,2BAAyB,OACzB;AACG,UAAM,eAAc;AAEpB,eAAW;AACX,QAAI,OAAO,eAAe,QAAQ,YAAY;AAAE,oBAAc,IAAI,KAAK;AAAA,IAAI;AAE3E,SAAK,oBAAoB,GAAG,SAAS,QAAQ;AAC7C,SAAK,oBAAoB,GAAG,SAAS,MAAM;AAAA,EAC7C;AATQ;AAWT,SAAO;AAAA,IAEJ,QAAQ,CAAC,YACT;AACG,UAAI,OAAO,QAAQ,WAAW,WAC9B;AACG,kBAAS,QAAQ;AACjB,YAAI,SAAQ;AAAE,4BAAiB;AAAA,QAAK,OAC/B;AAAE,0BAAiB;AAAA,QAAG;AAAA,MAC7B;AAED,UAAI,OAAO,QAAQ,WAAW,UAC9B;AACG,iBAAS,QAAQ;AAAA,MACnB;AAED,UAAI,QAAQ,aAAa,UAAU,QAAQ,aAAa,UACxD;AACG,mBAAW,QAAQ;AACnB,kBAAU,SAAS,QAAQ,QAAQ,CAAC,OAAO,MAAM,GAAG,WAAW;AAAA,MACjE;AAED,UAAI,OAAO,QAAQ,SAAS,WAAW;AAAE,eAAO,QAAQ;AAAA,MAAO;AAE/D,UAAI,OAAO,QAAQ,gBAAgB,UACnC;AACG,sBAAc,QAAQ;AACtB,gBAAQ,QAAQ,WAAW;AAAA,MAC7B;AAAA,IACH;AAAA,IAED,SAAS,MAAM,gBAAiB;AAAA,EACtC;AACA;AA9LS;AAgMT,MAAM,iBACN;AAAA,EACG,QAAQ;AAAA,EAER,eAAe,EAAE,UAAU,KAAK,MAAM,SAAQ;AAAA,EAO9C,iBAAiB,CAAA;AAAA,EAEjB,YAAY,EAAE,MAAM,gBAAgB,CAAE,GACtC;AAGG,WAAO,eAAe,MAAM,QAAQ;AAAA,MACjC,KAAK,MAAM;AAAE,eAAO,KAAK;AAAA,MAAQ;AAAA,MACjC,KAAK,CAAC,YACN;AACG,YAAI,OAAO,YAAY,WAAW;AAAE,gBAAM,IAAI,UAAU,0BAA0B;AAAA,QAAI;AAEtF,aAAK,QAAQ;AACb,aAAK,mBAAkB;AAAA,MACzB;AAAA,MACD,YAAY;AAAA,IACrB,CAAO;AAED,WAAO,eAAe,MAAM,eAAe;AAAA,MACxC,KAAK,MAAM;AAAE,eAAO,KAAK;AAAA,MAAe;AAAA,MACxC,KAAK,CAAC,mBACN;AACG,YAAI,mBAAmB,QAAQ,OAAO,mBAAmB,UACzD;AACG,gBAAM,IAAI,UAAU,iCAAiC;AAAA,QACvD;AAED,YAAI,eAAe,aAAa,QAChC;AACG,cAAI,CAAC,OAAO,SAAS,eAAe,QAAQ,GAC5C;AACG,kBAAM,IAAI,UAAU,gDAAgD;AAAA,UACtE;AAED,cAAI,eAAe,WAAW,GAAG;AAAE,kBAAM,IAAI,MAAM,wCAAwC;AAAA,UAAI;AAE/F,eAAK,aAAa,WAAW,eAAe;AAAA,QAC9C;AAED,YAAI,eAAe,SAAS,QAC5B;AACG,cAAI,OAAO,eAAe,SAAS,cAAc,OAAO,eAAe,SAAS,UAChF;AACG,kBAAM,IAAI,UAAU,iDAAiD;AAAA,UACvE;AAED,eAAK,aAAa,OAAO,eAAe;AAAA,QAC1C;AAED,aAAK,mBAAkB;AAAA,MACzB;AAAA,MACD,YAAY;AAAA,IACrB,CAAO;AAGD,QAAI,SAAS,QAAQ;AAAE,WAAK,OAAO;AAAA,IAAO;AAC1C,QAAI,gBAAgB,QAAQ;AAAE,WAAK,cAAc;AAAA,IAAc;AAAA,EACjE;AAAA,EAMD,IAAI,eAAe;AAAE,WAAO,KAAK,aAAa;AAAA,EAAW;AAAA,EAKzD,IAAI,YAAY;AAAE,WAAO,KAAK,aAAa;AAAA,EAAO;AAAA,EAMlD,IAAI,aAAa,UACjB;AACG,QAAI,CAAC,OAAO,SAAS,QAAQ,GAC7B;AACG,YAAM,IAAI,UAAU,oCAAoC;AAAA,IAC1D;AAED,QAAI,WAAW,GAAG;AAAE,YAAM,IAAI,MAAM,4BAA4B;AAAA,IAAI;AAEpE,SAAK,aAAa,WAAW;AAC7B,SAAK,mBAAkB;AAAA,EACzB;AAAA,EAKD,IAAI,UAAU,OACd;AACG,QAAI,OAAO,UAAU,cAAc,OAAO,UAAU,UACpD;AACG,YAAM,IAAI,UAAU,sCAAsC;AAAA,IAC5D;AAED,SAAK,aAAa,OAAO;AACzB,SAAK,mBAAkB;AAAA,EACzB;AAAA,EAKD,QACA;AACG,SAAK,QAAQ;AACb,SAAK,eAAe,EAAE,UAAU,KAAK,MAAM;AAC3C,SAAK,mBAAkB;AAAA,EACzB;AAAA,EAKD,YACA;AACG,SAAK,eAAe,EAAE,UAAU,KAAK,MAAM;AAC3C,SAAK,mBAAkB;AAAA,EACzB;AAAA,EASD,UAAU,SACV;AACG,SAAK,eAAe,KAAK,OAAO;AAEhC,YAAQ,IAAI;AAGZ,WAAO,MACP;AACG,YAAM,QAAQ,KAAK,eAAe,UAAU,CAAC,QAAQ,QAAQ,OAAO;AACpE,UAAI,SAAS,GAAG;AAAE,aAAK,eAAe,OAAO,OAAO,CAAC;AAAA,MAAI;AAAA,IAClE;AAAA,EACI;AAAA,EAED,qBACA;AACG,UAAM,gBAAgB,KAAK;AAG3B,QAAI,cAAc,SAAS,GAC3B;AACG,eAAS,OAAO,GAAG,OAAO,cAAc,QAAQ,QAAQ;AAAE,sBAAc,MAAM,IAAI;AAAA,MAAI;AAAA,IACxF;AAAA,EACH;AACJ;AAlKM;AAyKN,UAAU,UAAU,CAAC,YAAY,IAAI,iBAAiB,OAAO;AAO7D,MAAM,kBAAkB,EAAE,MAAM,GAAG,KAAK,EAAG;AC7vB3C,kBAAkB,UAAU,MAC5B;AACG,QAAM,SAAS,OAAO,SAAS,WAAW,KAAK,KAAK,SAAS,QAAQ,IAAI,KAAK,KAAK,OAAO,UAAU,IAAI;AACxG,SAAO,WAAW,SAAS,SAAS;AACvC;AAJS;;;;;;;;;;;;;eCzHQ,IAAK,EAAA;;AADG,WAAA,GAAA,SAAA,gBAAA,mBAAA,OAAO,KAAK;AAAA;;AALrC,aAOG,QAAA,GAAA,MAAA;iBADQ,IAAI,IAAA,CAAA;;;;8DANqC,IAAO,EAAA,CAAA,GAAA,IAAA;AAAA;;;0EAIvC,IAAM,EAAA,CAAA;AAAA;;;;;;mBAEf,KAAI,EAAA;;oBAAE,KAAK,EAAA;AADG,UAAA,QAAA,KAAA,kBAAA,iBAAA,mBAAA,QAAO,QAAK;;;;6CADjB,KAAM,EAAA;AAAA;;;;;;;;;;;;AAtCjB,MAAAQ,iBAAe;yDAmCsC;uDACF;sDACD;;AAvC7C,MAAA,EAAA,oBAAe;AAItB,MAAA,MAAM,OAAO,OAAO;AAef,mBAAQ,OAAK;AAGb,UAAA,SAAS,OAAO,YAAY,OAAO;AAE9B,QAAA,OAAA,WAAW,YAAU;AAE7B,aAAO,KAAK,QAAQ,KAAK;;;;AAPtB;;;;;;;UAbF,QAAM;AAEV,qBAAA,GAAA,QAAe,OAAA,OAAO,UAAU,WAAW,SAAS,OAAO,KAAK,IAAI,EAAE;AAGtE,qBAAA,GAAA,OAAc,OAAA,OAAO,SAAS,oBAAoBA,eAAa,KAAK,OAAO,IAAI,IAAI,OAAO,oBAC5E,OAAO,gBAAgB,aAAK;AAE1C,qBAAA,GAAA,QAAe,OAAA,OAAO,UAAU,WAAW,SAAS,OAAO,KAAK,IAAI,EAAE;AAEtE,qBAAA,GAAA,UAAgB,OAAA,OAAO,WAAW,WAAW,OAAO,eAAe;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC6DtB,QAAA,gCAAA,CAAA,QAAO,KAAK;AAA9B,MAAA,eAAA,QAAO;;;;;;;;;;;;;;;;;;;;;;;;;;kDAAW,kBAAA,+BAAA,CAAA,kBAAA,SAAO,KAAK,CAAA,CAAA;AAA9B,UAAA,iBAAA,gBAAA,SAAO,QAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAFoB,MAAA,WAAA,SAAS,IAAW,EAAA,IAAA;;;;;;;;mBACxE,IAAO;;iCAAZ,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;+BADgC,IAAkB,IAAA,KAAA;;;;AAH3D,aAOQ,QAAA,QAAA,MAAA;AAJL,aAAqF,QAAA,EAAA;;;;;;;;;wEAFjE,IAAW,EAAA,CAAA;AAAA,2EACT,IAAiB,EAAA,CAAA;AAAA;;;;;AACoB,UAAA,EAAA,WAAA,QAAA,OAAA,aAAA,YAAA,SAAS,KAAW,EAAA,IAAA;AAAA,iBAAA,IAAA,QAAA;;iCAAzC,KAAkB,IAAA,KAAA;AAAA;;qBACjD,KAAO;;mCAAZ,QAAI,KAAA,GAAA;;;;;;;;;;;;;4BAAJ,QAAI,IAAA,YAAA,QAAA,KAAA,GAAA;;;;;;2CAHc,KAAW,EAAA;;6CACT,KAAiB,EAAA;AAAA;;;;qCAErC,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;qBALN,IAAS;;;;;;;;;;;;;;;mEAAT,KAAS,EAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAnED,MAAA,aAAAC,yBAAkB;AAClB,MAAA,EAAA,8BAAyB;AAE9B,QAAA,cAAc,WAAW,UAAU,EAAE;AAErC,QAAA,aAAa,YAAY,SAAS,gBAAgB;;AAClD,QAAA,iBAAiB,YAAY,SAAS,gBAAgB;;AACtD,QAAA,gBAAgB,YAAY,SAAS,aAAa;AAClD,QAAA,qBAAqB,YAAY,SAAS,aAAa;;AACvD,QAAA,8BAA8B,YAAY,SAAS,gBAAgB;;AACnE,QAAA,mBAAmB,YAAY,SAAS,gBAAgB;;AACxD,QAAA,iBAAiB,YAAY,SAAS,aAAa;;MAErD;MAeA;MAIA;uBAciB,MAAM,cAAY;AAE9B,UAAA,WAAW,YAAY,kBAAkB,KAAK,WAAW;iCAErC;AAAK,WAAK,iBAAiB,YAAY,QAAQ;AAAA;AAAhE;+BACe;AAAK,WAAK,oBAAoB,YAAY,QAAQ;AAAA;AAAjE;QAEL,cAAY;AAAI;;;MAGjB,QAAS;YAEF,eAAY;AAAI;;AACb;;;MAGV,eAAe,gBAAe;AAAA;;AAhB3B;;;;;;;;;AA/BN,mBAAA,GAAAA,cAAmB,OAAAA,gBAAc,aAAaA,cAAYC,SAAW;AAAA;;AASrE,mBAAA,GAAA,cAAc,OAAO;QAAa,MAAM;AAAA,QAAM,eAAe,UAAU,KAAK,MAAM,SAAQ;AAAA,SACrF,OAAA,qBAAqB,WAAW;QAAyB,UAAU,YAAY;AAAA,QAAU,QAC/F;AAAA,QAAiB;AAAA;;;AAIhB,mBAAA,GAAA,qBAAqB,gCAAgC,kBAAkB,SAAS,IAAI;AAAA;;AAItF;wBAEE,UAAU,oBAAoB,OAAQ,CAAA,OAAO,WAAM;AAGhD,gBAAM,KAAK,kBAAkB,MAAM,MAAM,OAAO,QAAQ,OAAK,GAAA;YAC1D,OAAO;AAAA,YAAiB,SAAS,OAAM;AAAA;iBAEnC;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACoIhB,aAIK,QAAA,KAAA,MAAA;;;;UAHgB,QAAQ,IAAe;AAAA,UAAE,eAAA,IAAa;AAAA;;;;;;;UAAtC,QAAQ,KAAe;AAAA,UAAE,eAAA,KAAa;AAAA;;;;;;;;;;;;;;;;;;AAzL7C,MAAA,EAAA,cAAc,UAAK;AAExB,QAAA,cAAc,WAAW,UAAU,EAAE;QAGrC,mBAAmB,WAAW,kBAAkB;;AAEhD,QAAA,iBAAiB,YAAY,SAAS,gBAAgB;;AAEtD,QAAA,iBAAiB,YAAY,SAAS,aAAa;;AACnD,QAAA,gBAAgB,YAAY,SAAS,aAAa;MAEpD;qBAyBe,MAAQ,EAAA,kBAAS,MAAM,gCAAa,WAAS,IAAA;AAOzD,QAAA,WAAW;QAOX,kBAAe,CAAA;AAQf,QAAA,WAAW;UAOT,WAAQ;AAAA,MACX,YAAU,CAAG,eAAgB,OAAM,oBAAoB,CAAC,GAAG,KAAK;AAAA,MAChE,YAAU,CAAG,eAAgB,OAAM,oBAAoB,CAAC,GAAG,KAAK;AAAA,MAChE,UAAQ,CAAG,aAAc,OAAM,kBAAkB,CAAC,GAAG,KAAK;AAAA;iCAMnC;AAGvB,WAAK,iBAAoB,GAAA,SAAS,UAAU;AAE5C,mBAAA,GAAA,cAAc,IAAI;AAElB,WAAK,MAAM,UAAU;AAAA;AAPf;+BAae;iBAEV,gBAAe,QAAQ,YAAU;AAAI,uBAAc,IAAI,KAAK;AAAA;AAGvE,WAAK,oBAAuB,GAAA,SAAS,UAAU;AAC/C,WAAK,oBAAuB,GAAA,SAAS,UAAU;AAC/C,WAAK,oBAAuB,GAAA,SAAS,QAAQ;AAE7C,WAAK,MAAM,UAAU;AAErB,mBAAA,GAAA,cAAc,KAAK;AAAA;AAXb;QAeL,SAAM;AAEP;;AAIA,WAAK,MAAM,UAAU;AAAA;AAMf,iCAAoB,OAAK;AAE/B,YAAM,eAAc;AAEpB,iBAAW;AAGX,iBAAW,YAAY,SAAS;UAE5B,SAAS,WAAW,QAAM;AAAI,iBAAS,SAAS,kBAAkB;AAAA;UAClE,SAAS,UAAU,QAAM;AAAI,iBAAS,QAAQ,kBAAkB;AAAA;AAEpE,wBAAe,EAAK,GAAG,MAAM,SAAS,GAAG,MAAM;AAG/C,WAAK,iBAAoB,GAAA,SAAS,UAAU;AAC5C,WAAK,iBAAoB,GAAA,SAAS,QAAQ;AAE1C,WAAK,kBAAkB,MAAM,SAAS;AAAA;AAlBhC;AAwBA,iCAAoB,OAAK;AAE/B,YAAM,eAAc;AAEf,UAAA,CAAA,YAAmB,OAAA,gBAAe,QAAQ,YAAU;AAEtD,mBAAW;AACX,uBAAc,IAAI,IAAI;AAAA;AAGzB,kBAAY,SAAS,IAAG;AAAA,QACrB,OAAO,SAAS,QAAS,OAAM,UAAU,gBAAgB;AAAA,QACzD,QAAQ,SAAS,SAAU,OAAM,UAAU,gBAAgB;AAAA;;AAZxD;AAoBA,+BAAkB,OAAK;AAE7B,iBAAW;iBACA,gBAAe,QAAQ,YAAU;AAAI,uBAAc,IAAI,KAAK;AAAA;AAEvE,YAAM,eAAc;AACpB,WAAK,oBAAuB,GAAA,SAAS,UAAU;AAC/C,WAAK,oBAAuB,GAAA,SAAS,QAAQ;AAE7C,kBAAY,UAAU,KAAK;AAAA;AATrB;;MAaN,WAAW;YAEJ,SAAM;AAAI;;AACP;;;MAGV,eAAe,gBAAe;AAAA;;AA7I3B;;;AAqJI,sBAAa;;;;;;;;;;;UA5KnB,eAAa;wBAGjB,cAAc,MAAM,UAAU,eAAW,CAAK,kBAAkB,UAAU,QAAM,aAAA;AAG1E,cAAA,cAAc;YAChB,aAAW;AAAI,sBAAY,UAAU,cAAc,QAAQ,UAAU,WAAW;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBCwMzD,IAAW,IAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QADjC,MAAM,QAAQ,KAAW,GAAA;AAAA,aAAA;;;;;;;;;;;;;;;;;AAd3B,WAAA,KAAA,MAAA,eAAA,QAAY,EAAE;AACK,WAAA,KAAA,SAAA,kBAAA,oBAAA,QAAY,QAAQ,QAAQ,KAAK,GAAG,IAAA,gBAAA;AAC/C,WAAA,KAAA,cAAA,uBAAA,QAAY,KAAK;AAAA;;AAFlC,aAqBK,QAAA,KAAA,MAAA;;;AAXF,aASS,KAAA,OAAA;;;;;;;;;gFAPiB,IAAa,EAAA,CAAA;AAAA,uDACH,IAAqB,GAAA,CAAA;AAAA,qCAP/B,IAAU,KAAA,IAAA;AAAA,8EACjB,IAAS,EAAA,CAAA;AAAA,mDACH,IAAiB,GAAA,CAAA;AAAA;;;;;;;;;;;;;;6CAIhB,IAAa,EAAA;AAZjC,UAAA,CAAA,WAAA,QAAA,QAAA,iBAAA,gBAAA,QAAY,KAAE;;;AACK,UAAA,CAAA,WAAA,QAAA,QAAA,oBAAA,mBAAA,oBAAA,QAAY,QAAQ,QAAQ,KAAK,GAAG,IAAA,mBAAA;;;AAC/C,UAAA,CAAA,WAAA,QAAA,QAAA,yBAAA,wBAAA,QAAY,QAAK;;;;+CAKZ,IAAS,EAAA;AAAA;;;;;;;;;;sDAHT,IAAmB,EAAA;;;;;;;;;;;qDACjB,IAAoB,EAAA;;;;;;;;;;;;;;;;;;;;;AAnM9B,MAAA,EAAA,4BAAuB;AACvB,MAAA,EAAA,yBAAoB;AAGpB,MAAA,EAAA,mCAAkB;AAClB,MAAA,EAAA,8BAAyB;AAGzB,MAAA,EAAA,iCAAiB;AAGjB,MAAA,EAAA,uBAAkB;AAClB,MAAA,EAAA,2BAAsB;AAItB,MAAA,EAAA,kBAAkB,UAAK;AACvB,MAAA,EAAA,iBAAiB,UAAK;QAG3B,oBAAiB,CAAA,CAAK,mBAAe,CAAA,CAAM,iBAAiB,uBAAuB;AAI9E,MAAA,EAAA,sBAAsB,UAAK;AAC3B,MAAA,EAAA,qBAAqB,UAAK;QAG/B,wBAAqB,CAAA,CAAK,uBAAmB,CAAA,CAAM,qBAAqB,uBAAuB;AAG/F,QAAA,aAAc,kCAAK;eAEX,YAAY,QAAQ,WAAW,aAAa,YAAY,QAAQ,QAAM;UAE1E,gBAAgB,IAAI,cAAY;AAAI,oBAAY,WAAW,KAAK,WAAW;AAAA;AAK3E,UAAA,SAAS,kBAAkB,SAAS,QAAQ,MAAM,WAAW,SAAS,eAAa;YAGhF,SAAS,yBAAyB,aAAW;AAAI,mBAAS,cAAc;;AAG5E,iBAAS,KAAK;;;KAfH;AAuBf,MAAA,CAAA,WAAW,qBAAqB,GAAA;AAAK,eAAW,uBAAuB,SAAS,cAAc,CAAA;AAAA;AAC9F,MAAA,CAAA,WAAW,kBAAkB,GAAA;AAAK,eAAW,oBAAoB,SAAS,WAAW,CAAA;AAAA;QAcpF,UAAU,WAAW,UAAU;QAG/B,cAAc,QAAQ;AAKtB,QAAA,cAAc,MAAM,QAAQ,SAAQ,IAAI,YACtC,OAAA,YAAY,WAAW,QAAQ;AAQ5B,MAAA,EAAA,wBAAmB;AACnB,MAAA,EAAA,eAAe,yBAAoB;AACnC,MAAA,EAAA,gBAAgB,yBAAoB;AAGpC,MAAA,EAAA,+BAA0B;AAC1B,MAAA,EAAA,sBAAsB,iCAA4B;AAClD,MAAA,EAAA,uBAAuB,iCAA4B;AAG1D,MAAA;AACA,MAAA;iCA2D2B,aAAa,cAAY;AAErD,iBAAA,IAAA,qBAAqB,WAAW;AAChC,iBAAA,IAAA,sBAAsB,YAAY;AAAA;AAH5B;AAeA,6BAAkB,aAAa,cAAc,cAAc,eAAa;AAE9E,gBAAY,SAAS,OAAO,eAAe,OAAQ,YAAM;AAEtD,aAAO,eAAe;AACtB,aAAO,gBAAgB;AACvB,aAAO,cAAc;AACrB,aAAO,eAAe;aAEf;AAAA;AAGV,iBAAA,IAAA,kBAAkB,YAAY;AAC9B,iBAAA,IAAA,iBAAiB,WAAW;AAAA;AAbtB;;;AA8BW,uBAAc;;;;;;;AARrB,oBAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAvIjB,mBAAc,UAAe,mBAAmB,MAAI;AAExD,mBAAW,qBAAqB,EAAE,IAAI,cAAc;AAAA;;;UAIhD,gBAAW,UAAe,gBAAgB,MAAI;AAElD,mBAAW,kBAAkB,EAAE,IAAI,WAAW;AAAA;;;AAkChD,UAAM,kBAAkB,YAAU;AAI1B,cAAA,gBAAgB,yBAAyB,cAAqB,OAAA,eAAe,aAAa,aAC/F;AAED,qBAAA,GAAA,eAAe,aAAa;AAC5B,qBAAA,GAAA,gBAAgB,aAAa;AAE7B,qBAAA,IAAA,gBAAgB,aAAa;AAAA;;;AAI/B,UAAM,yBAAyB,mBAAiB;AAExC,cAAA,aAAa,sBAAsB,gCAAuC,OAAA,sBAAsB,WACrG,oBAAoB;AAErB,qBAAA,GAAA,sBAAsB,UAAU;AAChC,qBAAA,GAAA,uBAAuB,UAAU;AAEjC,qBAAA,IAAA,uBAAuB,UAAU;AAAA;;;AAInC,UAAA,OAAa,iBAAiB,YAAU;AAAI,qBAAA,GAAA,eAAe,oBAAoB;AAAA;;;AAE/E;AAGa,YAAA,OAAA,kBAAkB,YAAU;AAAI,uBAAA,GAAA,gBAAgB,oBAAoB;AAAA;AAG3E,YAAA,sBAAsB,aAAa,SAAS,0BAA0B,WAAS;AAEhF,uBAAA,IAAA,YAAY,QAAQ,wBAAwB,kBAAkB,sBAAoB,WAAA;AAAA;;;;AAKvF,UAAA,OAAa,wBAAwB,UAAQ;AAAI,qBAAA,GAAA,sBAAsB,4BAA4B;AAAA;;;AAGnG,UAAA,OAAa,yBAAyB,UAAQ;AAAI,qBAAA,GAAA,uBAAuB,4BAA4B;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCCuC3B,IAAW,EAAA;qBAAhC,IAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;uHAAM,KAAW,EAAA,CAAA,CAAA;2CAAhC,KAAe,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAF3D,IAAO,IAAA,QAAA,MAAA;;;;;mBAAP,KAAO,EAAA;AAAA;;;;;;;;;;;;;;;;mBAQV,IAAO;AAAY,QAAA,UAAA,iCAAA,SAAO,IAAP;iCAAxB,QAAI,KAAA,GAAA;;;;;;;;;;;;;;AADT,aASK,QAAA,KAAA,MAAA;;;;;;;qBARK,KAAO;;;;;;;;;;;;;;;;AAKwC,MAAA,YAAA,QAAO,OAAI;;;;;;;;;;;;;AAAX,UAAA,QAAA,KAAA,cAAA,aAAA,SAAO,OAAI;AAAA,iBAAA,EAAA,SAAA;AAAA;;;;;;;;;;;;;AAAO,MAAA,WAAA,QAAO,QAAK;;;;;;;;AAAjD,MAAA,WAAA,QAAO,QAAIC,oBAAA,GAAA;;;;;;;;;;;;;;;AAA9B,WAAA,MAAA,SAAA,mBAAA,QAAO,KAAK;AAJE,WAAA,QAAA,SAAA,qBAAA,mBAAA,QAAO,EAAE;sCAEhB,IAAM,IAAC,OAAO,IAAe,EAAA;;;;AAFpD,aAKQ,QAAA,QAAA,MAAA;AADL,aAAwF,QAAA,IAAA;;;;;;;;UADlE,iBAAA,qBAAA,YAAA,KAAA,MAAA,QAAA,QAAO,MAAM,CAAA;AAAA;;;;;;AACH,UAAA,QAAO,MAAI;;;;;;;;;;;;AAA0B,UAAA,QAAA,KAAA,aAAA,YAAA,QAAO,QAAK;AAAA,iBAAA,IAAA,QAAA;AAApE,UAAA,QAAA,KAAA,qBAAA,oBAAA,QAAO,QAAK;;;AAJE,UAAA,QAAA,KAAA,uBAAA,sBAAA,mBAAA,QAAO,KAAE;;;AAGd,UAAA,sBAAA,YAAA,mBAAA,MAAA,KAAA,QAAA;AAAA,2BAAA,OAAA,KAAA,MAAA,QAAO,MAAM;;wCADf,IAAM,IAAC,OAAO,IAAe,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;AAZxC,QAAA,OAAA,YAAY;AAAQ,aAAA;QAEtB,KAAe;AAAA,aAAA;;;;;;;AAKvB,MAAA,YAAA,OAAQ,UAAMC,kBAAA,GAAA;;;;;;;;;;;;;;;AARnB,aAMK,QAAA,KAAA,MAAA;;;;;;;;;;mDARoB,IAAS,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAU7B,UAAA,QAAQ,QAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA5LV,MAAA,eAAe;;QAPV,OAAI,OAAA;AACJ,MAAA,EAAA,YAAY,SAAI;AAChB,MAAA,EAAA,kCAAiB,UAAK;AACtB,MAAA,EAAA,kBAAkB,UAAK;AAEvB,MAAA,EAAA,4BAAuB;MAI9B;AACA,MAAA;MACA;MACA,cAAW,CAAA;AAEX,MAAA,cAAc,WAAW,UAAU,EAAE;MAErC,kBAAkB,KAAK;AAuEZ,yBAAQ,QAAM;;AAInB,UAAA,SAAS;AAGP,YAAA,SAAS,OAAO,YAAY,OAAO;qBAE1B;AAAA,aAEP;AAGF,yBAAe,OAAO,YAAY,QAAQ,SAAS,YAAY,UAAU,YAAY,QAAQ,IAC5F;;aAGC;AAEE,cAAA,6BAAyB,OAAW,eAAe,YAAY,YAAU;AAE1E,qBAAM,MAAS,eAAe,QAAQ,YAAY,QAAQ,SAAS,YAAY,UAC9E,YAAY,QAAQ,IAAI;;;;UAM9B,WAAS;AAAI,mBAAiB,MAAA,YAAY,SAAS,CAAC;AAAA;aAEjD;AAAA,aAEJ;AAEH,SAAG,cAAc,MAAM,GAAG;AAChB,YAAA,IAAA,MAAM,GAAG;AAAA;;AApCV;AAwCN,qBAAU,OAAK;QAMjB,MAAM,QAAQ,YAAY,GAAG,iBAAiB,aAAW;;;AAErD,YAAA,MAAM;AAAA,WAEN;AAEF,cAAM,eAAc;AACpB,cAAM,gBAAe;cAEf,eAAe,QAAQ,UAAW,YAAW,OAAO,OAAO,eAAe;AAC5E,YAAA,QAAQ,UAAU,eAAe,GAAC;AAEnC,uBAAA,GAAA,kBAAkB,QAAQ,eAAe,GAAG,EAAE;AAAA;;;WAK/C;AAEF,cAAM,eAAc;AACpB,cAAM,gBAAe;cAEf,eAAe,QAAQ,UAAW,YAAW,OAAO,OAAO,eAAe;YAC5E,QAAQ,UAAU,eAAe,QAAQ,SAAS,GAAC;AAEpD,uBAAA,GAAA,kBAAkB,QAAQ,eAAe,GAAG,EAAE;AAAA;;;WAK/C;AACF,cAAM,eAAc;AACpB,cAAM,gBAAe;AACd,eAAA,YAAY;WAEjB;AACF,cAAM,eAAc;AACpB,cAAM,gBAAe;YACjB,mBAAmB,SAAS,KAAK,OAAO,KAAK,mBAAmB,KAAK,SAAO;AAE7E,kBAAQ,KAAK,QAAQ,gBAAe;AAAA;;;YAKnC,iBAAc;AAAI,gBAAM,eAAc;AAAA;YACtC,iBAAe;AAAI,gBAAM,gBAAe;AAAA;;;;AApD5C;;;AAgEuB,uBAAc;;;;;AAQtB,QAAA,gBAAA,mCAAA,QAAQ,MAAM,GAAd;;;;;;;;;;;;;;;AApLvB;AAEE,qBAAA,GAAA,UAAW,CAAA,SAAS,KAAK,OAAO,SAAS,OAAO,KAAK,KAAK,OAAO,EAAE,OAAQ,CAAA,OAAO,QAAG;AAE5E,gBAAA,IAAI,KAAK,QAAQ;AAGjB,gBAAA,OAAc,OAAA,EAAE,SAAS,oBAAoB,aAAa,KAAK,EAAE,IAAI,IAAI,EAAE,OACnE,aAAA,EAAE;AAEV,gBAAA,QAAe,OAAA,EAAE,UAAU,cAAc,SAAI,SAAc,MAAM,KAAK,SAAS,EAAE,KAAK,MAAM;AAE5F,gBAAA,QAAe,OAAA,EAAE,UAAU,WAAW,SAAS,EAAE,KAAK;AAGtD,gBAAA,YAAmB,OAAA,EAAE,cAAc,aAAa,EAAE,UAAU,KAAK,CAAC,IAAI,EAAE,aAAa;cAEvF,WAAS;AAAI,kBAAM,KAAU,EAAA,GAAA,GAAG,IAAI,KAAK,MAAM,OAAO,MAAK,CAAA;AAAA;iBAExD;AAAA;;;;AAQZ,UAAA,CAAO,QAAQ,KAAM,YAAW,OAAO,OAAO,eAAe,GAAA;AAAK,qBAAA,GAAA,wBAAwB;AAAA;;;AAEpF,UAAA,YAAY,KAAK,SAAO;wBAE5B,UAAU,KAAK,OAAO;;AAIf,cAAA,kBAAkB,OAAO,GAAA;AAE1B,yBAAA,GAAA,kBAAkB,OAAO;4BACzB,cAAW,CAAA,CAAA;AAAA,UAEE,WAAA,OAAA,YAAY,UAAQ;AAE3B,kBAAA,eAAe,kBAAkB,SAAS,WAAW;4BAC3D,kBAAkB,aAAa,KAAK;4BACpC,cAAc,aAAa,SAAK,CAAA,CAAA;kBAG1B,YAAW,cAAc,SAAS,IAAI,UAAU,GAAG;gBAGrD,MAAM,QAAQ,SAAQ,GAAA;8BAAK,YAAY,WAAW,WAAQ,WAAA;AAAA;;AAI9D,yBAAA,GAAA,wBAAwB;4BACxB,cAAW,CAAA,CAAA;AAAA;iBAGV;AAEJ,uBAAA,GAAA,wBAAwB;0BACxB,cAAW,CAAA,CAAA;0BAEX,UAAU,IAAI,OAAO;AACrB,kBAAQ,MAAM,GAAG;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC4FoC,QAAA,iCAAA,CAAA,2BAA2B,KAAI,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAA/B,KAAQ,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAN9C,IAAA,GAAA,OAAY;AAAA;sBAAgC,MAAK;AAAA,uBAAmB,MAAK;AAAA,IAAM,IAAU;AAAA;;;;;;;;;;;;;;;;;;;;;UAAzF,IAAA,GAAA,QAAY;AAAA;;;yCAAmE,KAAU,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAOxD,IAAe,OAAA,QAAA;yCAAf,IAAe;AAAA;;;;;;;;;;;;;;;;;;;;;;;+CAAf,KAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBALsB;AAAA;;;;;MAAlC,IAAe,OAAA,QAAA;yCAAf,IAAe;AAAA;;;;;;;;;;;;;;;;;;;;;;;+CAAf,KAAe;;;;;;;;;;;;;;;;;;;;;;;;;;AADV,QAAA,iCAAA,CAAA,2BAA2B,KAAI,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAA/B,KAAQ,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAFpE,KAAK;AAAA,aAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA9JD,MAAA,qBAAqB;;AAZhB,MAAA,EAAA,4BAAuB;AACvB,MAAA,EAAA,yBAAoB;QAGpB,OAAI,OAAA;AAEJ,MAAA,EAAA,6BAAwB;AAE7B,QAAA,cAAc,WAAW,UAAU,EAAE;AAErC,QAAA,qBAAqB;QACrB,6BAA0B,EAAK,UAAU;AAG3C,MAAA;QAGE,WAAQ;AAAA,IAEX;IACA;IACA;IAGA;IACA;IACA;IAGA;IACA;;QAGG,aAAU;AAAA,IAEb;IAGA;IACA;IACA;IAGA;IACA;IACA;;AAGC,MAAA;AAGA,MAAA,YAAY;AAGZ,MAAA,kBAAgB;AAAI,YAAK,OAAU,MAAM,UAAU,YAAY,KAAK,QAAQ;AAAA;;;;;;;AAuHvB,sBAAe;;;;;;;;;;;;;;;;;;;;AAKlB,sBAAe;;;;;;;;;;;;;;;;;;;;;;;;;;AAnHpE,UAAA,OAAa,SAAS,UAAQ;AAE5B,qBAAA,GAAA,YAAmB,OAAA,KAAK,cAAc,YAAY,KAAK,YAAY,IAAI;AAEjE,cAAA,YAAY,OAAO,UAAU,KAAK,MAAM,KAAK,KAAK,WAAW,OAAO,KAAK,SAC9E,QAAQ,OAAO,mBAAmB,OAAO,mBAAmB;AACzD,YAAA,WAAW,WAAS;AAAI,uBAAA,GAAA,SAAS,SAAS;AAAA;AAGxC,cAAA,eAAe,KAAK,aAAa;AACnC,YAAA,YAAY,SAAS,cAAc,cAAY;AAAI,uBAAA,GAAA,YAAY,SAAS,YAAY,cAAY,WAAA;AAAA;AAE9F,cAAA,YAAY,KAAK,UAAU;AAC7B,YAAA,YAAY,SAAS,WAAW,WAAS;AAAI,uBAAA,GAAA,YAAY,SAAS,SAAS,WAAS,WAAA;AAAA;AAElF,cAAA,eAAe,KAAK,aAAa;AACnC,YAAA,YAAY,SAAS,cAAc,cAAY;AAAI,uBAAA,GAAA,YAAY,SAAS,YAAY,cAAY,WAAA;AAAA;AAG9F,cAAA,WAAW,KAAK,SAAS;AAC3B,YAAA,aAAa,aAAa,SAAS,OAAK;AAAI,uBAAA,GAAA,YAAY,SAAS,QAAQ,UAAQ,WAAA;AAAA;AAEjF,YAAA,YAAY,SAAS,WAAW,QAAM;AAAI,uBAAA,GAAA,YAAY,SAAS,SAAS,QAAM,WAAA;AAAA;;;;AAKvE,UAAA,OAAA,MAAM,eAAe,UAAQ;cAGlC,IAAI,KAAK;AAEX,YAAA,GAAG,eAAe,SAAS,YAAU;AAAI,uBAAA,GAAA,SAAS,aAAa,EAAE,YAAU,QAAA;AAAA;AAC3E,YAAA,GAAG,iBAAiB,SAAS,cAAY;AAAI,uBAAA,GAAA,SAAS,eAAe,EAAE,cAAY,QAAA;AAAA;AACnF,YAAA,GAAG,kBAAkB,SAAS,eAAa;AAAI,uBAAA,GAAA,SAAS,gBAAgB,EAAE,eAAa,QAAA;AAAA;AACvF,YAAA,GAAG,sBAAsB,SAAS,mBAAiB;AAAI,uBAAA,GAAA,SAAS,oBAAoB,EAAE,mBAAiB,QAAA;AAAA;AAEvG,YAAA,GAAG,wBAAwB,SAAS,qBAAmB;AAExD,uBAAA,GAAA,SAAS,sBAAsB,EAAE,qBAAmB,QAAA;AAAA;AAGnD,YAAA,GAAG,yBAAyB,SAAS,sBAAoB;AAE1D,uBAAA,GAAA,SAAS,uBAAuB,EAAE,sBAAoB,QAAA;AAAA;;;;AAM3D;AAEQ,cAAA,4BAA4B,MAAM,cAAc,eAAe,WAAW,KAAK,aAAa,aACjG;YAEG,uBAAuB,WAAW,YAAU;0BAAI,WAAW,aAAa,oBAAkB,UAAA;AAAA;;;;iBAGnF,MAAM,cAAc,eAAe,UAAQ;AAGhD,cAAA,IAAI,KAAK,aAAa;AAExB,YAAA,GAAG,eAAe,WAAW,YAAU;0BAExC,WAAW,aAAU,OAAU,GAAG,eAAe,aAAa,EAAE,aAAa;;AAG5E,YAAA,GAAG,iBAAiB,WAAW,cAAY;AAAI,uBAAA,GAAA,WAAW,eAAe,EAAE,cAAY,UAAA;AAAA;AACvF,YAAA,GAAG,kBAAkB,WAAW,eAAa;AAAI,uBAAA,GAAA,WAAW,gBAAgB,EAAE,eAAa,UAAA;AAAA;AAG3F,YAAA,GAAG,sBAAsB,WAAW,mBAAiB;0BAEtD,WAAW,oBAAiB,OAAU,GAAG,sBAAsB,WAAW,EAAE,oBAC3E;;AAGA,YAAA,GAAG,wBAAwB,WAAW,qBAAmB;AAE1D,uBAAA,GAAA,WAAW,sBAAsB,EAAE,qBAAmB,UAAA;AAAA;AAGrD,YAAA,GAAG,yBAAyB,WAAW,sBAAoB;AAE5D,uBAAA,GAAA,WAAW,uBAAuB,EAAE,sBAAoB,UAAA;AAAA;;cAKrD,qBAAkB,OAAU,MAAM,cAAc,YAAY,eAAe,aAChF,KAAK,aAAa,WAAW,aAAa;YAEvC,uBAAuB,WAAW,YAAU;0BAAI,WAAW,aAAa,oBAAkB,UAAA;AAAA;AAExF,cAAA,mCAAmC,MAAM,cAAc,sBAAsB,WAClF,KAAK,aAAa,oBAAoB;YAEnC,8BAA8B,WAAW,mBAAiB;0BAE3D,WAAW,oBAAoB,2BAAyB,UAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACvK1D,MAAM,WACb;AAAA,EAIG;AAAA,EAKA,YAAY,aACZ;AACG,SAAK,eAAe;AAAA,EACtB;AAAA,EAeD,IAAI,UAAU,cACd;AACG,WAAO,WAAW,MAAM,UAAU,YAAY;AAAA,EAChD;AAAA,EAKD,MAAM,MACN;AACG,cAAU,MAAM,IAAI;AAEpB,UAAM,YAAY,KAAK,aAAa,OAAO,UAAU,CAAC;AACtD,QAAI,WAAW,MAAM;AAAE,gBAAU,OAAO;AAAA,IAAO;AAAA,EACjD;AAAA,EAiBD,IAAI,UAAU,OACd;AACG,UAAM,UAAU,QAAQ,MAAM,UAAU,KAAK;AAG7C,QAAI,SACJ;AACG,YAAM,YAAY,KAAK,aAAa,OAAO,UAAU,CAAC;AACtD,UAAI,WAAW,MAAM;AAAE,kBAAU,OAAO;AAAA,MAAO;AAAA,IACjD;AAED,WAAO;AAAA,EACT;AACJ;AAxEa;ACQN,MAAM,kBAAkB,kBAC/B;AAAA,EAIG;AAAA,EAOA,YAAY,MAAM,UAAU,CAAE,GAC9B;AACG,UAAM,OAAO;AAEb,SAAK,QAAQ,IAAI,WAAW,IAAI;AAChC,SAAK,OAAO;AASZ,WAAO,eAAe,KAAK,QAAQ,mBAAmB;AAAA,MACnD,KAAK,MAAM,KAAK,QAAQ,kBAAkB;AAAA,IACnD,CAAO;AAAA,EACH;AAAA,EAOD,WAAW,iBACX;AACG,WAAO,UAAU,MAAM,gBAAgB;AAAA,MACpC,SAAS,CAAC,QAAQ;AAAA,MAClB,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,QAAQ;AAAA,QACL,OAAO;AAAA,QACP,OAAO;AAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO,WAAW;AAAE,iBAAO,EAAE,MAAM,KAAK,MAAK;AAAA,QAAK;AAAA,MACpD;AAAA,IACV,CAAO;AAAA,EACH;AAAA,EAOD,IAAI,OAAO;AAAE,WAAO,KAAK;AAAA,EAAQ;AAAA,EAOjC,IAAI,KAAK,MACT;AACG,UAAM,cAAc,OAAO,0BAA0B,KAAK,KAAK;AAG/D,eAAW,cAAc,aACzB;AACG,UAAI,YAAY,YAAY,cAAc;AAAE,eAAO,KAAK,MAAM;AAAA,MAAc;AAAA,IAC9E;AAGD,SAAK,MAAM,MAAM,IAAI;AAAA,EACvB;AAAA,EAOD,kBAAkB,MAClB;AACG,UAAM,kBAAkB,IAAI;AAE5B,QAAI,KAAK,KAAK,kBAAkB,UAChC;AACG,YAAM,aAAa,OAAO,KAAK,QAAQ,aAAa,WAAW,OAC9D,KAAK,QAAQ,SAAS,EAAE,KAAK,cAAc,IAAI,KAAK;AAErD,WAAK,KAAK,OAAO,KAAK,QAAQ,SAAS,aAAa,WAAW,EAAE;AAAA,IACnE;AAAA,EACH;AAAA,EAYD,MAAM,MAAM,SACZ;AAIG,QAAI,KAAK,KAAK,iBAAiB,UAC/B;AACG,WAAK,KAAK,MAAM,KAAK,QAAQ,SAAS,KAAK,UAAU,KAAK,QAAQ,EAAE;AAAA,IACtE;AAED,WAAO,MAAM,MAAM,OAAO;AAAA,EAC5B;AAAA,EAqBD,aAAa,QAAQ;AAAA,IAAE;AAAA,IAAO;AAAA,IAAS;AAAA,IAAK;AAAA,IAAI;AAAA,IAAQ,aAAa;AAAA,IAAM,cAAc;AAAA,IAAO,UAAU,CAAE;AAAA,IAC3G,UAAU,CAAA;AAAA,IAAI,wBAAY;AAAA,IAAM,QAAQ;AAAA,IAAO,eAAe,CAAE;AAAA,IAAE,SAAS;AAAA,IAAM,YAAY;AAAA,IAAO,aAAa,CAAE;AAAA,IAClH;AAAA,MAAW,CAAE,GACf;AAEG,UAAM,gBAAgB,UAAU;AAAA,MAC7B,KAAK;AAAA,QACF,MAAM;AAAA,QACN,OAAO,KAAK,KAAK,SAAS,KAAK;AAAA,MACjC;AAAA,MACD,IAAI;AAAA,QACD,MAAM;AAAA,QACN,OAAO,KAAK,KAAK,SAAS,IAAI;AAAA,MAChC;AAAA,IACH,GAAE,OAAO;AAEV,WAAO,IAAI,QAAQ,CAAC,SAAS,WAC7B;AACG,YAAM,SAAS,IAAI,KAAK;AAAA,QACrB;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,SAAS,UAAU,eAAe;AAAA,UAC/B,KAAK;AAAA,YACF,UAAU,CAAC,SACX;AACG,oBAAM,SAAS,MAAM,IAAI,IAAI,IAAI;AACjC,sBAAQ,MAAM;AAAA,YAChB;AAAA,UACH;AAAA,UACD,IAAI;AAAA,YACD,UAAU,CAAC,SACX;AACG,oBAAM,SAAS,KAAK,GAAG,IAAI,IAAI;AAC/B,sBAAQ,MAAM;AAAA,YAChB;AAAA,UACH;AAAA,QAChB,CAAa;AAAA,QACD,SAAS,aAAa,QAAQ;AAAA,QAC9B,OAAO,MACP;AACG,cAAI,aAAa;AAAE,mBAAO,iEAAiE;AAAA,UAAI,OAC1F;AAAE,oBAAQ,IAAI;AAAA,UAAI;AAAA,QACzB;AAAA,MACH,GAAE,OAAO;AACV,aAAO,OAAO,IAAI;AAAA,IAC3B,CAAO;AAAA,EACH;AAAA,EASD,aAAa,OAAO;AAAA,IAAE;AAAA,IAAO;AAAA,IAAS;AAAA,IAAO;AAAA,IAAU;AAAA,IAAQ,cAAc;AAAA,IAAO,UAAU,CAAE;AAAA,IAAE,wBAAY;AAAA,IAC7G,OAAO;AAAA,IAAgC,QAAQ;AAAA,IAAO,eAAe,CAAA;AAAA,IAAI,SAAS;AAAA,IAAM,YAAY;AAAA,IACnG,aAAa,CAAA;AAAA,IAAI;AAAA,MAAW,CAAE,GAChC;AACG,WAAO,IAAI,QAAQ,CAAC,SAAS,WAC7B;AACG,YAAM,SAAS,IAAI,KAAK;AAAA,QACrB;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,SAAS;AAAA,UACN,IAAI;AAAA,YACD;AAAA,YACA;AAAA,YACA,UAAU,CAAC,SACX;AACG,oBAAM,SAAS,WAAW,SAAS,IAAI,IAAI;AAC3C,sBAAQ,MAAM;AAAA,YAChB;AAAA,UACH;AAAA,QACH;AAAA,QACD,SAAS;AAAA,QACT,OAAO,MACP;AACG,cAAI,aACJ;AACG,mBAAO,IAAI,MAAM,sDAAsD,CAAC;AAAA,UAC1E,OACI;AAAE,oBAAQ,IAAI;AAAA,UAAI;AAAA,QACzB;AAAA,MACH,GAAE,OAAO;AACV,aAAO,OAAO,IAAI;AAAA,IAC3B,CAAO;AAAA,EACH;AACJ;AAlPa;;;;;;;;;;;kDCgB0B,IAAK,EAAA;AAAA,aAAA,KAAA,OAAA,aAAA;;;;AADxC,aAEM,QAAA,KAAA,MAAA;AADJ,aAAyC,KAAA,GAAA;AAAA;;+DAAR,KAAK,EAAA,GAAA;;;;;;;;;;;;;;;;;;;iCAIP,IAAW,EAAA;AAAA;;AAA5C,aAAqE,QAAA,OAAA,MAAA;6BAAT,IAAK,EAAA;;;;;;;;mCAAhC,KAAW,EAAA;AAAA;uCAAgB,KAAK,IAAA;+BAAL,KAAK,EAAA;AAAA;;;;;;;;;;;;;;;;;;kBAN9D,IAAS,MAAAD,oBAAA,GAAA;kBAKT,IAAS,MAAAC,kBAAA,GAAA;;;;;;;;;;;;;;;;;AANhB,aAUM,QAAA,KAAA,MAAA;;;;;;;AADJ,aAAwF,KAAA,MAAA;;0CAAtE,IAAW,EAAA;;;;;UARxB,KAAS,IAAA;;;;;;;;;;;;UAKT,KAAS,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QA/BH,UAAK;QACL,SAAI;QACJ,gBAAW;AACX,MAAA,EAAA,YAAY,UAAK;AACjB,MAAA,EAAA,YAAY,SAAI;AAEvB,MAAA,aAAa;yBAEG;SACb,YAAU;AACb,uBAAiB,WAAU;AAAA,QACnB;AAAA,QACN,SAAS;AAAA,QACT,UAAU,UAAI;AACZ,uBAAA,GAAA,QAAQ,IAAI;AACZ,uBAAa;AAAA;;;AAKnB,eAAW,OAAO,MAAQ,EAAA,OAAO,KAAI,CAAA;AAAA;AAZ9B;;AAwBqD,YAAK,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACtB9D,+BAA+B,QAAQ;AAC5C,QAAM,cAAczB,SAAmB,MAAM;AAC7C,MAAI,CAAC0B,gBAA8B,WAAW;AAAG,WAAO,CAAA;AACxD,QAAM,WAAWC,iBAA+B,WAAW;AAC3D,SAAO,MAAM,KAAK,KAAK,KAAK,EAAE,OAAO,OAAM,GAAE,UAAU,CAAC,SAAS,kBAAkB,EAAE,SAAS;AAChG;AALgB;AAaT,gCAAgC,QAAQ;AAC7C,QAAM,cAAc3B,SAAmB,MAAM;AAC7C,SAAO,QAAQ,MAAM,UAAU,YAAY,YAAY,MAAM,UAAU,MAAM,OAAO,KAAK,CAAE,CAAA;AAC7F;AAHgB;AAYT,mCAAmC,QAAQ,qBAAqB;AACrE,QAAM,cAAcA,SAAmB,MAAM;AAC7C,QAAM,qBAAqB,uBAAuB,WAAW;AAC7D,QAAM,iBAAiB,QAAQ,MAAM,YAAY,oBAAoB,mBAAmB;AACxF,SAAO,YAAY,OAAO;AAAA,IACxB,CAAC,UAAU,MAAM,UAAU;AAAA,EAC/B,CAAG;AACH;AAPgB;AAeT,kCAAkC,QAAQ;AAC/C,QAAM,cAAcA,SAAmB,MAAM;AAC7C,SAAO,YAAY,OAAO;AAAA,IACxB,CAAC,UAAU,MAAM,UAAU;AAAA,EAC/B,CAAG;AACH;AALgB;AAeT,sCAAsC,YAAY,YAAY,EAAE,QAAQ,CAAA,GAAI,aAAa,OAAO,IAAI;AAEzG,QAAM,cAAcA,SAAmB,UAAU;AACjD,QAAM,cAAcA,SAAmB,UAAU;AAEjD,QAAM,mBAAmB0B,gBAA8B,WAAW;AAClE,QAAM,mBAAmBA,gBAA8B,WAAW;AAGlE,MAAI,oBAAoB;AAAkB;AAE1C,MAAI,MAAM,QAAQ;AAChB,YAAQ,MAAM,IAAI,cAAY;AAC5B,kBAAY,SAAS,MAAM,KAAK,UAAU,yBAAyB,KAAK,IAAI,SAAS,QAAQ,CAAC;AAC9F,aAAO,SAAS;AAAA,IACtB,CAAK;AAAA,EACF;AAED,MAAI,CAAC,MAAM,QAAQ,UAAU,KAAK,OAAO,eAAe,UAAU;AAChE,iBAAa,OAAO,QAAQ,UAAU,EAAE,IAAI,WAAS;AACnD,aAAO;AAAA,QACL,MAAM,MAAM;AAAA,QACZ,UAAU,KAAK,IAAI,MAAM,EAAE;AAAA,MAC5B;AAAA,IACP,CAAK;AAAA,EACF;AAED,MAAI,kBAAkB;AAEpB,QAAIE,gBAA8B,gBAAgB,GAAG;AACnD,aAAO,yBAAyB,gBAAgB;AAAA,IACjD;AAED,UAAM,eAAc,yBAAyB,aAAa,YAAY,MAAM,EAAE,OAAO,WAAU,CAAE;AACjG,WAAO,0BAA0B,aAAa,YAAW;AAAA,EAE1D;AAED,QAAM,cAAc,8BAA8B,aAAa,YAAY,MAAM,EAAE,OAAO,WAAU,CAAE;AACtG,SAAO,0BAA0B,aAAa,WAAW;AAE3D;AAzCsB;AA2Cf,kCAAkC,UAAU,WAAW;AAAA,EAC5D,cAAc;AAAA,EACd,QAAQ,CAAE;AAAA,EACV,aAAa,CAAE;AAAA,IACb,IAAI;AAEN,QAAM,WAAWD,iBAA+B,QAAQ;AAExD,MAAI,kBAAkB,CAAA;AACtB,MAAI,CAAC,eAAiB,UAAS,qBAAqB,MAAM,UAAY,SAAS,0BAA0B,WAAW,SAAU;AAC5H,sBAAkB,uBAAuB,QAAQ;AAAA,EAClD;AAED,MAAI,SAAS,qBAAqB,MAAM,QAAQ;AAE9C,QAAI,CAAC,gBAAgB,OAAO;AAC1B,sBAAgB,QAAQ;IACzB;AAED,eAAW,QAAQ,OAAO;AAExB,UAAI,eAAexB,gBAA0B,gBAAgB,OAAO,IAAI;AAExE,UAAI,CAAC,cAAc;AACjB,YAAI,YAAY,gBAAgB,MAAM,KAAK0B,wBAAkC;AAAA,UAC3E,QAAQ,CAAC,EAAE,MAAM,WAAW,UAAU,EAAC,CAAE;AAAA,QAC1C,GAAE,IAAI,CAAC;AACR,uBAAe,gBAAgB,MAAM,YAAY;AAAA,MACzD,WAAiB,CAAC,aAAa,QAAQ;AAC/B,qBAAa,SAAS;AACtB,qBAAa,MAAM,KAAK;AAAA,MACzB;AAED,UAAI,YAAY,aAAa,OAAO,KAAK,UAAQ,KAAK,SAAS,SAAS;AAExE,YAAM,eAAezB,gBAA0B,IAAI;AACnD,UAAI,CAAC,WAAW;AACd,YAAI,eAAe,GAAG;AACpB,uBAAa,OAAO,KAAK,EAAE,MAAM,WAAW,UAAU,cAAc;AAAA,QACrE;AAAA,MACT,OAAa;AACL,kBAAU,YAAY;AACtB,YAAI,UAAU,YAAY,GAAG;AAC3B,uBAAa,OAAO,OAAO,aAAa,OAAO,QAAQ,SAAS,GAAG,CAAC;AAAA,QACrE;AACD,YAAI,aAAa,OAAO,WAAW,GAAG;AACpC,0BAAgB,MAAM,OAAO,gBAAgB,MAAM,QAAQ,YAAY,GAAG,CAAC;AAAA,QAC5E;AAAA,MACF;AAAA,IAEF;AAAA,EAEF;AAED,MAAI,SAAS,0BAA0B,WAAW,QAAQ;AAExD,QAAI,CAAC,gBAAgB,YAAY;AAC/B,sBAAgB,aAAa;IAC9B;AAED,eAAW,aAAa,YAAY;AAElC,UAAI,mBAAmB,gBAAgB,WAAW,KAAK,qBAAmB,gBAAgB,SAAS,UAAU,IAAI;AAEjH,UAAI,CAAC,kBAAkB;AACrB,YAAI,YAAY,gBAAgB,WAAW,KAAK;AAAA,UAC9C,MAAM,UAAU;AAAA,UAChB,QAAQ,CAAC,EAAE,MAAM,WAAW,UAAU,EAAC,CAAE;AAAA,QACnD,CAAS;AACD,2BAAmB,gBAAgB,WAAW,YAAY;AAAA,MAClE,OAAa;AACL,YAAI,CAAC,iBAAiB,QAAQ;AAC5B,2BAAiB,SAAS;QAC3B;AAAA,MACF;AAED,UAAI,YAAY,iBAAiB,OAAO,KAAK,UAAQ,KAAK,SAAS,SAAS;AAE5E,UAAI,CAAC,WAAW;AACd,YAAI,UAAU,WAAW,GAAG;AAC1B,2BAAiB,OAAO,KAAK,EAAE,MAAM,WAAW,UAAU,UAAU,UAAU;AAAA,QAC/E;AAAA,MACT,OAAa;AACL,kBAAU,YAAY,UAAU;AAChC,YAAI,UAAU,YAAY,GAAG;AAC3B,2BAAiB,OAAO,OAAO,iBAAiB,OAAO,QAAQ,SAAS,GAAG,CAAC;AAAA,QAC7E;AACD,YAAI,iBAAiB,OAAO,WAAW,GAAG;AACxC,0BAAgB,WAAW,OAAO,gBAAgB,WAAW,QAAQ,gBAAgB,GAAG,CAAC;AAAA,QAC1F;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAGD,SAAO;AAET;AAjGgB;AAmGT,uCAAuC,UAAU,WAAW,EAAE,QAAQ,CAAA,GAAI,aAAa,OAAO,IAAI;AAEvG,UAAQ,MAAM,IAAI,UAAQ;AACxB,gBAAY,MAAM,KAAK,UAAU,yBAAyBA,gBAA0B,IAAI,IAAI,EAAE;AAC9F,WAAO;AAAA,EACX,CAAG;AAED,eAAa,WAAW,IAAI,eAAa;AACvC,cAAU,WAAW,UAAU,WAAW;AAC1C,WAAO;AAAA,EACX,CAAG;AAED,SAAO,yBAAyB,UAAU,WAAW,EAAE,OAAO,WAAU,CAAE;AAE5E;AAdgB;AAgBT,mCAAmC,MAAM,MAAM,WAAW,EAAE,kBAAkB,MAAM,QAAQ,MAAM,UAAU,MAAM,YAAY,SAAO,CAAA,GAAI;AAE9I,MAAG,gBAAgB,QAAO;AACxB,WAAO,KAAK,MAAM,IAAI,IAAI;AAAA,EAC3B;AACD,MAAI,kBAAkB;AACtB,MAAI,gBAAgBC,QAAkB,SAAS;AAC/C,oBAAkB,mBAAmBD,gBAA0B,IAAI;AACnE,MAAI,cAAc;AAElB,cAAY,aAAa,uBAAuB,IAAI;AACpD,MAAI,WAAW,OAAO,QAAQ;AAC5B,UAAM,YAAYD,gBAA0B,UAAU,OAAO,IAAI;AACjE,QAAI,WAAW;AACb,oBAAc,UAAU,OAAO,OAAO,CAAC,KAAK,UAAU,MAAM,MAAM,UAAU,eAAe;AAC3F,YAAM,sBAAsB,UAAU,OAAO,KAAK,WAAS,MAAM,SAAS,aAAa;AACvF,wBAAkB,sBAAsB,oBAAoB,WAAW;AAAA,IACxE;AAAA,EACF;AAED,YAAU,WAAW,sBAAsB,IAAI,EAAE;AACjD,MAAI,kBAAkB,cAAc;AACpC,MAAI,CAAC,OAAO,UAAU,eAAe,KAAK,CAAC,OAAO;AAChD,uBAAmB;AAAA,EACpB;AAED,SAAO,KAAK,IAAI,GAAG,KAAK,IAAI,iBAAiB,KAAK,MAAM,kBAAkB,eAAe,CAAC,CAAC;AAE7F;AA5BgB;AA8BT,wCAAwC,MAAM,MAAM,WAAW,EAAE,kBAAkB,MAAM,QAAQ,MAAM,UAAU,MAAM,YAAY,SAAO,CAAA,GAAI;AAEnJ,MAAI,kBAAkB;AACtB,MAAI,gBAAgBE,QAAkB,SAAS;AAC/C,oBAAkB,mBAAmB,OAAO,YAAY,KAAK,MAAM,IAAI,KAAK,CAAC;AAC7E,MAAI,cAAc;AAElB,cAAY,aAAa,uBAAuB,IAAI;AACpD,MAAI,WAAW,YAAY,QAAQ;AACjC,UAAM,mBAAmB,UAAU,WAAW,KAAK,oBAAkB,eAAe,SAAS,IAAI;AACjG,QAAI,kBAAkB;AACpB,oBAAc,iBAAiB,OAAO,OAAO,CAAC,KAAK,UAAU,MAAM,MAAM,UAAU,eAAe;AAElG,YAAM,sBAAsB,kBAAkB,QAAQ,KAAK,WAAS,MAAM,SAAS,aAAa;AAChG,wBAAkB,sBAAsB,oBAAoB,WAAW;AAAA,IACxE;AAAA,EACF;AAED,YAAU,WAAW,sBAAsB,IAAI,EAAE;AACjD,MAAI,kBAAkB,cAAc;AACpC,MAAI,CAAC,OAAO,UAAU,eAAe,KAAK,CAAC,OAAO;AAChD,uBAAmB;AAAA,EACpB;AAED,SAAO,KAAK,IAAI,GAAG,KAAK,IAAI,iBAAiB,KAAK,MAAM,kBAAkB,eAAe,CAAC,CAAC;AAE7F;AA1BgB;;;;;;;;;;;;;;;;;;;;;;;;0BC3OyB,IAAQ,EAAA;;;;AAFhB,WAAA,KAAA,SAAA,kBAAA,OAAQ,KAAK;AAAA;;AAA9C,aAGM,QAAA,KAAA,MAAA;AAFJ,aAAoE,KAAA,MAAA;8BAAhB,IAAY,EAAA;;AAChE,aAAuF,KAAA,MAAA;8BAAhB,IAAY,EAAA;;;;;;;;;;;;;;;;;;;;;gCAD/B,KAAY,EAAA;AAAA;;;;;;;;4BACzB,KAAQ,EAAA;AAAA;oDAAwB,KAAY,IAAA;gCAAZ,KAAY,EAAA;AAAA;AAFpD,UAAA,QAAA,MAAA,oBAAA,mBAAA,QAAQ,QAAK;;;;;;;;;;;;;;;;QAfjC,UAAK;AACL,MAAA,EAAA,MAAM,MAAC;AACP,MAAA,EAAA,MAAM,QAAG;AACT,MAAA,EAAA,WAAW,aAAQ;AACnB,MAAA,EAAA,OAAO,MAAC;AACR,MAAA,EAAA,WAAW,QAAG;MAErB,eAAe,QAAQ;;AASyB,mBAAY,UAAA,KAAA,KAAA;;;;;AACO,mBAAY,UAAA,KAAA,KAAA;;;;;;;;;;;;;;;;;;;;;AARlF;wBACC,QAAQ,eAAe,QAAQ;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBCuElB,IAAc;mDAAsB,KAAK;iCAA9C,QAAI,KAAA,GAAA;;;;;;;;;;AALoB,UAAA,cAAA,GAAA,SAAS,oDAAoD;;;AAC7D,UAAA,cAAA,GAAA,SAAS,kEAAkE;;;AAC3E,UAAA,cAAA,GAAA,SAAS,mEAAmE;;;;;;;;;;;;;;;AAJxG,aA4BQ,QAAA,OAAA,MAAA;AA3BN,aAKK,OAAA,EAAA;AAJH,aAA4F,IAAA,GAAA;;AAC5F,aAA0G,IAAA,GAAA;;AAC1G,aAA2G,IAAA,GAAA;;AAC3G,aAA2B,IAAA,GAAA;;;;;;;;;qBAEtB,KAAc;;;;;;;;;qCAAnB,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;iBAIoD,IAAS,IAAC,MAAM,OAAI;;;;;;;;;;;;;;;;;;;;;;;;AAI7C,MAAA,QAAU,qBAAgB,QAAA;AAA1B,uBAAA,QAAA,QAAU;AAAA;;;;;;;;AAKV,MAAA,QAAU,sBAAiB,QAAA;AAA3B,uBAAA,QAAA,QAAU;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAZzC,aAkBK,QAAA,IAAA,MAAA;AAjBH,aAGK,IAAA,GAAA;AAFH,aAC6E,KAAA,CAAA;;;AAE/E,aAIK,IAAA,GAAA;AAHH,aAEM,KAAA,IAAA;;;AAER,aAIK,IAAA,GAAA;AAHH,aAEM,KAAA,IAAA;;;AAER,aAEK,IAAA,GAAA;AADH,aAAoF,KAAA,MAAA;;;;;;AAbtE,gBAAA,YAAA,QAAU,MAAM,MAAM,OAAO,IAAI,CAAjC;AAAA,sBAAU,MAAM,MAAM,OAAO,IAAI,EAAA,MAAA,MAAA,SAAA;AAAA;;AAaf,gBAAA,YAAA,IAAO,GAAA,IAAP,GAAA,CAAA;AAAA,qBAAO,IAAK,GAAA,EAAA,MAAA,MAAA,SAAA;AAAA;;;;;;;8DAbQ,IAAS,IAAC,MAAM,OAAI;AAAA,iBAAA,IAAA,QAAA;;;;AAI7C,6BAAA,QAAA,QAAU;;;;;;;AAKV,6BAAA,QAAA,QAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiBhB,MAAA,WAAA,SAAS,qDAAqD,IAAA;;;;;;AAG5D,MAAA,WAAA,SAAS,QAAQ,IAAA;;;;;AAzC7C,MAAA,WAAA,OAAe,UAAMoB,kBAAA,GAAA;;;;;AALxB,SAAA,cAAA,GAAA,SAAS,0DAA0D;;;;;;;AAqClC,SAAA,cAAA,GAAA,SAAS,uDAAuD;;;;;;;;;;;;;;AAlCvE,mBAAA,KAAA,oBAAA,CAAA,OAAe,MAAM;;;;;;;;AALrD,aAoDO,QAAA,QAAA,MAAA;AAlDL,aAA6E,QAAA,EAAA;;AAE7E,aAqCM,QAAA,GAAA;;;;AAFJ,aAAyG,KAAA,EAAA;;AAI3G,aAOS,QAAA,MAAA;AANP,aAES,QAAA,OAAA;AADP,aAA2B,SAAA,EAAA;;;;AAE7B,aAES,QAAA,OAAA;AADP,aAA4B,SAAA,EAAA;;;;;;;mCA5CbK,gBAAc;AAAA,8BAAW,IAAQ,EAAA;AAAA,kCAAeA,gBAAc;AAAA,mCAwC1C,IAAa,IAAA,EAAA,MAAA,MAAA;AAAA;mDA5CL,IAAc,EAAA,CAAA;AAAA;;;;;AAOtD,UAAA,QAAe,QAAM;;;;;;;;;;;;;;;;;;;;AAFE,qBAAA,KAAA,oBAAA,CAAA,QAAe,MAAM;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAf5C,0BAAe,OAAK;AAC3B,QAAM,eAAc;;AADbA;;UApDD,gBAAgB,WAAW,UAAU;MAEzC;QAEO,mBAAc;QACd,gBAAW;AAEb,kBAAO,OAAK;AACnB,mBAAe,OAAO,OAAO,CAAC;;;AADvB;kCAKoB;AAC3B,mBAAe,QAAQ,UAAI;AACzB,WAAK,QAAQ,KAAK,MAAM;AAAA;AAE1B,gBAAY,QAAQ,UAAU,cAAc;AAC5C,gBAAY,MAAK;AAAA;AALJ;2BAQc;AAC3B,SAAK,cAAa;AAAA;AADJ;AAIP,oBAAS,OAAK;AAErB,UAAM,eAAc;QAEhB;;AAEF,aAAO,KAAK,MAAM,MAAM,aAAa,QAAQ,YAAY,CAAA;AAAA,aAClD;aACA;AAAA;QAGL,KAAK,SAAS;AAAO;UAEnB,QAAQ,KAAK,OAAO,IAAI,KAAK,EAAE;SAEhC;AAAK;QAEN,eAAe,KAAK,WAAQ,MAAK,UAAU,KAAK;AAAA;AAEpD,mBAAe,KAAI;AAAA,MACV;AAAA,MACP,kBAAkB;AAAA,MAClB,mBAAmB;AAAA;;;AAtBd;;AA6DgC,QAAA,OAAA,GAAA,UAAA,UAAU,kBAAgB,KAAA,GAAA;AAA1B,gBAAU,mBAAgB;;;;;;AAK1B,QAAA,OAAA,GAAA,UAAA,UAAU,mBAAiB,KAAA,GAAA;AAA3B,gBAAU,oBAAiB;;;;;;AAmBnB,gBAAY,MAAK;AAAA;;;AA/CjD,aAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACjER,MAAM,6BAA6B,kBAAkB;AAAA,EAElE,YAAY,gBAAgB,SAAS;AAEnC,qBAAiB,eAAe,IAAI,UAAQ;AAC1C,WAAK,QAAQ,KAAK,OAAO,IAAI,KAAK,KAAK;AACvC,UAAI,CAAC,KAAK;AAAO,eAAO;AACxB,aAAO;AAAA,IACb,CAAK,EAAE,OAAO,OAAO;AAEjB,UAAM;AAAA,MACJ,QAAQ;AAAA,QACN,OAAOC;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,QACD;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,UAAU,KAAK;AAAA,MACzC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO,KAAK,KAAK,SAAS,oDAAoD;AAAA,MAC9E,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,gBAAgB;AAAA,IAChC,CAAK;AAAA,EACF;AAAA,EAED,aAAa,KAAK,OAAO,OAAO,UAAU,CAAA,GAAI;AAC5C,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,MAAM,OAAO,EAAE,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,IAC1D,CAAK;AAAA,EACF;AAEH;AAvCqB;;;;;;;;;;;;;;ACqCV,WAAA,KAAA,SAAA,kBAAA,OAAQ,KAAK;AAAA;;AANxB,aASK,QAAA,KAAA,MAAA;;;;;;;mCARa,IAAK,EAAA;AAAA,mCACL,IAAK,EAAA;AAAA;;8CAGK,IAAQ,EAAA,CAAA;AAAA;;;;;;;;;;AACzB,UAAA,CAAA,WAAA,QAAA,KAAA,oBAAA,mBAAA,QAAQ,QAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;QAtCX,aAAQ;QACR,eAAU;AACV,MAAA,EAAA,kBAAS,SAAI;AAEf,oBAAS,OAAK;SAChB;AAAM;AACX,iBAAA,GAAA,UAAU,CAAC;QACP;;AAEF,aAAO,KAAK,MAAM,MAAM,aAAa,QAAQ,YAAY,CAAA;AAAA,aAClD;aACA;AAAA;AAET,aAAS,IAAI;AAAA;AATN;AAYL,MAAA,UAAU;mBAEA;SACP;AAAM;oBACX,WAAO,OAAA;AAAA;AAFA;mBAKK;SACP;AAAM;oBACX,WAAO,OAAA;AAAA;AAFA;;;;;;;;;;;;;;;;;;;;;;AAKN,mBAAA,GAAA,aAAa,UAAU,CAAC;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACUvB,aAA0C,QAAA,KAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;sCAIA,IAAU,EAAA;;;;AADpD,aAIM,QAAA,MAAA,MAAA;AAHJ,aAEM,MAAA,IAAA;AAAA;;;wCAFkC,KAAU,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;AAkB9C,aAES,QAAA,QAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAJT,aAAuF,QAAA,OAAA,MAAA;6BAAxD,IAAI,IAAC,KAAK,IAAI;;;;;;;;uCAAd,IAAI,IAAC,KAAK,MAAI;+BAAd,IAAI,IAAC,KAAK,IAAI;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAJN;AAAA,eAAiB;AAAA;AAAmB,MAAA,QAAK,QAAG,QAAA;AAAR,qBAAA,QAAA,QAAK;AAAA;;;;QAG7E,KAAI,IAAC,SAAS;AAAW,aAAAN;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AARK,aAAA,UAAA,uBAAA,QAAK;;;;;;;;;;;AAD5C,aAsBM,QAAA,MAAA,MAAA;AArBJ,aAAoG,MAAA,IAAA;AAA/F,aAAyF,MAAA,MAAA;;AAC9F,aAAsD,MAAA,IAAA;AAAjD,aAA2C,MAAA,MAAA;AAAZ,sBAAA,QAAA,QAAK,IAAI;;AAC7C,aAAmF,MAAA,IAAA;AAA9E,aAAwE,MAAA,MAAA;AAApB,sBAAA,QAAA,QAAK,YAAY;;AAC1E,aAA8D,MAAA,IAAA;AAAzD,aAAmD,MAAA,MAAA;AAApB,sBAAA,QAAA,QAAK,YAAY;;AACrD,aAEM,MAAA,IAAA;;;AACN,aAQM,MAAA,IAAA;;;AACN,aAIM,MAAA,IAAA;AAHJ,aAES,MAAA,MAAA;;;;;;;;;;;;;;;;AAnB0B,UAAA,CAAA,WAAA,QAAA,KAAA,yBAAA,wBAAA,QAAK,UAAO;;;AACb,UAAA,QAAA,KAAA,OAAA,UAAA,QAAK,MAAI;AAAT,wBAAA,QAAA,QAAK,IAAI;AAAA;AACY,UAAA,QAAA,KAAA,UAAA,OAAA,KAAA,MAAA,QAAK,cAAY;AAAjB,wBAAA,QAAA,QAAK,YAAY;AAAA;AACtC,UAAA,QAAA,KAAA,OAAA,UAAA,QAAK,cAAY;AAAjB,wBAAA,QAAA,QAAK,YAAY;AAAA;;;;AAE0B,2BAAA,QAAA,QAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAjBnF,IAAU,MAAAO,oBAAA;AAGT,MAAA,YAAA,CAAA,OAAW,UAAMR,oBAAA,GAAA;mBAOhB,IAAU;AAAiB,QAAA,UAAA,iCAAA,SAAK,IAAL;iCAAhC,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AApBR,aAQM,QAAA,MAAA,MAAA;AAPJ,aAAsD,MAAA,IAAA;;AACtD,aAAe,MAAA,IAAA;;AACf,aAAmB,MAAA,IAAA;;AACnB,aAAgB,MAAA,IAAA;;AAChB,aAAe,MAAA,IAAA;;AACf,aAAe,MAAA,IAAA;;AACf,aAAmF,MAAA,IAAA;AAA9E,aAAwE,MAAA,CAAA;;AAE/E,aAoCM,QAAA,MAAA,MAAA;;;;;;;;;;;;;;;;;UAnCC,KAAU,IAAA;;;;;;;;;;;;AAGT,UAAA,CAAA,QAAW,QAAM;;;;;;;;;;;;;qBAOhB,KAAU;;;;;;;;;qCAAf,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cArBU,IAAQ;AAAA;;;MAAmB,IAAU,OAAA,QAAA;gCAAV,IAAU;AAAA;;;;;;;;;;;;;;;;;;sCAAV,KAAU;;;;;;;;;;;;;;;;;;;;;;;;QAvB5C,UAAK;QAEV,kBAAkB,MAAM;;AAC1B,MAAA,aAAa;AAIF,0BAAS,MAAI;AAErB,QAAA,CAAA,KAAK,MAAI;YACNS,aAAqB,+CAA+C;AAAA;QAGxE,KAAK,SAAS,QAAM;YAChBA,aAAqB,gCAAgC,KAAK,KAAK,YAAW,IAAK,GAAG;AAAA;AAG1F,UAAM,QAAQ,IAAI;AAAA;AAVL;AAwBW,QAAA,gBAAA,6BAAA,MAAM,gBAAN;2DAegD,MAAM,WAAW,KAAK;;sBACjD,OAAI,KAAA;;;;;sBACiB,eAAY,UAAA,KAAA,KAAA;;;;;sBACjC,eAAY,KAAA;;;;;AAE0B,QAAA,OAAA,GAAA,UAAA,KAAK,KAAG,KAAA,GAAA;AAAR,WAAK,MAAG;;;;;;AAI/C,eAAA,OAAA,KAAK,OAAI,KAAA;;;;4DAEP,MAAM,SAAS,KAAK;6DAMA,MAAM,YAAY,KAAK;;AAxC9C,iBAAU;;;;;;;;;;AAlBtD,mBAAA,GAAE,aAAa,gBAAgB;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACJnB,MAAM,cAAc;AAAA,EAEjC,YAAY,MAAM;AAChB,SAAK,aAAa,SAAS,KAAK,IAAI,CAAC,OAAO,UAAU;AACpD,aAAO;AAAA,QACL,GAAG;AAAA,QACH;AAAA,QACA,IAAI,MAAM,MAAM,QAAQ,MAAM,MAAM,OAAO,SAAU;AAAA,MACtD;AAAA,IACF,CAAA,CAAC;AAAA,EACH;AAAA,EAED,WAAW,OAAO;AAChB,UAAM,aAAazB,gBAAI,KAAK,UAAU;AACtC,eAAW,QAAQ,CAAC,OAAO,eAAe;AACxC,YAAM,UAAU,eAAe;AAAA,IACrC,CAAK;AACD,SAAK,WAAW,IAAI,UAAU;AAAA,EAC/B;AAAA,EAED,iBAAiB;AACf,UAAM,aAAaA,gBAAI,KAAK,UAAU;AACtC,eAAW,KAAK,CAAC,GAAG,MAAM;AACxB,aAAO,EAAE,eAAe,EAAE;AAAA,IAChC,CAAK;AACD,SAAK,WAAW,IAAI,UAAU;AAAA,EAC/B;AAAA,EAED,eAAe;AACb,UAAM,aAAaA,gBAAI,KAAK,UAAU;AACtC,SAAK,WAAW,IAAI,CAAC,GAAG,YAAY;AAAA,MAClC,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL,cAAc;AAAA,MACd,MAAM;AAAA,QACJ,MAAM;AAAA,MACP;AAAA,MACD,SAAS,CAAC,WAAW;AAAA,MACrB,cAAc;AAAA,IACf,CAAA,CAAC;AACF,SAAK,eAAc;AAAA,EACpB;AAAA,EAED,MAAM,QAAQ,MAAM;AAElB,QAAI,OAAO;AACX,QAAI,KAAK,MAAM;AACb,aAAO,eAAe,KAAK,OAAO,MAAM,KAAK;AAAA,IAC9C;AAED,QAAI,OAAO,MAAM,KAAK,eAAe,aAAa,IAAI;AACtD,QAAI,WAAW,KAAK;AAEpB,QAAI,CAAC,UAAU;AACb,cAAQ,MAAM,IAAI;AAClB,YAAMyB,aAAqB,+CAA+C;AAAA,IAC3E;AAED,QAAI,aAAazB,gBAAI,KAAK,UAAU;AAEpC,UAAM,iBAAiB,WAAW,IAAI,WAAS,MAAM,MAAM,QAAQ,CAAA,CAAE;AACrE,UAAM,YAAYL,gBAA0B,gBAAgB,QAAQ;AAEpE,QAAI,WAAW;AACb,YAAM,QAAQ,eAAe,QAAQ,SAAS;AAC9C,iBAAW,OAAO,OAAO;AAAA,QACvB;AAAA,QACA,MAAM;AAAA,MACP;AACD+B,oBAAsB,yBAAyB,SAAS,WAAW,OAAO,IAAI,gBAAgB,SAAS,OAAO;AAAA,IACpH,OAAW;AACL,mBAAa,CAAC,GAAG,YAAY;AAAA,QAC3B,IAAI,SAAU;AAAA,QACd,MAAM;AAAA,QACN,MAAM,SAAS;AAAA,QACf,KAAK,SAAS;AAAA,QACd,cAAc,SAAS,SAAS;AAAA,QAChC,MAAM;AAAA,UACJ;AAAA,UACA,MAAM;AAAA,QACP;AAAA,QACD,SAAS,CAAC,WAAW;AAAA,QACrB,cAAc;AAAA,MACtB,CAAO;AAAA,IACF;AACD,SAAK,WAAW,IAAI,UAAU;AAC9B,SAAK,eAAc;AAAA,EACpB;AAAA,EAED,MAAM,SAAS,OAAO;AACpB,UAAM,aAAa1B,gBAAI,KAAK,UAAU;AACtC,UAAM,OAAO,WAAW,OAAO;AAC/B,QAAI;AACJ,QAAI,KAAK,MAAM;AACb,aAAO,MAAM,SAAS,KAAK,IAAI;AAAA,IACrC,OAAW;AACL,UAAI,WAAW,KAAK;AACpB,UAAI,SAAS;AAAK,eAAO,SAAS;AAClC,UAAI,SAAS;AAAY,eAAO,SAAS;AACzC,YAAM,QAAQ,MAAM,KAAK,KAAK,KAAK;AACnC,aAAOL,gBAA0B,OAAO,QAAQ;AAChD,UAAI,CAAC,MAAM;AACT,oBAAY,UAAU,UAAU,MAAM,gBAAgB,IAAI;AAC1D,eAAO,MAAM,KAAK,eAAe,OAAO,QAAQ;AAChD+B,sBAAsB,gCAAgC,KAAK,sEAAsE;AAAA,MAClI;AAAA,IACF;AACD,SAAK,MAAM,OAAO,IAAI;AAAA,EACvB;AAAA,EAED,YAAY,OAAO;AACjB,UAAM,aAAa1B,gBAAI,KAAK,UAAU;AACtC,eAAW,OAAO,OAAO,CAAC;AAC1B,SAAK,WAAW,IAAI,UAAU;AAAA,EAC/B;AAAA,EAED,SAAS;AACP,WAAOA,gBAAI,KAAK,UAAU;AAAA,EAC3B;AAEH;AAzHqB;;;;;;;;;;;;;;;;ACwCgB,MAAA,WAAA,SAAS,iDAAiD,IAAA;;;;;;AAGxD,MAAA,YAAA,SAAS,QAAQ,IAAA;;;;;;;;;;AAbhD,SAAA,cAAA,GAAA,SAAS,sDAAsD;;;AAEjD,SAAA,cAAA,GAAA,SAAS,qEAAqE;;;AAEpD,SAAA,cAAA,GAAA,SAAS,gEAAgE;;;;;;;;;;;;;;;;;;;;;;;;;AANvH,aAmBO,QAAA,QAAA,MAAA;AAjBL,aAAyE,QAAA,EAAA;;AAEzE,aAAsG,QAAA,EAAA;;AAEtG,aAA2H,QAAA,EAAA;;;;AAI3H,aAOS,QAAA,MAAA;AANP,aAES,QAAA,OAAA;AADP,aAA2B,SAAA,EAAA;;;;AAE7B,aAES,QAAA,OAAA;AADP,aAA4B,SAAA,EAAA;;;;;;;mCAJO,IAAa,IAAA,EAAA,MAAA,MAAA;AAAA;mDAXL,IAAc,EAAA,CAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAxBvD,gBAAgB,WAAW,UAAU;QAElC,SAAI;QACJ,gBAAW;QAEhB,QAAK,IAAO,cAAc,QAAQ,WAAW,SAAS,UAAU,CAAA;MAElE;kCAEyB;AAC3B,gBAAY,QAAQ,QAAQ,MAAM,OAAM,CAAA;AACxC,gBAAY,MAAK;AAAA;AAFJ;2BAKc;AAC3B,SAAK,cAAa;AAAA;AADJ;;AAwBiC,gBAAY,MAAK;AAAA;;;AAdjD,aAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC/BR,MAAM,yBAAyB,kBAAkB;AAAA,EAE9D,YAAY,OAAO,OAAO,UAAU,CAAA,GAAI;AACtC,UAAM;AAAA,MACJ,QAAQ;AAAA,QACN,OAAO2B;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,QACD;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,UAAU,IAAI;AAAA,MACxC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO,KAAK,KAAK,SAAS,gDAAgD;AAAA,MAC1E,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,gBAAgB;AAAA,IAChC,CAAK;AAAA,EACF;AAAA,EAED,aAAa,KAAK,OAAO,OAAO,UAAU,CAAA,GAAI;AAC5C,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,MAAM,OAAO,EAAE,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,IAC1D,CAAK;AAAA,EACF;AACH;AA/BqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACoDb,aAMK,QAAA,IAAA,MAAA;AALH,aAA6E,IAAA,GAAA;AAAzE,aAAoE,KAAA,MAAA;8BAAR,IAAI,GAAA;;AACpE,aAA8F,IAAA,GAAA;AAA1F,aAAqF,KAAA,MAAA;8BAAX,IAAO,GAAA;;AACrF,aAEK,IAAA,GAAA;AADH,aAAoF,KAAA,MAAA;;;;;;;AAApD,gBAAA,YAAA,IAAO,GAAA,IAAP,GAAA,CAAA;AAAA,qBAAO,IAAK,GAAA,EAAA,MAAA,MAAA,SAAA;AAAA;;;;;;;wCAHkB,IAAI,KAAA;gCAAJ,IAAI,GAAA;AAAA;wCACU,IAAO,KAAA;gCAAP,IAAO,GAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAU1D,MAAA,WAAA,SAAS,6CAA6C,IAAA;;;;;;AAGpD,MAAA,YAAA,SAAS,QAAQ,IAAA;;;;mBAhB3C,IAAW;mDAA8B,KAAK;iCAAnD,QAAI,KAAA,GAAA;;;;;;;;;AARJ,QAAA,cAAA,GAAA,SAAS,kDAAkD;;;;;AAItD,UAAA,cAAA,GAAA,SAAS,2CAA2C;;;AACpD,UAAA,cAAA,GAAA,SAAS,8CAA8C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAPlE,aA8BO,QAAA,QAAA,MAAA;AA5BL,aAAqE,QAAA,CAAA;;AAErE,aAeQ,QAAA,KAAA;AAdN,aAIK,OAAA,EAAA;AAHH,aAAgE,IAAA,GAAA;;AAChE,aAAmE,IAAA,GAAA;;AACnE,aAA4G,IAAA,GAAA;AAAnF,aAA8E,KAAA,CAAA;;;;;;AAa3G,aAOS,QAAA,MAAA;AANP,aAES,QAAA,OAAA;AADP,aAA2B,SAAA,EAAA;;;;AAE7B,aAES,QAAA,OAAA;AADP,aAA4B,SAAA,EAAA;;;;;;6BAlBU,IAAG,EAAA;AAAA,mCAcN,IAAa,IAAA,EAAA,MAAA,MAAA;AAAA;mDAtBL,IAAc,EAAA,CAAA;AAAA;;;;;;qBAUpD,KAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UA9Cd,gBAAgB,WAAW,UAAU;QAElC,gBAAW;QACX,gBAAW;MAElB;OAEC,aAAW;AACd,kBAAc,WAAW,SAAS,YAAY;AAAA;iBAGpC;oBACV,cAAW,CAAA,GAAO,aAAe,EAAA,MAAM,IAAI,SAAS,GAAE,CAAA,CAAA;;;AAD/C;AAKA,kBAAO,OAAK;AACnB,gBAAY,OAAO,OAAO,CAAC;;;AADpB;kCAKoB;AAC3B,gBAAY,QAAQ,QAAQ,WAAW;AACvC,gBAAY,MAAK;AAAA;AAFJ;2BAKc;AAC3B,SAAK,cAAa;AAAA;AADJ;;;;;;;;;;;;AAmCiC,gBAAY,MAAK;AAAA;;;AAzBjD,aAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACzCR,MAAM,0BAA0B,kBAAkB;AAAA,EAE/D,YAAY,MAAM,SAAS;AACzB,UAAM;AAAA,MACJ,OAAO;AAAA,MACP,QAAQ;AAAA,QACN,OAAOC;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,QACD;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,QAAQ,IAAI;AAAA,MACtC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO,KAAK,KAAK,SAAS,4CAA4C;AAAA,MACtE,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,gBAAgB;AAAA,IAChC,CAAK;AAAA,EACF;AAAA,EAED,aAAa,KAAK,MAAM,UAAU,IAAI;AACpC,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,MAAM,OAAO,EAAE,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,IAC1D,CAAK;AAAA,EACF;AACH;AAhCqB;;;;;;;;;;;;;;;;;;ACUf,aAA4E,QAAA,KAAA,MAAA;AAAA;;;;;;;;;;;;;;AAO7C,WAAA,GAAA,SAAA,gBAAA,UAAA,OAAI,OAAI,gBAAA;AAAA;;AAAxB,aAA+B,QAAA,GAAA,MAAA;AAAA;;AAAf,UAAA,QAAA,KAAA,kBAAA,iBAAA,UAAA,QAAI,OAAI,mBAAA;;;;;;;;;;;;;;;;;;;;AAGrC,aAA0D,QAAA,KAAA,MAAA;AAAA;;;;;;;;;;;;;iBAF3D,SAAS,IAAG,GAAC,KAAK,IAAA;;;;;;kBAThB,IAAgB,MAAI,IAAK,KAAG,KAACJ,oBAAA;AAQ3B,MAAA,YAAA,OAAI,QAAIR,oBAAA,GAAA;AAER,MAAA,YAAA,OAAI,aAASC,kBAAA;;;;;;;;;;;;;;;;;;;;;;;;sCALG,IAAU,EAAA;kCACd,IAAS,OAAK,IAAG,GAAC,KAAK;;;;;;;;AAH1C,aAUM,QAAA,KAAA,MAAA;;;;;;;;;;;;;;;;UAbD,IAAgB,MAAI,IAAK,KAAG,GAAC;;;;;;;;;;;;AAQ3B,UAAA,OAAI,MAAI;;;;;;;;;;;;gDACZ,SAAS,IAAG,GAAC,KAAK,IAAA;AAAA,iBAAA,IAAA,QAAA;AACd,UAAA,OAAI,WAAS;;;;;;;;;;;;;wCALG,IAAU,EAAA;AAAA;;oCACd,IAAS,OAAK,IAAG,GAAC,KAAK;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;AAPrC,MAAA,aAAA,OAAK,OAAMY,MAAA;AAAoC,QAAA,UAAA,iCAAA,QAAI,OAAJ;iCAApD,QAAI,KAAA,GAAA;;;;;;;;;;;;;AADsC,WAAA,KAAA,SAAA,kBAAA,OAAQ,KAAK;AAAA;;AAA3D,aAiBM,QAAA,KAAA,MAAA;;;;;;;AAhBG,qBAAA,QAAK,OAAMA,MAAA;;;AAD0B,UAAA,QAAA,MAAA,oBAAA,mBAAA,QAAQ,QAAK;;;;;;;;;;;;;;;;eACtC,gCAAG,CAAK,IAAI,QAAZ;;QARR,cAAS;QACT,SAAI;AACJ,MAAA,EAAA,aAAa,UAAK;AAClB,MAAA,EAAA,mBAAmB,UAAK;;oBASV,YAAY,IAAI,KAAK;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACbhD,MAAM,SAAS,wBAAC,WAAW,CAAC,YAAY,gBAAgB,GAAG,UAAU,QAAQ,OAAO,CAAC,GAAG,GAAG,MAAM,IAAI,YAAY,IAAI,KAAK,CAAC,KAA5G;AACf,MAAM,SAAS,OAAO,UAAU,WAAW;AAE3C,MAAM,QAAQ;AAAA,EACZ,OAAO;AAAA,EACP,yBAAyB;AAAA,EACzB,qBAAqB;AAAA,EACrB,oBAAoB;AAAA,EACpB,gBAAgB;AAAA,EAChB,qBAAqB;AAAA,EACrB,iBAAiB;AAAA,EACjB,MAAM;AAAA,IACJ,YAAY;AAAA,IACZ,QAAQ;AAAA,IACR,YAAY;AAAA,IACZ,QAAQ;AAAA,IACR,YAAY;AAAA,IACZ,QAAQ;AAAA,IACR,WAAW;AAAA,IACX,OAAO;AAAA,IACP,UAAU;AAAA,IACV,MAAM;AAAA,IACN,UAAU;AAAA,IACV,MAAM;AAAA,IACN,YAAY;AAAA,IACZ,QAAQ;AAAA,IACR,YAAY;AAAA,IACZ,QAAQ;AAAA,IACR,eAAe;AAAA,IACf,WAAW;AAAA,IACX,iBAAiB;AAAA,IACjB,aAAa;AAAA,IACb,qBAAqB;AAAA,IACrB,iBAAiB;AAAA,EAClB;AAAA,EACD,MAAM;AAAA,IACJ,qBAAqB;AAAA,IACrB,UAAU;AAAA,IACV,MAAM;AAAA,IACN,cAAc;AAAA,IACd,UAAU;AAAA,IACV,SAAS;AAAA,IACT,KAAK;AAAA,IACL,YAAY;AAAA,IACZ,QAAQ;AAAA,IACR,kBAAkB;AAAA,IAClB,cAAc;AAAA,IACd,WAAW;AAAA,IACX,gBAAgB;AAAA,IAChB,OAAO;AAAA,EACR;AAAA,EACD,WAAW;AAAA,IACT,cAAc;AAAA,IACd,UAAU;AAAA,IACV,SAAS;AAAA,IACT,KAAK;AAAA,IACL,YAAY;AAAA,IACZ,QAAQ;AAAA,IACR,kBAAkB;AAAA,IAClB,cAAc;AAAA,EACf;AAAA,EACD,OAAO;AAAA,IACL,SAAS;AAAA,IACT,UAAU;AAAA,EACX;AACH;AC/DO,MAAM,oBAAoB;AAAA,EAC/B,IAAI,oBAAoB;AACtB,WAAQ,CAAC,YAAY,YAAY,CAAC,KAAK,SAAS,IAAI,UAAU,aAAa,iBAAiB,KACtF,YAAY,YAAY,KAAK,SAAS,IAAI,UAAU,aAAa,iBAAiB;AAAA,EACzF;AACH;AAEO,MAAM,cAAc;AAAA,EACzB,UAAU;AAAA,EACV,SAAS;AAAA,EACT,WAAW;AACb;AAEO,8BAA8B;AAEnC,OAAK,YAAY,SAAS,UAAU,aAAa,kCAAkC;AAAA,IACjF,MAAM;AAAA,IACN,YAAY;AAAA,MACV,EAAE,KAAK,cAAe;AAAA,IACvB;AAAA,IACD,QAAQ,MAAM;AACZ,kBAAY,WAAW;AAAA,IACxB;AAAA,IACD,MAAM,MAAM;AACV,kBAAY,WAAW;AAAA,IACxB;AAAA,IACD,mBAAmB,CAAC,SAAS,KAAK;AAAA,EACtC,CAAG;AAED,OAAK,YAAY,SAAS,UAAU,aAAa,mBAAmB;AAAA,IAClE,MAAM;AAAA,IACN,YAAY;AAAA,MACV,EAAE,KAAK,YAAa;AAAA,IACrB;AAAA,IACD,QAAQ,MAAM;AACZ,kBAAY,YAAY;AAAA,IACzB;AAAA,IACD,MAAM,MAAM;AACV,kBAAY,YAAY;AAAA,IACzB;AAAA,IACD,mBAAmB,CAAC,OAAO,SAAS;AAAA,EACxC,CAAG;AAED,OAAK,YAAY,SAAS,UAAU,aAAa,uBAAuB;AAAA,IACtE,MAAM;AAAA,IACN,YAAY;AAAA,MACV,EAAE,KAAK,UAAW;AAAA,IACnB;AAAA,IACD,QAAQ,MAAM;AACZ,kBAAY,UAAU;AAAA,IACvB;AAAA,IACD,MAAM,MAAM;AACV,kBAAY,UAAU;AAAA,IACvB;AAAA,IACD,mBAAmB,CAAC,SAAS,SAAS;AAAA,EAC1C,CAAG;AAEH;AA5CgB;AA8CT,+BAA+B;AAEpC,MAAI,CAAC,KAAK,KAAK,MAAM;AACnB,QAAI,UAAU;AACd,WAAO,iBAAiB,aAAa,CAAC,UAAU;AAC9C,UAAI,CAAC,OAAO;AAAO;AACnB,UAAI,CAAE,QAAO,uBAAuB;AAAa;AACjD,UAAI,KAAK,eAAe;AAAU;AAClC,YAAM,QAAQ,SAAS,iBAAiB,MAAM,SAAS,MAAM,OAAO;AACpE,UAAI,CAAC,SAAU,MAAM,OAAO;AAAU;AACtC,UAAI,MAAM,WAAW;AAAG;AAExB,YAAM,MAAM,OAAO,IAAI,SAAS,QAAQ,YAAY,MAAM,iBAAiB,OAAO,IAAI,KAAK;AAC3F,YAAM,SAASC,oBAA8B,GAAG,EAC7C,OAAO,YAAS;AACf,cAAM,UAAU,OAAM,SAAS,KAAK,IAAI;AACxC,cAAM,SAAS,OAAM,WAAW,KAAK,KAAK;AAC1C,eAAO,CAAC,WAAW;AAAA,MAC7B,CAAS;AACH,UAAI,CAAC,OAAO;AAAQ;AACpB,aAAO,KAAK,CAAC,GAAG,MAAM,EAAE,SAAS,EAAE,MAAM;AACzC,YAAM,QAAQvC,YAAsB,OAAO,EAAE;AAE7C,UAAI,YAAY,OAAO;AACrB,kBAAU;AACV,eAAO,WAAW,iBAAiB,KAAK;AAAA,MACzC;AAED,gBAAU;AACV,iBAAW,MAAM;AACf,kBAAU;AAAA,MACX,GAAE,GAAG;AAAA,IACZ,CAAK;AAAA,EACF;AACH;AAlCgB;;;ACtByB,MAAA,UAAA,SAAS,kDAAgD,EAAI,gBAAgB,OAAS,MAAI,IAAA;;;;;;;;;AAA7H,aAAoI,QAAA,GAAA,MAAA;;;;AAAjG,UAAA,QAAA,KAAA,YAAA,WAAA,SAAS,kDAAgD,EAAI,gBAAgB,QAAS,KAAI,CAAA,IAAA;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;;;;;;;AAkB7H,aAA+C,QAAA,OAAA,MAAA;AAAA;;;;;;;;;;;;AAXrC,MAAA,WAAA,SAAS,mDAAiD;AAAA,IAChE,UAAU,IAAY;AAAA,IACtB,UAAU,IAAW,GAAC;AAAA;;;;;;;;;;;;;;;;;;;;;;;;0BAI2C,IAAY,EAAA;;;;;;;AAPjF,aAKK,QAAA,MAAA,MAAA;AAJH,aAGU,MAAA,KAAA;;;AAEZ,aAGK,QAAA,MAAA,MAAA;AAFH,aAA2G,MAAA,MAAA;8BAAb,IAAW,EAAA;;AACzG,aAAgF,MAAA,MAAA;8BAAZ,IAAW,EAAA;;;;;;;;;;;AAPvE,UAAA,QAAA,KAAA,aAAA,YAAA,SAAS,mDAAiD;AAAA,QAChE,UAAU,KAAY;AAAA,QACtB,UAAU,KAAW,GAAC;AAAA;;;gCAIsE,KAAW,EAAA;AAAA;oDACrC,KAAW,IAAA;gCAAX,KAAW,EAAA;AAAA;;;;;;;;;;;;;;;;;;;AAgB5E,MAAA,WAAA,SAAS,0CAA0C,IAAA;;;;;;;;;;;;;;AAFtD,aAGQ,QAAA,QAAA,MAAA;AAFN,aAAyB,QAAA,CAAA;;;;0CADU,IAAa,IAAA,EAAA,MAAA,KAAA,CAAA;;;;;;;;;;;;;;;;;;AAH/C,MAAA,WAAA,SAAS,4CAA4C,IAAA;;;;;;;;;;;;;;AAFxD,aAGQ,QAAA,QAAA,MAAA;AAFN,aAA8B,QAAA,CAAA;;;;0CADK,IAAa,IAAA,EAAA,MAAA,KAAA,CAAA;;;;;;;;;;;;;;;;;AA3BrB,MAAA,WAAA,SAAS,2CAA2C,IAAA;;;AAAK,MAAA,WAAA,OAAY,OAAI;;;;;;;;;;AAuCrG,MAAA,WAAA,SAAS,QAAQ,IAAA;;;;kBArCjB,IAAQ,MAAAiC,oBAAA,GAAA;;AAMR,QAAA,UAAe;AAAC,aAAAR;;;;;;;QAkBd,KAAQ;AAAA,aAAAC;;;;;;;;;;;gBA1BwE,IAAE;;;;;;;;;;;;;;;;;;;;;;;;;AAH3F,aA8CM,QAAA,QAAA,MAAA;AA3CJ,aAA+G,QAAA,EAAA;;;;;;;;;;AAyB/G,aAgBQ,QAAA,MAAA;;;AAJN,aAGQ,QAAA,MAAA;AAFN,aAA2B,QAAA,CAAA;;;;;;;mDAzCgD,IAAM,EAAA,GAAA,EAAA,MAAA,MAAA;AAAA;;;;;AAGK,UAAA,QAAA,KAAA,aAAA,YAAA,QAAY,OAAI;AAAA,iBAAA,IAAA,QAAA;UAErG,KAAQ,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAjCP,gBAAgB,WAAW,UAAU;QAElC,gBAAW;QACX,aAAQ;QACR,gBAAW;MAElB;AAEA,MAAA,eAAerB,gBAA0B,WAAW;AACpD,MAAA,cAAc;2BAEI;AACpB,SAAK,cAAa;AAAA;AADX;oBAIM;AACb,gBAAY,QAAQ,QAAO;AAAA,MACzB,UAAU;AAAA,MACV,UAAU;AAAA;AAEZ,gBAAY,MAAK;AAAA;AALV;;AAiC2F,kBAAW,UAAA,KAAA,KAAA;;;;;AACrC,kBAAW,UAAA,KAAA,KAAA;;;;;AAmBzC,gBAAY,MAAK;AAAA;;;AAxCjB,aAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC/BnC,MAAM,uBAAuB,kBAAkB;AAAA,EAS5D,YAAY,aAAa,UAAU,UAAU,CAAA,GAAI;AAC/C,UAAM;AAAA,MACJ,IAAI,uBAAuB,YAAY,MAAM,SAAS;AAAA,MACtD,QAAQ;AAAA,QACN,OAAOmC;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,UACA;AAAA,QACD;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,UAAU,IAAI;AAAA,MACxC,GAAG;AAAA,IACT,CAAK;AACD,SAAK,cAAc;AACnB,SAAK,WAAW;AAAA,EACjB;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO,KAAK,KAAK,SAAS,wCAAwC;AAAA,MAClE,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,gBAAgB;AAAA,IAChC,CAAK;AAAA,EACF;AAAA,EAED,OAAO,cAAc,IAAI;AACvB,WAAO,OAAO,OAAO,GAAG,OAAO,EAAE,OAAO,SAAO,IAAI,OAAO,uBAAuB,IAAI;AAAA,EACtF;AAAA,EAED,aAAa,KAAK,aAAa,UAAU,UAAU,CAAA,GAAI;AACrD,UAAM,OAAO,KAAK,cAAc,YAAY,KAAK,MAAM,SAAS,EAAE;AAClE,QAAI,KAAK,QAAQ;AACf,eAAS,OAAO,MAAM;AACpB,YAAI,OAAO,OAAO,EAAE,OAAO,KAAM,CAAA;AAAA,MAClC;AACD;AAAA,IACD;AACD,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,aAAa,UAAU,OAAO,EAAE,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,IAC3E,CAAK;AAAA,EACF;AAEH;AAtDqB;;;;;;;;;gBC4CuB,IAAE;gBAAC,IAAS,EAAA;gBAAC,GAAC;;;;AAAlD,aAAyD,QAAA,MAAA,MAAA;;;;;;;qBAAlB,KAAS,EAAA;AAAA;;;;;;;;;;AA0B7C,MAAA,UAAA,+BAA+B,IAAK,GAAC,UAAU,gBAAgB,YAAU,IAAA;;;;;;;;AAD5E,aAEO,QAAA,MAAA,MAAA;;;;AADJ,UAAA,QAAA,KAAA,YAAA,WAAA,+BAA+B,KAAK,GAAC,UAAU,gBAAgB,YAAU,IAAA;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;gBANY,IACjF;gBAAC,IAAa,EAAA;;;;yBAHN,IAAS,EAAA;+CAAe,IAAS;;AAEuB,mBAAA,MAAA,yBAAA,CAAA,OAAM,SAAS;;;;AAJtF,aAOM,QAAA,KAAA,MAAA;AANJ,aACkD,KAAA,KAAA;6BADoB,IAAgB,EAAA;;AAGtF,aAEO,KAAA,IAAA;;;;;;;;;;2BAJM,KAAS,EAAA;AAAA;yEAAe,KAAS,KAAA;;;mDADwB,KAAgB,IAAA;+BAAhB,KAAgB,EAAA;AAAA;;qBAIhF,KAAa,EAAA;;AADkD,qBAAA,MAAA,yBAAA,CAAA,QAAM,SAAS;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;AAXxF,aAEM,QAAA,KAAA,MAAA;AADJ,aAAmF,KAAA,KAAA;6BAAb,IAAS,EAAA;;;;;;;kDAAT,KAAS,IAAA;+BAAT,KAAS,EAAA;AAAA;;;;;;;;;;;;;AA8BhF,MAAA,UAAA,SAAS,yBAAyB,IAAA;;;;;;;;;;;iDADtB,IAAa;AAAA;;AAJ5B,aAMS,QAAA,QAAA,MAAA;;;;;;;;2EAFM,KAAa,KAAA;;;;;;;;;;;;;;;;;;;;;;AAzCgD,MAAA,WAAA,OAAM,OAAI;;;;;;;;;;mBAC9E,IAAc,MAAAC,oBAAA,GAAA;;QAQjB,KAAc;AAAA,aAAAhB;QAQZ,KAAa;AAAA,aAAAQ;;;;;;mBAkBhB,IAAc,MAAAP,kBAAA,GAAA;;;;;;;;;;;;;;;;;;;;;AAxCgB,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,OAAM,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;mDAKJ,IAAU,GAAA;;;;;;AAbpB,mBAAA,MAAA,uBAAA,CAAA,WAAmB,IAAa,EAAA;AAAA;;AADjE,aA6DM,QAAA,MAAA,MAAA;AA1DJ,aAOM,MAAA,IAAA;AADJ,aAA+C,MAAA,GAAA;;AAGjD,aAOM,MAAA,IAAA;AANJ,aAKM,MAAA,IAAA;AAJJ,aAAyF,MAAA,CAAA;;;;;;AAO7F,aA0BM,MAAA,IAAA;;;;;;;qCAjC0D,IAAW,EAAA;;;;;AALvC,UAAA,CAAA,WAAA,QAAA,KAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAM,GAAG,GAAA;;;AAKiC,UAAA,EAAA,WAAA,QAAA,MAAA,aAAA,YAAA,QAAM,OAAI;AAAA,iBAAA,IAAA,QAAA;WAC9E,KAAc;AAAA,kBAAA,EAAA,MAAA,KAAA;;;;;;;;;;;WAkClB,KAAc;AAAA,kBAAA,EAAA,MAAA,KAAA;;AAhDW,qBAAA,MAAA,uBAAA,CAAA,YAAmB,KAAa,EAAA;AAAA;;;;;;AAD2B,YAAA,CAAA;AAAA,4BAAA,gCAAA,MAAA,MAAA,EAAA,UAAU,OAAG,IAAA;;;;;;AAAb,UAAA,CAAA;AAAA,0BAAA,gCAAA,MAAA,MAAA,EAAA,UAAU,OAAG,KAAA;;;;;;;;;;;;;;;;;;;;;;;;QAzB5F,UAAK;QACL,UAAK;QAEV,eAAe,MAAM;;QACrB,WAAW,MAAM;;QACjB,kBAAkB,MAAM;;yBAEV;SACb;AAAU;UACT,OAAO,MAAM,OAAO,MAAM,IAAI,MAAM,EAAE;SACvC;AAAI;AACL,QAAA,KAAK,KAAK,QAAQ,KAAK,MAAM,WAAW,KAAK,KAAK,QAAQ,GAAC;AACtD,aAAA,KAAK,MAAM,OAAO,IAAI;AAAA;UAEzB,MAAM,KAAK;AACX,UAAA,YAAY,IAAI,MAAQ,EAAA,UAAU,MAAK,CAAA;WACtC,MAAM,QAAQ,IAAI;AAAA;AATlB;QAYH,iBAAiB,MAAM;QAEvB,aAAa,MAAM,MAAMjB,gBAAI,MAAM,QAAQ,EAAE;;AA8ByB,gBAAS,UAAA,KAAA,KAAA;;;;;AAOP,uBAAgB,UAAA,KAAA,KAAA;;;;;AAmBtE,UAAM,KAAI;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBCnEzB,IAAM;AAAU,QAAA,UAAA,iCAAA,QAAK,YAAL;iCAArB,QAAI,KAAA,GAAA;;;;;;;;;AAF+B,SAAA,cAAA,GAAA,SAAS,kBAAkB;;;;;;;;;AAAhE,aAA8E,QAAA,KAAA,MAAA;AAA9C,aAAwC,KAAA,EAAA;;;;;;;;;;qBAEjE,KAAM;;;;;;;;;qCAAX,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAC2B,IAAI,OAAA,QAAA;4BAAJ,IAAI;AAAA;;;;;;;;;;;;;;;;;;;;;;;kCAAJ,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;AAJlC,MAAA,WAAA,SAAY,KAACiB,kBAAA,GAAA;;;;;;;;AAFpB,aAWK,QAAA,KAAA,MAAA;;;;;;AATE,UAAA,UAAY,GAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QARP,UAAK;QACV,QAAQ,MAAM;;QACd,WAAW,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACkIhB,MAAA,UAAA,SAAS,qDAAmD,EAAI,YAAY,OAAY,MAAI,IAAA;;;;;;;;;AAD/F,aAEG,QAAA,GAAA,MAAA;;;;AADA,UAAA,QAAA,KAAA,YAAA,WAAA,SAAS,qDAAmD,EAAI,YAAY,QAAY,KAAI,CAAA,IAAA;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;AAxD5F,MAAA,WAAA,KAAU,IAAA,WAAW,SAAS,+CAA+C,KAAA;;;;;;;;;qBAGzE,IAAU;AAAsB,QAAA,UAAA,iCAAA,SAAU,MAAV;mCAArC,QAAI,KAAA,GAAA;;;;;mBAyBC,IAAK;AAAiB,QAAA,YAAA,iCAAA,SAAK,IAAL;iCAA3B,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;AA7BN,aAEG,QAAA,GAAA,MAAA;;;;;;;;;;;;;AADA,UAAA,QAAA,KAAA,aAAA,YAAA,MAAU,IAAA,WAAW,SAAS,+CAA+C,KAAA;AAAA,iBAAA,IAAA,QAAA;;uBAGzE,KAAU;;;;qBAyBV,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AALwC,MAAA,WAAA,QAAU,WAAQ;;;;;;;;;;;;;;;;;;;;;;;gBAArB,IAAE;;;;;;AAPsC,WAAA,QAAA,OAAA,mBAAA,QAAU,QAAQ;;;;;;;;;AAArG,aAC8C,QAAA,QAAA,MAAA;AAA3B,sBAAA,QAAA,QAAU,eAAe;;AAC5C,aAIU,QAAA,QAAA,MAAA;AAHS,sBAAA,QAAA,QAAU,eAAe;;AAI5C,aAAsE,QAAA,KAAA,MAAA;;;;;;;;;;;;;;;AAPa,UAAA,QAAA,KAAA,qBAAA,oBAAA,QAAU,WAAQ;;;;AAClF,wBAAA,QAAA,QAAU,eAAe;AAAA;AAEzB,UAAA,QAAA,KAAA,UAAA,OAAA,KAAA,MAAA,QAAU,iBAAe;AAAzB,wBAAA,QAAA,QAAU,eAAe;AAAA;AAIE,UAAA,QAAA,KAAA,aAAA,YAAA,QAAU,WAAQ;AAAA,iBAAA,IAAA,QAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAVhE,aAC8C,QAAA,OAAA,MAAA;AAA3B,sBAAA,OAAA,QAAU,eAAe;;;;;;;;AAAzB,UAAA,QAAA,KAAA,UAAA,MAAA,KAAA,MAAA,QAAU,iBAAe;AAAzB,wBAAA,OAAA,QAAU,eAAe;AAAA;;;;;;;;;;;;;;;;;;;AALtC,MAAA,WAAA,QAAU,OAAI;;;;AAGjB,QAAA,SAAU;AAAmB,aAAAe;;;;;;;;;;;;;;;;;;;;AANE,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAU,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;;;;;;AAFnD,aAqBK,QAAA,MAAA,MAAA;AApBH,aAEK,MAAA,IAAA;AADH,aAAiD,MAAA,GAAA;;AAEnD,aAEK,MAAA,IAAA;AADH,aAA0B,MAAA,IAAA;;;;;;;AAHQ,UAAA,QAAA,KAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAU,GAAG,GAAA;;;AAGzC,UAAA,QAAA,KAAA,aAAA,YAAA,QAAU,OAAI;AAAA,iBAAA,IAAA,QAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuC0B,MAAA,WAAA,QAAK,WAAQ;;;;;;;;;;;;;;;;;;;;;;;gBAAhB,IAAE;;;;;;AAPsC,WAAA,QAAA,OAAA,mBAAA,QAAK,QAAQ;;;;;;;;;AAAhG,aACyC,QAAA,QAAA,MAAA;AAAtB,sBAAA,QAAA,QAAK,eAAe;;AACvC,aAIU,QAAA,QAAA,MAAA;AAHS,sBAAA,QAAA,QAAK,eAAe;;AAIvC,aAAiE,QAAA,KAAA,MAAA;;;;;;;;;;;;;;;AAPkB,UAAA,QAAA,MAAA,qBAAA,oBAAA,QAAK,WAAQ;;;;AAC7E,wBAAA,QAAA,QAAK,eAAe;AAAA;AAEpB,UAAA,QAAA,MAAA,UAAA,OAAA,KAAA,MAAA,QAAK,iBAAe;AAApB,wBAAA,QAAA,QAAK,eAAe;AAAA;AAIO,UAAA,QAAA,MAAA,aAAA,YAAA,QAAK,WAAQ;AAAA,iBAAA,IAAA,QAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAV3D,aACyC,QAAA,OAAA,MAAA;AAAtB,sBAAA,OAAA,QAAK,eAAe;;;;;;;;AAApB,UAAA,QAAA,MAAA,UAAA,MAAA,KAAA,MAAA,QAAK,iBAAe;AAApB,wBAAA,OAAA,QAAK,eAAe;AAAA;;;;;;;;;;;;;;;;;;;AALjC,MAAA,WAAA,QAAK,OAAI;;;;;AAGZ,QAAA,SAAU;AAAmB,aAAAR;;;;;;;;;;;;;;;;;;;;;AANE,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAK,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;;;;;;AAF9C,aAqBK,QAAA,MAAA,MAAA;AApBH,aAEK,MAAA,IAAA;AADH,aAA4C,MAAA,GAAA;;AAE9C,aAEK,MAAA,IAAA;AADH,aAAqB,MAAA,IAAA;;;;;;;;AAHa,UAAA,QAAA,MAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAK,GAAG,GAAA;;;AAGpC,UAAA,QAAA,MAAA,aAAA,YAAA,QAAK,OAAI;AAAA,iBAAA,IAAA,QAAA;;;;;;;;;;;;;;;;;;;;;;;;AA+BhB,MAAA,WAAA,KAAU,IAAA,UAAU,SAAS,kDAAkD,KAAA;;;;;;;;;;;;;;AAFlF,aAGQ,QAAA,QAAA,MAAA;AAFN,aAA8B,QAAA,CAAA;;;;0CADK,IAAa,IAAA,EAAA,MAAA,KAAA,CAAA;;;;;AAE/C,UAAA,QAAA,KAAA,aAAA,YAAA,MAAU,IAAA,UAAU,SAAS,kDAAkD,KAAA;AAAA,iBAAA,IAAA,QAAA;AAAA;;;;;;;;;;;;;;;;;;AAMjF,MAAA,WAAA,SAAS,QAAQ,IAAA;;;;;AA1EjB,QAAA,KAAW,GAAA,UAAU,QAAM;AAAM,aAAAR;;;;;;AAiE/B,MAAA,YAAA,KAAW,GAAA,UAAU,OAAM,WAAMC,kBAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;AApE1C,aAiFM,QAAA,QAAA,MAAA;;;AAdJ,aAYQ,QAAA,MAAA;;;;AAJN,aAGQ,QAAA,MAAA;AAFN,aAA2B,QAAA,CAAA;;;;;;;mDA5EgD,IAAM,EAAA,GAAA,EAAA,MAAA,MAAA;AAAA;;;;;;;;;;;;;;;AAoE9E,UAAA,KAAW,GAAA,UAAU,QAAM,QAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAzIlC,gBAAgB,WAAW,UAAU;QAElC,gBAAW;QACX,gBAAW;QACX,aAAQ;QACR,gBAAW;AAEhB,QAAA,qBAAqBgB,qBAAmC,WAAW;AAEnE,QAAA,aAAaC,mBAAiC,aAAW;AAAA,IAC7D,cAAc,mBAAmB;AAAA,IACjC,QAAQ,UAAU;AAAA;AAGhB,MAAA,aAAa,WAAW,OAAO,WAAS,MAAM,SAAS,WAAW,EACnE,IAAI,cAAQ;AACX,aAAS,kBAAkB;WACpB;AAAA;AAGP,MAAA,UAAU,oBAAkB;AAC9B,eAAW,QAAQ,cAAQ;AACnB,YAAA,mBAAmB,UAAU,mBAAmB,KAAK,uBAAoB,kBAAiB,OAAO,SAAS,EAAE;UAC9G,kBAAgB;AAClB,iBAAS,kBAAkB,iBAAiB;AAAA;;;AAK9C,MAAA,QAAQ,WAAW,OAAO,WAAS,MAAM,SAAS,WAAW,EAC9D,IAAI,cAAQ;AACX,aAAS,kBAAkB;WACpB;AAAA;AAGP,MAAA,UAAU,oBAAkB;AAC9B,UAAM,QAAQ,cAAQ;AACd,YAAA,mBAAmB,UAAU,mBAAmB,KAAK,uBAAoB,kBAAiB,OAAO,SAAS,EAAE;UAC9G,kBAAgB;AAClB,iBAAS,kBAAkB,iBAAiB;AAAA;;;MAK9C;2BAEkB;AACpB,SAAK,cAAa;AAAA;AADX;oBAIM;AACb,gBAAY,QAAQ,QAAO;AAAA,MACzB,YAAY,OAAO,YAAY,WAC5B,OAAO,eAAa,UAAU,eAAe,EAC7C,IAAI,eAAS,CAAK,UAAU,MAAM,UAAU,eAAe,CAAA,CAAA;AAAA,MAE9D,OAAO,MACJ,OAAO,UAAQ,KAAK,eAAe,EACnC,IAAI,UAAI;AAAA,QAAO,KAAK,KAAK;AAAA,QAAI,UAAU,KAAK;AAAA;;AAEjD,gBAAY,MAAK;AAAA;AAVV;;wBAuC8B,kBAAe,UAAA,KAAA,KAAA;;;;;wBAGf,kBAAe,UAAA,KAAA,KAAA;;;;;wBAEf,kBAAe,UAAA,KAAA,KAAA;;;;;AAEtB,iBAAA,GAAA,aAAA,OAAA,kBAAkB,KAAK,IAAI,GAAG,KAAK,IAAI,UAAU,UAAU,UAAU,eAAe,CAAA,GAAA,UAAA;AAAA;;sBAkBlF,kBAAe,UAAA,KAAA,KAAA;;;;;sBAGf,kBAAe,UAAA,KAAA,KAAA;;;;;sBAEf,kBAAe,UAAA,KAAA,KAAA;;;;;AAEtB,iBAAA,GAAA,WAAA,OAAA,kBAAkB,KAAK,IAAI,GAAG,KAAK,IAAI,KAAK,UAAU,KAAK,eAAe,CAAA,GAAA,KAAA;AAAA;;AAuBpD,gBAAY,MAAK;AAAA;;;AA3EtB,aAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACxEnC,MAAM,2BAA2B,kBAAkB;AAAA,EAUhE,YAAY,aAAa,aAAa,WAAW,CAAE,GAAE,UAAU,IAAI;AACjE,UAAM;AAAA,MACJ,IAAI,2BAA2B,YAAY,MAAM,YAAY;AAAA,MAC7D,OAAO,UAAU,SAAS,KAAK,KAAK,SAAS,8CAA8C;AAAA,MAC3F,QAAQ;AAAA,QACN,OAAOC;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,UACA;AAAA,UACA;AAAA,QACD;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,UAAU,IAAI;AAAA,MACxC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,gBAAgB;AAAA,IAChC,CAAK;AAAA,EACF;AAAA,EAED,OAAO,cAAc,IAAI;AACvB,WAAO,OAAO,OAAO,GAAG,OAAO,EAAE,OAAO,SAAO,IAAI,OAAO,2BAA2B,IAAI;AAAA,EAC1F;AAAA,EAED,aAAa,KAAK,aAAa,aAAa,WAAW,CAAE,GAAE,UAAU,IAAI;AACvE,UAAM,OAAO,KAAK,cAAc,YAAY,KAAK,MAAM,YAAY,EAAE;AACrE,QAAI,KAAK,QAAQ;AACf,eAAS,OAAO,MAAM;AACpB,YAAI,OAAO,OAAO,EAAE,OAAO,KAAM,CAAA;AAAA,MAClC;AACD;AAAA,IACD;AACD,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,aAAa,aAAa,UAAU,OAAO,EAAE,OAAO,MAAM,EAAE,OAAO,KAAM,CAAA;AAAA,IACxF,CAAK;AAAA,EACF;AAEH;AAtDqB;;;;;;;;;;;;;;AC0BV,SAAA,cAAA,GAAA,SAAS,uBAAuB;AAAA;;AAArC,aAA6C,QAAA,IAAA,MAAA;AAAA;;;;;;;;;;;;;AAKd,MAAA,WAAA,SAAS,gCAAgC,IAAA;;;;;;;;;;;;;;AAFxE,aAGI,QAAA,GAAA,MAAA;AADF,aAA2B,GAAA,CAAA;;;;qCADhB,IAAW,EAAA;;;;;;;;;;;;;;;;;;;mBAOjB,IAAW;AAAqB,QAAA,UAAA,iCAAA,SAAS,YAAT;iCAArC,QAAI,KAAA,GAAA;;;;;;;;;;;;;AADR,aAIM,QAAA,KAAA,MAAA;;;;;;;;qBAHG,KAAW;;;;;;;;;qCAAhB,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAC2B,IAAQ,QAAA,QAAA;4BAAR,IAAQ;AAAA;;;;;;;;;;;;;;;;;;;;;;;kCAAR,IAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAbtC,MAAA,YAAA,KAAiB,KAAA,KAAK,SAAY,MAACX,oBAAA;AAGnC,MAAA,YAAA,OAAM,aAASR,oBAAA,GAAA;kBAOjB,KAAc,KAAG,KAAK,IAAc,OAAAC,kBAAA,GAAA;;;;;;;;;;;;;;;;AAb3C,aAqBK,QAAA,MAAA,MAAA;AAnBH,aAUM,MAAA,IAAA;;;;;;;;;;;;AATC,UAAA,KAAiB,KAAA,KAAK,UAAY,GAAC;;;;;;;;;;;;AAGnC,UAAA,QAAM,WAAS;;;;;;;;;;;;UAOjB,KAAc,KAAG,KAAK,KAAc,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAhC9B,UAAK;QACV,aAAa,MAAM;;QACnB,WAAW,MAAM;;QACjB,gBAAgB,MAAM;;QACtB,iBAAiB,MAAM;+BAEH;UAClB,SAAM,MAAS,mBAAmB,KAAK,MAAM,WAAW,MAAM,MAAM;SACrE;AAAM;AACN,QAAA,CAAA,QAAQ,MAAM,cAAc,OAAO,UAAU,GAAA;YAC1C,KAAK,UAAU,mBAAmB,MAAM,WAAW,MAAM,QAAQ,OAAO,cAAc,eAAe,MAAM,cAAa,CAAA;AAAA;QAE5H,OAAO,MAAM,QAAM;YACf,KAAK,UAAU,cAAc,MAAM,WAAW,MAAM,QAAQ,OAAO,SAAS,eAAe,MAAM,cAAa,CAAA;AAAA;;AAPzG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACeV,MAAA,WAAA,SAAS,8BAA4B;AAAA,IAAI,WAAW,IAAM,GAAA,UAAU;AAAA;;;iBAChE,IAAY,GAAC,SAAS,KAACD,oBAAA,GAAA;;;;;;;;;;;;;AAF9B,aAoBI,QAAA,GAAA,MAAA;;;;;;;AAnBD,UAAA,QAAA,KAAA,aAAA,YAAA,SAAS,8BAA4B;AAAA,QAAI,WAAW,KAAM,GAAA,UAAU;AAAA;;UAChE,KAAY,GAAC,SAAS;AAAC,iBAAA,EAAA,MAAA,KAAA;AAAA;;;;;;;;;;;;;;;AAJkB,QAAA,cAAA,GAAA,SAAS,0BAA0B;;;;;AAAnF,aAAyF,QAAA,GAAA,MAAA;AAAA;;;;;;;;;;;;SAK/E,KAAa;AAAA,aAAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBAWR,IAAY;mDAAkB,KAAK;iCAAxC,QAAI,KAAA,GAAA;;;;;;;;;;;;;UALQ,IAAa,OAAA;AAAA,4BAAA,MAAA,IAAA,GAAA,KAAA,MAAA,CAAA;qCAEX,IAAa,EAAA;AAAA;;AAJ/B,aAUS,QAAA,QAAA,MAAA;;;;4BARO,IAAa,EAAA;;;;mCACd,IAAoB,EAAA;AAAA;;;;;;qBAI1B,KAAY;;;;8BALL,KAAa,EAAA;AAAA;;uCAEX,KAAa,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;iCAP0D,IAAa,EAAA;AAAA;;AAAtG,aACY,QAAA,GAAA,MAAA;;;;;;;;mCAD6E,KAAa,EAAA;AAAA;;;;;;;;;;;;;AAWjD,MAAA,UAAA,OAAM,OAAI;;;;;;;;AAA3C,aAAA,UAAA3B,QAAkB,OAAM,IAAI;;;;;AAA5C,aAAqE,QAAA,QAAA,MAAA;;;;;;;;;;;;;;;;QAlB5E,KAAc;AAAA,aAAAoB;;;;;;;;;;;;AAFrB,aA4BK,QAAA,KAAA,MAAA;;;;;;;;;;;;;;;;;QA5CQ,UAAK;MAEZ,iBAAiB,MAAM;AAEvB,MAAA,gBAAgB;MAChB,eAAe,KAAK,OAAO,OAAO,WAAS,MAAM,WAAW,UAAU,MAAM,aAAa,MAAM,KAAK,MAAM,SAAS;AACnH,MAAA,gBAAgBpB,QAAkB,MAAM,SAAS;kCAExB;AAC3B,iBAAA,GAAA,MAAM,YAAY,aAAa,KAAK,WAASA,QAAkB,KAAK,MAAM,aAAa,GAAA,KAAA;AACvF,UAAM,OAAM;AACZ,iBAAA,GAAA,gBAAgB,KAAK;AAAA;AAHd;;AAiBiD,iBAAA,GAAA,gBAAgB,IAAI;AAAA;;AAKtD,oBAAa,aAAA,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC7BvC,MAAM,aAAa;AAAA,EAEjB,YAAY,OAAO,MAAM;AACvB,SAAK,QAAQ;AACb,SAAK,gBAAgB;AACrB,SAAK,MAAM,IAAI;AAAA,EAChB;AAAA,EAED,cAAc;AACZ,SAAK,WAAW,SAAS,CAAC;AAC1B,SAAK,kBAAkB,SAAS,CAAC;AACjC,SAAK,eAAe,SAAS,CAAC;AAC9B,SAAK,WAAW,SAAS,IAAI;AAC7B,SAAK,sBAAsB,SAAS,KAAK;AAAA,EAC1C;AAAA,EAED,qBAAqB;AAAA,EAEpB;AAAA,EAED,MAAM,MAAM;AACV,SAAK,YAAW;AAChB,SAAK,YAAY,IAAI;AACrB,SAAK,mBAAmB,IAAI;AAAA,EAC7B;AAAA,EAED,YAAY,QAAQ,UAAU;AAC5B,SAAK,cAAc,KAAK,OAAO,UAAU,QAAQ,CAAC;AAAA,EACnD;AAAA,EAED,cAAc;AACZ,SAAK,cAAc,QAAQ,iBAAe,YAAa,CAAA;AACvD,SAAK,gBAAgB;EACtB;AACH;AAlCM;AAoCC,MAAM,iBAAiB,aAAa;AAAA,EAEzC,YAAY,MAAM;AAChB,UAAM,YAAW;AACjB,SAAK,OAAO;AACZ,SAAK,eAAe,IAAI,YAAY,KAAK,IAAI;AAC7C,SAAK,oBAAoB,IAAID,gBAA0B,KAAK,IAAI,IAAI,CAAC;AACrE,SAAK,SAAS,IAAIA,gBAA0B,KAAK,IAAI,CAAC;AACtD,SAAK,gBAAgB,IAAI,KAAK,IAAII,gBAAI,KAAK,eAAe,GAAGA,gBAAI,KAAK,YAAY,GAAGA,gBAAI,KAAK,QAAQ,CAAC,CAAC;AACxG,SAAK,KAAK,KAAK,KAAK;AACpB,SAAK,OAAO,KAAK,KAAK;AACtB,SAAK,OAAO,SAAS,KAAK,KAAK,IAAI;AACnC,SAAK,MAAM,SAAS,KAAK,KAAK,GAAG;AACjC,SAAK,eAAe,KAAK,KAAK;AAC9B,SAAK,aAAa,KAAK;AAAA,EACxB;AAAA,EAED,qBAAqB;AACnB,UAAM,mBAAkB;AAExB,SAAK,YAAY,KAAK,MAAM,WAAW,MAAM;AAC3C,UAAI,CAAC,KAAK,SAAS;AACjB,aAAK,aAAa,IAAIA,gBAAI,KAAK,QAAQ,CAAC;AACxC;AAAA,MACD;AACD,YAAM,eAAeoC,0BAA2C,KAAK,MAAM,OAAO,KAAK,MAAM,KAAK,MAAM,SAAS;AACjH,WAAK,aAAa,IAAI,YAAY;AAAA,IACxC,CAAK;AAED,SAAK,YAAY,KAAK,cAAc,MAAM;AACxC,YAAM,EAAE,SAAS,KAAK,aAAa;AACnC,WAAK,KAAK,IAAI,KAAK,KAAK,IAAI;AAC5B,WAAK,IAAI,IAAI,KAAK,KAAK,GAAG;AAC1B,WAAK,eAAef,wBAAkC,CAAE,GAAE,KAAK,IAAI;AACnE,UAAI,YAAY,MAAM,KAAK,UAAU,uBAAuB,GAAG;AAC7D,aAAK,SAAS,IAAIzB,gBAA0B,IAAI,CAAC;AACjD,cAAM,WAAW,KAAK,IAAII,gBAAI,KAAK,eAAe,GAAGA,gBAAI,KAAK,YAAY,GAAGA,gBAAI,KAAK,QAAQ,CAAC;AAC/F,aAAK,gBAAgB,IAAI,QAAQ;AAAA,MAClC;AAAA,IACP,CAAK;AAED,SAAK,YAAY,KAAK,UAAU,KAAK,OAAO,KAAK,IAAI,CAAC;AACtD,SAAK,YAAY,KAAK,MAAM,QAAQ,KAAK,OAAO,KAAK,IAAI,CAAC;AAC1D,SAAK,YAAY,KAAK,MAAM,UAAU,KAAK,gBAAgB,KAAK,IAAI,CAAC;AAAA,EACtE;AAAA,EAED,kBAAkB;AAChB,SAAK,aAAaqC,eAA6B,KAAK,MAAM,EAAE,QAAQ,KAAK,MAAM,MAAK,CAAE;AACtF,SAAK,eAAehB,wBAAkC,CAAE,GAAE,KAAK,IAAI;AACnE,SAAK,UAAU,KAAK,aAChBrB,gBAAI,KAAK,MAAM,QAAQ,EAAE,0BAA0B,CAAC,CAAC,KAAK,MAAM,YAChEA,gBAAI,KAAK,MAAM,QAAQ,EAAE,qBAAqB,CAAC,CAAC,KAAK,MAAM;AAAA,EAChE;AAAA,EAED,SAAS;AACP,UAAM,SAASA,gBAAI,KAAK,MAAM,MAAM;AACpC,UAAM,sBAAsBA,gBAAI,KAAK,mBAAmB;AACxD,UAAM,WAAWA,gBAAI,KAAK,QAAQ;AAClC,QAAI,aAAa,KAAK,CAAC,qBAAqB;AAC1C,WAAK,SAAS,IAAI,IAAI;AAAA,IACvB,WAAU,QAAQ;AACjB,WAAK,SAAS,IAAI,CAAC,KAAK,KAAK,YAAa,EAAC,SAAS,OAAO,YAAW,CAAE,CAAC;AAAA,IAC/E,OAAW;AACL,WAAK,SAAS,IAAI,CAAC,uBAAuB,aAAa,CAAC;AAAA,IACzD;AAAA,EACF;AAAA,EAGD,OAAO;AACL,UAAM,WAAW,KAAK,IAAIA,gBAAI,KAAK,eAAe,GAAGA,gBAAI,KAAK,YAAY,CAAC;AAC3E,WAAO,KAAK,UAAU,cACpB,KAAK,MAAM,OACX,KAAK,MAAM,WACX,CAAC,EAAE,KAAK,KAAK,IAAI,SAAQ,CAAE,GAC3B,EAAE,eAAe,KAAK,MAAM,cAAe,CACjD;AAAA,EACG;AAAA,EAED,eAAe,UAAU;AACvB,UAAM,OAAO,IAAI,KAAK,QAAQ,EAAE,SAAS,EAAE,OAAO,MAAK,CAAE;AACzD,SAAK,SAAS,IAAI,KAAK,KAAK;AAC5B,WAAO,KAAK,KAAK,OAAO;AAAA,MACtB,CAAC,KAAK,UAAU,0BAA0B,KAAK;AAAA,IACrD,CAAK;AAAA,EACF;AACH;AArFa;AAuFN,MAAM,sBAAsB,aAAa;AAAA,EAE9C,YAAY,WAAW;AACrB,UAAM,YAAW;AACjB,SAAK,YAAY;AACjB,SAAK,OAAO,KAAK,UAAU;AAC3B,SAAK,OAAO,SAAS,KAAK,UAAU,IAAI;AACxC,SAAK,MAAM,SAAS,KAAK,UAAU,GAAG;AACtC,SAAK,eAAe,KAAK,UAAU;AACnC,SAAK,aAAa,KAAK,UAAU;AACjC,SAAK,oBAAoB,IAAI,OAAO,YAAY,KAAK,MAAM,MAAM,MAAM,KAAK,UAAU,IAAI,KAAK,CAAC,IAAI,CAAC;AACrG,SAAK,SAAS,IAAI,OAAO,YAAY,KAAK,MAAM,MAAM,MAAM,KAAK,IAAI,KAAK,CAAC,CAAC;AAC5E,SAAK,gBAAgB,IAAI,KAAK,IAAIA,gBAAI,KAAK,eAAe,GAAGA,gBAAI,KAAK,YAAY,GAAGA,gBAAI,KAAK,QAAQ,CAAC,CAAC;AAAA,EACzG;AAAA,EAED,qBAAqB;AACnB,UAAM,mBAAkB;AAExB,SAAK,YAAY,KAAK,MAAM,WAAW,CAAC,QAAQ;AAC9C,UAAI,CAAC,KAAK,SAAS;AACjB,aAAK,aAAa,IAAIA,gBAAI,KAAK,QAAQ,CAAC;AACxC;AAAA,MACD;AACD,YAAM,eAAesC,+BAAgD,KAAK,MAAM,OAAO,KAAK,MAAM,KAAK,MAAM,SAAS;AACtH,WAAK,aAAa,IAAI,YAAY;AAAA,IACxC,CAAK;AAED,SAAK,YAAY,KAAK,MAAM,UAAU,MAAM;AAC1C,YAAM,EAAE,SAAS,KAAK,MAAM,SAAS;AACrC,WAAK,OAAO,KAAK,UAAU;AAC3B,WAAK,KAAK,IAAI,KAAK,UAAU,IAAI;AACjC,WAAK,IAAI,IAAI,KAAK,UAAU,GAAG;AAC/B,UAAI,YAAY,MAAM,KAAK,IAAI,GAAG;AAChC,aAAK,SAAS,IAAI,OAAO,YAAY,MAAM,KAAK,IAAI,KAAK,CAAC,CAAC;AAC3D,aAAK,gBAAgB,IAAI,KAAK,IAAItC,gBAAI,KAAK,eAAe,GAAGA,gBAAI,KAAK,YAAY,GAAGA,gBAAI,KAAK,QAAQ,CAAC,CAAC;AAAA,MACzG;AAAA,IACP,CAAK;AAED,SAAK,YAAY,KAAK,UAAU,KAAK,OAAO,KAAK,IAAI,CAAC;AACtD,SAAK,YAAY,KAAK,MAAM,QAAQ,KAAK,OAAO,KAAK,IAAI,CAAC;AAC1D,SAAK,YAAY,KAAK,MAAM,UAAU,KAAK,gBAAgB,KAAK,IAAI,CAAC;AAAA,EACtE;AAAA,EAED,kBAAkB;AAChB,SAAK,UAAUA,gBAAI,KAAK,MAAM,QAAQ,EAAE,0BAA0B,CAAC,CAAC,KAAK,MAAM;AAAA,EAChF;AAAA,EAED,SAAS;AACP,UAAM,OAAOA,gBAAI,KAAK,IAAI;AAC1B,UAAM,SAASA,gBAAI,KAAK,MAAM,MAAM;AACpC,UAAM,sBAAsBA,gBAAI,KAAK,mBAAmB;AACxD,UAAM,WAAWA,gBAAI,KAAK,QAAQ;AAClC,QAAI,aAAa,KAAK,CAAC,uBAAuB,CAAC,KAAK,MAAM,gBAAgB;AACxE,WAAK,SAAS,IAAI,IAAI;AAAA,IACvB,WAAU,QAAQ;AACjB,WAAK,SAAS,IAAI,CAAC,KAAK,cAAc,SAAS,OAAO,YAAa,CAAA,CAAC;AAAA,IAC1E,OAAW;AACL,WAAK,SAAS,IAAI,CAAC,uBAAuB,aAAa,KAAK,CAAC,KAAK,MAAM,cAAc;AAAA,IACvF;AAAA,EACF;AAAA,EAED,OAAO;AACL,UAAM,WAAW,KAAK,IAAIA,gBAAI,KAAK,eAAe,GAAGA,gBAAI,KAAK,YAAY,CAAC;AAC3E,WAAO,KAAK,UAAU,mBACpB,KAAK,MAAM,OACX,KAAK,MAAM,WACX,EAAE,CAAC,KAAK,OAAO,SAAU,GACzB,EAAE,eAAe,KAAK,cAAe,CAC3C;AAAA,EACG;AAAA,EAED,iBAAiB;AACf,WAAO,KAAK,MAAM,MAAM,OAAO;AAAA,MAC7B,CAAC,KAAK,OAAOA,gBAAI,KAAK,QAAQ;AAAA,IACpC,CAAK;AAAA,EACF;AAEH;AA7Ea;ACvHb,MAAM,aAAa,oBAAI;AAIR,MAAM,cAAc;AAAA,EAEjC,YAAY,aAAa,QAAQ,YAAY,OAAO,EAAE,oBAAoB,UAAU,IAAI;AAEtF,SAAK,gBAAgB;AAErB,SAAK,gBAAgB;AACrB,SAAK,cAAc;AAEnB,SAAK,OAAOH,QAAkB,MAAM;AACpC,SAAK,QAAQL,SAAmB,MAAM;AAEtC,SAAK,YAAY,YAAYA,SAAmB,SAAS,IAAI;AAE7D,SAAK,WAAW,IAAI,YAAY,KAAK,KAAK;AAC1C,SAAK,oBAAoB,YAAY,IAAI,YAAY,KAAK,SAAS,IAAI;AACvE,SAAK,oBAAoB;AAEzB,eAAW,IAAI,KAAK,MAAM,IAAI;AAE9B,SAAK,YAAW;AAChB,SAAK,mBAAkB;AAAA,EACxB;AAAA,EAED,IAAI,YAAY;AACd,WAAO;AAAA,EACR;AAAA,EAED,IAAI,iBAAiB;AACnB,WAAO;AAAA,EACR;AAAA,EAED,cAAc;AAEZ,SAAK,WAAW,SAAS2B,iBAA+B,KAAK,KAAK,CAAC;AACnE,SAAK,YAAY,SAASoB,uBAAwC,KAAK,KAAK,CAAC;AAE7E,SAAK,oBAAoB,KAAK,qBAAqB,SAAS,KAAK,YAAYpB,iBAA+B,KAAK,SAAS,IAAI,CAAE,CAAA;AAChI,SAAK,qBAAqB,SAAS,KAAK,YAAYoB,uBAAwC,KAAK,SAAS,IAAI,CAAA,CAAE;AAEhH,SAAK,UAAU,SAAS,KAAK;AAE7B,SAAK,SAAS,SAAS,EAAE;AACzB,SAAK,iBAAiB,CAAC,KAAK;AAE5B,SAAK,WAAW,SAAS,CAAA,CAAE;AAC3B,SAAK,aAAa,SAAS,CAAA,CAAE;AAE7B,SAAK,QAAQ,SAAS,CAAA,CAAE;AACxB,SAAK,aAAa,SAAS,CAAA,CAAE;AAC7B,SAAK,gBAAgB,SAAS,CAAA,CAAE;AAEhC,SAAK,WAAW,SAAS,CAAC;AAC1B,SAAK,gBAAgB,SAAS,CAAC;AAE/B,SAAK,OAAO,SAAS,EAAE;AACvB,SAAK,MAAM,SAAS,EAAE;AAAA,EAEvB;AAAA,EAED,qBAAqB;AAEnB,SAAK,YAAY,KAAK,UAAU,MAAM;AACpC,YAAM,EAAE,SAAS,KAAK,SAAS;AAC/B,WAAK,KAAK,IAAI,KAAK,MAAM,IAAI;AAC7B,WAAK,IAAI,IAAI,KAAK,MAAM,GAAG;AAC3B,UAAI,YAAY,MAAM,UAAU,MAAM,OAAO,GAAG;AAC9C,aAAK,UAAU,IAAIA,uBAAwC,KAAK,KAAK,CAAC;AACtE,aAAK,aAAY;AAAA,MAClB;AACD,UAAI,YAAY,MAAM,UAAU,MAAM,IAAI,GAAG;AAC3C,aAAK,SAAS,IAAIpB,iBAA+B,KAAK,KAAK,CAAC;AAC5D,aAAK,aAAY;AAAA,MAClB;AAAA,IACP,CAAK;AAED,QAAI,KAAK,mBAAmB;AAC1B,WAAK,YAAY,KAAK,mBAAmB,MAAM;AAC7C,cAAM,EAAE,SAAS,KAAK,SAAS;AAC/B,YAAI,YAAY,MAAM,UAAU,MAAM,OAAO,GAAG;AAC9C,eAAK,mBAAmB,IAAIoB,uBAAwC,KAAK,SAAS,CAAC;AACnF,eAAK,aAAY;AAAA,QAClB;AACD,YAAI,YAAY,MAAM,UAAU,MAAM,IAAI,GAAG;AAC3C,eAAK,kBAAkB,IAAIpB,iBAA+B,KAAK,SAAS,CAAC;AACzE,eAAK,aAAY;AAAA,QAClB;AAAA,MACT,CAAO;AAAA,IACF;AAED,UAAM,QAAQ,CAAA;AACd,UAAM,aAAa,CAAA;AAEnBqB,kBAA4B,KAAK,KAAK,EAAE,IAAI,UAAQ;AAClD,YAAM,KAAK,IAAI,KAAK,UAAU,MAAM,IAAI,CAAC;AAAA,IAC/C,CAAK;AAEDN,uBAAiC,KAAK,OAAO,EAAE,UAAU,KAAK,WAAW,QAAQ,KAAI,CAAE,EAAE,QAAQ,cAAY;AAC3G,UAAI,SAAS,SAAS,QAAQ;AAC5B,YAAI,CAAC,SAAS;AAAM;AACpB,cAAM,KAAK,IAAI,KAAK,UAAU,MAAM,SAAS,QAAQ,SAAS,IAAI,CAAC;AAAA,MAC3E,OAAa;AACL,mBAAW,KAAK,IAAI,KAAK,eAAe,MAAM,QAAQ,CAAC;AAAA,MACxD;AAAA,IACP,CAAK;AAED,SAAK,SAAS,IAAI,KAAK;AACvB,SAAK,WAAW,IAAI,UAAU;AAE9B,SAAK,YAAY,KAAK,UAAU,CAAC,QAAQ;AACvC,UAAI,CAAC;AAAK;AACV,WAAK,aAAY;AAAA,IACvB,CAAK;AACD,SAAK,YAAY,KAAK,YAAY,CAAC,QAAQ;AACzC,UAAI,CAAC;AAAK;AACV,WAAK,aAAY;AAAA,IACvB,CAAK;AAED,UAAM,iBAAiB,QAAQ,MAAM,SAAS,MAAM;AAClD,WAAK,aAAY;AAAA,IAClB,GAAE,GAAG;AACN,SAAK,YAAY,KAAK,QAAQ,CAAC,QAAQ;AACrC,UAAI,CAAC;AAAK;AACV,qBAAgB;AAAA,IACtB,CAAK;AAAA,EAEF;AAAA,EAED,OAAO,SAAS,OAAO;AACrB,UAAM,OAAOrC,QAAkB,KAAK;AACpC,WAAO,WAAW,IAAI,IAAI;AAAA,EAC3B;AAAA,EAED,OAAO,cAAc,OAAO,UAAU,MAAM;AAC1C,UAAM,QAAQ,KAAK,SAAS,KAAK;AACjC,QAAI,OAAO;AACT,YAAM,OAAO,GAAG,IAAI;AAAA,IACrB;AAAA,EACF;AAAA,EAED,eAAe;AACb,UAAM,WAAWG,gBAAI,KAAK,QAAQ;AAElC,UAAM,QAAQ,SAAS,OAAO,WAAS,CAAC,MAAM,UAAU;AACxD,UAAM,iBAAiB,SAAS,OAAO,WAAS,MAAM,UAAU;AAEhE,SAAK,SAAS,IAAI,MAAM,OAAO,WAASA,gBAAI,MAAM,QAAQ,IAAI,CAAC,EAAE,MAAM;AACvE,SAAK,MAAM,IAAI,MAAM,OAAO,WAAS,CAACA,gBAAI,MAAM,QAAQ,CAAC,CAAC;AAE1D,UAAM,aAAaA,gBAAI,KAAK,UAAU,EAAE,OAAO,cAAc;AAC7D,SAAK,cAAc,IAAI,WAAW,OAAO,WAASA,gBAAI,MAAM,QAAQ,IAAI,CAAC,EAAE,MAAM;AACjF,SAAK,WAAW,IAAI,WAAW,OAAO,WAAS,CAACA,gBAAI,MAAM,QAAQ,CAAC,CAAC;AACpE,SAAK,cAAc,IAAI,UAAU;AAAA,EAClC;AAAA,EAED,WAAW,MAAM;AACf,QAAIyC,cAA4B,KAAK,OAAO,IAAI;AAAG;AACnD,UAAM,QAAQzC,gBAAI,KAAK,QAAQ;AAC/B,UAAM,eAAe,MAClB,OAAO,WAAQ,MAAK,OAAO,IAAI,EAC/B,IAAI,WAAS;AAAA,MACZ,UAAU;AAAA,MACV,GAAG,MAAK;AAAA,IACT,EAAC;AACJ,UAAM,wBAAwBL,gBAA0B,cAAc,IAAI;AAC1E,QAAI,uBAAuB;AACzB,4BAAsB,SAAS,MAAM,IAAI;AAAA,IAC/C,OAAW;AACL,YAAM,KAAK,IAAI,SAAS,MAAM,IAAI,CAAC;AAAA,IACpC;AACD,SAAK,SAAS,IAAI,KAAK;AACvB,SAAK,aAAY;AAAA,EAClB;AAAA,EAED,WAAW,MAAM;AACf,QAAI8C,cAA4B,KAAK,OAAO,IAAI;AAAG;AACnD,UAAM,QAAQzC,gBAAI,KAAK,QAAQ;AAC/B,UAAM,WAAW,MAAM,KAAK,eAAY,UAAS,OAAO,KAAK,EAAE;AAC/D,QAAI,CAAC;AAAU;AACf,QAAI,KAAK,gBAAgB;AACvB,YAAM,OAAO,MAAM,QAAQ,QAAQ,GAAG,CAAC;AACvC,WAAK,SAAS,IAAI,KAAK;AAAA,IAC7B,OAAW;AACL,eAAS,KAAK;AACd,eAAS,SAAS,IAAI,CAAC;AACvB,eAAS,aAAa,IAAI,CAAC;AAAA,IAC5B;AACD,aAAS,YAAW;AACpB,SAAK,aAAY;AAAA,EAClB;AAAA,EAED,SAAS;AACP,SAAK,QAAQ,IAAI,IAAI;AAAA,EACtB;AAAA,EAED,MAAM,SAAS;AAEb,UAAM,gBAAgB,CAAA;AACtB,UAAM,gBAAgB,CAAA;AACtB,UAAM,qBAAqB,CAAA;AAE3B,UAAM,QAAQA,gBAAI,KAAK,QAAQ,EAAE,OAAO,UAAQ,KAAK,EAAE;AACvD,aAAS,QAAQ,OAAO;AACtB,YAAM,eAAeA,gBAAI,KAAK,QAAQ;AACtC,UAAI,iBAAiB,GAAG;AACtB,sBAAc,KAAK,KAAK,EAAE;AAAA,MAClC,OAAa;AACL,sBAAc,KAAK;AAAA,UACjB,KAAK,KAAK;AAAA,UACV,CAAC,KAAK,UAAU,0BAA0B;AAAA,QACpD,CAAS;AAAA,MACF;AAAA,IACF;AAED,UAAM,aAAaA,gBAAI,KAAK,UAAU;AACtC,aAAS,aAAa,YAAY;AAChC,yBAAmB,UAAU,QAAQA,gBAAI,UAAU,QAAQ;AAAA,IAC5D;AAED,UAAM,kBAAkBuC,uBAAwC,KAAK,KAAK;AAE1E,UAAM,KAAK,MAAM,OAAO,kBAAkB;AAC1C,QAAI,iBAAiB,YAAY;AAC/B,sBAAgB,aAAa,gBAAgB,WAAW,IAAI,cAAY;AACtE,YAAI,mBAAmB,SAAS,UAAU,QAAW;AACnD,mBAAS,SAAS,SAAS,OAAO,IAAI,WAAS;AAC7C,kBAAM,WAAW,KAAK,IAAI,GAAG,KAAK,IAAI,MAAM,UAAU,mBAAmB,SAAS,KAAK,CAAC;AACxF,mBAAO;AAAA,UACnB,CAAW;AAAA,QACF;AACD,eAAO;AAAA,MACf,CAAO;AAAA,IACF;AAED,UAAM,KAAK,MAAM,wBAAwB,QAAQ,aAAa;AAC9D,UAAM,KAAK,MAAM,wBAAwB,QAAQ,aAAa;AAC9D,QAAI,iBAAiB,OAAO;AAC1B,sBAAgB,QAAQ,gBAAgB,MAAM,IAAI,UAAQ;AACxD,cAAM,cAAc,cAAc,KAAK,WAAQ,MAAK,QAAQ,MAAK,EAAE;AACnE,YAAI,aAAa;AACf,eAAK,SAAS,KAAK,OAAO,IAAI,WAAS;AACrC,kBAAM,WAAW,KAAK,IAAI,GAAG,KAAK,IAAI,MAAM,UAAU,YAAY,QAAQ,CAAC;AAC3E,mBAAO;AAAA,UACnB,CAAW;AAAA,QACF;AACD,eAAO;AAAA,MACf,CAAO;AAAA,IACF;AAED,UAAMG,0BAA2C,KAAK,OAAO,eAAe;AAE5EhB,kBAAsB,iCAAiC;AAEvD,SAAK,aAAY;AAAA,EAElB;AAAA,EAED,UAAU;AACR,SAAK,UAAU,mBACb,KAAK,OACL,KAAK,WACL,EAAE,eAAe,KAAK,cAAe,CAC3C;AAAA,EACG;AAAA,EAED,WAAW;AACT,WAAO,KAAK,UAAU,sBAAsB,KAAK,OAAO,EAAE,YAAY,KAAK,UAAS,CAAE;AAAA,EACvF;AAAA,EAED,iBAAiB;AACf,QAAI,CAAC,iBAAiB,SAAS,KAAK,YAAY,EAAE,GAAG;AACnD,aAAO,KAAK,UAAU,cAAc,KAAK,KAAK;AAAA,IAC/C;AAAA,EACF;AAAA,EAED,YAAY,QAAQ,UAAU;AAC5B,SAAK,cAAc,KAAK,OAAO,UAAU,QAAQ,CAAC;AAAA,EACnD;AAAA,EAED,cAAc;AACZ,SAAK,cAAc,QAAQ,iBAAe,YAAa,CAAA;AACvD,SAAK,gBAAgB;EACtB;AAAA,EAED,YAAY;AACV,SAAK,YAAW;AAChB,eAAW,OAAO,KAAK,IAAI;AAAA,EAC5B;AACH;AAhSqB;;;;;;;;;;;;;;;;;kBCyER,IAAa,MAAA,mBAAA,GAAA;kBAQb,IAAW,MAAA,kBAAA;kBAST,IAAQ,MAAAiB,oBAAA;;kBAOR,IAAQ,MAAAC,oBAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AATf,aAeM,QAAA,KAAA,MAAA;;;;;;;;;;;;;wCAfoE,IAAc,GAAA;;;;;;;;;UAfnF,KAAa,IAAA;;;;;;;;;;;;;;;;;;;UAQb,KAAW,IAAA;;;;;;;;;;;;UAST,KAAQ,IAAA;;;;;;;;;;;;;;;;;;;;;;UAOR,KAAQ,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA9BZ,QAAA,cAAA,GAAA,SAAS,8BAA8B;;;;;AAD1C,aAEI,QAAA,GAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMF,aAIM,QAAA,KAAA,MAAA;AAFJ,aAAgE,KAAA,KAAA;;AAChE,aAA6C,KAAA,KAAA;6BAAd,IAAY,EAAA;;;;;;;;4CAAZ,KAAY,IAAA;+BAAZ,KAAY,EAAA;AAAA;;;;;;AAF8B,YAAA,CAAA;AAAA,2BAAA,gCAAA,KAAA,MAAA,EAAA,UAAU,OAAG,IAAA;;;;;;AAAb,UAAA,CAAA;AAAA,yBAAA,gCAAA,KAAA,MAAA,EAAA,UAAU,OAAG,KAAA;;;;;;;;;;;;;;;;;;;;AAQrF,QAAA,cAAA,GAAA,SAAS,0BAA0B;;;;;;AADtC,aAEI,QAAA,GAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;AAOF,aAAuF,QAAA,MAAA,MAAA;;AACvF,aAAW,QAAA,MAAA,MAAA;;;;;;;AADuD,YAAA,CAAA;AAAA,4BAAA,gCAAA,MAAA,MAAA,EAAA,UAAS,OAAG,IAAA;;;;;;AAAZ,UAAA,CAAA;AAAA,0BAAA,gCAAA,MAAA,MAAA,EAAA,UAAS,OAAG,KAAA;;;;;;;;;;;;;;;;;;;;;;;;AAO9E,aAAI,QAAA,IAAA,MAAA;AAAA;;;;;;;;;;;;AAYyB,MAAA,WAAA,SAAS,+CAA+C,IAAA;;;;;;;;;;;;;;AADvF,aAES,QAAA,QAAA,MAAA;AADP,aAA2B,QAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;AAOtB,QAAA,KAAU,IAAA,qBAAqB,SAAU;AAAsB,aAAAZ;AAE1D,QAAA,SAAU;AAAiB,aAAAa;;;;;;;;;;;;;;wBAJgC,IAAW;AAAA;;AAAlF,aASS,QAAA,QAAA,MAAA;AARP,aAAgC,QAAA,CAAA;;;;;;;;;;;;;;;;;;;;0BADqC,KAAW;AAAA;;;;;;;;;;;;;AAO7E,MAAA,UAAA,SAAS,sCAAwC,EAAA,aAAA,IAAW,KAAA,IAAA;;;;;;;;;;;;;;;;;;AAF5D,MAAA,UAAA,SAAS,+BAAiC,EAAA,aAAA,IAAW,KAAA,IAAA;;;;;;;;;;;;;;;;;;AAFrD,MAAA,UAAA,SAAS,+BAAiC,EAAA,aAAA,IAAW,KAAA,IAAA;;;;;;;;;;;;;;;;;;;;;AAWpB,MAAA,WAAA,SAAS,4BAA4B,IAAA;;;;;;;;;;;;wBADL,IAAW;AAAA;;AAAjF,aAES,QAAA,QAAA,MAAA;AADP,aAAkC,QAAA,CAAA;;;;;;;;;;0BADkC,KAAW;AAAA;;;;;;;;;;;;;;;AAOnD,MAAA,WAAA,SAAS,0BAA0B,IAAA;;;;;;;;;;;;;;AADjE,aAES,QAAA,QAAA,MAAA;AADP,aAA0B,QAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKS,MAAA,WAAA,SAAS,0BAA0B,IAAA;;;;;;;;;QA3EvE,KAAQ;AAAA,aAAA;;;;;;kBA2CN,IAAc,OAAAC,oBAAA,GAAA;AAMd,MAAA,YAAA,QAAU,mBAAetB,oBAAA,GAAA;AAazB,MAAA,YAAA,IAAM,GAAA,aAAa,QAAU,kBAAcR,oBAAA,GAAA;AAM3C,MAAA,YAAA,IAAU,IAAA,eAAgB,CAAA,OAAU,UAAMC,kBAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAzErD,aAsFO,QAAA,MAAA,MAAA;AApFL,aAkFM,MAAA,GAAA;;;AArCJ,aAmCS,KAAA,MAAA;;;;;;;;;;;;;AAHP,aAES,QAAA,MAAA;AADP,aAAmC,QAAA,CAAA;;;;;;;mCA9EiBK,gBAAc;AAAA,8BAAW,IAAQ,GAAA;AAAA,kCACzEA,gBAAc;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;UA6CvB,KAAc;AAAA,kBAAA,EAAA,MAAA,KAAA;AAMd,UAAA,SAAU,iBAAe;;;;;;;;;;;;AAazB,UAAA,KAAM,GAAA,aAAa,SAAU,gBAAc;;;;;;;;;;;;AAM3C,UAAA,KAAU,IAAA,eAAgB,CAAA,QAAU,QAAM;;;;;;;;;;;;;;;;;;;AAzErC,uBAAA,qBAAA,MAAA,MAAA,EAAA,UAAU,IAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AArBpB,0BAAe,OAAK;AAC3B,QAAM,eAAc;;AADbA;;;;;;;;;;UAvCD,gBAAgB,WAAW,UAAU;QAElC,gBAAW;QACX,UAAK;QACL,cAAS;QACT,cAAS;AAET,MAAA,EAAA,YAAY,cAAc,aAAa,OAAO,SAAS,MAAA;MAG9D,cAAc,MAAM;;MACpB,iBAAiB,MAAM;MACvB,WAAW,MAAM;;MACjB,UAAU,MAAM;;MAEhB,WAAW,MAAM;;MACjB,gBAAgB,MAAM;;AAMtB,MAAA,cAAcyB,sBAAuC,KAAK,EAAE;AAEvD,oBAAS,OAAK;AAErB,UAAM,eAAc;QAEhB;;AAEF,aAAO,KAAK,MAAM,MAAM,aAAa,QAAQ,YAAY,CAAA;AAAA,aAClD;aACA;AAAA;WAGF,WAAW,UAAU,QAAQ,MAAI,EAAI,QAAQ,MAAM,MAAK,CAAA;AAAA;AAXxD;MAmBL;AACA,MAAA,WAAW;4BAEQ;AACrB,iBAAA,GAAA,WAAW,gBAAgB,YAAY,EAAE;AAAA;AADlC;AAIT,YAAS,MAAA;AACP,UAAM,UAAS;AAAA;;AA0BwB,mBAAY,KAAA;;;;;;AAWD,wBAAe;;;;;;AAqBnB,UAAM,OAAM;AAAA;;AAMZ,UAAM,SAAQ;AAAA;;AAad,UAAM,QAAO;AAAA;;AAMb,UAAM,eAAc;AAAI,gBAAY,MAAK;AAAA;;AAK3C,gBAAY,MAAK;AAAA;;;;;;;;;;;;;;;;;;;;AAzH9D,mBAAA,GAAE,cAAc,cAAc,KAAK,mBAAmB,CAAC;AAAA;;AACrD,mBAAA,GAAA,WAAW,YAAY,CAAC;AAAA;;sBACxB,gBAAiB,YAAY,kBAAmB,CAAC;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC3B/C,MAAM,6BAA6B,kBAAkB;AAAA,EAU1D,YAAY,OAAO,WAAW,YAAY,CAAE,GAAE,UAAU,CAAA,GAAI,aAAa,IAAI;AAC3E,UAAM;AAAA,MACJ,IAAI,uBAAuB,MAAM;AAAA,MACjC,OAAO,MAAM;AAAA,MACb,QAAQ;AAAA,QACN,OAAOC;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,UACA;AAAA,UACA;AAAA,QACD;AAAA,MACF;AAAA,MACD,QAAQ;AAAA,MACR,GAAG;AAAA,IACJ,GAAE,UAAU;AAEb,SAAK,QAAQ;AACb,SAAK,YAAY;AAEjBC,UAAc,QAAQ,MAAM,gBAAgB,MAAM,OAAO,WAAW,SAAS;AAAA,EAE9E;AAAA,EAGD,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,eAAe;AAAA,MACf,SAAS,CAAC,0CAA0C;AAAA,MACpD,OAAO;AAAA,MACP,QAAQ;AAAA,IACd,CAAK;AAAA,EACF;AAAA,EAED,OAAO,cAAc,IAAI;AACvB,WAAO,OAAO,OAAO,GAAG,OAAO,EAAE,OAAO,SAAO,IAAI,OAAO,uBAAuB,IAAI;AAAA,EACtF;AAAA,EAED,aAAa,KAAK,QAAQ,YAAY,OAAO,YAAY,CAAE,GAAE,UAAU,CAAA,GAAI,aAAa,IAAI;AAC1F,aAASzD,SAAmB,MAAM;AAClC,gBAAYA,SAAmB,SAAS;AACxC,UAAM,SAASyD,MAAc,KAAK,MAAM,oBAAoB,QAAQ,WAAW,SAAS;AACxF,QAAI,WAAW;AAAO;AACtB,UAAM,OAAO,KAAK,cAAc,OAAO,EAAE;AACzC,QAAI,KAAK,QAAQ;AACf,eAAS,OAAO,MAAM;AACpB,YAAI,OAAO,OAAO,EAAE,OAAO,KAAM,CAAA;AAAA,MAClC;AACD;AAAA,IACD;AACD,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,QAAQ,WAAW,WAAW,SAAS,UAAU,EAAE,OAAO,MAAM,EAAE,OAAO,KAAM,CAAA;AAAA,IAC9F,CAAK;AAAA,EACF;AAAA,EAED,MAAM,MAAM,SAAS;AACnB,UAAM,SAASA,MAAc,KAAK,MAAM,qBAAqB,MAAM,KAAK,OAAO,KAAK,SAAS;AAC7F,QAAI,WAAW;AAAO;AACtBA,UAAc,QAAQ,MAAM,iBAAiB,MAAM,KAAK,OAAO,KAAK,SAAS;AAC7E,WAAO,MAAM,MAAM,OAAO;AAAA,EAC3B;AAAA,EAKD,oBAAoB;AAClB,QAAI,UAAU,MAAM;AACpB,UAAM,eAAe,KAAK,KAAK;AAC/B,QAAI,cAAc;AAChB,gBAAU;AAAA,QACR;AAAA,UACE,OAAO;AAAA,UACP,OAAO;AAAA,UACP,MAAM;AAAA,UACN,SAAS,MAAM;AACb,iBAAK,MAAM,MAAM,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,UAC9C;AAAA,QACF;AAAA,QACD;AAAA,UACE,OAAO;AAAA,UACP,OAAO;AAAA,UACP,MAAM;AAAA,UACN,SAAS,MAAM;AACb,2BAAe,KAAK,KAAK,KAAK;AAAA,UAC/B;AAAA,QACF;AAAA,MACT,EAAQ,OAAO,OAAO;AAAA,IACjB;AACD,WAAO;AAAA,EACR;AAEH;AAtGa;ACFE,MAAM,YAAY;AAAA,EAE/B,YAAY,OAAO;AACjB,SAAK,QAAQ;AACb,SAAK,gBAAgB;AACrB,SAAK,gBAAgB;AACrB,SAAK,gBAAgB;AACrB,SAAK,eAAe,oBAAI;AACxB,SAAK,eAAe;AACpB,SAAK,kBAAkB,oBAAI;AAC3B,SAAK,mBAAmB,oBAAI;AAC5B,SAAK,aAAa,oBAAI;AACtB,SAAK,cAAc,oBAAI;AACvB,SAAK,eAAe;AAAA,EACrB;AAAA,EAED,MAAM,kBAAkB,OAAO,EAAE,SAAS,OAAO,OAAO,WAAW,IAAI;AACrE,aAAS,QAAQ,OAAO;AACtB,UAAI,OAAO,KAAK,QAAQ;AACxB,UAAI,WAAW,gBAAgB,OAAO,KAAK,SAAU,IAAG;AACxD,UAAI,QAAQ,KAAK,kBAAkB;AACjC,mBAAW,MAAM,QAAQ,KAAK,iBAAiB,QAAQ;AAAA,MACxD;AACD,YAAM,mBAAmB,KAAK,IAAI,KAAK,YAAYrD,gBAA0B,QAAQ,CAAC,IAAK,UAAS,KAAK;AACzG,YAAM,oBAAoBD,gBAA0B,KAAK,MAAM,OAAO,QAAQ;AAC9E,UAAI,mBAAmB;AACrB,cAAM,qBAAqBA,gBAA0B,KAAK,eAAe,QAAQ;AACjF,YAAI,oBAAoB;AACtB,gBAAM,cAAcC,gBAA0B,kBAAkB,IAAI;AACpEsD,0BAA0B,oBAAoB,WAAW;AAAA,QACnE,OAAe;AACL,gBAAM,cAActD,gBAA0B,iBAAiB,IAAI;AACnE,gBAAM,UAASsD,gBAA0B,EAAE,KAAK,kBAAkB,GAAE,GAAI,WAAW;AACnF,eAAK,YAAY,IAAI,kBAAkB,IAAI,IAAI;AAC/C,eAAK,cAAc,KAAK,OAAM;AAC9B,eAAK,WAAW,IAAI,kBAAkB,IACnC,MAAK,WAAW,IAAI,kBAAkB,EAAE,IAAI,KAAK,WAAW,IAAI,kBAAkB,EAAE,IAAI,KAAK,gBAC1G;AAAA,QACS;AAAA,MACT,OAAa;AACL,cAAM,uBAAuBvD,gBAA0B,KAAK,eAAe,QAAQ;AACnF,YAAI,sBAAsB;AACxB,gBAAM,cAAcC,gBAA0B,oBAAoB,IAAI;AACtEsD,0BAA0B,sBAAsB,WAAW;AAAA,QACrE,OAAe;AACL,sBAAY,UAAU,KAAK,UAAU,yBAAyB,gBAAgB;AAC9E,eAAK,cAAc,KAAK,QAAQ;AAChC,eAAK,YAAY,IAAI,SAAS,KAAK,IAAI;AAAA,QACxC;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EAED,MAAM,mBAAmB,YAAY,EAAE,SAAS,OAAO,OAAO,gBAAgB,IAAI;AAChF,QAAI,CAAC,MAAM,QAAQ,UAAU,GAAG;AAC9B,mBAAa,OAAO,QAAQ,UAAU,EAAE,IAAI,WAAU,GAAE,MAAM,MAAM,IAAI,UAAU,MAAM,GAAI,EAAC;AAAA,IAC9F;AACD,SAAK,eAAe,WAAW,OAAO,CAAC,KAAK,cAAc;AACxD,YAAM,mBAAmB,KAAK,IAAI,UAAU,QAAQ,IAAK,UAAS,KAAK;AACvE,UAAI,UAAU,QAAQ,IAAI,UAAU,SAAS,OAAO,YAAY,KAAK,MAAM,MAAM,UAAU,IAAI,CAAC;AAChG,UAAI,UAAU,SAAS;AACvB,WAAK,gBAAgB,IAAI,UAAU,MAChC,MAAK,gBAAgB,IAAI,UAAU,IAAI,IAAI,KAAK,gBAAgB,IAAI,UAAU,IAAI,IAAI,KAAK,gBACpG;AACM,WAAK,iBAAiB,IAAI,UAAU,MAAM,IAAI;AAC9C,aAAO;AAAA,IACb,GAAO,KAAK,YAAY;AAAA,EACrB;AAAA,EAED,UAAU;AACR,SAAK,eAAe,OAAO,YAAY,OAAO,QAAQ,KAAK,YAAY,EAAE,OAAO,WAAS;AACvF,UAAI,KAAK,gBAAgB,IAAI,MAAM,EAAE,MAAM,GAAG;AAC5C,aAAK,gBAAgB,OAAO,MAAM,EAAE;AAAA,MACrC;AACD,aAAO,OAAO,YAAY,KAAK,MAAM,MAAM,MAAM,EAAE,CAAC,MAAM,MAAM;AAAA,IACtE,CAAK,CAAC;AACF,SAAK,gBAAgB,KAAK,cAAc,OAAO,UAAQ;AACrD,aAAOtD,gBAA0B,IAAI,IAAI,KAAK,KAAK,YAAY,IAAI,KAAK,GAAG,MAAM;AAAA,IACvF,CAAK;AACD,SAAK,gBAAgB,KAAK,cAAc,OAAO,UAAQ;AACrD,aAAOA,gBAA0B,IAAI,KAAK,KAAK,KAAK,YAAY,IAAI,KAAK,GAAG,MAAM;AAAA,IACnF,CAAA,EAAE,IAAI,UAAQ,KAAK,GAAG;AACvB,SAAK,aAAa,MAAM,KAAK,KAAK,UAAU,EAAE,IAAI,CAAC,CAAC,IAAI,cAAc;AACpE,YAAM,OAAO,KAAK,MAAM,MAAM,IAAI,EAAE,EAAE;AACtC,YAAM,OAAO,KAAK,YAAY,IAAI,EAAE;AACpC,kBAAY,MAAM,KAAK,UAAU,yBAAyB,QAAQ;AAClE,aAAO,EAAE,MAAM,UAAU;IAC/B,CAAK;AACD,SAAK,eAAe,MAAM,KAAK,KAAK,YAAY,EAAE,IAAI,CAAC,CAAC,IAAI,cAAc;AACxE,YAAM,OAAO,KAAK,MAAM,MAAM,IAAI,EAAE,EAAE;AACtC,YAAM,OAAO,KAAK,YAAY,IAAI,EAAE;AACpC,aAAO,EAAE,MAAM,UAAU;IAC/B,CAAK;AACD,SAAK,gBAAgB,KAAK,cAAc,OAAO,UAAQA,gBAA0B,IAAI,IAAI,CAAC,EAAE,OAAO,cAAY;AAC7G,YAAM,OAAO,KAAK,MAAM,MAAM,IAAI,SAAS,GAAG;AAC9C,aAAOA,gBAA0B,IAAI,MAAMA,gBAA0B,QAAQ;AAAA,IACnF,CAAK;AACD,SAAK,kBAAkB,OAAO,YAAY,KAAK,eAAe;AAC9D,SAAK,eAAe;AACpB,WAAO;AAAA,MACL,cAAc,KAAK;AAAA,MACnB,eAAe,KAAK;AAAA,MACpB,eAAe,KAAK;AAAA,MACpB,eAAe,KAAK;AAAA,MACpB,cAAc,KAAK;AAAA,MACnB,iBAAiB,KAAK;AAAA,MACtB,YAAY,KAAK;AAAA,IAClB;AAAA,EACF;AAAA,EAED,MAAM,SAAS;AAEb,QAAI,CAAC,KAAK,cAAc;AACtB,WAAK,QAAO;AAAA,IACb;AAED,QAAI;AACJ,UAAM,YAAYC,QAAkB,KAAK,KAAK;AAC9C,QAAI,CAAC,KAAK,MAAM,OAAO;AACrB,qBAAe,MAAM,eAAe,YAAY,eAAe,SAAS,sBAAsB,WAAW,KAAK,cAAc,KAAK,eAAe,KAAK,eAAe,KAAK,aAAa;AAAA,IAC5L,OAAW;AACL,qBAAe,MAAM,WAAW,oBAAoB,WAAW,KAAK,cAAc,KAAK,eAAe,KAAK,eAAe,KAAK,aAAa;AAAA,IAC7I;AAED,WAAO;AAAA,MACL,iBAAiB,KAAK;AAAA,MACtB,YAAY,KAAK,WAAW,OAAO,aAAa,IAAI,UAAQ;AAC1D,eAAO;AAAA,UACL;AAAA,UACA,UAAUD,gBAA0B,IAAI;AAAA,QACzC;AAAA,MACT,CAAO,CAAC;AAAA,IACH;AAAA,EACF;AACH;AAtIqB;ACDd,MAAM,aACb;AAAA,EACG;AAAA,EACA;AAAA,EACA;AAAA,EAOA,YAAY,EAAE,WAAW,SAAS,WAAW,CAAE,GAC/C;AACG,QAAI,OAAO,aAAa,UAAU;AAAE,YAAM,IAAI,UAAU,iDAAiD;AAAA,IAAI;AAC7G,QAAI,OAAO,WAAW,UAAU;AAAE,YAAM,IAAI,UAAU,+CAA+C;AAAA,IAAI;AAEzG,SAAK,YAAY;AAEjB,QAAI,SAAS,YAAY,QACzB;AACG,WAAK,gBAAgB,SAAS,cAAc,OAAO;AAEnD,eAAS,KAAK,OAAO,KAAK,aAAa;AAEvC,WAAK,cAAc,MAAM,WAAW,GAAG,eAAe,CAAC;AAEvD,WAAK,WAAW,KAAK,cAAc,MAAM,SAAS;AAElD,eAAS,UAAU,KAAK;AAAA,IAC1B,OAED;AACG,WAAK,gBAAgB,SAAS;AAC9B,WAAK,WAAW,KAAK,cAAc,MAAM,SAAS;AAAA,IACpD;AAAA,EACH;AAAA,EASD,IAAI,OAAO,YAAY,OACvB;AACG,QAAI,WACJ;AACG,iBAAW,CAAC,KAAK,UAAU,OAAO,QAAQ,KAAK,GAC/C;AACG,aAAK,SAAS,MAAM,YAAY,KAAK,KAAK;AAAA,MAC5C;AAAA,IACH,OAED;AAEG,iBAAW,CAAC,KAAK,UAAU,OAAO,QAAQ,KAAK,GAC/C;AACG,YAAI,KAAK,SAAS,MAAM,iBAAiB,GAAG,MAAM,IAClD;AACG,eAAK,SAAS,MAAM,YAAY,KAAK,KAAK;AAAA,QAC5C;AAAA,MACH;AAAA,IACH;AAAA,EACH;AAAA,EAQD,OAAO,MACP;AACG,QAAI,MAAM,QAAQ,IAAI,GACtB;AACG,iBAAW,OAAO,MAClB;AACG,YAAI,OAAO,QAAQ,UAAU;AAAE,eAAK,SAAS,MAAM,eAAe,GAAG;AAAA,QAAI;AAAA,MAC3E;AAAA,IACH,WACQ,OAAO,SAAS,UACzB;AACG,WAAK,SAAS,MAAM,eAAe,IAAI;AAAA,IACzC;AAAA,EACH;AACJ;AAtFa;ACFb,MAAM,cAAc;AAEpB,MAAM,eAAe,IAAI,aAAa,EAAE,QAAQ,YAAW,CAAE;ACDtD,MAAM,cACb;AAAA,EACG,OAAO,SAAS;AAAA,EAEhB,OAAO,YAAY,oBAAI;EAEvB,OAAO,eAAe;AAAA,EAKtB,OAAO,cACP;AACG,SAAK,eAAe;AAEpB,UAAM,cAAc,MAAM,KAAK,SAAS,WAAW,EAAE,OAAO,CAAC,WAAU,OAAM,SAAS,IAAI;AAE1F,QAAI;AAEJ,UAAM,oBAAoB,QAAQ,MAAM,SAAS,gBAAgB;AAGjE,eAAW,cAAc,aACzB;AACG,UAAI;AAEJ,UAAI;AAAE,cAAM,IAAI,IAAI,WAAW,IAAI;AAAA,eAAY,KAAP;AAAc;AAAA,MAAW;AAEjE,UAAI,OAAO,IAAI,aAAa,YAAY,IAAI,aAAa,mBACzD;AACG,aAAK,SAAS,QAAQ;AACtB;AAAA,MACF;AAAA,IACH;AAGD,QAAI,CAAC,OAAO;AAAE;AAAA,IAAS;AAGvB,eAAW,QAAQ,MAAM,UACzB;AACG,UAAI,CAAE,iBAAgB,eAAe;AAAE;AAAA,MAAW;AAElD,YAAM,MAAM,CAAA;AAGZ,iBAAW,SAAS,KAAK,MAAM,QAAQ,MAAM,GAAG,GAChD;AACG,cAAM,QAAQ,MAAM,MAAM,GAAG;AAG7B,YAAI,MAAM,SAAS,GAAG;AAAE;AAAA,QAAW;AAEnC,YAAI,MAAM,GAAG,KAAI,KAAM,MAAM,GAAG;MAClC;AAED,WAAK,UAAU,IAAI,KAAK,cAAc,GAAG;AAAA,IAC3C;AAAA,EACH;AAAA,EAUD,OAAO,cAAc,UACrB;AACG,QAAI,CAAC,KAAK,cAAc;AAAE,WAAK,YAAa;AAAA,IAAG;AAG/C,QAAI,KAAK,UAAU,IAAI,QAAQ,GAC/B;AACG,aAAO,KAAK,UAAU,IAAI,QAAQ;AAAA,IACpC;AAED,eAAW,OAAO,KAAK,UAAU,KAAM,GACvC;AACG,UAAI,IAAI,SAAS,QAAQ,GAAG;AAAE,eAAO,KAAK,UAAU,IAAI,GAAG;AAAA,MAAI;AAAA,IACjE;AAED,WAAO;AAAA,EACT;AAAA,EAYD,OAAO,YAAY,UAAU,UAC7B;AACG,QAAI,CAAC,KAAK,cAAc;AAAE,WAAK,YAAa;AAAA,IAAG;AAG/C,QAAI,KAAK,UAAU,IAAI,QAAQ,GAC/B;AACG,YAAM,OAAO,KAAK,UAAU,IAAI,QAAQ;AACxC,aAAO,OAAO,SAAS,YAAY,YAAY,OAAO,KAAK,YAAY;AAAA,IACzE;AAED,eAAW,OAAO,KAAK,UAAU,KAAM,GACvC;AACG,UAAI,IAAI,SAAS,QAAQ,GACzB;AACG,cAAM,OAAO,KAAK,UAAU,IAAI,GAAG;AACnC,YAAI,OAAO,SAAS,YAAY,YAAY,MAAM;AAAE,iBAAO,KAAK;AAAA,QAAY;AAAA,MAC9E;AAAA,IACH;AAED,WAAO;AAAA,EACT;AACJ;AAtHa;;;;;;;;;;;;;;;;AC8GA,MAAA,UAAA,SAAS,IAAI,EAAA,IAAA;;;;;;;;AAAjB,aAAuB,QAAA,GAAA,MAAA;;;;AAAnB,UAAA,QAAA,KAAA,YAAA,WAAA,SAAS,KAAI,EAAA,IAAA;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;;;qBAFO,IAAI;;;;;;;;;;;;;;;;;;;;;;2CAAJ,KAAI,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAD1B,KAAI;AAAA,aAAA;;;;;;;;kBAOP,IAAQ,MAAAqB,kBAAA,GAAA;;;;;;;;;;;;;;;;;;;;AAZJ,WAAA,KAAA,SAAA,kBAAA,SAAS,IAAY,EAAA,CAAA;;;;AAHjC,aAkBM,QAAA,KAAA,MAAA;;;;;AAZH,aAQO,KAAA,IAAA;;;;;;;;;;;;;;;;gCARS,IAAO,EAAA;AAAA;;;+BALX,IAAU,EAAA;AAAA,+BACV,IAAO,EAAA;AAAA,4EAEA,IAAM,EAAA,CAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAWpB,KAAQ,IAAA;;;;;;;;;;;;;;;;;;;AAZJ,UAAA,CAAA,WAAA,QAAA,MAAA,oBAAA,mBAAA,SAAS,KAAY,EAAA,IAAA;;;;6CACX,KAAM,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AArFd,MAAA,EAAA,mBAAc;AACd,MAAA,EAAA,yBAAa;AACb,MAAA,EAAA,kBAAa;AACb,MAAA,EAAA,mBAAc;AACd,MAAA,EAAA,2BAAsB;AACtB,MAAA,EAAA,mBAAc;;AACd,MAAA,EAAA,6BAAe;AACf,MAAA,EAAA,iBAAY;AACZ,MAAA,EAAA,8BAAyB;AACzB,MAAA,EAAA,8BAAyB;AAsBhC,MAAA,WAAW;AAON,mBAAQ,OAAK;AAEnB,iBAAA,GAAA,YAAY,QAAQ;QAChB,OAAK;AAAI,YAAM,IAAI,QAAQ;AAAA;SAE1B,kBAAgB;AAElB,YAAM,eAAc;AACpB,YAAM,gBAAe;AAAA;;AARlB;AAkBA,sBAAW,OAAK;SAEjB,kBAAgB;AAElB,YAAM,eAAc;AACpB,YAAM,gBAAe;AAAA;;AALlB;AAYA,mBAAQ,OAAK;AAEnB,iBAAA,GAAA,WAAW,KAAK;QACZ,OAAK;AAAI,YAAM,IAAI,KAAK;AAAA;SAEvB,kBAAgB;AAElB,YAAM,eAAc;AACpB,YAAM,gBAAe;AAAA;;AARlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAzDR,mBAAA,GAAE,QAAO,SAAS,KAAK,KAAA,OAAY,MAAM,SAAS,WAAW,MAAM,OAC5D,OAAA,UAAS,WAAW,QAAO,EAAE;AAAA;;AACpC,mBAAA,GAAE,OAAO,SAAS,KAAK,KAAK,kBAAkB,MAAM,IAAI,IAAI,MAAM,OAClE,kBAAkB,IAAI,IAAI,aAAa;AAAA;;AACvC,mBAAA,IAAE,QAAQ,SAAS,KAAK,KAAA,OAAY,MAAM,UAAU,WAAW,MAAM,QAC9D,OAAA,UAAU,WAAW,QAAQ,EAAE;AAAA;;AACtC,mBAAA,IAAE,gBAAgB,SAAS,KAAK,KAAA,OAAY,MAAM,kBAAkB,WAAW,MAAM,gBAC9E,OAAA,kBAAkB,WAAW,gBAAgB,EAAE;AAAA;;AACtD,wBAAA,aAAA,GAAE,QAAQ,SAAS,KAAK,KAAK,gBAAgB,MAAM,KAAK,IAAI,MAAM,QAAQ,gBAAgB,KAAK,IAC/F,cAAc,CAAA;AAAA;;AACd,mBAAA,GAAE,UAAS,SAAS,KAAK,KAAA,OAAY,MAAM,WAAW,WAAW,MAAM,SAChE,OAAA,YAAW,WAAW,gBAAe;AAAA;;AAC5C,mBAAA,GAAE,MAAM,SAAS,KAAK,KAAA,OAAY,MAAM,QAAQ,aAAa,MAAM,MAC5D,OAAA,QAAQ,aAAa;;;;AAE5B,mBAAA,IAAE,mBAAmB,SAAS,KAAK,KAAA,OAAY,MAAM,qBAAqB,YAAY,MAAM,mBACrF,OAAA,qBAAqB,YAAY,mBAAmB,KAAK;AAAA;;AAChE,mBAAA,IAAE,mBAAmB,SAAS,KAAK,KAAA,OAAY,MAAM,qBAAqB,YAAY,MAAM,mBACrF,OAAA,qBAAqB,YAAY,mBAAmB,KAAK;AAAA;;UAI1D,OAAK;AAAI,qBAAA,GAAA,WAAW,MAAM;AAAA;;;AAGhC,mBAAA,GAAE,eAAe,YAAY,kBAAkB,KAAK,gBAAgB,KAAK;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACoKjE,aAAI,QAAA,IAAA,MAAA;AAAA;;;;;;;;;;;;;;;;gBAHqC,SAAS,IAAI,IAAC,KAAK,IAAA;;;;;;;;;;;;;AAA/C,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAK,KAAK;AAAA,aAAA,KAAA,OAAA,aAAA;AAAO,WAAA,KAAA,OAAA,gBAAA,QAAK,GAAG;;;;;AADtC,aAEM,QAAA,KAAA,MAAA;AADH,aAAqC,KAAA,GAAA;;;;;;;;;AAA3B,UAAA,QAAA,KAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAK,KAAK,GAAA;;;AAAO,UAAA,QAAA,KAAA,kBAAA,iBAAA,QAAK,MAAG;;;8CAAG,SAAS,IAAI,IAAC,KAAK,IAAA;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;;;;;gBAJ/B,SAAS,IAAI,IAAC,KAAK,IAAA;;;;;;;;;;;;;AAAnC,WAAA,GAAA,SAAA,gBAAA,cAAA,QAAK,IAAI,IAAA,gBAAA;;;;AADtB,aAEM,QAAA,KAAA,MAAA;AADH,aAAyB,KAAA,CAAA;;;;;;;;;AAAf,UAAA,QAAA,KAAA,kBAAA,iBAAA,cAAA,QAAK,IAAI,IAAA,mBAAA;;;8CAAO,SAAS,IAAI,IAAC,KAAK,IAAA;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;;;;;;;AAJrB,MAAA,eAAA,QAAK;;;;;;;;;;;;;;;;AADhC,aAEM,QAAA,KAAA,MAAA;;;;;;wEAF4D,IAAO,EAAA,CAAA,CAAA;;;;;AAC9C,UAAA,iBAAA,gBAAA,SAAK,QAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAFnC,KAAI,IAAC,aAAa;AAAO,aAAA;QAIpB,KAAI,IAAC,aAAa;AAAM,aAAA;QAIxB,KAAI,IAAC,aAAa;AAAO,aAAA;QAIzB,KAAI,IAAC,aAAa;AAAc,aAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBAbtC,IAAQ;;iCAAb,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAXZ,aA8BM,QAAA,KAAA,MAAA;AAxBH,aAuBU,KAAA,OAAA;AAtBP,aAEM,SAAA,GAAA;;;;;;;;;;;;;;;;;;;;iCAXY,IAAY,EAAA;AAAA,+CAHP,IAAO,EAAA;AAAA,yCAAY,IAAO,EAAA;AAAA,gEAYH,IAAO,EAAA,CAAA,CAAA;AAAA;;;;;;;;;;;;;;;;;;;qBAI9C,KAAQ;;mCAAb,QAAI,KAAA,GAAA;;;;;;;;;;;;;4BAAJ,QAAI,IAAA,YAAA,QAAA,KAAA,GAAA;;;;;;;;;;;;;;;;qCAAJ,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDAPwC;mDACA;;;AAlL3C,QAAA,qBAAqB,GAAG,GAAG,GAAG,EAAC;AAE1B,MAAA,EAAA,kBAAa;AACb,MAAA,EAAA,mBAAc;AACd,MAAA,EAAA,oBAAe;AACf,MAAA,EAAA,6BAAe;AACf,MAAA,EAAA,iBAAY;AACZ,MAAA,EAAA,+BAA0B;MAEjC;MAwDA;AAGA,MAAA,SAAS;AAWJ,mBAAQ,MAAI;AAEZ,UAAA,SAAS,mBAAmB,KAAK,aAAa;SAE9C,SAAQ,gBAAgB,cAAW;AAEtC,cAAQ,KAAI,6EAAA;;;AAIT,UAAA,sBAAsB,QAAQ,KAAK,sBAAqB;AACxD,UAAA,uBAAuB,oBAAoB,IAAI,oBAAoB;UAEnE,WAAW,KAAK;AAChB,UAAA,aAAa,KAAK,cAAc,sBAAqB;UAErD,iBAAc,EAAA,GAAO,kBAAgB,GAAK,OAAM;AAEtD,SAAK,MAAM,MAAG,GAAM,eAAe,IAAI,WAAW;AAI9C,QAAA,WAAW,IAAI,SAAS,QAAQ,sBAAoB;AAErD,WAAK,MAAM,OAAU,GAAA,eAAe;AACpC,WAAK,MAAM,eAAe,OAAO;AAAA;AAIjC,WAAK,MAAM,QAAW,GAAA,eAAe;AACrC,WAAK,MAAM,eAAe,MAAM;AAAA;WAG5B,UAAU,MAAM,iBAAiB;AAAA;AAjClC;AA0CA,mBAAQ,MAAI;AAEZ,UAAA,WAAW,MAAM,WAAW,MAAM;AAE7B,QAAA,OAAA,aAAa,YAAU;AAAI,eAAS,IAAI;AAAA;SAE9C,QAAM;AAER,eAAS;AACT,aAAO,cAAkB,IAAA,YAAY,SAAO,EAAI,SAAS,KAAI,CAAA,CAAA;AAAA;;AAT1D;AAmBM,yBAAQ,OAAK;QAGrB,MAAM,WAAW,UAAU,OAAO,SAAS,MAAM,MAAM,GAAA;;;AAEvD,QAAA,MAAM,WAAW,OAAO,iBAAiB,OAAO,cAAc,SAAS,MAAM,MAAM,GAAA;;;SAElF,QAAM;AAER,eAAS;AACT,aAAO,cAAkB,IAAA,YAAY,SAAO,EAAI,SAAS,KAAI,CAAA,CAAA;AAAA;;AAVpD;0BAiBM;SAEb,QAAM;AAER,eAAS;AACT,aAAO,cAAkB,IAAA,YAAY,SAAO,EAAI,SAAS,KAAI,CAAA,CAAA;AAAA;;AAL1D;AAiCwE,QAAA,gBAAA,iCAAA,QAAQ,IAAI,GAAZ;AAIA,QAAA,kBAAA,iCAAA,QAAQ,IAAI,GAAZ;;;AApBpE,eAAM;;;;;;;;;;;;;;;;;;;;;;;AAnKlB;cACQ,WAAW,SAAS,IAAI,KAAK,WAAW,KAAK,KAAK,IAAI,KAAK,QAChE,WAAW,KAAK,IAAI,QAAK;cAEpB,YAAS,CAAA;AAEX,YAAA;AAEO,mBAAA,QAAQ,UAAQ;AAExB;AACK,cAAA,CAAA,SAAS,IAAI,GAAA;AAAe,kBAAA,IAAA,kCAAkC,0BAAI;AAAA;AAG5D,cAAA,OAAA,KAAK,cAAc,cAAe,CAAA,KAAK,aAAS;;;AAChD,cAAA,OAAA,KAAK,cAAc,aAAc,CAAA,KAAK,WAAS;;;cAEtD;cAEA,kBAAkB,KAAK,KAAK,GAAA;AAAK,mBAAO;AAAA,4BAC5B,KAAK,SAAS,UAAQ;AAAI,mBAAO;AAAA,4BACjC,KAAK,UAAU,UAAQ;AAAI,mBAAO;AAAA,4BAClC,KAAK,cAAc,UAAQ;gBAEpC,KAAK,cAAc,MAAI;AAEd,oBAAA,IAAA,8BACe,sEAAI;AAAA;AAGhC,mBAAO;AAAA;AAGN,cAAA,iBAAe;AAAc,kBAAA,IAAA,mDAAmD,SAAI;AAAA;AAExF,oBAAU,KAAI,EAAA,GAAM,MAAM,SAAS,KAAI,CAAA;AAAA;AAG1C,qBAAA,GAAA,WAAW,SAAS;AAAA;;;AAGtB,mBAAA,GAAE,SAAS,SAAS,IAAI,KAAK,SAAS,KAAK,MAAM,IAAI,KAAK,SAC1D,SAAS,MAAM,IAAI,SAAS,gBAAgB;AAAA;;AAE5C,mBAAA,GAAE,UAAS,SAAS,IAAI,KAAK,SAAS,KAAK,MAAM,IAAI,KAAK,SAC1D,SAAS,OAAM,IAAI,gBAAe;AAAA;;AAElC,mBAAA,GAAE,MAAM,SAAS,IAAI,KAAA,OAAY,KAAK,QAAQ,aAAa,KAAK,MACzD,OAAA,QAAQ,aAAa;;;;AAE5B,mBAAA,GAAE,oBAAoB,SAAS,IAAI,KAAK,SAAS,KAAK,iBAAiB,IAAI,KAAK,oBAC/E,SAAS,iBAAiB,IAAI,oBAAsB,EAAA,UAAU,KAAK,QAAQ,SAAQ,CAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACtExF,aAAa,IAAI;AAAA,EACd,kCAAkC;AACrC,CAAC;AAID,aAAa,IAAI;AAAA,EACd,gCAAgC;AAAA,EAChC,sCAAsC;AAAA,EACtC,yCAAyC;AAAA,EACzC,mCAAmC;AAAA,EACnC,+BAA+B;AAAA,EAC/B,8BAA8B;AAAA,EAC9B,gCAAgC;AACnC,CAAC;AAED;AAIG,QAAM,QAAQ,cAAc,cAAc,0CAA0C;AAEpF,MAAI,OAAO,UAAU,UACrB;AACG,iBAAa,IAAI;AAAA,MACd,0BAA0B,gBAAgB,QAAQ,MAAM,aAAa;AAAA,MACrE,sBAAsB,YAAY,QAAQ,MAAM,SAAS;AAAA,MACzD,6BAA6B,mBAAmB,QAAQ,MAAM,mBAAmB;AAAA,MACjF,sBAAsB,YAAY,QAAQ,MAAM,SAAS;AAAA,MACzD,yBAAyB,eAAe,QAAQ,MAAM,eAAe;AAAA,MACrE,qBAAqB,WAAW,QAAQ,MAAM,QAAQ;AAAA,IAC/D,CAAO;AAAA,EACH;AACJ;AAEA,aAAa,IAAI;AAAA,EACd,0BAA0B;AAC7B,CAAC;AAED,aAAa,IAAI;AAAA,EACd,qBAAqB;AAAA,EACrB,yBAAyB;AAAA,EACzB,oBAAoB;AAAA,EACpB,2CAA2C;AAC9C,CAAC;;;;;;;;;;;;;;;;;ACF2C,MAAA,UAAA,OAAM,OAAI;;;;;;;yCAAxB,IAAU,EAAA;AAAA;;AAApC,aAA4D,QAAA,OAAA,MAAA;;;;AAApB,UAAA,QAAA,MAAA,YAAA,WAAA,QAAM,OAAI;AAAA,iBAAA,GAAA,OAAA;;2CAAxB,KAAU,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAVnB,MAAA,WAAA,QAAM,WAAQ;;;AAAG,MAAA,WAAA,QAAM,OAAI;;;;;;;;;;;;;;;;;;;;;AAHM,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAM,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;AADnB,mBAAA,MAAA,gBAAA,CAAA,QAAM,eAAe,IAAK,GAAA,MAAM,SAAS;;;AAF5C,mBAAA,MAAA,eAAA,CAAA,QAAW,eAAe,IAAK,GAAA,MAAM,SAAS;;;;AALvE,aAaM,QAAA,MAAA,MAAA;AAPJ,aAGM,MAAA,IAAA;AADJ,aAA+C,MAAA,GAAA;;AAEjD,aAEM,MAAA,IAAA;;;;;;;;;;;AAJ8B,UAAA,QAAA,MAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAM,GAAG,GAAA;;;;AADnB,qBAAA,MAAA,gBAAA,CAAA,QAAM,eAAe,IAAK,GAAA,MAAM,SAAS;AAAA;AAIhE,UAAA,QAAA,MAAA,aAAA,YAAA,QAAM,WAAQ;AAAA,iBAAA,IAAA,QAAA;AAAG,UAAA,QAAA,MAAA,aAAA,YAAA,QAAM,OAAI;AAAA,iBAAA,IAAA,QAAA;;AANP,qBAAA,MAAA,eAAA,CAAA,QAAW,eAAe,IAAK,GAAA,MAAM,SAAS;AAAA;;;;;;;;;;;;;;;;qBANlE,IAAU,IAAC,OAAO,OAAM,IAAA;AAAgC,QAAA,UAAA,iCAAA,SAAM,IAAN;mCAA7D,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;AADiC,mBAAA,KAAA,YAAA,WAAwB,IAAK,GAAA;;;;AAAtE,aAiBM,QAAA,KAAA,MAAA;;;;;;;;;uBAhBG,IAAU,IAAC,OAAO,OAAM,IAAA;;;;AADQ,qBAAA,KAAA,YAAA,WAAwB,IAAK,GAAA;AAAA;;;;;;;;;;;;;;;;mBADjE,IAAO;mDAAuB,KAAK;iCAAxC,QAAI,KAAA,GAAA;;;;;;;;;;;;;;AADR,aAqBM,QAAA,KAAA,MAAA;;;;;;;qBApBG,KAAO;;;;;;;;;;;;;;;;;;;MAFA,QAAA,EAAA,GAAG,EAAC;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAJM,mBAAA,KAAA,mBAAA,IAAQ,GAAA,SAAS,MAAM,IAAU,EAAA;uCACrC,IAAU,EAAA;uDACM,IAAwB,EAAA;AAAA;;AAHhE,aAIM,QAAA,KAAA,MAAA;AAAA;;;AAHsB,qBAAA,KAAA,mBAAA,KAAQ,GAAA,SAAS,MAAM,KAAU,EAAA;AAAA;;yCACrC,KAAU,EAAA;AAAA;;yDACM,KAAwB,EAAA;AAAA;;;;;;;;;;;;;;;;;QAL/D,KAAO,GAAC,SAAS;AAAC,aAAA;;;;;;;;;;;;;AADzB,aAoCM,QAAA,KAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;aAxBwC,kCAAS,MAAM,MAAf;;;;;;;QA9BjC,SAAI;AACJ,MAAA,EAAA,aAAa,UAAK;QAEvB,QAAK,EACT,MAAM;QAGF,SAAS,KAAK;;AACC,OAAK;QACpB,qBAAqB,KAAK;;QAC1B,gBAAgB,aAAa,SAAS,EAAE,IAAI,KAAK,MAAM;;;AAuBtC,oBAAA,oBAAA,sBAAsB,OAAK,mBAAA;AAC3B,oBAAA,eAAA,iBAAiB,IAAE,cAAA;AAAA;;;;;;;;;AAtBzC,mBAAA,GAAE,aAAa,QAAQ,SAAS,KAAM,CAAA,QAAQ,sBAAsB,eAAe,KAAK,MAAM,aAAS,CAAK,UAAU;AAAA;;AACpH,mBAAA,GAAA,2BAA2B,eAAe,QAAQ,OAAO,WAAS,MAAM,WAAW,EAAE,MAAM;AAAA;;AAC7F,sBAAE,MAAM,OAAQ,eAAc,QAAQ,SAAS,IAAI,iCAAmC,MAAO,SAAQ,sBAAsB,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBC0EpG,OAC1B;gBAAC,IAAuB,EAAA;gBAAC,GAChC;;;;;;;;;;;;;AAJF,aAKK,QAAA,KAAA,MAAA;AAJH,aAAsB,KAAA,MAAA;;AACtB,aAEO,KAAA,MAAA;;;;;AAET,aAGG,QAAA,OAAA,MAAA;6BAHyE,IAAoB,EAAA;;;;;;;;;;;qBAHtF,KAAuB,EAAA;sDAG2C,KAAoB,IAAA;+BAApB,KAAoB,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;AAehG,aAA0C,QAAA,OAAA,MAAA;AAAA;;;;;;;;;;;AAJrC,MAAA,WAAA,IAAiB,KAAA,KAAK,OAAY,WAAO2B,oBAAA,GAAA;;;;;;;;;;;;;AAAzC,UAAA,KAAiB,KAAA,KAAK,QAAY,SAAO;;;;;;;;;;;;;;;;;;;;;;;;AACpC,MAAA,UAAA,OAAY,kBAAe;;;;;;;;AAAnC,aAA2C,QAAA,OAAA,MAAA;;;;AAAnC,UAAA,MAAA,KAAA,OAAA,YAAA,WAAA,QAAY,kBAAe;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;eAajC,UAEN;AAAA;;;;;;;;;;;;;;;eAJqB,cAErB;AAAA;;;;;;;;;;;;;;;eASM,UAEN;AAAA;;;;;;;;;;;;;;;eAJqB,eAErB;AAAA;;;;;;;;;;;;;;;;;;AAYa,MAAA,WAAA,QAAM,WAAQ;;;AAAG,MAAA,WAAA,QAAM,OAAI;;;;;;;;;;;;;;;AAFC,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAM,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;;;;;;AAF9C,aAKK,QAAA,MAAA,MAAA;AAJH,aAEK,MAAA,IAAA;AADH,aAA4C,MAAA,GAAA;;AAE9C,aAAyC,MAAA,IAAA;;;;;;;AAFN,UAAA,MAAA,KAAA,OAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,SAAM,GAAG,GAAA;;;AAErC,UAAA,MAAA,KAAA,OAAA,aAAA,YAAA,SAAM,WAAQ;AAAA,iBAAA,IAAA,QAAA;AAAG,UAAA,MAAA,KAAA,OAAA,aAAA,YAAA,SAAM,OAAI;AAAA,iBAAA,IAAA,QAAA;AAAA;;;;;;;;;;AALjC,MAAA,WAAA,QAAM,YAAQZ,oBAAA,GAAA;;;;;;;;;;;;;AAAd,UAAA,SAAM,UAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;AAsBZ,MAAA,aAAA,OAAY;;iCAAjB,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;AAHN,aAEM,QAAA,MAAA,MAAA;;;;;;;;;AACC,qBAAA,QAAY;;mCAAjB,QAAI,KAAA,GAAA;;;;;;;;;;;;;wCAAJ;AAAA;;;;;;;;;;;;;;;;;AAGW,MAAA,WAAA,QAAO,WAAQ;;;AAAG,MAAA,WAAA,QAAO,OAAI;;;;;;;;;;;;;;;;;;;AAED,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAO,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;;;;;;AAH/C,aAKK,QAAA,MAAA,MAAA;AAJH,aAA2C,MAAA,IAAA;;;;;AAC3C,aAEK,MAAA,IAAA;AADH,aAA6C,MAAA,GAAA;;;;AAFxC,UAAA,MAAA,KAAA,OAAA,aAAA,YAAA,SAAO,WAAQ;AAAA,iBAAA,IAAA,QAAA;AAAG,UAAA,MAAA,KAAA,OAAA,aAAA,YAAA,SAAO,OAAI;AAAA,iBAAA,IAAA,QAAA;AAED,UAAA,MAAA,KAAA,OAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,SAAO,GAAG,GAAA;;;;;;;;;;;;;AAJ5C,MAAA,WAAA,QAAO,YAAQR,oBAAA,GAAA;;;;;;;;;;;;;AAAf,UAAA,SAAO,UAAQ;;;;;;;;;;;;;;;;;;;;;;;;;AAmBgB,MAAA,WAAA,SAAS,mDAAmD,IAAA;;;;;;;;;;AAAlG,aAAoC,QAAA,GAAA,MAAA;;;;;;;;;;;;;;;;;;;AAFK,MAAA,WAAA,SAAS,oDAAoD,IAAA;;;;;;;;;;AAAtG,aAAuC,QAAA,GAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA3BhC,MAAA,WAAA,SAAiB,IAAI,SAAiB,MAAM;;;;;;;;;;;;;;;;AAmCpD,MAAA,YAAA,SAAS,QAAQ,IAAA;;;;;kBAhGb,IAAe,MAAAmB,oBAAA,GAAA;;;;;QAiBf,KAAe;AAAA,aAAAQ;;;;;;;AAaf,QAAA,QAAS;AAAO,aAAAL;;;;;;;AAShB,QAAA,QAAS;AAAO,aAAAD;;;;;;AAQd,MAAA,eAAA,OAAY;;qCAAjB,QAAI,MAAA,GAAA;;;kBAmBD,IAAW,GAAC,YAAY,UAAM7B,oBAAA,GAAA;;AAqB9B,QAAA,QAAS;AAAO,aAAAC;;;;;;;;;;;;;;;gBA5Fd,IAAS,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAkEyC,IAAS,EAAA;;;;;;;;;;;;;;;;;oDApE/B,IAAQ,EAAA;AAAA,aAAA,MAAA,OAAA,cAAA;;;;;;;;;;;;;;;;;;;;;;;;oDAsEN,IAAQ,EAAA;AAAA,aAAA,MAAA,OAAA,cAAA;;;;;;;;;;;;mDAuBd,IAAuB;;;;;;;AAlG5D,aAgHK,QAAA,OAAA,MAAA;AA9GH,aAmCK,OAAA,IAAA;AAlCH,aAKK,MAAA,IAAA;AAJH,aAEK,MAAA,IAAA;AADH,aAA2C,MAAA,IAAA;;AAE7C,aAAuB,MAAA,KAAA;;;AAGzB,aAcK,MAAA,IAAA;;;;AACL,aAEK,MAAA,IAAA;;;AACL,aAQK,MAAA,IAAA;;;AAGP,aAwDK,OAAA,KAAA;AAtDH,aAMQ,OAAA,OAAA;;;AAER,aAOQ,OAAA,OAAA;;;AAER,aAWK,OAAA,IAAA;;;;;AAEL,aAsBK,OAAA,IAAA;AArBH,aAKK,MAAA,IAAA;AAJH,aAAuE,MAAA,KAAA;;;;AACvE,aAEK,MAAA,IAAA;AADH,aAA2C,MAAA,IAAA;;;;;AAsBnD,aAaQ,OAAA,MAAA;AAZN,aAMQ,QAAA,OAAA;;;AAER,aAGQ,QAAA,OAAA;AAFN,aAA2B,SAAA,CAAA;;;;;;;;;;;;;kFAtGQ,KAAQ,EAAA,GAAA;;;;qBAEpC,KAAS,EAAA;UAKX,KAAe,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+Cb,uBAAA,QAAY;;uCAAjB,QAAI,MAAA,GAAA;;;;;;;;;;;;;0CAAJ;AAAA;AAcO,UAAA,EAAA,WAAA,MAAA,KAAA,OAAA,aAAA,YAAA,UAAiB,IAAI,UAAiB,MAAM;AAAE,iBAAA,IAAA,QAAA;;sBAAE,KAAS,EAAA;kFAE7B,KAAQ,EAAA,GAAA;;;UAGxC,KAAW,GAAC,YAAY,QAAM;;;;;;;;;;;;;;;;;;;;;;6FAoBJ,KAAuB,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAtKpD,gBAAgB,WAAW,UAAU;QAElC,SAAI;QACJ,WAAM;QACN,UAAK;QACL,aAAQ;QACR,gBAAW;QACX,QAAQ,KAAK,UAAK;QAEvB,WAAW,KAAK;;QAChB,UAAU,KAAK;;AACA,OAAK;QACpB,gBAAgB,KAAK;;QACrB,uBAAuB,KAAK;;QAC5B,SAAS,KAAK;;QAEd,iBAAiB,MAAM;;QACvB,gBAAgB,MAAM;;MAExB;MACA;QAEE,qBAAqB,KAAK;;MAO5B,cAAW,CAAA;oBAsBA;AACb,SAAK,UAAU,WAAW,QAAQ;;QAChC,MAAM,KAAK;AAAA,QACX,cAAcjB,gBAAI,kBAAkB;AAAA,QACpC,UAAUA,gBAAI,aAAa;AAAA;SAE3B,eAAe,MAAM,cAAA;AAEvB,gBAAY,QAAQ;AACpB,gBAAY,MAAK;AAAA;AATV;;AAoC2E,2BAAoB,UAAA,KAAA,KAAA;;;;yBAAc,gCAAG;AAC/G,oBAAA,eAAA,iBAAiB,KAAK,IAAI,GAAG,KAAK,IAAI,sBAAsB,uBAAuB,CAAA,GAAA,cAAA;AACnF,iBAAA,GAAA,uBAAuB,cAAc;AAAA,KAFuE;;AA+EhC;;;AAQrC,gBAAY,MAAK;AAAA;;;;;;;;;;;;;;;;;;;;;;AAvJjE;AAEC,qBAAA,GAAA,uBAAuB,CAAC;AACxB,wBAAA,eAAA,iBAAiB,GAAC,cAAA;AAAA;;;AAInB;cACO,OAAOoD;;YACX,MAAM,KAAK;AAAA,YACX,UAAU;AAAA,YACV,cAAc;AAAA;;UAEd;AAAA,UACA;AAAA,UACA,gBAAgB;AAAA,UAChB,eAAe;AAAA;AAEb,YAAA,SAAS;AAAO;AAGpB,qBAAA,GAAA,cAAc,IAAI;AAAA;;;AAGjB,mBAAA,IAAA,0BAA0B,gBAAgB,mBAAmB,WAAW,qBAAqB;AAAA;;sBAC7F,kBAAkB,QAAQ,qBAAqB,WAAW;AAAA;;AAC5D,mBAAA,GAAE,0BAA0B,KAAK,IAAI,iBAAiB,uBAAuB,CAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACvDjE,MAAM,gCAAgC,kBAAkB;AAAA,EAUrE,YAAY,MAAM,QAAQ,OAAO,WAAW,CAAE,GAAE,UAAU,IAAI;AAC5D,UAAM;AAAA,MACJ,IAAI,6BAA6B,KAAK,MAAM,OAAO,MAAM,MAAM;AAAA,MAC/D,OAAO,KAAK,KAAK,OAAO,mDAAmD,EAAE,WAAWpD,gBAAI,KAAK,IAAI,GAAG;AAAA,MACxG,QAAQ;AAAA,QACN,OAAOqD;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACD;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,UAAU,IAAI;AAAA,MACxC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,gBAAgB;AAAA,IAChC,CAAK;AAAA,EACF;AAAA,EAED,OAAO,cAAc,IAAI;AACvB,WAAO,OAAO,OAAO,GAAG,OAAO,EAAE,OAAO,SAAO,IAAI,OAAO,6BAA6B,IAAI;AAAA,EAC5F;AAAA,EAED,aAAa,KAAK,MAAM,QAAQ,OAAO,WAAW,CAAE,GAAE,UAAU,IAAI;AAClE,UAAM,OAAO,KAAK,cAAc,KAAK,KAAK,MAAM,OAAO,KAAK,MAAM,MAAM,EAAE;AAC1E,QAAI,KAAK,QAAQ;AACf,eAAS,OAAO,MAAM;AACpB,YAAI,OAAO,OAAO,EAAE,OAAO,KAAM,CAAA;AAAA,MAClC;AACD;AAAA,IACD;AACD,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,MAAM,QAAQ,OAAO,UAAU,OAAO,EAAE,OAAO,MAAM,EAAE,OAAO,KAAM,CAAA;AAAA,IACnF,CAAK;AAAA,EACF;AAEH;AAvDqB;ACKN,MAAM,sBAAsB,cAAc;AAAA,EAEvD,cAAc;AACZ,UAAM,YAAW;AACjB,SAAK,aAAa,SAAS,KAAK;AAChC,SAAK,mBAAmB,SAAS,CAAA,CAAE;AACnC,SAAK,aAAa,SAAS,CAAA,CAAE;AAC7B,SAAK,iBAAiB,SAAS,CAAA,CAAE;AACjC,SAAK,aAAa,SAAS,KAAK;AAChC,SAAK,wBAAwB,SAAS,CAAA,CAAE;AACxC,SAAK,yBAAyB,SAAS,CAAA,CAAE;AACzC,SAAK,gBAAgB,SAAS,EAAE;AAAA,EACjC;AAAA,EAED,IAAI,YAAY;AACd,WAAO;AAAA,EACR;AAAA,EAED,qBAAqB;AACnB,UAAM,mBAAkB;AACxB,SAAK,YAAY,KAAK,UAAU,MAAM;AACpC,WAAK,qBAAoB;AAAA,IAC/B,CAAK;AACD,QAAI,KAAK,mBAAmB;AAC1B,WAAK,YAAY,KAAK,mBAAmB,MAAM;AAC7C,aAAK,qBAAoB;AAAA,MACjC,CAAO;AACD,WAAK,YAAY,KAAK,mBAAmB,MAAM;AAC7C,aAAK,kBAAiB;AAAA,MAC9B,CAAO;AAAA,IACF;AACD,SAAK,YAAY,KAAK,YAAY,MAAM;AACtC,WAAK,aAAY;AAAA,IACvB,CAAK;AAAA,EACF;AAAA,EAED,eAAe;AACb,UAAM,aAAY;AAClB,UAAM,QAAQrD,gBAAI,KAAK,KAAK,EAAE,OAAO,UAAQ;AAC3C,aAAO,KAAK,KAAK,QAAQ,CAACA,gBAAI,KAAK,YAAY,EAAE;AAAA,IACvD,CAAK;AACD,SAAK,eAAe,IAAI,MAAM,KAAK,IAAI,IAAIA,gBAAI,KAAK,QAAQ,EAAE,OAAO,WAAS,CAAC,MAAM,UAAU,EAAE,IAAI,UAAQ,KAAK,IAAI,CAAC,CAAC,EAAE,IAAI,UAAS;AAAA,MACrI,OAAO,SAAS,OAAO,KAAK,WAAW,KAAK;AAAA,MAAG;AAAA,IAChD,EAAC,CAAC;AACH,UAAM,mBAAmB,MAAM,OAAO,CAAC,KAAK,SAAS;AACnD,UAAI,CAAC,IAAI,KAAK,OAAO;AACnB,YAAI,KAAK,QAAQ;MAClB;AACD,UAAI,KAAK,MAAM,KAAK,IAAI;AACxB,aAAO;AAAA,IACR,GAAE,CAAE,CAAA;AACL,SAAK,iBAAiB,IAAI,gBAAgB;AAC1C,QAAI,aAAa,OAAO,KAAK,gBAAgB;AAC7C,eAAW,KAAM;AACjB,SAAK,WAAW,IAAI,WAAW,IAAI,UAAQ;AACzC,aAAO;AAAA,QACL,OAAO,SAAS,OAAO,KAAK,WAAW,KAAK;AAAA,QAAG;AAAA,MAChD;AAAA,IACF,CAAA,CAAC;AAAA,EACH;AAAA,EAED,oBAAoB;AAClBA,oBAAI,KAAK,QAAQ,EAAE,QAAQ,UAAQ;AACjC,WAAK,iBAAgB;AAAA,IAC3B,CAAK;AAAA,EACF;AAAA,EAED,WAAW,MAAM;AACf,QAAIyC,cAA4B,KAAK,OAAO,IAAI;AAAG;AACnD,UAAM,QAAQzC,gBAAI,KAAK,QAAQ;AAC/B,UAAM,YAAY,IAAI,KAAK,UAAU,MAAM,IAAI;AAC/C,cAAU,iBAAgB;AAC1B,UAAM,KAAK,SAAS;AACpB,SAAK,SAAS,IAAI,KAAK;AACvB,SAAK,aAAY;AAAA,EAClB;AAAA,EAED,WAAW,MAAM;AACf,QAAIyC,cAA4B,KAAK,OAAO,IAAI;AAAG;AACnD,UAAM,QAAQzC,gBAAI,KAAK,QAAQ;AAC/B,UAAM,WAAW,MAAM,KAAK,eAAY,UAAS,OAAO,KAAK,EAAE;AAC/D,QAAI,CAAC;AAAU;AACf,aAAS,YAAW;AACpB,UAAM,OAAO,MAAM,QAAQ,QAAQ,GAAG,CAAC;AACvC,SAAK,SAAS,IAAI,KAAK;AACvB,SAAK,aAAY;AAAA,EAClB;AAAA,EAED,uBAAuB;AACrB,QAAI,WAAWA,gBAAI,KAAK,QAAQ;AAChC,SAAK,sBAAsB,IAAI,SAAS,uBAAuB,OAAO,CAAC,KAAK,cAAc;AACxF,UAAI,UAAU,QAAQ;AACtB,aAAO;AAAA,IACb,GAAO,CAAA,CAAE,CAAC;AACN,QAAI,KAAK,aAAa,SAAS,qBAAqB;AAClD,YAAM,yBAAyB,SAAS,qBAAqB,KAAK,UAAQ,KAAK,cAAc,KAAK,aAAa;AAC/G,UAAI,wBAAwB;AAC1B,aAAK,uBAAuB,IAAI,sBAAsB;AAAA,MACvD;AAAA,IACF;AAAA,EACF;AAAA,EAED,qBAAqB,MAAM;AACzB,UAAM,WAAWA,gBAAI,KAAK,QAAQ;AAClC,aAAS,uBAAuB,KAAK;AAAA,MACnC;AAAA,MACA,UAAU;AAAA,MACV,kBAAkB;AAAA,MAClB,mBAAmB;AAAA,IACzB,CAAK;AACD,SAAK,SAAS,IAAI,QAAQ;AAAA,EAC3B;AAAA,EAED,wBAAwB,MAAM;AAC5B,UAAM,WAAWA,gBAAI,KAAK,QAAQ;AAClC,UAAM,YAAY,SAAS;AAC3B,UAAM,YAAY,UAAU,KAAK,WAAS,MAAM,SAAS,IAAI;AAC7D,cAAU,OAAO,UAAU,QAAQ,SAAS,GAAG,CAAC;AAChD,SAAK,SAAS,IAAI,QAAQ;AAAA,EAC3B;AAAA,EAED,MAAM,SAAS;AACb,UAAM,WAAWA,gBAAI,KAAK,QAAQ;AAClC,UAAM,kBAAkBA,gBAAI,KAAK,qBAAqB;AACtD,aAAS,yBAAyB,OAAO,OAAO,eAAe;AAC/D,UAAMsD,mBAAiC,KAAK,OAAO,QAAQ;AAC3D5B,kBAAsB,SAAS,gDAAgD,CAAC;AAAA,EACjF;AAAA,EAED,UAAU,UAAU,SAAS;AAC3B,QAAI1B,gBAAI,SAAS,YAAY,EAAE,cAAc,CAAC,KAAK,KAAK;AAAM;AAC9D,4BAAwB,KACtB,UACA,KAAK,OACL,KAAK,WACL,EAAE,QAAS,CACjB;AAAA,EACG;AAEH;AA3IqB;AA6IrB,MAAM,yBAAyB,SAAS;AAAA,EAEtC,YAAY,MAAM;AAChB,UAAM,YAAY,IAAI;AACtB,SAAK,eAAe,SAAS,CAAA,CAAE;AAC/B,SAAK,SAAS,SAAS,CAAA,CAAE;AACzB,SAAK,kBAAkB,SAAS,KAAK;AACrC,SAAK,qBAAqB,SAAS,EAAE;AACrC,SAAK,gBAAgB,SAAS,CAAC;AAAA,EAChC;AAAA,EAED,qBAAqB;AACnB,QAAI,QAAQ;AACZ,UAAM,mBAAkB;AACxB,SAAK,aAAa,IAAIuD,gBAA8B,KAAK,IAAI,CAAC;AAC9D,SAAK,YAAY,KAAK,MAAM,UAAU,MAAM;AAC1C,UAAI,CAAC;AAAO;AACZ,WAAK,iBAAgB;AACrB,WAAK,uBAAsB;AAAA,IACjC,CAAK;AACD,QAAI,KAAK,MAAM,WAAW;AACxB,WAAK,YAAY,KAAK,MAAM,mBAAmB,MAAM;AACnD,YAAI,CAAC;AAAO;AACZ,aAAK,iBAAgB;AACrB,aAAK,uBAAsB;AAAA,MACnC,CAAO;AAAA,IACF;AACD,SAAK,YAAY,KAAK,MAAM,uBAAuB,MAAM;AACvD,UAAI,CAAC;AAAO;AACZ,WAAK,iBAAgB;AAAA,IAC3B,CAAK;AACD,SAAK,YAAY,KAAK,eAAe,MAAM;AACzC,UAAI,CAAC;AAAO;AACZ,WAAK,iBAAgB;AAAA,IAC3B,CAAK;AACD,SAAK,YAAY,KAAK,cAAc,MAAM;AACxC,UAAI,CAAC;AAAO;AACZ,YAAM,EAAE,SAAS,KAAK,aAAa;AACnC,UAAI,YAAY,MAAM,UAAU,MAAM,IAAI,GAAG;AAC3C,aAAK,aAAa,IAAIA,gBAA8B,KAAK,IAAI,CAAC;AAC9D,aAAK,uBAAsB;AAAA,MAC5B;AACD,UAAI,YAAY,MAAM,UAAU,MAAM,OAAO,SAAS,GAAG;AACvD,aAAK,iBAAgB;AAAA,MACtB;AACD,UAAI,YAAY,MAAM,KAAK,UAAU,oBAAoB,GAAG;AAC1D,aAAK,iBAAgB;AAAA,MACtB;AAAA,IACP,CAAK;AACD,YAAQ;AACR,SAAK,uBAAsB;AAC3B,SAAK,YAAY,KAAK,MAAM,YAAY,KAAK,OAAO,KAAK,IAAI,CAAC;AAAA,EAC/D;AAAA,EAED,yBAAyB;AAEvB,UAAM,0BAA0BvD,gBAAI,KAAK,MAAM,QAAQ,EAAE;AAEzD,UAAM,uBAAuBA,gBAAI,KAAK,YAAY,EAAE;AAEpD,QAAI,yBAAyB,UAAU;AACrC,aAAO,KAAK,gBAAgB,IAAI,IAAI;AAAA,IACrC;AAED,UAAM,sBAAsB;AAAA,MAC1B,WAAW,4BAA4B;AAAA,MACvC,OAAO;AAAA,MACP,MAAM;AAAA,IACZ,EAAM,wBAAwB;AAE1B,QAAI,wBAAwB,WAAW,QAAQ,GAAG;AAChD,aAAO,KAAK,gBAAgB,IAAI,wBAAwB,SAAS,KAAK,CAAC;AAAA,IACxE;AAED,SAAK,gBAAgB,IAAI,mBAAmB;AAAA,EAC7C;AAAA,EAED,mBAAmB;AAEjB,UAAM,gBAAgBA,gBAAI,KAAK,aAAa;AAC5C,UAAM,eAAeA,gBAAI,KAAK,YAAY;AAC1C,UAAM,iBAAiBA,gBAAI,KAAK,MAAM,QAAQ;AAC9C,UAAM,gBAAgBA,gBAAI,KAAK,MAAM,iBAAiB;AACtD,UAAM,YAAYwD,cAA4B,KAAK,MAAM;AAAA,MACvD,QAAQ,KAAK,MAAM;AAAA,MACnB,OAAO,KAAK,MAAM;AAAA,MAClB;AAAA,MACA;AAAA,MACA;AAAA,MACA,UAAU;AAAA,IAChB,CAAK;AAED,QAAI,qBAAqBxD,gBAAI,KAAK,kBAAkB;AACpD,QAAI,uBAAuB,IAAI;AAC7B,2BAAqB,KAAK,IAAI,GAAG,UAAU,UAAU,WAAS,MAAM,WAAW,CAAC;AAChF,WAAK,mBAAmB,IAAI,kBAAkB;AAAA,IAC/C;AAED,SAAK,OAAO,IAAI,SAAS;AAAA,EAE1B;AAAA,EAED,SAAS;AACP,UAAM,OAAOA,gBAAI,KAAK,IAAI;AAC1B,UAAM,SAASA,gBAAI,KAAK,MAAM,MAAM;AACpC,UAAM,iBAAiB,CAAC,KAAK,YAAW,EAAG,SAAS,OAAO,YAAW,CAAE;AACxE,UAAM,aAAaA,gBAAI,KAAK,MAAM,UAAU;AAC5C,UAAM,eAAe,eAAe,SAAS,WAAW,YAAW,MAAO,KAAK,KAAK;AACpF,SAAK,SAAS,IAAI,kBAAkB,YAAY;AAAA,EACjD;AAAA,EAED,MAAM,qBAAqB;AACzB,UAAM,eAAeA,gBAAI,KAAK,YAAY;AAC1C,UAAMyD,eAA6B,KAAK,MAAM,EAAE,OAAO,aAAY,CAAE;AAAA,EACtE;AAEH;AApHM;;;;;;;;;;;ACvHE,aAIM,QAAA,MAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4ByB,MAAA,OAAe,qBAAgB,QAAA;AAA/B,uBAAA,QAAA,OAAe;AAAA;;;;;;;;AAOC,MAAA,OAAe,sBAAiB,QAAA;AAAhC,uBAAA,QAAA,OAAe;AAAA;;;;;;;;;;AAzB/C,YAAA,cAAA,GAAA,SAAS,8DAA8D;;;AAC1E,SAAA,cAAA,GAAA,SAAS,yEAAyE;;;;;;;AAO/E,YAAA,cAAA,GAAA,SAAS,8DAA8D;;;AAC1E,SAAA,cAAA,GAAA,SAAS,yEAAyE;;;;;;AAOrF,aAAA,cAAA,GAAA,SAAS,kEAAkE;;;;;;AAO3E,aAAA,cAAA,GAAA,SAAS,mEAAmE;;;;;;;;;;;;;;;;;;;;AA7BrF,aAuCM,QAAA,MAAA,MAAA;AArCJ,aAgCM,MAAA,IAAA;AA9BJ,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;AAFN,aAAuF,QAAA,KAAA;;AACvF,aAA4F,QAAA,EAAA;;AAE9F,aAAmE,MAAA,MAAA;AAA9B,aAAA,UAAA,OAAe;;AAGtD,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;AAFN,aAAuF,QAAA,KAAA;;AACvF,aAA4F,QAAA,EAAA;;AAE9F,aAAmE,MAAA,MAAA;AAA9B,aAAA,UAAA,OAAe;;AAGtD,aAKM,MAAA,IAAA;AAJJ,aAEQ,MAAA,MAAA;;;;AAIV,aAKM,MAAA,IAAA;AAJJ,aAEQ,MAAA,MAAA;;;;AAMZ,aAES,MAAA,MAAA;;;;;;;;;;;;;AA7BgC,eAAA,UAAA,QAAe;AAAA;;AAQf,eAAA,UAAA,QAAe;AAAA;;;;AAO3B,6BAAA,QAAA,QAAe;;;;;;;AAOC,6BAAA,QAAA,QAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QA9C9D,OAAO;AAAA,QAAe,OAAO;AAAA;;QAC7B,OAAO;AAAA,QAAY,OAAO;AAAA,QAAY,QAAS,CAAA,KAAK,KAAK;AAAA;;;MACzC,IAAgB,OAAA,QAAA;2BAAhB,IAAgB;AAAA;;;AAI7B,MAAA,YAAA,WAAqB,iBAAazC,oBAAA;AAQlC,MAAA,YAAA,WAAqB,cAAUC,kBAAA,GAAA;;;;;;;;;;;;;;;;kDApB1B,IAAY,EAAA;AAAA,aAAA,KAAA,OAAA,aAAA;;;;;;;;AAH5B,aAsEM,QAAA,MAAA,MAAA;AApEJ,aAEM,MAAA,IAAA;AADJ,aAA4B,MAAA,GAAA;;AAG9B,aA8DM,MAAA,IAAA;;;AAvDJ,aAqDU,MAAA,OAAA;;;;;;;;;2EA/DE,KAAY,EAAA,GAAA;;;;;;iCAQJ,KAAgB;;;;AAI7B,UAAA,YAAqB,eAAa;;;;;;;;;;;;AAQlC,UAAA,YAAqB,YAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAhC7B,UAAK;QAEV,cAAc,MAAM;;QACpB,gBAAgB,MAAM;;AAExB,MAAA,mBAAmB;;AAeD,uBAAgB;;;;;AAsBW,mBAAe,eAAY,KAAA;;;;;AAQ3B,mBAAe,eAAY,KAAA;;;;;AAOvC,QAAA,OAAA,GAAA,UAAA,eAAe,kBAAgB,KAAA,GAAA;AAA/B,qBAAe,mBAAgB;;;;;;AAOf,QAAA,OAAA,GAAA,UAAA,eAAe,mBAAiB,KAAA,GAAA;AAAhC,qBAAe,oBAAiB;;;;;;AAKf,UAAM,OAAM;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACtEpF,MAAM,iBAAiB,oBAAI;AAEZ,MAAM,eAAe;AAAA,EAElC,OAAO,KAAK,MAAM;AAChB,QAAI,eAAe,IAAI,KAAK,EAAE,GAAG;AAC/B,aAAO,eAAe,IAAI,KAAK,EAAE;AAAA,IAClC;AACD,WAAO,IAAI,KAAK,IAAI;AAAA,EACrB;AAAA,EAED,YAAY,MAAM;AAEhB,SAAK,OAAO;AACZ,SAAK,UAAU,IAAI,YAAY,KAAK,IAAI;AAExC,SAAK,QAAQ,SAAS,CAAC;AAEvB,UAAM,OAAOsC,gBAA8B,KAAK,IAAI;AAEpD,SAAK,OAAO,QAAQ,WAAS;AAC3B,YAAM,QAAQ,WAAS;AACrB,YAAI,CAAC,MAAM,IAAI;AACb,gBAAM,KAAK;QACZ;AAAA,MACT,CAAO;AAAA,IACP,CAAK;AAED,SAAK,OAAO,SAAS,IAAI;AAEzB,SAAK,QAAQ,UAAU,CAAC,OAAM,YAAY;AACxC,YAAM,EAAE,gBAAS;AACjB,UAAI,YAAY,OAAM,UAAU,MAAM,IAAI,GAAG;AAC3C,cAAM,UAAU,YAAY,OAAM,UAAU,MAAM,IAAI;AACtD,cAAM,UAAUvD,gBAAI,KAAK,IAAI;AAC7B,aAAK,KAAK,IAAI,QAAQ,MAAM,YAAY,SAAS,OAAO,CAAC;AAAA,MAC1D;AACD,WAAK,MAAM,IAAI,YAAY,KAAK,KAAK,SAAQ,GAAI,KAAK,UAAU,oBAAoB,CAAC;AAAA,IAC3F,CAAK;AAAA,EAEF;AAAA,EAED,YAAY,YAAY;AACtB,UAAM,OAAOA,gBAAI,KAAK,IAAI;AAC1B,SAAK,OAAO,OAAO,YAAY,CAAC;AAChC,SAAK,KAAK,IAAI,IAAI;AAAA,EACnB;AAAA,EAED,SAAS;AACP,WAAO;AAAA,MACL,MAAM;AAAA,QACJ,CAAC,KAAK,UAAU,uBAAuBA,gBAAI,KAAK,KAAK;AAAA,MACtD;AAAA,MACD,OAAOA,gBAAI,KAAK,IAAI;AAAA,IAC1B;AAAA,EACG;AAEH;AAvDqB;ACJrB,cAAc,MAAM,EAAE,MAAM,MAAM,SAAS,IAAI;AAC3C,QAAM,QAAQ,iBAAiB,IAAI;AACnC,QAAM,YAAY,MAAM,cAAc,SAAS,KAAK,MAAM;AAC1D,QAAM,CAAC,IAAI,MAAM,MAAM,gBAAgB,MAAM,GAAG,EAAE,IAAI,UAAU;AAChE,QAAM,KAAM,KAAK,OAAO,KAAK,QAAQ,KAAK,GAAG,QAAU,IAAG,OAAO;AACjE,QAAM,KAAM,KAAK,MAAM,KAAK,SAAS,KAAK,GAAG,SAAW,IAAG,MAAM;AACjE,QAAM,EAAE,QAAQ,GAAG,WAAW,wBAAC,MAAM,KAAK,KAAK,CAAC,IAAI,KAAtB,aAA2B,SAAS,aAAa;AAC/E,SAAO;AAAA,IACH;AAAA,IACA,UAAU,YAAY,QAAQ,IAAI,SAAS,KAAK,KAAK,KAAK,KAAK,KAAK,EAAE,CAAC,IAAI;AAAA,IAC3E;AAAA,IACA,KAAK,CAAC,GAAG,MAAM;AACX,YAAM,IAAI,IAAI;AACd,YAAM,IAAI,IAAI;AACd,YAAM,KAAK,IAAI,IAAI,KAAK,QAAQ,GAAG;AACnC,YAAM,KAAK,IAAI,IAAI,KAAK,SAAS,GAAG;AACpC,aAAO,cAAc,uBAAuB,QAAQ,cAAc,OAAO;AAAA,IAC5E;AAAA,EACT;AACA;AAnBS;ACFT,MAAM,sBAAsB;AAC5B,MAAM,sBAAsB;AAWrB,+BAA+B,IAAI,OAAO,MAAM;AACnD,KAAG,cACC,IAAI,YAAY,qBAAqB;AAAA,IACjC,QAAQ,EAAC,OAAO,KAAI;AAAA,EAChC,CAAS,CACT;AACA;AANgB;AAcT,+BAA+B,IAAI,OAAO,MAAM;AACnD,KAAG,cACC,IAAI,YAAY,qBAAqB;AAAA,IACjC,QAAQ,EAAC,OAAO,KAAI;AAAA,EAChC,CAAS,CACT;AACA;AANgB;AAST,MAAM,6BAA6B;AACnC,MAAM,0BAA0B;AAChC,MAAM,gCAAgC;AACtC,MAAM,mCAAmC;AAEzC,MAAM,qBAAqB;AAAA,EAC9B,kBAAkB;AAAA,EAClB,gBAAgB;AACpB;AAEO,gDAAgD,aAAa,UAAU,YAAW;AACrF,cAAY,cACR,IAAI,YAAY,4BAA4B;AAAA,IACxC,QAAQ,EAAC,UAAU,sBAAS;AAAA,EACxC,CAAS,CACT;AACA;AANgB;AAaT,uDAAuD,aAAa,YAAW,YAAY;AAC9F,cAAY,cACR,IAAI,YAAY,yBAAyB;AAAA,IACrC,QAAQ,EAAC,uBAAW,MAAM,mBAAmB,kBAAkB,WAAU;AAAA,EACrF,CAAS,CACT;AACA;AANgB;AAQT,oDAAoD,aAAa,YAAW;AAC/E,cAAY,cACR,IAAI,YAAY,yBAAyB;AAAA,IACrC,QAAQ,EAAC,uBAAW,MAAM,mBAAmB,eAAc;AAAA,EACvE,CAAS,CACT;AACA;AANgB;AAOT,2CAA2C,aAAa,UAAU,YAAW;AAChF,cAAY,cACR,IAAI,YAAY,+BAA+B;AAAA,IAC3C,QAAQ,EAAC,UAAU,sBAAS;AAAA,EACxC,CAAS,CACT;AACA;AANgB;AAOT,qCAAqC,YAAW;AACnD,SAAO,cACH,IAAI,YAAY,kCAAkC;AAAA,IAC9C,QAAQ,EAAC,sBAAS;AAAA,EAC9B,CAAS,CACT;AACA;AANgB;AC/ET,MAAM,WAAW;AAAA,EACpB,cAAc;AAAA,EACd,iBAAiB;AAAA,EACjB,yBAAyB;AAAA,EACzB,oBAAoB;AAAA,EACpB,cAAc;AAAA,EACd,kBAAkB;AAAA,EAClB,mBAAmB;AAAA,EACnB,sBAAsB;AAAA,EACtB,wBAAwB;AAAA,EACxB,cAAc;AAClB;AAEO,MAAM,UAAU;AAAA,EACnB,SAAS;AAAA,EACT,UAAU;AACd;AAEO,MAAM,mCAAmC;AACzC,MAAM,gCAAgC;AACtC,MAAM,6BAA6B;AACnC,MAAM,qBAAqB;AAE3B,IAAI,cAAc;AACzB,IAAI,qBAAqB;AAClB,wCAAwC;AAC3C;AACJ;AAFgB;AAGT,wCAAwC;AAC3C,MAAI,uBAAuB,GAAG;AAC1B,UAAM,IAAI,MAAM,sDAAsD;AAAA,EACzE;AACD;AACJ;AALgB;AAwBT,MAAM,aAAa,OAAO,WAAW;AC/CrC,qCAAqC,IAAI;AAC5C,MAAI;AACJ,QAAM,OAAO,GAAG;AAChB,QAAM,QAAQ,iBAAiB,EAAE;AACjC,QAAM,KAAK,MAAM;AAEjB,MAAI,IAAI;AACJ,QAAI,IAAI,IAAI,IAAI;AAChB,QAAI,GAAG,WAAW,WAAW,GAAG;AAC5B,WAAK,GAAG,MAAM,GAAG,EAAE,EAAE,MAAM,IAAI;AAC/B,WAAK,CAAC,GAAG;AACT,WAAK,CAAC,GAAG;AACT,WAAK,CAAC,GAAG;AACT,WAAK,CAAC,GAAG;AAAA,IACZ,WAAU,GAAG,WAAW,SAAS,GAAG;AACjC,WAAK,GAAG,MAAM,GAAG,EAAE,EAAE,MAAM,IAAI;AAC/B,WAAK,CAAC,GAAG;AACT,WAAK,CAAC,GAAG;AACT,WAAK,CAAC,GAAG;AACT,WAAK,CAAC,GAAG;AAAA,IACrB,OAAe;AACH,aAAO;AAAA,IACV;AAED,UAAM,KAAK,MAAM;AACjB,UAAM,IAAI,KAAK,IAAI,KAAM,KAAI,MAAM,WAAW,EAAE;AAChD,UAAM,IAAI,KAAK,IAAI,KAAM,KAAI,MAAM,WAAW,GAAG,MAAM,GAAG,QAAQ,GAAG,IAAI,CAAC,CAAC;AAC3E,UAAM,IAAI,KAAK,KAAK,QAAQ,KAAK,GAAG;AACpC,UAAM,IAAI,KAAK,KAAK,SAAS,KAAK,GAAG;AACrC,WAAO;AAAA,MACH;AAAA,MACA;AAAA,MACA,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,KAAK;AAAA,MACL,OAAO,IAAI;AAAA,MACX,QAAQ,IAAI;AAAA,MACZ,MAAM;AAAA,IAClB;AAAA,EACA,OAAW;AACH,WAAO;AAAA,EACV;AACL;AA1CgB;AAiDT,qCAAqC,IAAI;AAC5C,QAAM,OAAO,4BAA4B,EAAE;AAC3C,SAAO;AAAA,IACH,KAAK,KAAK,MAAM,OAAO;AAAA,IACvB,QAAQ,KAAK,SAAS,OAAO;AAAA,IAC7B,MAAM,KAAK,OAAO,OAAO;AAAA,IACzB,OAAO,KAAK,QAAQ,OAAO;AAAA,EACnC;AACA;AARgB;AAeT,yBAAyB,IAAI;AAChC,QAAM,OAAO,GAAG;AAChB,SAAO;AAAA,IACH,KAAK,KAAK,MAAM,OAAO;AAAA,IACvB,QAAQ,KAAK,SAAS,OAAO;AAAA,IAC7B,MAAM,KAAK,OAAO,OAAO;AAAA,IACzB,OAAO,KAAK,QAAQ,OAAO;AAAA,EACnC;AACA;AARgB;AAoBT,oBAAoB,MAAM;AAC7B,SAAO;AAAA,IACH,GAAI,MAAK,OAAO,KAAK,SAAS;AAAA,IAC9B,GAAI,MAAK,MAAM,KAAK,UAAU;AAAA,EACtC;AACA;AALgB;AAehB,sBAAsB,QAAQ,QAAQ;AAClC,SAAO,KAAK,KAAK,KAAK,IAAI,OAAO,IAAI,OAAO,GAAG,CAAC,IAAI,KAAK,IAAI,OAAO,IAAI,OAAO,GAAG,CAAC,CAAC;AACxF;AAFS;AASF,2BAA2B,OAAO,MAAM;AAC3C,SAAO,MAAM,KAAK,KAAK,UAAU,MAAM,KAAK,KAAK,OAAO,MAAM,KAAK,KAAK,QAAQ,MAAM,KAAK,KAAK;AACpG;AAFgB;AAST,6BAA6B,IAAI;AACpC,SAAO,WAAW,gBAAgB,EAAE,CAAC;AACzC;AAFgB;AAST,4BAA4B,KAAK,KAAK;AACzC,QAAM,YAAY,oBAAoB,GAAG;AACzC,QAAM,UAAU,4BAA4B,GAAG;AAC/C,SAAO,kBAAkB,WAAW,OAAO;AAC/C;AAJgB;AAWT,oCAAoC,KAAK,KAAK;AACjD,QAAM,YAAY,oBAAoB,GAAG;AACzC,QAAM,YAAY,oBAAoB,GAAG;AACzC,SAAO,aAAa,WAAW,SAAS;AAC5C;AAJgB;AAUT,8BAA8B,IAAI;AACrC,QAAM,OAAO,gBAAgB,EAAE;AAC/B,SAAO,KAAK,QAAQ,KAAK,KAAK,OAAO,SAAS,gBAAgB,eAAe,KAAK,SAAS,KAAK,KAAK,MAAM,SAAS,gBAAgB;AACxI;AAHgB;AAWT,yDAAyD,OAAO,IAAI;AACvE,QAAM,OAAO,gBAAgB,EAAE;AAC/B,MAAI,CAAC,kBAAkB,OAAO,IAAI,GAAG;AACjC,WAAO;AAAA,EACV;AACD,SAAO;AAAA,IACH,KAAK,MAAM,IAAI,KAAK;AAAA,IACpB,QAAQ,KAAK,SAAS,MAAM;AAAA,IAC5B,MAAM,MAAM,IAAI,KAAK;AAAA,IAErB,OAAO,KAAK,IAAI,KAAK,OAAO,SAAS,gBAAgB,WAAW,IAAI,MAAM;AAAA,EAClF;AACA;AAZgB;AClKhB,IAAI;AAKG,6BAA6B;AAEhC,0BAAwB,oBAAI;AAChC;AAHgB;AAIhB;AAMO,gCAAgC,IAAI;AAEvC,wBAAsB,OAAO,EAAE;AACnC;AAHgB;AAWhB,yBAAyB,IAAI;AACzB,QAAM,gBAAgB,MAAM,KAAK,GAAG,QAAQ,EAAE,UAAU,WAAS,MAAM,aAAa,6BAA6B,CAAC;AAClH,MAAI,iBAAiB,GAAG;AACpB,QAAI,CAAC,sBAAsB,IAAI,EAAE,GAAG;AAChC,4BAAsB,IAAI,IAAI,oBAAI,IAAK,CAAA;AAAA,IAC1C;AACD,0BAAsB,IAAI,EAAE,EAAE,IAAI,eAAe,4BAA4B,GAAG,SAAS,cAAc,CAAC;AACxG,WAAO;AAAA,EACV;AACD,SAAO;AACX;AAVS;AAuBF,0BAA0B,iBAAiB,mBAAmB;AACjE,MAAI,CAAC,mBAAmB,iBAAiB,iBAAiB,GAAG;AACzD,WAAO;AAAA,EACV;AACD,QAAM,YAAW,kBAAkB;AAEnC,MAAI,UAAS,WAAW,GAAG;AACvB,WAAO,EAAC,OAAO,GAAG,kBAAkB,KAAI;AAAA,EAC3C;AACD,QAAM,gBAAgB,gBAAgB,iBAAiB;AAIvD,WAAS,IAAI,GAAG,IAAI,UAAS,QAAQ,KAAK;AACtC,QAAI,mBAAmB,iBAAiB,UAAS,EAAE,GAAG;AAClD,YAAM,mBAAmB,sBAAsB,IAAI,iBAAiB,KAAK,sBAAsB,IAAI,iBAAiB,EAAE,IAAI,CAAC;AAC3H,UAAI,kBAAkB;AAClB,YAAI,CAAC,kBAAkB,oBAAoB,eAAe,GAAG,gBAAgB,GAAG;AAC5E,iBAAO,EAAC,OAAO,eAAe,kBAAkB,MAAK;AAAA,QACxD;AAAA,MACJ;AACD,aAAO,EAAC,OAAO,GAAG,kBAAkB,MAAK;AAAA,IAC5C;AAAA,EACJ;AAGD,MAAI,mBAAmB,OAAO;AAC9B,MAAI,aAAa;AAEjB,WAAS,IAAI,GAAG,IAAI,UAAS,QAAQ,KAAK;AACtC,UAAM,WAAW,2BAA2B,iBAAiB,UAAS,EAAE;AACxE,QAAI,WAAW,kBAAkB;AAC7B,yBAAmB;AACnB,mBAAa;AAAA,IAChB;AAAA,EACJ;AACD,SAAO,EAAC,OAAO,YAAY,kBAAkB,KAAI;AACrD;AArCgB;ACnDhB,MAAM,iBAAiB;AAEhB,wBAAwB;AAC3B,MAAI;AACJ,6BAA0B;AACtB,oBAAgB,EAAC,cAAc,QAAW,QAAQ,EAAC;AAAA,EACtD;AAFQ;AAGT;AAEA,2BAAyB,aAAa;AAClC,UAAM,EAAC,cAAc,WAAU;AAC/B,QAAI,cAAc;AACd,kBAAY,SAAS,aAAa,IAAI,QAAQ,aAAa,IAAI,MAAM;AACrE,aAAO,sBAAsB,MAAM,gBAAgB,WAAW,CAAC;AAAA,IAClE;AAAA,EACJ;AANQ;AAOT,4BAA0B,YAAY;AAClC,WAAO,iBAAiB;AAAA,EAC3B;AAFQ;AAST,2BAAwB,SAAS,iBAAiB;AAC9C,QAAI,CAAC,iBAAiB;AAClB,aAAO;AAAA,IACV;AACD,UAAM,YAAY,gDAAgD,SAAS,eAAe;AAC1F,QAAI,cAAc,MAAM;AACpB;AACA,aAAO;AAAA,IACV;AACD,UAAM,qBAAqB,CAAC,CAAC,cAAc;AAC3C,QAAI,CAAC,qBAAqB,yBAAyB,CAAC,OAAO,KAAK;AAEhE,QAAI,gBAAgB,eAAe,gBAAgB,cAAc;AAC7D,UAAI,UAAU,SAAS,gBAAgB;AACnC,8BAAsB;AACtB,sBAAc,eAAe,EAAC,GAAG,GAAG,GAAG,EAAC;AACxC,sBAAc,SAAS,iBAAiB,UAAU,MAAM;AAAA,MACxE,WAAuB,UAAU,MAAM,gBAAgB;AACvC,8BAAsB;AACtB,sBAAc,eAAe,EAAC,GAAG,GAAG,GAAG,GAAE;AACzC,sBAAc,SAAS,iBAAiB,UAAU,GAAG;AAAA,MACxD;AACD,UAAI,CAAC,sBAAsB,qBAAqB;AAC5C,wBAAgB,eAAe;AAC/B,eAAO;AAAA,MACV;AAAA,IACJ;AAED,QAAI,gBAAgB,cAAc,gBAAgB,aAAa;AAC3D,UAAI,UAAU,QAAQ,gBAAgB;AAClC,gCAAwB;AACxB,sBAAc,eAAe,EAAC,GAAG,GAAG,GAAG,EAAC;AACxC,sBAAc,SAAS,iBAAiB,UAAU,KAAK;AAAA,MACvE,WAAuB,UAAU,OAAO,gBAAgB;AACxC,gCAAwB;AACxB,sBAAc,eAAe,EAAC,GAAG,IAAI,GAAG,EAAC;AACzC,sBAAc,SAAS,iBAAiB,UAAU,IAAI;AAAA,MACzD;AACD,UAAI,CAAC,sBAAsB,uBAAuB;AAC9C,wBAAgB,eAAe;AAC/B,eAAO;AAAA,MACV;AAAA,IACJ;AACD;AACA,WAAO;AAAA,EACV;AA7CQ;AA+CT,SAAO;AAAA,IACH;AAAA,IACA;AAAA,EACR;AACA;AA1EgB;ACCT,kBAAkB,QAAQ;AAC7B,SAAO,KAAK,UAAU,QAAQ,MAAM,CAAC;AACzC;AAFgB;AAST,kBAAkB,MAAM;AAC3B,MAAI,CAAC,MAAM;AACP,UAAM,IAAI,MAAM,kCAAkC;AAAA,EACrD;AACD,SAAO,UAAU,MAAM,CAAC;AAC5B;AALgB;AAMhB,mBAAmB,MAAM,aAAa,GAAG;AACrC,MAAI,CAAC,KAAK,eAAe;AACrB,WAAO,aAAa;AAAA,EACvB;AACD,SAAO,UAAU,KAAK,eAAe,aAAa,CAAC;AACvD;AALS;AAaF,gCAAgC,MAAM,MAAM;AAC/C,MAAI,OAAO,KAAK,IAAI,EAAE,WAAW,OAAO,KAAK,IAAI,EAAE,QAAQ;AACvD,WAAO;AAAA,EACV;AACD,aAAW,QAAQ,MAAM;AACrB,QAAI,CAAC,CAAE,EAAC,eAAe,KAAK,MAAM,IAAI,KAAK,KAAK,UAAU,KAAK,OAAO;AAClE,aAAO;AAAA,IACV;AAAA,EACJ;AACD,SAAO;AACX;AAVgB;AAkBT,wCAAwC,MAAM,MAAM;AACvD,MAAI,KAAK,WAAW,KAAK,QAAQ;AAC7B,WAAO;AAAA,EACV;AACD,WAAS,IAAI,GAAG,IAAI,KAAK,QAAQ,KAAK;AAClC,QAAI,KAAK,OAAO,KAAK,IAAI;AACrB,aAAO;AAAA,IACV;AAAA,EACJ;AACD,SAAO;AACX;AAVgB;ACrChB,MAAM0D,gBAAc;AACpB,MAAM,eAAe;AACrB,MAAM,EAAA,gBAACC,kBAAgBC,gBAAAA,qBAAkB;AACzC,IAAIC;AAQG,iBAAiB,YAAW,WAAW,aAAaH,eAAa;AAEpE,MAAI;AACJ,MAAI;AACJ,MAAI,2BAA2B;AAC/B,MAAI;AAEJ,QAAM,6BAA6B,MAAM,KAAK,SAAS,EAAE,KAAK,CAAC,KAAK,QAAQ,SAAS,GAAG,IAAI,SAAS,GAAG,CAAC;AAKzG,oBAAkB;AACd,UAAM,yBAAyB,oBAAoB,UAAS;AAC5D,UAAM,WAAWC,iBAAe,wBAAwB,iBAAiB;AAEzE,QACI,CAAC,YACD,+BACA,KAAK,IAAI,4BAA4B,IAAI,uBAAuB,CAAC,IAAI,gBACrE,KAAK,IAAI,4BAA4B,IAAI,uBAAuB,CAAC,IAAI,cACvE;AACEE,eAAO,OAAO,WAAW,QAAQ,UAAU;AAC3C;AAAA,IACH;AACD,QAAI,qBAAqB,UAAS,GAAG;AAEjC,kCAA4B,UAAS;AACrC;AAAA,IACH;AAED,kCAA8B;AAE9B,QAAI,uBAAuB;AAC3B,eAAW,MAAM,4BAA4B;AACzC,UAAI;AAAU,+BAAuB,iBAAiB;AACtD,YAAM,WAAW,iBAAiB,YAAW,EAAE;AAC/C,UAAI,aAAa,MAAM;AAEnB;AAAA,MACH;AACD,YAAM,EAAC,UAAS;AAChB,6BAAuB;AAEvB,UAAI,OAAO,mBAAmB;AAC1B,6BAAqB,8CAA8C,mBAAmB,YAAW,EAAE;AACnG,+CAAuC,IAAI,UAAU,UAAS;AAC9D,4BAAoB;AAAA,MACpC,WAAuB,UAAU,gBAAgB;AACjC,0CAAkC,IAAI,UAAU,UAAS;AACzD,yBAAiB;AAAA,MACpB;AAED;AAAA,IACH;AAED,QAAI,CAAC,wBAAwB,4BAA4B,mBAAmB;AACxE,iDAA2C,mBAAmB,UAAS;AACvE,0BAAoB;AACpB,uBAAiB;AACjB,iCAA2B;AAAA,IACvC,OAAe;AACH,iCAA2B;AAAA,IAC9B;AACDA,aAAO,OAAO,WAAW,QAAQ,UAAU;AAAA,EAC9C;AArDQ;AAsDT;AACJ;AAnEgB;AAsET,qBAAqB;AAExB,eAAaA,MAAI;AACjBD;AACA;AACJ;AALgB;AC1FhB,MAAM,cAAc;AACpB,IAAI;AAOG,6BAA6B,GAAG;AACnC,QAAM,IAAI,EAAE,UAAU,EAAE,QAAQ,KAAK;AACrC,kBAAgB,EAAC,GAAG,EAAE,SAAS,GAAG,EAAE,QAAO;AAC/C;AAHgB;AAIhB,MAAM,EAAC,gBAAgB,mBAAkB;AACzC,IAAI;AAEJ,gBAAgB;AACZ,MAAI,eAAe;AACf,UAAM,WAAW,eAAe,eAAe,SAAS,eAAe;AACvE,QAAI;AAAU;EACjB;AACD,SAAO,OAAO,WAAW,MAAM,WAAW;AAC9C;AANS;AAWF,6BAA6B;AAEhC,SAAO,iBAAiB,aAAa,mBAAmB;AACxD,SAAO,iBAAiB,aAAa,mBAAmB;AACxD;AACJ;AALgB;AAUT,gCAAgC;AAEnC,SAAO,oBAAoB,aAAa,mBAAmB;AAC3D,SAAO,oBAAoB,aAAa,mBAAmB;AAC3D,kBAAgB;AAChB,SAAO,aAAa,IAAI;AACxB;AACJ;AAPgB;AC/BT,yBAAyB,IAAI;AAClC,QAAM,SAAS,GAAG,UAAU,IAAI;AAEhC,QAAM,SAAS,CAAA;AACf,QAAM,aAAa,GAAG,YAAY;AAClC,QAAM,UAAU,aAAa,CAAC,EAAE,IAAI,CAAC,GAAG,GAAG,iBAAiB,QAAQ,CAAC;AACrE,aAAW,UAAU,SAAS;AAC5B,WAAO,KAAK,OAAO,KAAK;AAAA,EACzB;AAED,MAAI,QAAQ,UAAU,GAAG;AACvB,WAAO;AAAA,EACR;AAED,QAAM,gBAAgB,aAAa,CAAC,MAAM,IAAI,CAAC,GAAG,OAAO,iBAAiB,QAAQ,CAAC;AACnF,WAAS,IAAI,GAAG,IAAI,cAAc,QAAQ,KAAK;AAC7C,UAAM,SAAS,cAAc;AAC7B,UAAM,QAAQ,OAAO;AACrB,UAAM,WAAW,OAAO,cAAc,iBAAiB,QAAQ;AAC/D,QAAI,UAAU;AACZ,eAAS,aAAa,YAAY,IAAI;AAAA,IACvC;AAAA,EACF;AAED,SAAO;AACT;AAzBgB;ACLhB,MAAM,8BAA8B;AAOpC,aAAa,UAAU;AACnB,SAAO,GAAG,YAAY;AAC1B;AAFS;AASF,kCAAkC,iBAAiB,oBAAoB;AAC1E,QAAM,OAAO,gBAAgB;AAC7B,QAAM,aAAY,gBAAgB,eAAe;AACjD,mBAAiB,iBAAiB,UAAS;AAC3C,aAAU,KAAK;AACf,aAAU,MAAM,WAAW;AAC3B,MAAI,UAAU,KAAK;AACnB,MAAI,WAAW,KAAK;AACpB,aAAU,MAAM,MAAM,GAAG;AACzB,aAAU,MAAM,OAAO,GAAG;AAC1B,MAAI,oBAAoB;AACpB,UAAM,SAAS,WAAW,IAAI;AAC9B,eAAW,OAAO,IAAI,mBAAmB;AACzC,gBAAY,OAAO,IAAI,mBAAmB;AAC1C,WAAO,WAAW,MAAM;AACpB,iBAAU,MAAM,MAAM,GAAG;AACzB,iBAAU,MAAM,OAAO,GAAG;AAAA,IAC7B,GAAE,CAAC;AAAA,EACP;AACD,aAAU,MAAM,SAAS;AAEzB,aAAU,MAAM,YAAY;AAC5B,aAAU,MAAM,SAAS,GAAG,KAAK;AACjC,aAAU,MAAM,QAAQ,GAAG,KAAK;AAChC,aAAU,MAAM,aAAa,GAAG,IAAI,KAAK,MAAM,IAAI,MAAM,MAAM,IAAI,kBAAkB,MAAM,IAAI,SAAS,MAAM,IAAI,OAAO;AAEzH,SAAO,WAAW,MAAO,WAAU,MAAM,cAAc,KAAK,IAAI,OAAO,MAAM,IAAI,QAAQ,KAAM,CAAC;AAChG,aAAU,MAAM,SAAS;AACzB,aAAU,MAAM,SAAS;AAEzB,SAAO;AACX;AA/BgB;AAqCT,6CAA6C,YAAW;AAC3D,aAAU,MAAM,SAAS;AAC7B;AAFgB;AAYT,qCAAqC,YAAW,YAAY,eAAe,eAAe,yBAAyB;AACtH,QAAM,UAAU,WAAW;AAC3B,QAAM,gBAAgB,WAAU;AAChC,QAAM,cAAc,QAAQ,QAAQ,cAAc;AAClD,QAAM,eAAe,QAAQ,SAAS,cAAc;AACpD,MAAI,eAAe,cAAc;AAC7B,UAAM,iDAAiD;AAAA,MACnD,MAAO,iBAAgB,cAAc,QAAQ,cAAc;AAAA,MAC3D,KAAM,iBAAgB,cAAc,OAAO,cAAc;AAAA,IACrE;AACQ,eAAU,MAAM,SAAS,GAAG,QAAQ;AACpC,eAAU,MAAM,QAAQ,GAAG,QAAQ;AACnC,eAAU,MAAM,OAAO,GAAG,WAAW,WAAU,MAAM,IAAI,IAAI,+CAA+C,OAAO;AACnH,eAAU,MAAM,MAAM,GAAG,WAAW,WAAU,MAAM,GAAG,IAAI,+CAA+C,MAAM;AAAA,EACnH;AAGD,mBAAiB,YAAY,UAAS;AACtC;AACJ;AAnBgB;AAyBhB,0BAA0B,YAAY,UAAU;AAC5C,QAAM,gBAAgB,OAAO,iBAAiB,UAAU;AACxD,QAAM,KAAK,aAAa,EACnB,OACG,OACI,EAAE,WAAW,YAAY,KACzB,EAAE,WAAW,SAAS,KACtB,EAAE,WAAW,MAAM,KACnB,EAAE,WAAW,MAAM,KACnB,EAAE,WAAW,OAAO,KACpB,EAAE,WAAW,SAAS,KACtB,EAAE,WAAW,SAAS,KACtB,EAAE,WAAW,MAAM,KACnB,EAAE,WAAW,QAAQ,KACrB,MAAM,aACN,MAAM,WACN,MAAM,iBACb,EACA,QAAQ,OAAK,SAAS,MAAM,YAAY,GAAG,cAAc,iBAAiB,CAAC,GAAG,cAAc,oBAAoB,CAAC,CAAC,CAAC;AAC5H;AAnBS;AA0BF,wBAAwB,aAAa,cAAc;AACtD,cAAY,YAAY;AACxB,cAAY,cAAc,MAAM;AAChC,MAAI,CAAC,cAAc;AACf,gBAAY,MAAM,aAAa;AAC/B,gBAAY,MAAM,mBAAmB;AACrC,gBAAY,MAAM,SAAS;AAAA,EACnC,OAAW;AACH,gBAAY,MAAM,aAAa;AAC/B,gBAAY,MAAM,mBAAmB;AACrC,gBAAY,MAAM,SAAS;AAAA,EAC9B;AACL;AAZgB;AAkBT,qBAAqB,YAAY;AACpC,aAAW,MAAM,UAAU;AAC3B,aAAW,MAAM,WAAW;AAC5B,aAAW,MAAM,SAAS;AAC9B;AAJgB;AAUT,0BAA0B,UAAU;AACvC,WAAS,MAAM,aAAa;AAC5B,WAAS,aAAa,+BAA+B,MAAM;AAC/D;AAHgB;AAST,iCAAiC,UAAU;AAC9C,WAAS,MAAM,aAAa;AAC5B,WAAS,gBAAgB,6BAA6B;AAC1D;AAHgB;AAWT,8BAA8B,WAAW,YAAY,MAAM;AAAA,GAAI,aAAa,MAAM,IAAI;AACzF,YAAU,QAAQ,QAAM;AACpB,UAAM,UAAS,UAAU,EAAE;AAC3B,WAAO,KAAK,OAAM,EAAE,QAAQ,WAAS;AACjC,SAAG,MAAM,SAAS,QAAO;AAAA,IACrC,CAAS;AACD,eAAW,EAAE,EAAE,QAAQ,OAAK,GAAG,UAAU,IAAI,CAAC,CAAC;AAAA,EACvD,CAAK;AACL;AARgB;AAgBT,gCAAgC,WAAW,YAAY,MAAM;AAAA,GAAI,aAAa,MAAM,IAAI;AAC3F,YAAU,QAAQ,QAAM;AACpB,UAAM,UAAS,UAAU,EAAE;AAC3B,WAAO,KAAK,OAAM,EAAE,QAAQ,WAAS;AACjC,SAAG,MAAM,SAAS;AAAA,IAC9B,CAAS;AACD,eAAW,EAAE,EAAE,QAAQ,OAAK,GAAG,UAAU,SAAS,CAAC,KAAK,GAAG,UAAU,OAAO,CAAC,CAAC;AAAA,EACtF,CAAK;AACL;AARgB;AAeT,0BAA0B,IAAI;AACjC,QAAM,oBAAoB,GAAG,MAAM;AACnC,KAAG,MAAM,YAAY,OAAO,iBAAiB,EAAE,EAAE,iBAAiB,QAAQ;AAC1E,QAAM,mBAAmB,GAAG,MAAM;AAClC,KAAG,MAAM,WAAW,OAAO,iBAAiB,EAAE,EAAE,iBAAiB,OAAO;AACxE,SAAO,uCAAgB;AACnB,OAAG,MAAM,YAAY;AACrB,OAAG,MAAM,WAAW;AAAA,EAC5B,GAHW;AAIX;AATgB;ACnKhB,MAAME,2BAAyB;AAC/B,MAAM,8BAA8B;AACpC,MAAM,oCAAoC;AAC1C,MAAMC,8BAA4B;AAAA,EAC9B,SAAS;AACb;AAEA,IAAI;AACJ,IAAI;AACJ,IAAI;AACJ,IAAI;AACJ,IAAI;AACJ,IAAI;AACJ,IAAI;AACJ,IAAI;AACJ,IAAI;AACJ,IAAI;AACJ,IAAI,0BAA0B;AAC9B,IAAI,yBAAyB;AAC7B,IAAI;AACJ,IAAI,0BAA0B;AAC9B,IAAI,+BAA+B,CAAA;AAGnC,MAAMC,oBAAkB,oBAAI;AAE5B,MAAMC,eAAa,oBAAI;AAEvB,MAAM,wBAAwB,oBAAI;AAGlC,4BAA0B,YAAY,MAAM;AAExC,MAAI,CAACD,kBAAgB,IAAI,IAAI,GAAG;AAC5BA,sBAAgB,IAAI,MAAM,oBAAI,IAAK,CAAA;AAAA,EACtC;AACD,MAAI,CAACA,kBAAgB,IAAI,IAAI,EAAE,IAAI,UAAU,GAAG;AAC5CA,sBAAgB,IAAI,IAAI,EAAE,IAAI,UAAU;AACxC;EACH;AACL;AATSE;AAUT,8BAA4B,YAAY,MAAM;AAC1CF,oBAAgB,IAAI,IAAI,EAAE,OAAO,UAAU;AAC3C;AACA,MAAIA,kBAAgB,IAAI,IAAI,EAAE,SAAS,GAAG;AACtCA,sBAAgB,OAAO,IAAI;AAAA,EAC9B;AACL;AANSG;AAST,+BAA+B;AAE3B;AACA,QAAM,YAAYH,kBAAgB,IAAI,aAAa;AACnD,aAAW,MAAM,WAAW;AACxB,OAAG,iBAAiB,4BAA4B,oBAAoB;AACpE,OAAG,iBAAiB,yBAAyB,iBAAiB;AAC9D,OAAG,iBAAiB,+BAA+B,wBAAwB;AAAA,EAC9E;AACD,SAAO,iBAAiB,kCAAkCI,YAAU;AAEpE,QAAM,wBAAwB,KAAK,IAC/B,6BACA,GAAG,MAAM,KAAK,UAAU,KAAI,CAAE,EAAE,IAAI,QAAMH,aAAW,IAAI,EAAE,EAAE,uBAAuB,CAC5F;AACI,UAAQ,WAAW,WAAW,wBAAwB,IAAI;AAC9D;AAhBS;AAiBT,iCAAiC;AAE7B;AACA,QAAM,YAAYD,kBAAgB,IAAI,aAAa;AACnD,aAAW,MAAM,WAAW;AACxB,OAAG,oBAAoB,4BAA4B,oBAAoB;AACvE,OAAG,oBAAoB,yBAAyB,iBAAiB;AACjE,OAAG,oBAAoB,+BAA+B,wBAAwB;AAAA,EACjF;AACD,SAAO,oBAAoB,kCAAkCI,YAAU;AACvE;AACJ;AAXS;AAcT,kCAAkC,OAAO;AACrC,SAAO,MAAM,UAAU,UAAQ,KAAK,iBAAiB,0BAA0B;AACnF;AAFS;AAGT,8BAA8B,OAAO;AAEjC,SAAO,MAAM,UAAU,UAAQ,CAAC,CAAC,KAAK,qCAAqC,KAAK,iBAAiB,0BAA0B;AAC/H;AAHS;AAMT,8BAA8B,GAAG;AAE7B,MAAI,EAAC,OAAO,2BAA0BH,aAAW,IAAI,EAAE,aAAa;AACpE,MAAI,0BAA0B,EAAE,kBAAkB,gBAAgB;AAE9D;AAAA,EACH;AACD,4BAA0B;AAE1B,UAAQ,MAAM,OAAO,UAAQ,KAAK,iBAAiB,aAAa,YAAY;AAG5E,MAAI,mBAAmB,EAAE,eAAe;AACpC,UAAM,kBAAkBA,aAAW,IAAI,cAAc,EAAE;AACvD,UAAM,qBAAqB,gBAAgB,OAAO,UAAQ,CAAC,KAAK,iCAAiC;AACjG,0BAAsB,gBAAgB,oBAAoB;AAAA,MACtD,SAAS,SAAS;AAAA,MAClB,IAAI,cAAc;AAAA,MAClB,QAAQ,QAAQ;AAAA,IAC5B,CAAS;AAAA,EACT,OAAW;AACH,UAAM,uBAAuB,yBAAyB,KAAK;AAC3D,QAAI,yBAAyB,IAAI;AAG7B,YAAM,OAAO,sBAAsB,CAAC;AAAA,IACvC;AAAA,EACJ;AAED,QAAM,EAAC,OAAO,qBAAoB,EAAE,OAAO;AAC3C,QAAM,cAAc,oBAAoB,UAAU,EAAE,cAAc,SAAS,SAAS,IAAI,QAAQ,IAAI;AACpG,qBAAmB,EAAE;AACrB,QAAM,OAAO,aAAa,GAAG,YAAY;AACzC,wBAAsB,EAAE,eAAe,OAAO,EAAC,SAAS,SAAS,iBAAiB,IAAI,cAAc,cAAc,QAAQ,QAAQ,QAAO,CAAC;AAC9I;AAlCS;AAoCT,2BAA2B,GAAG;AAE1B,MAAI,CAAC;AAAyB;AAE9B,QAAM,EAAC,OAAO,2BAA0BA,aAAW,IAAI,EAAE,aAAa;AACtE,MAAI,0BAA0B,EAAE,kBAAkB,kBAAkB,EAAE,kBAAkB,kBAAkB;AAEtG;AAAA,EACH;AACD,QAAM,cAAc,qBAAqB,KAAK;AAC9C,QAAM,aAAa,MAAM,OAAO,aAAa,CAAC,EAAE;AAChD,qBAAmB;AACnB,QAAM,EAAC,MAAM,eAAc,EAAE;AAC7B,MACI,SAAS,mBAAmB,kBAC3B,SAAS,mBAAmB,oBAAoB,eAAe,kBAAkBA,aAAW,IAAI,UAAU,EAAE,wBAC/G;AAEE,8BAA0B;AAC1B,uBAAmB;AACnB,UAAM,kBAAkBA,aAAW,IAAI,cAAc,EAAE;AACvD,oBAAgB,OAAO,aAAa,GAAG,UAAU;AACjD,0BAAsB,gBAAgB,iBAAiB;AAAA,MACnD,SAAS,SAAS;AAAA,MAClB,IAAI,cAAc;AAAA,MAClB,QAAQ,QAAQ;AAAA,IAC5B,CAAS;AAAA,EACJ;AAED,wBAAsB,EAAE,eAAe,OAAO;AAAA,IAC1C,SAAS,SAAS;AAAA,IAClB,IAAI,cAAc;AAAA,IAClB,QAAQ,QAAQ;AAAA,EACxB,CAAK;AACL;AAlCS;AAmCT,kCAAkC,GAAG;AAEjC,QAAM,EAAC,OAAO,2BAA0BA,aAAW,IAAI,EAAE,aAAa;AACtE,MAAI,0BAA0B,EAAE,kBAAkB,gBAAgB;AAE9D;AAAA,EACH;AACD,4BAA0B;AAC1B,QAAM,EAAC,UAAS,EAAE,OAAO;AACzB,QAAM,cAAc,qBAAqB,KAAK;AAC9C,QAAM,OAAO,aAAa,CAAC;AAC3B,QAAM,OAAO,OAAO,GAAG,YAAY;AACnC,wBAAsB,EAAE,eAAe,OAAO,EAAC,SAAS,SAAS,oBAAoB,IAAI,cAAc,cAAc,QAAQ,QAAQ,QAAO,CAAC;AACjJ;AAbS;AAgBT,yBAAyB,GAAG;AACxB,IAAE,eAAc;AAChB,QAAM,IAAI,EAAE,UAAU,EAAE,QAAQ,KAAK;AACrC,yBAAuB,EAAC,GAAG,EAAE,SAAS,GAAG,EAAE,QAAO;AAClD,YAAU,MAAM,YAAY,eAAe,qBAAqB,IAAI,uBAAuB,QACvF,qBAAqB,IAAI,uBAAuB;AAExD;AAPS;AAST,wBAAsB;AAElB,2BAAyB;AAEzB,SAAO,oBAAoB,aAAa,eAAe;AACvD,SAAO,oBAAoB,aAAa,eAAe;AACvD,SAAO,oBAAoB,WAAWG,YAAU;AAChD,SAAO,oBAAoB,YAAYA,YAAU;AACjD;AACA,sCAAoC,SAAS;AAE7C,MAAI,CAAC,kBAAkB;AAEnB,uBAAmB;AAAA,EACtB;AAED,MAAI,EAAC,OAAO,SAAQH,aAAW,IAAI,gBAAgB;AACnD,yBACID,kBAAgB,IAAI,IAAI,GACxB,QAAMC,aAAW,IAAI,EAAE,EAAE,iBACzB,QAAMA,aAAW,IAAI,EAAE,EAAE,iBACjC;AACI,MAAI,cAAc,qBAAqB,KAAK;AAE5C,MAAI,gBAAgB;AAAI,kBAAc;AACtC,UAAQ,MAAM,IAAI,UAAS,KAAK,oCAAoC,gBAAgB,IAAK;AACzF,gCAA8B;AAC1B;AACA,0BAAsB,kBAAkB,OAAO;AAAA,MAC3C,SAAS,0BAA0B,SAAS,yBAAyB,SAAS;AAAA,MAC9E,IAAI,cAAc;AAAA,MAClB,QAAQ,QAAQ;AAAA,IAC5B,CAAS;AACD,QAAI,qBAAqB,gBAAgB;AAErC,4BAAsB,gBAAgBA,aAAW,IAAI,cAAc,EAAE,OAAO;AAAA,QACxE,SAAS,SAAS;AAAA,QAClB,IAAI,cAAc;AAAA,QAClB,QAAQ,QAAQ;AAAA,MAChC,CAAa;AAAA,IACJ;AACD,4BAAwB,iBAAiB,SAAS,YAAY;AAC9D;EACH;AAjBQ;AAkBT,gCAA8B,aAAa,kBAAkB;AACjE;AA7CSG;AAgDT,uCAAuC,aAAa,UAAU;AAC1D,QAAM,eAAe,4BAA4B,iBAAiB,SAAS,YAAY;AACvF,QAAM,eAAe;AAAA,IACjB,GAAG,aAAa,OAAO,WAAW,UAAU,MAAM,IAAI;AAAA,IACtD,GAAG,aAAa,MAAM,WAAW,UAAU,MAAM,GAAG;AAAA,EAC5D;AACI,QAAM,EAAC,4BAA2BH,aAAW,IAAI,gBAAgB;AACjE,QAAM,aAAa,aAAa;AAChC,YAAU,MAAM,aAAa,UAAU,MAAM,aAAa,UAAU,MAAM,aAAa,MAAM,aAAa;AAC1G,YAAU,MAAM,YAAY,eAAe,aAAa,QAAQ,aAAa;AAC7E,SAAO,WAAW,UAAU,uBAAuB;AACvD;AAXS;AAaT,uCAAuC,IAAI,SAAS;AAChD,+BAA6B,KAAK,EAAC,IAAI,QAAO,CAAC;AAC/C,SAAO,sBAAsB,MAAM;AAC/B,gBAAY,EAAE;AACd,aAAS,KAAK,YAAY,EAAE;AAAA,EACpC,CAAK;AACL;AANS;AAQT,2BAA2B;AACvB,YAAU,OAAM;AAChB,qBAAmB,OAAM;AACzB,MAAI,6BAA6B,QAAQ;AAErC,iCAA6B,QAAQ,CAAC,EAAC,IAAI,cAAa;AACpD;AACA,SAAG,OAAM;AAAA,IACrB,CAAS;AACD,mCAA+B,CAAA;AAAA,EAClC;AACD,cAAY;AACZ,uBAAqB;AACrB,kBAAgB;AAChB,kBAAgB;AAChB,mBAAiB;AACjB,gBAAc;AACd,iBAAe;AACf,qBAAmB;AACnB,2BAAyB;AACzB,yBAAuB;AACvB,4BAA0B;AAC1B,2BAAyB;AACzB,gCAA8B;AAC9B,4BAA0B;AAC9B;AAzBS;AA2BF,mBAAiB,MAAM,SAAS;AACnC,MAAI,cAAc;AAClB,QAAM,SAAS;AAAA,IACX,OAAO;AAAA,IACP,MAAM;AAAA,IACN,gBAAgB;AAAA,IAChB,cAAc;AAAA,IACd,eAAe;AAAA,IACf,wBAAwB;AAAA,IACxB,iBAAiBF;AAAAA,IACjB,mBAAmB,CAAE;AAAA,IACrB,yBAAyB,MAAM;AAAA,IAAE;AAAA,IACjC,uBAAuB;AAAA,EAC/B;AAEI,MAAI,UAAU,oBAAI;AAElB,+BAA6B;AACzB,WAAO,iBAAiB,aAAa,+BAA+B,EAAC,SAAS,MAAK,CAAC;AACpF,WAAO,iBAAiB,aAAa,+BAA+B,EAAC,SAAS,OAAO,SAAS,MAAK,CAAC;AACpG,WAAO,iBAAiB,WAAW,kBAAkB,EAAC,SAAS,MAAK,CAAC;AACrE,WAAO,iBAAiB,YAAY,kBAAkB,EAAC,SAAS,MAAK,CAAC;AAAA,EACzE;AALQ;AAMT,kCAAgC;AAC5B,WAAO,oBAAoB,aAAa,6BAA6B;AACrE,WAAO,oBAAoB,aAAa,6BAA6B;AACrE,WAAO,oBAAoB,WAAW,gBAAgB;AACtD,WAAO,oBAAoB,YAAY,gBAAgB;AAAA,EAC1D;AALQ;AAMT,8BAA4B;AACxB;AACA,yBAAqB;AACrB,6BAAyB;AACzB,2BAAuB;AAAA,EAC1B;AALQ;AAOT,yCAAuC,GAAG;AACtC,MAAE,eAAc;AAChB,UAAM,IAAI,EAAE,UAAU,EAAE,QAAQ,KAAK;AACrC,2BAAuB,EAAC,GAAG,EAAE,SAAS,GAAG,EAAE,QAAO;AAClD,QACI,KAAK,IAAI,qBAAqB,IAAI,uBAAuB,CAAC,KAAK,qCAC/D,KAAK,IAAI,qBAAqB,IAAI,uBAAuB,CAAC,KAAK,mCACjE;AACE;AACA;IACH;AAAA,EACJ;AAXQ;AAYT,2BAAyB,GAAG;AAExB,QAAI,EAAE,WAAW,EAAE,iBAAkB,GAAE,OAAO,UAAU,UAAa,EAAE,OAAO,oBAAoB;AAE9F;AAAA,IACH;AAED,QAAI,EAAE,QAAQ;AAEV;AAAA,IACH;AACD,QAAI,yBAAyB;AAEzB;AAAA,IACH;AACD,MAAE,gBAAe;AACjB,UAAM,IAAI,EAAE,UAAU,EAAE,QAAQ,KAAK;AACrC,6BAAyB,EAAC,GAAG,EAAE,SAAS,GAAG,EAAE,QAAO;AACpD,2BAAuB,EAAC,GAAG,uBAAsB;AACjD,yBAAqB,EAAE;AACvB;EACH;AArBQ;AAuBT,6BAA2B;AAEvB,8BAA0B;AAG1B,UAAM,aAAa,QAAQ,IAAI,kBAAkB;AACjD,kBAAc;AACd,qBAAiB,mBAAmB;AAEpC,UAAM,WAAW,eAAe;AAChC,UAAM,qBAAqB,SAAS,QAAQ;AAC5C,UAAM,EAAC,OAAO,MAAM,0BAAyB;AAC7C,oBAAgB,EAAC,GAAG,MAAM,YAAW;AACrC,oBAAgB;AAChB,mBAAe,EAAC,GAAG,eAAe,CAAC,mCAAmC,KAAI;AAE1E,UAAM,oBAAoB,EAAC,GAAG,cAAc,CAAC,cAAc,2BAA0B;AAGrF,gBAAY,yBAAyB,oBAAoB,yBAAyB,oBAAoB;AAEtG,wCAAoC;AAChC,UAAI,CAAC,UAAU,eAAe;AAC1B,2BAAmB,YAAY,SAAS;AAExC,kBAAU,MAAK;AACf;AACA,oBAAY,kBAAkB;AAC9B,2BAAmB,YAAY,kBAAkB;AAAA,MACjE,OAAmB;AACH,eAAO,sBAAsB,wBAAwB;AAAA,MACxD;AAAA,IACJ;AAXQ;AAYT,WAAO,sBAAsB,wBAAwB;AAErD,yBACI,MAAM,KAAKC,kBAAgB,IAAI,OAAO,IAAI,CAAC,EAAE,OAAO,QAAM,OAAO,kBAAkB,CAACC,aAAW,IAAI,EAAE,EAAE,sBAAsB,GAC7H,QAAMA,aAAW,IAAI,EAAE,EAAE,iBACzB,QAAMA,aAAW,IAAI,EAAE,EAAE,iBACrC;AAGQ,UAAM,OAAO,YAAY,GAAG,iBAAiB;AAC7C,kCAA8B,iBAAiB,cAAc;AAE7D,0BAAsB,gBAAgB,OAAO,EAAC,SAAS,SAAS,cAAc,IAAI,cAAc,cAAc,QAAQ,QAAQ,QAAO,CAAC;AAGtI,WAAO,iBAAiB,aAAa,iBAAiB,EAAC,SAAS,MAAK,CAAC;AACtE,WAAO,iBAAiB,aAAa,iBAAiB,EAAC,SAAS,OAAO,SAAS,MAAK,CAAC;AACtF,WAAO,iBAAiB,WAAWG,cAAY,EAAC,SAAS,MAAK,CAAC;AAC/D,WAAO,iBAAiB,YAAYA,cAAY,EAAC,SAAS,MAAK,CAAC;AAAA,EACnE;AApDQ;AAsDT,qBAAmB;AAAA,IACf,QAAQ;AAAA,IACR,gBAAgB,0BAA0B;AAAA,IAC1C,MAAM,UAAUN;AAAAA,IAChB,eAAe;AAAA,IACf,gBAAgB;AAAA,IAChB,yBAAyB;AAAA,IACzB,kBAAkBC;AAAAA,IAClB,oBAAoB,CAAE;AAAA,IACtB,0BAA0B,6BAAM;AAAA,IAAE,GAAR;AAAA,IAC1B,wBAAwB;AAAA,KACzB;AACC,WAAO,0BAA0B;AACjC,QAAI,OAAO,QAAQ,YAAY,OAAO,MAAM;AACxCI,2BAAmB,MAAM,OAAO,IAAI;AAAA,IACvC;AACD,WAAO,OAAO;AACdD,uBAAiB,MAAM,OAAO;AAC9B,WAAO,QAAQ,CAAC,GAAG,KAAK;AACxB,WAAO,eAAe;AACtB,WAAO,gBAAgB;AACvB,WAAO,0BAA0B;AACjC,WAAO,wBAAwB;AAG/B,QACI,eACA,2BACA,CAAC,0BACA,EAAC,uBAAuB,iBAAiB,OAAO,eAAe,KAC5D,CAAC,+BAA+B,mBAAmB,OAAO,iBAAiB,IACjF;AACE,6BACI,CAAC,IAAI,GACL,MAAM,OAAO,iBACb,MAAM,iBACtB;AACY,2BACI,CAAC,IAAI,GACL,MAAM,iBACN,MAAM,iBACtB;AAAA,IACS;AACD,WAAO,kBAAkB;AACzB,WAAO,oBAAoB,CAAC,GAAG,iBAAiB;AAGhD,2BAAuB,IAAI,UAAU;AACjC,aAAOD,aAAW,IAAI,EAAE,IAAIA,aAAW,IAAI,EAAE,EAAE,YAAY,OAAO;AAAA,IACrE;AAFQ;AAGT,QAAI,eAAe,2BAA2B,OAAO,2BAA2B,wBAAwB;AACpG,UAAI,wBAAwB;AACxB,+BACI,CAAC,IAAI,GACL,QAAM,cAAc,IAAI,iBAAiB,GACzC,QAAM,cAAc,IAAI,mBAAmB,CAC/D;AAAA,MACA,OAAmB;AACH,6BACI,CAAC,IAAI,GACL,QAAM,cAAc,IAAI,iBAAiB,GACzC,QAAM,cAAc,IAAI,mBAAmB,CAC/D;AAAA,MACa;AAAA,IACJ;AACD,WAAO,yBAAyB;AAEhCA,iBAAW,IAAI,MAAM,MAAM;AAC3B,UAAM,cAAc,qBAAqB,OAAO,KAAK;AACrD,aAAS,MAAM,GAAG,MAAM,KAAK,SAAS,QAAQ,OAAO;AACjD,YAAM,cAAc,KAAK,SAAS;AAClC,qBAAe,aAAa,YAAY;AACxC,UAAI,QAAQ,aAAa;AACrB,YAAI,CAAC,eAAe;AAChB,sCAA4B,WAAW,aAAa,qBAAqB,GAAG,qBAAqB,GAAG,MAChG,OAAO,wBAAwB,WAAW,eAAe,GAAG,CACpF;AAAA,QACiB;AACD,yBAAiB,WAAW;AAC5B;AAAA,MACH;AACD,kBAAY,oBAAoB,aAAa,sBAAsB,IAAI,WAAW,CAAC;AACnF,kBAAY,oBAAoB,cAAc,sBAAsB,IAAI,WAAW,CAAC;AACpF,UAAI,CAAC,cAAc;AACf,oBAAY,iBAAiB,aAAa,eAAe;AACzD,oBAAY,iBAAiB,cAAc,eAAe;AAC1D,8BAAsB,IAAI,aAAa,eAAe;AAAA,MACzD;AAED,cAAQ,IAAI,aAAa,GAAG;AAE5B,UAAI,CAAC,aAAa;AACd,sBAAc;AAAA,MACjB;AAAA,IACJ;AAAA,EACJ;AA/FQ;AAgGT,YAAU,OAAO;AAEjB,SAAO;AAAA,IACH,QAAQ,gBAAc;AAElB,gBAAU,UAAU;AAAA,IACvB;AAAA,IACD,SAAS,MAAM;AACX,2BAAqB;AAEjBE,6BAAmB,MAAMF,aAAW,IAAI,IAAI,EAAE,IAAI;AAClDA,qBAAW,OAAO,IAAI;AAAA,MACzB;AAJQ;AAKT,UAAI,yBAAyB;AAEzB,sCAA8B,MAAM,SAAS;AAAA,MAC7D,OAAmB;AACJ;MACF;AAAA,IACJ;AAAA,EACT;AACA;AAlPgBI;AC5ThB,MAAMC,oBAAkB;AAAA,EACpB,iBAAiB;AAAA,EACjB,wBAAwB;AAC5B;AACA,MAAM,oBAAoB;AAAA,EACtB,CAACA,kBAAgB,kBAAkB;AAAA,EACnC,CAACA,kBAAgB,yBAAyB;AAC9C;AAEA,MAAM,eAAe;AACrB,IAAI;AAEJ,6BAA6B;AACzB,MAAI,WAAW;AAEX;AAAA,EACH;AAED,cAAY,SAAS,cAAc,KAAK;AACxC,EAAC,iDAAyB;AACtB,cAAU,KAAK;AAGf,cAAU,MAAM,WAAW;AAC3B,cAAU,MAAM,SAAS;AACzB,cAAU,MAAM,OAAO;AACvB,cAAU,MAAM,SAAS;AACzB,cAAU,MAAM,UAAU;AAC1B,cAAU,MAAM,SAAS;AACzB,cAAU,MAAM,QAAQ;AACxB,cAAU,aAAa,QAAQ,OAAO;AAAA,EAC9C,GAZK;AAaD,WAAS,KAAK,QAAQ,SAAS;AAG/B,SAAO,QAAQ,iBAAiB,EAAE,QAAQ,CAAC,CAAC,IAAI,SAAS,SAAS,KAAK,QAAQ,uBAAuB,IAAI,GAAG,CAAC,CAAC;AACnH;AAxBS;AA8BF,oBAAoB;AACvB,MAAI;AAAY,WAAO;AACvB,MAAI,SAAS,eAAe,YAAY;AACpC;EACR,OAAW;AACH,WAAO,iBAAiB,oBAAoB,iBAAiB;AAAA,EAChE;AACD,SAAO,EAAC,GAAGA,kBAAe;AAC9B;AARgB;AAaT,uBAAuB;AAC1B,MAAI,cAAc,CAAC;AAAW;AAC9B,SAAO,KAAK,iBAAiB,EAAE,QAAQ,QAAM,SAAS,eAAe,EAAE,GAAG,OAAQ,CAAA;AAClF,YAAU,OAAM;AAChB,cAAY;AAChB;AALgB;AAOhB,gCAAgC,IAAI,KAAK;AACrC,QAAM,MAAM,SAAS,cAAc,KAAK;AACxC,MAAI,KAAK;AACT,MAAI,YAAY,MAAM;AACtB,MAAI,MAAM,UAAU;AACpB,MAAI,MAAM,WAAW;AACrB,MAAI,MAAM,SAAS;AACnB,SAAO;AACX;AARS;AAcF,6BAA6B,KAAK;AACrC,MAAI;AAAY;AAChB,MAAI,CAAC,WAAW;AACZ;EACH;AACD,YAAU,YAAY;AACtB,QAAM,YAAY,SAAS,eAAe,GAAG;AAC7C,YAAU,YAAY,SAAS;AAE/B,YAAU,MAAM,UAAU;AAC1B,YAAU,MAAM,UAAU;AAC9B;AAXgB;ACvEhB,MAAM,yBAAyB;AAC/B,MAAM,4BAA4B;AAAA,EAC9B,SAAS;AACb;AAEA,IAAI,aAAa;AACjB,IAAI;AACJ,IAAI;AACJ,IAAI,iBAAiB;AACrB,IAAI;AACJ,IAAI;AACJ,IAAI,mBAAmB;AACvB,MAAM,iBAAiB,oBAAI;AAC3B,MAAM,uBAAuB,oBAAI;AACjC,MAAM,qBAAqB,oBAAI;AAC/B,MAAM,cAAc,oBAAI;AACxB,MAAM,aAAa,oBAAI;AACvB,MAAM,kBAAkB,oBAAI;AAO5B,IAAI;AAGJ,0BAA0B,YAAY,MAAM;AAExC,MAAI,gBAAgB,SAAS,GAAG;AAE5B,sBAAkB,SAAQ;AAC1B,WAAO,iBAAiB,WAAW,oBAAoB;AACvD,WAAO,iBAAiB,SAAS,kBAAkB;AAAA,EACtD;AACD,MAAI,CAAC,gBAAgB,IAAI,IAAI,GAAG;AAC5B,oBAAgB,IAAI,MAAM,oBAAI,IAAK,CAAA;AAAA,EACtC;AACD,MAAI,CAAC,gBAAgB,IAAI,IAAI,EAAE,IAAI,UAAU,GAAG;AAC5C,oBAAgB,IAAI,IAAI,EAAE,IAAI,UAAU;AACxC;EACH;AACL;AAfS;AAgBT,4BAA4B,YAAY,MAAM;AAE1C,MAAI,cAAc,YAAY;AAC1B;EACH;AACD,kBAAgB,IAAI,IAAI,EAAE,OAAO,UAAU;AAC3C;AACA,MAAI,gBAAgB,IAAI,IAAI,EAAE,SAAS,GAAG;AACtC,oBAAgB,OAAO,IAAI;AAAA,EAC9B;AACD,MAAI,gBAAgB,SAAS,GAAG;AAE5B,WAAO,oBAAoB,WAAW,oBAAoB;AAC1D,WAAO,oBAAoB,SAAS,kBAAkB;AACtD,sBAAkB;AAClB;EACH;AACL;AAjBS;AAmBT,8BAA8B,GAAG;AAC7B,MAAI,CAAC;AAAY;AACjB,UAAQ,EAAE;AAAA,SACD,UAAU;AACX;AACA;AAAA,IACH;AAAA;AAET;AARS;AAUT,8BAA8B;AAC1B,MAAI,CAAC;AAAY;AACjB,MAAI,CAAC,eAAe,IAAI,SAAS,aAAa,GAAG;AAE7C;EACH;AACL;AANS;AAQT,yBAAyB,GAAG;AAExB,MAAI,CAAC;AAAY;AACjB,QAAM,iBAAiB,EAAE;AACzB,MAAI,mBAAmB;AAAW;AAElC,mBAAiB,eAAe,aAAa,YAAY,KAAK;AAC9D,QAAM,EAAC,OAAO,gBAAe,WAAW,IAAI,SAAS;AACrD,QAAM,aAAa,YAAY,KAAK,UAAQ,KAAK,iBAAiB,aAAa;AAC/E,QAAM,YAAY,YAAY,QAAQ,UAAU;AAChD,QAAM,aAAa,YAAY,OAAO,WAAW,CAAC,EAAE;AACpD,QAAM,EAAC,OAAO,aAAa,qBAAoB,WAAW,IAAI,cAAc;AAC5E,MACI,eAAe,sBAAqB,EAAG,MAAM,UAAU,sBAAuB,EAAC,OAC/E,eAAe,sBAAqB,EAAG,OAAO,UAAU,sBAAuB,EAAC,MAClF;AACE,gBAAY,KAAK,UAAU;AAC3B,QAAI,CAAC,kBAAkB;AACnB,0BAAoB,cAAc,2CAA2C,gBAAgB;AAAA,IAChG;AAAA,EACT,OAAW;AACH,gBAAY,QAAQ,UAAU;AAC9B,QAAI,CAAC,kBAAkB;AACnB,0BAAoB,cAAc,iDAAiD,gBAAgB;AAAA,IACtG;AAAA,EACJ;AACD,QAAM,SAAS;AACf,wBAAsB,QAAQ,aAAa,EAAC,SAAS,SAAS,sBAAsB,IAAI,eAAe,QAAQ,QAAQ,SAAQ,CAAC;AAChI,wBAAsB,gBAAgB,aAAa,EAAC,SAAS,SAAS,mBAAmB,IAAI,eAAe,QAAQ,QAAQ,SAAQ,CAAC;AACrI,cAAY;AAChB;AA9BS;AAgCT,+BAA+B;AAC3B,cAAY,QAAQ,CAAC,EAAC,mBAAS,OAAO,QAAO,WAAW,IAAI,EAAE,CAAC,CAAC;AACpE;AAFS;AAIT,oBAAoB,mBAAmB,MAAM;AAEzC,MAAI,CAAC,WAAW,IAAI,SAAS,EAAE,kBAAkB;AAC7C,wBAAoB,yBAAyB,kBAAkB;AAAA,EAClE;AACD,MAAI,eAAe,IAAI,SAAS,aAAa,GAAG;AAC5C,aAAS,cAAc;EAC1B;AACD,MAAI,kBAAkB;AAClB,0BAAsB,WAAW,WAAW,IAAI,SAAS,EAAE,OAAO;AAAA,MAC9D,SAAS,SAAS;AAAA,MAClB,IAAI;AAAA,MACJ,QAAQ,QAAQ;AAAA,IAC5B,CAAS;AAAA,EACJ;AACD,yBACI,gBAAgB,IAAI,eAAe,GACnC,QAAM,WAAW,IAAI,EAAE,EAAE,iBACzB,QAAM,WAAW,IAAI,EAAE,EAAE,iBACjC;AACI,gBAAc;AACd,kBAAgB;AAChB,qBAAmB;AACnB,oBAAkB;AAClB,cAAY;AACZ,mBAAiB;AACjB,eAAa;AACb;AACJ;AA5BS;AA8BF,mBAAiB,MAAM,SAAS;AACnC,QAAM,SAAS;AAAA,IACX,OAAO;AAAA,IACP,MAAM;AAAA,IACN,cAAc;AAAA,IACd,cAAc;AAAA,IACd,wBAAwB;AAAA,IACxB,iBAAiB;AAAA,IACjB,mBAAmB,CAAE;AAAA,IACrB,kBAAkB;AAAA,EAC1B;AAEI,gBAAc,KAAK,GAAG,GAAG;AACrB,QAAI,IAAI,UAAU;AAAG;AACrB,QAAI,OAAO,GAAG,GAAG,IAAI,OAAO,GAAG,GAAG,IAAI,EAAE,EAAE,EAAE;AAAA,EAC/C;AAHQ;AAKT,yBAAuB,GAAG;AAEtB,YAAQ,EAAE;AAAA,WACD;AAAA,WACA,KAAK;AAEN,YAAK,GAAE,OAAO,aAAa,UAAa,EAAE,OAAO,QAAQ,EAAE,OAAO,sBAAsB,CAAC,eAAe,IAAI,EAAE,MAAM,GAAG;AACnH;AAAA,QACH;AACD,UAAE,eAAc;AAChB,UAAE,gBAAe;AACjB,YAAI,YAAY;AAEZ;QACpB,OAAuB;AAEH,0BAAgB,CAAC;AAAA,QACpB;AACD;AAAA,MACH;AAAA,WACI;AAAA,WACA,cAAc;AACf,YAAI,CAAC;AAAY;AACjB,UAAE,eAAc;AAChB,UAAE,gBAAe;AACjB,cAAM,EAAC,UAAS,WAAW,IAAI,IAAI;AACnC,cAAM,YAAW,MAAM,KAAK,KAAK,QAAQ;AACzC,cAAM,MAAM,UAAS,QAAQ,EAAE,aAAa;AAE5C,YAAI,MAAM,UAAS,SAAS,GAAG;AAC3B,cAAI,CAAC,OAAO,kBAAkB;AAC1B,gCAAoB,cAAc,gCAAgC,MAAM,iBAAiB,gBAAgB;AAAA,UAC5G;AACD,eAAK,OAAO,KAAK,MAAM,CAAC;AACxB,gCAAsB,MAAM,OAAO,EAAC,SAAS,SAAS,mBAAmB,IAAI,eAAe,QAAQ,QAAQ,SAAQ,CAAC;AAAA,QACxH;AACD;AAAA,MACH;AAAA,WACI;AAAA,WACA,aAAa;AACd,YAAI,CAAC;AAAY;AACjB,UAAE,eAAc;AAChB,UAAE,gBAAe;AACjB,cAAM,EAAC,UAAS,WAAW,IAAI,IAAI;AACnC,cAAM,YAAW,MAAM,KAAK,KAAK,QAAQ;AACzC,cAAM,MAAM,UAAS,QAAQ,EAAE,aAAa;AAE5C,YAAI,MAAM,GAAG;AACT,cAAI,CAAC,OAAO,kBAAkB;AAC1B,gCAAoB,cAAc,gCAAgC,mBAAmB,gBAAgB;AAAA,UACxG;AACD,eAAK,OAAO,KAAK,MAAM,CAAC;AACxB,gCAAsB,MAAM,OAAO,EAAC,SAAS,SAAS,mBAAmB,IAAI,eAAe,QAAQ,QAAQ,SAAQ,CAAC;AAAA,QACxH;AACD;AAAA,MACH;AAAA;AAAA,EAER;AAzDQ;AA0DT,2BAAyB,GAAG;AAExB,0BAAsB,EAAE,aAAa;AACrC,gBAAY;AACZ,sBAAkB,OAAO;AACzB,iBAAa;AACb,UAAM,cAAc,MAAM,KAAK,gBAAgB,IAAI,OAAO,IAAI,CAAC,EAAE,OAAO,QAAM,OAAO,aAAa,CAAC,WAAW,IAAI,EAAE,EAAE,sBAAsB;AAC5I,yBACI,aACA,QAAM,WAAW,IAAI,EAAE,EAAE,iBACzB,QAAM,WAAW,IAAI,EAAE,EAAE,iBACrC;AACQ,QAAI,CAAC,OAAO,kBAAkB;AAC1B,UAAI,MAAM,yBAAyB,mEAAmE;AACtG,UAAI,YAAY,SAAS,GAAG;AACxB,eAAO;AAAA,MACV;AACD,0BAAoB,GAAG;AAAA,IAC1B;AACD,0BAAsB,MAAM,WAAW,IAAI,IAAI,EAAE,OAAO,EAAC,SAAS,SAAS,cAAc,IAAI,eAAe,QAAQ,QAAQ,SAAQ,CAAC;AACrI;EACH;AArBQ;AAuBT,uBAAqB,GAAG;AACpB,QAAI,CAAC;AAAY;AACjB,QAAI,EAAE,kBAAkB;AAAa;AACrC,MAAE,gBAAe;AACjB,eAAW,KAAK;AAChB,oBAAgB,CAAC;AAAA,EACpB;AANQ;AAOT,iCAA+B,aAAa;AACxC,UAAM,EAAC,UAAS,WAAW,IAAI,IAAI;AACnC,UAAM,YAAW,MAAM,KAAK,KAAK,QAAQ;AACzC,UAAM,iBAAiB,UAAS,QAAQ,WAAW;AACnD,kBAAc;AACd,gBAAY,WAAW;AACvB,oBAAgB,MAAM,gBAAgB;AACtC,uBAAmB,UAAS,gBAAgB,aAAa,YAAY,KAAK;AAAA,EAC7E;AARQ;AAUT,qBAAmB;AAAA,IACf,QAAQ,CAAE;AAAA,IACV,MAAM,UAAU;AAAA,IAChB,eAAe;AAAA,IACf,eAAe;AAAA,IACf,yBAAyB;AAAA,IACzB,kBAAkB;AAAA,IAClB,oBAAoB,CAAE;AAAA,IACtB,mBAAmB;AAAA,KACpB;AACC,WAAO,QAAQ,CAAC,GAAG,KAAK;AACxB,WAAO,eAAe;AACtB,WAAO,yBAAyB;AAChC,WAAO,eAAe;AACtB,WAAO,kBAAkB;AACzB,WAAO,oBAAoB;AAC3B,WAAO,mBAAmB;AAC1B,QAAI,OAAO,QAAQ,YAAY,OAAO,MAAM;AACxC,yBAAmB,MAAM,OAAO,IAAI;AAAA,IACvC;AACD,WAAO,OAAO;AACd,qBAAiB,MAAM,OAAO;AAC9B,QAAI,CAAC,kBAAkB;AACnB,WAAK,aAAa,iBAAiB,YAAY;AAC/C,WAAK,aAAa,QAAQ,MAAM;AAChC,WAAK,aAAa,oBAAoB,eAAe,gBAAgB,yBAAyB,gBAAgB,eAAe;AAAA,IAChI;AACD,eAAW,IAAI,MAAM,MAAM;AAE3B,QAAI,YAAY;AACZ,WAAK,WACD,SAAS,aACT,YAAY,SAAS,IAAI,KACzB,OAAO,0BACN,aAAa,OAAO,SAAS,WAAW,IAAI,SAAS,EAAE,OAClD,KACA;AAAA,IACtB,OAAe;AACH,WAAK,WAAW,OAAO;AAAA,IAC1B;AAED,SAAK,iBAAiB,SAAS,eAAe;AAE9C,aAAS,IAAI,GAAG,IAAI,KAAK,SAAS,QAAQ,KAAK;AAC3C,YAAM,cAAc,KAAK,SAAS;AAClC,qBAAe,IAAI,WAAW;AAC9B,kBAAY,WAAW,aAAa,KAAK;AACzC,UAAI,CAAC,kBAAkB;AACnB,oBAAY,aAAa,QAAQ,UAAU;AAAA,MAC9C;AACD,kBAAY,oBAAoB,WAAW,qBAAqB,IAAI,WAAW,CAAC;AAChF,kBAAY,oBAAoB,SAAS,mBAAmB,IAAI,WAAW,CAAC;AAC5E,UAAI,CAAC,cAAc;AACf,oBAAY,iBAAiB,WAAW,aAAa;AACrD,6BAAqB,IAAI,aAAa,aAAa;AACnD,oBAAY,iBAAiB,SAAS,WAAW;AACjD,2BAAmB,IAAI,aAAa,WAAW;AAAA,MAClD;AACD,UAAI,cAAc,OAAO,MAAM,GAAG,iBAAiB,eAAe;AAG9D,sBAAc;AACd,oBAAY,WAAW;AAEvB,oBAAY,MAAK;AAAA,MACpB;AAAA,IACJ;AAAA,EACJ;AAnEQ;AAoET,YAAU,OAAO;AAEjB,QAAM,UAAU;AAAA,IACZ,QAAQ,gBAAc;AAElB,gBAAU,UAAU;AAAA,IACvB;AAAA,IACD,SAAS,MAAM;AAEX,yBAAmB,MAAM,OAAO,IAAI;AACpC,iBAAW,OAAO,IAAI;AACtB,kBAAY,OAAO,IAAI;AAAA,IAC1B;AAAA,EACT;AACI,cAAY,IAAI,MAAM,OAAO;AAC7B,SAAO;AACX;AAvMgBD;AC/HT,iBAAiB,MAAM,SAAS;AACnC,kBAAgB,OAAO;AACvB,QAAM,cAAcE,UAAe,MAAM,OAAO;AAChD,QAAM,eAAeC,UAAgB,MAAM,OAAO;AAClD,SAAO;AAAA,IACH,QAAQ,gBAAc;AAClB,sBAAgB,UAAU;AAC1B,kBAAY,OAAO,UAAU;AAC7B,mBAAa,OAAO,UAAU;AAAA,IACjC;AAAA,IACD,SAAS,MAAM;AACX,kBAAY,QAAO;AACnB,mBAAa,QAAO;AAAA,IACvB;AAAA,EACT;AACA;AAfgB;AAiBhB,yBAAyB,SAAS;AAE9B,QAAM;AAAA,IACF;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,OACG;AAAA,MACH;AAEJ,MAAI,OAAO,KAAK,IAAI,EAAE,SAAS,GAAG;AAC9B,YAAQ,KAAK,uCAAuC,IAAI;AAAA,EAC3D;AACD,MAAI,CAAC,OAAO;AACR,UAAM,IAAI,MAAM,oCAAoC;AAAA,EACvD;AACD,QAAM,oBAAoB,MAAM,KAAK,UAAQ,CAAC,GAAG,eAAe,KAAK,MAAM,WAAW,CAAC;AACvF,MAAI,mBAAmB;AACnB,UAAM,IAAI,MAAM,YAAY,kCAAkC,SAAS,iBAAiB,GAAG;AAAA,EAC9F;AACD,MAAI,qBAAqB,CAAC,MAAM,QAAQ,iBAAiB,GAAG;AACxD,UAAM,IAAI,MAAM,4DAA4D,OAAO,sBAAsB,SAAS,iBAAiB,GAAG;AAAA,EACzI;AACD,MAAI,gBAAgB,CAAC,MAAM,YAAY,GAAG;AACtC,UAAM,IAAI,MAAM,uDAAuD,OAAO,iBAAiB,SAAS,YAAY,GAAG;AAAA,EAC1H;AACL;AAlCS;AAoCT,eAAe,OAAO;AAClB,SAAO,CAAC,MAAM,KAAK,KAAM,SAAS,GAAG;AAAE,WAAQ,KAAI,OAAO;AAAA,EAAE,EAAI,WAAW,KAAK,CAAC;AACrF;AAFS;;;;;;;;;;;;;;;;;;;AC6ED,aAAyC,QAAA,KAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;AAuBnC,aAEQ,QAAA,QAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAJR,aAAuF,QAAA,OAAA,MAAA;6BAAxD,IAAK,IAAC,KAAK,IAAI;;;;;;;;uCAAf,IAAK,IAAC,KAAK,MAAI;+BAAf,IAAK,IAAC,KAAK,IAAI;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAJP;AAAA,eAAiB;AAAA;AAAmB,MAAA,QAAM,QAAG,QAAA;AAAT,qBAAA,QAAA,QAAM;AAAA;;;;QAG9E,KAAK,IAAC,SAAS;AAAW,aAAAvD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mDAflB,IAAY,KAAE,IAAC,EAAK;;6CAEvB,IAAY,KAAG,iBAAiB,kBAAkB;;;;;;;;;;AAJhE,aA4BK,QAAA,MAAA,MAAA;AA1BH,aAMiC,MAAA,IAAA;AAAhC,aAA2B,MAAA,EAAA;;AAC5B,aAAsD,MAAA,IAAA;AAAjD,aAA4C,MAAA,MAAA;AAAb,sBAAA,QAAA,QAAM,IAAI;;AAC9C,aAA4D,MAAA,IAAA;AAAvD,aAAkD,MAAA,MAAA;AAAjB,sBAAA,QAAA,QAAM,QAAQ;;AACpD,aAA6D,MAAA,IAAA;AAAxD,aAAmD,MAAA,MAAA;AAAd,aAAA,UAAA,QAAM;;AAChD,aAA8D,MAAA,IAAA;AAAzD,aAAoD,MAAA,MAAA;AAArB,sBAAA,QAAA,QAAM,YAAY;;AACtD,aAEK,MAAA,IAAA;;;AACL,aAQK,MAAA,IAAA;;;AACL,aAEK,MAAA,IAAA;AADH,aAA8F,MAAA,MAAA;;;;oCArB7E,IAAS,GAAA;AAAA,qCACR,IAAS,GAAA;AAAA,kCACZ,IAAa,GAAA;AAAA;;;;;;;;;;;kFALf,IAAY,KAAE,IAAC,KAAK;;;4EAEvB,IAAY,KAAG,iBAAiB,qBAAkB;;;AAK1B,UAAA,QAAA,KAAA,OAAA,UAAA,QAAM,MAAI;AAAV,wBAAA,QAAA,QAAM,IAAI;AAAA;AACR,UAAA,QAAA,KAAA,UAAA,OAAA,KAAA,MAAA,QAAM,UAAQ;AAAd,wBAAA,QAAA,QAAM,QAAQ;AAAA;;AACV,eAAA,UAAA,QAAM;AAAA;AACZ,UAAA,QAAA,KAAA,OAAA,UAAA,QAAM,cAAY;AAAlB,wBAAA,QAAA,QAAM,YAAY;AAAA;;;;AAEyB,2BAAA,QAAA,QAAM;;;;;;;;;;;;;;;;;;;;;;;;AAbjE,uBAAA,iBAAA,MAAA,MAAA,MAAA,EAAA,UAAU,eAAc,CAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAL3C,IAAU,MAAAD,oBAAA;mBAGR,IAAM;AAAkB,QAAA,UAAA,iCAAA,SAAM,IAAN;iCAA7B,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkCC,SAAA,cAAA,GAAA,SAAS,kDAAkD;;;;oCADV,IAAU,EAAA;;;;;;AApDtE,aA0DK,QAAA,OAAA,MAAA;AAzDH,aASK,OAAA,IAAA;AARH,aAAU,MAAA,IAAA;;AACV,aAAc,MAAA,IAAA;;AACd,aAAc,MAAA,IAAA;;AACd,aAAe,MAAA,IAAA;;AACf,aAAe,MAAA,IAAA;;AACf,aAAc,MAAA,IAAA;;AACd,aAAc,MAAA,IAAA;;AACd,aAAwG,MAAA,IAAA;AAAnG,aAA8F,MAAA,EAAA;;AAErG,aA8CS,OAAA,OAAA;;;;;;;;AAPP,aAMK,SAAA,KAAA;AALH,aAIK,OAAA,IAAA;AAHH,aAEG,MAAA,EAAA;;;;;;;YA1CW,OAAO,IAAM;AAAA,YAAE,cAAA,IAAY;AAAA,YAAE;AAAA;sCAC/B,IAAc,EAAA;AAAA,sCACd,IAAc,EAAA;AAAA;;;;;UAEzB,KAAU,IAAA;;;;;;;;;;;;;qBAGR,KAAM;;;;;;;;;;sCAiC2C,KAAU,EAAA;AAAA;;;UAxChD,OAAO,KAAM;AAAA,UAAE,cAAA,KAAY;AAAA,UAAE;AAAA;;;;;qCAO7C,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cApBQ,IAAQ;AAAA;;;MAAmB,IAAU,OAAA,QAAA;gCAAV,IAAU;AAAA;;;;;;;;;;;;;;;;;;sCAAV,KAAU;;;;;;;;;;;;;;;;;;;;;AA5HjD,IAAA,iBAAiB;;QAJV,WAAM;QACN,WAAM;AAEb,MAAA,aAAa;AAEb,MAAA,eAAe;AAEV,uBAAY,OAAK;AACtB,WAAO,OAAO,OAAO,CAAC;;;AADjB;0BAKY;oBACjB,SAAM;AAAA,SAAO;AAAA;QACT,IAAI,SAAQ;AAAA,QACZ,MAAM;AAAA,QACN,MAAM;AAAA,QACN,KAAK;AAAA,QACL,cAAc;AAAA,QACd,MAAI,EACA,MAAM,GAAC;AAAA,QAEX,UAAU;AAAA,QACV,OAAO;AAAA;;;AAXN;AAeM,0BAAS,MAAI;AAEnB,QAAA,CAAA,KAAK,MAAI;YACJS,aAAqB,+CAA+C;AAAA;QAG1E,KAAK,SAAS,QAAM;YACdA,aAAqB,gCAAgC,KAAK,KAAK,YAAW,IAAK,GAAG;AAAA;AAGxF,QAAA,OAAO;AACP,QAAA,KAAK,MAAI;AACT,aAAO,eAAe,KAAK,OAAO,MAAM,KAAK;AAAA;AAG7C,QAAA,aAAa,KAAK,eAAe,aAAa,IAAI;QAClD,WAAW,KAAK;SAEf,UAAQ;AACT,cAAQ,MAAM,IAAI;YACZA,aAAqB,+CAA+C;AAAA;UAGxE,iBAAiB,OAAO,IAAI,WAAS,MAAM,MAAM,QAAI,CAAA,CAAA;AACrD,UAAA,YAAY9B,gBAA0B,gBAAgB,QAAQ;QAEhE,WAAS;AACH,YAAA,QAAQ,eAAe,QAAQ,SAAS;sBAC9C,OAAO,OAAO,SACV,MACA,MAAM,SAAA,GAAA,MAAA;AAEV+B,oBAA+C,yBAAA,SAAS,OAAO,OAAO,IAAI,gBAAgB,SAAS,OAAI;AAAA;sBAEvG,SAAM;AAAA,WAAO;AAAA;UACT,IAAI,SAAQ;AAAA,UACZ,MAAM;AAAA,UACN,MAAM,SAAS;AAAA,UACf,KAAK,SAAS;AAAA,UACd,cAAc,SAAS,SAAS;AAAA,UAChC,MACI,EAAA,MACA,MAAM,SAAA;AAAA,UAEV,UAAU;AAAA,UACV,OAAO;AAAA;;;;AA7CJ;AAkDA,0BAAS,OAAK;AACnB,UAAA,OAAO,OAAO,OAAO;QACvB;AACA,QAAA,KAAK,MAAI;AACT,aAAa,MAAA,SAAS,KAAK,IAAI;AAAA;UAE3B,WAAW,KAAK;AAChB,UAAA,SAAS;AAAY,eAAA,SAAS;AAC9B,UAAA,SAAS;AAAmB,eAAA,SAAS;AACnC,YAAA,QAAQ,MAAM,KAAK,KAAK,KAAK;AACnC,aAAO/B,gBAA0B,OAAO,QAAQ;WAC3C,MAAI;AACL,oBAAY,UAAU,UAAU,MAAM,gBAAgB,IAAI;AAC1D,qBAAa,KAAK,eAAe,OAAO,QAAQ;AAChD+B,sBAAsD,gCAAA,KAAK,sEAAI;AAAA;;AAGvE,SAAK,MAAM,OAAO,IAAI;AAAA;AAjBX;AAoBN,0BAAe,GAAC;YACb,OAAO,UAAU,MAAI,EAAI,QAAQ,cAAc,EAAE;AACzD,iBAAA,GAAA,SAAS,QAAQ;QAEb,WAAW,QAAQ,YAAY,YAAY,SAAS,cAAY;AAChE,mBAAA,GAAA,eAAe,IAAI;AAAA;;AALlB;AASA,0BAAe,GAAC;YACb,OAAO,UAAU,QAAQ,aAAa,EAAE;AAChD,iBAAA,GAAA,SAAS,QAAQ;QAEb,WAAW,QAAQ,SAAO;AAC1B,mBAAA,GAAA,eAAe,IAAI;AAAA;;AALlB;AASA,qBAAU,GAAC;AAEhB,MAAE,eAAc;AAChB,iBAAA,GAAA,eAAe,KAAK;AAAA;AAHf;AAMA,yBAAc,GAAC;AACf,QAAA,GAAE,QAAQ,WAAW,EAAE,QAAQ,QAAQ;AAAc,mBAAA,GAAA,eAAe,KAAK;AAAA;AADzE;qDAiBkD;;sBAoBX,OAAI,KAAA;;;;;sBACF,WAAQ,UAAA,KAAA,KAAA;;;;;sBACJ,QAAK,KAAA;;;;;sBACX,eAAY,KAAA;;;;;AAEyB,QAAA,OAAA,GAAA,UAAA,MAAM,KAAG,KAAA,GAAA;AAAT,YAAM,MAAG;;;;;;AAI/C,eAAA,OAAA,KAAK,OAAI,KAAA;;;;AAER,QAAA,kBAAA,kCAAA,SAAS,KAAK,GAAd;AAMF,QAAA,mBAAA,kCAAA,YAAY,KAAK,GAAjB;uDAMrB;;AArDkB,iBAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC3E1C,MAAA,WAAA,SAAS,2CAA2C,IAAA;;;;;;;;;;AAQpD,MAAA,WAAA,SAAS,+CAA+C,IAAA;;;;;;;;;;AAQxD,MAAA,YAAA,SAAS,qDAAqD,IAAA;;;;;;;;;;AAQ9D,MAAA,YAAA,SAAS,oDAAoD,IAAA;;;;;;;;;;;;;;;;;;;;;AAvB1D,SAAA,cAAA,GAAA,SAAS,sDAAsD;;;;;;;;;;AAQ/D,SAAA,cAAA,GAAA,SAAS,0DAA0D;;;;;;;;;;AAQnE,SAAA,cAAA,GAAA,SAAS,gEAAgE;;;;;;;;;;AAQzE,SAAA,cAAA,GAAA,SAAS,+DAA+D;;;;AAIzE,cAAA,cAAA,GAAA,SAAS,2DAA2D;AAAA;;AAGpE,cAAA,cAAA,GAAA,SAAS,uDAAuD;AAAA;;AAGhE,cAAA,cAAA,GAAA,SAAS,sDAAsD;;;;;;;;;;;;;;;;;AARxB,UAAA,OAAa,oBAAe;AAAA,4BAAA,MAAA,IAAA,IAAA,KAAA,MAAA,CAAA;;;;;AA/B5E,aA4CM,QAAA,MAAA,MAAA;AA1CJ,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;;AAFiD,aAAI,QAAA,GAAA;;AAC3D,aAAyE,QAAA,EAAA;;AAE3E,aAA2D,MAAA,MAAA;AAAtB,aAAA,UAAA,OAAa;;AAGpD,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;;AAFqD,aAAI,QAAA,GAAA;;AAC/D,aAA6E,QAAA,EAAA;;AAE/E,aAA+D,MAAA,MAAA;AAA1B,aAAA,UAAA,OAAa;;AAGpD,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;;AAF2D,aAAI,QAAA,GAAA;;AACrE,aAAmF,QAAA,EAAA;;AAErF,aAAqE,MAAA,MAAA;AAAhC,aAAA,UAAA,OAAa;;AAGpD,aAgBM,MAAA,IAAA;AAfJ,aAGQ,MAAA,MAAA;;AAF0D,aAAI,QAAA,GAAA;;AACpE,aAAkF,QAAA,EAAA;;AAEpF,aAUS,MAAA,MAAA;AATP,aAES,QAAA,OAAA;AACT,aAES,QAAA,OAAA;AACT,aAES,QAAA,OAAA;AATiC,oBAAA,QAAA,OAAa,eAAe;;;;;;;;;;;;;AAxBnC,eAAA,UAAA,QAAa;AAAA;;AAQb,eAAA,UAAA,QAAa;AAAA;;AAQb,eAAA,UAAA,QAAa;AAAA;;AAQN,sBAAA,QAAA,QAAa,eAAe;AAAA;;;;;;;;;;;;;;;AAuBrE,MAAA,WAAA,SAAS,8CAA8C,IAAA;;;;;;;;;;AAUvD,MAAA,WAAA,SAAS,yCAAyC,IAAA;;;;;;;;;;AAQlD,MAAA,YAAA,SAAS,sDAAsD,IAAA;;;;;;;;;;AAQ/D,MAAA,YAAA,SAAS,oDAAoD,IAAA;;;;;;;;;AAM7D,MAAA,YAAA,SAAS,sDAAsD,IAAA;;;;;;iBAI/D,IAAY,GAAC,OAAO,UAAMV,oBAAA,GAAA;;;;;;;;;;AAnCvB,SAAA,cAAA,GAAA,SAAS,yDAAyD;;;;;;;;;;AAUlE,SAAA,cAAA,GAAA,SAAS,oDAAoD;;;;;;;;;;AAQ7D,SAAA,cAAA,GAAA,SAAS,iEAAiE;;;;;;;;;;AAQ1E,SAAA,cAAA,GAAA,SAAS,+DAA+D;;;;;;;;;;;;;;;;;;;;;;;;;AA/BlF,aA8CM,QAAA,MAAA,MAAA;AA5CJ,aAQM,MAAA,IAAA;AAPJ,aAGQ,MAAA,MAAA;;AAFoD,aAAI,QAAA,GAAA;;AAC9D,aAA4E,QAAA,EAAA;;AAE9E,aAEI,MAAA,MAAA;8BAF2B,IAAM,EAAA;;AAKvC,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;;AAF+C,aAAI,QAAA,GAAA;;AACzD,aAAuE,QAAA,EAAA;;AAEzE,aAAyD,MAAA,MAAA;AAApB,aAAA,UAAA,OAAa;;AAGpD,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;;AAF4D,aAAI,QAAA,GAAA;;AACtE,aAAoF,QAAA,EAAA;;AAEtF,aAAsE,MAAA,MAAA;AAAjC,aAAA,UAAA,OAAa;;AAGpD,aAUM,MAAA,IAAA;AATJ,aAGQ,MAAA,MAAA;;AAF0D,aAAI,QAAA,GAAA;;AACpE,aAAkF,QAAA,EAAA;;AAGpF,aAGS,MAAA,MAAA;AAFP,aAA2B,QAAA,CAAA;;;;;;;;;;;;;;;;;;;4CA5BE,KAAM,IAAA;gCAAN,KAAM,EAAA;AAAA;;AAUA,eAAA,UAAA,QAAa;AAAA;;AAQb,eAAA,UAAA,QAAa;AAAA;UAe/C,KAAY,GAAC,OAAO,QAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACtB,MAAA,aAAA,OAAa;mDAA8B,KAAU;iCAA1D,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;AAAC,qBAAA,QAAa;;;;;;;;;qCAAlB,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MACoB,IAAM,QAAA,QAAA;6BAAN,IAAM;AAAA;;;;;;;;;;;;;;;;;;;;;;;mCAAN,IAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYP,MAAA,WAAA,SAAS,2CAA2C,IAAA;;;;;;AAGlD,MAAA,WAAA,SAAS,QAAQ,IAAA;;;;;;;;;;;;QAnHlD,OAAO;AAAA,QAAW,OAAO,SAAS,4CAA4C;AAAA;;QAC9E,OAAO;AAAA,QAAS,OAAO,SAAS,0CAA0C;AAAA;;;;;;;;AAKrE,MAAA,YAAA,WAAc,aAASQ,oBAAA,GAAA;AAkDvB,MAAA,YAAA,WAAc,WAAOP,kBAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA3D9B,aA0HO,QAAA,QAAA,MAAA;;;AAnHL,aAwGU,QAAA,OAAA;;;;;;;AAEV,aAOS,QAAA,MAAA;AANP,aAES,QAAA,OAAA;AADP,aAA2B,SAAA,EAAA;;;;AAE7B,aAES,QAAA,OAAA;AADP,aAA4B,SAAA,EAAA;;;;;;;mCAJO,IAAa,IAAA,EAAA,MAAA,MAAA;AAAA;mDAlHL,IAAc,GAAA,CAAA;AAAA;;;;;;;;;;;;AAStD,UAAA,YAAc,WAAS;;;;;;;;;;;;AAkDvB,UAAA,YAAc,SAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAlGtB,gBAAgB,WAAW,UAAU;QAElC,SAAI;QACJ,gBAAW;AAElB,MAAA,QAAQ,eAAe,KAAK,IAAI;QAE9B,gBAAgB,MAAM;;MACxB,QAAQ,MAAM;;MAId;kCAEyB;AACrB,UAAAwC,eAA6B,MAAM,MAAM,OAAM,CAAA;AACrD,gBAAY,QAAQ;AACpB,gBAAY,MAAK;AAAA;AAHJ;2BAMc;AAC3B,SAAK,cAAa;AAAA;AADJ;sBAIC;AACf,iBAAA,GAAA,aAAa,SACR,CAAA,GAAA,aAAa,QAAM,CAAA,CAAA,GAAA,YAAA;AAAA;AAFjB;AAOL,MAAA,YAAY;;;;;;;AA0B+B,iBAAa,SAAM,KAAA;;;;;AAQnB,iBAAa,aAAU,KAAA;;;;;AAQvB,iBAAa,mBAAgB,KAAA;;;;;AAQtB,iBAAa,kBAAe,aAAA,IAAA;;;;;AA0BzC,aAAM,KAAA;;;;;2BACnC,SAAS,KAAK,IAAI,GAAG,OAAO,MAAM,CAAA,EAAG,SAAQ,GAAA,MAAA;AAAA;;AASV,iBAAa,OAAI,KAAA;;;;;AAQjB,iBAAa,oBAAiB,KAAA;;;;;AAS3B;;;AAQU,UAAM,YAAY,UAAU;AAAA;;;;;;;AAcvC,gBAAY,MAAK;AAAA;;;AArHjD,aAAI;;;;;;;;;;;;;;;;;;AA7BpB,mBAAA,GAAE,eAAe,cAAc;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AChBnB,MAAM,mBAAmB,kBAAkB;AAAA,EAExD,YAAY,OAAO,OAAO,SAAS;AACjC,UAAM;AAAA,MACJ,IAAI,yBAAyB,KAAK;AAAA,MAClC,OAAO,KAAK,KAAK,OAAO,4CAA4C,EAAE,WAAW,KAAK,MAAM;AAAA,MAC5F,QAAQ;AAAA,QACN,OAAOgB;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,QACD;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,QAAQ,IAAI;AAAA,MACtC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,gBAAgB;AAAA,IAChC,CAAK;AAAA,EACF;AAAA,EAED,OAAO,aAAa,IAAI;AACtB,WAAO,OAAO,OAAO,GAAG,OAAO,EAAE,KAAK,SAAO,IAAI,OAAO,yBAAyB,IAAI;AAAA,EACtF;AAAA,EAED,aAAa,KAAK,OAAO,OAAO,UAAU,CAAE,GAAE,aAAa,IAAI;AAC7D,UAAM,MAAM,KAAK,aAAa,KAAK,EAAE;AACrC,QAAI;AAAK,aAAO,IAAI,OAAO,OAAO,EAAE,OAAO,KAAI,CAAE;AACjD,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,MAAM,SAAS,UAAU,EAAE,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,IACtE,CAAK;AAAA,EACF;AACH;AAtCqB;;;;;;eCiDZ,IAAS,GAAA;AAAA;;;;;;oBAAT,KAAS,GAAA;AAAA;;;;;;;;;;;;;;;;eAFoD,IAAS,GAAA;;;;AAAvE,aAA2E,QAAA,GAAA,MAAA;;;;AAAjC,cAAA,YAAA,IAAY,IAAA,IAAZ,EAAA,CAAA;AAAA,oBAAY,IAAI,EAAA,EAAA,MAAA,MAAA,SAAA;AAAA;;;;;;;oBAAI,IAAS,GAAA;AAAA;;;;;;;;;;;;;AAKlE,QAAA,QAAa;AAAgB,aAAAtB;SAEvB,KAAgB;AAAA,aAAAP;AAAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAE8C,IAAE;gBAAC,IAAQ,EAAA;gBAAC,GAAC;;sDADf,KAAK,KAAK,IAAI;AAAA;;AAAnF,aAC0F,QAAA,MAAA,MAAA;;;;;;;;;;;qBAAhB,KAAQ,EAAA;AAAA;;;;;;;;;;;;;;;;;;;AAHlF,aAA6C,QAAA,MAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAO/C,aAMK,QAAA,MAAA,MAAA;AALH,aAIK,MAAA,IAAA;AAHH,aAEmF,MAAA,KAAA;6BAFvB,IAAY,EAAA;;;;;;;;;;;;wCAAZ,KAAY,IAAA;+BAAZ,KAAY,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;iBAazE,KAAK,KAAK,QAAIZ,oBAAA,GAAA;;;;;;;;;;;;AAOa,mBAAA,IAAA,UAAA,CAAA,OAAa,MAAM;AAAsB,mBAAA,IAAA,gBAAA,OAAa,MAAM;;;AAI1D,mBAAA,IAAA,YAAA,CAAA,OAAa,UAAU;AAAwB,mBAAA,IAAA,kBAAA,OAAa,UAAU;;;;;;;AANxG,aAGM,QAAA,OAAA,MAAA;AADJ,aAA+F,OAAA,EAAA;;AAEjG,aAGM,QAAA,OAAA,MAAA;AADJ,aAA2G,OAAA,EAAA;;;;;;;;;;UAXxG,KAAK,KAAK;AAAI,iBAAA,EAAA,MAAA,KAAA;;AAOa,qBAAA,IAAA,UAAA,CAAA,QAAa,MAAM;AAAA;;AAAsB,qBAAA,IAAA,gBAAA,QAAa,MAAM;AAAA;;AAI1D,qBAAA,IAAA,YAAA,CAAA,QAAa,UAAU;AAAA;;AAAwB,qBAAA,IAAA,kBAAA,QAAa,UAAU;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAVtG,aAEM,QAAA,MAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;kBAoBA,IAAqB,OAAAhB,oBAAA,GAAA;;;;;;;;;2CADa,IAAO,EAAA;6CAA6B,IAAO,EAAA;;AAP7C,mBAAA,MAAA,6BAAA,CAAA,OAAa,cAAc,KAAK,KAAK,IAAI;+DACjC,IAAQ,MAAI,KAAM,IAAY,GAAC,cAAU,CAAK,KAAK,KAAK,IAAI;uCACpF,IAAqB,GAAA;AAAA;;AAF7C,aASM,QAAA,MAAA,MAAA;AAFJ,aAAwF,MAAA,CAAA;;;;;;;;;;;6CAAhD,KAAO,EAAA;AAAA;;+CAA6B,KAAO,EAAA;AAAA;WAC7E,KAAqB;AAAA,iBAAA,EAAA,MAAA,KAAA;;AARW,qBAAA,MAAA,6BAAA,CAAA,QAAa,cAAc,KAAK,KAAK,IAAI;AAAA;;iEACjC,KAAQ,MAAI,KAAM,KAAY,GAAC,cAAU,CAAK,KAAK,KAAK,IAAI;AAAA;;;;;;;;;;;;;;iBAO3E,IAAO,KAAG,QAAQ;;;;;;;;;;+CAAlB,KAAO,KAAG,QAAQ;AAAM,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;AApDpD,QAAA,QAAU,mBAAmB,KAAK,KAAK;AAAI,aAAA;;;;;;kBAK3C,IAAe,MAAA8B,oBAAA,GAAA;kBAQf,IAAgB,MAAAD,oBAAA,GAAA;;kBAelB,IAAqB,OAAArB,oBAAA,GAAA;kBAerB,IAAgB,OAAAP,kBAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;kDAhDa,IAAU,EAAA;AAAA,aAAA,KAAA,OAAA,aAAA;;yCADY,IAAY,GAAC,cAAU,CAAK,IAAQ,EAAA;;;;;;AAJ/D,mBAAA,MAAA,wBAAA,OAAa,MAAM;AAAA;;AADpD,aAoEK,QAAA,MAAA,MAAA;AA/DH,aAEK,MAAA,IAAA;AADH,aAA+C,MAAA,GAAA;;AAGjD,aAyBK,MAAA,IAAA;AAxBH,aAuBK,MAAA,IAAA;;;;;;;;;;;AAKP,aA4BK,MAAA,IAAA;;;;;;;;;6EA5D+B,KAAU,EAAA,GAAA;;;;2CADY,KAAY,GAAC,cAAU,CAAK,KAAQ,EAAA;AAAA;;;;;;;;;;;UAWrF,KAAe,IAAA;;;;;;;;;;;;UAQf,KAAgB,IAAA;;;;;;;;;;;;;;;;UAelB,KAAqB;AAAA,kBAAA,EAAA,MAAA,KAAA;UAerB,KAAgB;AAAA,kBAAA,EAAA,MAAA,KAAA;;AArDQ,qBAAA,MAAA,wBAAA,QAAa,MAAM;AAAA;;;;;;;;AACvB,cAAA,CAAA;AAAA,8BAAA,gCAAA,MAAA,MAAA,EAAA,UAAU,OAAG,IAAA;;;;;;;;;AAAb,YAAA,CAAA;AAAA,4BAAA,gCAAA,MAAA,MAAA,EAAA,UAAU,OAAG,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAnC7B,UAAK;QACL,SAAI;AACJ,MAAA,EAAA,UAAU,UAAK;QAEpB,WAAW,KAAK;;QAChB,YAAY,KAAK;;QAEjB,WAAW,MAAM;;QACjB,uBAAuB,KAAK;;QAC5B,gBAAgB,KAAK;;QACrB,oBAAoB,KAAK;;AAM3B,MAAA,mBAAmB;AAEjB,QAAA,wBAAwB,MAAM,MAAM,YAAY;QAChD,mBAAgB,CAAA,CAAK,MAAM;AAExB,uBAAY,OAAI;AACvB,YAAO,MAAM,MAAM,MAAM,IAAI,MAAK,EAAE;AAChC,QAAA,KAAK,KAAK,QAAQ,MAAK,KAAK,WAAW,KAAK,KAAK,QAAQ,GAAC;AACrD,aAAA,MAAK,MAAM,OAAO,IAAI;AAAA;UAEzB,MAAM,MAAK;AACX,UAAA,YAAY,IAAI,OAAQ,EAAA,UAAU,MAAK,CAAA;WACtC,MAAM,QAAQ,IAAI;AAAA;AAPlB;;AAiC0B,QAAA,KAAK,KAAK;AAAM,mBAAA,GAAA,mBAAmB,IAAI;AAAA;;AAMJ,mBAAY,KAAA;;;;;AAC9C,iBAAA,GAAA,mBAAmB,KAAK;AAAE,SAAK,eAAe,YAAY;AAAA;0BAChE,gCAAG;AAAU,QAAA,IAAI,QAAQ;AAAS,mBAAA,GAAA,mBAAmB,KAAK;AAAA,KAA1D;;AAYkC,eAAW,KAAK,KAAK,IAAI;AAAA;;AAK7D,iBAAA,GAAA,aAAa,SAAU,CAAA,aAAa,QAAM,YAAA;AAAE,SAAK,mBAAkB;AAAA;;AAInE,iBAAA,GAAA,aAAa,aAAc,CAAA,aAAa,YAAU,YAAA;AAAE,SAAK,mBAAkB;AAAA;;QASxF,YAAY,KAAM,aAAa,cAAU,CAAK,KAAK,KAAK;AAAI;AAC/D,UAAM,UAAU,MAAM,OAAO;AAAA;;;;;;;;;;;AAjFxC,mBAAA,GAAE,eAAe,kBAAkB;AAAA;;AACnC,mBAAA,GAAE,kBAAkB,qBAAqB;AAAA;;AACzC,mBAAA,GAAE,WAAW,cAAc;AAAA;;AAC3B,mBAAA,GAAE,eAAe,cAAc;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACOK,MAAA,UAAA,QAAS,QAAK;;;;;;;;;AAA9B,aAAA,UAAA,qBAAA,QAAS;;;;;AAAxB,aAAuD,QAAA,QAAA,MAAA;;;;;AAAxB,UAAA,QAAA,MAAA,YAAA,WAAA,QAAS,QAAK;AAAA,iBAAA,GAAA,OAAA;AAA9B,UAAA,QAAA,MAAA,uBAAA,sBAAA,QAAS,OAAI;;;;;;;;;;;;;;;iBAanB,IAAsB,GAAC,IAAQ,IAAC,SAAIe,oBAAA,GAAA;;;;;;;;;;;;;;UAApC,KAAsB,GAAC,KAAQ,IAAC,OAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGd,MAAA,IAAuB,GAAA,IAAS,IAAA,MAAM,qBAAgB,QAAA;AAAtD,sBAAA,QAAA,IAAuB,GAAA,IAAS,IAAA,MAAM;AAAA;;;;;gBAHtB,6BAEzC;;;;;;;;;AAAA,aAAqF,QAAA,OAAA,MAAA;AAAhD,YAAA,UAAA,IAAuB,GAAA,IAAS,IAAA,MAAM;;;;;;;;;;;;AAAtC,cAAA,UAAA,IAAuB,GAAA,IAAS,IAAA,MAAM;AAAA;;;;AAClD,4BAAA,QAAA,IAAuB,GAAA,IAAS,IAAA,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAM5D,KAAsB,GAAC,KAAQ,IAAC;AAAI,aAAAhB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIvC,aACsE,QAAA,GAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAJtE,aACyE,QAAA,GAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAf5E,SAAS,IAAQ,IAAC,KAAK,IAAA;;;;;;;;;;;;;kBAGnB,IAAU,MAAAQ,oBAAA,GAAA;kBASV,IAAU,MAAAP,kBAAA,GAAA;qBAaV,IAAsB,GAAC,IAAQ,IAAC;AAAe,QAAA,UAAA,iCAAA,SAAK,IAAL;mCAApD,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA5BV,aAgCM,QAAA,MAAA,MAAA;AA/BJ,aAwBK,MAAA,EAAA;AAvBH,aAEM,IAAA,IAAA;;;AACN,aAQM,IAAA,IAAA;;;;AACN,aAUM,IAAA,IAAA;;;;AAGR,aAIM,MAAA,IAAA;;;;;;;;;+DA5BD,SAAS,IAAQ,IAAC,KAAK,IAAA;AAAA,iBAAA,IAAA,QAAA;UAGnB,IAAU,IAAA;;;;;;;;;;;;;;;;;;;UASV,IAAU,IAAA;;;;;;;;;;;;;uBAaV,IAAsB,GAAC,IAAQ,IAAC;;;;;;;;;;uCAArC,QAAI,KAAA,GAAA;;;;;;AA5BW,yBAAA,qBAAA,MAAA,MAAA,EAAA,UAAU,IAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAPzB,IAAoB;AAAc,QAAA,UAAA,iCAAA,SAAS,MAAT;mCAAvC,QAAI,KAAA,GAAA;;;;;mBAMH,IAAc;AAAqB,QAAA,YAAA,iCAAA,SAAS,MAAT;iCAAxC,QAAI,KAAA,GAAA;;;;;;;;;;;;;AAPmB,aAAA,cAAA,GAAA,SAAS,KAAK;;;;;;;;;;;;;;;UADyC,IAAgB,OAAA;AAAA,4BAAA,MAAA,IAAA,IAAA,KAAA,MAAA,CAAA;;;;AAJlG,aAgDM,QAAA,MAAA,MAAA;AA9CJ,aAQM,MAAA,IAAA;AAPJ,aAA6E,MAAA,KAAA;6BAA9C,IAAY,EAAA;;AAC3C,aAKS,MAAA,MAAA;AAJP,aAA8C,QAAA,MAAA;;;;4BAD8B,IAAgB,EAAA;;;;;;;;;;;;;;;uCAD/D,KAAY,IAAA;+BAAZ,KAAY,EAAA;AAAA;;uBAGlC,KAAoB;;;;8BAFiD,KAAgB,EAAA;AAAA;;qBAQzF,KAAc;;;;;;;;;qCAAnB,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAzBK,UAAK;QAEV,cAAc,MAAM;;QACpB,wBAAwB,MAAM;;QAC9B,gBAAgB,MAAM;;QACtB,wBAAwB,MAAM;;QAC9B,sBAAsB,MAAM;;QAC5B,kBAAkB,MAAM;;;AASG,mBAAY,KAAA;;;;;AACmC,uBAAgB,aAAA,IAAA;;;;;AAkB/C,2BAAuB,SAAS,MAAM,WAAQ,KAAA;;;;;AAC1D,QAAA,OAAA,GAAA,UAAA,uBAAuB,SAAS,MAAM,kBAAgB,KAAA,GAAA;AAAtD,6BAAuB,SAAS,MAAM,mBAAgB;;;;;;AAQ1D,UAAM,wBAAwB,SAAS,IAAI;AAAA;;AAG3C,UAAM,qBAAqB,SAAS,IAAI;AAAA;;;;;;;sBAtCtE,aAAa,KAA0B;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBCQjC,SAAS,IAAQ,GAAC,KAAK,IAAA;;;;;;;;;qBAKnB,IAAsB,GAAC,IAAQ,GAAC;AAAe,QAAA,UAAA,iCAAA,SAAK,IAAL;mCAApD,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;AARV,aAYM,QAAA,MAAA,MAAA;AAXJ,aAIK,MAAA,EAAA;AAHH,aAEM,IAAA,IAAA;;;AAGR,aAIM,MAAA,IAAA;;;;;;;;;8DARD,SAAS,IAAQ,GAAC,KAAK,IAAA;AAAA,iBAAA,IAAA,QAAA;;uBAKnB,IAAsB,GAAC,IAAQ,GAAC;;;;;;;;;uCAArC,QAAI,KAAA,GAAA;;;;;;AARW,yBAAA,qBAAA,MAAA,MAAA,EAAA,UAAU,IAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBAD7B,IAAc;AAAqB,QAAA,UAAA,iCAAA,QAAS,MAAT;iCAAxC,QAAI,KAAA,GAAA;;;;;;;;;;;;;AAFR,aAkBM,QAAA,KAAA,MAAA;;;;;;;;qBAhBG,KAAc;;;;;;;;;qCAAnB,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;QAbK,UAAK;AAEI,QAAM;QACpB,wBAAwB,MAAM;;QAC9B,gBAAgB,MAAM;;AACE,QAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACiGJ,MAAA,UAAA,QAAM,OAAI;;;;;;;;AAArB,aAAA,UAAA,QAAM;;;;;AAArB,aAA8C,QAAA,QAAA,MAAA;;;;;;;;;;;;;;;;;;;;;AA4BvC,MAAA,WAAA,QAAK,OAAI;;;AAAI,MAAA,WAAA,QAAK,WAAQ;;;;;;;;;;;;;;gBAAhB,IAAE;;;;AAJmB,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAK,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;;;;;;;AAF9C,aASM,QAAA,MAAA,MAAA;AARJ,aAEM,MAAA,IAAA;AADJ,aAA8C,MAAA,GAAA;;AAEhD,aAIM,MAAA,IAAA;AAHJ,aAEM,MAAA,IAAA;;;;;;;;AAL4B,UAAA,QAAA,KAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAK,GAAG,GAAA;;;AAIvC,UAAA,QAAA,KAAA,aAAA,YAAA,QAAK,OAAI;AAAA,iBAAA,IAAA,QAAA;AAAI,UAAA,QAAA,KAAA,aAAA,YAAA,QAAK,WAAQ;AAAA,iBAAA,IAAA,QAAA;AAAA;;;;;;;;;;;;eAaxB,qBAEP;AAAA;;;;;;;;;;;;;;;;;;gBAJwC,SAC/B;gBAAC,IAAW,EAAA;gBAAC,SACtB;AAAA;;;;;;;;qBADU,KAAW,EAAA;AAAA;;;;;;;;;;;;;;;;;;;mBAchB,IAAY;AAAU,QAAA,UAAA,iCAAA,SAAK,UAAL;iCAA3B,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;AA4BN,aAES,QAAA,QAAA,MAAA;;;;;;;;qBA9BF,KAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYP,MAAA,WAAA,QAAK,OAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AALmB,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAK,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;;;;;;;;;;;;;;AAN9C,aAwBM,QAAA,MAAA,MAAA;AAvBJ,aAES,MAAA,OAAA;;AAET,aAEM,MAAA,IAAA;AADJ,aAA8C,MAAA,GAAA;;AAGhD,aAIM,MAAA,IAAA;AAHJ,aAEM,MAAA,IAAA;AADJ,aAAkB,MAAA,CAAA;;;AAItB,aAIM,MAAA,IAAA;AAHJ,aAEM,MAAA,IAAA;AADJ,aAAuF,MAAA,KAAA;AAAjB,sBAAA,OAAA,QAAK,QAAQ;;AAIvF,aAES,MAAA,OAAA;;;;;;;;;;;;AAjB2B,UAAA,QAAA,MAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAK,GAAG,GAAA;;;AAKpC,UAAA,QAAA,MAAA,aAAA,YAAA,QAAK,OAAI;AAAA,iBAAA,IAAA,QAAA;AAMyD,UAAA,QAAA,MAAA,UAAA,MAAA,KAAA,MAAA,QAAK,UAAQ;AAAb,wBAAA,OAAA,QAAK,QAAQ;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;AAtD1F,MAAA,WAAA,OAAa,SAAS,mBAAmB;;;;;;;;;;;;;;;;;qBAnBrC,IAAM;AAAW,QAAA,UAAA,iCAAA,SAAM,IAAN;mCAAtB,QAAI,KAAA,GAAA;;;;;qBAsBC,IAAY;AAAU,QAAA,YAAA,iCAAA,SAAK,IAAL;mCAA3B,QAAI,KAAA,GAAA;;;;;;QAkBG,KAAW,MAAI,KAAY,GAAC;AAAM,aAAAD;;;;;;AActC,MAAA,YAAA,OAAa,UAAMC,kBAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAvDN,IAAa,OAAA;AAAA,4BAAA,MAAA,IAAA,IAAA,KAAA,MAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;AAJrC,aAkGM,QAAA,MAAA,MAAA;AAhGJ,aAeM,MAAA,IAAA;AAbJ,aAIS,MAAA,MAAA;;;;4BAJW,IAAa,EAAA;;AAMjC,aAC+E,MAAA,MAAA;8BADhD,IAAW,EAAA;;AAG1C,aAES,MAAA,MAAA;;AAIX,aA6EM,MAAA,IAAA;AA3EJ,aAkBM,MAAA,IAAA;AAhBJ,aAEM,MAAA,IAAA;;;;;;;AAgBR,aAqDM,MAAA,IAAA;AAnDJ,aAaM,MAAA,IAAA;AAZJ,aAMQ,MAAA,MAAA;;;AAER,aAGM,MAAA,IAAA;AAFJ,aAA2B,MAAA,MAAA;;AAC3B,aAAiD,MAAA,MAAA;uBAAZ,IAAU;;;;;;;;kCAzCkB,IAAS,EAAA;AAAA;;;;;;;uBARvE,KAAM;;;;8BADK,KAAa,EAAA;AAAA;wCAMF,KAAW,IAAA;gCAAX,KAAW,EAAA;AAAA;AAcrC,UAAA,QAAA,KAAA,aAAA,YAAA,QAAa,SAAS,mBAAmB;AAAuB,iBAAA,IAAA,QAAA;;uBAG5D,KAAY;;;;;;;;;;;;;;yBA2BsB,KAAU;AAAA;AAK9C,UAAA,QAAa,QAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AArGb,uBAAQ,WAAS;MAC1B;MACA,UAAU,eAAe,QAAM;AACjC,WAAO,KAAK,MAAM,IAAI,UAAU,QAAQ;AAAA;UAElC,aAAa,KAAK,MAAM,IAAI,UAAU,UAAU;QAClD,YAAU;AACZ,mBAAa,WAAW,YAAY,UAAU,QAAQ;AAAA;;SAGnD;;AAVM;;;;QA1DJ,UAAK;AAEZ,MAAA,SAAS,MAAM,KAAK,KAAK,MAAM;AAC/B,MAAA,gBAAgB,SAAS,GAAG;AAC5B,MAAA,cAAc;AACd,MAAA,cAAc;AACd,MAAA,aAAa;MAEb,YAAY,MAAM;;MAElB,eAAY,CAAA;AAcZ,MAAA,cAAc,SAAQ,CAAA,CAAA;;6BAEF;AAChB,UAAA,QAAQ,KAAK,OAAO,IAAI,aAAa;UACrC,OAAI,IAAO,KAAK,eAAe,CAAC,EAAE,SAAQ,EAAG,OAAO,MAAK,CAAA;SAC1D,YAAU;AACb,kBAAY,IAAG,CAAA,CAAA;AAAA;oBAEjB,cAAc,KAAK,KAAK;QACpB,KAAK,SAAS,GAAC;;;AAGb,UAAA,MAAM;UACN,YAAS,MAAS,MAAM,SAAS,aAAW,EAAI,aAAa,MAAK,CAAA;AACxE,gBAAY,OAAO,WAAK;AACtB,gBAAU,QAAQ,QAAQ,YAAM;cACxB,WAAW,OAAO;AAClB,cAAA,eAAe,MAAM,KAAK,UAAQ,KAAK,aAAa,SAAS,QAAQ;YACvE,cAAY;AACd,uBAAa;AAAA;AAEb,gBAAM,KAAI,EAAA,GACL,UACH,UAAU,EAAC,CAAA;AAAA;;AAIjB,YAAM,KAAM,CAAA,GAAG,MAAC;eACP,EAAE,OAAO,EAAE,OAAI,KAAQ;AAAA;aAEzB;AAAA;;AA5BI;AA6CA,yBAAQ,WAAS;QAC1B,OAAI,MAAS,QAAQ,SAAS;QAC9B,MAAI;AACA,YAAA,KAAK,UAAU,SAAS,MAAM,OAAK,CAAA,EAAK,MAAM,UAAU,UAAU,SAAQ,CAAA,CAAA;AAAA;AAElF,eAAW,SAAS;AAAA;AALP;AAQN,sBAAW,cAAY;AAC9B,gBAAY,OAAO,WAAK;AAChB,YAAA,oBAAoB,MAAM,UAAU,UAAQ,KAAK,aAAa,aAAa,QAAQ;AACzF,YAAM,OAAO,mBAAmB,CAAC;aAC1B;AAAA;;AAJF;+BAQiB;UAClB,aAAajB,gBAAI,WAAW;UAC5B,QAAK,CAAA;AACA,eAAA,aAAa,YAAU;UAC5B,OAAI,MAAS,QAAQ,SAAS;AAClC,YAAM,KAAO,EAAA,MAAM,UAAU,UAAU,SAAQ,CAAA;AAAA;UAE3C,KAAK,UAAU,SAAS,MAAM,OAAO,KAAK;AAChD,gBAAY,IAAG,CAAA,CAAA;AAAA;AARF;;AAiBO,oBAAa,aAAA,IAAA;;;;;;AAMF,kBAAW,KAAA;;;;;AA4CC,iBAAU,KAAA;;;;AAQiB,QAAA,gBAAA,iCAAA,QAAQ,IAAI,GAAZ;;2BAgBiB,WAAQ,UAAA,KAAA,KAAA;;;;AAIN,QAAA,kBAAA,iCAAA,WAAW,IAAI,GAAf;wDAM/B;;;;;;;AAhL3D;AACC,qBAAA,GAAA,eAAe,WAAW,IAAI,UAAI;AAAA,UAChC,IAAI,KAAK,KAAK;AAAA,UACd,MAAM,KAAK,KAAK;AAAA,UAChB,UAAUA,gBAAI,KAAK,QAAQ;AAAA,UAC3B,KAAK,KAAK,KAAK;AAAA;AAEjB,qBAAa,KAAM,CAAA,GAAG,MAAC;iBACd,EAAE,OAAO,EAAE,OAAI,KAAQ;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oBCoBN,IAAc,GAAA;AAAA;;;;;;;;;;;;wCAAd,KAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAsB7BA,gBAAI,IAAQ,IAAC,IAAI,IAAA;;;iBAAMA,gBAAI,IAAQ,IAAC,QAAQ,IAAA;;;;;;gBAAzB,KAAG;;gBAAwB,GACjD;AAAA;;;;;;;;iDADGA,gBAAI,KAAQ,IAAC,IAAI,IAAA;AAAA,iBAAA,IAAA,QAAA;iDAAMA,gBAAI,KAAQ,IAAC,QAAQ,IAAA;AAAA,iBAAA,IAAA,QAAA;AAAA;;;;;;;;;;;;;;;gBAF5C,IAAQ,IAAC,aAAa,QAAQ,OAAOA,gBAAI,IAAQ,IAAC,QAAQ,CAAA,IAAA;;;;;;;;;;+CAA1D,KAAQ,IAAC,aAAa,QAAQ,OAAOA,gBAAI,KAAQ,IAAC,QAAQ,CAAA,IAAA;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;;;;;;;AADxD,QAAA,SAAS;AAAY,aAAAiB;;;;;;;;;;;;;;;;;;;kDALMjB,gBAAI,IAAQ,IAAC,GAAG,CAAA;AAAA,aAAA,KAAA,OAAA,aAAA;;;;;;;;;;;AAHtD,aAgBM,QAAA,MAAA,MAAA;AAdJ,aAEM,MAAA,IAAA;AADJ,aAAuD,MAAA,GAAA;;AAGzD,aAQM,MAAA,IAAA;AAPJ,aAMM,MAAA,IAAA;;;;;;gEAV4BA,gBAAI,IAAQ,IAAC,GAAG,CAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAzBxC,IAAI,OAAA,QAAA;wBAAJ,IAAI;AAAA;MACA,IAAS,OAAA,QAAA;6BAAT,IAAS;AAAA;;;;;;;AAOxB,QAAA,YAAc;AAAK,aAAA;AAEd,QAAA,YAAc;AAAM,aAAA;AAEpB,QAAA,YAAc;AAAQ,aAAA;;;;;;;mBAQzB,IAAW;AAAc,QAAA,UAAA,iCAAA,SAAS,YAAT;iCAA9B,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;AAvBV,aA+CM,QAAA,MAAA,MAAA;;;AAtCJ,aAUM,MAAA,IAAA;;;;;AAEN,aAwBM,MAAA,IAAA;;;;;;;;;;8BA1CY,KAAI;;;;;mCACA,KAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAmBtB,KAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QA5CT,UAAK;QACL,mBAAc;QAEnB,aAAa,eAAe;;QAE5B,gBAAgB,MAAM;;MAExB;MACA;AACA,MAAA,YAAY;;AAeE,WAAI;;;;;AACA,gBAAS;;;;;;;;;;;;AAf9B;wBACC,aAAa,eAAe,YAAY;wBACxC,OAAI;AAAA,UACA,EAAA,OAAO,OAAO,OAAO,YAAW;AAAA;YAChC,OAAO;AAAA,YAAQ,OAAO;AAAA,YAAc,QAAM,CAAG,kBAAkB;AAAA;;YAC/D,OAAO;AAAA,YAAU,OAAO;AAAA,YAAkB,QAAS,CAAA,KAAK,KAAK;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBCC5B,IAAY,EAAA;;;;;AAFjD,aAGM,QAAA,KAAA,MAAA;AAFJ,aAA0B,KAAA,KAAA;;AAC1B,aAAuD,KAAA,KAAA;;;;;qBAApB,KAAY,EAAA;AAAA;;;;;;;;;;;;;iBAH9C,IAAc,GAAC,UAAU,WAAOiB,kBAAA,GAAA;;;;;gBADT,IAAa,EAAA;;;;;;;;AAD3C,aAQM,QAAA,MAAA,MAAA;AAPJ,aAAgD,MAAA,IAAA;;;;;;;;qBAApB,KAAa,EAAA;UACpC,KAAc,GAAC,UAAU,SAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;QAnB1B,UAAK;QAEV,gBAAgB,MAAM;;QACtB,eAAe,MAAM;;AAEvB,MAAA,eAAe;;;;;;;AAElB;AACK,YAAA,OAAO,eAAe,UAAU;AAChC,YAAA,QAAQ,eAAe,UAAU;YACjC,WAAQ,GAAM,KAAK,KAAK,WAAW,SAAS,GAAG,GAAG,KAAK,KAAK,OAAO,WAAW,SAAS,GAAG,GAAG;YAC7F,YAAS,GAAM,MAAM,KAAK,WAAW,SAAS,GAAG,GAAG,KAAK,MAAM,OAAO,WAAW,SAAS,GAAG,GAAG;wBACpG,eAAY,GAAM,cAAc,WAAS;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACwEzC,aAGM,QAAA,KAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBALY,IAAQ;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAtEpB,gBAAgB,WAAW,UAAU;QAElC,gBAAW;QAEX,aAAQ;QACR,cAAS;AAET,MAAA,EAAA,YAAY,cAAc,aAAa,UAAU,SAAS,MAAA;AAC1D,MAAA,EAAA,iBAAiB,gBAAgB,cAAc,aAAa,WAAW,UAAQ,EAAI,mBAAmB,MAAM,UAAQ,IAAM,UAAK;AAE1I,YAAS,MAAA;AACP,UAAM,UAAS;AAAA;MAGb,gBAAgB,MAAM;;AAEX,0BAAS,MAAI;AAErB,QAAA,CAAA,KAAK,MAAI;YACNQ,aAAqB,+CAA+C;AAAA;QAGxE,KAAK,SAAS,QAAM;YAChBA,aAAqB,gCAAgC,KAAK,KAAK,YAAW,IAAK,GAAG;AAAA;AAGtF,QAAA,aAAa,KAAK,eAAe,aAAa,IAAI;QAClD,WAAW,KAAK;QAEhB,QAAQ,KAAK,kBAAgB;AAC/B,iBAAW,QAAQ,KAAK,iBAAiB,QAAQ;AAAA;AAG7C,UAAA,iBAAiBgB,cAA4B,UAAU,IAAI;QAC7D,gBAAc;WACX,KAAK,KAAK,MAAI;AACV,eAAAiC,eAAuB,KAAK,KAAK,OAAO,wCAA0C,EAAA,MAAM,eAAc,IAAK,IAAI;AAAA;AAEnH,UAAA,CAAA,YAAY,WAAS;cAClB,QAAK,MAAS,OAAO,QAAO;AAAA,UAChC,OAAO,KAAK,KAAK,SAAS,sCAAsC;AAAA,UAChE,SAAO,gCAAkC,KAAK,KAAK,OAAO,8CAA4C,EAAI,MAAM,eAAc,CAAA;AAAA,UAC9H,YAAY;AAAA;aAET,OAAK;iBACD;AAAA;;;AAKT,QAAA,KAAK,SAAO;;gBAEJ,KAAK,KAAK,MAAI;aACjBA,eAAuB,KAAK,KAAK,SAAS,gCAAgC,GAAG,IAAI;AAAA;AAGnF,WAAA,KAAK,UAAU,SAAS,UAC7B,CAAA,EAAA,MAAM,UACN,UAAU,EAAC,CAAA,CAAA;AAAA;AA1CA;;AAmDgB,oBAAA,eAAA,iBAAiB,IAAE,cAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC7ErC,MAAM,oBAAoB,kBAAkB;AAAA,EAEzD,YAAY,UAAU,YAAY,OAAO,UAAU,CAAE,GAAE,aAAa,IAAI;AACtE,UAAM;AAAA,MACJ,OAAO,aAAa,SAAS;AAAA,MAC7B,IAAI,sBAAsB,SAAS;AAAA,MACnC,QAAQ;AAAA,QACN,OAAOC;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,UACA;AAAA,QACD;AAAA,MACF;AAAA,MACD,QAAQ;AAAA,MACR,GAAG;AAAA,IACJ,GAAE,UAAU;AACb,SAAK,WAAW;AAAA,EACjB;AAAA,EAGD,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,SAAS,CAAC,wBAAwB,2BAA2B;AAAA,MAC7D,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,eAAe;AAAA,MACf,WAAW;AAAA,IACjB,CAAK;AAAA,EACF;AAAA,EAED,OAAO,aAAa,IAAI;AACtB,WAAO,OAAO,OAAO,GAAG,OAAO,EAAE,KAAK,SAAO,IAAI,OAAO,sBAAsB,IAAI;AAAA,EACnF;AAAA,EAED,aAAa,KAAK,UAAU,YAAY,OAAO,UAAU,CAAE,GAAE,aAAa,IAAI;AAC5E,eAAW,UAAU,SAAS;AAC9B,gBAAY,WAAW,SAAS;AAChC,UAAM,MAAM,KAAK,aAAa,SAAS,EAAE;AACzC,QAAI;AAAK,aAAO,IAAI,OAAO,OAAO,EAAE,OAAO,KAAI,CAAE;AACjD,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,UAAU,WAAW,SAAS,UAAU,EAAE,OAAO,MAAM,EAAE,OAAO,KAAM,CAAA;AAAA,IACrF,CAAK;AAAA,EACF;AAAA,EAED,eAAe;AACb,SAAK,OAAO,iBAAiB,MAAM,aAAY;AAAA,EAChD;AAAA,EAGD,oBAAoB;AAClB,QAAI,UAAU,MAAM;AACpB,UAAM,eAAe,KAAK,KAAK;AAC/B,QAAI,cAAc;AAChB,gBAAU;AAAA,QACR;AAAA,UACE,OAAO;AAAA,UACP,OAAO;AAAA,UACP,MAAM;AAAA,UACN,SAAS,MAAM;AACb,iBAAK,SAAS,MAAM,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,UACjD;AAAA,QACF;AAAA,QACD;AAAA,UACE,OAAO;AAAA,UACP,OAAO;AAAA,UACP,MAAM;AAAA,UACN,SAAS,MAAM;AACb,2BAAe,KAAK,KAAK,QAAQ;AAAA,UAClC;AAAA,QACF;AAAA,MACT,EAAQ,OAAO,OAAO;AAAA,IACjB;AACD,WAAO;AAAA,EACR;AAAA,EAED,MAAM,MAAM,SAAS;AACnB,eAAW,OAAO,OAAO,OAAO,GAAG,OAAO,GAAG;AAC3C,UAAI,QAAQ,QAAQ,KAAK,OAAO,iBAAiB,UAAU,KAAK,QAAQ,kBAAkB,OAAO;AAC/F,YAAI,MAAK;AAAA,MACV;AAAA,IACF;AACD,WAAO,MAAM,MAAM,OAAO;AAAA,EAC3B;AAEH;AAtFqB;ACYrB,MAAM,iBAAiB,oBAAI;AAEZ,MAAM,WAAW;AAAA,EAK9B,OAAO,aAAa;AAClB1B,UAAc,GAAG,eAAe,KAAK,eAAe,KAAK,IAAI,CAAC;AAC9DA,UAAc,GAAG,cAAc,KAAK,cAAc,KAAK,IAAI,CAAC;AAC5DA,UAAc,GAAG,cAAc,KAAK,cAAc,KAAK,IAAI,CAAC;AAC5DA,UAAc,GAAG,cAAc,KAAK,cAAc,KAAK,IAAI,CAAC;AAC5DA,UAAc,GAAG,eAAe,KAAK,eAAe,KAAK,IAAI,CAAC;AAC9DA,UAAc,GAAG,eAAe,KAAK,eAAe,KAAK,IAAI,CAAC;AAC9DA,UAAc,GAAG,eAAe,KAAK,eAAe,KAAK,IAAI,CAAC;AAC9DA,UAAc,GAAG,kBAAkB,KAAK,kBAAkB,KAAK,IAAI,CAAC;AACpEA,UAAc,GAAG,eAAe,KAAK,eAAe,KAAK,IAAI,CAAC;AAC9DA,UAAc,GAAG,kBAAkB,KAAK,UAAU,KAAK,IAAI,CAAC;AAAA,EAC7D;AAAA,EAKD,aAAa,eAAe,SAAQ;AAClC,UAAM,SAAS,CAAC,GAAG,QAAO,OAAO,UAAU,EAAE,IAAI,WAAS,MAAM,QAAQ;AACxE,eAAW,OAAO,QAAQ;AACxB,YAAM,KAAK,sBAAsB,GAAG;AAAA,IACrC;AAAA,EACF;AAAA,EAKD,OAAO,cAAc,KAAK;AACxB,QAAI,CAAC,IAAI;AAAQ;AACjB,kBAAc,cAAc,cAAc,IAAI,QAAQ,GAAG;AACzD,QAAI,CAAC/B,gBAA8B,IAAI,MAAM;AAAG;AAChD,SAAK,wBAAwB,IAAI,MAAM;AAAA,EACxC;AAAA,EAKD,OAAO,cAAc,KAAK;AACxB,QAAI,CAAC,IAAI;AAAQ;AACjB,QAAI,CAACA,gBAA8B,IAAI,MAAM;AAAG;AAChD,SAAK,wBAAwB,IAAI,MAAM;AAAA,EACxC;AAAA,EAKD,OAAO,cAAc,KAAK;AACxB,QAAI,CAAC,IAAI;AAAQ;AACjB,kBAAc,cAAc,cAAc,IAAI,QAAQ,GAAG;AACzD,QAAI,CAACA,gBAA8B,IAAI,MAAM;AAAG;AAChD,SAAK,wBAAwB,IAAI,MAAM;AAAA,EACxC;AAAA,EAKD,OAAO,eAAe,KAAK,SAAS;AAClC,QAAI,CAACA,gBAA8B,GAAG;AAAG;AACzC,SAAK,wBAAwB,KAAK,OAAO;AAAA,EAC1C;AAAA,EAKD,OAAO,eAAe,KAAK;AACzB,kBAAc,cAAc,UAAU,IAAI,KAAK;AAC/C,QAAI,CAACA,gBAA8B,GAAG;AAAG;AACzC+B,UAAc,QAAQ,MAAM,KAAK,QAAQ,GAAG;AAAA,EAC7C;AAAA,EAKD,OAAO,eAAe,KAAK;AACzB,kBAAc,cAAc,UAAU,GAAG;AAAA,EAC1C;AAAA,EAKD,OAAO,kBAAkB,KAAK;AAC5B,QAAI,CAAC,IAAI,UAAU;AACjB,UAAI,KAAK,OAAO;AAAA,QACd,CAAC,mBAAmB,UAAU,0BAA0B;AAAA,MAChE,CAAO;AAAA,IACF;AACD,UAAM,iBAAiB9B,iBAA+B,IAAI,KAAK;AAC/D,UAAM,cAAcqB,cAA4B,IAAI,KAAK;AACzD,UAAM,mBAAmBN,mBAAiC,IAAI,KAAK;AACnE,UAAM,OAAO,EAAE,MAAM,gBAAgB,OAAO,aAAa,YAAY;AACrE,QAAI,KAAK,OAAO;AAAA,MACd,OAAO0C,sBAAoC,KAAK,IAAI;AAAA,MACpD,SAASC,sBAAoC,KAAK,IAAI;AAAA,MACtD,QAAQC,gBAA8B,KAAK,IAAI;AAAA,MAC/C,CAAC,UAAU,MAAM,OAAO;AAAA,IAC9B,CAAK;AAAA,EACF;AAAA,EAKD,OAAO,eAAe,KAAK;AACzB,QAAI,CAAC5D,gBAA8B,GAAG;AAAG;AACzC,UAAM,iBAAiBC,iBAA+B,IAAI,KAAK;AAC/D8B,UAAc,QAAQ,MAAM,KAAK,QAAQ,KAAK,cAAc;AAC5D,WAAO,KAAK,sBAAsB,GAAG;AAAA,EACtC;AAAA,EAED,aAAa,UAAU,YAAY,OAAO,QAAQ,EAAE,gBAAgB,UAAU,IAAI;AAEhF,UAAM,cAAczD,SAAmB,UAAU;AAEjD,UAAM,cAAc,IAAI,YAAY,WAAW;AAE/C,UAAM,YAAY,kBAAkB,KAAK;AAEzC,UAAM,EAAE,eAAe,kBAAkB,YAAY,QAAO;AAE5D,UAAM,aAAayD,MAAc,KAAK,MAAM,KAAK,SAAS,aAAa,eAAe,eAAe,MAAM;AAC3G,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,EAAE,eAAe,MAAM,YAAY,OAAM;AAE/C,UAAM,eAAe,SAAS,MAAM,KAAK,KAAK,YAAY,YAAY,QAAQ,aAAa;AAE3F,UAAM,KAAK,sBAAsB,YAAY;AAAA,MAC3C,QAAQ;AAAA,MAAY,QAAQ;AAAA,MAAY,OAAO;AAAA,MAAY;AAAA,MAAgB;AAAA,IACjF,CAAK;AAED,WAAO;AAAA,EAER;AAAA,EAED,aAAa,aAAa,YAAY,OAAO,QAAQ,EAAE,gBAAgB,UAAU,IAAI;AAEnF,UAAM,cAAczD,SAAmB,UAAU;AAEjD,UAAM,cAAc,IAAI,YAAY,WAAW;AAE/C,UAAM,YAAY,kBAAkB,OAAO,EAAE,QAAQ,KAAI,CAAE;AAE3D,UAAM,EAAE,eAAe,kBAAkB,YAAY,QAAO;AAE5D,UAAM,aAAayD,MAAc,KAAK,MAAM,KAAK,YAAY,aAAa,eAAe,eAAe,MAAM;AAC9G,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,EAAE,eAAe,MAAM,YAAY,OAAM;AAE/C,UAAM,eAAe,SAAS,MAAM,KAAK,QAAQ,YAAY,YAAY,QAAQ,aAAa;AAE9F,UAAM,KAAK,sBAAsB,YAAY;AAAA,MAC3C,QAAQ;AAAA,MAAe,QAAQ;AAAA,MAAY,OAAO;AAAA,MAAY;AAAA,MAAgB;AAAA,IACpF,CAAK;AAED,UAAM,kBAAkB8B,wBAAsC,UAAU;AACxE,QAAI,iBAAiB;AACnB,YAAM,KAAK,gBAAgB,UAAU;AAAA,IACtC;AAED,WAAO;AAAA,EAER;AAAA,EAED,aAAa,eAAe,YAAY,YAAY,OAAO,QAAQ,EAAE,gBAAgB,UAAU,IAAI;AAEjG,UAAM,cAAcvF,SAAmB,UAAU;AACjD,UAAM,cAAcA,SAAmB,UAAU;AAEjD,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,kBAAkB,OAAO,EAAE,QAAQ,KAAI,CAAE;AACjE,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,kBAAkB,cAAc,UAAU;AAClE,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,aAAayD,MAAc,KAAK,MAAM,KAAK,cAAc,aAAa,eAAe,aAAa,eAAe,MAAM;AAC7H,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,kBAAkB;AACxB,UAAM,EAAE,eAAe,MAAM,kBAAkB,OAAM;AAErD,UAAM,eAAe,SAAS,MAAM,KAAK,UAAU,YAAY,YAAY,YAAY,QAAQ,aAAa;AAE5G,UAAM,YAAY;AAAA,MAChB,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,OAAO;AAAA,MACP;AAAA,MACA;AAAA,IACN;AAEI,UAAM,KAAK,sBAAsB,YAAY,SAAS;AACtD,UAAM,KAAK,sBAAsB,YAAY,SAAS;AAEtD,UAAM,WAAW+B,SAAmB,UAAU;AAE9C,UAAM,kBAAkBD,wBAAsC,UAAU;AACxE,QAAI,iBAAiB;AACnB,YAAM,KAAK,gBAAgB,UAAU;AAAA,IAC3C,WAAe3D,gBAA8B,QAAQ,GAAG;AAClD,YAAM6D,yBAA0C,QAAQ;AAAA,IAC9D,OAAW;AACL,YAAMC,uBAAwC,YAAY,YAAY;AAAA,QACpE,OAAO;AAAA,MACf,CAAO;AAAA,IACF;AAED,WAAO;AAAA,EAER;AAAA,EAED,aAAa,kBAAkB,YAAY,YAAY,QAAQ,EAAE,cAAc,OAAO,gBAAgB,UAAU,IAAI;AAElH,UAAM,cAAc1F,SAAmB,UAAU;AACjD,UAAM,cAAcA,SAAmB,UAAU;AAEjD,UAAM,kBAAkBgD,cAA4B,aAAa,EAAE,YAAW,CAAE,EAAE,IAAI,UAAQ,KAAK,SAAU,CAAA;AAE7G,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,kBAAkB,iBAAiB,EAAE,QAAQ,KAAI,CAAE;AAC3E,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,kBAAkB,cAAc,UAAU;AAClE,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,aAAaS,MAAc,KAAK,MAAM,KAAK,kBAAkB,aAAa,eAAe,aAAa,eAAe,MAAM;AACjI,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,kBAAkB;AACxB,UAAM,EAAE,eAAe,MAAM,kBAAkB,OAAM;AAErD,UAAM,eAAe,SAAS,MAAM,KAAK,cAAc,YAAY,YAAY,YAAY,QAAQ,aAAa;AAEhH,UAAM,YAAY;AAAA,MAChB,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,OAAO;AAAA,MACP;AAAA,MACA;AAAA,IACN;AACI,UAAM,KAAK,sBAAsB,YAAY,SAAS;AACtD,UAAM,KAAK,sBAAsB,YAAY,SAAS;AAEtD,UAAM,kBAAkB8B,wBAAsC,UAAU;AACxE,QAAI,iBAAiB;AACnB,YAAM,KAAK,gBAAgB,UAAU;AAAA,IACtC;AAED,WAAO;AAAA,EACR;AAAA,EAED,aAAa,eAAe,YAAY,YAAY,QAAQ,EAAE,gBAAgB,UAAU,IAAI;AAE1F,UAAM,cAAcvF,SAAmB,UAAU;AAEjD,UAAM,cAAc,IAAI,YAAY,WAAW;AAC/C,UAAM,YAAY,mBAAmB,UAAU;AAC/C,UAAM,EAAE,iBAAiB,YAAY,QAAO;AAE5C,UAAM,aAAayD,MAAc,KAAK,MAAM,UAAU,SAAS,aAAa,cAAc,aAAa;AACvG,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,EAAE,oBAAoB,MAAM,YAAY,OAAM;AAEpD,UAAM,eAAe,SAAS,MAAM,UAAU,KAAK,YAAY,iBAAiB,QAAQ,aAAa;AAErG,UAAM,KAAK,sBAAsB,YAAY;AAAA,MAC3C,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,YAAY;AAAA,MACZ;AAAA,MACA;AAAA,IACN,CAAK;AAED,WAAO;AAAA,EAER;AAAA,EAED,aAAa,kBAAkB,YAAY,YAAY,QAAQ,EAAE,gBAAgB,UAAU,IAAI;AAE7F,UAAM,cAAczD,SAAmB,UAAU;AAEjD,UAAM,cAAc,IAAI,YAAY,WAAW;AAC/C,UAAM,YAAY,mBAAmB,YAAY,EAAE,QAAQ,KAAI,CAAE;AACjE,UAAM,EAAE,iBAAiB,YAAY,QAAO;AAE5C,UAAM,aAAayD,MAAc,KAAK,MAAM,UAAU,YAAY,aAAa,cAAc,aAAa;AAC1G,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,EAAE,oBAAoB,MAAM,YAAY,OAAM;AAEpD,UAAM,eAAe,SAAS,MAAM,UAAU,QAAQ,YAAY,iBAAiB,QAAQ,aAAa;AAExG,UAAM,KAAK,sBAAsB,YAAY;AAAA,MAC3C,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,YAAY;AAAA,MACZ;AAAA,MACA;AAAA,IACN,CAAK;AAED,UAAM,kBAAkB8B,wBAAsC,UAAU;AACxE,QAAI,iBAAiB;AACnB,YAAM,KAAK,gBAAgB,UAAU;AAAA,IACtC;AAED,WAAO;AAAA,EAER;AAAA,EAED,aAAa,oBAAoB,YAAY,YAAY,YAAY,QAAQ,EAAE,gBAAgB,UAAU,IAAI;AAE3G,UAAM,cAAcvF,SAAmB,UAAU;AACjD,UAAM,cAAcA,SAAmB,UAAU;AAEjD,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,mBAAmB,YAAY,EAAE,QAAQ,KAAI,CAAE;AACvE,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,mBAAmB,cAAc,eAAe;AACxE,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,aAAayD,MAAc,KAAK,MAAM,UAAU,cAAc,aAAa,cAAc,cAAc,aAAa,cAAc,cAAc,aAAa;AACnK,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,kBAAkB;AACxB,UAAM,EAAE,oBAAoB,MAAM,kBAAkB,OAAM;AAE1D,UAAM,eAAe,mBAAmB,eAAe,SAAS,WAAW,MAAM,UAAU,UAAU,YAAY,YAAY,iBAAiB,QAAQ,aAAa;AAEnK,UAAM,YAAY;AAAA,MAChB,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,YAAY;AAAA,MACZ;AAAA,MACA;AAAA,IACN;AACI,UAAM,KAAK,sBAAsB,YAAY,SAAS;AACtD,UAAM,KAAK,sBAAsB,YAAY,SAAS;AAEtD,UAAM,kBAAkB8B,wBAAsC,UAAU;AAExE,UAAM,WAAW,MAAM,SAAS,UAAU;AAE1C,QAAI,iBAAiB;AACnB,YAAM,KAAK,gBAAgB,UAAU;AAAA,IAC3C,WAAe3D,gBAA8B,QAAQ,GAAG;AAClD,YAAM6D,yBAA0C,QAAQ;AAAA,IAC9D,OAAW;AACL,YAAMC,uBAAwC,YAAY,YAAY;AAAA,QACpE,YAAY;AAAA,MACpB,CAAO;AAAA,IACF;AAED,WAAO;AAAA,EAER;AAAA,EAED,aAAa,uBAAuB,YAAY,YAAY,QAAQ,EAAE,gBAAgB,UAAU,IAAI;AAElG,UAAM,cAAc1F,SAAmB,UAAU;AACjD,UAAM,cAAcA,SAAmB,UAAU;AAEjD,UAAM,mBAAmB0C,mBAAiC,WAAW,EAAE,OAAO,WAAS,MAAM,SAAS,WAAW;AACjH,UAAM,uBAAuB,iBAAiB,OAAO,eAAa;AAChE,aAAO,YAAY,YAAY,MAAM,UAAU,KAAK,IAAI;AAAA,IAC9D,CAAK,EAAE,IAAI,eAAa,UAAU,KAAK,IAAI;AAEvC,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,mBAAmB,sBAAsB,EAAE,QAAQ,KAAI,CAAE;AACjF,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,mBAAmB,cAAc,eAAe;AACxE,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,aAAae,MAAc,KAAK,MAAM,UAAU,kBAAkB,aAAa,cAAc,cAAc,aAAa,cAAc,cAAc,aAAa;AACvK,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,kBAAkB;AACxB,UAAM,EAAE,oBAAoB,MAAM,kBAAkB,OAAM;AAE1D,UAAM,eAAe,SAAS,MAAM,UAAU,cAAc,YAAY,YAAY,iBAAiB,QAAQ,aAAa;AAE1H,UAAM,YAAY;AAAA,MAChB,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,YAAY;AAAA,MACZ;AAAA,MACA;AAAA,IACN;AACI,UAAM,KAAK,sBAAsB,YAAY,SAAS;AACtD,UAAM,KAAK,sBAAsB,YAAY,SAAS;AAEtD,UAAM,kBAAkB8B,wBAAsC,UAAU;AAExE,QAAI,iBAAiB;AACnB,YAAM,KAAK,gBAAgB,UAAU;AAAA,IACtC;AAED,WAAO;AAAA,EAER;AAAA,EAED,aAAa,oBAAoB,YAAY,YAAY,QAAQ,EAAE,cAAc,OAAO,kBAAkB,IAAI;AAE5G,UAAM,cAAcvF,SAAmB,UAAU;AACjD,UAAM,cAAcA,SAAmB,UAAU;AAEjD,UAAM,kBAAkBgD,cAA4B,aAAa,EAAE,YAAW,CAAE,EAAE,IAAI,UAAQ,KAAK,SAAU,CAAA;AAE7G,UAAM,mBAAmBN,mBAAiC,WAAW,EAAE,OAAO,WAAS,MAAM,SAAS,WAAW;AACjH,UAAM,uBAAuB,iBAAiB,OAAO,eAAa;AAChE,aAAO,YAAY,YAAY,MAAM,UAAU,KAAK,IAAI;AAAA,IAC9D,CAAK,EAAE,IAAI,eAAa,UAAU,KAAK,IAAI;AAEvC,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,kBAAkB,iBAAiB,EAAE,QAAQ,KAAI,CAAE;AAC3E,UAAM,kBAAkB,mBAAmB,sBAAsB,EAAE,QAAQ,KAAI,CAAE;AACjF,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,oBAAoB,IAAI,YAAY,WAAW;AACrD,UAAM,kBAAkB,kBAAkB,cAAc,UAAU;AAClE,UAAM,kBAAkB,mBAAmB,cAAc,eAAe;AACxE,UAAM,gBAAgB,kBAAkB;AAExC,UAAM,aAAae,MAAc,KAAK,MAAM,yBAAyB,aAAa,eAAe,aAAa,eAAe,MAAM;AACnI,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,kBAAkB;AACxB,UAAM,EAAE,YAAY,oBAAoB,MAAM,kBAAkB,OAAM;AAEtE,UAAM,eAAe,mBAAmB,eAAe,SAAS,WAAW,MAAM,qBAAqB,YAAY,YAAY,YAAY,iBAAiB,QAAQ,aAAa;AAEhL,UAAM,YAAY;AAAA,MAChB,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,OAAO;AAAA,MACP,YAAY;AAAA,MACZ;AAAA,MACA;AAAA,IACN;AACI,UAAM,KAAK,sBAAsB,YAAY,SAAS;AACtD,UAAM,KAAK,sBAAsB,YAAY,SAAS;AAEtD,UAAM,kBAAkB8B,wBAAsC,UAAU;AACxE,QAAI,iBAAiB;AACnB,YAAM,KAAK,gBAAgB,UAAU;AAAA,IACtC;AAED,WAAO;AAAA,MACL,kBAAkB;AAAA,MAAY,uBAAuB;AAAA,IAC3D;AAAA,EAEG;AAAA,EAED,aAAa,oBAAoB,WAAW,cAAc,eAAe,eAAe,eAAe;AACrG,UAAM,QAAQvF,SAAmB,SAAS;AAC1C,UAAM,MAAM,OAAO,YAAY;AAC/B,UAAM,MAAM,wBAAwB,QAAQ,aAAa;AACzD,UAAM,MAAM,wBAAwB,QAAQ,aAAa;AACzD,UAAM,eAAe,MAAM,MAAM,wBAAwB,QAAQ,aAAa;AAC9E,WAAO,aAAa,IAAI,UAAQ,KAAK,SAAU,CAAA;AAAA,EAChD;AAAA,EAkBD,aAAa,WAAW;AAAA,IACE;AAAA,IAAQ;AAAA,IAAS,aAAa;AAAA,IAAO,aAAa;AAAA,IAAO,WAAW;AAAA,IAAO,WAAW;AAAA,MACpF,IAAI;AAE9B,QAAI;AAGJ,QAAI,YAAY;AAEd,YAAM,kBAAkB,CAAC,EAAE,KAAK,SAAS,KAAK,KAAK,UAAU,SAAS,SAAQ,CAAE;AAGhF,UAAI,YAAY;AACd,uBAAe,MAAM,KAAK,eAAe,YAAY,YAAY,iBAAiB,MAAM;AAAA,MAChG,OAAa;AACL,uBAAe,MAAM,KAAK,aAAa,YAAY,iBAAiB,MAAM;AAC1E,qBAAa,MAAM,KAAK,gBAAgB,SAAS,UAAU,EAAE,OAAO,aAAY,CAAE;AAAA,MACnF;AAAA,IAGP,OAAW;AAGL,UAAI,YAAY;AACd,uBAAe,MAAM,KAAK,UAAU,YAAY,CAAC,QAAQ,GAAG,MAAM;AAAA,MAC1E,OAAa;AACL,qBAAa,MAAM,KAAK,gBAAgB,SAAS,UAAU,EAAE,OAAO,CAAC,QAAQ,EAAC,CAAE;AAAA,MACjF;AAAA,IAEF;AAED,UAAM,eAAe,SAAS,MAAM,KAAK,MAAM,YAAY,YAAY,cAAc,QAAQ;AAE7F,WAAO,EAAE,YAAY,YAAY,UAAU,aAAY;AAAA,EAExD;AAAA,EAGD,aAAa,gBAAgB,SAAS,UAAU,EAAE,gBAAgB,OAAO,QAAQ,UAAU,IAAI;AAE7F,QAAI;AAEJ,QAAI,CAAC,eAAe;AAElB,kBAAYE,WAAmB,SAAS,0BAA0B;AAElE,UAAI,CAAC,WAAW;AAEdgC,sBAAsB,4JAA4J;AAElL,cAAM,mBAAmB,QAAQ,MAAM,UAAU,UAAU,aAAa;AAExE,yBAAiB,UAAU;AAC3B,yBAAiB,kBAAkB;AACnC,yBAAiB,aAAa;AAC9B,yBAAiB,eAAe;AAChC,yBAAiB,0BAA0B;AAC3C,yBAAiB,kBAAkB;AAEnC,oBAAY,MAAM,MAAM,OAAO;AAAA,UAC7B,MAAM;AAAA,UACN,MAAMhC,WAAmB,gBAAgB;AAAA,UACzC,KAAK;AAAA,UACL,CAAC,UAAU,MAAM,OAAO;AAAA,QAClC,CAAS;AAED,cAAM,UAAU,OAAO;AAAA,UACrB,SAAS;AAAA,YACP,MAAM;AAAA,YACN,WAAW;AAAA,YACX,MAAM,EAAE,WAAW,GAAI;AAAA,YACvB,QAAQ;AAAA,YACR,aAAa;AAAA,YACb,CAAC,UAAU,MAAM,OAAO;AAAA,UACzB;AAAA,QACX,CAAS;AAED,cAAM,KAAK,SAAS,IAAI,UAAU,aAAa,0BAA0B,UAAU,EAAE;AAAA,MAEtF;AAAA,IAEP,OAAW;AAEL,kBAAY,KAAK,OAAO,QAAQ,aAAa;AAAA,IAE9C;AAED,QAAI,eAAe,EAAE,GAAG;AAExB,UAAM,WAAWyB,iBAA+B,SAAS;AAEzD,QAAI,CAAC,UAAU,KAAK,MAAM,WAAW;AAEnC,UAAI,OAAO;AACT,iBAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;AACrC,gBAAM,WAAW,MAAM,IAAI,QAAQ,MAAM;AACzC,cAAI,QAAQ,KAAK,kBAAkB;AACjC,kBAAM,KAAK,MAAM,QAAQ,KAAK,iBAAiB,QAAQ;AAAA,UACxD;AAAA,QACF;AAAA,MACT,OAAa;AACL,gBAAQ,CAAE;AAAA,MACX;AAED,cAAQ,QAAQ,MAAM,IAAI,UAAQ;AAChC,YAAI,WAAW,KAAK,QAAQ;AAC5B,eAAO;AAAA,MACR,CAAA,IAAI,CAAA;AAEL,mBAAa,eAAe;AAAA,QAC1B;AAAA,MACD;AAED,YAAM,OAAO,EAAE,MAAM,UAAU,MAAY;AAE3C,qBAAe,QAAQ,MAAM,YAAY,cAAc;AAAA,QACrD,OAAOyD,sBAAoC,WAAW,IAAI;AAAA,QAC1D,SAASC,sBAAoC,WAAW,IAAI;AAAA,QAC5D,QAAQC,gBAA8B,WAAW,IAAI;AAAA,MAC7D,CAAO;AAAA,IAEF;AAED,UAAM,YAAY,MAAM,UAAU,aAAa,YAAY;AAE3D,UAAM,QAAQ,KAAK,OAAO,IAAI,OAAO;AAErC,UAAM,aAAa7B,MAAc,KAAK,MAAM,KAAK,YAAY,SAAS;AACtE,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,CAAC,iBAAiB,MAAM,MAAM,wBAAwB,SAAS,CAAC,SAAS,CAAC;AAEhF,WAAOpD,QAAkB,aAAa;AAAA,EAEvC;AAAA,EAED,aAAa,yBAAyB,aAAa,eAAe,CAAA,GAAI,gBAAgB,CAAA,GAAI;AAExF,UAAM,oBAAoB,CAAA;AAC1B,UAAM,oBAAoB,CAAA;AAE1B,eAAW,cAAc,aAAa;AAEpC,UAAI,SAASJ,aAAuB,UAAU;AAE9C,qBAAe,QAAQ,MAAM,YAAY0B,iBAA+B,MAAM,GAAG,YAAY;AAC7F,mBAAa,UAAU;AAEvB,YAAM,cAAcqB,cAA4B,QAAQ,EAAE,aAAa,aAAa,oBAAmB,CAAE;AACzG,YAAM,mBAAmBN,mBAAiC,QAAQ,EAAE,cAAc,aAAa,mBAAkB,CAAE;AAEnH,YAAM,OAAO,EAAE,MAAM,cAAc,OAAO,aAAa,YAAY;AAEnE,sBAAgB,QAAQ,MAAM,YAAY,eAAe;AAAA,QACvD,OAAO0C,sBAAoC,QAAQ,IAAI;AAAA,QACvD,SAASC,sBAAoC,QAAQ,IAAI;AAAA,QACzD,QAAQC,gBAA8B,QAAQ,IAAI;AAAA,MAC1D,CAAO;AAED,YAAM,UAAU,WAAW,MAAM,GAAG,EAAE;AACtC,YAAM,UAAU,WAAW,MAAM,GAAG,EAAE;AAEtC,UAAI,CAAC,kBAAkB,UAAU;AAC/B,0BAAkB,WAAW,CAAE;AAAA,MAChC;AAED,wBAAkB,SAAS,KAAK;AAAA,QAC9B,OAAO;AAAA,QAAS,GAAG;AAAA,QACnB,CAAC,UAAU,MAAM,OAAO;AAAA,QACxB,CAAC,aAAa,UAAU,MAAM,SAAS;AAAA,MAC/C,CAAO;AAED,UAAI,OAAO,UAAU;AACnB,YAAI,kBAAkB,OAAO,MAAM;AAAK;AACxC,0BAAkB,OAAO,MAAM,MAAM;AAAA,UACnC,OAAO,OAAO,MAAM;AAAA,UAAI,CAAC,UAAU,MAAM,OAAO;AAAA,QACjD;AAAA,MACF;AAAA,IACF;AAED,UAAM,aAAa7B,MAAc,KAAK,MAAM,KAAK,eAAe,mBAAmB,iBAAiB;AACpG,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,MAAM,gBAAgB,OAAO,OAAO,iBAAiB,CAAC;AAE5D,eAAW,CAAC,SAAS,eAAe,OAAO,QAAQ,iBAAiB,GAAG;AACrE,YAAM,QAAQ,KAAK,OAAO,IAAI,OAAO;AACrC,YAAM,MAAM,wBAAwB,SAAS,UAAU;AAAA,IACxD;AAED,UAAM,eAAe,SAAS,MAAM,KAAK,WAAW,mBAAmB,iBAAiB;AAExF,WAAO;AAAA,EAER;AAAA,EAED,aAAa,2BAA2B,aAAa,eAAe;AAElE,UAAM,oBAAoB,CAAA;AAC1B,UAAM,oBAAoB,CAAA;AAE1B,eAAW,cAAc,aAAa;AAEpC,UAAI,SAASxD,aAAuB,UAAU;AAE9C,YAAM,eAAe0B,iBAA+B,MAAM;AAC1D,mBAAa,UAAU;AAEvB,YAAM,UAAU,WAAW,MAAM,GAAG,EAAE;AACtC,YAAM,UAAU,WAAW,MAAM,GAAG,EAAE;AAEtC,UAAI,CAAC,kBAAkB,UAAU;AAC/B,0BAAkB,WAAW;MAC9B;AAED,wBAAkB,SAAS,KAAK;AAAA,QAC9B,OAAO;AAAA,QAAS,GAAG;AAAA,QACnB,CAAC,UAAU,MAAM,OAAO;AAAA,QACxB,CAAC,aAAa,UAAU,MAAM,SAAS;AAAA,MAC/C,CAAO;AAED,UAAI,OAAO,UAAU;AACnB,YAAI,kBAAkB,OAAO,MAAM;AAAK;AACxC,0BAAkB,OAAO,MAAM,MAAM;AAAA,UACnC,OAAO,OAAO,MAAM;AAAA,UAAI,CAAC,UAAU,MAAM,OAAO;AAAA,QACjD;AAAA,MACF;AAAA,IACF;AAED,UAAM,aAAa8B,MAAc,KAAK,MAAM,KAAK,iBAAiB,mBAAmB,iBAAiB;AACtG,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,MAAM,gBAAgB,OAAO,OAAO,iBAAiB,CAAC;AAE5D,eAAW,CAAC,SAAS,eAAe,OAAO,QAAQ,iBAAiB,GAAG;AACrE,YAAM,QAAQ,KAAK,OAAO,IAAI,OAAO;AACrC,YAAM,MAAM,wBAAwB,SAAS,UAAU;AAAA,IACxD;AAED,UAAM,eAAe,SAAS,MAAM,KAAK,aAAa,mBAAmB,iBAAiB;AAE1F,WAAO;AAAA,EAER;AAAA,EAED,aAAa,gBAAgB,YAAY,SAAS,EAAE,uBAAuB,OAAO,gBAAgB,UAAU,IAAI;AAE9G,UAAM,cAAczD,SAAmB,UAAU;AACjD,UAAM,mBAAmB,uBAAuBwF,SAAmB,oBAAoB,IAAI;AAE3F,UAAM,UAAU7D,iBAA+B,WAAW;AAE1D,UAAM,OAAO,QAAQ,MAAM,YAAY,QAAQ,MAAM,UAAU,OAAO,GAAG,QAAQ,MAAM,UAAU,OAAO,CAAC;AAEzG,UAAM,OAAO,QAAQ,MAAM,WAAW,SAAS,IAAI;AAEnD,UAAM,aAAa8B,MAAc,KAAK,MAAM,KAAK,YAAY,aAAa,MAAM,kBAAkB,aAAa;AAC/G,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAMkC,OAAa,EAAE;AAErB,UAAM7B,mBAAiC,aAAa,MAAM,aAAa;AAEvE,QAAI,KAAK,WAAW,KAAK,aAAa;AACpC,UAAI,MAAM,WAAW,MAAM;AACzB,cAAM,KAAK,sBAAsB,YAAY;AAAA,UAC3C,QAAQ;AAAA,UAAiB,QAAQ;AAAA,UAAsB,QAAQ;AAAA,QACzE,CAAS;AAAA,MACF;AACD,UAAI,MAAM,WAAW,MAAM;AACzB,cAAM,KAAK,sBAAsB,YAAY;AAAA,UAC3C,QAAQ;AAAA,UAAgB,QAAQ;AAAA,UAAsB,QAAQ;AAAA,QACxE,CAAS;AAAA,MACF;AACD,UAAI,MAAM,WAAW,OAAO;AAC1B,cAAM,KAAK,sBAAsB,YAAY;AAAA,UAC3C,QAAQ;AAAA,UAAkB,QAAQ;AAAA,UAAsB,QAAQ;AAAA,QAC1E,CAAS;AAAA,MACF;AACD,UAAI,MAAM,WAAW,OAAO;AAC1B,cAAM,KAAK,sBAAsB,YAAY;AAAA,UAC3C,QAAQ;AAAA,UAAgB,QAAQ;AAAA,UAAsB,QAAQ;AAAA,QACxE,CAAS;AAAA,MACF;AAAA,IACF;AAED,WAAO,eAAe,mBAAmB,eAAe,SAAS,cAAc,YAAY,MAAM,oBAAoB;AAAA,EACtH;AAAA,EAED,OAAO,iBAAiB,YAAY,UAAU,sBAAsB;AAElE,UAAM,SAAS0B,SAAmB,UAAU;AAE5C,UAAM,mBAAmB,uBAAuBvF,aAAuB,oBAAoB,IAAI;AAE/F,QAAI,QAAQ,MAAM,cAAc,QAAQ;AAAG,aAAO;AAElD,UAAM,OAAO0B,iBAA+B,MAAM;AAElD8B,UAAc,QAAQ,MAAM,KAAK,QAAQ,QAAQ,UAAU,gBAAgB;AAE3E,QAAI,KAAK,WAAW,KAAK,aAAa;AACpC,UAAI,UAAU,WAAW,MAAM;AAC7BA,cAAc,QAAQ,MAAM,KAAK,OAAO,QAAQ,gBAAgB;AAAA,MACjE;AACD,UAAI,UAAU,WAAW,MAAM;AAC7BA,cAAc,QAAQ,MAAM,KAAK,MAAM,QAAQ,gBAAgB;AAAA,MAChE;AACD,UAAI,UAAU,WAAW,OAAO;AAC9BA,cAAc,QAAQ,MAAM,KAAK,QAAQ,QAAQ,gBAAgB;AAAA,MAClE;AACD,UAAI,UAAU,WAAW,OAAO;AAC9BA,cAAc,QAAQ,MAAM,KAAK,MAAM,QAAQ,gBAAgB;AAAA,MAChE;AAAA,IACF;AAAA,EACF;AAAA,EAED,aAAa,gBAAgB,YAAY;AACvC,UAAM,SAAS+B,SAAmB,UAAU;AAC5C,QAAI,CAAC;AAAQ,aAAO;AACpB,UAAM,aAAa/B,MAAc,KAAK,MAAM,KAAK,YAAY,MAAM;AACnE,QAAI,eAAe;AAAO,aAAO;AACjC,WAAO,OAAO;EACf;AAAA,EAYD,OAAO,wBAAwB,KAAK,SAAS;AAC3C,UAAM,SAAS,KAAK,SAAS;AAC7B,QAAI,CAACmC,gBAAuB;AAAI;AAChC,QAAI,CAAClE,gBAA8B,MAAM;AAAG;AAC5C,UAAM,aAAa,OAAO;AAC1B,WAAOmE,gBAAwB,YAAY,YAAY,OAAO,SAAS;AACrE,YAAM,UAAUN,wBAAsC,IAAI;AAC1D,UAAI;AAAS;AACb,YAAM9B,MAAc,WAAW,YAAY;AACzC,cAAMK,mBAAiC,IAAI;AAAA,MACnD,CAAO;AAAA,IACP,CAAK,EAAE,UAAU;AAAA,EAEd;AAAA,EAQD,aAAa,sBAAsB,eAAe;AAEhD,QAAI,CAACpC,gBAA8B,aAAa;AAAG,aAAO;AAE1D,UAAM,WAAWC,iBAA+B,aAAa;AAE7D,QAAIzB,WAAmB,cAAc,GAAG;AACtC,YAAM,QAAQ,WAAW,OAAO,QAAQ,QAAQ,EAAE,IAAI,WAAS;AAC7D,eAAO,IAAI,QAAQ,OAAO,YAAY;AACpC,gBAAM,CAAC,UAAU,YAAY;AAC7B,gBAAM,UAAU,SAAS,YAAa,EAAC,SAAS,OAAO;AACvD,gBAAM,UAAU,SAAS,YAAa,EAAC,SAAS,OAAO;AACvD,cAAK,CAAC,WAAW,CAAC,WAAa,EAAC,YAAY,eAAe,IAAI,QAAQ;AAAI,mBAAO,QAAO;AACzF,yBAAe,IAAI,QAAQ;AAE3B,cAAI,SAAS;AACX,kBAAM,YAAY,QAAQ;AAC1B4F,kBAAc,oBAAoB,UAAU;AAAA,UAC7C,WAAU,SAAS;AAClBA,kBAAc,oBAAoB,UAAU;AAC5C,kBAAM,YAAY,aAAa,QAAQ;AAAA,UACxC;AACD;QACV,CAAS;AAAA,MACF,CAAA,CAAC;AAAA,IACH;AAEDA,UAAc,mCAAmC,cAAc,MAAM;AAAA,EACtE;AAAA,EAUD,OAAO,sBAAsB,YAAY,WAAW;AAElD,UAAM,SAASN,SAAmB,UAAU;AAE5C,QAAI,CAAC9D,gBAA8B,MAAM;AAAG,aAAO;AAEnD,UAAM,WAAWC,iBAA+B,MAAM;AAEtD,QAAI,CAAC,SAAS;AAAO,aAAO;AAE5B,UAAM,QAAQ,KAAK,OAAO,QAAQ,SAAS,KAAK;AAEhD,QAAI,CAAC,OAAO;AACV,YAAMM,aAAqB,mCAAmC,SAAS,8BAA8B,OAAO,MAAM;AAAA,IACnH;AAGD,QAAI,UAAU,QAAQ;AACpB,gBAAU,SAAShC,aAAuB,UAAU,MAAM;AAAA,IAC3D;AAED,QAAI,UAAU,QAAQ;AACpB,gBAAU,SAASA,aAAuB,UAAU,MAAM;AAAA,IAC3D;AAED,UAAM,cAAc,UAAU,kBAAkB,gBAAgB,UAAU,OAAO,QAAQ,UAAU;AAEnG,QAAI,UAAU,MAAM;AAClB,gBAAU,QAAQ,UAAU,MAAM,IAAI,UAAQ,YAAY,MAAM,IAAI,KAAK,GAAG,CAAC;AAAA,IAC9E;AAED,WAAO,MAAM,QAAQ,CAAC,SAAS,CAAC;AAAA,EAEjC;AAAA,EAUD,aAAa,UAAU,SAAQ,MAAM,EAAE,SAAS,UAAU,IAAI;AAE5D,QAAI,KAAK,SAAS;AAAQ,aAAO;AAEjC,QAAI,OAAO,MAAM,KAAK,eAAe,aAAa,IAAI;AACtD,QAAI,WAAW,KAAK;AAEpB,QAAI,CAAC,UAAU;AACb,cAAQ,MAAM,IAAI;AAClB,YAAMgC,aAAqB,+CAA+C;AAAA,IAC3E;AAED,UAAM,WAAW;AAAA,MACf,QAAQ;AAAA,MAAO;AAAA,MAAgB,UAAU;AAAA,QACvC,MAAM;AAAA,QAAU,UAAU;AAAA,MAC3B;AAAA,MAAE,UAAU;AAAA,IACd;AAED,QAAI,KAAK,SAAS;AAChB,eAAS,SAAS,QAAO,OAAO,IAAI,KAAK,OAAO,EAAE;AAAA,IACxD,WAAe,KAAK,SAAS;AACvB,eAAS,SAAS,KAAK,OAAO,IAAI,KAAK,OAAO;AAAA,IAC/C;AAED,QAAI,CAAC,SAAS,UAAU,CAAC,KAAK,KAAK,MAAM;AACvC,aAAOiD,eAAuB,KAAK,KAAK,SAAS,gCAAgC,GAAG,IAAI;AAAA,IACzF;AAED,UAAM,2BAA2BzB,MAAc,KAAK,MAAM,KAAK,qBAAqB,SAAS,QAAQ,SAAS,QAAQ,SAAS,UAAU,SAAS,QAAQ;AAC1J,QAAI,6BAA6B;AAAO,aAAO;AAE/C,QAAI;AACJ,QAAI,qBAAqB,CAAA;AACzB,QAAI;AACJ,QAAI;AAEJ,QAAI,SAAS,QAAQ;AAEnB,yBAAmB,KAAK,SAAS,MAAM;AAAA,IAE7C,OAAW;AAEL,YAAM,WAAW,QAAO,KAAK,WAAW,KAAK,GAAG,KAAK,CAAC;AACtD,UAAI,SAAS;AACb,UAAI,SAAS;AAEb,2BAAqBnB,oBAA8B,EAAE,GAAG,EAAC,CAAE,EACxD,IAAI,WAASvC,YAAsB,KAAK,CAAC,EACzC,OAAO,WAAS2B,gBAA8B,KAAK,CAAC;AAAA,IAExD;AAED,QAAI,mBAAmB,UAAU,KAAK,QAAQ,IAAI,UAAU,GAAG,UAAU,KAAK,SAAS,IAAI,YAAY,gBAAgB,GAAG;AACxHwD,qBAAuB,sFAAsF;AAC7G,aAAO;AAAA,IACR;AAED,QAAI,mBAAmB,SAAS,KAAK,CAAC,KAAK,KAAK,MAAM;AAEpD,UAAI,CAAE,oBAAmB,cAAc,SAAS,SAAS,kBAAkB,QAAQ;AAEjF,cAAM,cAAc,QAAO,OAAO,WAAW,KAAK,WAAS,MAAM,UAAU,SAAS,MAAM;AAE1F,YAAI,aAAa;AAEf,gBAAM,cAAc,mBAAmB;AAEvC,gBAAM,WAAW,KAAK,MAAMa,sBAAgC,aAAa,YAAY,MAAM,IAAI,QAAO,KAAK,IAAI,IAAI;AAEnH,gBAAM,WAAWpE,iBAA+B,WAAW;AAE3D,gBAAM,cAAc,SAAS,WAAW,SAAS,WAAW;AAE5D,cAAI,WAAW,aAAa;AAC1BuD,2BAAuB,KAAK,KAAK,SAAS,8BAA8B,GAAG,IAAI;AAC/E,mBAAO;AAAA,UACR;AAAA,QACF;AAAA,MACF;AAED,2BAAqB,mBAAmB,OAAO,WAAS,CAAC,KAAK,UAAU,iBAAiB,KAAK,CAAC;AAE/F,UAAI,CAAC,mBAAmB,QAAQ;AAC9BA,uBAAuB,KAAK,KAAK,SAAS,8BAA8B,GAAG,IAAI;AAC/E,eAAO;AAAA,MACR;AAAA,IACF;AAED,UAAM,iBAAiBjC,cAA4B,qBAAqB,IAAI,SAAS,SAAS,IAAI;AAClG,QAAI,gBAAgB;AAClB,UAAI,CAAC,KAAK,KAAK,MAAM;AACnB,eAAOiC,eAAuB,KAAK,KAAK,OAAO,wCAAwC,EAAE,MAAM,gBAAgB,GAAG,IAAI;AAAA,MACvH;AAED,UAAI,QAAQ,KAAK,kBAAkB;AACjC,iBAAS,SAAS,OAAO,MAAM,QAAQ,KAAK,iBAAiB,SAAS,SAAS,IAAI;AAAA,MACpF;AAED,YAAM,oBAAoBjC,cAA4B,qBAAqB,IAAI,SAAS,SAAS,IAAI;AAErG,UAAI,qBAAqB,CAAC,YAAY,WAAW;AAC/C,cAAM,QAAQ,MAAM,OAAO,QAAQ;AAAA,UACjC,OAAO,KAAK,KAAK,SAAS,sCAAsC;AAAA,UAChE,SAAS,gCAAgC,KAAK,KAAK,OAAO,8CAA8C,EAAE,MAAM,kBAAmB,CAAA;AAAA,UACnI,YAAY;AAAA,QACtB,CAAS;AACD,YAAI,CAAC,OAAO;AACV,iBAAO;AAAA,QACR;AAAA,MACF;AAAA,IACP,OAAW;AACL,UAAI,QAAQ,KAAK,kBAAkB;AACjC,iBAAS,SAAS,OAAO,MAAM,QAAQ,KAAK,iBAAiB,SAAS,SAAS,IAAI;AAAA,MACpF;AAAA,IACF;AAED,QAAI,YAAY,SAAS;AAEvB,UAAI,mBAAmB,QAAQ;AAC7B,iBAAS;AAAA,MACV;AAED,kBAAY,SAAS,SAAS,MAAM,KAAK,UAAU,yBAAyB,CAAC;AAC7E,eAAS,SAAS,WAAW;AAAA,IAEnC,OAAW;AAEL,YAAM,WAAW,YAAY,SAAS,SAAS,MAAM,KAAK,UAAU,uBAAuB;AAE3F,UAAI,SAAS,EAAE,QAAQ,aAAa,UAAU,EAAG;AACjD,UAAI,WAAW,GAAG;AAChB,iBAAS,MAAM,eAAe,KAAK,MAAM,mBAAmB,EAAE;AAC9D,YAAI,CAAC;AAAQ,iBAAO;AAAA,MACrB;AAED,eAAS,OAAO;AAChB,kBAAY,SAAS,SAAS,MAAM,KAAK,UAAU,yBAAyB,OAAO,OAAO,QAAQ,CAAC;AACnG,eAAS,SAAS,WAAW,OAAO,OAAO,QAAQ;AAAA,IAEpD;AAED,QAAI,WAAW,aAAa;AAC1B,eAAS,SAAS,mBAAmB;AAAA,IAC3C,OAAW;AACL,eAAS,WAAW,EAAE,GAAG,EAAC;AAAA,IAC3B;AAED,UAAM,aAAaQ,MAAc,KAAK,MAAM,KAAK,UAAU,SAAS,QAAQ,SAAS,QAAQ,SAAS,UAAU,SAAS,QAAQ;AACjI,QAAI,eAAe;AAAO,aAAO;AAEjC,WAAO,eAAe,YAAY,eAAe,SAAS,YAAY;AAAA,MACpE,QAAQ,KAAK,KAAK;AAAA,MAClB,SAAS,QAAO,MAAM;AAAA,MACtB,YAAYpD,QAAkB,SAAS,MAAM;AAAA,MAC7C,YAAYA,QAAkB,SAAS,MAAM;AAAA,MAC7C,UAAU,SAAS;AAAA,MACnB,UAAU,SAAS;AAAA,IACzB,CAAK;AAAA,EAEF;AAAA,EAED,aAAa,iBAAiB,cAAc;AAE1C,QAAI,CAACqB,gBAA8B,YAAY;AAAG,aAAO;AAEzD,UAAM,YAAY,aAAa;AAE/B,QAAI,CAACsE,cAAqB,GAAI;AAC5Bd,qBAAuB,uFAAuF,IAAI;AAClH,aAAO;AAAA,IACR;AAEDY,UAAc,YAAY,aAAa,MAAM;AAE7C,UAAM,WAAWnE,iBAA+B,YAAY;AAE5D,UAAM,cAAc,SAAS,WAAW,SAAS,WAAW;AAE5D,QAAI,cAAc,CAAA;AAElB,QAAI,OAAO,OAAO,WAAW,SAAS,GAAG;AACvC,oBAAc,CAAC,GAAG,OAAO,OAAO,UAAU;AAC1C,oBAAc,YAAY,OAAO,WAAS,MAAM,aAAa,YAAY;AAAA,IAC1E;AAED,QAAI,CAAC,YAAY,UAAU,CAAC,KAAK,KAAK,MAAM;AAC1C,kBAAY,KAAK,GAAG,OAAO,OAAO,UAAU;AAC5C,UAAI,QAAQ;AACV,oBAAY,QAAQ,MAAM;AAAA,MAC3B;AAAA,IACF;AAED,kBAAc,YAAY,OAAO,WAAS,MAAM,SAAS,MAAM,aAAa,YAAY,EAAE,OAAO,WAAS;AACxG,aAAOsE,oBAA8B,WAAW,OAAO,WAAW,KAAK,KAAK,KAAK;AAAA,IACvF,CAAK;AAED,QAAI,CAAC,YAAY,UAAU,CAAC,KAAK,KAAK,QAAQ,gBAAgB,UAAU;AACtEf,qBAAuB,KAAK,KAAK,SAAS,8BAA8B,GAAG,IAAI;AAC/E,aAAO;AAAA,IACR;AAED,QAAI;AACJ,QAAI,YAAY,QAAQ;AACtB,UAAI,YAAY,SAAS,MAAM,GAAG;AAChC,2BAAmB,OAAO;AAAA,MAClC,OAAa;AACL,oBAAY,KAAK,CAAC,kBAAkB,qBAAqB;AACvD,iBAAOgB,qBAA+B,WAAW,gBAAgB,IAAIA,qBAA+B,WAAW,gBAAgB;AAAA,QACzI,CAAS;AACD,2BAAmB,YAAY,GAAG;AAAA,MACnC;AAAA,IACP,WAAe,KAAK,KAAK,aAAa,CAAC,KAAK,KAAK,MAAM;AACjD,yBAAmB,KAAK,KAAK;AAAA,IAC9B;AAED,QAAI,SAAS,eAAe,kBAAkB;AAE5C,UAAI,SAAS,UAAU,CAAC,KAAK,KAAK,MAAM;AACtCJ,cAAc,2CAA2C,aAAa,MAAM;AAC5E,eAAO,KAAK,UAAU,eAAe,cAAc,gBAAgB;AAAA,MACpE;AAED,UAAI,SAAS,QAAQ;AACnBA,cAAc,8BAA8B,aAAa,MAAM;AAC/D,cAAM,KAAK,UAAU,aAAa,cAAc,gBAAgB;AAAA,MACjE;AAAA,IAEF;AAED,WAAO,KAAK,yBAAyB,aAAa,MAAM,EAAE,sBAAsB,kBAAkB,KAAI,CAAE;AAAA,EAEzG;AAAA,EAED,aAAa,uBAAuB,cAAc,YAAY,QAAQ,YAAY;AAEhF,UAAM,gBAAgB9F,SAAmB,YAAY;AAErD,UAAM,QAAQgD,cAA4B,aAAa;AACvD,UAAM,aAAaN,mBAAiC,aAAa;AAEjE,UAAM,WAAWf,iBAA+B,aAAa;AAC7D,UAAM,YAAYoB,uBAAwC,aAAa;AAEvE,UAAM,kBAAkB,IAAI,YAAY,aAAa;AAErD,UAAM,iBAAiB,WAAW,IAAI,UAAQ;AAC5C,aAAO,CAAC,MAAM,IAAI,YAAY/C,SAAmB,IAAI,CAAC,CAAC;AAAA,IAC7D,CAAK;AAED,QAAI,SAAS,mBAAmB;AAC9B,YAAM,gBAAgB,kBAAkB,OAAO,EAAE,QAAQ,KAAI,CAAE;AAAA,IAChE;AAED,QAAI,SAAS,wBAAwB;AACnC,YAAM,gBAAgB,WAAW,OAAO,WAAS,MAAM,SAAS,MAAM;AACtE,YAAM,gBAAgB,kBAAkB,eAAe,EAAE,QAAQ,MAAM,MAAM,WAAU,CAAE;AAEzF,YAAM,aAAa,WAAW,OAAO,WAAS,MAAM,SAAS,WAAW;AACxE,YAAM,gBAAgB,mBAAmB,YAAY,EAAE,QAAQ,KAAI,CAAE;AAAA,IACtE;AAED,UAAM,eAAe,gBAAgB;AAErC,eAAW,CAAC,MAAM,gBAAgB,gBAAgB;AAChD,UAAI,SAAS,mBAAmB;AAC9B,cAAM,YAAY,kBAAkB,aAAa,WAAW,OAAO,WAAS,MAAM,SAAS,MAAM,EAAE,IAAI,WAAS;AAC9G,gBAAM,WAAW4C,0BAA2C,eAAe,MAAM,MAAM,MAAM;AAAA,YAC3F,SAAS,WAAW;AAAA,YACpB;AAAA,YACA,OAAO;AAAA,UACnB,CAAW;AACD,iBAAO;AAAA,QACR,CAAA,CAAC;AAAA,MACH;AAED,UAAI,SAAS,wBAAwB;AACnC,cAAM,YAAY,kBAAkB,aAAa,WAAW,OAAO,WAAS,MAAM,SAAS,UAAU,EAAE,IAAI,WAAS;AAClH,gBAAM,WAAWA,0BAA2C,eAAe,MAAM,MAAM,MAAM;AAAA,YAC3F,SAAS,WAAW;AAAA,YACpB;AAAA,YACA,OAAO;AAAA,UACnB,CAAW;AACD,iBAAO;AAAA,QACR,CAAA,GAAG,EAAE,MAAM,WAAU,CAAE;AAExB,cAAM,YAAY,mBAAmB,OAAO,QAAQ,aAAa,eAAe,EAAE,IAAI,WAAS;AAC7F,cAAI,CAAC,QAAQ;AACb,gBAAM,WAAWE,+BAAgD,eAAe,MAAM,MAAM;AAAA,YAC1F,SAAS,WAAW;AAAA,YACpB;AAAA,YACA,OAAO;AAAA,UACnB,CAAW;AACD,iBAAO,EAAE,MAAM;QAChB,CAAA,CAAC;AAAA,MACH;AAAA,IACF;AAED,UAAM,oBAAoB,OAAO,YAAY,eAAe,IAAI,WAAS,CAAC,MAAM,IAAI,MAAM,GAAG,QAAO,CAAE,CAAC,CAAC;AAExG,UAAM,aAAaW,MAAc,KAAK,MAAM,KAAK,qBAAqB,eAAe,cAAc,mBAAmB,QAAQ,UAAU;AACxI,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,aAAa,MAAM,gBAAgB;AACzC,UAAM,cAAc,CAAA;AACpB,eAAW,CAAC,MAAM,gBAAgB,gBAAgB;AAChD,kBAAY,QAAQ,MAAM,YAAY,OAAM;AAAA,IAC7C;AAED,UAAMgC,yBAA0C,aAAa;AAE7D,UAAM,eAAe,SAAS,MAAM,KAAK,iBAAiB,cAAc,YAAY,aAAa,QAAQ,UAAU;AAEnH,UAAM,KAAK,sBAAsB,cAAc;AAAA,MAC7C,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,WAAW;AAAA,QACT;AAAA,QACA;AAAA,MACD;AAAA,MACD;AAAA,MACA;AAAA,IACN,CAAK;AAED,UAAM,kBAAkBF,wBAAsC,YAAY;AAC1E,QAAI,iBAAiB;AACnB,YAAM,KAAK,gBAAgB,YAAY;AAAA,IACxC;AAED,WAAO;AAAA,MACL;AAAA,MACA;AAAA,IACN;AAAA,EAEG;AAAA,EAED,aAAa,kBAAkB;AAC7B,QAAI,CAAC,OAAO,OAAO,IAAI;AAAU;AACjC,WAAO,OAAO,OAAO,IAAI,OAAO,IAAI;AAAA,EACrC;AAAA,EAED,aAAa,yBAAyB,YAAY;AAAA,IAChD,uBAAuB;AAAA,IAAO,sBAAsB;AAAA,IAAO,SAAS;AAAA,MAClE,IAAI;AAEN,UAAM,SAASvF,SAAmB,UAAU;AAE5C,QAAI;AACJ,QAAI,uBAAuB,CAAC,KAAK,KAAK,MAAM;AAC1C,yBAAmB,KAAK,KAAK;AAAA,IACnC,OAAW;AACL,yBAAmB,uBAAuBC,aAAuB,oBAAoB,IAAI;AAAA,IAC1F;AAED,UAAM,WAAWkG,mBAAiC,MAAM;AACxD,QAAI,UAAU;AACZ,aAAO,YAAY,KAAK,QAAQ,gBAAgB;AAAA,IACjD;AAED,WAAO,qBAAqB,KAAK,QAAQ,kBAAkB,EAAE,OAAM,CAAE;AAAA,EAEtE;AAAA,EAED,aAAa,YAAY,YAAY,WAAW,OAAO,QAAQ;AAAA,IAC7D,gBAAgB;AAAA,MACd,IAAI;AAEN,UAAM,eAAenG,SAAmB,UAAU;AAClD,UAAM,cAAcA,SAAmB,SAAS;AAEhD,UAAM,aAAa4D,kBAAgC,MAAM,IAAI,UAAS;AAAA,MACpE,GAAG;AAAA,MACH,MAAM,aAAa,MAAM,IAAI,KAAK,EAAE;AAAA,IAC1C,EAAM,GAAG,EAAE,QAAQ,cAAc,OAAO,YAAW,CAAE;AAEjD,UAAM,oBAAoBH,MAAc,KAAK,MAAM,KAAK,gBAAgB,cAAc,aAAa,YAAY,MAAM;AACrH,QAAI,sBAAsB;AAAO,aAAO;AAExC,UAAM,oBAAoB,IAAI,YAAY,YAAY;AACtD,UAAM,iBAAiB9B,iBAA+B,iBAAiB;AACvE,UAAM,yBAAyB,eAAe,WAAW,eAAe,YAAY,eAAe;AAEnG,eAAW,WAAW,WAAW,eAAe;AAC9C,UAAI,CAAC,QAAQ;AAAU;AACvB,UAAI,QAAQ,SAAS,aAAa;AAChC,cAAM,kBAAkB,mBAAmB,CAAC;AAAA,UAC1C,MAAM,QAAQ,KAAK;AAAA,UACnB,UAAU,QAAQ;AAAA,QAC5B,CAAS,GAAG,EAAE,MAAM,QAAQ,aAAa,aAAa,QAAQ,KAAI,CAAE;AAAA,MACpE,OAAa;AACL,cAAM,kBAAkB,kBAAkB,CAAC;AAAA,UACzC,MAAM,QAAQ;AAAA,UACd,UAAU,QAAQ;AAAA,QAC5B,CAAS,GAAG,EAAE,MAAM,QAAQ,aAAa,aAAa,QAAQ,KAAI,CAAE;AAAA,MAC7D;AAAA,IACF;AAED,eAAW,SAAS,WAAW,cAAc;AAC3C,UAAI,CAAC,MAAM,YAAY;AAAwB;AAC/C,UAAI,MAAM,SAAS,aAAa;AAC9B,cAAM,kBAAkB,mBAAmB,CAAC;AAAA,UAC1C,MAAM,MAAM,KAAK;AAAA,UACjB,UAAU,MAAM;AAAA,QACjB,CAAA,GAAG,EAAE,QAAQ,MAAM,MAAM,MAAM,aAAa,aAAa,MAAM,KAAI,CAAE;AAAA,MAC9E,OAAa;AACL,cAAM,kBAAkB,kBAAkB,CAAC;AAAA,UACzC,MAAM,MAAM;AAAA,UACZ,UAAU,MAAM;AAAA,QACjB,CAAA,GAAG,EAAE,QAAQ,MAAM,MAAM,MAAM,aAAa,aAAa,MAAM,KAAI,CAAE;AAAA,MACvE;AAAA,IACF;AAED,UAAM,mBAAmB,IAAI,YAAY,WAAW;AACpD,UAAM,gBAAgBA,iBAA+B,WAAW;AAChE,UAAM,kBAAkB,cAAc,WAAW,cAAc;AAC/D,UAAM,0BAA0B,mBAAmB,cAAc;AACjE,UAAM,wBAAwB,mBAAmB,cAAc;AAC/D,UAAM,qBAAqB,mBAAmB,cAAc;AAE5D,eAAW,SAAS,WAAW,aAAa;AAC1C,UAAI,CAAC,MAAM,YAAa,2BAA2B,MAAM,cAAgB,yBAAyB,CAAC,MAAM,YAAa;AACpH;AAAA,MACD;AACD,UAAI,MAAM,SAAS,aAAa;AAC9B,cAAM,iBAAiB,mBAAmB,CAAC;AAAA,UACzC,MAAM,MAAM,KAAK;AAAA,UACjB,UAAU,MAAM;AAAA,QACjB,CAAA,GAAG,EAAE,QAAQ,MAAM,MAAM,MAAM,aAAa,aAAa,MAAM,KAAI,CAAE;AAAA,MAC9E,OAAa;AACL,cAAM,iBAAiB,kBAAkB,CAAC;AAAA,UACxC,MAAM,MAAM;AAAA,UACZ,UAAU,MAAM;AAAA,QACjB,CAAA,GAAG,EAAE,QAAQ,MAAM,MAAM,MAAM,aAAa,aAAa,MAAM,KAAI,CAAE;AAAA,MACvE;AAAA,IACF;AAED,eAAW,SAAS,WAAW,cAAc;AAC3C,UAAI,CAAC,MAAM;AAAU;AACrB,UAAI,MAAM,SAAS,aAAa;AAC9B,cAAM,iBAAiB,mBAAmB,CAAC;AAAA,UACzC,MAAM,MAAM,KAAK;AAAA,UACjB,UAAU,MAAM;AAAA,QACjB,CAAA,GAAG,EAAE,MAAM,MAAM,KAAM,CAAA;AAAA,MAChC,OAAa;AACL,cAAM,OAAO,MAAM,KAAK,SAAQ;AAChC,YAAI,oBAAoB;AACtB,sBAAY,MAAM,UAAU,MAAM,OAAO,WAAW,IAAI;AAAA,QACzD;AACD,cAAM,iBAAiB,kBAAkB,CAAC;AAAA,UACxC;AAAA,UACA,UAAU,MAAM;AAAA,QACjB,CAAA,GAAG,EAAE,MAAM,MAAM,KAAM,CAAA;AAAA,MACzB;AAAA,IACF;AAED,eAAW,UAAU,WAAW,aAAa;AAC3C,UAAI,CAAC,OAAO;AAAU;AACtB,UAAI,OAAO,SAAS,aAAa;AAC/B,cAAM,iBAAiB,mBAAmB,CAAC;AAAA,UACzC,MAAM,OAAO,KAAK;AAAA,UAClB,UAAU,OAAO;AAAA,QAClB,CAAA,GAAG,EAAE,MAAM,WAAU,CAAE;AAAA,MAChC,OAAa;AACL,cAAM,iBAAiB,kBAAkB,CAAC;AAAA,UACxC,MAAM,OAAO;AAAA,UACb,UAAU,OAAO;AAAA,QAClB,CAAA,GAAG,EAAE,MAAM,WAAU,CAAE;AAAA,MACzB;AAAA,IACF;AAED,UAAM,gBAAgB,kBAAkB;AACxC,UAAM,eAAe,iBAAiB;AAEtC,UAAM,aAAa8B,MAAc,KAAK,MAAM,KAAK,WAAW,cAAc,eAAe,aAAa,cAAc,MAAM;AAC1H,QAAI,eAAe;AAAO,aAAO;AAEjC,UAAM,kBAAkB;AACxB,UAAM,EAAE,YAAY,oBAAoB,MAAM,iBAAiB,OAAM;AAErE,UAAM,eAAe,mBAAmB,eAAe,SAAS,WAAW,MAAM,KAAK,OAAO,YAAY,WAAW,YAAY,iBAAiB,QAAQ,aAAa;AAEtK,WAAO,EAAE,YAAY,iBAAiB;EAEvC;AAEH;AAv4CqB;;;;;;;;;;;;;;;;qDCJiB,IAAI,EAAA,IAAA,gBAAA;;;;AAAtC,aAAiD,QAAA,GAAA,MAAA;AAA1B,aAAsB,GAAA,CAAA;AAAA;;wEAAX,KAAI,EAAA,IAAA,mBAAA;;;;;;;;;;;;;;;;;;AAQtC,aAAsB,QAAA,GAAA,MAAA;oBAAZ,IAAO;AAAA;;;sBAAP,KAAO;AAAA;;;;;;;;;;mBAJV,IAAO;;iCAAZ,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;qBAAC,KAAO;;mCAAZ,QAAI,KAAA,GAAA;;;;;;;;;;;;;wCAAJ;AAAA;;;;;;;;;;;;kBACU,IAAI,KAAA;;;;;;AAAd,aAAmB,QAAA,GAAA,MAAA;;;;kDAAT,KAAI,KAAA;AAAA,UAAA,YAAA;AAAA;;;;;;;;;;;;;;;;kBANb,IAAI,MAAAjC,oBAAA,GAAA;;;;;kBAIJ,MAAM,QAAQ,KAAO,EAAA;;;;;;;;;;;;;;;;gBADC,IAAM,EAAA;;;;;;;AALnC,aAcM,QAAA,KAAA,MAAA;;;;AATJ,aAA+C,KAAA,CAAA;AAA7B,aAAyB,GAAA,MAAA;;;;;;UAHtC,KAAI,IAAA;;;;;;;;;;;;;qBAGkB,KAAM,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;QAdtB,SAAI;QACJ,WAAM;QACN,YAAO;QACP,QAAG;QACH,OAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC4EJ,QAAA,cAAA,GAAA,SAAS,mCAAmC;AAAA;;AAAjD,aAAwD,QAAA,GAAA,MAAA;AAAA;;;;;;;;;;;;kBA1BjD,IAAK,GAAC,KAAK,OAAG6B,oBAAA,GAAA;;QAId,KAAc;AAAA,aAAArB;;;;;;;;;;;;;;;;AALrB,aAyBM,QAAA,KAAA,MAAA;;;;;;;UAxBC,KAAK,GAAC,KAAK,KAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDACN,IAAK,GAAC,KAAK,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;;;AAAzB,aAA4B,QAAA,KAAA,MAAA;AAAA;;+DAAjB,KAAK,GAAC,KAAK,GAAG,GAAA;;;;;;;;;;;;;AAoBjB,MAAA,UAAA,OAAM,OAAI;;;;;;;;;AAAlB,aAA2B,QAAA,MAAA,MAAA;;;;AAAnB,UAAA,QAAA,KAAA,YAAA,WAAA,QAAM,OAAI;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;QAfX,KAAa;AAAA,aAAAQ;;;;;;;;;;;;;AADpB,aAcO,QAAA,MAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;AAF4C,MAAA,UAAA,OAAM,OAAI;;;;;;;;;;;AADzD,aAC+D,QAAA,GAAA,MAAA;;;;;;;;AAAhB,UAAA,QAAA,KAAA,YAAA,WAAA,QAAM,OAAI;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;;;;;mBANhD,IAAM;AAAoB,QAAA,UAAA,iCAAA,SAAe,IAAf;iCAA/B,QAAI,KAAA,GAAA;;;;;;;;;;;;UAHY,IAAK,OAAA;AAAA,4BAAA,MAAA,IAAA,IAAA,KAAA,MAAA,CAAA;AAAA;;AADzB,aAOS,QAAA,QAAA,MAAA;;;;4BANW,IAAK,EAAA;;;;;;;;;;;qBAGhB,KAAM;;;;8BAHK,KAAK,EAAA;AAAA;;;;;;;;;;;;;;;;AAIY,MAAA,UAAA,QAAe,OAAI;;;;;;;;;4CAAtC,IAAc;;;;;AAA9B,aAAiE,QAAA,QAAA,MAAA;;;;;AAA9B,UAAA,QAAA,KAAA,YAAA,WAAA,QAAe,OAAI;AAAA,iBAAA,GAAA,OAAA;oEAAtC,IAAc,MAAA;;;;;;;;;;;;;;;;;AAqBrC,MAAA,WAAA,SAAS,mCAAmC,IAAA;;;;;;;;;;;;;;;;AAHjD,aAKM,QAAA,KAAA,MAAA;AAJJ,aAGS,KAAA,MAAA;AAFP,aAA6B,QAAA,CAAA;;;;0CADC,IAAyB,EAAA;;;;;;;;;;;;;;;;;;;;;QAjCtD,KAAK;AAAA,aAAAhB;;;;;;kBA+BP,IAAyB,MAAAC,kBAAA,GAAA;;;;;;;;;;AAtCO,mBAAA,MAAA,4BAAA,SAAU,CAAC;;;;AAFlD,aAgDM,QAAA,MAAA,MAAA;AA/CJ,aAsCM,MAAA,IAAA;;;;;;;oCApCa,cAAc;AAAA,+BACnB,IAAQ,EAAA;AAAA,mCACJ,cAAc;AAAA,oCACb,IAAS,EAAA;AAAA,oCACT,IAAS,EAAA;AAAA;;;;;;;;;;;;;;;;AALS,qBAAA,MAAA,4BAAA,UAAU,CAAC;AAAA;UAsC3C,KAAyB;AAAA,kBAAA,EAAA,MAAA,KAAA;AAAA;;;;;;;;;;;;;;;AA/CrB,wBAAe,OAAK;AAC3B,QAAM,eAAc;;AADb;;QAlCE,UAAK;QACL,WAAM;AAEb,MAAA,gBAAgB;MAChB,iBAAiB,OAAO,SAAS,KAAC,CAAK,KAAK,KAAK;AACjD,MAAA,4BAA4B,OAAO,OAAO,OAAM,CAAA,EAAE,KAAK,MAAM,SAAS,EAAE,SAAS;uCAEnD;AAC5B,QAAA,OAAO,OAAO,WAAW,WAAW;AAAC;oBACzC,QAAQ,OAAO,OAAO,WAAW,GAAG,KAAK;AAAA;AAFlC;AAKA,oBAAS,OAAK;AACrB,iBAAA,GAAA,UAAU,CAAC;QACP;;AAEF,aAAO,KAAK,MAAM,MAAM,aAAa,QAAQ,YAAY,CAAA;AAAA,aAClD;aACA;AAAA;QAEL,KAAK,SAAS;AAAO;oBACzB,QAAQ,KAAK,OAAO,IAAI,KAAK,EAAE,CAAA;AAAA;AATxB;AAYL,MAAA,UAAU;uBAEI;oBAChB,WAAO,OAAA;AAAA;AADA;uBAIS;oBAChB,WAAO,OAAA;AAAA;AADA;;AA8BuB,YAAK,aAAA,IAAA;;;;;;AACE,iBAAA,GAAA,gBAAgB,KAAK;AAAA;;AAQ3B,iBAAA,GAAA,gBAAgB,IAAI;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACrBV,MAAA,UAAA,QAAc,OAAI;;;;;;;;;4CAAnC,IAAa;;;;;AAA7B,aAA6D,QAAA,QAAA,MAAA;;;;;AAA5B,UAAA,QAAA,KAAA,YAAA,WAAA,QAAc,OAAI;AAAA,iBAAA,GAAA,OAAA;oEAAnC,IAAa,MAAA;;;;;;;;;;;;;;;;;AAkB/B,QAAA,cAAA,GAAA,SAAS,mCAAmC;AAAA;;AAAhD,aAAsD,QAAA,GAAA,MAAA;AAAA;;;;;;;;;;;;;;AAFlD,QAAA,cAAA,GAAA,SAAS,qCAAqC;AAAA;;AAAlD,aAAwD,QAAA,GAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASxB,MAAA,YAAA,SAAS,+BAA+B,IAAA;;;;;;mBA1B7D,IAAK;AAAmB,QAAA,UAAA,iCAAA,SAAc,IAAd;iCAA7B,QAAI,KAAA,GAAA;;;;;;QAgBP,KAAK;AAAA,aAAAA;;;;;;;;;;;MAMmB,IAAK,OAAA,QAAA;kCAAL,IAAK;AAAA;;;;;;;;;;;AA/B7B,aAAA,cAAA,GAAA,SAAS,+BAA+B;;;AAIzC,SAAA,cAAA,GAAA,SAAS,8BAA8B;;;;;;;;;;;;;;;AAe9B,WAAA,cAAA,GAAA,SAAS,0BAA0B;;;AAEpC,YAAA,cAAA,GAAA,SAAS,qCAAqC;;;;;;;;;;;;;;;UAbF,IAAI,OAAA;AAAA,4BAAA,MAAA,IAAA,GAAA,KAAA,MAAA,CAAA;;;;;;;;;;iDA0BI,IAAK;;;;;;AAxCvE,aA6CM,QAAA,MAAA,MAAA;AA3CJ,aAA8D,MAAA,EAAA;;AAE9D,aAII,MAAA,EAAA;AAHF,aAES,IAAA,MAAA;;AAGX,aAAiD,MAAA,EAAA;;AAEjD,aAQM,MAAA,IAAA;AAPJ,aAMM,MAAA,IAAA;AALJ,aAIS,MAAA,MAAA;;;;4BAJ2C,IAAI,EAAA;;AAO5D,aAQM,MAAA,IAAA;AAPJ,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,KAAA;AAFN,aAA+D,OAAA,KAAA;sBAAX,IAAS;;AAC7D,aAAmD,OAAA,IAAA;;AAErD,aAAgE,MAAA,KAAA;;;;;;AAYpE,aAIS,MAAA,MAAA;AAHP,aAES,QAAA,MAAA;AADP,aAA4B,QAAA,EAAA;;;;;;;;kCADO,IAAY,IAAA,EAAA,MAAA,MAAA;AAAA;;;;;;qBAzBtC,KAAK;;;;8BADsC,KAAI,EAAA;AAAA;;wBAUF,KAAS;AAAA;;;;;;;;;;;;;;;;wCAatC,KAAK;;;;wFAG8B,KAAK,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UArE/D,gBAAgB,WAAW,UAAU;QAElC,gBAAW;QACX,cAAS;QACT,UAAK;QACL,SAAI;QACJ,WAAM;QACN,UAAK;AAEZ,MAAA,OAAO,KAAK,KAAK;AAErB,UAAQ,KAAK,MAAM,OAAO,WAAQ,MAAK,UAAU,UAAS,KAAK,IAAI;AACnE,SAAO,QAAQ,QAAQ,MAAM;AAC7B,WAAS,UAAU,KAAK,OAAO,OAAO,YAAS,OAAM,OAAO;AAC5D,UAAQ,SAAS,KAAK,KAAK,aAAS,EAAM,OAAO,SAAS,KAAK;0BAE1C;AACnB,gBAAY,QAAQ,UAClB,MACA,OACA,UAAS,CAAA;AAEX,gBAAY,MAAK;AAAA;AANV;;AA2BiD,WAAI,aAAA,IAAA;;;;;;AAUF,gBAAS,KAAA;;;;;AAatC,YAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACrEtC,iBAAiB,KAAK;AAClB,SAAO,OAAO,UAAU,SAAS,KAAK,GAAG,MAAM;AACnD;AAFS;AA+GT,0BAA0B,GAAG,GAAG;AAC5B,MAAI,MAAM,KAAK,MAAM;AACjB,WAAO,MAAM;AACjB,QAAM,OAAO,OAAO;AACpB,MAAI,SAAS,OAAO,KAAK,MAAM,QAAQ,CAAC,MAAM,MAAM,QAAQ,CAAC,GAAG;AAC5D,UAAM,IAAI,MAAM,6CAA6C;AAAA,EAChE;AACD,MAAI,MAAM,QAAQ,CAAC,GAAG;AAClB,UAAM,MAAM,EAAE,IAAI,CAAC,IAAI,MAAM;AACzB,aAAO,iBAAiB,EAAE,IAAI,EAAE;AAAA,IAC5C,CAAS;AACD,WAAO,OAAK,IAAI,IAAI,QAAM,GAAG,CAAC,CAAC;AAAA,EAClC;AACD,MAAI,SAAS,UAAU;AACnB,QAAI,CAAC,KAAK,CAAC;AACP,YAAM,IAAI,MAAM,uBAAuB;AAC3C,QAAI,QAAQ,CAAC,KAAK,QAAQ,CAAC,GAAG;AAC1B,UAAI,EAAE;AACN,UAAI,EAAE;AACN,YAAM,QAAQ,IAAI;AAClB,aAAO,OAAK,IAAI,KAAK,IAAI,IAAI,KAAK;AAAA,IACrC;AACD,UAAM,OAAO,OAAO,KAAK,CAAC;AAC1B,UAAM,gBAAgB,CAAA;AACtB,SAAK,QAAQ,SAAO;AAChB,oBAAc,OAAO,iBAAiB,EAAE,MAAM,EAAE,IAAI;AAAA,IAChE,CAAS;AACD,WAAO,OAAK;AACR,YAAM,SAAS,CAAA;AACf,WAAK,QAAQ,SAAO;AAChB,eAAO,OAAO,cAAc,KAAK,CAAC;AAAA,MAClD,CAAa;AACD,aAAO;AAAA,IACnB;AAAA,EACK;AACD,MAAI,SAAS,UAAU;AACnB,UAAM,QAAQ,IAAI;AAClB,WAAO,OAAK,IAAI,IAAI;AAAA,EACvB;AACD,QAAM,IAAI,MAAM,sBAAsB,aAAa;AACvD;AAxCS;AAyCT,iBAAiB,OAAO,WAAW,IAAI;AACnC,QAAM,QAAQ,SAAS,KAAK;AAC5B,MAAI;AACJ,MAAI,eAAe;AACnB,eAAa,WAAW,MAAM;AAC1B,QAAI,SAAS,MAAM;AACf,YAAM,IAAI,QAAQ,SAAS;AAC3B,aAAO,QAAQ;IAClB;AACD,mBAAe;AACf,QAAI,gBAAgB;AACpB,QAAI,UAAU;AACd,QAAI,EAAE,QAAQ,GAAG,WAAW,KAAK,SAASZ,UAAQ,cAAc,qBAAqB,OAAO,OAAO,CAAE,GAAE,QAAQ,GAAG,IAAI;AACtH,QAAI,aAAa,GAAG;AAChB,UAAI,eAAe;AACf,sBAAc,MAAK;AACnB,wBAAgB;AAAA,MACnB;AACD,YAAM,IAAI,QAAQ,YAAY;AAC9B,aAAO,QAAQ;IAClB;AACD,UAAM,QAAQ,IAAK,IAAG;AACtB,QAAI;AACJ,WAAON,OAAK,UAAO;AACf,UAAI,OAAM;AACN,eAAO;AACX,UAAI,CAAC,SAAS;AACV,aAAK,YAAY,OAAO,SAAS;AACjC,YAAI,OAAO,aAAa;AACpB,qBAAW,SAAS,OAAO,SAAS;AACxC,kBAAU;AAAA,MACb;AACD,UAAI,eAAe;AACf,sBAAc,MAAK;AACnB,wBAAgB;AAAA,MACnB;AACD,YAAM,UAAU,OAAM;AACtB,UAAI,UAAU,UAAU;AACpB,cAAM,IAAI,QAAQ,SAAS;AAC3B,eAAO;AAAA,MACV;AAED,YAAM,IAAI,QAAQ,GAAG,OAAO,UAAU,QAAQ,CAAC,CAAC;AAChD,aAAO;AAAA,IACnB,CAAS;AACD,WAAO,KAAK;AAAA,EACf;AA1CQ;AA2CT,SAAO;AAAA,IACH;AAAA,IACA,QAAQ,CAAC,IAAI,SAAS,IAAI,GAAG,cAAc,KAAK,GAAG,IAAI;AAAA,IACvD,WAAW,MAAM;AAAA,EACzB;AACA;AApDS;;;;ACtDG,MAAA,UAAA,SAAS,oCAAkC;AAAA,IAC7C,mBAAmB,IAAW,GAAC;AAAA,IAC/B,oBAAoB,IAAY,GAAC;AAAA;;;;;;;;AAFnC,aAGO,QAAA,GAAA,MAAA;;;;AAHH,UAAA,QAAA,MAAA,YAAA,WAAA,SAAS,oCAAkC;AAAA,QAC7C,mBAAmB,KAAW,GAAC;AAAA,QAC/B,oBAAoB,KAAY,GAAC;AAAA;;;;;;;;;;;;AAPzB,MAAA,YAAA,SAAS,2CAAyC;AAAA,IAC1D,mBAAmB,IAAW,GAAC;AAAA,IAC/B,oBAAoB,IAAY,GAAC;AAAA;;;;;;AAFnC,aAGO,QAAA,GAAA,MAAA;;;;AAHG,UAAA,QAAA,MAAA,cAAA,aAAA,SAAS,2CAAyC;AAAA,QAC1D,mBAAmB,KAAW,GAAC;AAAA,QAC/B,oBAAoB,KAAY,GAAC;AAAA;;;;;;;;;;;;;;;AAcjC,QAAA,cAAA,GAAA,SAAS,mCAAmC;AAAA;;AAAhD,aAAsD,QAAA,GAAA,MAAA;AAAA;;;;;;;;;;;;;;AAFlD,QAAA,cAAA,GAAA,SAAS,qCAAqC;AAAA;;AAAlD,aAAwD,QAAA,GAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASxB,MAAA,WAAA,SAAS,yBAAyB,IAAA;;;;;;;AAGlC,MAAA,YAAA,SAAS,0BAA0B,IAAA;;;;;;AAG3B,MAAA,YAAA,SAAS,uBAAuB,IAAA;;;;;;;;;QA9BnE,KAAS;AAAA,aAAAiB;;;;;;;QAcX,KAAK;AAAA,aAAAC;;;;;;;;;;;MAMmB,IAAK,OAAA,QAAA;kCAAL,IAAK;AAAA;;;;;;;;;;;AAzB5B,aAAA,cAAA,GAAA,SAAS,gCAAgC;;;;;;AAgBzC,SAAA,cAAA,GAAA,SAAS,sCAAsC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mDAYK,IAAK;;;;;;;;;;+BAYnB,IAAc,KAAA,GAAA;;;AADa,mBAAA,MAAA,UAAA,SAAiB,CAAC;;;;AA7C3F,aAgDM,QAAA,MAAA,MAAA;AA9CJ,aAA8D,MAAA,EAAA;;AAE9D,aAII,MAAA,EAAA;AAHF,aAES,IAAA,MAAA;;AAGX,aAaM,MAAA,IAAA;;;AADJ,aAAyD,MAAA,EAAA;;;;;;AAW3D,aAUS,MAAA,MAAA;AATP,aAES,QAAA,OAAA;AADP,aAA4B,SAAA,EAAA;;;;AAE9B,aAES,QAAA,OAAA;AADP,aAA4B,SAAA,EAAA;;;;AAE9B,aAES,QAAA,OAAA;AADP,aAAoC,SAAA,EAAA;;;;AAIxC,aAEM,MAAA,IAAA;AADJ,aAAoE,MAAA,IAAA;;;;mCAZ/B,IAAM,IAAA,EAAA,MAAA,MAAA;AAAA,mCAGN,IAAO,IAAA,EAAA,MAAA,MAAA;AAAA,mCAGP,IAAI,IAAA,EAAA,MAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCATd,KAAK;;;;yFAGwB,KAAK,KAAA;;;;iCAYnB,KAAc,KAAA,GAAA;AAAA;;AADa,qBAAA,MAAA,UAAA,UAAiB,CAAC;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAxHnF,gBAAgB,WAAW,UAAU;QAElC,gBAAW;QACX,cAAS;QACT,iBAAY;QACZ,gBAAW;QACX,UAAK;QACL,SAAI;QACJ,WAAM;QACN,UAAK;AAEZ,MAAA,OAAO,KAAK,KAAK;AAErB,UAAQ,KAAK,MAAM,OAAO,WAAQ,MAAK,UAAU,UAAS,KAAK,IAAI;AACnE,SAAO,QAAQ,QAAQ,MAAM;AAC7B,WAAS,UAAU,KAAK,OAAO,OAAO,YAAS,OAAM,OAAO;AAC5D,UAAQ,SAAS,KAAK,KAAK,aAAS,EAAM,OAAO,SAAS,KAAK;AAE3D,MAAA,OAAO;0BAEU;AACnB,gBAAY,QAAQ,QAAQ,KAAK;AACjC;;AAFa;2BAKO;AACpB,gBAAY,QAAQ,QAAQ,KAAK;AACjC;;AAFa;wBAKI;AACjB,gBAAY,QAAQ,QAAQ,MAAM;AAClC;;AAFa;gCAKY;AACzByD,mBAAuB,KAAK,KAAK,SAAS,+BAA+B,GAAG,IAAI;AAChF;;AAFa;QAKT,WAAW,QAAQ,GAAC,EACxB,UAAU,KACV,QAAQrE,SAAM,CAAA;;AAKZ,MAAA,UAAU;QACR;AAAI;AACR,aAAS,IAAI,CAAC;AACd,cAAU;UACJ;AAAI;AACRqE,qBAAuB,SAAS,8BAA8B,GAAG,IAAI;AACrE;OACC;KACF;AAEG,QAAA,aAAa;UACX,QAAO,KAAK,MAAM,IAAI,YAAY,EAAE;AACrC,QAAA,CAAA,MAAK,QAAM;AACd;;KAED;mBAEW;AACZ,kBAAc,UAAU;AACxB,iBAAa,OAAO;AACpB,WAAO;AACP,gBAAY,MAAK;AAAA;AAJV;;AA0CsB,YAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA7DjC,mBAAA,GAAA,iBAAiB,YAAY,GAAG;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACnD9B,MAAM,0BAA0B,kBAAkB;AAAA,EAEvD,YAAY,cAAc,UAAU,IAAI;AACtC,UAAM;AAAA,MACJ,QAAQ;AAAA,QACN,OAAOkB;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL,GAAG;AAAA,QACJ;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,UAAU,IAAI;AAAA,MACxC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO,KAAK,KAAK,SAAS,wBAAwB;AAAA,MAClD,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,QAAQ;AAAA,IACxB,CAAK;AAAA,EACF;AAAA,EAED,OAAO,KAAK,cAAc,UAAU,CAAA,GAAI,aAAa,CAAA,GAAI;AACvD,WAAO,IAAI,QAAQ,aAAW;AAC5B,cAAQ,UAAU;AAClB,UAAI,KAAK,cAAc,SAAS,UAAU,EAAE,OAAO,IAAI;AAAA,IAC7D,CAAK;AAAA,EACF;AACH;AA/Ba;AAiCN,MAAM,2BAA2B,kBAAkB;AAAA,EAExD,YAAY,cAAc,UAAU,IAAI;AAEtC,UAAM;AAAA,MACJ,QAAQ;AAAA,QACN,OAAOC;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL,GAAG;AAAA,QACJ;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,UAAU,IAAI;AAAA,MACxC,GAAG;AAAA,IACT,CAAK;AACD,SAAK,UAAU,aAAa;AAAA,EAC7B;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO,KAAK,KAAK,SAAS,wBAAwB;AAAA,MAClD,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,QAAQ;AAAA,IACxB,CAAK;AAAA,EACF;AAAA,EAED,OAAO,KAAK,cAAc,UAAU,IAAI;AACtC,WAAO,IAAI,QAAQ,aAAW;AAC5B,cAAQ,UAAU;AAClB,UAAI,KAAK,cAAc,OAAO,EAAE,OAAO,IAAI;AAAA,IACjD,CAAK;AAAA,EACF;AAAA,EAED,OAAO,OAAO,SAAS;AACrB,eAAW,OAAO,OAAO,OAAO,GAAG,OAAO,GAAG;AAC3C,UAAI,eAAe,QAAQ,IAAI,YAAY,SAAS;AAClD,YAAI,QAAQ,QAAQ,EAAE,MAAM,YAAa,CAAA;AACzC,eAAO,IAAI;MACZ;AAAA,IACF;AACD,WAAO;AAAA,EACR;AAEH;AA5Ca;AClCE,MAAM,WAAW;AAAA,EAE9B,YAAY,YAAY,aAAa,eAAe,iBAAiB,OAAO,YAAY,OAAO;AAE7F,SAAK,gBAAgB;AACrB,SAAK,iBAAiB;AACtB,SAAK,YAAY;AAEjB,SAAK,iBAAiB,WAAW;AACjC,SAAK,kBAAkB,WAAW;AAClC,SAAK,kBAAkB,SAAS,WAAW,SAAS,CAAE,CAAA;AACtD,SAAK,uBAAuB,SAAS,WAAW,cAAc,CAAE,CAAA;AAChE,SAAK,2BAA2B,SAAS,WAAW,kBAAkB,CAAE,CAAA;AACxE,SAAK,qBAAqB,SAAS,WAAW,YAAY,KAAK;AAE/D,SAAK,kBAAkB,YAAY;AACnC,SAAK,mBAAmB,YAAY;AACpC,SAAK,mBAAmB,SAAS,YAAY,SAAS,CAAE,CAAA;AACxD,SAAK,wBAAwB,SAAS,YAAY,cAAc,CAAE,CAAA;AAClE,SAAK,4BAA4B,SAAS,YAAY,kBAAkB,CAAE,CAAA;AAC1E,SAAK,sBAAsB,SAAS,aAAa,YAAY,KAAK;AAAA,EAEnE;AAAA,EAED,OAAO,OAAO,gBAAgB,iBAAiB,eAAe;AAE5D,UAAM,aAAa;AAAA,MACjB,MAAM,KAAK,MAAM,IAAI,eAAe,IAAI;AAAA,MACxC,OAAOpG,aAAuB,eAAe,SAAS;AAAA,MACtD,OAAO,eAAe;AAAA,MACtB,YAAY,eAAe;AAAA,MAC3B,gBAAgB,eAAe;AAAA,MAC/B,UAAU,eAAe;AAAA,IAC/B;AAEI,UAAM,cAAc;AAAA,MAClB,MAAM,KAAK,MAAM,IAAI,gBAAgB,IAAI;AAAA,MACzC,OAAOA,aAAuB,gBAAgB,SAAS;AAAA,MACvD,OAAO,gBAAgB;AAAA,MACvB,YAAY,gBAAgB;AAAA,MAC5B,gBAAgB,gBAAgB;AAAA,MAChC,UAAU,gBAAgB;AAAA,IAChC;AAEI,WAAO,IAAI,KAAK,YAAY,aAAa,aAAa;AAAA,EACvD;AAAA,EAED,SAAS;AACP,WAAO,CAAC;AAAA,MACN,QAAQ,KAAK,eAAe;AAAA,MAC5B,WAAWI,QAAkB,KAAK,eAAe;AAAA,MACjD,OAAOG,gBAAI,KAAK,eAAe;AAAA,MAC/B,YAAYA,gBAAI,KAAK,oBAAoB;AAAA,MACzC,gBAAgBA,gBAAI,KAAK,wBAAwB;AAAA,MACjD,UAAUA,gBAAI,KAAK,kBAAkB;AAAA,IAC3C,GAAO;AAAA,MACD,QAAQ,KAAK,gBAAgB;AAAA,MAC7B,WAAWH,QAAkB,KAAK,gBAAgB;AAAA,MAClD,OAAOG,gBAAI,KAAK,gBAAgB;AAAA,MAChC,YAAYA,gBAAI,KAAK,qBAAqB;AAAA,MAC1C,gBAAgBA,gBAAI,KAAK,yBAAyB;AAAA,MAClD,UAAUA,gBAAI,KAAK,mBAAmB;AAAA,IAC5C,GAAO,KAAK,aAAa;AAAA,EACtB;AAAA,EAED,eAAe;AACb,WAAO;AAAA,MACL,aAAa,KAAK;AAAA,MAClB,aAAa,KAAK;AAAA,MAClB,QAAQ;AAAA,QACN,OAAOA,gBAAI,KAAK,eAAe,EAAE,OAAOA,gBAAI,KAAK,wBAAwB,CAAC;AAAA,QAC1E,YAAYA,gBAAI,KAAK,oBAAoB;AAAA,MAC1C;AAAA,MAAE,KAAK;AAAA,QACN,OAAOA,gBAAI,KAAK,gBAAgB,EAAE,OAAOA,gBAAI,KAAK,yBAAyB,CAAC;AAAA,QAC5E,YAAYA,gBAAI,KAAK,qBAAqB;AAAA,MAC3C;AAAA,IACP;AAAA,EACG;AAAA,EAED,wBAAwB;AACtB,WAAO,CAAC,GAAGA,gBAAI,KAAK,oBAAoB,GAAG,GAAGA,gBAAI,KAAK,wBAAwB,CAAC;AAAA,EACjF;AAAA,EAED,IAAI,kBAAkB;AACpB,WAAOA,gBAAI,KAAK,kBAAkB,KAAKA,gBAAI,KAAK,mBAAmB;AAAA,EACpE;AAAA,EAED,MAAM,iBAAiB;AACrB,SAAK,mBAAmB,IAAI,CAACA,gBAAI,KAAK,kBAAkB,CAAC;AAAA,EAC1D;AAAA,EAED,YAAY,QAAQ,SAAS;AAC3B,QAAI,WAAW,KAAK,KAAK;AAAI;AAC7B,SAAK,mBAAmB,IAAI,KAAK;AACjC,SAAK,oBAAoB,IAAI,KAAK;AAClC,QAAI,WAAW,KAAK,eAAe,IAAI;AACrC,WAAK,gBAAgB,IAAI,OAAO;AAAA,IACjC;AACD,QAAI,WAAW,KAAK,gBAAgB,IAAI;AACtC,WAAK,iBAAiB,IAAI,OAAO;AAAA,IAClC;AAAA,EACF;AAAA,EAED,qBAAqB,QAAQ,gBAAgB;AAC3C,QAAI,WAAW,KAAK,KAAK;AAAI;AAC7B,SAAK,mBAAmB,IAAI,KAAK;AACjC,SAAK,oBAAoB,IAAI,KAAK;AAClC,QAAI,WAAW,KAAK,eAAe,IAAI;AACrC,WAAK,yBAAyB,IAAI,cAAc;AAAA,IACjD;AACD,QAAI,WAAW,KAAK,gBAAgB,IAAI;AACtC,WAAK,0BAA0B,IAAI,cAAc;AAAA,IAClD;AAAA,EACF;AAAA,EAED,iBAAiB,QAAQ,cAAc;AACrC,QAAI,WAAW,KAAK,KAAK;AAAI;AAC7B,SAAK,mBAAmB,IAAI,KAAK;AACjC,SAAK,oBAAoB,IAAI,KAAK;AAClC,QAAI,WAAW,KAAK,eAAe,IAAI;AACrC,WAAK,qBAAqB,IAAI,YAAY;AAAA,IAC3C;AACD,QAAI,WAAW,KAAK,gBAAgB,IAAI;AACtC,WAAK,sBAAsB,IAAI,YAAY;AAAA,IAC5C;AAAA,EACF;AAAA,EAED,oBAAoB,QAAQ,OAAO;AACjC,QAAI,WAAW,KAAK,KAAK;AAAI;AAC7B,QAAI,WAAW,KAAK,eAAe,IAAI;AACrC,WAAK,mBAAmB,IAAI,KAAK;AAAA,IAClC;AACD,QAAI,WAAW,KAAK,gBAAgB,IAAI;AACtC,WAAK,oBAAoB,IAAI,KAAK;AAAA,IACnC;AAAA,EACF;AAAA,EAED,QAAQ,SAAS,EAAE,WAAW,OAAO,WAAW,UAAU,IAAI;AAE5D,UAAM,QAAQ,CAAC,WAAWA,gBAAI,KAAK,eAAe,IAAIA,gBAAI,KAAK,wBAAwB;AAEvF,UAAM,OAAOL,gBAA0B,OAAO,OAAO;AAErD,UAAM,cAAc,KAAK,KAAK,OAAO,WAAWC,gBAA0B,OAAO;AAEjF,QAAI,CAAC,MAAM;AACT,YAAM,KAAK;AAAA,QACT,IAAI,QAAQ;AAAA,QACZ,MAAM,QAAQ;AAAA,QACd,KAAK,SAAS,OAAO;AAAA,QACrB;AAAA,QACA,UAAU,WAAW,WAAW;AAAA,QAChC,aAAa,WAAW,WAAW;AAAA,QACnC;AAAA,QACA,MAAM;AAAA,MACd,CAAO;AAAA,IACP,OAAW;AACL,UAAI,KAAK,YAAY;AAAa;AAClC,WAAK,WAAW,KAAK,IAAI,WAAW,WAAW,KAAK,WAAW,GAAG,WAAW;AAC7E,WAAK,cAAc,KAAK;AACxB,WAAK,cAAc;AAAA,IACpB;AAED,QAAI,CAAC,UAAU;AACb,WAAK,gBAAgB,IAAI,KAAK;AAAA,IACpC,OAAW;AACL,WAAK,yBAAyB,IAAI,KAAK;AAAA,IACxC;AAAA,EAEF;AAAA,EAED,aAAa,aAAa;AAExB,UAAM,aAAaI,gBAAI,KAAK,oBAAoB;AAEhD,UAAM,mBAAmB,WAAW,KAAK,cAAY,SAAS,SAAS,YAAY,IAAI;AAEvF,QAAI,kBAAkB;AACpB,uBAAiB,WAAW,YAAY;AACxC,uBAAiB,cAAc,YAAY;AAAA,IACjD,OAAW;AACL,iBAAW,KAAK,WAAW;AAAA,IAC5B;AAED,eAAW,KAAK,CAAC,GAAG,MAAM,EAAE,QAAQ,EAAE,KAAK;AAE3C,SAAK,qBAAqB,IAAI,UAAU;AAAA,EAEzC;AAAA,EAED,YAAY,OAAO;AAEjB,QAAI,MAAM,IAAI;AAEZ,UAAI,CAAC,MAAM,UAAU;AAEnB,cAAM,QAAQA,gBAAI,KAAK,eAAe,EACnC,OAAO,UAAQ,KAAK,OAAO,MAAM,EAAE;AAEtC,aAAK,gBAAgB,IAAI,KAAK;AAAA,MAEtC,OAAa;AAEL,cAAM,QAAQA,gBAAI,KAAK,wBAAwB,EAC5C,OAAO,UAAQ,KAAK,OAAO,MAAM,EAAE;AAEtC,aAAK,yBAAyB,IAAI,KAAK;AAAA,MAExC;AAAA,IAEP,OAAW;AAEL,YAAM,QAAQA,gBAAI,KAAK,oBAAoB,EACxC,OAAO,cAAY,SAAS,SAAS,MAAM,IAAI;AAElD,WAAK,qBAAqB,IAAI,KAAK;AAAA,IAEpC;AAAA,EAEF;AAEH;AA7NqB;;;;;;;;;;;;;;;;ACwCjB,aAIM,QAAA,KAAA,MAAA;AAHJ,aAEI,KAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgBJ,aAEI,QAAA,GAAA,MAAA;;qCAFyE,IAAc,EAAA;;;;;;;;;;;;;;;;AA0B9B,MAAA,UAAA,OAAK,WAAQ;;;;;;;;;;AAA1E,aAAkF,QAAA,MAAA,MAAA;;;;AAArB,UAAA,QAAA,KAAA,YAAA,WAAA,QAAK,WAAQ;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;AAjBnE,QAAA,QAAK;AAAO,aAAAgB;;;;;;;;;;;;;AADnB,aAgBM,QAAA,KAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;AAHG,MAAA,UAAA,OAAK,WAAQ;;;;;;;;;;;AAFhB,aAGO,QAAA,MAAA,MAAA;;;;;;;;AADJ,UAAA,QAAA,KAAA,YAAA,WAAA,QAAK,WAAQ;AAAA,iBAAA,GAAA,OAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;AAXlB,aAOM,QAAA,KAAA,MAAA;AANJ,aAKE,KAAA,KAAA;AAFc,sBAAA,OAAA,OAAK,WAAW;;;;mCAChB,IAAS,EAAA;AAAA;;;;;AADT,UAAA,QAAA,KAAA,UAAA,MAAA,KAAA,MAAA,QAAK,aAAW;AAAhB,wBAAA,OAAA,QAAK,WAAW;AAAA;;;;;;;;;;;;;;;;;;;;;AApBoC,MAAA,WAAA,OAAK,OAAI;;;;;;;;kBAdlF,IAAQ,MAAAgB,oBAAA,GAAA;AAmBN,MAAA,YAAA,OAAK,WAAOR,oBAAA,GAAA;;QAQZ,KAAQ;AAAA,aAAAP;;;;;;;;;;;;;;;;;;;;;;;;;;;AAlBqB,UAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,OAAK,GAAG;AAAA,aAAA,KAAA,OAAA,aAAA;;mDAKH,IAAU,EAAA;;;;;;0DAYqB,IAAQ,EAAA;;;;AA5BlF,aAmDK,QAAA,MAAA,MAAA;;;;AAzCH,aAEM,MAAA,IAAA;AADJ,aAA8C,MAAA,GAAA;;AAGhD,aAIM,MAAA,IAAA;AAHJ,aAEM,MAAA,IAAA;AADJ,aAAwF,MAAA,CAAA;;;AAI5F,aAMM,MAAA,IAAA;;;;AAEN,aAsBM,MAAA,IAAA;;;qCAlC0D,IAAW,EAAA;;;;;UAdtE,KAAQ,IAAA;;;;;;;;;;;;AASuB,UAAA,QAAA,KAAA,CAAA,cAAA,IAAA,KAAA,gBAAA,QAAK,GAAG,GAAA;;;AAKkC,UAAA,QAAA,KAAA,aAAA,YAAA,QAAK,OAAI;AAAA,iBAAA,IAAA,QAAA;AAKhF,UAAA,QAAK,SAAO;;;;;;;;;;;;;;;;;;;;;;;4DAOqD,KAAQ,EAAA;AAAA;;;;;;;;;;;;;;;;;;;QA/DrE,UAAK;QACL,SAAI;AACJ,MAAA,EAAA,WAAW,SAAI;AAEpB,QAAA,aAAa,KAAK,MAAOvB,YAAmB,SAAS,sBAAsB,KAAK;yBAElE;SACb,cAAU,CAAK,KAAK;AAAE;UACrB,OAAO,MAAM,gBAAgB,MAAM,IAAI,KAAK,EAAE,KAAK,MAAM,iBAAiB,MAAM,IAAI,KAAK,EAAE;SAC5F;AAAI;AACL,QAAA,KAAK,KAAK,QAAQ,KAAK,KAAK,WAAW,KAAK,KAAK,QAAQ,GAAC;AACrD,aAAA,KAAK,MAAM,OAAO,IAAI;AAAA;UAEzB,MAAM,KAAK;AACX,UAAA,YAAY,IAAI,MAAQ,EAAA,UAAU,MAAK,CAAA;WACtC,MAAM,QAAQ,IAAI;AAAA;AATlB;AAYA,qBAAU,GAAC;QACd,EAAE,YAAY,IAAE;AAClB;;;AAFK;4BAMc;AACrB,iBAAA,GAAA,KAAK,WAAW,KAAK,IAAI,GAAG,KAAK,IAAI,KAAK,aAAa,KAAK,WAAW,CAAA,GAAA,IAAA;QACnE,KAAK,aAAa,GAAC;aACd,MAAM,YAAY,IAAI;AAAA;AAE/B,iBAAA,GAAA,KAAK,cAAc,KAAK,UAAQ,IAAA;oBAChC,KAAK,UAAU,OAAK,IAAA;AAAA;AANb;;AAeiD,UAAM,YAAY,IAAI;AAAA;;AAgCtD,SAAK,cAAW,UAAA,KAAA,KAAA;;;;;oBAMN,KAAK,UAAU,MAAI,IAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACsErD,aAKM,QAAA,MAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgC4C,SAAA,cAAA,GAAA,SAAS,2BAA2B;;;;;AAD1E,aAEM,QAAA,KAAA,MAAA;AADJ,aAA+E,KAAA,EAAA;AAAA;;;;;;;;;;;;;;;;;;;;eAKjC,IAAS;AAAA;MAAlC,IAAI,QAAA,QAAA;4BAAJ,IAAI;AAAA;;;;;;;;;;;;;;;;;;;;;;;kCAAJ,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBASrB,IAAS,OAAAmD,oBAAA,GAAA;qBAiBR,IAAe;AAAc,QAAA,UAAA,iCAAA,SAAS,MAAT;mCAAlC,QAAI,KAAA,GAAA;;;;;qBAIC,IAAmB;AAAU,QAAA,YAAA,iCAAA,SAAK,MAAL;mCAAlC,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;AAvBR,aA2BM,QAAA,KAAA,MAAA;;;;;;;;;;;;;;WAzBE,KAAS;AAAA,iBAAA,EAAA,MAAA,KAAA;;uBAiBR,KAAe;;;;;;uBAIf,KAAmB;;;;;;;;;uCAJxB,QAAI,KAAA,GAAA;;;uCAIJ,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AATC,MAAA,WAAA,SAAS,gCAAgC,IAAA;;;;iBAVvC,IAAI,OAAA,kBAAA,GAAA;;;;;;;;;;;;;;;;AADX,aAaM,QAAA,KAAA,MAAA;;;;AALJ,aAII,KAAA,CAAA;AAFF,aAA2B,GAAA,CAAA;;;;;;;;;UATxB,KAAI;AAAA,iBAAA,EAAA,MAAA,KAAA;AAAA;;;;;;;;;;;;;;;;AAIJ,MAAA,WAAA,SAAS,gCAAgC,IAAA;;;;;;;;;;;;;;AAH5C,aAII,QAAA,GAAA,MAAA;AAFF,aAA2B,GAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAamB,IAAS;AAAA;MAAtC,IAAQ,QAAA,QAAA;4BAAR,IAAQ;AAAA;;;;;;;;;;;;;;;;;;;;;;;kCAAR,IAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAIiB,IAAS;AAAA;MAAlC,IAAI,QAAA,QAAA;4BAAJ,IAAI;AAAA;;;;;;;;;;;;;;;;;;;;;;;kCAAJ,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;AAgB9B,MAAA,WAAA,SAAS,yBAAyB,IAAA;;;;;;;;;;AADnC,aAA4B,QAAA,GAAA,MAAA;;;;;;;;;;;;;;;;;;;AAF3B,MAAA,WAAA,SAAS,QAAQ,IAAA;;;;;;;;;;AADlB,aAA4B,QAAA,GAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;;;oDAgCqB;MAAxB,IAAI,QAAA,QAAA;4BAAJ,IAAI;AAAA;;;;;;;;;;;;;;;;;;;;;;;kCAAJ,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAStB,MAAA,WAAA,OAAiB,UAAM7B,oBAAA;qBAIrB,IAAgB;AAAc,QAAA,UAAA,iCAAA,SAAS,MAAT;mCAAnC,QAAI,KAAA,GAAA;;;;;mBAIC,IAAoB;AAAU,QAAA,YAAA,iCAAA,SAAK,MAAL;iCAAnC,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;AAVR,aAcM,QAAA,KAAA,MAAA;;;;;;;;;;;;;;AAZC,UAAA,QAAiB,QAAM;;;;;;;;;;;;;uBAIrB,KAAgB;;;;;;qBAIhB,KAAoB;;;;;;;;;uCAJzB,QAAI,KAAA,GAAA;;;qCAIJ,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAPJ,aAA8C,QAAA,KAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;oDAIK;MAA5B,IAAQ,QAAA,QAAA;4BAAR,IAAQ;AAAA;;;;;;;;;;;;;;;;;;;;;;;kCAAR,IAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDAIgB;MAAxB,IAAI,QAAA,QAAA;4BAAJ,IAAI;AAAA;;;;;;;;;;;;;;;;;;;;;;;kCAAJ,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBApHzB,IAAK,GAAC,gBAAgB,OAAI;;;;;;;;;;;;;;;;;;;;;iBAwF/B,IAAK,GAAC,iBAAiB,OAAI;;;;;;;;;;;;;;AAxEtB,MAAA,YAAA,CAAA,OAAW,UAAM,kBAAA;qBAMhB,IAAU;AAAU,QAAA,UAAA,iCAAA,SAAK,IAAL;mCAAzB,QAAI,KAAA,GAAA;;;;;kBAMH,IAAmB,OAAAgB,oBAAA,GAAA;;QAqCnB,KAAmB;AAAA,aAAAR;;;;;;qBAgCf,IAAW;AAAU,QAAA,YAAA,iCAAA,SAAK,IAAL;mCAA1B,QAAI,KAAA,GAAA;;;;;kBAMH,IAAmB,OAAAP,kBAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDAzGb,IAAK,GAAC,gBAAgB,GAAG;AAAA,aAAA,MAAA,OAAA,cAAA;;;mCAMd,IAAmB,EAAA;wCACd,IAAmB,EAAA;yCAClB,IAAmB,EAAA;;;;;;;;;mCA2EzB,IAAoB,EAAA;wCACf,IAAoB,EAAA;yCACnB,IAAoB,EAAA;;oDAOrC,IAAK,GAAC,iBAAiB,GAAG;AAAA,aAAA,MAAA,OAAA,cAAA;;;;;;;;;AAnG7C,aAyIM,QAAA,OAAA,MAAA;AAvIJ,aAqIM,OAAA,KAAA;AAnIJ,aA+EM,OAAA,IAAA;AA7EJ,aAaM,MAAA,IAAA;AAZJ,aAAuC,MAAA,IAAA;;AACvC,aAEK,MAAA,GAAA;AADH,aAAuC,KAAA,IAAA;;;AAEzC,aAOM,MAAA,IAAA;AANJ,aAKK,MAAA,EAAA;;AAIT,aAiDM,MAAA,IAAA;AA/CJ,aAYM,MAAA,IAAA;;;;;;;;;;;AAqCR,aASS,MAAA,MAAA;;;AAIX,aAiDM,OAAA,KAAA;AA/CJ,aAaM,OAAA,IAAA;AAZJ,aAOM,MAAA,IAAA;AANJ,aAKK,MAAA,EAAA;;AAEP,aAEK,MAAA,GAAA;;;AACL,aAAwC,MAAA,IAAA;;AAG1C,aA8BM,OAAA,IAAA;AA5BJ,aAMM,MAAA,IAAA;;;;;;;;;;;;;;gFAvGK,KAAK,GAAC,gBAAgB,GAAG,GAAA;;;iEAE5B,KAAK,GAAC,gBAAgB,OAAI;AAAA,iBAAA,IAAA,QAAA;;qCAIZ,KAAmB,EAAA;AAAA;;0CACd,KAAmB,EAAA;AAAA;;2CAClB,KAAmB,EAAA;AAAA;AAUvC,UAAA,CAAA,QAAW,QAAM;;;;;;;;;;;;;uBAMhB,KAAU;;;;;UAMd,KAAmB;AAAA,kBAAA,EAAA,MAAA,KAAA;;;;;;;;;;;;qCAqDF,KAAoB,EAAA;AAAA;;0CACf,KAAoB,EAAA;AAAA;;2CACnB,KAAoB,EAAA;AAAA;iEAK7C,KAAK,GAAC,iBAAiB,OAAI;AAAA,iBAAA,IAAA,QAAA;gFAEnB,KAAK,GAAC,iBAAiB,GAAG,GAAA;;;;uBAO5B,KAAW;;;;;UAMf,KAAmB;AAAA,kBAAA,EAAA,MAAA,KAAA;AAAA;;;;uCAjFpB,QAAI,KAAA,GAAA;;;;uCA2EJ,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AArHb,MAAA,WAAA,UAAuB,IAAoB,MAAA,kBAAA;;;gBAS5B,IAAQ;AAAA;;;;;;;;;;;;;;;;;;;AATvB,UAAA,WAAuB,KAAoB,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAzIrC,gBAAW;QACX,UAAK;QAEV,YAAY,MAAM;;QAClB,iBAAiB,MAAM;;QACvB,qBAAqB,MAAM;;QAC3B,qBAAqB,MAAM;;QAE3B,aAAa,MAAM;;QACnB,kBAAkB,MAAM;;QACxB,sBAAsB,MAAM;;QAC5B,sBAAsB,MAAM;;AAE9B,MAAA,OAAO,KAAK,KAAK;MACjB,sBAAsB,KAAK,UAAU,WAAW,MAAM,SAAS,KAC9D,KAAK,UAAU,WAAW,WAAW,SAAS;AAC/C,MAAA,YAAY,KAAK,SAAS,MAAM,kBAAkB,KAAK,SAAS,MAAM;AAE3D,0BAAS,MAAI;QAEtB,KAAK,SAAS;AAAM;AAEnB,QAAA,CAAA,KAAK,SAAO;AACV,UAAA,CAAA,KAAK,KAAK;AAAI,eAASyD,eAAuB,KAAK,KAAK,SAAS,gCAAgC,GAAG,IAAI;AAAA;AAG1G,QAAA,CAAA,KAAK,KAAK,QAAQ,KAAK,WAAW,KAAK,YAAY,MAAM,gBAAgB,IAAE;AACxE,YAAAjD,aAAoB,uEAAwE,MAAM,gBAAgB,OAAI;AAAA;AAG1H,QAAA,aAAa,KAAK,eAAe,aAAa,IAAI;QAClD,WAAW,KAAK;SAEf,UAAQ;AACX,cAAQ,MAAM,IAAI;YACZA,aAAqB,+CAA+C;AAAA;UAGtE,iBAAiBgB,cAA4B,MAAM,kBAAkB,IAAI;QAC3E,gBAAc;WACX,KAAK,KAAK,MAAI;AACV,eAAAiC,eAAuB,KAAK,KAAK,OAAO,yCAA2C,EAAA,MAAM,eAAc,IAAK,IAAI;AAAA;AAEpH,UAAA,CAAA,YAAY,WAAS;cAClB,QAAK,MAAS,OAAO,QAAO;AAAA,UAChC,OAAO,KAAK,KAAK,SAAS,sCAAsC;AAAA,UAChE,SAAO,gCAAkC,KAAK,KAAK,OAAO,+CAA6C,EAAI,MAAM,eAAc,CAAA;AAAA,UAC/H,YAAY;AAAA;aAET,OAAK;iBACD;AAAA;;;UAKP,wBAAwBzC,qBAAmC,MAAM,eAAe,EAAE;AAClF,UAAA,aAAe,CAAA,CAAAtC,gBAA0B,sBAAsB,IAAI,WAAQ,MAAK,IAAI,GAAG,QAAQ;AAE9F,WAAA,MAAM,QAAQ,UAAY,EAAA,UAAU,WAAU,CAAA;AAAA;AAxCxC;AA4CT,QAAA,uBAAuB,gBAAgB,UAAK;AAC1C,UAAA,eAAe,gBAAgB,eAAe,SAAS,4BAA6B,CAAA,MAAM,eAAe,IAAI,MAAM,gBAAgB,EAAE,GAAG,MAAM,gBAAgB,KAAK,KAAK,IAAI,KAAK;AAChL,WAAA,oBAAoB,eAAe,SAAS,2BAA2B,MAAM,eAAe,KAAK,KAAK,IAAI,KAAK;AAAA,KACrH;AACH,YAAU,UAAU,oBAAoB;AAElC,QAAA,gCAAgC,gBAAgB,UAAK;AACnD,UAAA,eAAe,gBAAgB,eAAe,SAAS,sCAAuC,CAAA,MAAM,eAAe,IAAI,MAAM,gBAAgB,EAAE,GAAG,MAAM,gBAAgB,KAAK,KAAK,IAAI,KAAK;AAC1L,WAAA,oBAAoB,eAAe,SAAS,qCAAqC,MAAM,eAAe,KAAK,KAAK,IAAI,KAAK;AAAA,KAC/H;AACH,qBAAmB,UAAU,6BAA6B;AAEpD,QAAA,4BAA4B,gBAAgB,eAAU;AACpD,UAAA,eAAe,gBAAgB,eAAe,SAAS,iCAAkC,CAAA,MAAM,eAAe,IAAI,MAAM,gBAAgB,EAAE,GAAG,MAAM,gBAAgB,KAAK,KAAK,IAAI,UAAU;AAC1L,WAAA,oBAAoB,eAAe,SAAS,gCAAgC,MAAM,eAAe,KAAK,KAAK,IAAI,UAAU;AAAA,KAC/H;AACH,iBAAe,UAAU,yBAAyB;AAE5C,QAAA,mBAAmB,gBAAgB,kBAAa;AAC9C,UAAA,eAAe,gBAAgB,eAAe,SAAS,qBAAsB,CAAA,MAAM,eAAe,IAAI,MAAM,gBAAgB,EAAE,GAAG,MAAM,gBAAgB,KAAK,KAAK,IAAI,aAAa;AACjL,WAAA,oBAAoB,eAAe,SAAS,oBAAoB,MAAM,eAAe,KAAK,KAAK,IAAI,aAAa;AAAA,KACtH;AACH,qBAAmB,UAAU,gBAAgB;qCAEV,kBAAkB,MAAI;AACnD,QAAA,MAAM,WAAS;AACV,aAAA,eAAe,gBAAgB,eAAa,CAAG,MAAM,eAAe,IAAI,MAAM,gBAAgB,EAAE,MAAM,IAAI;AAAA;AAE5G,WAAA,eAAe,mBAAmB,kBAAkB,IAAI;AAAA;AAJlD;6BAOY,OAAO,OAAK;UAE/B,kBAAe,MAAS,mBAAmB,KAC/C,MAAM,iBACN,MAAM,kBAAgB;AAAA,MAEpB,oBAAoB,MAAM,sBAAqB;AAAA,MAC/C,OAAO,KAAK,KAAK,SAAS,oCAAoC;AAAA,MAC9D,SAAS,KAAK,KAAK,OAAO,wCAAsC;AAAA,QAAI,mBAAmB,MAAM,iBAAiB;AAAA;MAC9G,QAAQ,KAAK,KAAK,SAAS,oCAAoC;AAAA,MAC/D,qBAAqB;AAAA;AAIpB,QAAA,CAAA,mBAAoB,QAAQ,MAAM,cAAc,gBAAgB,UAAU,KAAM,CAAA,gBAAgB,MAAM;AAAM;AAEjH,oBAAgB,MAAM,QAAQ,UAAI;AAC1B,YAAA,WAAW,MAAM,gBAAgB,MAAM,IAAI,KAAK,GAAG,EAAE;AAC3D,YAAM,QAAQ,UAAY,EAAA,UAAU,KAAK,UAAU,UAAU,KAAI,CAAA;AAAA;UAG7D,aAAauC,mBAAiC,MAAM,iBAAmB,EAAA,QAAQ,MAAI,EACtF,OAAO,cAAY,SAAS,SAAS,WAAW;AAEnD,WAAO,QAAQ,gBAAgB,UAAU,EAAE,QAAO,CAAA,CAAG,MAAM,cAAQ;YAC3D,WAAW,WAAW,KAAK,eAAY,UAAS,SAAS,IAAI;AACnE,YAAM,aAAY;AAAA,QACV;AAAA,QACI;AAAA,QACV,aAAa;AAAA,QACb,MAAM,SAAS;AAAA,QACf,KAAK,SAAS;AAAA,QACd,aAAW,CAAG,KAAK,KAAK,OAAO,SAAS,WAAW;AAAA,QACnD,OAAO,SAAS;AAAA;;;AAjCP;;;;;;;AAmG0B,gBAAY,IAAI;AAAA;;AAMlB;;;;;;;;;;;;;AAuBL,UAAM,eAAe,MAAM,eAAe,EAAE;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACvOjE,MAAM,mBAAmB,kBAAkB;AAAA,EACxD,YAAY,OAAO,UAAU,CAAA,GAAI,aAAa,CAAA,GAAI;AAChD,UAAM;AAAA,MACJ,OAAO,KAAK,KAAK,OAAO,4BAA4B;AAAA,QAClD,SAAS,MAAM,gBAAgB;AAAA,QAC/B,SAAS,MAAM,iBAAiB;AAAA,MACxC,CAAO;AAAA,MACD,QAAQ;AAAA,QACN,OAAO4D;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,QACD;AAAA,MACF;AAAA,MACD,GAAG;AAAA,IACJ,GAAE,UAAU;AAEb,SAAK,gBAAgB,MAAM;AAAA,EAC5B;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,QAAQ;AAAA,MACR,SAAS,CAAC,UAAU,0BAA0B;AAAA,MAC9C,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,eAAe;AAAA,IACrB,CAAK;AAAA,EACF;AAAA,EAED,MAAM,MAAM,UAAU,IAAI;AACxB,QAAI,CAAC,SAAS,UAAU;AACtB,YAAM,eAAe,mBAAmB,eAAe,SAAS,cAAc,KAAK,eAAe,KAAK,KAAK,EAAE;AAAA,IAC/G;AACD,WAAO,MAAM,MAAM,OAAO;AAAA,EAC3B;AAAA,EAED,OAAO,aAAa,eAAe;AACjC,eAAW,OAAO,OAAO,OAAO,GAAG,OAAO,GAAG;AAC3C,UAAI,eAAe,QAAQ,KAAK,kBAAkB,eAAe;AAC/D,eAAO;AAAA,MACR;AAAA,IACF;AACD,WAAO;AAAA,EACR;AACH;AA7CqB;ACUrB,MAAM,aAAa,oBAAI;AACvB,MAAM,gBAAgB,oBAAI;AAEX,MAAM,SAAS;AAAA,EAE5B,OAAO,aAAa;AAClB,UAAM,GAAG,oBAAoB,KAAK,kBAAkB,KAAK,IAAI,CAAC;AAAA,EAC/D;AAAA,EAED,aAAa,cAAc,OAAO,OAAO;AAGvC,UAAM,QAAQ,KAAK,MAAM,OAAO,WAAQ,MAAK,UAAU,UAAS,KAAK,IAAI;AAGzE,QAAI,CAAC,MAAM,QAAQ;AACjB,aAAO,UAAU,OAAO;AAAA,QACtB,OAAO,KAAK,KAAK,SAAS,wBAAwB;AAAA,QAAG,SAAS;AAAA,UAC5D,OAAO;AAAA,UAAc,OAAO;AAAA,YAC1B,QAAQ,KAAK,KAAK,SAAS,sCAAsC;AAAA,YACjE,SAAS,KAAK,KAAK,SAAS,wCAAwC;AAAA,YACpE,MAAM;AAAA,UACP;AAAA,QACF;AAAA,QAAE,OAAO;AAAA,QAAM,WAAW;AAAA,QAAO,SAAS;AAAA,UACzC,QAAQ;AAAA,QACT;AAAA,MACT,CAAO;AAAA,IACF;AAED,QAAI;AACJ,QAAI;AACJ,QAAI;AAGJ,UAAM,SAAS,KAAK,OAAO,OAAO,YAAS,OAAM,OAAO;AAGxD,QAAI,OAAO,WAAW,KAAK,MAAM;AAC/B,eAAS,KAAK;AACd,cAAQ,OAAO;AACf,kBAAY;AAAA,IAClB,OAAW;AAEL,YAAM,SAAS,MAAM,kBAAkB,KAAK,EAAE,QAAQ,OAAO,KAAI,CAAE;AACnE,UAAI,CAAC;AAAQ;AACb,eAAS,OAAO,KAAK;AACrB,cAAQ,OAAO;AACf,kBAAY,OAAO;AAAA,IACpB;AAED,QAAI,CAAC;AAAO,aAAO;AAEnB,YAAQ,OAAO,SAAS;AAExB,UAAM,aAAa,KAAK,MAAM,KAAK,WAAQ,MAAK,cAAc,SAAS,UAAS,KAAK,IAAI;AACzF,QAAI,YAAY;AAEd,YAAM,aAAa,UAAU,QAAQ;AAAA,QACnC,OAAO,KAAK,KAAK,SAAS,wBAAwB;AAAA,QAAG,SAAS;AAAA,UAC5D,OAAO;AAAA,UAAc,OAAO;AAAA,YAC1B,QAAQ,KAAK,KAAK,SAAS,wBAAwB;AAAA,YACnD,SAAS,WAAW,SAAS,KAAK,KAAK,OAAO,+CAA+C;AAAA,cAC3F,YAAY,MAAM;AAAA,cAAM,aAAa,WAAW;AAAA,YACjD,CAAA,IAAI,KAAK,KAAK,OAAO,yCAAyC;AAAA,cAC7D,YAAY,MAAM;AAAA,cAAM,aAAa,WAAW;AAAA,YAC9D,CAAa;AAAA,YACD,MAAM;AAAA,UACP;AAAA,QACX;AAAA,QAAW,OAAO;AAAA,QAAM,WAAW;AAAA,QAAO,aAAa;AAAA,QAAO,YAAY;AAAA,QAAM,SAAS;AAAA,UAC/E,QAAQ;AAAA,QACT;AAAA,MACT,CAAO;AACD,UAAI,CAAC,YAAY;AACf;AAAA,MACD;AAAA,IACF;AAED,UAAM,iBAAiB;AACvB,UAAM,gBAAgB;AAGtB,UAAM,eAAe,IAAI,OAAO;AAAA,MAC9B,OAAO,KAAK,KAAK,SAAS,wBAAwB;AAAA,MAClD,SAAS,iCAAiC,KAAK,KAAK,OAAO,2CAA2C,EAAE,WAAW,KAAK,MAAM,IAAI,MAAM,EAAE,KAAI,CAAE;AAAA,MAChJ,SAAS;AAAA,QACP,SAAS;AAAA,UACP,MAAM;AAAA,UACN,OAAO,KAAK,KAAK,SAAS,uCAAuC;AAAA,UACjE,UAAU,MAAM;AACd,2BAAe,cAAc,eAAe,SAAS,yBAAyB,QAAQ,KAAK,KAAK,IAAI,cAAc;AAAA,UACnH;AAAA,QACF;AAAA,MACF;AAAA,IACP,GAAO;AAAA,MACD,KAAK;AAAA,MAAI,OAAO;AAAA,IACtB,CAAK,EAAE,OAAO,IAAI;AAGd,WAAO,eAAe,cAAc,eAAe,SAAS,sBAAsB,QAAQ,KAAK,KAAK,IAAI,MAAM,MAAM,gBAAgB,eAAe,SAAS,EACzJ,KAAK,OAAO,SAAS;AAEpB,UAAI,SAAS;AAAa;AAC1B,mBAAa,MAAK;AAGlB,UAAI,CAAC,QAAQ,CAAC,KAAK,mBAAmB,SAAS,cAAc,GAAG;AAC9D,eAAOpB,eAAuB,KAAK,KAAK,SAAS,2BAA2B,GAAG,IAAI;AAAA,MACpF;AAED,YAAM,cAAclF,SAAmB,KAAK,SAAS;AAErD,YAAM,QAAQ,IAAI,WAAW;AAAA,QAC3B,MAAM,KAAK;AAAA,QAAM;AAAA,MAC3B,GAAW;AAAA,QACD,MAAM,KAAK,MAAM,IAAI,MAAM;AAAA,QAAG,OAAO;AAAA,MACtC,GAAE,KAAK,mBAAmB,KAAK,oBAAoB,SAAS;AAE7D,YAAM,MAAM,IAAI,WAAW,OAAO,KAAK,cAAc,KAAK,EAAE,QAAQ,EAAE,OAAO,IAAI;AAEjF,oBAAc,IAAI,KAAK,mBAAmB,EAAE,KAAK,MAAK,CAAE;AAExD,YAAM,MAAM,OAAO,MAAM,KAAK,cAAc,KAAK,EAAE,UAAU;AAE7D,UAAI,WAAW;AACb,eAAO,eAAe,iBAAiB,MAAM,MAAM,SAAS,CAAC,KAAK,KAAK,IAAI,MAAM,GAAG;AAAA,UAClF,MAAM,KAAK,KAAK;AAAA,UAAI,OAAO,MAAM;AAAA,QAC7C,GAAa,EAAE,MAAM,QAAQ,OAAO,KAAK,UAAS,GAAI,KAAK,mBAAmB,SAAS;AAAA,MAC9E;AAED,aAAO,eAAe,SAAS,MAAM,MAAM,SAAS;AAAA,QAClD,MAAM,KAAK,KAAK;AAAA,QAAI,OAAO,MAAM;AAAA,MAC3C,GAAW,EAAE,MAAM,QAAQ,OAAO,KAAK,UAAS,GAAI,KAAK,mBAAmB,SAAS;AAAA,IAErF,CAAO,EAAE,MAAM,CAAC,QAAQ;AAChB,cAAQ,MAAM,GAAG;AAEjBkF,qBAAuB,KAAK,KAAK,SAAS,+BAA+B,GAAG,IAAI;AAChF,mBAAa,MAAO;AAAA,IAC5B,CAAO;AAAA,EAEJ;AAAA,EAED,aAAa,eAAe,eAAe,kBAAkB,gBAAgB,eAAe,WAAW;AAGrG,QAAI,WAAW,IAAI,aAAa,GAAG;AACjC,YAAMS,OAAa,KAAK,OAAQ,IAAG,IAAK;AACxC,aAAO;AAAA,IACR;AAGD,UAAM,qBAAqB,iBAAiB;AAC5C,UAAM,oBAAoB,gBAAgB;AAE1C,UAAM,cAAc,KAAK,MAAM,IAAI,aAAa;AAChD,QAAI,eAAe1F,aAAuB,gBAAgB;AAE1D,mBAAe,cAAc,SAAS;AAGtC,UAAM,SAAS,MAAM,mBAAmB,KAAK,EAAE,SAAS,gBAAgB,aAAa,cAAc,UAAS,CAAE;AAE9G,QAAI,CAAC;AAAQ,aAAO;AAEpB,QAAI,WAAW,aAAa;AAC1B,aAAO;AAAA,IACR;AAGD,QAAI,WAAW,QAAQ;AACrB,iBAAW,KAAK,aAAa;AAC7B,aAAO;AAAA,IACR;AAED,UAAM,QAAQ,OAAO,SAAS;AAE9B,UAAM,QAAQ,IAAI,WAAW,EAAE,MAAM,KAAK,MAAM,SAAS;AAAA,MACvD,MAAM;AAAA,MAAa,OAAO;AAAA,IAChC,GAAO,mBAAmB,oBAAoB,SAAS;AAEnD,UAAM,MAAM,IAAI,WAAW,OAAO,KAAK,cAAc,KAAK,EAAE,QAAQ,EAAE,OAAO,IAAI;AAEjF,kBAAc,IAAI,mBAAmB,EAAE,KAAK,MAAO,CAAA;AAEnD,UAAM,MAAM,OAAO,MAAM,KAAK,cAAc,KAAK,EAAE,UAAU;AAE7D,WAAO;AAAA,MACL;AAAA,MAAoB;AAAA,MAAmB,WAAW,OAAO;AAAA,IAC/D;AAAA,EAEG;AAAA,EAED,OAAO,cAAc,OAAO;AAC1B,UAAM,WAAY,OAAO,aAAa,IAAK;AAC3C,WAAO;AAAA,MACL,YAAY,EAAE,MAAM,WAAW,MAAM,MAAM,SAAS,QAAQ,GAAI;AAAA,MAAE,UAAU,EAAE,MAAM,WAAW,GAAI;AAAA,IACpG;AAAA,EACF;AAAA,EAED,aAAa,gBAAgB,QAAQ,gBAAgB;AAEnD,cAAU,OAAO;AAAA,MACf,OAAO,KAAK,KAAK,SAAS,wBAAwB;AAAA,MAAG,SAAS;AAAA,QAC5D,OAAO;AAAA,QAAc,OAAO;AAAA,UAC1B,QAAQ,KAAK,KAAK,SAAS,wBAAwB;AAAA,UACnD,SAAS,KAAK,KAAK,OAAO,6CAA6C,EAAE,WAAW,KAAK,MAAM,IAAI,MAAM,EAAE,KAAI,CAAE;AAAA,UACjH,MAAM;AAAA,QACP;AAAA,MACF;AAAA,MAAE,OAAO;AAAA,MAAM,WAAW;AAAA,MAAO,SAAS;AAAA,QACzC,QAAQ;AAAA,MACT;AAAA,IACP,CAAK;AAED,WAAO,mBAAmB,OAAO,cAAc;AAAA,EAEhD;AAAA,EAED,aAAa,kBAAkB,EAAE,SAAS,cAAc,CAAA,GAAI;AAE1D,UAAM,eAAe,KAAK,iBAAiB,OAAO;AAClD,QAAI,cAAc;AAChB,aAAO,aAAa,MAAM;IAC3B;AAED,UAAM,OAAO,KAAK,MAAM,IAAI,SAAS;AACrC,QAAI,CAAC,MAAM,QAAQ;AACjB,aAAO;AAAA,IACR;AAED,UAAM,mBAAmB,MAAM,eAAe,cAAc,eAAe,SAAS,oBAAoB,WAAW,SAAS,KAAK,KAAK,EAAE;AACxI,QAAI,CAAC,kBAAkB;AACrB,aAAO;AAAA,IACR;AAED,WAAO;AAAA,EAER;AAAA,EAED,aAAa,eAAe,EAAE,SAAS,cAAc,CAAA,GAAI;AAEvD,UAAM,MAAM,WAAW,aAAa,OAAO;AAC3C,QAAI,KAAK;AACP,aAAO,IAAI,OAAO,OAAO,EAAE,OAAO,KAAI,CAAE;AAAA,IACzC;AAED,UAAM,mBAAmB,MAAM,KAAK,kBAAkB,EAAE,SAAS,UAAS,CAAE;AAC5E,QAAI,CAAC,kBAAkB;AACrB,UAAI+F,cAAqB,GAAI;AAC3B,uBAAe,YAAY,eAAe,SAAS,2BAA2B,OAAO;AAAA,MACtF;AACD,aAAOd,eAAuB,KAAK,KAAK,SAAS,uBAAuB,GAAG,IAAI;AAAA,IAChF;AAED,UAAM,QAAQ,WAAW,OAAO,GAAG,gBAAgB;AACnD,WAAO,IAAI,WAAW,KAAK,EAAE,OAAO,IAAI;AAAA,EAEzC;AAAA,EAED,aAAa,wBAAwB,SAAS,aAAa;AACzD,UAAM,QAAQ,KAAK,iBAAiB,SAAS,WAAW;AACxD,QAAI,CAAC;AAAO;AACZ,WAAO,MAAM,MAAM;EACpB;AAAA,EAED,OAAO,iBAAiB,SAAS,cAAc,KAAK,KAAK,IAAI;AAC3D,QAAI,CAAC,cAAc,IAAI,OAAO;AAAG,aAAO;AACxC,UAAM,QAAQ,cAAc,IAAI,OAAO;AACvC,QAAI,CAAC,MAAM,MAAM,WAAW;AAC1B,aAAO;AAAA,IACR;AACD,QAAI,MAAM,MAAM,eAAe,OAAO,eAAe,MAAM,MAAM,gBAAgB,OAAO;AAAa,aAAO;AAC5G,WAAO;AAAA,EACR;AAAA,EAED,aAAa,aAAa,SAAS,QAAQ,OAAO;AAChD,UAAM,QAAQ,KAAK,iBAAiB,OAAO;AAC3C,QAAI,CAAC;AAAO;AACZ,UAAM,MAAM,YAAY,QAAQ,KAAK;AAAA,EACtC;AAAA,EAED,aAAa,sBAAsB,SAAS,QAAQ,OAAO;AACzD,UAAM,QAAQ,KAAK,iBAAiB,OAAO;AAC3C,QAAI,CAAC;AAAO;AACZ,UAAM,MAAM,qBAAqB,QAAQ,KAAK;AAAA,EAC/C;AAAA,EAED,aAAa,kBAAkB,SAAS,QAAQ,YAAY;AAC1D,UAAM,QAAQ,KAAK,iBAAiB,OAAO;AAC3C,QAAI,CAAC;AAAO;AACZ,UAAM,MAAM,iBAAiB,QAAQ,UAAU;AAAA,EAChD;AAAA,EAED,aAAa,qBAAqB,SAAS,QAAQ,QAAQ;AACzD,UAAM,QAAQ,KAAK,iBAAiB,OAAO;AAC3C,QAAI,CAAC;AAAO;AACZ,UAAM,MAAM,oBAAoB,QAAQ,MAAM;AAC9C,QAAI,WAAW,KAAK,KAAK,MAAO,OAAM,MAAM,eAAe,OAAO,KAAK,KAAK,MAAM,MAAM,MAAM,gBAAgB,OAAO,KAAK,KAAK,KAAK;AAClI,UAAI,MAAM,MAAM,iBAAiB;AAC/B,mBAAW,YAAY;AACrB,cAAI,MAAM,MAAM,iBAAiB;AAC/B,2BAAe,gBACb,eAAe,SAAS,eACxB,CAAC,MAAM,MAAM,eAAe,IAAI,MAAM,MAAM,gBAAgB,EAAE,GAC9D,MAAM,MAAM,eACZ,MAAM,MAAM,gBACZ,MAAM;AAAA,UACT;AAAA,QACF,GAAE,GAAI;AAAA,MACR;AAAA,IACF;AAAA,EACF;AAAA,EAED,aAAa,kBAAkB,KAAK,MAAM,MAAM;AAC9C,UAAM,iBAAiB,CAAA;AACvB,aAAS,CAAC,SAAS,UAAU,eAAe;AAC1C,YAAM,YAAY,KAAK,MAAM,KAAK,OAAK,MAAM,MAAM,MAAM,cAAc;AACvE,YAAM,aAAa,KAAK,MAAM,KAAK,OAAK,MAAM,MAAM,MAAM,eAAe;AACzE,UAAI,aAAa;AAAY;AAC7B,qBAAe,KAAK,OAAO;AAC3BA,qBAAuB,KAAK,KAAK,SAAS,+BAA+B,GAAG,IAAI;AAChF,YAAM,MAAM,IAAI,MAAM,EAAE,UAAU,KAAI,CAAE;AACxC,UAAI,cAAc,KAAK,QAAQ,eAAe,KAAK,MAAM;AACvD,YAAIc,cAAqB,GAAI;AAC3B,gBAAM,eAAe,YAAY,eAAe,SAAS,2BAA2B,OAAO;AAAA,QAC5F;AAAA,MACF;AAAA,IACF;AACD,mBAAe,QAAQ,aAAW,cAAc,OAAO,OAAO,CAAC;AAAA,EAChE;AAAA,EAED,aAAa,aAAa,SAAS,aAAa;AAC9C,UAAM,QAAQ,KAAK,iBAAiB,OAAO;AAC3C,QAAI,CAAC;AAAO;AAEZ,QAAI,MAAM,MAAM,eAAe,OAAO,KAAK,KAAK,MAAM,MAAM,MAAM,gBAAgB,OAAO,KAAK,KAAK,IAAI;AAErG,UAAI,gBAAgB,MAAM,MAAM,gBAAgB,IAAI;AAElD,kBAAU,OAAO;AAAA,UACf,OAAO,KAAK,KAAK,SAAS,+BAA+B;AAAA,UAAG,SAAS;AAAA,YACnE,OAAO;AAAA,YAAc,OAAO;AAAA,cAC1B,QAAQ,KAAK,KAAK,SAAS,+BAA+B;AAAA,cAC1D,SAAS,KAAK,KAAK,OAAO,gCAAgC;AAAA,gBACxD,WAAW,MAAM,MAAM,gBAAgB;AAAA,cACvD,CAAe;AAAA,cACD,MAAM;AAAA,YACP;AAAA,UACF;AAAA,UAAE,OAAO;AAAA,UAAO,WAAW;AAAA,UAAM,SAAS;AAAA,YACzC,QAAQ;AAAA,UACT;AAAA,QACX,CAAS;AAAA,MAET,OAAa;AAEL,YAAI,MAAM,MAAM,WAAW;AACzB,gBAAM,cAAc,MAAM,MAAM,eAAe,OAAO,KAAK,KAAK,KAAK,MAAM,MAAM,gBAAgB,KAAK,MAAM,MAAM,eAAe;AACjI,yBAAe,cAAc,eAAe,SAAS,cAAc,aAAa,SAAS,KAAK,KAAK,EAAE;AAAA,QAC/G,OAAe;AACL,yBAAe,iBAAiB,eAAe,SAAS,cAAc,SAAS,KAAK,KAAK,EAAE;AAAA,QAC5F;AAED,kBAAU,OAAO;AAAA,UACf,OAAO,KAAK,KAAK,SAAS,+BAA+B;AAAA,UAAG,SAAS;AAAA,YACnE,OAAO;AAAA,YAAc,OAAO;AAAA,cAC1B,QAAQ,KAAK,KAAK,SAAS,+BAA+B;AAAA,cAC1D,SAAS,KAAK,KAAK,OAAO,6BAA6B;AAAA,cACvD,MAAM;AAAA,YACP;AAAA,UACF;AAAA,UAAE,OAAO;AAAA,UAAO,WAAW;AAAA,UAAM,SAAS;AAAA,YACzC,QAAQ;AAAA,UACT;AAAA,QACX,CAAS;AAED,YAAIA,cAAqB,GAAI;AAC3B,gBAAM,eAAe,YAAY,eAAe,SAAS,2BAA2B,OAAO;AAAA,QAC5F;AAAA,MACF;AAAA,IAEP,OAAW;AAELd,qBAAuB,KAAK,KAAK,SAAS,iCAAiC,GAAG,IAAI;AAAA,IAEnF;AAED,UAAM,IAAI,MAAM,EAAE,UAAU,KAAM,CAAA;AAClC,kBAAc,OAAO,OAAO;AAAA,EAC7B;AAAA,EAED,aAAa,cAAc,SAAS,WAAW,QAAQ;AACrD,UAAM,QAAQ,KAAK,iBAAiB,OAAO;AAC3C,QAAI,CAAC;AAAO;AACZ,QAAI,MAAM,MAAM,mBAAmB;AAAW;AAC9C,UAAM,UAAU,MAAM,MAAM,aAAY;AAExC,UAAM,aAAa,QAAQ,IAAI,MAAM,IAAI,WAAS;AAChD,YAAM,WAAW,QAAQ,YAAY,MAAM,IAAI,MAAM,EAAE,EAAE;AACzD,aAAOxB,gBAA0B,UAAU,MAAM,QAAQ;AAAA,IAC/D,CAAK;AAED,UAAM,gBAAgB,QAAQ,OAAO,MAAM,IAAI,WAAS;AACtD,YAAM,WAAW,QAAQ,YAAY,MAAM,IAAI,MAAM,EAAE,EAAE;AACzD,aAAOA,gBAA0B,UAAU,MAAM,QAAQ;AAAA,IAC/D,CAAK;AAED,UAAM,cAAc,IAAI,YAAY,QAAQ,WAAW;AACvD,gBAAY,kBAAkB,UAAU;AACxC,gBAAY,kBAAkB,eAAe,EAAE,QAAQ,KAAM,CAAA;AAC7D,gBAAY,mBAAmB,QAAQ,IAAI,UAAU;AACrD,gBAAY,mBAAmB,QAAQ,OAAO,YAAY,EAAE,QAAQ,KAAI,CAAE;AAC1E,UAAM,YAAY;AAElB,QAAI,MAAM,MAAM,WAAW;AACzB,YAAM,IAAI,MAAM,EAAE,UAAU,KAAM,CAAA;AAClC,oBAAc,OAAO,OAAO;AAAA,IAC7B,WAAU,WAAW,KAAK,KAAK,IAAI;AAClC,UAAIsC,cAAqB,GAAI;AAC3B,cAAM,eAAe,YAAY,eAAe,SAAS,2BAA2B,OAAO;AAAA,MAC5F;AACD,aAAO,eAAe,mBAAmB,eAAe,SAAS,iBAAiB,SAAS,OAAO;AAAA,IACnG;AAAA,EACF;AAAA,EAED,aAAa,gBAAgB,SAAS,SAAS;AAC7C,UAAM,QAAQ,KAAK,iBAAiB,OAAO;AAC3C,QAAI,CAAC;AAAO;AACZvC,UAAc,QAAQ,MAAM,MAAM,UAAU,SAAS,OAAO;AAC5D,UAAM,IAAI,MAAM,EAAE,UAAU,KAAM,CAAA;AAClC,kBAAc,OAAO,OAAO;AAAA,EAC7B;AAEH;AA3aqB;ACRN,MAAM,QAAQ;AAAA,EAE3B,OAAO,aAAa;AAElB,UAAM,GAAG,wBAAwB,KAAK,sBAAsB,KAAK,IAAI,CAAC;AACtE,UAAM,GAAG,qBAAqB,KAAK,mBAAmB,KAAK,IAAI,CAAC;AAChE,UAAM,GAAG,MAAM,KAAK,UAAU,KAAK,oBAAoB,KAAK,IAAI,CAAC;AACjE,UAAM,GAAG,MAAM,UAAU,UAAU,KAAK,wBAAwB,KAAK,IAAI,CAAC;AAC1E,UAAM,GAAG,MAAM,qBAAqB,KAAK,0BAA0B,KAAK,IAAI,CAAC;AAC7E,UAAM,GAAG,MAAM,KAAK,iBAAiB,KAAK,8BAA8B,KAAK,IAAI,CAAC;AAClF,UAAM,GAAG,MAAM,MAAM,SAAS,KAAK,oBAAoB,KAAK,IAAI,CAAC;AACjE,UAAM,GAAG,MAAM,MAAM,UAAU,KAAK,qBAAqB,KAAK,IAAI,CAAC;AAEnE,MAAE,QAAQ,EAAE,GAAG,SAAS,iDAAiD,iBAAkB;AACzF,UAAI,EAAE,IAAI,EAAE,KAAK,MAAM;AAAG;AAC1B,YAAMkC,OAAa,EAAE;AACrB,QAAE,IAAI,EAAE,OAAM,EAAG,GAAG,eAAe,EAAE,UAAU,UAAU,OAAO,WAAW,QAAQ,QAAS,CAAA;AAAA,IAClG,CAAK;AAAA,EACF;AAAA,EAED,OAAO,sBAAsB,aAAa;AAExC,QAAI,CAACzF,WAAmB,SAAS,cAAc;AAAG;AAElD,UAAM,UAAU,YAAY,KAAK,QAAQ,YAAW;AAEpD,QAAI,CAAE,SAAQ,WAAW,YAAY,KAAK,QAAQ,WAAW,KAAK;AAAI;AAEtE,UAAM,OAAO,QAAQ,MAAM,GAAG,EAAE,MAAM,CAAC;AAEvC,QAAI,KAAK,OAAO,SAAS;AACvB,iBAAW,MAAM;AACf,aAAK,UAAU;MACvB,CAAO;AAAA,IACF;AAED,WAAO;AAAA,EAER;AAAA,EAED,OAAO,mBAAmB,KAAK,MAAM;AACnC,SAAK,KAAK,2BAA2B,EAAE,MAAM,WAAY;AACvD,WAAK,UAAU,cAAc,EAAE,IAAI,EAAE,KAAI,CAAE;AAAA,IACjD,CAAK;AAAA,EACF;AAAA,EAED,OAAO,sBAAsB,eAAe;AAC1C,UAAM,UAAU,MAAM,KAAK,KAAK,QAAQ,EAAE,KAAK,cAAW;AACxD,aAAO,YAAY,SAAQ,MAAM,UAAU,MAAM,eAAe,MAAM;AAAA,IAC5E,CAAK;AACD,QAAI,CAAC;AAAS;AACd,UAAM,UAAS,KAAK,oBAAoB,OAAO;AAC/C,WAAO,QAAQ,OAAO,OAAM;AAAA,EAC7B;AAAA,EAED,aAAa,4BAA4B;AACvC,QAAI,CAAC,KAAK,KAAK;AAAM;AAErB,UAAM,WAAW,MAAM,KAAK,KAAK,QAAQ,EAAE,OAAO,aAAW;AAC3D,aAAO,YAAY,QAAQ,MAAM,UAAU,MAAM,eAAe;AAAA,IACtE,CAAK;AAED,QAAI,CAAC,SAAS;AAAQ;AACtB,UAAM,UAAU,CAAA;AAChB,aAAS,WAAW,UAAU;AAC5B,YAAM,UAAS,KAAK,oBAAoB,OAAO;AAC/C,YAAM,UAAU,YAAY,QAAQ,MAAM,UAAU,MAAM,eAAe;AACzE,YAAM,aAAa,YAAY,QAAQ,MAAM,UAAU,MAAM,WAAW;AACxE,YAAM,kBAAkB,WAAW,OAAO,YAAU,KAAK,MAAM,IAAI,MAAM,EAAE,MAAM,EAAE,WAAW,WAAW;AACzG,UAAI,CAAC,iBAAiB;AACpB,gBAAQ,KAAK,OAAM;AAAA,MAC3B,OAAa;AACL,cAAM,aAAa,WAAW,OAAO,YAAU,WAAW,KAAK,KAAK,EAAE;AACtE,cAAM,YAAY,MAAM,SAAS,kBAAkB,EAAE,SAAS,WAAW,WAAW,GAAE,CAAE;AACxF,YAAI,CAAC,WAAW;AACd,kBAAQ,KAAK,OAAM;AAAA,QACpB;AAAA,MACF;AAAA,IACF;AAED,QAAI,CAAC,QAAQ;AAAQ;AAErB,WAAO,YAAY,gBAAgB,OAAO;AAAA,EAE3C;AAAA,EAED,OAAO,oBAAoB,SAAS;AAClC,UAAM,UAAU,YAAY,QAAQ,MAAM,UAAU,MAAM,eAAe;AACzE,UAAM,eAAe,kBAAkB;AACvC,QAAI,UAAU,QAAQ,KAAK;AAC3B,cAAU,QAAQ,QAAQ,cAAc,EAAE;AAC1C,cAAU,QAAQ,QAAQ,cAAc,UAAU;AAClD,cAAU,QAAQ,QAAQ,KAAK,KAAK,SAAS,+BAA+B,GAAG,KAAK,KAAK,SAAS,kCAAkC,CAAC;AACrI,WAAO;AAAA,MACL,KAAK,QAAQ;AAAA,MACb;AAAA,MACA,CAAC,WAAW,UAAU,gBAAgB;AAAA,IAC5C;AAAA,EACG;AAAA,EAaD,aAAa,oBAAoB,QAAQ,QAAQ,OAAO,QAAQ,eAAe;AAC7E,QAAI,CAACwB,gBAA8B,MAAM;AAAG;AAC5C,QAAI,CAAC,iBAAiB,KAAK,KAAK,OAAO,UAAU,CAACxB,WAAmB,SAAS,cAAc;AAAG;AAC/F,UAAM,WAAW,MAAM,KAAK,gBAAgB,KAAK;AACjD,WAAO,eAAe,YAAY,eAAe,SAAS,qBAAqB,OAAO,MAAM,OAAO,MAAM,UAAU,CAAE,GAAE,QAAQ,aAAa;AAAA,EAC7I;AAAA,EAYD,aAAa,wBAAwB,QAAQ,QAAQ,YAAY,QAAQ,eAAe;AACtF,QAAI,CAACwB,gBAA8B,MAAM;AAAG;AAC5C,QAAI,CAAC,iBAAiB,KAAK,KAAK,OAAO,UAAU,CAACxB,WAAmB,SAAS,cAAc;AAAG;AAC/F,UAAM,eAAe,KAAK,oBAAoB,QAAQ,UAAU;AAChE,WAAO,eAAe,YAAY,eAAe,SAAS,qBAAqB,OAAO,MAAM,OAAO,MAAM,CAAE,GAAE,cAAc,QAAQ,aAAa;AAAA,EACjJ;AAAA,EAaD,aAAa,0BAA0B,QAAQ,QAAQ,OAAO,YAAY,QAAQ,eAAe;AAC/F,QAAI,CAACwB,gBAA8B,MAAM;AAAG;AAC5C,QAAI,CAAC,iBAAiB,KAAK,KAAK,OAAO,UAAU,CAACxB,WAAmB,SAAS,cAAc;AAAG;AAC/F,UAAM,WAAW,MAAM,KAAK,gBAAgB,KAAK;AACjD,UAAM,eAAe,KAAK,oBAAoB,QAAQ,UAAU;AAChE,WAAO,eAAe,YAAY,eAAe,SAAS,qBAAqB,OAAO,MAAM,OAAO,MAAM,UAAU,cAAc,QAAQ,aAAa;AAAA,EACvJ;AAAA,EAED,OAAO,8BAA8B,QAAQ,cAAc,QAAQ;AACjE,QAAI,CAACwB,gBAA8B,MAAM;AAAG;AAC5C,QAAI,KAAK,KAAK,OAAO,UAAU,CAACxB,WAAmB,SAAS,cAAc;AAAG;AAC7E,WAAO,eAAe,YAAY,eAAe,SAAS,oBAAoB,OAAO,MAAM,cAAc,MAAM;AAAA,EAChH;AAAA,EAED,aAAa,oBAAoB,SAAS,SAAS,eAAe,WAAW;AAC3E,QAAI,QAAQ,SAAS,KAAK,KAAK,MAAM,CAACA,WAAmB,SAAS,cAAc,KAAK;AAAW;AAChG,WAAO,KAAK,0BAA0B,SAAS,SAAS,aAAa;AAAA,EACtE;AAAA,EAED,aAAa,qBAAqB,SAAS,SAAS,eAAe,WAAW;AAC5E,QAAI,CAACA,WAAmB,SAAS,cAAc;AAAG;AAClD,WAAO,KAAK,2BAA2B,SAAS,SAAS,eAAe,SAAS;AAAA,EAClF;AAAA,EAQD,aAAa,gBAAgB,OAAO;AAClC,UAAM,iBAAiB,CAAA;AACvB,eAAW,YAAY,OAAO;AAC5B,YAAM,WAAW,MAAM,KAAK,eAAe,OAAO,SAAS,MAAM,EAAE,WAAW,KAAI,CAAE;AACpF,qBAAe,KAAK;AAAA,QAClB,MAAM,KAAK,KAAK,SAAS,SAAS,IAAI;AAAA,QACtC,KAAK,SAAS,KAAK,OAAO;AAAA,QAC1B,UAAU,SAAS;AAAA,MAC3B,CAAO;AAAA,IACF;AACD,WAAO;AAAA,EACR;AAAA,EASD,OAAO,oBAAoB,UAAU,YAAY;AAC/C,UAAM,eAAewC,mBAAiC,QAAQ;AAC9D,WAAO,OAAO,QAAQ,UAAU,EAAE,IAAI,WAAS;AAC7C,YAAM,WAAW,aAAa,KAAK,eAAY,UAAS,OAAO,MAAM,EAAE;AACvE,aAAO;AAAA,QACL,MAAM,SAAS;AAAA,QACf,KAAK,SAAS,OAAO;AAAA,QACrB,UAAU,MAAM;AAAA,QAChB,OAAO,aAAa,QAAQ,QAAQ;AAAA,MACrC;AAAA,IACP,CAAK;AAAA,EACF;AAAA,EAaD,aAAa,oBAAoB,YAAY,YAAY,OAAO,YAAY,QAAQ,eAAe;AAEjG,UAAM,cAAc1C,SAAmB,UAAU;AACjD,UAAM,cAAcA,SAAmB,UAAU;AAEjD,UAAM,OAAO,CAAC,IAAI,KAAI;AAGtB,UAAM,WAAW,MAAM,KAAK,KAAK,QAAQ,EAAE,OAAO,aAAY,OAAM,QAAQ,KAAK,aAAe,KAAS,EAAE,MAAM,GAAG;AACpH,aAAS,QAAS;AAElB,aAAS,CAAC,OAAO,YAAY,SAAS,QAAO,GAAI;AAC/C,YAAM,QAAQ,YAAY,QAAQ,MAAM,UAAU,MAAM,IAAI;AAC5D,UAAI,SAAS,MAAM,WAAW,cAAc,MAAM,WAAW,cAAe,OAAM,kBAAkB,iBAAiB,UAAU,IAAI;AACjI,eAAO,KAAK,6BAA6B,SAAS,aAAa,aAAa,OAAO,YAAY,aAAa;AAAA,MAC7G;AAAA,IACF;AAED,UAAM,eAAe,MAAM,eAAe,UAAU,OAAO,8BAA8B;AAAA,MACvF,SAAS,KAAK,KAAK,OAAO,0BAA0B,EAAE,MAAM,YAAY,MAAM;AAAA,MAC9E,UAAU;AAAA,MACV,OAAO;AAAA,MACP;AAAA,MACA;AAAA,IACN,CAAK;AAED,WAAO,KAAK,sBAAsB,QAAQ;AAAA,MACxC,MAAM,KAAK,KAAK;AAAA,MAChB,MAAM,MAAM,mBAAmB;AAAA,MAC/B,SAAS;AAAA,MACT,QAAQ;AAAA,MACR,SAAS,YAAY,WAAW,EAAE,OAAO,KAAK,KAAK,MAAM;AAAA,MACzD,CAAC,UAAU,MAAM,OAAO;AAAA,QACtB,QAAQ;AAAA,QACR,QAAQ;AAAA,QACR;AAAA,QACA;AAAA,QACA;AAAA,MACD;AAAA,IACP,CAAK;AAAA,EAEF;AAAA,EAED,OAAO,cAAc,iBAAiB,iBAAiB;AAErD,UAAM,kBAAkB,gBAAgB,IAAI,mBAAiB;AAC3D,YAAM,aAAa,gBAAgB,KAAK,UAAQ,KAAK,SAAS,cAAc,QAAQ,cAAc,QAAQ,KAAK,GAAG;AAClH,UAAI,YAAY;AACd,sBAAc,YAAY,WAAW;AACrC,wBAAgB,OAAO,gBAAgB,QAAQ,UAAU,GAAG,CAAC;AAAA,MAC9D;AACD,aAAO;AAAA,IACb,CAAK;AAED,oBAAgB,QAAQ,UAAQ,gBAAgB,KAAK,IAAI,CAAC;AAE1D,WAAO;AAAA,EAER;AAAA,EAED,aAAa,6BAA6B,SAAS,aAAa,aAAa,OAAO,YAAY,eAAe;AAE7G,UAAM,QAAQ,YAAY,QAAQ,MAAM,UAAU,MAAM,IAAI;AAE5D,UAAM,WAAW,KAAK,cAAc,MAAM,OAAO,KAAK;AACtD,UAAM,gBAAgB,KAAK,cAAc,MAAM,YAAY,UAAU;AAErE,kBAAc,KAAK,CAAC,GAAG,MAAM;AAC3B,aAAO,EAAE,QAAQ,EAAE;AAAA,IACzB,CAAK;AAED,UAAM,eAAe,MAAM,eAAe,UAAU,OAAO,8BAA8B;AAAA,MACvF,SAAS,KAAK,KAAK,OAAO,0BAA0B,EAAE,MAAM,YAAY,MAAM;AAAA,MAC9E,UAAU;AAAA,MACV,OAAO;AAAA,MACP,OAAO;AAAA,MACP,YAAY;AAAA,IAClB,CAAK;AAED,WAAO,QAAQ,OAAO;AAAA,MACpB,SAAS;AAAA,MACT,CAAC,GAAG,UAAU,MAAM,uBAAuB;AAAA,MAC3C,CAAC,GAAG,UAAU,MAAM,eAAe;AAAA,MACnC,CAAC,GAAG,UAAU,MAAM,oBAAoB;AAAA,IAC9C,CAAK;AAAA,EAEF;AAAA,EAED,aAAa,mBAAmB,YAAY,cAAc,QAAQ;AAEhE,UAAM,SAAS,MAAM,SAAS,UAAU;AAExC,UAAM,cAAc,QAAQ,SAAS;AAErC,UAAM,eAAe,MAAM,eAAe,UAAU,OAAO,8BAA8B;AAAA,MACvF,SAAS,KAAK,KAAK,OAAO,yBAAyB,EAAE,aAAa,aAAa,aAAa;AAAA,MAC5F,UAAU;AAAA,MACV,OAAO,aAAa;AAAA,MACpB,YAAY,aAAa;AAAA,IAC/B,CAAK;AAED,WAAO,KAAK,sBAAsB,QAAQ;AAAA,MACxC,MAAM,KAAK,KAAK;AAAA,MAChB,MAAM,MAAM,mBAAmB;AAAA,MAC/B,SAAS;AAAA,MACT,QAAQ;AAAA,MACR,SAAS,YAAY,WAAW,EAAE,OAAO,KAAK,KAAK,MAAM;AAAA,IAC/D,CAAK;AAAA,EAEF;AAAA,EAED,aAAa,0BAA0B,SAAS,SAAS,eAAe;AAEtE,UAAM,gBAAgBA,SAAmB,QAAQ,KAAK;AACtD,UAAM,gBAAgBA,SAAmB,QAAQ,KAAK;AAEtD,UAAM,eAAe,MAAM,eAAe,UAAU,OAAO,qCAAqC;AAAA,MAC9F;AAAA,MACA;AAAA,MACA;AAAA,MACA,QAAQ,KAAK,KAAK;AAAA,IACxB,CAAK;AAED,WAAO,KAAK,sBAAsB,KAAK,KAAK,IAAI;AAAA,MAC9C,MAAM,KAAK,KAAK;AAAA,MAChB,MAAM,MAAM,mBAAmB;AAAA,MAC/B,SAAS;AAAA,MACT,QAAQ;AAAA,MACR,SAAS,YAAY,WAAW,EAAE,OAAO,KAAK,KAAK,MAAM;AAAA,MACzD,CAAC,UAAU,MAAM,kBAAkB;AAAA,MACnC,CAAC,UAAU,MAAM,cAAc,CAAC,QAAQ,MAAM,QAAQ,IAAI;AAAA,IAChE,CAAK;AAAA,EACF;AAAA,EAED,aAAa,2BAA2B,SAAS,SAAS,eAAe,WAAW;AAElF,QAAI,QAAQ,SAAS,KAAK,KAAK;AAAI;AAEnC,QAAI,gBAAgB,MAAM,SAAS,QAAQ,KAAK;AAChD,oBAAgB,eAAe,SAAS;AACxC,UAAM,eAAe;AAAA,MACnB,OAAO;AAAA,MACP,OAAO,QAAQ;AAAA,MACf,YAAY,QAAQ;AAAA,IACrB;AACD,iBAAa,cAAc,CAAC,aAAa,MAAM,UAAU,CAAC,aAAa,WAAW;AAElF,QAAI,gBAAgB,MAAM,SAAS,QAAQ,KAAK;AAChD,oBAAgB,eAAe,SAAS;AACxC,UAAM,eAAe;AAAA,MACnB,OAAO;AAAA,MACP,OAAO,QAAQ;AAAA,MACf,YAAY,QAAQ;AAAA,IACrB;AACD,iBAAa,cAAc,CAAC,aAAa,MAAM,UAAU,CAAC,aAAa,WAAW;AAElF,QAAI,QAAQ,eAAe,QAAQ;AAAa;AAEhD,UAAM,iBAAkB,aAAa,MAAM,SAAS,aAAa,WAAW,SAAS,aAAa,MAAM,SAAS,aAAa,WAAW,SAAU;AAEnJ,UAAM,eAAe,MAAM,eAAe,UAAU,OAAO,sCAAsC;AAAA,MAC/F,SAAS;AAAA,MACT,SAAS;AAAA,MACT;AAAA,MACA;AAAA,MACA;AAAA,IACN,CAAK;AAED,WAAO,KAAK,sBAAsB,KAAK,KAAK,IAAI;AAAA,MAC9C,MAAM,KAAK,KAAK;AAAA,MAChB,MAAM,YAAY,MAAM,mBAAmB,UAAU,MAAM,mBAAmB;AAAA,MAC9E,SAAS;AAAA,MACT,QAAQ,eAAgB,aAAY,OAAO,KAAK,KAAK,SAAS,8BAA8B,IAAI;AAAA,MAChG,SAAS,YAAY,WAAW,EAAE,OAAO,KAAK,KAAK,MAAM;AAAA,MACzD,SAAS,YAAY,CAAC,QAAQ,IAAI,IAAI,CAAE;AAAA,IAC9C,CAAK;AAAA,EAEF;AAAA,EAED,OAAO,sBAAsB,QAAQ,UAAU;AAE7C,QAAI,CAAC,SAAS,SAAS;AAErB,YAAM,OAAOE,WAAmB,SAAS,cAAc;AAEvD,UAAI,OAAO,GAAG;AACZ,iBAAS,UAAU,MAAM,KAAK,KAAK,KAAK,EACrC,OAAO,UAAQ,KAAK,IAAI,EACxB,IAAI,UAAQ,KAAK,EAAE;AACtB,YAAI,SAAS,GAAG;AACd,mBAAS,QAAQ,KAAK,MAAM;AAAA,QAC7B;AACD,iBAAS,OAAO,MAAM,mBAAmB;AAAA,MAC1C;AAAA,IAEF;AAED,WAAO,YAAY,OAAO,QAAQ;AAAA,EAEnC;AAEH;AAraqB;ACAN,MAAM,eAAe;AAAA,EAElC,OAAO,WAAW;AAAA,IAIhB,WAAW;AAAA,IAKX,qBAAqB;AAAA,IACrB,oBAAoB;AAAA,IACpB,2BAA2B;AAAA,IAK3B,aAAa;AAAA,IACb,aAAa;AAAA,IACb,cAAc;AAAA,IACd,aAAa;AAAA,IACb,gBAAgB;AAAA,IAChB,kBAAkB;AAAA,IAClB,cAAc;AAAA,IACd,YAAY;AAAA,IAKZ,kBAAkB;AAAA,IAClB,oBAAoB;AAAA,IACpB,uBAAuB;AAAA,IACvB,uBAAuB;AAAA,IAKvB,YAAY;AAAA,IACZ,WAAW;AAAA,IACX,cAAc;AAAA,IACd,gBAAgB;AAAA,IAChB,oBAAoB;AAAA,IACpB,eAAe;AAAA,IACf,mBAAmB;AAAA,IACnB,qBAAqB;AAAA,IACrB,yBAAyB;AAAA,IACzB,qBAAqB;AAAA,IACrB,sBAAsB;AAAA,IAKtB,sBAAsB;AAAA,IACtB,yBAAyB;AAAA,IACzB,oBAAoB;AAAA,IACpB,cAAc;AAAA,IACd,2BAA2B;AAAA,IAC3B,qCAAqC;AAAA,IACrC,gCAAgC;AAAA,IAChC,oBAAoB;AAAA,IACpB,4BAA4B;AAAA,IAC5B,sCAAsC;AAAA,IACtC,iCAAiC;AAAA,IACjC,qBAAqB;AAAA,IACrB,eAAe;AAAA,IACf,iBAAiB;AAAA,IAKjB,aAAa;AAAA,EACd;AAAA,EAED,OAAO,WAAW;AAAA,IAChB,CAAC,KAAK,SAAS,YAAY,CAAC,MAAM,aAAa,SAAS,SAAS,MAAM,UAAU,GAAG,IAAI;AAAA,IAExF,CAAC,KAAK,SAAS,aAAa,CAAC,SAAS,WAAW,WAAW,IAAI;AAAA,IAChE,CAAC,KAAK,SAAS,YAAY,IAAI,SAAS,WAAW,UAAU,GAAG,IAAI;AAAA,IACpE,CAAC,KAAK,SAAS,eAAe,IAAI,SAAS,WAAW,aAAa,GAAG,IAAI;AAAA,IAC1E,CAAC,KAAK,SAAS,iBAAiB,IAAI,SAAS,WAAW,eAAe,GAAG,IAAI;AAAA,IAC9E,CAAC,KAAK,SAAS,qBAAqB,IAAI,SAAS,WAAW,kBAAkB,GAAG,IAAI;AAAA,IACrF,CAAC,KAAK,SAAS,gBAAgB,IAAI,SAAS,WAAW,eAAe,GAAG,IAAI;AAAA,IAC7E,CAAC,KAAK,SAAS,oBAAoB,IAAI,SAAS,WAAW,kBAAkB,GAAG,IAAI;AAAA,IACpF,CAAC,KAAK,SAAS,sBAAsB,IAAI,SAAS,WAAW,oBAAoB,GAAG,IAAI;AAAA,IACxF,CAAC,KAAK,SAAS,0BAA0B,IAAI,SAAS,WAAW,uBAAuB,GAAG,IAAI;AAAA,IAC/F,CAAC,KAAK,SAAS,sBAAsB,IAAI,SAAS,WAAW,oBAAoB,GAAG,IAAI;AAAA,IACxF,CAAC,KAAK,SAAS,uBAAuB,IAAI,SAAS,WAAW,oBAAoB,GAAG,IAAI;AAAA,IAEzF,CAAC,KAAK,SAAS,cAAc,IAAI,SAAS,WAAW,gBAAgB,GAAG,IAAI;AAAA,IAC5E,CAAC,KAAK,SAAS,cAAc,IAAI,SAAS,WAAW,gBAAgB,GAAG,IAAI;AAAA,IAC5E,CAAC,KAAK,SAAS,eAAe,IAAI,SAAS,WAAW,iBAAiB,GAAG,IAAI;AAAA,IAC9E,CAAC,KAAK,SAAS,cAAc,IAAI,SAAS,WAAW,gBAAgB,GAAG,IAAI;AAAA,IAC5E,CAAC,KAAK,SAAS,iBAAiB,IAAI,SAAS,WAAW,yBAAyB,GAAG,IAAI;AAAA,IACxF,CAAC,KAAK,SAAS,mBAAmB,IAAI,SAAS,WAAW,2BAA2B,GAAG,IAAI;AAAA,IAC5F,CAAC,KAAK,SAAS,aAAa,IAAI,SAAS,WAAW,uBAAuB,GAAG,IAAI;AAAA,IAElF,CAAC,KAAK,SAAS,uBAAuB,IAAI,SAAS,SAAS,eAAe,GAAG,IAAI;AAAA,IAClF,CAAC,KAAK,SAAS,0BAA0B,IAAI,SAAS,SAAS,gBAAgB,GAAG,IAAI;AAAA,IACtF,CAAC,KAAK,SAAS,gBAAgB,IAAI,SAAS,SAAS,cAAc,GAAG,IAAI;AAAA,IAC1E,CAAC,KAAK,SAAS,kBAAkB,IAAI,SAAS,SAAS,gBAAgB,GAAG,IAAI;AAAA,IAC9E,CAAC,KAAK,SAAS,qBAAqB,IAAI,SAAS,SAAS,wBAAwB,GAAG,IAAI;AAAA,IACzF,CAAC,KAAK,SAAS,eAAe,IAAI,SAAS,SAAS,aAAa,GAAG,IAAI;AAAA,IAExE,CAAC,KAAK,SAAS,4BAA4B,IAAI,SAAS,SAAS,aAAa,GAAG,IAAI;AAAA,IACrF,CAAC,KAAK,SAAS,sCAAsC,IAAI,SAAS,SAAS,sBAAsB,GAAG,IAAI;AAAA,IACxG,CAAC,KAAK,SAAS,iCAAiC,IAAI,SAAS,SAAS,kBAAkB,GAAG,IAAI;AAAA,IAC/F,CAAC,KAAK,SAAS,qBAAqB,IAAI,SAAS,SAAS,qBAAqB,GAAG,IAAI;AAAA,IAEtF,CAAC,KAAK,SAAS,6BAA6B,IAAI,SAAS,SAAS,aAAa,GAAG,IAAI;AAAA,IACtF,CAAC,KAAK,SAAS,uCAAuC,IAAI,SAAS,SAAS,sBAAsB,GAAG,IAAI;AAAA,IACzG,CAAC,KAAK,SAAS,kCAAkC,IAAI,SAAS,SAAS,kBAAkB,GAAG,IAAI;AAAA,IAChG,CAAC,KAAK,SAAS,sBAAsB,IAAI,SAAS,SAAS,qBAAqB,GAAG,IAAI;AAAA,IAEvF,CAAC,KAAK,SAAS,sBAAsB,IAAI,SAAS,QAAQ,oBAAoB,GAAG,IAAI;AAAA,IACrF,CAAC,KAAK,SAAS,qBAAqB,IAAI,SAAS,QAAQ,mBAAmB,GAAG,IAAI;AAAA,IACnF,CAAC,KAAK,SAAS,4BAA4B,IAAI,SAAS,QAAQ,sBAAsB,GAAG,IAAI;AAAA,IAE7F,CAAC,KAAK,SAAS,mBAAmB,IAAI,SAAS,WAAW,yBAAyB,GAAG,IAAI;AAAA,IAC1F,CAAC,KAAK,SAAS,qBAAqB,IAAI,SAAS,WAAW,gBAAgB,GAAG,IAAI;AAAA,IACnF,CAAC,KAAK,SAAS,wBAAwB,IAAI,SAAS,iBAAiB,WAAW,GAAG,IAAI;AAAA,IACvF,CAAC,KAAK,SAAS,wBAAwB,IAAI,SAAS,iBAAiB,WAAW,GAAG,IAAI;AAAA,IAEvF,CAAC,KAAK,SAAS,cAAc,IAAI,SAAS,WAAW,YAAY,GAAG,IAAI;AAAA,EACzE;AAAA,EAED,OAAO;AAAA,EAEP,OAAO,aAAa;AAClB,qBAAiB,WAAU;AAC3B,SAAK,UAAU,UAAU,eAAe,UAAU,WAAW;AAC7D,aAAS,CAAC,KAAK,aAAa,OAAO,QAAQ,KAAK,QAAQ,GAAG;AACzD,WAAK,QAAQ,SAAS,KAAK,QAAQ;AACnC,YAAM,8BAA8B,KAAK;AAAA,IAC1C;AAAA,EACF;AAAA,EAED,OAAO,YAAY,YAAY,MAAM;AACnC,WAAO,KAAK,QAAQ,YAAY,SAAS,GAAG,IAAI;AAAA,EACjD;AAAA,EAED,OAAO,cAAc,SAAS,WAAW,MAAM;AAC7C,WAAO,KAAK,QAAQ,cAAc,SAAS,QAAQ,GAAG,IAAI;AAAA,EAC3D;AAAA,EAED,OAAO,iBAAiB,YAAY,MAAM;AACxC,WAAO,KAAK,QAAQ,iBAAiB,SAAS,GAAG,IAAI;AAAA,EACtD;AAAA,EAED,OAAO,mBAAmB,YAAY,MAAM;AAC1C,WAAO,KAAK,QAAQ,mBAAmB,SAAS,GAAG,IAAI;AAAA,EACxD;AAAA,EAED,OAAO,mBAAmB,YAAY,MAAM;AAC1C,WAAO,KAAK,QAAQ,mBAAmB,SAAS,GAAG,IAAI;AAAA,EACxD;AAAA,EAED,OAAO,iBAAiB,YAAY,MAAM;AACxC,WAAO,KAAK,QAAQ,iBAAiB,SAAS,GAAG,IAAI;AAAA,EACtD;AAAA,EAED,OAAO,gBAAgB,SAAS,YAAY,MAAM;AAChD,WAAO,KAAK,QAAQ,gBAAgB,SAAS,SAAS,GAAG,IAAI;AAAA,EAC9D;AAAA,EAED,OAAO,SAAS,SAAS,MAAM;AAC7B,QAAI,CAACuD,MAAc;AAAK;AACxB,WAAO,KAAK,QAAQ,mBAAmB,KAAK,SAAS,WAAW,MAAM,GAAG,IAAI;AAAA,EAC9E;AAAA,EAED,OAAO,iBAAiB,MAAM,UAAU,MAAM;AAC5C,QAAI,CAACA,MAAc;AAAK;AACxB,WAAO,KAAK,QAAQ,gBAAgB,KAAK,SAAS,WAAW,OAAO,MAAM,GAAG,IAAI;AAAA,EAClF;AAEH;AA/KqB;AAiLrB,wBAAwB,SAAS,MAAM;AACrC,QAAM,UAAU,CAAA;AAChB,WAAS,OAAO,MAAM;AACpB,QAAI,aAAa,GAAG,GAAG;AACrB,YAAM,UAAU,aAAa,GAAG;AAChC,UAAI,SAAS;AACX,cAAM;AAAA,MACP;AAAA,IACF;AACD,YAAQ,KAAK,GAAG;AAAA,EACjB;AACD,SAAO,MAAM,QAAQ,MAAM,GAAG,OAAO;AACvC;AAZe;AAcR,MAAM,mBAAmB;AAAA,EAE9B,OAAO,CAAE;AAAA,EAET,aAAa;AACX,SAAK,QAAQ;AACb,UAAM,GAAG,oBAAoB,MAAM;AACjC,YAAM,KAAK,KAAK,KAAK,EAAE,QAAQ,UAAQ;AACrC,YAAI,CAAC,KAAK,MAAM,KAAK,OAAO,CAAC,KAAK,QAAQ;AACxC,eAAK,MAAM,KAAK,MAAM,oBAAI,IAAG;AAAA,QAC9B;AAAA,MACT,CAAO;AAAA,IACP,CAAK;AACD,UAAM,GAAG,MAAM,gBAAgB,CAAC,QAAQ;AACtC,qBAAe,iBAAiB,eAAe,SAAS,uBAAuB,KAAK,KAAK,IAAI,IAAI,EAAE;AAAA,IACzG,CAAK;AACD,UAAM,GAAG,MAAM,iBAAiB,CAAC,QAAQ;AACvC,qBAAe,iBAAiB,eAAe,SAAS,uBAAuB,KAAK,KAAK,IAAI,IAAI,EAAE;AAAA,IACzG,CAAK;AAAA,EACF;AAAA,EAED,WAAW,QAAQ,IAAI;AACrB,SAAK,MAAM,QAAQ,IAAI,EAAE;AAAA,EAC1B;AAAA,EAED,WAAW,QAAQ,IAAI;AACrB,SAAK,MAAM,QAAQ,OAAO,EAAE;AAAA,EAC7B;AAAA,EAED,SAAS,IAAI;AACX,WAAO,OAAO,OAAO,KAAK,KAAK,EAAE,KAAK,mBAAiB;AACrD,aAAO,cAAc,IAAI,EAAE;AAAA,IACjC,CAAK;AAAA,EACF;AAEH;AChOA,MAAM,MAAM;AAAA,EAOV,IAAI,mBAAmB;AACrB,WAAOvD,WAAmB,SAAS,gBAAgB;AAAA,EACpD;AAAA,EAOD,IAAI,aAAa;AACf,WAAOA,WAAmB,SAAS,UAAU;AAAA,EAC9C;AAAA,EAOD,IAAI,uBAAuB;AACzB,WAAOA,WAAmB,SAAS,oBAAoB;AAAA,EACxD;AAAA,EAOD,IAAI,0BAA0B;AAC5B,WAAOA,WAAmB,SAAS,uBAAuB;AAAA,EAC3D;AAAA,EAOD,IAAI,eAAe;AACjB,WAAOA,WAAmB,SAAS,YAAY;AAAA,EAChD;AAAA,EAOD,IAAI,oBAAoB;AACtB,WAAOA,WAAmB,SAAS,iBAAiB;AAAA,EACrD;AAAA,EAQD,kBAAkB,aAAa;AAC7B,QAAI,OAAO,gBAAgB,UAAU;AACnC,YAAM+B,aAAqB,wDAAwD;AAAA,IACpF;AACD,WAAOsE,WAAmB,SAAS,kBAAkB,WAAW;AAAA,EACjE;AAAA,EAQD,cAAc,cAAc;AAC1B,QAAI,CAAC,MAAM,QAAQ,YAAY,GAAG;AAChC,YAAMtE,aAAqB,+CAA+C;AAAA,IAC3E;AAED,iBAAa,QAAQ,cAAY;AAC/B,UAAI,OAAO,aAAa,UAAU;AAChC,cAAMA,aAAqB,mEAAmE;AAAA,MAC/F;AACD,UAAI,OAAO,SAAS,YAAY,WAAW;AACzC,cAAMA,aAAqB,0DAA0D;AAAA,MACtF;AACD,UAAI,OAAO,SAAS,SAAS,UAAU;AACrC,cAAMA,aAAqB,sDAAsD;AAAA,MAClF;AACD,UAAI,OAAO,SAAS,iBAAiB,UAAU;AAC7C,cAAMA,aAAqB,8DAA8D;AAAA,MAC1F;AACD,UAAI,OAAO,SAAS,aAAa,UAAU;AACzC,cAAMA,aAAqB,0DAA0D;AAAA,MACtF;AACD,UAAI,OAAO,SAAS,SAAS,UAAU;AACrC,cAAMA,aAAqB,sDAAsD;AAAA,MAClF;AACD,UAAI,SAAS,OAAO,OAAO,SAAS,QAAQ,UAAU;AACpD,cAAMA,aAAqB,qDAAqD;AAAA,MACjF;AAAA,IACP,CAAK;AAED,WAAOsE,WAAmB,SAAS,YAAY,YAAY;AAAA,EAC5D;AAAA,EAQD,sBAAsB,aAAa;AACjC,QAAI,OAAO,gBAAgB,UAAU;AACnC,YAAMtE,aAAqB,4DAA4D;AAAA,IACxF;AACD,WAAOsE,WAAmB,SAAS,sBAAsB,WAAW;AAAA,EACrE;AAAA,EAQD,yBAAyB,aAAa;AACpC,QAAI,OAAO,gBAAgB,UAAU;AACnC,YAAMtE,aAAqB,+DAA+D;AAAA,IAC3F;AACD,WAAOsE,WAAmB,SAAS,yBAAyB,WAAW;AAAA,EACxE;AAAA,EAQD,eAAe,WAAW;AACxB,QAAI,CAAC,MAAM,QAAQ,SAAS,GAAG;AAC7B,YAAMtE,aAAqB,kDAAkD;AAAA,IAC9E;AACD,cAAU,QAAQ,YAAU;AAC1B,UAAI,OAAO,QAAQ,SAAS,UAAU;AACpC,cAAMA,aAAqB,0GAA4G;AAAA,MACxI;AACD,UAAI,OAAO,QAAQ,YAAY,UAAU;AACvC,cAAMA,aAAqB,6GAA+G;AAAA,MAC3I;AAAA,IACP,CAAK;AACD,WAAOsE,WAAmB,SAAS,cAAc,SAAS;AAAA,EAC3D;AAAA,EAQD,oBAAoB,SAAS;AAC3B,QAAI,CAAC,MAAM,QAAQ,OAAO,GAAG;AAC3B,YAAMtE,aAAqB,qDAAqD;AAAA,IACjF;AACD,YAAQ,QAAQ,UAAQ;AACtB,UAAI,OAAO,SAAS,UAAU;AAC5B,cAAMA,aAAqB,oEAAoE;AAAA,MAChG;AAAA,IACP,CAAK;AACD,WAAOsE,WAAmB,SAAS,mBAAmB,OAAO;AAAA,EAC9D;AAAA,EAED,mBAAmB,QAAQ,OAAO;AAChC,QAAI,SAAS,iBAAiB,OAAO;AACnC,aAAOC,wBAAsC,KAAK;AAAA,IACnD;AACD,WAAO,KAAK,WAAW,KAAK,cAAY,SAAS,OAAO;AAAA,EACzD;AAAA,EAcD,eAAe,UAAU;AAAA,IACvB,UAAU,KAAK,KAAK;AAAA,IAAa,QAAQ;AAAA,IAAO,gBAAgB;AAAA,MAC9D,IAAI;AAEN,QAAI,eAAe;AACjB,YAAM,YAAY,KAAK,OAAO,QAAQ,aAAa;AACnD,UAAI,CAAC,WAAW;AACd,cAAMvE,aAAqB,kCAAkC,kBAAkB,IAAI;AAAA,MAC3F,WAAiB,CAACP,gBAA8B,SAAS,GAAG;AACpD,cAAMO,aAAqB,sBAAsB,kDAAkD,IAAI;AAAA,MACxG;AAAA,IACF;AAED,QAAI,OAAO;AACT,cAAQ,MAAM,IAAI,UAAQ;AACxB,eAAO,gBAAgB,OAAO,KAAK,SAAQ,IAAK;AAAA,MACxD,CAAO;AAAA,IACF;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,aAAa,SAAS,UAAU,EAAE,eAAe,MAAO,CAAA;AAAA,EACnH;AAAA,EAWD,wBAAwB,SAAS,EAAE,eAAe,CAAE,GAAE,gBAAgB,CAAA,MAAO,IAAI;AAE/E,QAAI,CAAC,MAAM,QAAQ,OAAO;AAAG,gBAAU,CAAC,OAAO;AAE/C,UAAM,cAAc,QAAQ,IAAI,YAAU;AACxC,UAAI,CAAE,mBAAkB,SAAS,kBAAkB,gBAAgB;AACjE,cAAMA,aAAqB,2EAA2E,IAAI;AAAA,MAC3G;AACD,YAAM,aAAa5B,QAAkB,MAAM;AAC3C,UAAI,CAAC;AAAY,cAAM4B,aAAqB,yFAAyF,IAAI;AACzI,aAAO;AAAA,IACb,CAAK;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,gBAAgB,aAAa,cAAc,aAAa;AAAA,EACnH;AAAA,EAUD,0BAA0B,SAAS,EAAE,gBAAgB,CAAE,MAAK,CAAA,GAAI;AAE9D,QAAI,CAAC,MAAM,QAAQ,OAAO;AAAG,gBAAU,CAAC,OAAO;AAE/C,UAAM,cAAc,QAAQ,IAAI,YAAU;AACxC,UAAI,CAAE,mBAAkB,SAAS,kBAAkB,gBAAgB;AACjE,cAAMA,aAAqB,6EAA6E,IAAI;AAAA,MAC7G;AACD,YAAM,aAAa5B,QAAkB,MAAM;AAC3C,UAAI,CAAC;AAAY,cAAM4B,aAAqB,2FAA2F,IAAI;AAC3I,aAAO;AAAA,IACb,CAAK;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,kBAAkB,aAAa,aAAa;AAAA,EACvG;AAAA,EAUD,aAAa,QAAQ,mBAAmB,OAAO;AAC7C,UAAM,cAAcjC,SAAmB,MAAM;AAC7C,UAAM,2BAA2B,mBAAmBA,SAAmB,gBAAgB,IAAI;AAC3F,UAAM,OAAO2B,iBAA+B,WAAW;AACvD,QAAI,CAAC,MAAM,WAAW,CAAC,MAAM;AAAa,aAAO;AACjD,UAAM,YAAY,KAAK;AACvB,UAAM,YAAY,KAAK;AACvB,SAAK,SAAS;AACd,SAAK,SAAS;AACd,QAAI,WAAW;AACb,YAAM,cAAa8B,MAAc,KAAK,MAAM,KAAK,YAAY,aAAa,MAAM,wBAAwB;AACxG,UAAI,gBAAe;AAAO,eAAO;AAAA,IAClC;AACD,UAAM,aAAaA,MAAc,KAAK,MAAM,KAAK,UAAU,aAAa,MAAM,wBAAwB;AACtG,QAAI,eAAe;AAAO,aAAO;AACjC,QAAI,aAAa,KAAK,WAAW;AAC/B,kBAAY,KAAK,EAAE,KAAK,KAAK,UAAS,CAAE;AAAA,IACzC;AACD,WAAO,KAAK,eAAe,aAAa,MAAM,EAAE,kBAAkB,yBAAwB,CAAE;AAAA,EAC7F;AAAA,EAUD,cAAc,QAAQ,mBAAmB,OAAO;AAC9C,UAAM,cAAczD,SAAmB,MAAM;AAC7C,UAAM,2BAA2B,mBAAmBA,SAAmB,gBAAgB,IAAI;AAC3F,UAAM,WAAW2B,iBAA+B,WAAW;AAC3D,QAAI,CAAC,UAAU,WAAW,CAAC,UAAU;AAAa,aAAO;AAEzD,UAAM,UAAU,CAAC,SAAS;AAC1B,aAAS,SAAS;AAElB,UAAM,aAAa8B,MAAc,KAAK,MAAM,KAAK,WAAW,aAAa,UAAU,wBAAwB;AAC3G,QAAI,eAAe;AAAO,aAAO;AAEjC,QAAI,WAAW,SAAS,YAAY;AAClC,kBAAY,KAAK,EAAE,KAAK,SAAS,WAAU,CAAE;AAAA,IAC9C;AAED,WAAO,KAAK,eAAe,aAAa,UAAU,EAAE,kBAAkB,yBAAwB,CAAE;AAAA,EACjG;AAAA,EAUD,MAAM,qBAAqB,QAAQ,mBAAmB,OAAO;AAC3D,UAAM,cAAczD,SAAmB,MAAM;AAC7C,UAAM,2BAA2B,mBAAmBA,SAAmB,gBAAgB,IAAI;AAC3F,UAAM,WAAW2B,iBAA+B,WAAW;AAC3D,QAAI,CAAC,UAAU,WAAW,CAAC,UAAU;AAAa,aAAO;AACzD,QAAI,SAAS,QAAQ;AACnB,YAAM,KAAK,aAAa,aAAa,wBAAwB;AAAA,IACnE,OAAW;AACL,YAAM,KAAK,cAAc,aAAa,wBAAwB;AAAA,IAC/D;AACD,WAAO,CAAC,SAAS;AAAA,EAClB;AAAA,EAUD,aAAa,QAAQ,mBAAmB,OAAO;AAC7C,UAAM,cAAc3B,SAAmB,MAAM;AAC7C,UAAM,2BAA2B,mBAAmBA,SAAmB,gBAAgB,IAAI;AAC3F,UAAM,WAAW2B,iBAA+B,WAAW;AAC3D,QAAI,CAAC,UAAU,WAAW,CAAC,UAAU;AAAa,aAAO;AACzD,UAAM,YAAY,SAAS;AAC3B,aAAS,SAAS;AAClB,aAAS,SAAS;AAClB,QAAI,CAAC,WAAW;AACd,YAAM,cAAa8B,MAAc,KAAK,MAAM,KAAK,WAAW,aAAa,UAAU,wBAAwB;AAC3G,UAAI,gBAAe;AAAO,eAAO;AAAA,IAClC;AACD,UAAM,aAAaA,MAAc,KAAK,MAAM,KAAK,UAAU,aAAa,UAAU,wBAAwB;AAC1G,QAAI,eAAe;AAAO,aAAO;AACjC,QAAI,CAAC,aAAa,SAAS,YAAY;AACrC,kBAAY,KAAK,EAAE,KAAK,SAAS,WAAU,CAAE;AAAA,IAC9C;AACD,WAAO,KAAK,eAAe,aAAa,UAAU,EAAE,kBAAkB,yBAAwB,CAAE;AAAA,EACjG;AAAA,EAUD,eAAe,QAAQ,mBAAmB,OAAO;AAC/C,UAAM,cAAczD,SAAmB,MAAM;AAC7C,UAAM,2BAA2B,mBAAmBA,SAAmB,gBAAgB,IAAI;AAC3F,UAAM,WAAW2B,iBAA+B,WAAW;AAC3D,QAAI,CAAC,UAAU,WAAW,CAAC,UAAU;AAAa,aAAO;AACzD,aAAS,SAAS;AAClB8B,UAAc,KAAK,MAAM,KAAK,YAAY,aAAa,UAAU,wBAAwB;AACzF,WAAO,KAAK,eAAe,aAAa,UAAU,EAAE,kBAAkB,yBAAwB,CAAE;AAAA,EACjG;AAAA,EAUD,qBAAqB,QAAQ,mBAAmB,OAAO;AACrD,UAAM,cAAczD,SAAmB,MAAM;AAC7C,UAAM,2BAA2B,mBAAmBA,SAAmB,gBAAgB,IAAI;AAC3F,UAAM,WAAW2B,iBAA+B,WAAW;AAC3D,QAAI,CAAC,UAAU,WAAW,CAAC,UAAU;AAAa,aAAO;AACzD,QAAI,SAAS,QAAQ;AACnB,aAAO,KAAK,eAAe,aAAa,wBAAwB;AAAA,IACjE;AACD,WAAO,KAAK,aAAa,aAAa,wBAAwB;AAAA,EAC/D;AAAA,EAUD,eAAe,QAAQ,mBAAmB,OAAO;AAC/C,UAAM,cAAc3B,SAAmB,MAAM;AAC7C,UAAM,2BAA2B,mBAAmBA,SAAmB,gBAAgB,IAAI;AAE3F,UAAM,WAAW2B,iBAA+B,WAAW;AAE3D,QAAI,CAAC,UAAU,WAAW,CAAC,UAAU,eAAe,CAAC,UAAU;AAAQ,aAAO;AAE9E8B,UAAc,KAAK,MAAM,KAAK,YAAY,aAAa,UAAU,wBAAwB;AAEzF,QAAI,SAAS,aAAa;AACxB,kBAAY,KAAK,EAAE,KAAK,SAAS,YAAW,CAAE;AAAA,IAC/C;AAED,WAAO,eAAe,mBAAmB,eAAe,SAAS,WAAW,MAAM,KAAK,QAAQpD,QAAkB,WAAW,GAAG,UAAUA,QAAkB,wBAAwB,CAAC;AAAA,EACrL;AAAA,EASD,iBAAiB,QAAQ;AACvB,WAAOoG,iBAA+B,MAAM;AAAA,EAC7C;AAAA,EASD,iBAAiB,QAAQ;AACvB,WAAOC,iBAA+B,MAAM;AAAA,EAC7C;AAAA,EASD,oBAAoB,QAAQ;AAC1B,WAAOC,oBAAkC,MAAM;AAAA,EAChD;AAAA,EAYD,eAAe,QAAQ,SAAS,EAAE,mBAAmB,OAAO,gBAAgB,UAAU,IAAI;AAExF,UAAM,aAAatG,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,gFAAgF,IAAI;AAEhI,UAAM,uBAAuB,mBAAmB5B,QAAkB,gBAAgB,IAAI;AACtF,QAAI,oBAAoB,CAAC;AAAsB,YAAM4B,aAAqB,gFAAgF,IAAI;AAE9J,WAAO,eAAe,YAAY,eAAe,SAAS,aAAa,YAAY,SAAS;AAAA,MAC1F;AAAA,MAAsB;AAAA,IAC5B,CAAK;AAAA,EACF;AAAA,EASD,eAAe,QAAQ;AACrB,QAAI,CAACP,gBAA8B,MAAM,GAAG;AAC1C,YAAMO,aAAqB,4EAA4E,IAAI;AAAA,IAC5G;AACD,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,gFAAgF,IAAI;AAChI,QAAI,CAAC,WAAW,SAAS,OAAO,GAAG;AACjC,YAAMA,aAAqB,4DAA4D,IAAI;AAAA,IAC5F;AACD,WAAO,eAAe,YAAY,eAAe,SAAS,aAAa,UAAU;AAAA,EAClF;AAAA,EAUD,sBAAsB,QAAQ,EAAE,UAAU,OAAO,aAAa,UAAU,IAAI;AAE1E,QAAI,CAACP,gBAA8B,MAAM;AAAG,aAAO;AAEnD,UAAM,eAAerB,QAAkB,MAAM;AAC7C,QAAI,CAAC;AAAc,YAAM4B,aAAqB,0FAA0F,IAAI;AAE5I,UAAM,gBAAgBjC,SAAmB,MAAM;AAE/C,QAAI,SAAS;AACX,UAAI,CAAC,MAAM,QAAQ,OAAO,GAAG;AAC3B,kBAAU,CAAC,OAAO;AAAA,MACnB;AACD,cAAQ,QAAQ,WAAS;AACvB,YAAI,CAAE,kBAAiB,iBAAiB,iBAAiB,QAAQ;AAC/D,gBAAMiC,aAAqB,+FAA+F;AAAA,QAC3H;AAAA,MACT,CAAO;AACD,gBAAU,QAAQ,IAAI,aAAU,SAAQ,aAAa,SAAQ,SAAS,OAAM;AAAA,IAC7E;AAED,QAAI,cAAc,CAAE,uBAAsB,iBAAiB,sBAAsB,QAAQ;AACvF,YAAMA,aAAqB,2EAA2E;AAAA,IACvG;AAED,UAAM,aAAc,YAAWsB,sBAAuC,aAAa,EAAE,IAAI,OAAK,EAAE,SAAS,GAAG,IAAI,WAASlD,QAAkB,KAAK,CAAC;AAEjJ,WAAO,eAAe,YAAY,eAAe,SAAS,YAAY,cAAc,YAAY,KAAK,KAAK,IAAI,UAAU;AAAA,EAEzH;AAAA,EAcD,SAAS,QAAQ,OAAO,EAAE,oBAAoB,MAAM,gBAAgB,UAAU,IAAI;AAChF,UAAM,aAAaA,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,0EAA0E,IAAI;AAE1H,UAAM,aAAa,CAAE;AACrB,UAAM,QAAQ,cAAY;AAExB,UAAI,OAAO;AACX,UAAI,oBAAoB,MAAM;AAC5B,eAAO,SAAS;MACxB,WAAiB,SAAS,gBAAgB,MAAM;AACxC,eAAO,SAAS,KAAK;MAC7B,WAAiB,SAAS,MAAM;AACxB,eAAO,SAAS;AAAA,MACjB;AAED,UAAI,UAAU,aAAa,QAAW;AACpC,oBAAY,MAAM,KAAK,UAAU,yBAAyB,UAAU,QAAQ;AAAA,MAC7E;AAED,YAAM,gBAAgB,oBAAoB9B,gBAA0B,YAAY,IAAI,IAAI;AACxF,UAAI,eAAe;AACjB,oBAAY,eAAe,KAAK,UAAU,yBAAyBC,gBAA0B,aAAa,IAAIA,gBAA0B,IAAI,CAAC;AAAA,MACrJ,OAAa;AACL,mBAAW,KAAK,IAAI;AAAA,MACrB;AAAA,IAEP,CAAK;AAED,QAAI,eAAe;AACjB,UAAI,OAAO,kBAAkB;AAAU,cAAM6B,aAAqB,iDAAiD;AAAA,IACpH;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,WAAW,YAAY,YAAY,KAAK,KAAK,IAAI,EAAE,cAAe,CAAA;AAAA,EAC7H;AAAA,EAWD,YAAY,QAAQ,OAAO,EAAE,gBAAgB,UAAU,IAAI;AAEzD,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,6EAA6E,IAAI;AAE7H,UAAM,mBAAmB,KAAK,UAAU,cAAc,MAAM;AAE5D,YAAQ,MAAM,IAAI,cAAY;AAE5B,UAAI;AACJ,UAAI,OAAO,aAAa,YAAY,SAAS,KAAK;AAChD,cAAM,SAAS,OAAO,aAAa,WAAW,WAAW,SAAS;AAClE,eAAO,iBAAiB,KAAK,eAAa,UAAU,OAAO,MAAM;AACjE,YAAI,CAAC,MAAM;AACT,gBAAMA,aAAqB,8CAA8C,sBAAsB,eAAe,IAAI;AAAA,QACnH;AACD,eAAO,KAAK;MACpB,OAAa;AACL,YAAI,SAAS,gBAAgB,MAAM;AACjC,iBAAO,SAAS,KAAK;QAC/B,WAAmB,oBAAoB,MAAM;AACnC,iBAAO,SAAS;QAC1B,OAAe;AACL,iBAAO,SAAS;AAAA,QACjB;AACD,YAAI,iBAAiB,iBAAiB,KAAK,eAAa,UAAU,OAAO,KAAK,GAAG;AACjF,YAAI,CAAC,gBAAgB;AACnB,gBAAMA,aAAqB,8CAA8C,KAAK,mBAAmB,eAAe,IAAI;AAAA,QACrH;AAAA,MACF;AAED,aAAO;AAAA,QACL,KAAK,KAAK;AAAA,QAAK,UAAU,UAAU,YAAY7B,gBAA0B,IAAI;AAAA,MAC9E;AAAA,IACP,CAAK;AAED,QAAI,eAAe;AACjB,UAAI,OAAO,kBAAkB;AAAU,cAAM6B,aAAqB,oDAAoD;AAAA,IACvH;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,cAAc,YAAY,OAAO,KAAK,KAAK,IAAI,EAAE,cAAe,CAAA;AAAA,EAC3H;AAAA,EAYD,cAAc,QAAQ,QAAQ,OAAO,EAAE,gBAAgB,UAAU,IAAI;AAEnE,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,+EAA+E,IAAI;AAE/H,UAAM,mBAAmBe,cAA4B,MAAM;AAE3D,YAAQ,MAAM,IAAI,cAAY;AAE5B,UAAI;AACJ,UAAI,OAAO,aAAa,YAAY,SAAS,KAAK;AAChD,cAAM,SAAS,OAAO,aAAa,WAAW,WAAW,SAAS;AAClE,eAAO,iBAAiB,KAAK,eAAa,UAAU,OAAO,MAAM;AACjE,YAAI,CAAC,MAAM;AACT,gBAAMf,aAAqB,gDAAgD,sBAAsB,eAAe,IAAI;AAAA,QACrH;AACD,eAAO,KAAK;MACpB,WAAiB,oBAAoB,MAAM;AACnC,eAAO,SAAS;MACxB,WAAiB,SAAS,gBAAgB,MAAM;AACxC,eAAO,SAAS,KAAK;MAC7B,OAAa;AACL,eAAO,SAAS;AAAA,MACjB;AAED,UAAI,iBAAiB,iBAAiB,KAAK,eAAa,UAAU,OAAO,KAAK,GAAG;AACjF,UAAI,CAAC,gBAAgB;AACnB,cAAMA,aAAqB,gDAAgD,KAAK,mBAAmB,eAAe,IAAI;AAAA,MACvH;AAED,aAAO;AAAA,QACL,KAAK,KAAK;AAAA,QAAK,UAAU,KAAK,IAAK,UAAU,YAAY,KAAM7B,gBAA0B,QAAQ,CAAC;AAAA,MACnG;AAAA,IACP,CAAK;AAED,UAAM,aAAaC,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,+EAA+E,IAAI;AAE/H,QAAI,eAAe;AACjB,UAAI,OAAO,kBAAkB;AAAU,cAAMA,aAAqB,sDAAsD;AAAA,IACzH;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,gBAAgB,YAAY,YAAY,OAAO,KAAK,KAAK,IAAI,EAAE,cAAe,CAAA;AAAA,EAEzI;AAAA,EAYD,iBAAiB,QAAQ,QAAQ,EAAE,cAAc,OAAO,gBAAgB,UAAU,IAAI;AAEpF,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,kFAAkF,IAAI;AAElI,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,kFAAkF,IAAI;AAElI,QAAI,aAAa;AACf,UAAI,CAAC,MAAM,QAAQ,WAAW;AAAG,cAAMA,aAAqB,sDAAsD;AAClH,kBAAY,QAAQ,WAAS;AAC3B,YAAI,OAAO,OAAO,SAAS;AAAU,gBAAMA,aAAqB,qGAAqG;AACrK,YAAI,OAAO,OAAO,WAAW;AAAU,gBAAMA,aAAqB,uGAAuG;AAAA,MACjL,CAAO;AAAA,IACF;AAED,QAAI,eAAe;AACjB,UAAI,OAAO,kBAAkB;AAAU,cAAMA,aAAqB,yDAAyD;AAAA,IAC5H;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,oBAAoB,YAAY,YAAY,KAAK,KAAK,IAAI;AAAA,MAClH;AAAA,MAAa;AAAA,IACnB,CAAK;AAAA,EACF;AAAA,EAYD,cAAc,QAAQ,YAAY,EAAE,gBAAgB,UAAU,IAAI;AAEhE,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,+EAA+E,IAAI;AAE/H,UAAM,cAAcjC,SAAmB,MAAM;AAE7C,WAAO,QAAQ,UAAU,EAAE,QAAQ,WAAS;AAC1C,YAAM,CAAC,WAAW,YAAY;AAC9B,UAAI,CAAC,YAAY,YAAY,MAAM,SAAS,GAAG;AAC7C,cAAMiC,aAAqB,4CAA4C,0CAA0C,eAAe,IAAI;AAAA,MACrI;AACD,UAAI,CAAC2E,aAAqB,QAAQ,KAAK,WAAW,GAAG;AACnD,cAAM3E,aAAqB,8BAA8B,wDAAwD,IAAI;AAAA,MACtH;AAAA,IACP,CAAK;AAED,QAAI,eAAe;AACjB,UAAI,OAAO,kBAAkB;AAAU,cAAMA,aAAqB,sDAAsD;AAAA,IACzH;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,eAAe,YAAY,YAAY,KAAK,KAAK,IAAI,EAAE,cAAe,CAAA;AAAA,EAEjI;AAAA,EAWD,iBAAiB,QAAQ,YAAY,EAAE,gBAAgB,UAAU,IAAI;AAEnE,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,kFAAkF,IAAI;AAElI,UAAM,cAAcjC,SAAmB,MAAM;AAE7C,QAAI,MAAM,QAAQ,UAAU,GAAG;AAC7B,iBAAW,QAAQ,eAAa;AAC9B,YAAI,OAAO,cAAc,UAAU;AACjC,gBAAMiC,aAAqB,yEAAyE,IAAI;AAAA,QACzG;AACD,YAAI,CAAC,YAAY,YAAY,MAAM,SAAS,GAAG;AAC7C,gBAAMA,aAAqB,+CAA+C,0CAA0C,eAAe,IAAI;AAAA,QACxI;AAAA,MACT,CAAO;AAAA,IACP,OAAW;AACL,aAAO,QAAQ,UAAU,EAAE,QAAQ,WAAS;AAC1C,cAAM,CAAC,WAAW,YAAY;AAC9B,YAAI,CAAC,YAAY,YAAY,MAAM,SAAS,GAAG;AAC7C,gBAAMA,aAAqB,+CAA+C,0CAA0C,eAAe,IAAI;AAAA,QACxI;AACD,YAAI,CAAC,eAAe,QAAQ,KAAK,WAAW,GAAG;AAC7C,gBAAMA,aAAqB,iCAAiC,wDAAwD,IAAI;AAAA,QACzH;AAAA,MACT,CAAO;AAAA,IACF;AAED,QAAI,eAAe;AACjB,UAAI,OAAO,kBAAkB;AAAU,cAAMA,aAAqB,yDAAyD;AAAA,IAC5H;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,mBAAmB,YAAY,YAAY,KAAK,KAAK,IAAI,EAAE,cAAe,CAAA;AAAA,EAErI;AAAA,EAYD,mBAAmB,QAAQ,QAAQ,YAAY,EAAE,gBAAgB,UAAU,IAAI;AAE7E,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,oFAAoF,IAAI;AACpI,UAAM,cAAcjC,SAAmB,MAAM;AAE7C,UAAM,aAAaK,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,oFAAoF,IAAI;AACpI,UAAM,cAAcjC,SAAmB,MAAM;AAE7C,QAAI,MAAM,QAAQ,UAAU,GAAG;AAC7B,iBAAW,QAAQ,eAAa;AAC9B,YAAI,OAAO,cAAc,UAAU;AACjC,gBAAMiC,aAAqB,2EAA2E,IAAI;AAAA,QAC3G;AACD,YAAI,CAAC,YAAY,YAAY,MAAM,SAAS,GAAG;AAC7C,gBAAMA,aAAqB,iDAAiD,0CAA0C,eAAe,IAAI;AAAA,QAC1I;AACD,YAAI,CAAC,YAAY,YAAY,MAAM,SAAS,GAAG;AAC7C,gBAAMA,aAAqB,iDAAiD,0CAA0C,eAAe,IAAI;AAAA,QAC1I;AAAA,MACT,CAAO;AAAA,IACP,OAAW;AACL,aAAO,QAAQ,UAAU,EAAE,QAAQ,WAAS;AAC1C,cAAM,CAAC,WAAW,YAAY;AAC9B,YAAI,CAAC,YAAY,YAAY,MAAM,SAAS,GAAG;AAC7C,gBAAMA,aAAqB,iDAAiD,0CAA0C,eAAe,IAAI;AAAA,QAC1I;AACD,YAAI,CAAC,YAAY,YAAY,MAAM,SAAS,GAAG;AAC7C,gBAAMA,aAAqB,iDAAiD,0CAA0C,eAAe,IAAI;AAAA,QAC1I;AACD,YAAI,CAAC2E,aAAqB,QAAQ,KAAK,WAAW,GAAG;AACnD,gBAAM3E,aAAqB,mCAAmC,wDAAwD,IAAI;AAAA,QAC3H;AAAA,MACT,CAAO;AAAA,IACF;AAED,QAAI,eAAe;AACjB,UAAI,OAAO,kBAAkB;AAAU,cAAMA,aAAqB,2DAA2D;AAAA,IAC9H;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,qBAAqB,YAAY,YAAY,YAAY,KAAK,KAAK,IAAI,EAAE,cAAe,CAAA;AAAA,EAEnJ;AAAA,EAWD,sBAAsB,QAAQ,QAAQ,EAAE,gBAAgB,UAAU,IAAI;AAEpE,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,uFAAuF,IAAI;AAEvI,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,uFAAuF,IAAI;AAEvI,QAAI,eAAe;AACjB,UAAI,OAAO,kBAAkB;AAAU,cAAMA,aAAqB,8DAA8D;AAAA,IACjI;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,yBAAyB,YAAY,YAAY,KAAK,KAAK,IAAI,EAAE,cAAe,CAAA;AAAA,EAE3I;AAAA,EAYD,mBAAmB,QAAQ,QAAQ,EAAE,cAAc,OAAO,gBAAgB,UAAU,IAAI;AAEtF,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,oFAAoF,IAAI;AAEpI,UAAM,aAAa5B,QAAkB,MAAM;AAC3C,QAAI,CAAC;AAAY,YAAM4B,aAAqB,oFAAoF,IAAI;AAEpI,QAAI,aAAa;AACf,UAAI,CAAC,MAAM,QAAQ,WAAW;AAAG,cAAMA,aAAqB,wDAAwD;AACpH,kBAAY,QAAQ,WAAS;AAC3B,YAAI,OAAO,OAAO,SAAS;AAAU,gBAAMA,aAAqB,uGAAuG;AACvK,YAAI,OAAO,OAAO,WAAW;AAAU,gBAAMA,aAAqB,yGAAyG;AAAA,MACnL,CAAO;AAAA,IACF;AAED,QAAI,eAAe;AACjB,UAAI,OAAO,kBAAkB;AAAU,cAAMA,aAAqB,2DAA2D;AAAA,IAC9H;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,qBAAqB,YAAY,YAAY,KAAK,KAAK,IAAI;AAAA,MACnH;AAAA,MAAa;AAAA,IACnB,CAAK;AAAA,EAEF;AAAA,EAED,iBAAiB;AACf,WAAO,eAAe,mBAAmB,eAAe,SAAS,kBAAkB;AAAA,EACpF;AAAA,EAED,aAAa,MAAM;AACjB,WAAO,SAAS,cAAc,IAAI;AAAA,EACnC;AAAA,EAED,cAAc,SAAS;AACrB,WAAO,SAAS,eAAe,OAAO;AAAA,EACvC;AAAA,EAED,wBAAwB,QAAQ;AAAA,IAC9B,UAAU;AAAA,IAAM,mBAAmB;AAAA,IAAM,sBAAsB;AAAA,MAC7D,IAAI;AAEN,UAAM,iBAAiBlC,YAAsB,MAAM;AACnD,UAAM,aAAaM,QAAkB,cAAc;AACnD,QAAI,CAAC;AAAY,YAAM4B,aAAqB,iGAAiG;AAE7I,QAAI,CAACP,gBAA8B,cAAc,GAAG;AAClD,YAAMO,aAAqB,gEAAgE;AAAA,IAC5F;AAED,QAAI,CAAC,oBAAoB,CAAC,qBAAqB;AAC7C,4BAAsB;AAAA,IACvB;AAED,QAAI,oBAAoB,qBAAqB;AAC3C,YAAMA,aAAqB,mIAAmI;AAAA,IAC/J;AAED,UAAM,uBAAuB,mBAAmB5B,QAAkB,gBAAgB,IAAI;AACtF,QAAI,oBAAoB,CAAC;AAAsB,YAAM4B,aAAqB,kGAAkG;AAE5K,QAAI,CAAC,MAAM,QAAQ,OAAO;AAAG,gBAAU,CAAC,KAAK,KAAK,EAAE;AAEpD,QAAI,CAAC,KAAK,KAAK,MAAM;AACnB,UAAI,QAAQ,SAAS,KAAK,CAAC,QAAQ,SAAS,KAAK,KAAK,EAAE,GAAG;AACzD,cAAMA,aAAqB,2GAA2G;AAAA,MACvI;AACD,gBAAU,CAAC,KAAK,KAAK,EAAE;AAAA,IACxB;AAED,QAAI,QAAQ,WAAW,KAAK,QAAQ,OAAO,KAAK,KAAK,IAAI;AACvD,aAAO,WAAW,yBAAyB,YAAY;AAAA,QACrD;AAAA,QACA;AAAA,QACA,QAAQ;AAAA,MAChB,CAAO;AAAA,IACF;AAED,eAAW,UAAU,SAAS;AAC5B,YAAM,OAAO,KAAK,MAAM,IAAI,MAAM;AAClC,UAAI,CAAC;AAAM,cAAMA,aAAqB,8CAA8C,gBAAgB;AACpG,UAAI,qBAAqB;AACvB,YAAI,CAAC,KAAK,WAAW;AACnBiD,yBAAuB,mCAAmC,KAAK,kCAAkC,IAAI;AACrG;AAAA,QACD;AAAA,MACF;AAAA,IACF;AAED,WAAO,eAAe,gBAAgB,eAAe,SAAS,kBAAkB,SAAS,YAAY;AAAA,MACnG;AAAA,MACA;AAAA,MACA,QAAQ;AAAA,IACd,CAAK;AAAA,EAEF;AAAA,EAED,iBAAiB,MAAM,EAAE,SAAS,OAAO,QAAQ,OAAO,WAAW,MAAM,IAAI;AAE3E,QAAI,CAAE,iBAAgB,OAAO;AAC3B,YAAMjD,aAAqB,wDAAwD;AAAA,IACpF;AAED,QAAI,QAAQ;AACV,eAASjC,SAAmB,MAAM;AAClC,UAAI,CAAC,QAAQ;AACX,cAAMiC,aAAqB,6DAA6D;AAAA,MACzF;AAAA,IACP,OAAW;AACL,UAAI,CAAC,KAAK,QAAQ;AAChB,cAAMA,aAAqB,6EAA6E;AAAA,MACzG;AACD,eAASjC,SAAmB,KAAK,MAAM;AAAA,IACxC;AAED,QAAI,OAAO;AACT,cAAQA,SAAmB,KAAK;AAChC,UAAI,CAAC,OAAO;AACV,cAAMiC,aAAqB,gEAAgE;AAAA,MAC5F;AAAA,IACF;AAED,WAAO+B,cAA4B,MAAM,EAAE,QAAQ,OAAO,SAAQ,CAAE;AAAA,EAErE;AAAA,EAcD,WAAW,QAAQ,OAAO,OAAO,EAAE,gBAAgB,UAAU,IAAI;AAE/D,UAAM,cAAchE,SAAmB,MAAM;AAC7C,UAAM,aAAaK,QAAkB,WAAW;AAChD,QAAI,CAAC,YAAY;AACf,YAAM4B,aAAqB,kGAAkG,IAAI;AAAA,IAClI;AAED,UAAM,aAAajC,SAAmB,KAAK;AAC3C,UAAM,YAAYK,QAAkB,KAAK;AACzC,QAAI,CAAC,WAAW;AACd,YAAM4B,aAAqB,iGAAiG,IAAI;AAAA,IACjI;AAED,UAAM,cAAc,MAAM,IAAI,UAAQ;AAEpC,aAAO,QAAQ,MAAM,YAAY;AAAA,QAC/B,MAAM;AAAA,QACN,UAAU;AAAA,QACV,cAAc;AAAA,MACf,GAAE,IAAI;AAEP,UAAI,CAAC,KAAK,MAAM;AACd,cAAMA,aAAqB,0CAA0C,IAAI;AAAA,MAC1E;AAED,UAAI;AACJ,UAAI,OAAO,KAAK,SAAS,UAAU;AACjC,oBAAY,YAAY,MAAM,IAAI,KAAK,IAAI,KAAK,YAAY,MAAM,QAAQ,KAAK,IAAI;AACnF,YAAI,CAAC,WAAW;AACd,gBAAMA,aAAqB,+DAA+D,KAAK,OAAO;AAAA,QACvG;AAAA,MACT,OAAa;AACL,oBAAY,YAAY,MAAM,IAAI,KAAK,gBAAgB,OAAO,KAAK,KAAK,KAAK,KAAK,KAAK,GAAG,KAAK,YAAY,MAAM,QAAQ,KAAK,KAAK,IAAI;AACvI,YAAI,CAAC,WAAW;AACd,gBAAMA,aAAqB,qDAAqD;AAAA,QACjF;AAAA,MACF;AAED,YAAM,aAAa+B,cAA4B,WAAW;AAAA,QACxD,QAAQ;AAAA,QACR,OAAO;AAAA,QACP,UAAU,KAAK;AAAA,MACvB,CAAO;AACD,UAAI,WAAW,QAAQ;AACrB,YAAI,KAAK,gBAAgB,WAAW,UAAU,KAAK,eAAe,GAAG;AACnE,gBAAM/B,aAAqB,qDAAqD,UAAU,QAAQ,IAAI;AAAA,QACvG;AAED,cAAM,gBAAgB,WAAW,KAAK;AACtC,YAAI,KAAK,WAAW,cAAc,aAAa;AAC7C,gBAAMA,aAAqB,8CAA8C,KAAK,eAAe,UAAU,aAAa,cAAc,gBAAgB,IAAI;AAAA,QACvJ;AAAA,MACF;AAED,aAAO;AAAA,QACL,IAAI,UAAU;AAAA,QACd,UAAU,KAAK;AAAA,QACf,cAAc,KAAK;AAAA,MAC3B;AAAA,IAEA,CAAK;AAED,WAAO,eAAe,YAAY,eAAe,SAAS,aAAa,YAAY,WAAW,aAAa,KAAK,KAAK,IAAI,EAAE,cAAe,CAAA;AAAA,EAE3I;AAEH;;;;;;;;;;;;;;;;;;;AChhCuB,MAAA,WAAA,SAAS,IAAK,GAAA,IAAA;;;;;;;;;;;uBAFD,IAAQ;;gDACL,IAAQ,QAAK,IAAU,IAAA,SAAS,IAAW,GAAC,SAAS,IAAQ,GAAA;;;;AADhF,aAGS,QAAA,QAAA,MAAA;;;;;;2EAFU,IAAQ,QAAK,IAAU,IAAA,SAAS,IAAW,GAAC,SAAS,IAAQ,GAAA,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAF3E,IAAW;mDAAuB,KAAQ;mCAA/C,QAAI,KAAA,GAAA;;;;;;;;;;;;;;AAWiC,MAAA,QAAU,qBAAgB,QAAA;AAA1B,uBAAA,QAAA,QAAU;AAAA;;;;;;;;AAKV,MAAA,QAAU,sBAAiB,QAAA;AAA3B,uBAAA,QAAA,QAAU;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAjB/B,UAAA,QAAU,SAAI;AAAA,4BAAA,qBAAA;;;;;;;;;;;;;AARxC,aA+BK,QAAA,IAAA,MAAA;AA9BH,aAIK,IAAA,GAAA;AAHH,aAEM,KAAA,IAAA;AADJ,aAAyD,MAAA,KAAA;AAApB,YAAA,UAAA,QAAU;;AAGnD,aAWK,IAAA,GAAA;AAVH,aASM,KAAA,IAAA;AARJ,aAOS,MAAA,MAAA;;;;AAPW,oBAAA,QAAA,QAAU,IAAI;;AAUtC,aAIK,IAAA,GAAA;AAHH,aAEM,KAAA,IAAA;;;AAER,aAIK,IAAA,GAAA;AAHH,aAEM,KAAA,IAAA;;;AAER,aAEK,IAAA,GAAA;AADH,aAAoF,KAAA,MAAA;;;;;;;;AAApD,gBAAA,YAAA,IAAO,GAAA,IAAP,GAAA,CAAA;AAAA,qBAAO,IAAK,GAAA,EAAA,MAAA,MAAA,SAAA;AAAA;;;;;;;;AA1BL,cAAA,UAAA,QAAU;AAAA;;uBAMtC,IAAW;;;;AADA,sBAAA,QAAA,QAAU,IAAI;AAAA;;;;AAYO,6BAAA,QAAA,QAAU;;;;;;;AAKV,6BAAA,QAAA,QAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAc9B,MAAA,YAAA,SAAS,6DAA6D,IAAA;;;;;;AAGpE,MAAA,YAAA,SAAS,QAAQ,IAAA;;;;;mBA3CzC,IAAsB;mDAAsB,KAAK;iCAAtD,QAAI,KAAA,GAAA;;;;;;;;;AAhBN,QAAA,cAAA,GAAA,SAAS,kEAAkE;;;;;;AAMlD,UAAA,cAAA,GAAA,SAAS,+DAA+D;;;AACvE,UAAA,cAAA,GAAA,SAAS,+DAA+D;;;AACxE,UAAA,cAAA,GAAA,SAAS,kEAAkE;;;AAC3E,UAAA,cAAA,GAAA,SAAS,mEAAmE;;;;;;;;;;;;;;;;;;;;;;;;AAE9C,mBAAA,MAAA,6BAAA,OAAY,MAAM;;;;;;;;;;;AAbhF,aAiEO,QAAA,QAAA,MAAA;AA/DL,aAAqF,QAAA,CAAA;;AAErF,aAkDM,QAAA,GAAA;AAhDJ,aA8CQ,KAAA,KAAA;AA7CN,aAUK,OAAA,EAAA;AATH,aAAsG,IAAA,GAAA;;AACtG,aAAuG,IAAA,GAAA;;AACvG,aAA0G,IAAA,GAAA;;AAC1G,aAA2G,IAAA,GAAA;;AAC3G,aAIK,IAAA,GAAA;AAHL,aAEO,KAAA,IAAA;;;;;;AAyCb,aAOS,QAAA,MAAA;AANP,aAES,QAAA,OAAA;AADP,aAA2B,SAAA,EAAA;;;;AAE7B,aAES,QAAA,OAAA;AADP,aAA4B,SAAA,EAAA;;;;;;;gCAhDV,IAAG,EAAA;AAAA,mCA4Cc,IAAa,IAAA,EAAA,MAAA,MAAA;AAAA;mDAzDL,IAAc,EAAA,CAAA;AAAA;;;;;;AAaD,qBAAA,MAAA,6BAAA,QAAY,MAAM;AAAA;;qBAKnE,KAAsB;;;;;;;;;qCAA3B,QAAI,KAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UA7DJ,gBAAgB,WAAW,UAAU;QAElC,gBAAW;QACX,yBAAsB,OAAA;MAE7B;MACA;MACA,cAAc,OAAO,QAAQ,OAAO,KAAK,UAAU;iBAM3C;AACL,QAAA,CAAA,YAAY;AAAM;AACvB,2BAAuB,KAAI;AAAA,MACzB,MAAM,YAAY;AAAA,MAClB,UAAU;AAAA,MACV,kBAAkB;AAAA,MAClB,mBAAmB;AAAA;;;AANd;AAWA,kBAAO,OAAK;AACnB,2BAAuB,OAAO,OAAO,CAAC;;;AAD/B;kCAKoB;AAC3B,gBAAY,QAAQ,UAAU,sBAAsB;AACpD,gBAAY,MAAK;AAAA;AAFJ;2BAKc;AAC3B,SAAK,cAAa;AAAA;AADJ;;sBA+B6C,WAAQ,KAAA;;;;;;sBAKzB,OAAI,aAAA,IAAA;;;;;;AAYO,QAAA,OAAA,GAAA,UAAA,UAAU,kBAAgB,KAAA,GAAA;AAA1B,gBAAU,mBAAgB;;;;;;AAK1B,QAAA,OAAA,GAAA,UAAA,UAAU,mBAAiB,KAAA,GAAA;AAA3B,gBAAU,oBAAiB;;;;;;AAgBjC,gBAAY,MAAK;AAAA;;;AA5DjD,aAAI;;;;;;;;;;;;;;;;;;AAlCpB;wBACC,cAAc,OAAO,KAAK,OAAO,KAAK,UAAU,EAAE,OAAO,UAAI,CAAK,uBAAuB,KAAK,eAAa,UAAU,SAAS,IAAI,CAAA,CAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACbvH,MAAM,qCAAqC,kBAAkB;AAAA,EAE1E,YAAY,wBAAwB,SAAS;AAE3C,UAAM;AAAA,MACJ,QAAQ;AAAA,QACN,OAAO4E;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,QACD;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,UAAU,KAAK;AAAA,MACzC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO,KAAK,KAAK,SAAS,4DAA4D;AAAA,MACtF,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,gBAAgB;AAAA,IAChC,CAAK;AAAA,EACF;AAAA,EAED,aAAa,KAAK,OAAO,OAAO,UAAU,CAAA,GAAI;AAC5C,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,MAAM,OAAO,EAAE,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,IAC1D,CAAK;AAAA,EACF;AAEH;AAjCqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC0NN,MAAA,YAAA,SAAS,yEAAyE,IAAA;;;;;;;;;;;;;;AAelF,MAAA,YAAA,SAAS,0EAA0E,IAAA;;;;;AA1ElF,MAAA,WAAA,CAAA,OAAS,WAAO7E,oBAAA;;;;;;;AALX,YAAA,cAAA,GAAA,SAAS,yDAAyD;;;AACrE,SAAA,cAAA,GAAA,SAAS,oEAAoE;;;;;;;;;;;;AAa1E,YAAA,cAAA,GAAA,SAAS,sDAAsD;;;AAClE,SAAA,cAAA,GAAA,SAAS,uDAAuD;;;;;;;AAO7D,YAAA,cAAA,GAAA,SAAS,0DAA0D;;;AACtE,SAAA,cAAA,GAAA,SAAS,qEAAqE;;;;;;;AAO3E,YAAA,cAAA,GAAA,SAAS,6DAA6D;;;AACzE,SAAA,cAAA,GAAA,SAAS,wEAAwE;;;;AAIhE,cAAA,cAAA,GAAA,SAAS,oEAAoE;AAAA,mBAC9F,SAAS,IAAsB,EAAA;AAAA;;AAEb,cAAA,cAAA,GAAA,SAAS,gEAAgE;;AACxE,cAAA,cAAA,GAAA,SAAS,+DAA+D;;;;;AAMxF,YAAA,cAAA,GAAA,SAAS,mDAAmD;;;AAC/D,SAAA,cAAA,GAAA,SAAS,8DAA8D;;;;;;;AASpE,YAAA,cAAA,GAAA,SAAS,gEAAgE;;;AAC5E,SAAA,cAAA,GAAA,SAAS,2EAA2E;;;;;;;;;;;AAcjF,YAAA,cAAA,GAAA,SAAS,iEAAiE;;;AAC7E,SAAA,cAAA,GAAA,SAAS,4EAA4E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAtCvD,UAAA,OAAS,oBAAe;AAAA,4BAAA,MAAA,IAAA,IAAA,KAAA,MAAA,CAAA;;;;;AAgBxC,WAAA,QAAA,eAAA,SAAS,8DAA8D,CAAA;;;;;;mDAcxE,IAAqB;;;;;;;mDAerB,IAAsB;;;;;;AAlF7C,aAuFM,QAAA,MAAA,MAAA;AArFJ,aAYM,MAAA,IAAA;AAXJ,aAGQ,MAAA,MAAA;AAFN,aAAkF,QAAA,KAAA;;AAClF,aAAuF,QAAA,EAAA;;AAGzF,aAKG,MAAA,KAAA;;;;AADD,aAA4F,OAAA,KAAA;AAA/D,aAAwD,OAAA,MAAA;AAAnB,aAAA,UAAA,OAAS;;AAI/E,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;AAFN,aAA+E,QAAA,KAAA;;AAC/E,aAA0E,QAAA,EAAA;;AAE5E,aAA4F,MAAA,MAAA;AAApB,sBAAA,QAAA,OAAS,QAAQ;;AAG3F,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;AAFN,aAAmF,QAAA,KAAA;;AACnF,aAAwF,QAAA,EAAA;;AAE1F,aAAgE,MAAA,MAAA;AAA3B,aAAA,UAAA,OAAS;;AAGhD,aAaM,MAAA,IAAA;AAZJ,aAGQ,MAAA,MAAA;AAFN,aAAsF,QAAA,KAAA;;AACtF,aAA2F,QAAA,EAAA;;AAE7F,aAOS,MAAA,MAAA;AANP,aAGS,QAAA,OAAA;AACT,aAA0G,QAAA,OAAA;AAC1G,aAA0G,QAAA,OAAA;AANxE,oBAAA,QAAA,OAAS,eAAe;;AAU9D,aAQM,MAAA,IAAA;AAPJ,aAGQ,MAAA,MAAA;AAFN,aAA4E,QAAA,KAAA;;AAC5E,aAAiF,QAAA,EAAA;;AAEnF,aAEsC,MAAA,MAAA;AAAlB,sBAAA,QAAA,OAAS,KAAK;;AAGpC,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;AAFN,aAAyF,QAAA,KAAA;;AACzF,aAA8F,QAAA,EAAA;;AAEhG,aAA6D,MAAA,MAAA;uBAAxB,IAAqB;;AAG5D,aAKM,MAAA,IAAA;AAJJ,aAGS,MAAA,OAAA;;;AAGX,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;AAFN,aAA0F,QAAA,KAAA;;AAC1F,aAA+F,QAAA,EAAA;;AAEjG,aAA8D,MAAA,MAAA;uBAAzB,IAAsB;;AAG7D,aAKM,MAAA,IAAA;AAJJ,aAGS,MAAA,OAAA;;;;;;;;;;;;;;;;;;AA3EL,UAAA,CAAA,QAAS,SAAO;;;;;;;;;;;;;AAGgD,eAAA,UAAA,QAAS;AAAA;AASL,UAAA,MAAA,KAAA,MAAA,UAAA,OAAA,KAAA,MAAA,QAAS,UAAQ;AAAjB,wBAAA,QAAA,QAAS,QAAQ;AAAA;;AAQpD,eAAA,UAAA,QAAS;AAAA;;AAQV,sBAAA,QAAA,QAAS,eAAe;AAAA;AAiBxC,UAAA,MAAA,KAAA,MAAA,OAAA,UAAA,QAAS,OAAK;AAAd,wBAAA,QAAA,QAAS,KAAK;AAAA;;yBAQG,KAAqB;AAAA;gFAKvC,KAAqB,KAAA;;;;yBAUH,KAAsB;AAAA;gFAKxC,KAAsB,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;AAxEzC,aAAqG,QAAA,KAAA,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyJvD,MAAA,OAAS,gBAAW,QAAA;AAApB,sBAAA,QAAA,OAAS;AAAA;;;;;;;;;;;AAOT,MAAA,OAAS,gBAAW,QAAA;AAApB,sBAAA,QAAA,OAAS;AAAA;;;;;;;;;;;AAOT,MAAA,OAAS,eAAU,QAAA;AAAnB,sBAAA,QAAA,OAAS;AAAA;;;;;;;;;;;AAOT,MAAA,OAAS,gBAAW,QAAA;AAApB,sBAAA,QAAA,OAAS;AAAA;;;;;;;;;;;AAOd,MAAA,OAAS,eAAU,QAAA;AAAnB,sBAAA,QAAA,OAAS;AAAA;;;;;;;;;;;AAOT,MAAA,OAAS,cAAS,QAAA;AAAlB,sBAAA,QAAA,OAAS;AAAA;;;;;;;;;;;AAOT,MAAA,OAAS,gBAAW,QAAA;AAApB,sBAAA,QAAA,OAAS;AAAA;;;;;;;;AA6IP,MAAA,OAAS,qBAAgB,QAAA;AAAzB,uBAAA,QAAA,OAAS;AAAA;;;;;;;;AAOT,MAAA,OAAS,sBAAiB,QAAA;AAA1B,uBAAA,QAAA,OAAS;AAAA;;;;;;;;AAhQ1C,eAAA,cAAA,GAAA,SAAS,yDAAyD;;;AAG7C,aAAA,cAAA,GAAA,SAAS,8EAA8E;;;;;AAI3G,YAAA,cAAA,GAAA,SAAS,8DAA8D;;;AAC1E,SAAA,cAAA,GAAA,SAAS,yEAAyE;;;;;;;;AAS7E,YAAA,cAAA,GAAA,SAAS,4DAA4D;;;AACxE,SAAA,cAAA,GAAA,SAAS,uEAAuE;;;;;;;AAO7E,YAAA,cAAA,GAAA,SAAS,iEAAiE;;;;;;;AAO1E,YAAA,cAAA,GAAA,SAAS,yDAAyD;;;;;;;;AAcrE,eAAA,cAAA,GAAA,SAAS,wDAAwD;;;;AAGjE,aAAA,cAAA,GAAA,SAAS,8DAA8D;;;;;;AAKvE,aAAA,cAAA,GAAA,SAAS,yDAAyD;;;;;;AAKlE,aAAA,cAAA,GAAA,SAAS,yDAAyD;;;;;;AAKlE,aAAA,cAAA,GAAA,SAAS,kEAAkE;;;;;;;AAO3E,aAAA,cAAA,GAAA,SAAS,kEAAkE;;;;;;;AAO3E,aAAA,cAAA,GAAA,SAAS,iEAAiE;;;;;;;AAO1E,cAAA,cAAA,GAAA,SAAS,kEAAkE;;;;;;;AAO3E,cAAA,cAAA,GAAA,SAAS,iEAAiE;;;;;;;AAO1E,cAAA,cAAA,GAAA,SAAS,gEAAgE;;;;;;;AAOzE,cAAA,cAAA,GAAA,SAAS,kEAAkE;;;;;;;AAU3E,eAAA,cAAA,GAAA,SAAS,sDAAsD;;;;;AAI9D,YAAA,cAAA,GAAA,SAAS,kEAAkE;;;AAC9E,SAAA,cAAA,GAAA,SAAS,6EAA6E;;;;;;;AAOnF,YAAA,cAAA,GAAA,SAAS,uEAAuE;;;AACnF,SAAA,cAAA,GAAA,SAAS,kFAAkF;;;;;;;AAOxF,YAAA,cAAA,GAAA,SAAS,+DAA+D;;;AAC3E,SAAA,cAAA,GAAA,SAAS,0EAA0E;;;;;;;AAOhF,YAAA,cAAA,GAAA,SAAS,gEAAgE;;;AAC5E,SAAA,cAAA,GAAA,SAAS,2EAA2E;;;;;;;AAOjF,YAAA,cAAA,GAAA,SAAS,gEAAgE;;;AAC5E,SAAA,cAAA,GAAA,SAAS,2EAA2E;;;;;;;AAOjF,YAAA,cAAA,GAAA,SAAS,iEAAiE;;;AAC7E,SAAA,cAAA,GAAA,SAAS,4EAA4E;;;;AAM1C,cAAA,cAAA,GAAA,SAAS,iEAAiE;;;;AAOnH,eAAA,cAAA,GAAA,SAAS,uDAAuD;;;;;AAI/D,aAAA,cAAA,GAAA,SAAS,yDAAyD;;;AACrE,SAAA,cAAA,GAAA,SAAS,oEAAoE;;;;;;;AAO1E,aAAA,cAAA,GAAA,SAAS,kEAAkE;;;AAC9E,SAAA,cAAA,GAAA,SAAS,6EAA6E;;;;;;;AAOnF,aAAA,cAAA,GAAA,SAAS,kEAAkE;;;AAC9E,UAAA,cAAA,GAAA,SAAS,6EAA6E;;;;;;;AAOnF,aAAA,cAAA,GAAA,SAAS,iEAAiE;;;AAC7E,UAAA,cAAA,GAAA,SAAS,4EAA4E;;;;;;AAKtF,cAAA,cAAA,GAAA,SAAS,oEAAoE;AAAA;;AAG7E,cAAA,cAAA,GAAA,SAAS,mEAAmE;AAAA;;AAG5E,cAAA,cAAA,GAAA,SAAS,0EAA0E;AAAA;;AAGnF,cAAA,cAAA,GAAA,SAAS,yEAAyE;;;;;AAO9E,aAAA,cAAA,GAAA,SAAS,8DAA8D;;;AAC1E,UAAA,cAAA,GAAA,SAAS,yEAAyE;;;;;;;AAO/E,aAAA,cAAA,GAAA,SAAS,8DAA8D;;;AAC1E,UAAA,cAAA,GAAA,SAAS,yEAAyE;;;;;;;AAO/E,aAAA,cAAA,GAAA,SAAS,oEAAoE;;;AAChF,UAAA,cAAA,GAAA,SAAS,0EAA0E;;;;;AAMhF,aAAA,cAAA,GAAA,SAAS,kEAAkE;;;;;;;AAO3E,aAAA,cAAA,GAAA,SAAS,mEAAmE;;;;;;;;AAQ1E,aAAA,cAAA,GAAA,SAAS,kEAAkE;;;AAC9E,UAAA,cAAA,GAAA,SAAS,8EAA8E;;;AAG1F,cAAA,cAAA,GAAA,SAAS,iFAAiF;;;;;;AAQpF,aAAA,cAAA,GAAA,SAAS,qEAAqE;;;AACjF,UAAA,cAAA,GAAA,SAAS,gFAAgF;;;AAG5F,cAAA,cAAA,GAAA,SAAS,8EAA8E;;;;;AAOnF,aAAA,cAAA,GAAA,SAAS,2DAA2D;;;AACvE,UAAA,cAAA,GAAA,SAAS,sEAAsE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA3PhE,aAAA,WAAA,wBAAA,CAAA,OAAS;;;;;;AAET,aAAA,WAAA,wBAAA,CAAA,OAAS;;AAPsB,mBAAA,MAAA,uBAAA,CAAA,OAAS,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgLhD,UAAA,OAAS,oBAAe;AAAA,4BAAA,MAAA,IAAA,IAAA,KAAA,MAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;mDA4FI,IAAQ,GAAC,UAAU;;;;;mDAG9C,IAAQ,GAAC,UAAU;;;;;;;mDASQ,IAAQ,GAAC,UAAU;;;;;mDAG9C,IAAQ,GAAC,UAAU;;;;kDArBzB,IAAQ,GAAC,UAAU,OAAO;;;;;AAzSG,mBAAA,OAAA,UAAA,WAAc,eAAe;AAAA;;AAA/F,aAsUM,QAAA,OAAA,MAAA;AAnUJ,aA4CU,OAAA,QAAA;AA1CR,aAAwF,UAAA,QAAA;;AAExF,aACiI,UAAA,MAAA;;AAEjI,aAMM,UAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;AAFN,aAAuF,QAAA,KAAA;;AACvF,aAA4F,QAAA,EAAA;;AAE9F,aAA2D,MAAA,MAAA;AAAtB,aAAA,UAAA,OAAS;;AAGhD,aA2BM,UAAA,IAAA;AAzBJ,aAMM,MAAA,IAAA;AALJ,aAGQ,MAAA,MAAA;AAFN,aAAqF,QAAA,KAAA;;AACrF,aAA0F,QAAA,EAAA;;AAE5F,aAA6D,MAAA,MAAA;AAAxB,aAAA,UAAA,OAAS;;AAGhD,aAKM,MAAA,IAAA;AAJJ,aAEQ,MAAA,MAAA;AADN,aAA0F,QAAA,KAAA;;AAE5F,aAAwE,MAAA,MAAA;AAAnC,aAAA,UAAA,OAAS;;AAGhD,aAQM,MAAA,IAAA;AAPJ,aAEQ,MAAA,MAAA;AADN,aAAkF,QAAA,KAAA;;AAEpF,aAC+F,MAAA,MAAA;AAA5B,sBAAA,QAAA,OAAS,eAAe;;AAC3F,aAC+F,MAAA,MAAA;AAA5B,sBAAA,QAAA,OAAS,eAAe;;AAOjG,aAoEU,OAAA,QAAA;AAlER,aAAuF,UAAA,QAAA;;AAEvF,aAGM,UAAA,IAAA;AAFJ,aAAyF,MAAA,MAAA;;AACzF,aAA4D,MAAA,MAAA;AAAvB,aAAA,UAAA,OAAS;;AAGhD,aAGM,UAAA,IAAA;AAFJ,aAAoF,MAAA,MAAA;;AACpF,aAAuD,MAAA,MAAA;AAAlB,aAAA,UAAA,OAAS;;AAGhD,aAGM,UAAA,IAAA;AAFJ,aAAoF,MAAA,MAAA;;AACpF,aAAuD,MAAA,MAAA;AAAlB,aAAA,UAAA,OAAS;;AAGhD,aAKM,UAAA,IAAA;AAJJ,aAA6F,MAAA,MAAA;;AAC7F,aAEM,MAAA,IAAA;;;AAGR,aAKM,UAAA,KAAA;AAJJ,aAA6F,OAAA,MAAA;;AAC7F,aAEM,OAAA,KAAA;;;AAGR,aAKM,UAAA,KAAA;AAJJ,aAA4F,OAAA,MAAA;;AAC5F,aAEM,OAAA,KAAA;;;AAGR,aAKM,UAAA,KAAA;AAJJ,aAA6F,OAAA,OAAA;;AAC7F,aAEM,OAAA,KAAA;;;AAGR,aAKM,UAAA,KAAA;AAJJ,aAA4F,OAAA,OAAA;;AAC5F,aAEM,OAAA,KAAA;;;AAGR,aAKM,UAAA,KAAA;AAJJ,aAA2F,OAAA,OAAA;;AAC3F,aAEM,OAAA,KAAA;;;AAGR,aAKM,UAAA,KAAA;AAJJ,aAA6F,OAAA,OAAA;;AAC7F,aAEM,OAAA,KAAA;;;AAKV,aAwDU,OAAA,QAAA;AAtDR,aAAqF,UAAA,QAAA;;AAErF,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAA2F,SAAA,KAAA;;AAC3F,aAAgG,SAAA,EAAA;;AAElG,aAAkE,OAAA,MAAA;AAA7B,aAAA,UAAA,OAAS;;AAGhD,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAAgG,SAAA,KAAA;;AAChG,aAAqG,SAAA,EAAA;;AAEvG,aAAuE,OAAA,MAAA;AAAlC,aAAA,UAAA,OAAS;;AAGhD,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAAwF,SAAA,KAAA;;AACxF,aAA6F,SAAA,EAAA;;AAE/F,aAA+D,OAAA,OAAA;AAA1B,cAAA,UAAA,OAAS;;AAGhD,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAAyF,SAAA,KAAA;;AACzF,aAA8F,SAAA,EAAA;;AAEhG,aAAgE,OAAA,OAAA;AAA3B,cAAA,UAAA,OAAS;;AAGhD,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAAyF,SAAA,KAAA;;AACzF,aAA8F,SAAA,EAAA;;AAEhG,aAA8D,OAAA,OAAA;AAAzB,cAAA,UAAA,OAAS;;AAGhD,aAKM,UAAA,KAAA;AAJJ,aAGQ,OAAA,OAAA;AAFN,aAA0F,SAAA,KAAA;;AAC1F,aAA+F,SAAA,EAAA;;AAInG,aAGM,UAAA,KAAA;AAFJ,aACsI,OAAA,OAAA;;AAK1I,aAmJU,OAAA,QAAA;AAjJR,aAAsF,UAAA,QAAA;;AAEtF,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAAkF,SAAA,MAAA;;AAClF,aAAuF,SAAA,EAAA;;AAEzF,aAA2D,OAAA,OAAA;AAAtB,cAAA,UAAA,OAAS;;AAGhD,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAA2F,SAAA,MAAA;;AAC3F,aAAgG,SAAA,EAAA;;AAElG,aAAiE,OAAA,OAAA;AAA5B,cAAA,UAAA,OAAS;;AAGhD,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAA2F,SAAA,MAAA;;AAC3F,aAAgG,SAAA,GAAA;;AAElG,aAAmE,OAAA,OAAA;AAA9B,cAAA,UAAA,OAAS;;AAGhD,aAoBM,UAAA,KAAA;AAnBJ,aAGQ,OAAA,OAAA;AAFN,aAA0F,SAAA,MAAA;;AAC1F,aAA+F,SAAA,GAAA;;AAEjG,aAAyB,OAAA,KAAA;;AACzB,aAaS,OAAA,MAAA;AAZP,aAES,QAAA,OAAA;AACT,aAES,QAAA,OAAA;AACT,aAES,QAAA,OAAA;AACT,aAES,QAAA,OAAA;AAZyB,oBAAA,QAAA,OAAS,eAAe;;AAgB9D,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAAuF,SAAA,MAAA;;AACvF,aAA4F,SAAA,GAAA;;AAE9F,aAA6D,OAAA,OAAA;AAAxB,cAAA,UAAA,OAAS;;AAGhD,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAAuF,SAAA,MAAA;;AACvF,aAA4F,SAAA,GAAA;;AAE9F,aAA6D,OAAA,OAAA;AAAxB,cAAA,UAAA,OAAS;;AAGhD,aAKM,UAAA,KAAA;AAJJ,aAGQ,OAAA,OAAA;AAFN,aAA6F,SAAA,MAAA;;AAC7F,aAA6F,SAAA,GAAA;;AAIjG,aAKM,UAAA,KAAA;AAJJ,aAEQ,OAAA,OAAA;AADN,aAA2F,SAAA,MAAA;;;;AAK/F,aAKM,UAAA,KAAA;AAJJ,aAEQ,OAAA,OAAA;AADN,aAA4F,SAAA,MAAA;;;;AAKhG,aAUM,UAAA,KAAA;AATJ,aAQM,OAAA,KAAA;AAPJ,aAGQ,OAAA,OAAA;AAFN,aAA2F,SAAA,MAAA;;AAC3F,aAAiG,SAAA,GAAA;;AAEnG,aAES,OAAA,OAAA;;AAIb,aAUM,UAAA,KAAA;AATJ,aAQM,OAAA,KAAA;AAPJ,aAGQ,OAAA,OAAA;AAFN,aAA8F,SAAA,MAAA;;AAC9F,aAAmG,SAAA,GAAA;;AAErG,aAES,OAAA,OAAA;;AAIb,aAMM,UAAA,KAAA;AALJ,aAGQ,OAAA,OAAA;AAFN,aAAoF,SAAA,MAAA;;AACpF,aAAyF,SAAA,GAAA;;AAE3F,aAAkE,OAAA,OAAA;wBAA7B,IAAQ,GAAC,UAAU;;AAG1D,aA0BM,UAAA,KAAA;AAxBJ,aAWM,OAAA,KAAA;AAVJ,aAEQ,OAAA,OAAA;;AACR,aAMM,OAAA,KAAA;AALJ,aACoD,OAAA,OAAA;AAAhC,sBAAA,SAAA,IAAS,GAAA,UAAU,KAAK,IAAI;;AAChD,aAAmE,OAAA,MAAA;;AACnE,aACsD,OAAA,OAAA;AAAlC,sBAAA,SAAA,IAAS,GAAA,UAAU,KAAK,MAAM;;AAGtD,aAWM,OAAA,KAAA;AAVJ,aAEQ,OAAA,OAAA;;AACR,aAMM,OAAA,KAAA;AALJ,aACqD,OAAA,OAAA;AAAjC,sBAAA,SAAA,IAAS,GAAA,UAAU,MAAM,IAAI;;AACjD,aAAmE,OAAA,MAAA;;AACnE,aACuD,OAAA,OAAA;AAAnC,sBAAA,SAAA,IAAS,GAAA,UAAU,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAhTlB,eAAA,UAAA,QAAS;AAAA;;AAUP,eAAA,UAAA,QAAS;AAAA;;AAOT,eAAA,UAAA,QAAS;AAAA;AAQ3B,UAAA,CAAA,WAAA,MAAA,KAAA,MAAA,0BAAA,yBAAA,CAAA,QAAS,0BAAuB;;;;AAAgB,wBAAA,QAAA,QAAS,eAAe;AAAA;AAExE,UAAA,CAAA,WAAA,MAAA,KAAA,MAAA,0BAAA,yBAAA,CAAA,QAAS,0BAAuB;;;AAAgB,UAAA,MAAA,KAAA,MAAA,UAAA,OAAA,KAAA,MAAA,QAAS,iBAAe;AAAxB,wBAAA,QAAA,QAAS,eAAe;AAAA;;AAPzC,qBAAA,MAAA,uBAAA,CAAA,QAAS,uBAAuB;AAAA;;AAoB/C,eAAA,UAAA,QAAS;AAAA;;AAKT,eAAA,UAAA,QAAS;AAAA;;AAKT,eAAA,UAAA,QAAS;AAAA;;;;AAMF,4BAAA,QAAA,QAAS;;;;;;;AAOT,4BAAA,QAAA,QAAS;;;;;;;AAOT,4BAAA,QAAA,QAAS;;;;;;;AAOT,4BAAA,QAAA,QAAS;;;;;;;AAOd,4BAAA,QAAA,QAAS;;;;;;;AAOT,4BAAA,QAAA,QAAS;;;;;;;AAOT,4BAAA,QAAA,QAAS;;;;;AAeX,eAAA,UAAA,QAAS;AAAA;;AAQT,eAAA,UAAA,QAAS;AAAA;;AAQT,gBAAA,UAAA,QAAS;AAAA;;AAQT,gBAAA,UAAA,QAAS;AAAA;;AAQT,gBAAA,UAAA,QAAS;AAAA;;AA0BT,gBAAA,UAAA,QAAS;AAAA;;AAQT,gBAAA,UAAA,QAAS;AAAA;;AAQT,gBAAA,UAAA,QAAS;AAAA;;AASV,sBAAA,QAAA,QAAS,eAAe;AAAA;;AAqBvB,gBAAA,UAAA,QAAS;AAAA;;AAQT,gBAAA,UAAA,QAAS;AAAA;;;;AAcL,6BAAA,QAAA,QAAS;;;;;;;AAOT,6BAAA,QAAA,QAAS;;;;;0BAgCb,KAAQ,GAAC,UAAU;AAAA;6FAUQ,KAAQ,GAAC,UAAU,UAAO;;;AAClE,UAAA,MAAA,KAAA,MAAA,UAAA,QAAA,KAAA,MAAA,KAAS,GAAA,UAAU,KAAK,MAAI;AAA5B,wBAAA,SAAA,KAAS,GAAA,UAAU,KAAK,IAAI;AAAA;6FAEf,KAAQ,GAAC,UAAU,UAAO;;;AACvC,UAAA,MAAA,KAAA,MAAA,UAAA,QAAA,KAAA,MAAA,KAAS,GAAA,UAAU,KAAK,QAAM;AAA9B,wBAAA,SAAA,KAAS,GAAA,UAAU,KAAK,MAAM;AAAA;6FAQU,KAAQ,GAAC,UAAU,UAAO;;;AAClE,UAAA,MAAA,KAAA,MAAA,UAAA,QAAA,KAAA,MAAA,KAAS,GAAA,UAAU,MAAM,MAAI;AAA7B,wBAAA,SAAA,KAAS,GAAA,UAAU,MAAM,IAAI;AAAA;6FAEhB,KAAQ,GAAC,UAAU,UAAO;;;AACvC,UAAA,MAAA,KAAA,MAAA,UAAA,QAAA,KAAA,MAAA,KAAS,GAAA,UAAU,MAAM,QAAM;AAA/B,wBAAA,SAAA,KAAS,GAAA,UAAU,MAAM,MAAM;AAAA;;oDAtBxB,KAAQ,GAAC,UAAU,OAAO;AAAA;;AAzSG,qBAAA,OAAA,UAAA,YAAc,eAAe;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+U9F,MAAA,WAAA,SAAS,+CAA+C,IAAA;;;;;;;;;;;;QAnb3D,OAAO;AAAA,QAAgB,OAAO,SAAS,mDAAmD;AAAA,QAAG,WAAS,CAAG,IAAQ,GAAC;AAAA;;QAClH,OAAO;AAAA,QAAiB,OAAO,SAAS,oDAAoD;AAAA;;;;;;;;AAKvF,MAAA,YAAA,WAAc,kBAAcR,oBAAA,GAAA;AA4F5B,MAAA,YAAA,WAAc,mBAAeC,kBAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;AAtGtC,aA2bO,QAAA,QAAA,MAAA;;;AAnbL,aA0aU,QAAA,OAAA;;;;;;;AAEV,aAKS,QAAA,MAAA;AAJP,aAGS,QAAA,MAAA;AAFP,aAA2B,QAAA,CAAA;;;;;;;kCADQ,IAAa,KAAA,EAAA,MAAA,MAAA;AAAA,mDArbA,IAAc,EAAA,GAAA,EAAA,MAAA,MAAA;AAAA;;;;;;;;;YAIhE,OAAO;AAAA,YAAgB,OAAO,SAAS,mDAAmD;AAAA,YAAG,WAAS,CAAG,KAAQ,GAAC;AAAA;;YAClH,OAAO;AAAA,YAAiB,OAAO,SAAS,oDAAoD;AAAA;;;;;;;;AAKvF,UAAA,YAAc,gBAAc;;;;;;;;;;;;AA4F5B,UAAA,YAAc,iBAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UA7N9B,gBAAgB,WAAW,UAAU;QAElC,gBAAW;QACX,cAAS;MAEhB;AAEA,MAAA,WAAWE,iBAA+B,SAAS;MACnD,yBAAyB,SAASzB,WAAmB,SAAS,kBAAkB,IAAI,QAAQ,IAAI;AAEhG,MAAA,wBAA+B,OAAA,UAAU,uBAAuB;AAChE,MAAA,yBAAgC,OAAA,UAAU,wBAAwB;kCAazC;QAEvB,WAAW,QAAQ,MAAM,UAAU,UAAU,aAAa;UAExD,OAAO,QAAQ,MAAM,YAAY,UAAU,QAAQ;AAEzD,SAAK,kBAAe;AAAA,MAClB,WAAW;AAAA,MACX,QAAQ;AAAA,MACR,SAAS;AAAA,IACT,EAAA,KAAK;AAEP4G,QAAQ,eAAe,WAAW,IAAI;AAEtC,gBAAY,MAAK;AAAA;AAdJ;wCAiBoB;oBACjC,SAAS,qBAAqB,UAAU,sBAAsB,KAAK,UAAU,YAAU,QAAA;AAChF,WAAA,iBAAiB,KACtB,SAAS;MACP,IAAE,+BAAiC,UAAU;AAAA;MAC7C,OAAO,KAAK,KAAK,OAAO,uDAAyD,EAAA,YAAY,UAAU,MAAI;AAAA,KAC7G,EAAA,KAAM,YAAM;sBACZ,SAAS,qBAAqB,QAAM,QAAA;AAAA;;AAPzB;yCAWqB;oBAClC,SAAS,sBAAsB,UAAU,uBAAuB,KAAK,UAAU,cAAY,QAAA;AACpF,WAAA,kBAAkB,KACvB,SAAS;MACP,IAAE,iCAAmC,UAAU;AAAA;MAC/C,OAAO,KAAK,KAAK,OAAO,mDAAqD,EAAA,YAAY,UAAU,MAAI;AAAA,KACzG,EAAA,KAAM,YAAM;sBACZ,SAAS,sBAAsB,QAAM,QAAA;AAAA;;AAP1B;8CAW0B;UACjC,OAAO,SAAS,0BAAsB;AACrC,WAAA,6BAA6B,KAClC;MACE,IAAE,6CAA+C,UAAU;AAAA;MAC3D,OAAO,KAAK,KAAK,OAAO,mEAAqE,EAAA,YAAY,UAAU,MAAI;AAAA,KACzH,EAAA,KAAM,YAAM;sBACZ,SAAS,yBAAyB,UAAM,CAAA,GAAA,QAAA;AAAA;;AAP7B;2CAWuB;UAC9B,OAAO,SAAS,uBAAmB;AAClC,WAAA,qBAAqB,KAC1B;MACE,IAAE,mCAAqC,UAAU;AAAA;MACjD,OAAO,KAAK,KAAK,OAAO,2DAA6D,EAAA,YAAY,UAAU,MAAI;AAAA,KACjH,EAAA,KAAM,YAAM;sBACZ,SAAS,sBAAsB,UAAM,CAAA,GAAA,QAAA;AAAA;;AAP1B;oCAWgB;eAClB,OAAM;AAAA,MACf,IAAE,mCAAqC,UAAU;AAAA,MACjD,OAAO,KAAK,KAAK,SAAS,2CAA2C;AAAA,MACrE,SAASC,aAAoB;AAAA,QAAG,SAAS,KAAK,KAAK,SAAS,6CAA6C;AAAA;MACzG,SAAO;AAAA,QACL,SAAO;AAAA,UACL,MAAM;AAAA,UACN,OAAO,KAAK,KAAK,SAAS,6CAA6C;AAAA,UACvE,UAAQ,MAAA;AACNtB,qCAA0C,SAAS;AAAA;;QAGvD,QAAM;AAAA,UACJ,MAAM;AAAA,UACN,OAAO,KAAK,KAAK,SAAS,IAAI;AAAA;;MAGlC,SAAS;AAAA,IACR,CAAA,EAAA,OAAO,IAAI;AAAA;AAnBD;2BAsBO;AACpB,SAAK,cAAa;AAAA;AADX;AAIL,MAAA,YAAY;;;;;;;AAgC8D,aAAS,UAAO,KAAA;;;;;AASZ,aAAS,WAAQ,UAAA,KAAA,KAAA;;;;;AAQpD,aAAS,kBAAe,KAAA;;;;;AAQzB,aAAS,kBAAe,aAAA,IAAA;;;;;AAiBxC,aAAS,QAAK,KAAA;;;;;AAQG,4BAAqB,KAAA;;;;;AAIlB;;;AAWH,6BAAsB,KAAA;;;;;AAInB;;;AA0BD,aAAS,aAAU,KAAA;;;;;AAUjB,aAAS,eAAY,KAAA;;;;;AAOrB,aAAS,0BAAuB,KAAA;;;;;AAQF,aAAS,kBAAe,UAAA,KAAA,KAAA;;;;;AAExB,aAAS,kBAAe,UAAA,KAAA,KAAA;;;;;AAaxD,aAAS,cAAW,KAAA;;;;;AAKpB,aAAS,SAAM,KAAA;;;;;AAKf,aAAS,SAAM,KAAA;;;;;AAMR,QAAA,OAAA,GAAA,UAAA,SAAS,aAAW,KAAA,GAAA;AAApB,eAAS,cAAW;;;;;;AAOpB,QAAA,OAAA,GAAA,UAAA,SAAS,aAAW,KAAA,GAAA;AAApB,eAAS,cAAW;;;;;;AAOpB,QAAA,OAAA,GAAA,UAAA,SAAS,YAAU,KAAA,GAAA;AAAnB,eAAS,aAAU;;;;;;AAOnB,QAAA,OAAA,GAAA,UAAA,SAAS,aAAW,KAAA,GAAA;AAApB,eAAS,cAAW;;;;;;AAOzB,QAAA,OAAA,GAAA,UAAA,SAAS,YAAU,KAAA,GAAA;AAAnB,eAAS,aAAU;;;;;;AAOnB,QAAA,OAAA,GAAA,UAAA,SAAS,WAAS,KAAA,GAAA;AAAlB,eAAS,YAAS;;;;;;AAOlB,QAAA,OAAA,GAAA,UAAA,SAAS,aAAW,KAAA,GAAA;AAApB,eAAS,cAAW;;;;;;AAetB,aAAS,oBAAiB,KAAA;;;;;AAQ1B,aAAS,yBAAsB,KAAA;;;;;AAQ/B,aAAS,iBAAc,KAAA;;;;;AAQvB,aAAS,kBAAe,KAAA;;;;;AAQxB,aAAS,gBAAa,KAAA;;;;;AAYjC;;;AAcW,aAAS,aAAU,KAAA;;;;;AAQnB,aAAS,mBAAgB,KAAA;;;;;AAQzB,aAAS,qBAAkB,KAAA;;;;;AAS5B,aAAS,kBAAe,aAAA,IAAA;;;;;AAqBvB,aAAS,eAAY,KAAA;;;;;AAQrB,aAAS,eAAY,KAAA;;;;;AAcjB,QAAA,OAAA,GAAA,UAAA,SAAS,kBAAgB,KAAA,GAAA;AAAzB,eAAS,mBAAgB;;;;;;AAOzB,QAAA,OAAA,GAAA,UAAA,SAAS,mBAAiB,KAAA,GAAA;AAA1B,eAAS,oBAAiB;;;;;;AASzB;;;AAYA;;;AAWL,aAAS,UAAU,UAAO,KAAA;;;;;AAWvC,aAAS,UAAU,KAAK,OAAI,UAAA,KAAA,KAAA;;;;;AAG5B,aAAS,UAAU,KAAK,SAAM,UAAA,KAAA,KAAA;;;;;AAS9B,aAAS,UAAU,MAAM,OAAI,UAAA,KAAA,KAAA;;;;;AAG7B,aAAS,UAAU,MAAM,SAAM,UAAA,KAAA,KAAA;;;;;;AAvalD,aAAI;;;;;;;;;;;;;;;;;;AA1GpB;aACM,uBAAqB;0BACxB,SAAS,qBAAqB,OAAK,QAAA;AAAA;;;;AAGtC;aACM,wBAAsB;0BACzB,SAAS,sBAAsB,OAAK,QAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACtC3B,MAAM,uBAAuB,kBAAkB;AAAA,EAE5D,YAAY,WAAW,UAAU,IAAI;AAEnC,UAAM;AAAA,MACJ,IAAI,oBAAoB,UAAU;AAAA,MAClC,OAAO,KAAK,KAAK,OAAO,gDAAgD,EAAE,YAAY,UAAU,MAAM;AAAA,MACtG,QAAQ;AAAA,QACN,OAAOuB;AAAAA,QACP,QAAQ,SAAS;AAAA,QACjB,OAAO;AAAA,UACL;AAAA,QACD;AAAA,MACF;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,UAAU,IAAI;AAAA,MACxC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,mBAAmB;AAAA,IACnC,CAAK;AAAA,EACF;AAAA,EAED,OAAO,aAAa,IAAI;AACtB,WAAO,OAAO,OAAO,GAAG,OAAO,EAAE,KAAK,SAAO,IAAI,OAAO,oBAAoB,IAAI;AAAA,EACjF;AAAA,EAED,aAAa,KAAK,QAAQ,UAAU,CAAA,GAAI,aAAa,CAAA,GAAI;AACvD,UAAM,cAAchH,SAAmB,MAAM;AAC7C,UAAM,MAAM,KAAK,aAAa,YAAY,EAAE;AAC5C,QAAI;AAAK,aAAO,IAAI,OAAO,OAAO,EAAE,OAAO,KAAI,CAAE;AACjD,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,aAAa,SAAS,UAAU,EAAE,OAAO,IAAI;AAAA,IAC5D,CAAK;AAAA,EACF;AAAA,EAED,MAAM,MAAM,SAAS;AACnB,WAAO,OAAO,GAAG,OAAO,EAAE,QAAQ,SAAO;AACvC,UAAI,QAAQ,QAAQ,IAAI,YAAY,IAAI,SAAS,cAAc,MAAM;AACnE,YAAI,MAAK;AAAA,MACV;AAAA,IACP,CAAK;AACD,WAAO,MAAM,MAAM,OAAO;AAAA,EAC3B;AACH;AAjDqB;ACGN,+BAA+B;AAC5C,QAAM,GAAG,oBAAoB,cAAc;AAC3C,QAAM,GAAG,iCAAiC,2BAA2B;AACrE,QAAM,GAAG,8BAA8B,wBAAwB;AAC/D,QAAM,GAAG,6BAA6B,uBAAuB;AAC7D,QAAM,GAAG,oBAAoB,kBAAkB;AACjD;AANwB;AAQxB,4BAA4B,SAAS;AACnC,MAAI,QAAQ,YAAY;AAAS;AACjC,QAAM,KAAK,KAAK,KAAK,EAAE,OAAO,UAAQ;AAClC,WAAO,YAAY,KAAK,SAAQ,GAAI,UAAU,MAAM,cAAc;AAAA,EACxE,CAAK,EACA,QAAQ,UAAQ;AACf,UAAM,WAAU,QAAQ,QAAQ,KAAK,qCAAqC,KAAK,MAAM;AACrF,QAAI,CAAC,SAAQ;AAAQ;AACrB,QAAI,SAAQ,OAAQ,EAAC,SAAQ,EAAG,WAAW,GAAG;AAC5C,aAAO,SAAQ,SAAS;IACzB;AACD,aAAQ,KAAK,qCAAqC,KAAK,MAAM,EAAE;EACrE,CAAK;AACL;AAbS;AAeT,wBAAwB,KAAK,MAAM;AACjC,MAAI,CAACE,WAAmB,SAAS,cAAc,KAAK,CAACA,WAAmB,SAAS,iBAAiB;AAAG;AAErG,QAAM,YAAY,KAAK,QAAQ,IAAI,YAAY,GAAG;AAClD,QAAM,UAAU,wCAAyC,aAAY,2BAA2B;AAChG,QAAM,QAAO,CAAC,YAAY,mBAAmB;AAC7C,QAAM,SAAS,EAAE,gCAAgC,4CAA4C,gBAAe;AAE5G,SAAO,MAAM,MAAM;AACjB,SAAK,UAAU;EACnB,CAAG;AACD,OAAK,OAAO,MAAM;AACpB;AAZS;AAcT,qCAAqC,MAAM,WAAW;AAEpD,YAAU,KAAK;AAAA,IACb,MAAM;AAAA,IACN,MAAM;AAAA,IACN,UAAU,CAAC,UAAS;AAClB,YAAM,UAAU,MAAK,GAAG,QAAQ;AAChC,YAAM,QAAQ,KAAK,OAAO,IAAI,OAAO;AACrC,YAAM,QAAQ,MAAM,KAAK,KAAK,KAAK,EAAE,OAAO,OAAK,EAAE,MAAM,EAAE,IAAI,OAAK,EAAE,EAAE;AACxE,aAAO,KAAK,UAAU,wBAAwB,OAAO,EAAE,OAAO,qBAAqB,KAAI,CAAE;AAAA,IAC1F;AAAA,IACD,WAAW,CAAC,UAAS;AACnB,YAAM,UAAU,MAAK,GAAG,QAAQ;AAChC,YAAM,QAAQ,KAAK,OAAO,IAAI,OAAO;AACrC,aAAO,KAAK,KAAK,QAAQwB,gBAA8B,KAAK;AAAA,IAC7D;AAAA,EACL,GAAK;AAAA,IACD,MAAM;AAAA,IACN,MAAM;AAAA,IACN,UAAU,CAAC,UAAS;AAClB,YAAM,UAAU,MAAK,GAAG,QAAQ;AAChC,YAAM,QAAQ,KAAK,OAAO,IAAI,OAAO;AACrC,YAAM,OAAO,MAAM,KAAK,KAAK,KAAK,EAAE,KAAK,OAAK,EAAE,cAAc,SAAS,EAAE,MAAM;AAC/E,aAAO,KAAK,UAAU,aAAa,IAAI;AAAA,IACxC;AAAA,IACD,WAAW,CAAC,UAAS;AACnB,YAAM,UAAU,MAAK,GAAG,QAAQ;AAChC,YAAM,QAAQ,KAAK,OAAO,IAAI,OAAO;AACrC,aAAOxB,WAAmB,SAAS,cAAc,KAC3C,MAAK,MAAM,cAAc,SAAS,MAAM,KAAK,KAAK,KAAK,EAAE,KAAK,OAAK,EAAE,cAAc,SAAS,EAAE,MAAM;AAAA,IAC3G;AAAA,EACL,CAAG;AACH;AAhCS;AAkCT,kCAAkC,YAAY,SAAS;AAErD,MAAI,CAAC,KAAK,KAAK;AAAM;AAErB,MAAI,MAAM,WAAW;AAErB,UAAQ,QAAQ;AAAA,IACd,OAAOA,WAAmB,SAAS,sBAAsB,IAAI,KAAK;AAAA,IAClE,MAAM;AAAA,IACN,OAAO;AAAA,IACP,SAAS,MAAM;AACb,qBAAe,KAAK,GAAG;AAAA,IACxB;AAAA,EACL,CAAG;AACH;AAdS;AAgBT,iCAAiC,WAAW,SAAS;AAEnD,MAAI,CAAC,KAAK,KAAK;AAAM;AAErB,MAAI,MAAM,UAAU;AAEpB,UAAQ,QAAQ;AAAA,IACd,OAAOA,WAAmB,SAAS,sBAAsB,IAAI,KAAK;AAAA,IAClE,MAAM;AAAA,IACN,OAAO;AAAA,IACP,SAAS,MAAM;AACb,iBAAW,KAAK,GAAG;AAAA,IACpB;AAAA,EACL,CAAG;AACH;AAdS;ACzFM,+BAA+B;AAE5C,aAAW,SAAS,UAAU,aAAa,iCAAiC,SAAU,YAAY,MAAM;AACtG,QAAIwB,gBAA8B,KAAK,QAAQ,KAAK,kBAAkB,mBAAmB;AACvF,aAAO,WAAW,iBAAiB,KAAK,QAAQ;AAAA,IACjD;AACD,WAAO,QAAQ,GAAG,IAAI;AAAA,EACvB,GAAE,OAAO;AAEV,aAAW,SAAS,UAAU,aAAa,mDAAmD,SAAU,SAAS,OAAO;AAEtH,UAAM,eAAc;AACpB,UAAM,WAAU,MAAM;AACtB,UAAM,aAAa,SAAQ,cAAc,QAAQ;AACjD,UAAM,YAAW,KAAK,YAAY,WAAW,IAAI,UAAU;AAE3D,QAAIA,gBAA8B,SAAQ,KAAK,kBAAkB,mBAAmB;AAClF,aAAO,KAAK,UAAU,wBAAwB,WAAU,EAAE,qBAAqB,KAAI,CAAE;AAAA,IACtF;AACD,WAAO,QAAQ,KAAK;AAAA,EACrB,GAAE,OAAO;AAEZ;AAtBwB;;;;;;;;;;;;;;;;ACqCX,MAAA,WAAA,OAAK,YAAQ,kBAAA,GAAA;;;;;;;;;;;;;;AAFpB,aAKM,QAAA,KAAA,MAAA;AAJJ,aAAoD,KAAA,KAAA;AAAZ,sBAAA,OAAA,OAAK,KAAK;;;;;;;;;;AAAV,UAAA,QAAA,KAAA,MAAA,UAAA,QAAK,OAAK;AAAV,wBAAA,OAAA,QAAK,KAAK;AAAA;AAC7C,UAAA,QAAK,UAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AANkD,mBAAA,OAAA,WAAA,CAAA,OAAK,SAAS,IAAK,GAAA,UAAU,CAAC;AAAA;;AAApG,aAAsG,QAAA,OAAA,MAAA;AAA5D,sBAAA,OAAA,OAAK,KAAK;;;;;;;AAAV,UAAA,QAAA,KAAA,UAAA,MAAA,KAAA,MAAA,QAAK,OAAK;AAAV,wBAAA,OAAA,QAAK,KAAK;AAAA;;AAAkB,qBAAA,OAAA,WAAA,CAAA,QAAK,SAAS,KAAK,GAAA,UAAU,CAAC;AAAA;;;;;;;;;;;;;;;;;;;AAZzF,MAAA,aAAA,OAAO,QAAQ,OAAK,OAAO;mDAA2B,KAAK;iCAAhE,QAAI,KAAA,GAAA;;;;;;;;;;;;AADM,WAAA,QAAA,QAAA,oBAAA,OAAK,GAAG;;AAAc,UAAA,OAAK,UAAK;AAAA,4BAAA,MAAA,IAAA,GAAA,KAAA,MAAA,CAAA;;;;AADhD,aAUM,QAAA,KAAA,MAAA;AATJ,aAQS,KAAA,MAAA;;;;AAR2B,oBAAA,QAAA,OAAK,KAAK;;;;;;;;AACrC,qBAAA,OAAO,QAAQ,QAAK,OAAO;;;AADtB,UAAA,QAAA,KAAA,sBAAA,qBAAA,QAAK,MAAG;;;;AAAc,sBAAA,QAAA,QAAK,KAAK;AAAA;;;;;;;;;;;;;;;;;;;;;;;;AALhD,aAAiD,QAAA,OAAA,MAAA;AAAZ,YAAA,UAAA,OAAK;;;;;;;;AAAL,cAAA,UAAA,QAAK;AAAA;;;;;;;;;;;;;;;;;;;wCAyBH,SAAS,IAAI,GAAC,KAAK;;;;AAAtD,aAAyD,QAAA,OAAA,MAAA;AAAA;;kEAAtB,SAAS,KAAI,GAAC,KAAK,MAAA,MAAA,UAAA,mBAAA;;;;;;;;;;;;;AAf3B,MAAA,UAAA,SAAS,IAAM,EAAA,IAAA;;;;;;;4CAAtB,IAAG;;;;AAAnB,aAAiD,QAAA,QAAA,MAAA;;;;AAA1B,UAAA,QAAA,KAAA,YAAA,WAAA,SAAS,KAAM,EAAA,IAAA;AAAA,iBAAA,GAAA,OAAA;oEAAtB,KAAG,KAAA;;;;;;;;;;;;;;AAFM,MAAA,UAAA,SAAS,IAAM,EAAA,IAAA;;;;;;;4CAAxB,IAAK;;;;AAArB,aAAmD,QAAA,QAAA,MAAA;;;;AAA1B,UAAA,QAAA,KAAA,YAAA,WAAA,SAAS,KAAM,EAAA,IAAA;AAAA,iBAAA,GAAA,OAAA;oEAAxB,KAAK,KAAA;;;;;;;;;;;;;;;;QADlB,KAAI,GAAC,SAAS;AAAM,aAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAhBzB,SAAS,IAAI,GAAC,IAAI,IAAA;;;;;;;iBAER,SAAS,IAAI,GAAC,IAAI,IAAA;;;;;;;QAK/B,KAAI,GAAC,SAAS;AAAO,aAAAD;AAIhB,QAAA,QAAK;AAAO,aAAA;QAcZ,KAAI,GAAC,SAAS;AAAM,aAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA5BlC,aA4CM,QAAA,MAAA,MAAA;AA1CJ,aAIM,MAAA,IAAA;AAHJ,aACmG,MAAA,KAAA;;;AADtE,aAC8D,OAAA,CAAA;AAD3D,aACuD,GAAA,CAAA;;AACvF,aAA0C,MAAA,CAAA;;;AAG5C,aAkCM,MAAA,IAAA;;;;;;;;gDAvCI,SAAS,KAAI,GAAC,IAAI,IAAA;AAAA,iBAAA,IAAA,QAAA;gDAER,SAAS,KAAI,GAAC,IAAI,IAAA;AAAA,iBAAA,IAAA,QAAA;;;;;;;;;;;;;;;;;;;;;;;;;QAR3B,SAAI;;AAOwC,iBAAA,GAAA,KAAK,QAAQ,KAAK,SAAO,IAAA;AAAA;;AAQvC,SAAK,QAAK,KAAA;;;;;AAKT,SAAK,QAAK,aAAA,IAAA;;;;;AAaN,SAAK,QAAK,UAAA,KAAA,KAAA;;;;;AAKV,SAAK,QAAK,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACOlD,aAKK,QAAA,IAAA,MAAA;AAJH,aAA6F,IAAA,GAAA;AAAzF,aAAoF,KAAA,KAAA;6BAAR,IAAI,GAAA;;AACpF,aAEK,IAAA,GAAA;AADH,aAAoF,KAAA,MAAA;;;;;;AAApD,gBAAA,YAAA,IAAO,GAAA,IAAP,GAAA,CAAA;AAAA,qBAAO,IAAK,GAAA,EAAA,MAAA,MAAA,SAAA;AAAA;;;;;;;uCAFkC,IAAI,KAAA;+BAAJ,IAAI,GAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUzD,MAAA,WAAA,SAAS,mDAAmD,IAAA;;;;;;AAG1D,MAAA,YAAA,SAAS,QAAQ,IAAA;;;;mBAf3C,IAAgB;mDAAiB,KAAK;iCAA3C,QAAI,KAAA,GAAA;;;;;;;;;AARJ,SAAA,cAAA,GAAA,SAAS,2DAA2D;;;AACpE,SAAA,cAAA,GAAA,SAAS,2DAA2D;;;;;AAI/D,UAAA,cAAA,GAAA,SAAS,iDAAiD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AANrE,aA4BO,QAAA,QAAA,MAAA;AA3BL,aAA8E,QAAA,EAAA;;AAC9E,aAA8E,QAAA,EAAA;;AAE9E,aAaQ,QAAA,KAAA;AAZN,aAGK,OAAA,EAAA;AAFH,aAAsE,IAAA,GAAA;;AACtE,aAAqG,IAAA,GAAA;AAAnF,aAA8E,KAAA,CAAA;;;;;;AAYpG,aAOS,QAAA,MAAA;AANP,aAES,QAAA,OAAA;AADP,aAA2B,SAAA,EAAA;;;;AAE7B,aAES,QAAA,OAAA;AADP,aAA4B,SAAA,EAAA;;;;;;6BAjBG,IAAG,EAAA;AAAA,mCAaC,IAAa,IAAA,EAAA,MAAA,MAAA;AAAA;mDApBL,IAAc,EAAA,CAAA;AAAA;;;;;;qBASpD,KAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAxCnB,gBAAgB,WAAW,UAAU;MAEzC;QAEO,gBAAW;AAClB,MAAA,mBAAmB,WAAW,SAAS,iBAAiB;iBAEhD;oBACV,mBAAgB,CAAA,GAAO,kBAAkB,EAAE,CAAA;;;AADpC;AAKA,kBAAO,OAAK;AACnB,qBAAiB,OAAO,OAAO,CAAC;;;AADzB;kCAKoB;AAC3B,gBAAY,QAAQ,QAAQ,gBAAgB;AAC5C,gBAAY,MAAK;AAAA;AAFJ;2BAKc;AAC3B,SAAK,cAAa;AAAA;AADJ;;;;;;;AAgCiC,gBAAY,MAAK;AAAA;;;AAvBjD,aAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACnCR,MAAM,+BAA+B,kBAAkB;AAAA,EAEpE,YAAY,SAAS;AACnB,UAAM;AAAA,MACJ,QAAQ;AAAA,QACN,OAAOwF;AAAAA,QACP,QAAQ,SAAS;AAAA,MAClB;AAAA,MACD,OAAO,MAAM,KAAK,QAAQ,QAAQ,IAAI;AAAA,MACtC,GAAG;AAAA,IACT,CAAK;AAAA,EACF;AAAA,EAED,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,OAAO,KAAK,KAAK,SAAS,kDAAkD;AAAA,MAC5E,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS,CAAC,gBAAgB;AAAA,IAChC,CAAK;AAAA,EACF;AAAA,EAED,aAAa,KAAK,UAAU,IAAI;AAC9B,WAAO,IAAI,QAAQ,aAAW;AAC5B,cAAQ,UAAU;AAClB,aAAO,IAAI,KAAK,OAAO,EAAE,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,IAC3D,CAAK;AAAA,EACF;AACH;AA5BqB;ACErB,MAAe,UAAA;AAAA,EACb,cAAc;AAAA,EACd,gBAAgB;AAAA,EAChB,qBAAqB;AAAA,EACrB,mBAAmB;AACrB;;;;;;iBCgBY,SAAS,IAAI,GAAC,IAAI,IAAA;;;;;;;iBAER,SAAS,IAAI,GAAC,IAAI,IAAA;;;;;;;;;iBAO/B,SAAS,IAAI,GAAC,KAAK,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AADT,WAAA,IAAA,SAAA,iBAAA,cAAA,OAAK,IAAI,IAAA,iBAAA;;;;;;;;AAX5B,aAiBM,QAAA,MAAA,MAAA;AAfJ,aAIM,MAAA,IAAA;AAHJ,aACmG,MAAA,KAAA;;;AADtE,aAC8D,OAAA,CAAA;AAD3D,aACuD,GAAA,EAAA;;AACvF,aAA0C,MAAA,CAAA;;;AAG5C,aAOM,MAAA,IAAA;AANJ,aAKM,MAAA,IAAA;AAJJ,aAGS,MAAA,MAAA;AAFP,aAA2B,QAAA,EAAA;;;;;;kCADG,IAAU,EAAA;AAAA;;;;;gDAPpC,SAAS,KAAI,GAAC,IAAI,IAAA;AAAA,iBAAA,IAAA,QAAA;gDAER,SAAS,KAAI,GAAC,IAAI,IAAA;AAAA,iBAAA,IAAA,QAAA;AAMrB,UAAA,QAAA,KAAA,mBAAA,kBAAA,cAAA,QAAK,IAAI,IAAA,oBAAA;;;gDACnB,SAAS,KAAI,GAAC,KAAK,IAAA;AAAA,iBAAA,IAAA,QAAA;AAAA;;;;;;;;;;;;;UA9BlB,gBAAgB,WAAW,UAAU;QAElC,SAAI;AACX,MAAA,SAAS,QAAQ,KAAK;wBAEP;QACb,QAAM;AACR,aAAO,KAAI,EAAG,KAAM,YAAM;YACpB,QAAM;0BACR,KAAK,QAAQ,QAAM,IAAA;AAAA;;AAGvB,kBAAY,QAAQ,SAAS;AAAA;;AAPxB;;AAiB8C,iBAAA,GAAA,KAAK,QAAQ,KAAK,SAAO,IAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MCiEnD,IAAQ,GAAC,SAAS,2BAAqB,QAAA;0BAAvC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,oBAAc,QAAA;0BAAhC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,wBAAkB,QAAA;0BAApC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,oBAAc,QAAA;0BAAhC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,uBAAiB,QAAA;0BAAnC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,4BAAsB,QAAA;0BAAxC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;IAI6B,SAAA,KAAK,OAAO,SAAS,MAAM;AAAA;MAA1E,IAAQ,GAAC,SAAS,sBAAgB,QAAA;0BAAlC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,6BAAuB,QAAA;0BAAzC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,0BAAoB,QAAA;0BAAtC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MACZ,IAAQ,GAAC,SAAS,gBAAU,QAAA;gCAA5B,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,kBAAY,QAAA;gCAA9B,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,uBAAiB,QAAA;gCAAnC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAfX,mBAAA,MAAA,UAAA,WAAc,QAAQ;;;;AAStB,mBAAA,MAAA,UAAA,WAAc,QAAQ;AAAA;;AAT1D,aAOM,QAAA,MAAA,MAAA;;;;;;;;;;;;;AAEN,aAOM,QAAA,MAAA,MAAA;;;;;;;;;;;;;;;;;;gCAfiB,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;AANL,qBAAA,MAAA,UAAA,YAAc,QAAQ;AAAA;;;;gCAUnC,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;;;sCACZ,KAAQ,GAAC,SAAS;;;;;;;sCAClB,KAAQ,GAAC,SAAS;;;;;;;sCAClB,KAAQ,GAAC,SAAS;;;;;AANX,qBAAA,MAAA,UAAA,YAAc,QAAQ;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAc9B,MAAA,YAAA,SAAS,yCAAyC,IAAA;;;;;;;;;;;;;;;;;;;;MAtDzD,IAAQ,GAAC,SAAS,uBAAiB,QAAA;0BAAnC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,4BAAsB,QAAA;0BAAxC,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,mBAAa,QAAA;0BAA/B,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,WAAK,QAAA;0BAAvB,IAAQ,GAAC,SAAS;AAAA;;;;;;;;MAClB,IAAQ,GAAC,SAAS,iBAAW,QAAA;0BAA7B,IAAQ,GAAC,SAAS;AAAA;;;iBA0BpC,IAAQ,MAAA,gBAAA,GAAA;;;;;AAtCuC,SAAA,cAAA,GAAA,SAAS,wCAAwC;;;;;;;;;;;;;;;;;;AAe7F,SAAA,cAAA,GAAA,SAAS,6CAA6C;AAAA;;;;AAMtD,SAAA,cAAA,GAAA,SAAS,0CAA0C;;;AAGpD,SAAA,cAAA,GAAA,SAAS,yCAAyC;;;;;;;;;;;;;;;;;;;;;;;;;;AAlBrB,mBAAA,MAAA,UAAA,WAAc,OAAO;;;;;;;;AAR7D,aAkEO,QAAA,QAAA,MAAA;AAhEL,aAA8G,QAAA,EAAA;;;;AAI9G,aAsDU,QAAA,OAAA;AApDR,aA8BM,SAAA,IAAA;;;;;;;;;;;AAtBJ,aAoBM,MAAA,IAAA;AAnBJ,aACA,MAAA,EAAA;AAAA,aACA,MAAA,EAAA;AAAA,aAKI,MAAA,EAAA;AAJF,aAG2D,IAAA,EAAA;;AAE7D,aAEI,MAAA,EAAA;;AACJ,aAOI,MAAA,EAAA;;;;;AA2BV,aAGS,QAAA,MAAA;AAFP,aAC2F,QAAA,OAAA;AADvC,aACxB,SAAA,CAAA;;;;;;;mCADS,IAAa,IAAA,EAAA,MAAA,MAAA;AAAA,mDA/DA,IAAc,EAAA,GAAA,EAAA,MAAA,MAAA;AAAA;;;;;;;;;;;;;;;gCAUzC,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;;;gCAClB,KAAQ,GAAC,SAAS;;;;;AANL,qBAAA,MAAA,UAAA,YAAc,OAAO;AAAA;UAgCpD,KAAQ;AAAA,iBAAA,EAAA,MAAA,KAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UA7ET,gBAAgB,WAAW,UAAU;QAElC,gBAAW;MAClB;AAEA,MAAA,WAAW,OAAO,YAAY,OAAO,QAAQ,SAAS,YAAe,CAAA,EAAA,IAAI,WAAK;AAChF,UAAM,GAAG,QAAQC,WAAmB,MAAM,EAAC;WACpC;AAAA;AAGL,MAAA,WAAW,KAAK,KAAK;2BAEH;AACpB,SAAK,cAAa;AAAA;AADX;kCAIoB;AACvB,QAAA,mBAAmB,OAAO,QAAQ,QAAQ,EAAE,OAAO,WAAS,YAAY,MAAM,GAAG,UAAU,QAAQ;cAC7F,KAAK,YAAY,kBAAgB;AACnC,YAAAC,WAAmB,KAAK,QAAQ,KAAK;AAAA;AAE7C,gBAAY,MAAK;AAAA;AALJ;MAQX,OAAI;AAAA;MACJ,OAAO;AAAA,MAAS,OAAO,SAAS,wCAAwC;AAAA;;MACxE,OAAO;AAAA,MAAU,OAAO,SAAS,yCAAyC;AAAA,MAAG,SAAS;AAAA;;MACtF,OAAO;AAAA,MAAU,OAAO,SAAS,yCAAyC;AAAA,MAAG,SAAS;AAAA;;AAGtF,MAAA,YAAY,KAAK,GAAG;;;;;;;4BAiBG,SAAS,SAAS,oBAAiB,KAAA,GAAA;AAAnC,eAAS,SAAS,qBAAiB;;;;;;4BACnC,SAAS,SAAS,yBAAsB,KAAA,GAAA;AAAxC,eAAS,SAAS,0BAAsB;;;;;;4BACxC,SAAS,SAAS,gBAAa,KAAA,GAAA;AAA/B,eAAS,SAAS,iBAAa;;;;;;4BAC/B,SAAS,SAAS,QAAK,KAAA,GAAA;AAAvB,eAAS,SAAS,SAAK;;;;;;4BACvB,SAAS,SAAS,cAAW,KAAA,GAAA;AAA7B,eAAS,SAAS,eAAW;;;;;;4BA4B3B,SAAS,SAAS,wBAAqB,KAAA,GAAA;AAAvC,eAAS,SAAS,yBAAqB;;;;;;4BACvC,SAAS,SAAS,iBAAc,KAAA,GAAA;AAAhC,eAAS,SAAS,kBAAc;;;;;;4BAChC,SAAS,SAAS,qBAAkB,KAAA,GAAA;AAApC,eAAS,SAAS,sBAAkB;;;;;;4BACpC,SAAS,SAAS,iBAAc,KAAA,GAAA;AAAhC,eAAS,SAAS,kBAAc;;;;;;4BAChC,SAAS,SAAS,oBAAiB,KAAA,GAAA;AAAnC,eAAS,SAAS,qBAAiB;;;;;;4BACnC,SAAS,SAAS,yBAAsB,KAAA,GAAA;AAAxC,eAAS,SAAS,0BAAsB;;;;;;4BAIxC,SAAS,SAAS,mBAAgB,KAAA,GAAA;AAAlC,eAAS,SAAS,oBAAgB;;;;;;4BAClC,SAAS,SAAS,0BAAuB,KAAA,GAAA;AAAzC,eAAS,SAAS,2BAAuB;;;;;;4BACzC,SAAS,SAAS,uBAAoB,KAAA,GAAA;AAAtC,eAAS,SAAS,wBAAoB;;;;;;4BAChC,SAAS,SAAS,aAAU,KAAA,GAAA;AAA5B,eAAS,SAAS,cAAU;;;;;;4BAC5B,SAAS,SAAS,eAAY,KAAA,GAAA;AAA9B,eAAS,SAAS,gBAAY;;;;;;4BAC9B,SAAS,SAAS,oBAAiB,KAAA,GAAA;AAAnC,eAAS,SAAS,qBAAiB;;;;;;;AAxDrD,aAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC/CvB,MAAM,oBAAoB,kBAAkB;AAAA,EAE1C,WAAW,iBAAiB;AAC1B,WAAO,QAAQ,MAAM,YAAY,MAAM,gBAAgB;AAAA,MACrD,IAAI;AAAA,MACJ,OAAO;AAAA,MACP,OAAO;AAAA,MACP,QAAQ;AAAA,QACN,OAAOC;AAAAA,QACP,QAAQ,SAAS;AAAA,MAClB;AAAA,MACD,QAAQ;AAAA,IACd,CAAK;AAAA,EACF;AAAA,EAED,OAAO,eAAe;AACpB,WAAO,OAAO,OAAO,GAAG,OAAO,EAAE,KAAK,SAAO,IAAI,OAAO,wCAAwC;AAAA,EACjG;AAAA,EAED,aAAa,KAAK,UAAU,IAAI,aAAa,CAAA,GAAI;AAC/C,UAAM,MAAM,KAAK,aAAc;AAC/B,QAAI;AAAK,aAAO,IAAI,OAAO,OAAO,EAAE,OAAO,KAAI,CAAE;AACjD,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,cAAQ,UAAU;AAClB,UAAI,KAAK,SAAS,UAAU,EAAE,OAAO,MAAM,EAAE,OAAO,KAAI,CAAE;AAAA,IAChE,CAAK;AAAA,EACF;AACH;AA3BM;AA6BS,MAAM,qBAAqB,gBAAgB;AAAA,EAKxD,cAAc;AACZ,UAAM,CAAE,CAAA;AACR,gBAAY,KAAI;AAAA,EACjB;AAAA,EAED,MAAM,cAAc,OAAO,UAAU;AAAA,EACpC;AAAA,EAED,SAAS;AACP,SAAK,MAAK;AAAA,EACX;AAEH;AAjBqB;AC1Bd,4BAA4B;AAEjC,OAAK,SAAS,aAAa,UAAU,aAAa,sBAAsB;AAAA,IACtE,MAAM;AAAA,IACN,OAAO;AAAA,IACP,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,YAAY;AAAA,EAChB,CAAG;AAED,WAAS,CAAC,MAAM,SAAS,OAAO,QAAQ,SAAS,YAAW,CAAE,GAAG;AAC/D,SAAK,SAAS,SAAS,UAAU,aAAa,MAAM,IAAI;AAAA,EACzD;AAEH;AAfgB;AAiBhB,sCAAsC;AACpC,QAAM,WAAW,SAAS;AAC1B,aAAW,CAAC,MAAM,SAAS,OAAO,QAAQ,QAAQ,GAAG;AACnD,UAAMb,WAAmB,MAAM,KAAK,OAAO;AAAA,EAC5C;AACD,QAAMA,WAAmB,SAAS,gBAAgB,QAAQ,KAAK,OAAO;AACtE,QAAM,sBAAqB;AAC7B;AAPe;AASR,uCAAuC;AAC5C,QAAM,aAAarG,WAAmB,SAAS,UAAU;AACzD,WAAS,YAAY,YAAY;AAC/B,QAAI,SAAS,SAAS,UAAU,CAAC,SAAS,KAAK,QAAQ,SAAS,KAAK;AAAM;AAC3E,UAAM,OAAO,MAAM,SAAS,SAAS,KAAK,IAAI;AAC9C,QAAI,CAAC;AAAM;AACX,aAAS,KAAK,OAAO,KAAK,SAAQ;AAAA,EACnC;AACD,QAAMqG,WAAmB,SAAS,YAAY,UAAU;AAC1D;AATsB;AAWf,6BAA6B;AAElC,MAAIrG,WAAmB,SAAS,oBAAoB;AAAG;AAEvD,MAAI,CAAC,QAAQ,oBAAoB;AAE/B,QAAIA,WAAmB,SAAS,8BAA8B;AAAG;AAEjE,QAAI,gBAAgB;AACpB,eAAW,CAAC,MAAM,SAAS,OAAO,QAAQ,SAAS,YAAW,CAAE,GAAG;AACjE,sBAAgB,iBAAiBA,WAAmB,IAAI,EAAE,WAAY,IAAI,KAAK,OAAM;AAAA,IACtF;AAED,QAAI;AAAe;AAEnB,WAAO,OAAO;AAAA,MACZ,OAAO,KAAK,KAAK,SAAS,wCAAwC;AAAA,MAClE,SAAS6G,aAAqB,EAAE,SAAS,KAAK,KAAK,SAAS,0CAA0C,GAAG;AAAA,MACzG,UAAU,MAAM;AAAA,MACf;AAAA,IACP,CAAK;AAED,WAAOR,WAAmB,SAAS,gCAAgC,IAAI;AAAA,EAExE;AAED,MAAIrG,WAAmB,SAAS,YAAY,GAAG;AAC7C,UAAM,iBAAiBA,WAAmB,SAAS,cAAc;AACjE,UAAM,aAAa,QAAQ,KAAK;AAChC,QAAI,eAAe,YAAY,cAAc,GAAG;AAC9C,aAAO,IAAI,OAAO;AAAA,QAChB,OAAO,KAAK,KAAK,SAAS,2CAA2C;AAAA,QACrE,SAAS6G,aAAqB;AAAA,UAC5B,SAAS,KAAK,KAAK,SAAS,6CAA6C;AAAA,QACnF,CAAS;AAAA,QACD,SAAS;AAAA,UACP,SAAS;AAAA,YACP,MAAM;AAAA,YACN,OAAO,KAAK,KAAK,SAAS,6CAA6C;AAAA,YACvE,UAAU,MAAM;AACd;YACD;AAAA,UACF;AAAA,UACD,QAAQ;AAAA,YACN,MAAM;AAAA,YACN,OAAO,KAAK,KAAK,SAAS,IAAI;AAAA,UAC/B;AAAA,QACF;AAAA,QACD,SAAS;AAAA,MACjB,CAAO,EAAE,OAAO,IAAI;AAAA,IACf;AACD;AAAA,EACD;AAED,QAAMR,WAAmB,SAAS,cAAc,IAAI;AAEpD,MAAIrG,WAAmB,SAAS,8BAA8B,GAAG;AAE/D,WAAO,IAAI,OAAO;AAAA,MAChB,OAAO,KAAK,KAAK,SAAS,sCAAsC;AAAA,MAChE,SAAS6G,aAAqB;AAAA,QAC5B,SAAS,KAAK,KAAK,SAAS,wCAAwC;AAAA,QACpE,MAAM;AAAA,MACd,CAAO;AAAA,MACD,SAAS;AAAA,QACP,SAAS;AAAA,UACP,MAAM;AAAA,UACN,OAAO,KAAK,KAAK,SAAS,wCAAwC;AAAA,UAClE,UAAU,MAAM;AACd;UACD;AAAA,QACF;AAAA,QACD,QAAQ;AAAA,UACN,MAAM;AAAA,UACN,OAAO,KAAK,KAAK,SAAS,IAAI;AAAA,QAC/B;AAAA,MACF;AAAA,MACD,SAAS;AAAA,IACf,CAAK,EAAE,OAAO,IAAI;AAAA,EAEf;AAED,SAAO,qBAAoB;AAC7B;AAnFsB;ACzBtB,MAAM,KAAK,QAAQ,YAAY;AAC7B;AACA;AACA;AACA;AAEA,aAAW,WAAU;AACrB,WAAS,WAAU;AACnB,UAAQ,WAAU;AAElB,OAAK,YAAY;AACjB,SAAO,YAAY;AAAA,IACjB;AAAA,EACJ;AACA,CAAC;AAED,MAAM,KAAK,SAAS,YAAY;AAE9B,MAAI,CAAC,KAAK,QAAQ,IAAI,aAAa,GAAG,UAAU,KAAK,KAAK,MAAM;AAC9D,QAAI,OAAO;AACX,QAAI,KAAK,QAAQ,IAAI,aAAa;AAAG,aAAO;AAC5C,UAAM9E,aAAqB,uDAAuD,UAAU;AAAA,EAC7F;AACD,MAAI,CAAC,KAAK,QAAQ,IAAI,WAAW,GAAG,UAAU,KAAK,KAAK,MAAM;AAC5D,QAAI,OAAO;AACX,QAAI,KAAK,QAAQ,IAAI,WAAW;AAAG,aAAO;AAC1C,UAAMA,aAAqB,sDAAsD,UAAU;AAAA,EAC5F;AAED,MAAI,CAAC+D,cAAqB,GAAI;AAC5Bd,mBAAuB,uFAAuF,IAAI;AAAA,EACnH;AAED,MAAI,KAAK,KAAK,MAAM;AAClB;AACA;EACD;AACD;AACA,QAAM,QAAQ,MAAM,KAAK;AAEzB,UAAQ,0BAAyB;AAsBnC,CAAC;AAED,MAAM,KAAK,mBAAmB,MAAM;AAClCmC,iBAAO,WAAU;AACnB,CAAC;AAED,MAAM,GAAG,4BAA4B,YAAY;AAC/C,WAAS,WAAW,KAAK,SAAS,QAAQ,IAAI,OAAO,EAAE,OAAO,cAAW,SAAQ,KAAK,IAAI,SAAS,YAAY,CAAC,GAAG;AACjH,UAAM,QAAQ;EACf;AACH,CAAC;"}
\ No newline at end of file
diff --git a/module.json b/module.json
index 0d38224f..85be4495 100644
--- a/module.json
+++ b/module.json
@@ -1,54 +1,56 @@
{
- "name": "item-piles",
- "title": "Item Piles",
- "description": "This module adds the ability for items to be dropped onto the ground, and then picked up.",
- "version": "This is auto replaced",
- "library": "false",
- "manifestPlusVersion": "1.0.0",
- "minimumCoreVersion": "0.8.9",
- "compatibleCoreVersion": "9",
- "authors": [
- {
- "name": "Wasp",
- "url": "https://github.com/Haxxer",
- "discord": "Wasp#2005"
- }
- ],
- "esmodules": [
- "/scripts/module.js"
- ],
- "styles": [
- "/styles/module.css"
- ],
- "languages": [
- {
- "lang": "en",
- "name": "English",
- "path": "languages/en.json"
- },
- {
- "lang": "fr",
- "name": "French",
- "path": "languages/fr.json"
- },
- {
- "lang": "ja",
- "name": "ę„ę¬čŖ",
- "path": "languages/ja.json"
- }
- ],
- "dependencies": [
- {
- "name": "socketlib"
- },
- {
- "name": "lib-wrapper"
- }
- ],
- "socket": true,
- "url": "This is auto replaced",
- "manifest": "This is auto replaced",
- "download": "This is auto replaced",
- "bugs": "This is auto replaced",
- "allowBugReporter": true
+ "name": "item-piles",
+ "title": "Item Piles",
+ "description": "This module adds the ability for items to be dropped onto the ground, and then picked up.",
+ "version": "100.0.0",
+ "library": "false",
+ "manifestPlusVersion": "1.0.0",
+ "minimumCoreVersion": "0.8.9",
+ "compatibleCoreVersion": "9",
+ "authors": [
+ {
+ "name": "Wasp",
+ "url": "https://github.com/Haxxer",
+ "discord": "Wasp#2005"
+ }
+ ],
+ "esmodules": [
+ "module.js"
+ ],
+ "styles": [
+ "style.css"
+ ],
+ "languages": [
+ {
+ "lang": "en",
+ "name": "English",
+ "path": "languages/en.json"
+ },
+ {
+ "lang": "fr",
+ "name": "French",
+ "path": "languages/fr.json"
+ },
+ {
+ "lang": "ja",
+ "name": "ę„ę¬čŖ",
+ "path": "languages/ja.json"
+ }
+ ],
+ "dependencies": [
+ {
+ "name": "socketlib",
+ "type": "module"
+ },
+ {
+ "name": "lib-wrapper",
+ "type": "module"
+ }
+ ],
+ "socket": true,
+ "url": "This is auto replaced",
+ "manifest": "This is auto replaced",
+ "download": "This is auto replaced",
+ "bugs": "This is auto replaced",
+ "allowBugReporter": true
}
diff --git a/package-lock.json b/package-lock.json
index 899840bf..93022c67 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1,1518 +1,15677 @@
{
- "name": "item-piles",
- "lockfileVersion": 2,
- "requires": true,
- "packages": {
- "": {
- "devDependencies": {
- "@league-of-foundry-developers/foundry-vtt-types": "^9.238.1"
- }
- },
- "node_modules/@league-of-foundry-developers/foundry-vtt-types": {
- "version": "9.238.1",
- "resolved": "https://registry.npmjs.org/@league-of-foundry-developers/foundry-vtt-types/-/foundry-vtt-types-9.238.1.tgz",
- "integrity": "sha512-ZnCay8eRsJTU7+y1x87BsGGEnVSSv2tW8+/8d0BHuULWOuu1HA3Tr1wIGUt++/bd6YKg0iR8jnGLtelXamj6+g==",
- "dev": true,
- "dependencies": {
- "@types/jquery": "~3.5.9",
- "@types/simple-peer": "~9.11.1",
- "handlebars": "4.7.7",
- "pixi-particles": "4.3.1",
- "pixi.js": "5.3.11",
- "socket.io-client": "4.3.2",
- "tinymce": "5.10.1"
- }
- },
- "node_modules/@pixi/accessibility": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/accessibility/-/accessibility-5.3.11.tgz",
- "integrity": "sha512-/oSizd8/g6KUCeAlknMLJ9CRxBt+vWs6e2DrOctMoRupEHcmhICCjIyAp5GF6RZy9T9gNHDOU5p7vo7qEyVxgQ==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/app": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/app/-/app-5.3.11.tgz",
- "integrity": "sha512-ZWrOjGvVl+lK5OJQT3OqSnSRtU2XgQSe/ULg2uGsSWUqMkJews33JIGOjvk4tIsjm4ekSKiPZRMdYFHzPfgEJg==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11"
- }
- },
- "node_modules/@pixi/constants": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
- "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
- "dev": true
- },
- "node_modules/@pixi/core": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
- "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
- "dev": true,
- "dependencies": {
- "@pixi/constants": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/runner": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/ticker": "5.3.11",
- "@pixi/utils": "5.3.11"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/pixijs"
- }
- },
- "node_modules/@pixi/display": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
- "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
- "dev": true,
- "dependencies": {
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/extract": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/extract/-/extract-5.3.11.tgz",
- "integrity": "sha512-YeBrpIO3E5HUgcdKEldCUqwwDNHm5OBe98YFcdLr5Z0+dQaHnxp9Dm4n75/NojoGb5guYdrV00x+gU2UPHsVdw==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/filter-alpha": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-alpha/-/filter-alpha-5.3.11.tgz",
- "integrity": "sha512-HC4PbiEqDWSi3A715av7knFqD3knSXRxPJKG9mWat2CU9eCizSw+JxXp/okMU/fL4ewooiqQWVU2l1wXOHhVFw==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11"
- }
- },
- "node_modules/@pixi/filter-blur": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-blur/-/filter-blur-5.3.11.tgz",
- "integrity": "sha512-iW5cOMEcDiJidOV95bUfhxdcvwM9JzCoWAd+92gAie8L+ElRSHpu1jxXbKHjo/QczQV1LulOlheyDaJNpaBCDg==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/settings": "5.3.11"
- }
- },
- "node_modules/@pixi/filter-color-matrix": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-color-matrix/-/filter-color-matrix-5.3.11.tgz",
- "integrity": "sha512-u9NT4+N1I3XV9ygwsmF8/jIwCLqNCLeFOdM4f73kbw/UmakZZ6i6xjjJMc5YFUpC25qDr1TFlqgdGGGHAPl4ug==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11"
- }
- },
- "node_modules/@pixi/filter-displacement": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-displacement/-/filter-displacement-5.3.11.tgz",
- "integrity": "sha512-CTIy7C/L9I1X3VNx4nMzQbMFvznsGk2viQh0dSo8r5NLgmaAdxhkGI0KUpNjLBz30278tzFfNuRe59K1y1kHuw==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/math": "5.3.11"
- }
- },
- "node_modules/@pixi/filter-fxaa": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-fxaa/-/filter-fxaa-5.3.11.tgz",
- "integrity": "sha512-0ahjui5385e1vRvd7zCc0n5W8ULtNI1uVbDJHP9ueeiF25TKC0GqtZzntNwrQPoU46q8zXdnIGjzMpikbbAasg==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11"
- }
- },
- "node_modules/@pixi/filter-noise": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-noise/-/filter-noise-5.3.11.tgz",
- "integrity": "sha512-98WC9Nd5u2F03Ned9T3vnbmO/YF1jLSioZ623z9wjqpd5DosZgRtYTSGxjVcXTSfpviIuiJpkyF+X097pbVprg==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11"
- }
- },
- "node_modules/@pixi/graphics": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/graphics/-/graphics-5.3.11.tgz",
- "integrity": "sha512-HLu53LV6mRlY0uFSIM2OrCuL7xqXzeJs5d2QfmUJfKJVVZ9sbHDS+6/N/f0tXzvkRPYhSKXvcNPsNn4HmlIE9w==",
- "dev": true,
- "dependencies": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/interaction": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/interaction/-/interaction-5.3.11.tgz",
- "integrity": "sha512-n2K99CYyBcrf8NPxpzmZ5IlJ9TEplsSZfJ/uzMNOEnTObKl4wAhxs51Nb58raH3Ouzwu14YHOpqYrBTEoT1yPA==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/ticker": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/loaders": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/loaders/-/loaders-5.3.11.tgz",
- "integrity": "sha512-1HAeb/NFXyhNhZWAbVkngsTPBGpjZEPhQflBTrKycRaub7XDSZ8F0fwPltpKKVRWNDT+HBgU/zDNE2fpjzqfYg==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/utils": "5.3.11",
- "resource-loader": "^3.0.1"
- }
- },
- "node_modules/@pixi/math": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
- "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
- "dev": true
- },
- "node_modules/@pixi/mesh": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mesh/-/mesh-5.3.11.tgz",
- "integrity": "sha512-KWKKksEr0YuUX1uz1FmpIa/Y37b/0pvFUS+87LoyYq0mRtGbKsTY5i3lBPG/taHwN7a2DQAX3JZpw6yhGKoGpA==",
- "dev": true,
- "dependencies": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/mesh-extras": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mesh-extras/-/mesh-extras-5.3.11.tgz",
- "integrity": "sha512-1GTCMMUW1xv/72x26cxRysblBXW0wU77TNgqtSIMZ1M6JbleObChklWTvwi9MzQO2vQ3S6Hvcsa5m5EiM2hSPQ==",
- "dev": true,
- "dependencies": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/mesh": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/mixin-cache-as-bitmap": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mixin-cache-as-bitmap/-/mixin-cache-as-bitmap-5.3.11.tgz",
- "integrity": "sha512-uQUxatGTTD5zfQ0pWdjibVjT+xEEZJ/xZDZtm/GxC7HSHd4jgoJBcTXWVhbhzwpLPVTnD8+sMnRrGlhoKcpTpQ==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/mixin-get-child-by-name": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mixin-get-child-by-name/-/mixin-get-child-by-name-5.3.11.tgz",
- "integrity": "sha512-fWFVxWtMYcwJttrgDNmZ4CJrx316p8ToNliC2ILmJZW77me7I4GzJ57gSHQU1xFwdHoOYRC4fnlrZoK5qJ9lDw==",
- "dev": true,
- "dependencies": {
- "@pixi/display": "5.3.11"
- }
- },
- "node_modules/@pixi/mixin-get-global-position": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mixin-get-global-position/-/mixin-get-global-position-5.3.11.tgz",
- "integrity": "sha512-wrS9i+UUodLM5XL2N0Y+XSKiqLRdJV3ltFUWG6+jPT5yoP0HsKtx3sFAzX526RwIYwRzRusbc/quxHfRA4tvgg==",
- "dev": true,
- "dependencies": {
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11"
- }
- },
- "node_modules/@pixi/particles": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/particles/-/particles-5.3.11.tgz",
- "integrity": "sha512-+mkt/inWXtRrxQc07RZ29uNIDWV1oMsrRBVBIvHgpR92Kn8EjIDRgoSXNu0jiZ18gRKKCBhwsS4dCXGsZRQ/sA==",
- "dev": true,
- "dependencies": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/polyfill": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/polyfill/-/polyfill-5.3.11.tgz",
- "integrity": "sha512-yQOngcnn+2/L7n6L/g45hCnIDLWdnWmmcCY3UKJrOgbNX+JtLru1RR8AGLifkdsa0R5u48x584YQGqkTAChWVA==",
- "dev": true,
- "dependencies": {
- "es6-promise-polyfill": "^1.2.0",
- "object-assign": "^4.1.1"
- }
- },
- "node_modules/@pixi/prepare": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/prepare/-/prepare-5.3.11.tgz",
- "integrity": "sha512-TvjGeg7xPKjv5NxbM5NXReno9yxUCw/N0HtDEtEFRVeBLN3u0Q/dZsXxL6gIvkHoS09NFW+7AwsYQLZrVbppjA==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/graphics": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/text": "5.3.11",
- "@pixi/ticker": "5.3.11"
- }
- },
- "node_modules/@pixi/runner": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
- "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
- "dev": true
- },
- "node_modules/@pixi/settings": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
- "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
- "dev": true,
- "dependencies": {
- "ismobilejs": "^1.1.0"
- }
- },
- "node_modules/@pixi/sprite": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
- "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
- "dev": true,
- "dependencies": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/sprite-animated": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/sprite-animated/-/sprite-animated-5.3.11.tgz",
- "integrity": "sha512-xU1b6H8nJ1l05h7cBGw2DGo4QdLj7xootstZUx2BrTVX5ZENn5mjAGVD0uRpk8yt7Q6Bj7M+PS7ktzAgBW/hmQ==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/ticker": "5.3.11"
- }
- },
- "node_modules/@pixi/sprite-tiling": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/sprite-tiling/-/sprite-tiling-5.3.11.tgz",
- "integrity": "sha512-KUiWsIumjrnp9QKGMe1BqtrV9Hxm91KoaiOlCBk/gw8753iKvuMmH+/Z0RnzeZylJ1sJsdonTWy/IaLi1jnd0g==",
- "dev": true,
- "dependencies": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/spritesheet": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/spritesheet/-/spritesheet-5.3.11.tgz",
- "integrity": "sha512-Y9Wiwcz/YOuS1v73Ij9KWQakYBzZfldEy3H8T4GPLK+S19/sypntdkNtRZbmR2wWfhJ4axYEB2/Df86aOAU2qA==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/loaders": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/text": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/text/-/text-5.3.11.tgz",
- "integrity": "sha512-PmWvJv0wiKyyz3fahnxM19+m8IbF2vpDKIImqb5472WyxRGzKyVBW90xrADf5202tdKMk4b8hqvpof2XULr5PA==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/text-bitmap": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/text-bitmap/-/text-bitmap-5.3.11.tgz",
- "integrity": "sha512-Bjc/G4VHaPXc9HJsvyYOm5cNTHdqmX6AgzBAlCfltuMAlnveUgUPuX8D/MJHRRnoVSDHSmCBtnJgTc0y/nIeCw==",
- "dev": true,
- "dependencies": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/loaders": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/mesh": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/text": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "node_modules/@pixi/ticker": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
- "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
- "dev": true,
- "dependencies": {
- "@pixi/settings": "5.3.11"
- }
- },
- "node_modules/@pixi/utils": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
- "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
- "dev": true,
- "dependencies": {
- "@pixi/constants": "5.3.11",
- "@pixi/settings": "5.3.11",
- "earcut": "^2.1.5",
- "eventemitter3": "^3.1.0",
- "url": "^0.11.0"
- }
- },
- "node_modules/@socket.io/component-emitter": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/@socket.io/component-emitter/-/component-emitter-3.0.0.tgz",
- "integrity": "sha512-2pTGuibAXJswAPJjaKisthqS/NOK5ypG4LYT6tEAV0S/mxW0zOIvYvGK0V8w8+SHxAm6vRMSjqSalFXeBAqs+Q==",
- "dev": true
- },
- "node_modules/@types/jquery": {
- "version": "3.5.13",
- "resolved": "https://registry.npmjs.org/@types/jquery/-/jquery-3.5.13.tgz",
- "integrity": "sha512-ZxJrup8nz/ZxcU0vantG+TPdboMhB24jad2uSap50zE7Q9rUeYlCF25kFMSmHR33qoeOgqcdHEp3roaookC0Sg==",
- "dev": true,
- "dependencies": {
- "@types/sizzle": "*"
- }
- },
- "node_modules/@types/node": {
- "version": "17.0.8",
- "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.8.tgz",
- "integrity": "sha512-YofkM6fGv4gDJq78g4j0mMuGMkZVxZDgtU0JRdx6FgiJDG+0fY0GKVolOV8WqVmEhLCXkQRjwDdKyPxJp/uucg==",
- "dev": true
- },
- "node_modules/@types/simple-peer": {
- "version": "9.11.4",
- "resolved": "https://registry.npmjs.org/@types/simple-peer/-/simple-peer-9.11.4.tgz",
- "integrity": "sha512-Elje14YvM47k+XEaoyRAeUSvZN7TOLWYL233QCckUaXjT4lRESHnYs0iOK2JoosO5DnCvWu/0Vpl9qnw4KCLWw==",
- "dev": true,
- "dependencies": {
- "@types/node": "*"
- }
- },
- "node_modules/@types/sizzle": {
- "version": "2.3.3",
- "resolved": "https://registry.npmjs.org/@types/sizzle/-/sizzle-2.3.3.tgz",
- "integrity": "sha512-JYM8x9EGF163bEyhdJBpR2QX1R5naCJHC8ucJylJ3w9/CVBaskdQ8WqBf8MmQrd1kRvp/a4TS8HJ+bxzR7ZJYQ==",
- "dev": true
- },
- "node_modules/backo2": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz",
- "integrity": "sha1-MasayLEpNjRj41s+u2n038+6eUc=",
- "dev": true
- },
- "node_modules/base64-arraybuffer": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-1.0.1.tgz",
- "integrity": "sha512-vFIUq7FdLtjZMhATwDul5RZWv2jpXQ09Pd6jcVEOvIsqCWTRFD/ONHNfyOS8dA/Ippi5dsIgpyKWKZaAKZltbA==",
- "dev": true,
- "engines": {
- "node": ">= 0.6.0"
- }
- },
- "node_modules/debug": {
- "version": "4.3.3",
- "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz",
- "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==",
- "dev": true,
- "dependencies": {
- "ms": "2.1.2"
- },
- "engines": {
- "node": ">=6.0"
- },
- "peerDependenciesMeta": {
- "supports-color": {
- "optional": true
- }
- }
- },
- "node_modules/earcut": {
- "version": "2.2.3",
- "resolved": "https://registry.npmjs.org/earcut/-/earcut-2.2.3.tgz",
- "integrity": "sha512-iRDI1QeCQIhMCZk48DRDMVgQSSBDmbzzNhnxIo+pwx3swkfjMh6vh0nWLq1NdvGHLKH6wIrAM3vQWeTj6qeoug==",
- "dev": true
- },
- "node_modules/engine.io-client": {
- "version": "6.0.3",
- "resolved": "https://registry.npmjs.org/engine.io-client/-/engine.io-client-6.0.3.tgz",
- "integrity": "sha512-IH8ZhDIwiLv0d/wXVzmjfV9Y82hbJIDhCGSVUV8o1kcpDe2I6Y3bZA3ZbJy4Ls7k7IVmcy/qn4k9RKWFhUGf5w==",
- "dev": true,
- "dependencies": {
- "@socket.io/component-emitter": "~3.0.0",
- "debug": "~4.3.1",
- "engine.io-parser": "~5.0.0",
- "has-cors": "1.1.0",
- "parseqs": "0.0.6",
- "parseuri": "0.0.6",
- "ws": "~8.2.3",
- "xmlhttprequest-ssl": "~2.0.0",
- "yeast": "0.1.2"
- }
- },
- "node_modules/engine.io-parser": {
- "version": "5.0.2",
- "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.0.2.tgz",
- "integrity": "sha512-wuiO7qO/OEkPJSFueuATIXtrxF7/6GTbAO9QLv7nnbjwZ5tYhLm9zxvLwxstRs0dcT0KUlWTjtIOs1T86jt12g==",
- "dev": true,
- "dependencies": {
- "base64-arraybuffer": "~1.0.1"
- },
- "engines": {
- "node": ">=10.0.0"
- }
- },
- "node_modules/es6-promise-polyfill": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/es6-promise-polyfill/-/es6-promise-polyfill-1.2.0.tgz",
- "integrity": "sha1-84kl8jyz4+jObNqP93T867sJDN4=",
- "dev": true
- },
- "node_modules/eventemitter3": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-3.1.2.tgz",
- "integrity": "sha512-tvtQIeLVHjDkJYnzf2dgVMxfuSGJeM/7UCG17TT4EumTfNtF+0nebF/4zWOIkCreAbtNqhGEboB6BWrwqNaw4Q==",
- "dev": true
- },
- "node_modules/handlebars": {
- "version": "4.7.7",
- "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.7.7.tgz",
- "integrity": "sha512-aAcXm5OAfE/8IXkcZvCepKU3VzW1/39Fb5ZuqMtgI/hT8X2YgoMvBY5dLhq/cpOvw7Lk1nK/UF71aLG/ZnVYRA==",
- "dev": true,
- "dependencies": {
- "minimist": "^1.2.5",
- "neo-async": "^2.6.0",
- "source-map": "^0.6.1",
- "wordwrap": "^1.0.0"
- },
- "bin": {
- "handlebars": "bin/handlebars"
- },
- "engines": {
- "node": ">=0.4.7"
- },
- "optionalDependencies": {
- "uglify-js": "^3.1.4"
- }
- },
- "node_modules/has-cors": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/has-cors/-/has-cors-1.1.0.tgz",
- "integrity": "sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk=",
- "dev": true
- },
- "node_modules/ismobilejs": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/ismobilejs/-/ismobilejs-1.1.1.tgz",
- "integrity": "sha512-VaFW53yt8QO61k2WJui0dHf4SlL8lxBofUuUmwBo0ljPk0Drz2TiuDW4jo3wDcv41qy/SxrJ+VAzJ/qYqsmzRw==",
- "dev": true
- },
- "node_modules/mini-signals": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/mini-signals/-/mini-signals-1.2.0.tgz",
- "integrity": "sha1-RbCAE8X65RokqhqTXNMXye1yHXQ=",
- "dev": true
- },
- "node_modules/minimist": {
- "version": "1.2.5",
- "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
- "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
- "dev": true
- },
- "node_modules/ms": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
- "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
- "dev": true
- },
- "node_modules/neo-async": {
- "version": "2.6.2",
- "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz",
- "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==",
- "dev": true
- },
- "node_modules/object-assign": {
- "version": "4.1.1",
- "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
- "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/parse-uri": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/parse-uri/-/parse-uri-1.0.3.tgz",
- "integrity": "sha512-upMnGxNcm+45So85HoguwZTVZI9u11i36DdxJfGF2HYWS2eh3TIx7+/tTi7qrEq15qzGkVhsKjesau+kCk48pA==",
- "dev": true,
- "engines": {
- "node": ">= 0.10"
- }
- },
- "node_modules/parseqs": {
- "version": "0.0.6",
- "resolved": "https://registry.npmjs.org/parseqs/-/parseqs-0.0.6.tgz",
- "integrity": "sha512-jeAGzMDbfSHHA091hr0r31eYfTig+29g3GKKE/PPbEQ65X0lmMwlEoqmhzu0iztID5uJpZsFlUPDP8ThPL7M8w==",
- "dev": true
- },
- "node_modules/parseuri": {
- "version": "0.0.6",
- "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.6.tgz",
- "integrity": "sha512-AUjen8sAkGgao7UyCX6Ahv0gIK2fABKmYjvP4xmy5JaKvcbTRueIqIPHLAfq30xJddqSE033IOMUSOMCcK3Sow==",
- "dev": true
- },
- "node_modules/pixi-particles": {
- "version": "4.3.1",
- "resolved": "https://registry.npmjs.org/pixi-particles/-/pixi-particles-4.3.1.tgz",
- "integrity": "sha512-XSqDFgYwm/7FRCgP5I2Fc57d98qvb1ql/x4uTjdP4uXDUGgjdO8OW/2A0HVWS1CkOht/1x6dQzsM1oCJAUlaow==",
- "dev": true,
- "peerDependencies": {
- "pixi.js": ">=4.0.0"
- }
- },
- "node_modules/pixi.js": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/pixi.js/-/pixi.js-5.3.11.tgz",
- "integrity": "sha512-/9td6IHDQqG0Po5lyQ5aKDzrnEVD1SvGourI4Nqp0mvNI0Cbm74tMHLjk1V5foqGPAS9pochENr6Y3ft/2cDiQ==",
- "dev": true,
- "dependencies": {
- "@pixi/accessibility": "5.3.11",
- "@pixi/app": "5.3.11",
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/extract": "5.3.11",
- "@pixi/filter-alpha": "5.3.11",
- "@pixi/filter-blur": "5.3.11",
- "@pixi/filter-color-matrix": "5.3.11",
- "@pixi/filter-displacement": "5.3.11",
- "@pixi/filter-fxaa": "5.3.11",
- "@pixi/filter-noise": "5.3.11",
- "@pixi/graphics": "5.3.11",
- "@pixi/interaction": "5.3.11",
- "@pixi/loaders": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/mesh": "5.3.11",
- "@pixi/mesh-extras": "5.3.11",
- "@pixi/mixin-cache-as-bitmap": "5.3.11",
- "@pixi/mixin-get-child-by-name": "5.3.11",
- "@pixi/mixin-get-global-position": "5.3.11",
- "@pixi/particles": "5.3.11",
- "@pixi/polyfill": "5.3.11",
- "@pixi/prepare": "5.3.11",
- "@pixi/runner": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/sprite-animated": "5.3.11",
- "@pixi/sprite-tiling": "5.3.11",
- "@pixi/spritesheet": "5.3.11",
- "@pixi/text": "5.3.11",
- "@pixi/text-bitmap": "5.3.11",
- "@pixi/ticker": "5.3.11",
- "@pixi/utils": "5.3.11"
- },
- "funding": {
- "type": "opencollective",
- "url": "https://opencollective.com/pixijs"
- }
- },
- "node_modules/punycode": {
- "version": "1.3.2",
- "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz",
- "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=",
- "dev": true
- },
- "node_modules/querystring": {
- "version": "0.2.0",
- "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz",
- "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=",
- "deprecated": "The querystring API is considered Legacy. new code should use the URLSearchParams API instead.",
- "dev": true,
- "engines": {
- "node": ">=0.4.x"
- }
- },
- "node_modules/resource-loader": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/resource-loader/-/resource-loader-3.0.1.tgz",
- "integrity": "sha512-fBuCRbEHdLCI1eglzQhUv9Rrdcmqkydr1r6uHE2cYHvRBrcLXeSmbE/qI/urFt8rPr/IGxir3BUwM5kUK8XoyA==",
- "dev": true,
- "dependencies": {
- "mini-signals": "^1.2.0",
- "parse-uri": "^1.0.0"
- }
- },
- "node_modules/socket.io-client": {
- "version": "4.3.2",
- "resolved": "https://registry.npmjs.org/socket.io-client/-/socket.io-client-4.3.2.tgz",
- "integrity": "sha512-2B9LqSunN60yV8F7S84CCEEcgbYNfrn7ejIInZtLZ7ppWtiX8rGZAjvdCvbnC8bqo/9RlCNOUsORLyskxSFP1g==",
- "dev": true,
- "dependencies": {
- "@socket.io/component-emitter": "~3.0.0",
- "backo2": "~1.0.2",
- "debug": "~4.3.2",
- "engine.io-client": "~6.0.1",
- "parseuri": "0.0.6",
- "socket.io-parser": "~4.1.1"
- },
- "engines": {
- "node": ">=10.0.0"
- }
- },
- "node_modules/socket.io-parser": {
- "version": "4.1.1",
- "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.1.1.tgz",
- "integrity": "sha512-USQVLSkDWE5nbcY760ExdKaJxCE65kcsG/8k5FDGZVVxpD1pA7hABYXYkCUvxUuYYh/+uQw0N/fvBzfT8o07KA==",
- "dev": true,
- "dependencies": {
- "@socket.io/component-emitter": "~3.0.0",
- "debug": "~4.3.1"
- },
- "engines": {
- "node": ">=10.0.0"
- }
- },
- "node_modules/source-map": {
- "version": "0.6.1",
- "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
- "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
- "dev": true,
- "engines": {
- "node": ">=0.10.0"
- }
- },
- "node_modules/tinymce": {
- "version": "5.10.1",
- "resolved": "https://registry.npmjs.org/tinymce/-/tinymce-5.10.1.tgz",
- "integrity": "sha512-aIsFTYiuESpoYkCgkoojpVtPwrSvYBxp4mMEGsj20CnUruLCWosywkbYHDII+j7KlQZZn3p+xK89f5gT3QyuGw==",
- "dev": true
- },
- "node_modules/uglify-js": {
- "version": "3.14.5",
- "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.14.5.tgz",
- "integrity": "sha512-qZukoSxOG0urUTvjc2ERMTcAy+BiFh3weWAkeurLwjrCba73poHmG3E36XEjd/JGukMzwTL7uCxZiAexj8ppvQ==",
- "dev": true,
- "optional": true,
- "bin": {
- "uglifyjs": "bin/uglifyjs"
- },
- "engines": {
- "node": ">=0.8.0"
- }
- },
- "node_modules/url": {
- "version": "0.11.0",
- "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz",
- "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=",
- "dev": true,
- "dependencies": {
- "punycode": "1.3.2",
- "querystring": "0.2.0"
- }
- },
- "node_modules/wordwrap": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz",
- "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=",
- "dev": true
- },
- "node_modules/ws": {
- "version": "8.2.3",
- "resolved": "https://registry.npmjs.org/ws/-/ws-8.2.3.tgz",
- "integrity": "sha512-wBuoj1BDpC6ZQ1B7DWQBYVLphPWkm8i9Y0/3YdHjHKHiohOJ1ws+3OccDWtH+PoC9DZD5WOTrJvNbWvjS6JWaA==",
- "dev": true,
- "engines": {
- "node": ">=10.0.0"
- },
- "peerDependencies": {
- "bufferutil": "^4.0.1",
- "utf-8-validate": "^5.0.2"
- },
- "peerDependenciesMeta": {
- "bufferutil": {
- "optional": true
- },
- "utf-8-validate": {
- "optional": true
- }
- }
- },
- "node_modules/xmlhttprequest-ssl": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-2.0.0.tgz",
- "integrity": "sha512-QKxVRxiRACQcVuQEYFsI1hhkrMlrXHPegbbd1yn9UHOmRxY+si12nQYzri3vbzt8VdTTRviqcKxcyllFas5z2A==",
- "dev": true,
- "engines": {
- "node": ">=0.4.0"
- }
- },
- "node_modules/yeast": {
- "version": "0.1.2",
- "resolved": "https://registry.npmjs.org/yeast/-/yeast-0.1.2.tgz",
- "integrity": "sha1-AI4G2AlDIMNy28L47XagymyKxBk=",
- "dev": true
+ "name": "essential-svelte-esm",
+ "version": "0.0.5",
+ "lockfileVersion": 2,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "essential-svelte-esm",
+ "version": "0.0.5",
+ "license": "MIT",
+ "dependencies": {
+ "@typhonjs-fvtt/runtime": "^0.0.19",
+ "@typhonjs-fvtt/svelte-standard": "^0.0.9",
+ "svelte": "^3.49.0"
+ },
+ "devDependencies": {
+ "@babel/core": "^7",
+ "@babel/preset-env": "^7",
+ "@league-of-foundry-developers/foundry-vtt-types": "^9.238.1",
+ "@rollup/plugin-babel": "^5",
+ "@typhonjs-config/eslint-config": "^0.3.0",
+ "@typhonjs-fvtt/eslint-config-foundry.js": "^0.8.0",
+ "eslint": "^8",
+ "rollup": "^2",
+ "svelte-dnd-action": "^0.9.18",
+ "svelte-preprocess": "^4.10.0",
+ "vite": "^3"
+ }
+ },
+ "node_modules/@ampproject/remapping": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz",
+ "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==",
+ "devOptional": true,
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.1.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/code-frame": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz",
+ "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==",
+ "dependencies": {
+ "@babel/highlight": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/compat-data": {
+ "version": "7.18.8",
+ "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.18.8.tgz",
+ "integrity": "sha512-HSmX4WZPPK3FUxYp7g2T6EyO8j96HlZJlxmKPSh6KAcqwyDrfx7hKjXpAW/0FhFfTJsR0Yt4lAjLI2coMptIHQ==",
+ "devOptional": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/core": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.18.9.tgz",
+ "integrity": "sha512-1LIb1eL8APMy91/IMW+31ckrfBM4yCoLaVzoDhZUKSM4cu1L1nIidyxkCgzPAgrC5WEz36IPEr/eSeSF9pIn+g==",
+ "devOptional": true,
+ "dependencies": {
+ "@ampproject/remapping": "^2.1.0",
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.18.9",
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-module-transforms": "^7.18.9",
+ "@babel/helpers": "^7.18.9",
+ "@babel/parser": "^7.18.9",
+ "@babel/template": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9",
+ "convert-source-map": "^1.7.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.1",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/babel"
+ }
+ },
+ "node_modules/@babel/generator": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.18.9.tgz",
+ "integrity": "sha512-wt5Naw6lJrL1/SGkipMiFxJjtyczUWTP38deiP1PO60HsBjDeKk08CGC3S8iVuvf0FmTdgKwU1KIXzSKL1G0Ug==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/types": "^7.18.9",
+ "@jridgewell/gen-mapping": "^0.3.2",
+ "jsesc": "^2.5.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/generator/node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz",
+ "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==",
+ "devOptional": true,
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/helper-annotate-as-pure": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz",
+ "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-builder-binary-assignment-operator-visitor": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.9.tgz",
+ "integrity": "sha512-yFQ0YCHoIqarl8BCRwBL8ulYUaZpz3bNsA7oFepAzee+8/+ImtADXNOmO5vJvsPff3qi+hvpkY/NYBTrBQgdNw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-explode-assignable-expression": "^7.18.6",
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.18.9.tgz",
+ "integrity": "sha512-tzLCyVmqUiFlcFoAPLA/gL9TeYrF61VLNtb+hvkuVaB5SUjW7jcfrglBIX1vUIoT7CLP3bBlIMeyEsIl2eFQNg==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.18.8",
+ "@babel/helper-validator-option": "^7.18.6",
+ "browserslist": "^4.20.2",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-create-class-features-plugin": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.18.9.tgz",
+ "integrity": "sha512-WvypNAYaVh23QcjpMR24CwZY2Nz6hqdOcFdPbNpV56hL5H6KiFheO7Xm1aPdlLQ7d5emYZX7VZwPp9x3z+2opw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-member-expression-to-functions": "^7.18.9",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/helper-replace-supers": "^7.18.9",
+ "@babel/helper-split-export-declaration": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-create-regexp-features-plugin": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.18.6.tgz",
+ "integrity": "sha512-7LcpH1wnQLGrI+4v+nPp+zUvIkF9x0ddv1Hkdue10tg3gmRnLy97DXh4STiOf1qeIInyD69Qv5kKSZzKD8B/7A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "regexpu-core": "^5.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-define-polyfill-provider": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.2.tgz",
+ "integrity": "sha512-r9QJJ+uDWrd+94BSPcP6/de67ygLtvVy6cK4luE6MOuDsZIdoaPBnfSpbO/+LTifjPckbKXRuI9BB/Z2/y3iTg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-compilation-targets": "^7.17.7",
+ "@babel/helper-plugin-utils": "^7.16.7",
+ "debug": "^4.1.1",
+ "lodash.debounce": "^4.0.8",
+ "resolve": "^1.14.2",
+ "semver": "^6.1.2"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.4.0-0"
+ }
+ },
+ "node_modules/@babel/helper-environment-visitor": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz",
+ "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==",
+ "devOptional": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-explode-assignable-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz",
+ "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-function-name": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.18.9.tgz",
+ "integrity": "sha512-fJgWlZt7nxGksJS9a0XdSaI4XvpExnNIgRP+rVefWh5U7BL8pPuir6SJUmFKRfjWQ51OtWSzwOxhaH/EBWWc0A==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/template": "^7.18.6",
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-hoist-variables": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz",
+ "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-member-expression-to-functions": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.18.9.tgz",
+ "integrity": "sha512-RxifAh2ZoVU67PyKIO4AMi1wTenGfMR/O/ae0CCRqwgBAt5v7xjdtRw7UoSbsreKrQn5t7r89eruK/9JjYHuDg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-imports": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz",
+ "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-transforms": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.18.9.tgz",
+ "integrity": "sha512-KYNqY0ICwfv19b31XzvmI/mfcylOzbLtowkw+mfvGPAQ3kfCnMLYbED3YecL5tPd8nAYFQFAd6JHp2LxZk/J1g==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-simple-access": "^7.18.6",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "@babel/template": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-optimise-call-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz",
+ "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-plugin-utils": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.18.9.tgz",
+ "integrity": "sha512-aBXPT3bmtLryXaoJLyYPXPlSD4p1ld9aYeR+sJNOZjJJGiOpb+fKfh3NkcCu7J54nUJwCERPBExCCpyCOHnu/w==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-remap-async-to-generator": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz",
+ "integrity": "sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-wrap-function": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-replace-supers": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.18.9.tgz",
+ "integrity": "sha512-dNsWibVI4lNT6HiuOIBr1oyxo40HvIVmbwPUm3XZ7wMh4k2WxrxTqZwSqw/eEmXDS9np0ey5M2bz9tBmO9c+YQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-member-expression-to-functions": "^7.18.9",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-simple-access": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz",
+ "integrity": "sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-skip-transparent-expression-wrappers": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.18.9.tgz",
+ "integrity": "sha512-imytd2gHi3cJPsybLRbmFrF7u5BIEuI2cNheyKi3/iOBC63kNn3q8Crn2xVuESli0aM4KYsyEqKyS7lFL8YVtw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-split-export-declaration": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz",
+ "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz",
+ "integrity": "sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g==",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-option": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz",
+ "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==",
+ "devOptional": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-wrap-function": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.18.9.tgz",
+ "integrity": "sha512-cG2ru3TRAL6a60tfQflpEfs4ldiPwF6YW3zfJiRgmoFVIaC1vGnBBgatfec+ZUziPHkHSaXAuEck3Cdkf3eRpQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/template": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helpers": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.18.9.tgz",
+ "integrity": "sha512-Jf5a+rbrLoR4eNdUmnFu8cN5eNJT6qdTdOg5IHIzq87WwyRw9PwguLFOWYgktN/60IP4fgDUawJvs7PjQIzELQ==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/template": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/highlight": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz",
+ "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==",
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "chalk": "^2.0.0",
+ "js-tokens": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.18.9.tgz",
+ "integrity": "sha512-9uJveS9eY9DJ0t64YbIBZICtJy8a5QrDEVdiLCG97fVLpDTpGX7t8mMSb6OWw6Lrnjqj4O8zwjELX3dhoMgiBg==",
+ "devOptional": true,
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz",
+ "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.18.9.tgz",
+ "integrity": "sha512-AHrP9jadvH7qlOj6PINbgSuphjQUAK7AOT7DPjBo9EHoLhQTnnK5u45e1Hd4DbSQEO9nqPWtQ89r+XEOWFScKg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.18.9",
+ "@babel/plugin-proposal-optional-chaining": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.13.0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-async-generator-functions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.18.6.tgz",
+ "integrity": "sha512-WAz4R9bvozx4qwf74M+sfqPMKfSqwM0phxPTR6iJIi8robgzXwkEgmeJG1gEKhm6sDqT/U9aV3lfcqybIpev8w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-remap-async-to-generator": "^7.18.6",
+ "@babel/plugin-syntax-async-generators": "^7.8.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-class-properties": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz",
+ "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-class-static-block": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.18.6.tgz",
+ "integrity": "sha512-+I3oIiNxrCpup3Gi8n5IGMwj0gOCAjcJUSQEcotNnCCPMEnixawOQ+KeJPlgfjzx+FKQ1QSyZOWe7wmoJp7vhw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.12.0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-dynamic-import": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz",
+ "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-export-namespace-from": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz",
+ "integrity": "sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-json-strings": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz",
+ "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-json-strings": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-logical-assignment-operators": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.18.9.tgz",
+ "integrity": "sha512-128YbMpjCrP35IOExw2Fq+x55LMP42DzhOhX2aNNIdI9avSWl2PI0yuBWarr3RYpZBSPtabfadkH2yeRiMD61Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-nullish-coalescing-operator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz",
+ "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-numeric-separator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz",
+ "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-object-rest-spread": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.18.9.tgz",
+ "integrity": "sha512-kDDHQ5rflIeY5xl69CEqGEZ0KY369ehsCIEbTGb4siHG5BE9sga/T0r0OUwyZNLMmZE79E1kbsqAjwFCW4ds6Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.18.8",
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-transform-parameters": "^7.18.8"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-optional-catch-binding": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz",
+ "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-optional-chaining": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.18.9.tgz",
+ "integrity": "sha512-v5nwt4IqBXihxGsW2QmCWMDS3B3bzGIk/EQVZz2ei7f3NJl8NzAJVvUmpDW5q1CRNY+Beb/k58UAH1Km1N411w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.18.9",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-private-methods": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz",
+ "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-private-property-in-object": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.18.6.tgz",
+ "integrity": "sha512-9Rysx7FOctvT5ouj5JODjAFAkgGoudQuLPamZb0v1TGLpapdNaftzifU8NTWQm0IRjqoYypdrSmyWgkocDQ8Dw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-unicode-property-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz",
+ "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-async-generators": {
+ "version": "7.8.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz",
+ "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-class-properties": {
+ "version": "7.12.13",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz",
+ "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.12.13"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-class-static-block": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz",
+ "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-dynamic-import": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz",
+ "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-export-namespace-from": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz",
+ "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.3"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-import-assertions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.18.6.tgz",
+ "integrity": "sha512-/DU3RXad9+bZwrgWJQKbr39gYbJpLJHezqEzRzi/BHRlJ9zsQb4CK2CA/5apllXNomwA1qHwzvHl+AdEmC5krQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-json-strings": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz",
+ "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-logical-assignment-operators": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz",
+ "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz",
+ "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-numeric-separator": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz",
+ "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-object-rest-spread": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz",
+ "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-optional-catch-binding": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz",
+ "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-optional-chaining": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz",
+ "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-private-property-in-object": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz",
+ "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-top-level-await": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz",
+ "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-arrow-functions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.18.6.tgz",
+ "integrity": "sha512-9S9X9RUefzrsHZmKMbDXxweEH+YlE8JJEuat9FdvW9Qh1cw7W64jELCtWNkPBPX5En45uy28KGvA/AySqUh8CQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-async-to-generator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.18.6.tgz",
+ "integrity": "sha512-ARE5wZLKnTgPW7/1ftQmSi1CmkqqHo2DNmtztFhvgtOWSDfq0Cq9/9L+KnZNYSNrydBekhW3rwShduf59RoXag==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-remap-async-to-generator": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-block-scoped-functions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz",
+ "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-block-scoping": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.18.9.tgz",
+ "integrity": "sha512-5sDIJRV1KtQVEbt/EIBwGy4T01uYIo4KRB3VUqzkhrAIOGx7AoctL9+Ux88btY0zXdDyPJ9mW+bg+v+XEkGmtw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-classes": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.18.9.tgz",
+ "integrity": "sha512-EkRQxsxoytpTlKJmSPYrsOMjCILacAjtSVkd4gChEe2kXjFCun3yohhW5I7plXJhCemM0gKsaGMcO8tinvCA5g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-replace-supers": "^7.18.9",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-computed-properties": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.18.9.tgz",
+ "integrity": "sha512-+i0ZU1bCDymKakLxn5srGHrsAPRELC2WIbzwjLhHW9SIE1cPYkLCL0NlnXMZaM1vhfgA2+M7hySk42VBvrkBRw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-destructuring": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.18.9.tgz",
+ "integrity": "sha512-p5VCYNddPLkZTq4XymQIaIfZNJwT9YsjkPOhkVEqt6QIpQFZVM9IltqqYpOEkJoN1DPznmxUDyZ5CTZs/ZCuHA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-dotall-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz",
+ "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-duplicate-keys": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz",
+ "integrity": "sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-exponentiation-operator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz",
+ "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-for-of": {
+ "version": "7.18.8",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz",
+ "integrity": "sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-function-name": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz",
+ "integrity": "sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-literals": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz",
+ "integrity": "sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-member-expression-literals": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz",
+ "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-amd": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.18.6.tgz",
+ "integrity": "sha512-Pra5aXsmTsOnjM3IajS8rTaLCy++nGM4v3YR4esk5PCsyg9z8NA5oQLwxzMUtDBd8F+UmVza3VxoAaWCbzH1rg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-transforms": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "babel-plugin-dynamic-import-node": "^2.3.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-commonjs": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.18.6.tgz",
+ "integrity": "sha512-Qfv2ZOWikpvmedXQJDSbxNqy7Xr/j2Y8/KfijM0iJyKkBTmWuvCA1yeH1yDM7NJhBW/2aXxeucLj6i80/LAJ/Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-transforms": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-simple-access": "^7.18.6",
+ "babel-plugin-dynamic-import-node": "^2.3.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-systemjs": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.18.9.tgz",
+ "integrity": "sha512-zY/VSIbbqtoRoJKo2cDTewL364jSlZGvn0LKOf9ntbfxOvjfmyrdtEEOAdswOswhZEb8UH3jDkCKHd1sPgsS0A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-hoist-variables": "^7.18.6",
+ "@babel/helper-module-transforms": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "babel-plugin-dynamic-import-node": "^2.3.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-umd": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz",
+ "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-transforms": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-named-capturing-groups-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.18.6.tgz",
+ "integrity": "sha512-UmEOGF8XgaIqD74bC8g7iV3RYj8lMf0Bw7NJzvnS9qQhM4mg+1WHKotUIdjxgD2RGrgFLZZPCFPFj3P/kVDYhg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-new-target": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz",
+ "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-object-super": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz",
+ "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-replace-supers": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-parameters": {
+ "version": "7.18.8",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.18.8.tgz",
+ "integrity": "sha512-ivfbE3X2Ss+Fj8nnXvKJS6sjRG4gzwPMsP+taZC+ZzEGjAYlvENixmt1sZ5Ca6tWls+BlKSGKPJ6OOXvXCbkFg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-property-literals": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz",
+ "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-regenerator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.18.6.tgz",
+ "integrity": "sha512-poqRI2+qiSdeldcz4wTSTXBRryoq3Gc70ye7m7UD5Ww0nE29IXqMl6r7Nd15WBgRd74vloEMlShtH6CKxVzfmQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "regenerator-transform": "^0.15.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-reserved-words": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz",
+ "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-shorthand-properties": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz",
+ "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-spread": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.18.9.tgz",
+ "integrity": "sha512-39Q814wyoOPtIB/qGopNIL9xDChOE1pNU0ZY5dO0owhiVt/5kFm4li+/bBtwc7QotG0u5EPzqhZdjMtmqBqyQA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-sticky-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz",
+ "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-template-literals": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz",
+ "integrity": "sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-typeof-symbol": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz",
+ "integrity": "sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-unicode-escapes": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.6.tgz",
+ "integrity": "sha512-XNRwQUXYMP7VLuy54cr/KS/WeL3AZeORhrmeZ7iewgu+X2eBqmpaLI/hzqr9ZxCeUoq0ASK4GUzSM0BDhZkLFw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-unicode-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz",
+ "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/preset-env": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.18.9.tgz",
+ "integrity": "sha512-75pt/q95cMIHWssYtyfjVlvI+QEZQThQbKvR9xH+F/Agtw/s4Wfc2V9Bwd/P39VtixB7oWxGdH4GteTTwYJWMg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.18.8",
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-validator-option": "^7.18.6",
+ "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6",
+ "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.9",
+ "@babel/plugin-proposal-async-generator-functions": "^7.18.6",
+ "@babel/plugin-proposal-class-properties": "^7.18.6",
+ "@babel/plugin-proposal-class-static-block": "^7.18.6",
+ "@babel/plugin-proposal-dynamic-import": "^7.18.6",
+ "@babel/plugin-proposal-export-namespace-from": "^7.18.9",
+ "@babel/plugin-proposal-json-strings": "^7.18.6",
+ "@babel/plugin-proposal-logical-assignment-operators": "^7.18.9",
+ "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
+ "@babel/plugin-proposal-numeric-separator": "^7.18.6",
+ "@babel/plugin-proposal-object-rest-spread": "^7.18.9",
+ "@babel/plugin-proposal-optional-catch-binding": "^7.18.6",
+ "@babel/plugin-proposal-optional-chaining": "^7.18.9",
+ "@babel/plugin-proposal-private-methods": "^7.18.6",
+ "@babel/plugin-proposal-private-property-in-object": "^7.18.6",
+ "@babel/plugin-proposal-unicode-property-regex": "^7.18.6",
+ "@babel/plugin-syntax-async-generators": "^7.8.4",
+ "@babel/plugin-syntax-class-properties": "^7.12.13",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3",
+ "@babel/plugin-syntax-import-assertions": "^7.18.6",
+ "@babel/plugin-syntax-json-strings": "^7.8.3",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5",
+ "@babel/plugin-syntax-top-level-await": "^7.14.5",
+ "@babel/plugin-transform-arrow-functions": "^7.18.6",
+ "@babel/plugin-transform-async-to-generator": "^7.18.6",
+ "@babel/plugin-transform-block-scoped-functions": "^7.18.6",
+ "@babel/plugin-transform-block-scoping": "^7.18.9",
+ "@babel/plugin-transform-classes": "^7.18.9",
+ "@babel/plugin-transform-computed-properties": "^7.18.9",
+ "@babel/plugin-transform-destructuring": "^7.18.9",
+ "@babel/plugin-transform-dotall-regex": "^7.18.6",
+ "@babel/plugin-transform-duplicate-keys": "^7.18.9",
+ "@babel/plugin-transform-exponentiation-operator": "^7.18.6",
+ "@babel/plugin-transform-for-of": "^7.18.8",
+ "@babel/plugin-transform-function-name": "^7.18.9",
+ "@babel/plugin-transform-literals": "^7.18.9",
+ "@babel/plugin-transform-member-expression-literals": "^7.18.6",
+ "@babel/plugin-transform-modules-amd": "^7.18.6",
+ "@babel/plugin-transform-modules-commonjs": "^7.18.6",
+ "@babel/plugin-transform-modules-systemjs": "^7.18.9",
+ "@babel/plugin-transform-modules-umd": "^7.18.6",
+ "@babel/plugin-transform-named-capturing-groups-regex": "^7.18.6",
+ "@babel/plugin-transform-new-target": "^7.18.6",
+ "@babel/plugin-transform-object-super": "^7.18.6",
+ "@babel/plugin-transform-parameters": "^7.18.8",
+ "@babel/plugin-transform-property-literals": "^7.18.6",
+ "@babel/plugin-transform-regenerator": "^7.18.6",
+ "@babel/plugin-transform-reserved-words": "^7.18.6",
+ "@babel/plugin-transform-shorthand-properties": "^7.18.6",
+ "@babel/plugin-transform-spread": "^7.18.9",
+ "@babel/plugin-transform-sticky-regex": "^7.18.6",
+ "@babel/plugin-transform-template-literals": "^7.18.9",
+ "@babel/plugin-transform-typeof-symbol": "^7.18.9",
+ "@babel/plugin-transform-unicode-escapes": "^7.18.6",
+ "@babel/plugin-transform-unicode-regex": "^7.18.6",
+ "@babel/preset-modules": "^0.1.5",
+ "@babel/types": "^7.18.9",
+ "babel-plugin-polyfill-corejs2": "^0.3.1",
+ "babel-plugin-polyfill-corejs3": "^0.5.2",
+ "babel-plugin-polyfill-regenerator": "^0.3.1",
+ "core-js-compat": "^3.22.1",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/preset-modules": {
+ "version": "0.1.5",
+ "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz",
+ "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.0.0",
+ "@babel/plugin-proposal-unicode-property-regex": "^7.4.4",
+ "@babel/plugin-transform-dotall-regex": "^7.4.4",
+ "@babel/types": "^7.4.4",
+ "esutils": "^2.0.2"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/runtime": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.18.9.tgz",
+ "integrity": "sha512-lkqXDcvlFT5rvEjiu6+QYO+1GXrEHRo2LOtS7E4GtX5ESIZOgepqsZBVIj6Pv+a6zqsya9VCgiK1KAK4BvJDAw==",
+ "dev": true,
+ "dependencies": {
+ "regenerator-runtime": "^0.13.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/template": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.18.6.tgz",
+ "integrity": "sha512-JoDWzPe+wgBsTTgdnIma3iHNFC7YVJoPssVBDjiHfNlyt4YcunDtcDOUmfVDfCK5MfdsaIoX9PkijPhjH3nYUw==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/parser": "^7.18.6",
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/traverse": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.18.9.tgz",
+ "integrity": "sha512-LcPAnujXGwBgv3/WHv01pHtb2tihcyW1XuL9wd7jqh1Z8AQkTd+QVjMrMijrln0T7ED3UXLIy36P9Ao7W75rYg==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.18.9",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-hoist-variables": "^7.18.6",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/parser": "^7.18.9",
+ "@babel/types": "^7.18.9",
+ "debug": "^4.1.0",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.18.9.tgz",
+ "integrity": "sha512-WwMLAg2MvJmt/rKEVQBBhIVffMmnilX4oe0sRe7iPOHIGsqpruFHHdrfj4O1CMMtgMtCU4oPafZjDPCRgO57Wg==",
+ "devOptional": true,
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "to-fast-properties": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@csstools/postcss-cascade-layers": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-cascade-layers/-/postcss-cascade-layers-1.0.5.tgz",
+ "integrity": "sha512-Id/9wBT7FkgFzdEpiEWrsVd4ltDxN0rI0QS0SChbeQiSuux3z21SJCRLu6h2cvCEUmaRi+VD0mHFj+GJD4GFnw==",
+ "dependencies": {
+ "@csstools/selector-specificity": "^2.0.2",
+ "postcss-selector-parser": "^6.0.10"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-color-function": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-color-function/-/postcss-color-function-1.1.1.tgz",
+ "integrity": "sha512-Bc0f62WmHdtRDjf5f3e2STwRAl89N2CLb+9iAwzrv4L2hncrbDwnQD9PCq0gtAt7pOI2leIV08HIBUd4jxD8cw==",
+ "dependencies": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-font-format-keywords": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-font-format-keywords/-/postcss-font-format-keywords-1.0.1.tgz",
+ "integrity": "sha512-ZgrlzuUAjXIOc2JueK0X5sZDjCtgimVp/O5CEqTcs5ShWBa6smhWYbS0x5cVc/+rycTDbjjzoP0KTDnUneZGOg==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-hwb-function": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-hwb-function/-/postcss-hwb-function-1.0.2.tgz",
+ "integrity": "sha512-YHdEru4o3Rsbjmu6vHy4UKOXZD+Rn2zmkAmLRfPet6+Jz4Ojw8cbWxe1n42VaXQhD3CQUXXTooIy8OkVbUcL+w==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-ic-unit": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-ic-unit/-/postcss-ic-unit-1.0.1.tgz",
+ "integrity": "sha512-Ot1rcwRAaRHNKC9tAqoqNZhjdYBzKk1POgWfhN4uCOE47ebGcLRqXjKkApVDpjifL6u2/55ekkpnFcp+s/OZUw==",
+ "dependencies": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-is-pseudo-class": {
+ "version": "2.0.7",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-is-pseudo-class/-/postcss-is-pseudo-class-2.0.7.tgz",
+ "integrity": "sha512-7JPeVVZHd+jxYdULl87lvjgvWldYu+Bc62s9vD/ED6/QTGjy0jy0US/f6BG53sVMTBJ1lzKZFpYmofBN9eaRiA==",
+ "dependencies": {
+ "@csstools/selector-specificity": "^2.0.0",
+ "postcss-selector-parser": "^6.0.10"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-normalize-display-values": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-normalize-display-values/-/postcss-normalize-display-values-1.0.1.tgz",
+ "integrity": "sha512-jcOanIbv55OFKQ3sYeFD/T0Ti7AMXc9nM1hZWu8m/2722gOTxFg7xYu4RDLJLeZmPUVQlGzo4jhzvTUq3x4ZUw==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-oklab-function": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-oklab-function/-/postcss-oklab-function-1.1.1.tgz",
+ "integrity": "sha512-nJpJgsdA3dA9y5pgyb/UfEzE7W5Ka7u0CX0/HIMVBNWzWemdcTH3XwANECU6anWv/ao4vVNLTMxhiPNZsTK6iA==",
+ "dependencies": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-progressive-custom-properties": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-progressive-custom-properties/-/postcss-progressive-custom-properties-1.3.0.tgz",
+ "integrity": "sha512-ASA9W1aIy5ygskZYuWams4BzafD12ULvSypmaLJT2jvQ8G0M3I8PRQhC0h7mG0Z3LI05+agZjqSR9+K9yaQQjA==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "peerDependencies": {
+ "postcss": "^8.3"
+ }
+ },
+ "node_modules/@csstools/postcss-stepped-value-functions": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-stepped-value-functions/-/postcss-stepped-value-functions-1.0.1.tgz",
+ "integrity": "sha512-dz0LNoo3ijpTOQqEJLY8nyaapl6umbmDcgj4AD0lgVQ572b2eqA1iGZYTTWhrcrHztWDDRAX2DGYyw2VBjvCvQ==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-trigonometric-functions": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-trigonometric-functions/-/postcss-trigonometric-functions-1.0.2.tgz",
+ "integrity": "sha512-woKaLO///4bb+zZC2s80l+7cm07M7268MsyG3M0ActXXEFi6SuhvriQYcb58iiKGbjwwIU7n45iRLEHypB47Og==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/postcss-unset-value": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-unset-value/-/postcss-unset-value-1.0.2.tgz",
+ "integrity": "sha512-c8J4roPBILnelAsdLr4XOAR/GsTm0GJi4XpcfvoWk3U6KiTCqiFYc63KhRMQQX35jYMp4Ao8Ij9+IZRgMfJp1g==",
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/@csstools/selector-specificity": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/@csstools/selector-specificity/-/selector-specificity-2.0.2.tgz",
+ "integrity": "sha512-IkpVW/ehM1hWKln4fCA3NzJU8KwD+kIOvPZA4cqxoJHtE21CCzjyp+Kxbu0i5I4tBNOlXPL9mjwnWlL0VEG4Fg==",
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2",
+ "postcss-selector-parser": "^6.0.10"
+ }
+ },
+ "node_modules/@es-joy/jsdoccomment": {
+ "version": "0.20.1",
+ "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.20.1.tgz",
+ "integrity": "sha512-oeJK41dcdqkvdZy/HctKklJNkt/jh+av3PZARrZEl+fs/8HaHeeYoAvEwOV0u5I6bArTF17JEsTZMY359e/nfQ==",
+ "dev": true,
+ "dependencies": {
+ "comment-parser": "1.3.0",
+ "esquery": "^1.4.0",
+ "jsdoc-type-pratt-parser": "~2.2.3"
+ },
+ "engines": {
+ "node": "^12 || ^14 || ^16 || ^17"
+ }
+ },
+ "node_modules/@eslint/eslintrc": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.3.0.tgz",
+ "integrity": "sha512-UWW0TMTmk2d7hLcWD1/e2g5HDM/HQ3csaLSqXCfqwh4uNDuNqlaKWXmEsL4Cs41Z0KnILNvwbHAah3C2yt06kw==",
+ "dev": true,
+ "dependencies": {
+ "ajv": "^6.12.4",
+ "debug": "^4.3.2",
+ "espree": "^9.3.2",
+ "globals": "^13.15.0",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.2.1",
+ "js-yaml": "^4.1.0",
+ "minimatch": "^3.1.2",
+ "strip-json-comments": "^3.1.1"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
+ "node_modules/@eslint/eslintrc/node_modules/globals": {
+ "version": "13.17.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-13.17.0.tgz",
+ "integrity": "sha512-1C+6nQRb1GwGMKm2dH/E7enFAMxGTmGI7/dEdhy/DNelv85w9B72t3uc5frtMNXIbzrarJJ/lTCjcaZwbLJmyw==",
+ "dev": true,
+ "dependencies": {
+ "type-fest": "^0.20.2"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/@humanwhocodes/config-array": {
+ "version": "0.9.5",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.5.tgz",
+ "integrity": "sha512-ObyMyWxZiCu/yTisA7uzx81s40xR2fD5Cg/2Kq7G02ajkNubJf6BopgDTmDyc3U7sXpNKM8cYOw7s7Tyr+DnCw==",
+ "dev": true,
+ "dependencies": {
+ "@humanwhocodes/object-schema": "^1.2.1",
+ "debug": "^4.1.1",
+ "minimatch": "^3.0.4"
+ },
+ "engines": {
+ "node": ">=10.10.0"
+ }
+ },
+ "node_modules/@humanwhocodes/object-schema": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz",
+ "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==",
+ "dev": true
+ },
+ "node_modules/@jridgewell/gen-mapping": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz",
+ "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==",
+ "devOptional": true,
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.0",
+ "@jridgewell/sourcemap-codec": "^1.4.10"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/resolve-uri": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz",
+ "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==",
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/set-array": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz",
+ "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==",
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/source-map": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.2.tgz",
+ "integrity": "sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==",
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.3.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ },
+ "node_modules/@jridgewell/source-map/node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz",
+ "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==",
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/sourcemap-codec": {
+ "version": "1.4.14",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz",
+ "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw=="
+ },
+ "node_modules/@jridgewell/trace-mapping": {
+ "version": "0.3.14",
+ "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz",
+ "integrity": "sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ==",
+ "dependencies": {
+ "@jridgewell/resolve-uri": "^3.0.3",
+ "@jridgewell/sourcemap-codec": "^1.4.10"
+ }
+ },
+ "node_modules/@league-of-foundry-developers/foundry-vtt-types": {
+ "version": "9.269.0",
+ "resolved": "https://registry.npmjs.org/@league-of-foundry-developers/foundry-vtt-types/-/foundry-vtt-types-9.269.0.tgz",
+ "integrity": "sha512-M/rz86decPLXet9e6+bi0dm8WSGrT/5MM1QXUMEC7Z8vfKB9Y5D61B1J5laaqb3DdjVDS1kZtQEW3/sPg3EALw==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/graphics-smooth": "0.0.22",
+ "@types/jquery": "~3.5.9",
+ "@types/simple-peer": "~9.11.1",
+ "handlebars": "4.7.7",
+ "pixi-particles": "4.3.1",
+ "pixi.js": "5.3.11",
+ "socket.io-client": "4.3.2",
+ "tinymce": "5.10.1"
+ }
+ },
+ "node_modules/@pixi/accessibility": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/accessibility/-/accessibility-5.3.11.tgz",
+ "integrity": "sha512-/oSizd8/g6KUCeAlknMLJ9CRxBt+vWs6e2DrOctMoRupEHcmhICCjIyAp5GF6RZy9T9gNHDOU5p7vo7qEyVxgQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/accessibility/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/accessibility/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/accessibility/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/accessibility/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/accessibility/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/accessibility/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/accessibility/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/accessibility/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/app": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/app/-/app-5.3.11.tgz",
+ "integrity": "sha512-ZWrOjGvVl+lK5OJQT3OqSnSRtU2XgQSe/ULg2uGsSWUqMkJews33JIGOjvk4tIsjm4ekSKiPZRMdYFHzPfgEJg==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/app/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/app/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/app/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/app/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/app/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/app/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/app/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/app/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/constants": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-6.5.0.tgz",
+ "integrity": "sha512-rr2szhjkM/TEHFcq+I3sg3uvRDRCC+ggO0lOvbHt3B84QdSGltndI4GSefSRpmvb5KbrZP7R0NO6UY7AZ0NqQg==",
+ "dev": true,
+ "peer": true
+ },
+ "node_modules/@pixi/core": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-6.5.0.tgz",
+ "integrity": "sha512-73dceDRGvdMs/i9t9sNAVKK2lkPZ/olaLp+Xa2vo+BsaBdr5e+11vnAzT7XUtZyGjWOm3o1KXABZ6jr9AuKdkg==",
+ "dev": true,
+ "peer": true,
+ "dependencies": {
+ "@types/offscreencanvas": "^2019.6.4"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ },
+ "peerDependencies": {
+ "@pixi/constants": "6.5.0",
+ "@pixi/math": "6.5.0",
+ "@pixi/runner": "6.5.0",
+ "@pixi/settings": "6.5.0",
+ "@pixi/ticker": "6.5.0",
+ "@pixi/utils": "6.5.0"
+ }
+ },
+ "node_modules/@pixi/display": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-6.5.0.tgz",
+ "integrity": "sha512-ksjGtleam+p319teRT1FL7MSwJ1w5L5xWyq1w8QIREKNxHuI8lOfYgxPABo6HUI8FZ4AysifnfAdnxDqbPtauw==",
+ "dev": true,
+ "peer": true,
+ "peerDependencies": {
+ "@pixi/math": "6.5.0",
+ "@pixi/settings": "6.5.0",
+ "@pixi/utils": "6.5.0"
+ }
+ },
+ "node_modules/@pixi/extract": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/extract/-/extract-5.3.11.tgz",
+ "integrity": "sha512-YeBrpIO3E5HUgcdKEldCUqwwDNHm5OBe98YFcdLr5Z0+dQaHnxp9Dm4n75/NojoGb5guYdrV00x+gU2UPHsVdw==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/extract/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/extract/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/extract/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/extract/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/extract/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/extract/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/extract/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/filter-alpha": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-alpha/-/filter-alpha-5.3.11.tgz",
+ "integrity": "sha512-HC4PbiEqDWSi3A715av7knFqD3knSXRxPJKG9mWat2CU9eCizSw+JxXp/okMU/fL4ewooiqQWVU2l1wXOHhVFw==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-alpha/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-alpha/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/filter-alpha/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-alpha/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-alpha/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/filter-alpha/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-alpha/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/filter-blur": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-blur/-/filter-blur-5.3.11.tgz",
+ "integrity": "sha512-iW5cOMEcDiJidOV95bUfhxdcvwM9JzCoWAd+92gAie8L+ElRSHpu1jxXbKHjo/QczQV1LulOlheyDaJNpaBCDg==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-blur/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-blur/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/filter-blur/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-blur/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-blur/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/filter-blur/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-blur/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/filter-color-matrix": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-color-matrix/-/filter-color-matrix-5.3.11.tgz",
+ "integrity": "sha512-u9NT4+N1I3XV9ygwsmF8/jIwCLqNCLeFOdM4f73kbw/UmakZZ6i6xjjJMc5YFUpC25qDr1TFlqgdGGGHAPl4ug==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-color-matrix/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-color-matrix/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/filter-color-matrix/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-color-matrix/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-color-matrix/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/filter-color-matrix/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-color-matrix/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/filter-displacement": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-displacement/-/filter-displacement-5.3.11.tgz",
+ "integrity": "sha512-CTIy7C/L9I1X3VNx4nMzQbMFvznsGk2viQh0dSo8r5NLgmaAdxhkGI0KUpNjLBz30278tzFfNuRe59K1y1kHuw==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/math": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-displacement/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-displacement/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/filter-displacement/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-displacement/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-displacement/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/filter-displacement/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-displacement/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/filter-fxaa": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-fxaa/-/filter-fxaa-5.3.11.tgz",
+ "integrity": "sha512-0ahjui5385e1vRvd7zCc0n5W8ULtNI1uVbDJHP9ueeiF25TKC0GqtZzntNwrQPoU46q8zXdnIGjzMpikbbAasg==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-fxaa/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-fxaa/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/filter-fxaa/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-fxaa/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-fxaa/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/filter-fxaa/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-fxaa/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/filter-noise": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-noise/-/filter-noise-5.3.11.tgz",
+ "integrity": "sha512-98WC9Nd5u2F03Ned9T3vnbmO/YF1jLSioZ623z9wjqpd5DosZgRtYTSGxjVcXTSfpviIuiJpkyF+X097pbVprg==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-noise/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-noise/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/filter-noise/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-noise/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/filter-noise/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/filter-noise/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/filter-noise/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/graphics": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/graphics/-/graphics-6.5.0.tgz",
+ "integrity": "sha512-8AoZDLlZtCQ2x/XmjnjdMUfri0L3oUoDWcMoa1CSqqzHBUhpWqrn5f/VeJnSS7xGixpGe1XeJXWwRoxSwN2D7A==",
+ "dev": true,
+ "peer": true,
+ "peerDependencies": {
+ "@pixi/constants": "6.5.0",
+ "@pixi/core": "6.5.0",
+ "@pixi/display": "6.5.0",
+ "@pixi/math": "6.5.0",
+ "@pixi/sprite": "6.5.0",
+ "@pixi/utils": "6.5.0"
+ }
+ },
+ "node_modules/@pixi/graphics-smooth": {
+ "version": "0.0.22",
+ "resolved": "https://registry.npmjs.org/@pixi/graphics-smooth/-/graphics-smooth-0.0.22.tgz",
+ "integrity": "sha512-qq2u+BJBIDBuuSTc2Xzm1D/8RiiKBdxnVDiMb7Go5v8achnV5ctC6m+rf8Mq0sWm66mbOqu1aq/9efT4A4sPrA==",
+ "dev": true,
+ "engines": {
+ "node": ">=14",
+ "npm": ">=7"
+ },
+ "peerDependencies": {
+ "@pixi/constants": "^6.0.4",
+ "@pixi/core": "^6.0.4",
+ "@pixi/display": "^6.0.4",
+ "@pixi/graphics": "^6.0.4",
+ "@pixi/math": "^6.0.4",
+ "@pixi/utils": "^6.0.4"
+ }
+ },
+ "node_modules/@pixi/interaction": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/interaction/-/interaction-5.3.11.tgz",
+ "integrity": "sha512-n2K99CYyBcrf8NPxpzmZ5IlJ9TEplsSZfJ/uzMNOEnTObKl4wAhxs51Nb58raH3Ouzwu14YHOpqYrBTEoT1yPA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/interaction/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/interaction/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/interaction/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/interaction/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/interaction/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/interaction/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/interaction/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/interaction/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/loaders": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/loaders/-/loaders-5.3.11.tgz",
+ "integrity": "sha512-1HAeb/NFXyhNhZWAbVkngsTPBGpjZEPhQflBTrKycRaub7XDSZ8F0fwPltpKKVRWNDT+HBgU/zDNE2fpjzqfYg==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/utils": "5.3.11",
+ "resource-loader": "^3.0.1"
+ }
+ },
+ "node_modules/@pixi/loaders/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/loaders/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/loaders/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/loaders/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/loaders/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/loaders/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/loaders/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/math": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-6.5.0.tgz",
+ "integrity": "sha512-NWOxO8my4KxdCyrR4UJGchwDkpWortMy8zUtXuds+92I+5fpBfctVkshf45o9QX2yX4pbtCPs0VupI2i5G3AOQ==",
+ "dev": true,
+ "peer": true
+ },
+ "node_modules/@pixi/mesh": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mesh/-/mesh-5.3.11.tgz",
+ "integrity": "sha512-KWKKksEr0YuUX1uz1FmpIa/Y37b/0pvFUS+87LoyYq0mRtGbKsTY5i3lBPG/taHwN7a2DQAX3JZpw6yhGKoGpA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mesh-extras": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mesh-extras/-/mesh-extras-5.3.11.tgz",
+ "integrity": "sha512-1GTCMMUW1xv/72x26cxRysblBXW0wU77TNgqtSIMZ1M6JbleObChklWTvwi9MzQO2vQ3S6Hvcsa5m5EiM2hSPQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/mesh": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mesh-extras/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/mesh-extras/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/mesh-extras/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/mesh-extras/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/mesh-extras/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/mesh-extras/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mesh-extras/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/mesh/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/mesh/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/mesh/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mesh/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/mesh/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/mesh/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/mesh/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mesh/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mixin-cache-as-bitmap/-/mixin-cache-as-bitmap-5.3.11.tgz",
+ "integrity": "sha512-uQUxatGTTD5zfQ0pWdjibVjT+xEEZJ/xZDZtm/GxC7HSHd4jgoJBcTXWVhbhzwpLPVTnD8+sMnRrGlhoKcpTpQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap/node_modules/@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mixin-cache-as-bitmap/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/mixin-get-child-by-name": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mixin-get-child-by-name/-/mixin-get-child-by-name-5.3.11.tgz",
+ "integrity": "sha512-fWFVxWtMYcwJttrgDNmZ4CJrx316p8ToNliC2ILmJZW77me7I4GzJ57gSHQU1xFwdHoOYRC4fnlrZoK5qJ9lDw==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/display": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mixin-get-child-by-name/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/mixin-get-child-by-name/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mixin-get-child-by-name/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/mixin-get-child-by-name/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/mixin-get-child-by-name/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/mixin-get-global-position": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mixin-get-global-position/-/mixin-get-global-position-5.3.11.tgz",
+ "integrity": "sha512-wrS9i+UUodLM5XL2N0Y+XSKiqLRdJV3ltFUWG6+jPT5yoP0HsKtx3sFAzX526RwIYwRzRusbc/quxHfRA4tvgg==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mixin-get-global-position/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/mixin-get-global-position/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/mixin-get-global-position/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/mixin-get-global-position/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/mixin-get-global-position/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/particles": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/particles/-/particles-5.3.11.tgz",
+ "integrity": "sha512-+mkt/inWXtRrxQc07RZ29uNIDWV1oMsrRBVBIvHgpR92Kn8EjIDRgoSXNu0jiZ18gRKKCBhwsS4dCXGsZRQ/sA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/particles/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/particles/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/particles/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/particles/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/particles/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/particles/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/particles/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/particles/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/polyfill": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/polyfill/-/polyfill-5.3.11.tgz",
+ "integrity": "sha512-yQOngcnn+2/L7n6L/g45hCnIDLWdnWmmcCY3UKJrOgbNX+JtLru1RR8AGLifkdsa0R5u48x584YQGqkTAChWVA==",
+ "dev": true,
+ "dependencies": {
+ "es6-promise-polyfill": "^1.2.0",
+ "object-assign": "^4.1.1"
+ }
+ },
+ "node_modules/@pixi/prepare": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/prepare/-/prepare-5.3.11.tgz",
+ "integrity": "sha512-TvjGeg7xPKjv5NxbM5NXReno9yxUCw/N0HtDEtEFRVeBLN3u0Q/dZsXxL6gIvkHoS09NFW+7AwsYQLZrVbppjA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/graphics": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/text": "5.3.11",
+ "@pixi/ticker": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/graphics": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/graphics/-/graphics-5.3.11.tgz",
+ "integrity": "sha512-HLu53LV6mRlY0uFSIM2OrCuL7xqXzeJs5d2QfmUJfKJVVZ9sbHDS+6/N/f0tXzvkRPYhSKXvcNPsNn4HmlIE9w==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/prepare/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/runner": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-6.5.0.tgz",
+ "integrity": "sha512-jZEilMPQlROJgRvRaJZcxp/K3adn4gx2mXwqK8DPqAcc5epwLzF8D4Us20PmY+7ALTglMdFZ7hHQKAPngi/jRA==",
+ "dev": true,
+ "peer": true
+ },
+ "node_modules/@pixi/settings": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-6.5.0.tgz",
+ "integrity": "sha512-fXbFYNJGv1v0ZS0kypziKFh2LJfI16aRBvqDqLFPvB0fkRkEOJuRTU4Lq77shgzP5v20oz7JShoVxyN5X9VNSw==",
+ "dev": true,
+ "peer": true
+ },
+ "node_modules/@pixi/sprite": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-6.5.0.tgz",
+ "integrity": "sha512-hxoH6poGBU+pZ4uC3rUuu9BXaFGrxZcyDu48/5ZYXjNC5HcCNPycmffalEkPcDQF7ymr7/3vTZ73mybcq9EIMA==",
+ "dev": true,
+ "peer": true,
+ "peerDependencies": {
+ "@pixi/constants": "6.5.0",
+ "@pixi/core": "6.5.0",
+ "@pixi/display": "6.5.0",
+ "@pixi/math": "6.5.0",
+ "@pixi/settings": "6.5.0",
+ "@pixi/utils": "6.5.0"
+ }
+ },
+ "node_modules/@pixi/sprite-animated": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite-animated/-/sprite-animated-5.3.11.tgz",
+ "integrity": "sha512-xU1b6H8nJ1l05h7cBGw2DGo4QdLj7xootstZUx2BrTVX5ZENn5mjAGVD0uRpk8yt7Q6Bj7M+PS7ktzAgBW/hmQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/ticker": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/sprite-animated/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/sprite-animated/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/sprite-animated/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/sprite-animated/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/sprite-animated/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/sprite-animated/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/sprite-animated/node_modules/@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/sprite-animated/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/sprite-animated/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/sprite-tiling": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite-tiling/-/sprite-tiling-5.3.11.tgz",
+ "integrity": "sha512-KUiWsIumjrnp9QKGMe1BqtrV9Hxm91KoaiOlCBk/gw8753iKvuMmH+/Z0RnzeZylJ1sJsdonTWy/IaLi1jnd0g==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/sprite-tiling/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/sprite-tiling/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/sprite-tiling/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/sprite-tiling/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/sprite-tiling/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/sprite-tiling/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/sprite-tiling/node_modules/@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/sprite-tiling/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/sprite-tiling/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/spritesheet": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/spritesheet/-/spritesheet-5.3.11.tgz",
+ "integrity": "sha512-Y9Wiwcz/YOuS1v73Ij9KWQakYBzZfldEy3H8T4GPLK+S19/sypntdkNtRZbmR2wWfhJ4axYEB2/Df86aOAU2qA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/loaders": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/spritesheet/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/spritesheet/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/spritesheet/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/spritesheet/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/spritesheet/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/spritesheet/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/spritesheet/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/text": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/text/-/text-5.3.11.tgz",
+ "integrity": "sha512-PmWvJv0wiKyyz3fahnxM19+m8IbF2vpDKIImqb5472WyxRGzKyVBW90xrADf5202tdKMk4b8hqvpof2XULr5PA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/text-bitmap": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/text-bitmap/-/text-bitmap-5.3.11.tgz",
+ "integrity": "sha512-Bjc/G4VHaPXc9HJsvyYOm5cNTHdqmX6AgzBAlCfltuMAlnveUgUPuX8D/MJHRRnoVSDHSmCBtnJgTc0y/nIeCw==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/loaders": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/mesh": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/text": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/text-bitmap/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/text-bitmap/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/text-bitmap/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/text-bitmap/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/text-bitmap/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/text-bitmap/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/text-bitmap/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/text-bitmap/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/text/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/@pixi/text/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/@pixi/text/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/text/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/@pixi/text/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/@pixi/text/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/@pixi/text/node_modules/@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/text/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/@pixi/text/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/@pixi/ticker": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-6.5.0.tgz",
+ "integrity": "sha512-sPoE2ra5bAS6WpFdHgAUzu2jDjW8bGuHlEtK+uQtD5KF07JViDEPnBqFXPWgZYHimnIFBnYw7+OtxPM1kTeKmQ==",
+ "dev": true,
+ "peer": true,
+ "peerDependencies": {
+ "@pixi/settings": "6.5.0"
+ }
+ },
+ "node_modules/@pixi/utils": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-6.5.0.tgz",
+ "integrity": "sha512-ttJZwTh2LhvwMt4WkU6HAWh6UE3ELGds+DQW29KW2yrKZnUEMsA2Jnsq7uFn6x6LM7tzBvJbzGvTyKgFL/jvVg==",
+ "dev": true,
+ "peer": true,
+ "dependencies": {
+ "@types/earcut": "^2.1.0",
+ "earcut": "^2.2.4",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ },
+ "peerDependencies": {
+ "@pixi/constants": "6.5.0",
+ "@pixi/settings": "6.5.0"
+ }
+ },
+ "node_modules/@rollup/plugin-babel": {
+ "version": "5.3.1",
+ "resolved": "https://registry.npmjs.org/@rollup/plugin-babel/-/plugin-babel-5.3.1.tgz",
+ "integrity": "sha512-WFfdLWU/xVWKeRQnKmIAQULUI7Il0gZnBIH/ZFO069wYIfPu+8zrfp/KMW0atmELoRDq8FbiP3VCss9MhCut7Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.10.4",
+ "@rollup/pluginutils": "^3.1.0"
+ },
+ "engines": {
+ "node": ">= 10.0.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0",
+ "@types/babel__core": "^7.1.9",
+ "rollup": "^1.20.0||^2.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/babel__core": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@rollup/plugin-node-resolve": {
+ "version": "13.3.0",
+ "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-13.3.0.tgz",
+ "integrity": "sha512-Lus8rbUo1eEcnS4yTFKLZrVumLPY+YayBdWXgFSHYhTT2iJbMhoaaBL3xl5NCdeRytErGr8tZ0L71BMRmnlwSw==",
+ "dependencies": {
+ "@rollup/pluginutils": "^3.1.0",
+ "@types/resolve": "1.17.1",
+ "deepmerge": "^4.2.2",
+ "is-builtin-module": "^3.1.0",
+ "is-module": "^1.0.0",
+ "resolve": "^1.19.0"
+ },
+ "engines": {
+ "node": ">= 10.0.0"
+ },
+ "peerDependencies": {
+ "rollup": "^2.42.0"
+ }
+ },
+ "node_modules/@rollup/pluginutils": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz",
+ "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==",
+ "dependencies": {
+ "@types/estree": "0.0.39",
+ "estree-walker": "^1.0.1",
+ "picomatch": "^2.2.2"
+ },
+ "engines": {
+ "node": ">= 8.0.0"
+ },
+ "peerDependencies": {
+ "rollup": "^1.20.0||^2.0.0"
+ }
+ },
+ "node_modules/@socket.io/component-emitter": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/@socket.io/component-emitter/-/component-emitter-3.0.0.tgz",
+ "integrity": "sha512-2pTGuibAXJswAPJjaKisthqS/NOK5ypG4LYT6tEAV0S/mxW0zOIvYvGK0V8w8+SHxAm6vRMSjqSalFXeBAqs+Q==",
+ "dev": true
+ },
+ "node_modules/@sveltejs/vite-plugin-svelte": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte/-/vite-plugin-svelte-1.0.1.tgz",
+ "integrity": "sha512-PorCgUounn0VXcpeJu+hOweZODKmGuLHsLomwqSj+p26IwjjGffmYQfVHtiTWq+NqaUuuHWWG7vPge6UFw4Aeg==",
+ "dependencies": {
+ "@rollup/pluginutils": "^4.2.1",
+ "debug": "^4.3.4",
+ "deepmerge": "^4.2.2",
+ "kleur": "^4.1.5",
+ "magic-string": "^0.26.2",
+ "svelte-hmr": "^0.14.12"
+ },
+ "engines": {
+ "node": "^14.18.0 || >= 16"
+ },
+ "peerDependencies": {
+ "diff-match-patch": "^1.0.5",
+ "svelte": "^3.44.0",
+ "vite": "^3.0.0"
+ },
+ "peerDependenciesMeta": {
+ "diff-match-patch": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@sveltejs/vite-plugin-svelte/node_modules/@rollup/pluginutils": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-4.2.1.tgz",
+ "integrity": "sha512-iKnFXr7NkdZAIHiIWE+BX5ULi/ucVFYWD6TbAV+rZctiRTY2PL6tsIKhoIOaoskiWAkgu+VsbXgUVDNLHf+InQ==",
+ "dependencies": {
+ "estree-walker": "^2.0.1",
+ "picomatch": "^2.2.2"
+ },
+ "engines": {
+ "node": ">= 8.0.0"
+ }
+ },
+ "node_modules/@sveltejs/vite-plugin-svelte/node_modules/estree-walker": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz",
+ "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w=="
+ },
+ "node_modules/@trysound/sax": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/@trysound/sax/-/sax-0.2.0.tgz",
+ "integrity": "sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA==",
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/@types/earcut": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/@types/earcut/-/earcut-2.1.1.tgz",
+ "integrity": "sha512-w8oigUCDjElRHRRrMvn/spybSMyX8MTkKA5Dv+tS1IE/TgmNZPqUYtvYBXGY8cieSE66gm+szeK+bnbxC2xHTQ==",
+ "dev": true,
+ "peer": true
+ },
+ "node_modules/@types/estree": {
+ "version": "0.0.39",
+ "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz",
+ "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw=="
+ },
+ "node_modules/@types/jquery": {
+ "version": "3.5.14",
+ "resolved": "https://registry.npmjs.org/@types/jquery/-/jquery-3.5.14.tgz",
+ "integrity": "sha512-X1gtMRMbziVQkErhTQmSe2jFwwENA/Zr+PprCkF63vFq+Yt5PZ4AlKqgmeNlwgn7dhsXEK888eIW2520EpC+xg==",
+ "dev": true,
+ "dependencies": {
+ "@types/sizzle": "*"
+ }
+ },
+ "node_modules/@types/node": {
+ "version": "18.0.6",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-18.0.6.tgz",
+ "integrity": "sha512-/xUq6H2aQm261exT6iZTMifUySEt4GR5KX8eYyY+C4MSNPqSh9oNIP7tz2GLKTlFaiBbgZNxffoR3CVRG+cljw=="
+ },
+ "node_modules/@types/offscreencanvas": {
+ "version": "2019.7.0",
+ "resolved": "https://registry.npmjs.org/@types/offscreencanvas/-/offscreencanvas-2019.7.0.tgz",
+ "integrity": "sha512-PGcyveRIpL1XIqK8eBsmRBt76eFgtzuPiSTyKHZxnGemp2yzGzWpjYKAfK3wIMiU7eH+851yEpiuP8JZerTmWg==",
+ "dev": true,
+ "peer": true
+ },
+ "node_modules/@types/pug": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/@types/pug/-/pug-2.0.6.tgz",
+ "integrity": "sha512-SnHmG9wN1UVmagJOnyo/qkk0Z7gejYxOYYmaAwr5u2yFYfsupN3sg10kyzN8Hep/2zbHxCnsumxOoRIRMBwKCg=="
+ },
+ "node_modules/@types/resolve": {
+ "version": "1.17.1",
+ "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.17.1.tgz",
+ "integrity": "sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==",
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/sass": {
+ "version": "1.43.1",
+ "resolved": "https://registry.npmjs.org/@types/sass/-/sass-1.43.1.tgz",
+ "integrity": "sha512-BPdoIt1lfJ6B7rw35ncdwBZrAssjcwzI5LByIrYs+tpXlj/CAkuVdRsgZDdP4lq5EjyWzwxZCqAoFyHKFwp32g==",
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/simple-peer": {
+ "version": "9.11.4",
+ "resolved": "https://registry.npmjs.org/@types/simple-peer/-/simple-peer-9.11.4.tgz",
+ "integrity": "sha512-Elje14YvM47k+XEaoyRAeUSvZN7TOLWYL233QCckUaXjT4lRESHnYs0iOK2JoosO5DnCvWu/0Vpl9qnw4KCLWw==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/sizzle": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/@types/sizzle/-/sizzle-2.3.3.tgz",
+ "integrity": "sha512-JYM8x9EGF163bEyhdJBpR2QX1R5naCJHC8ucJylJ3w9/CVBaskdQ8WqBf8MmQrd1kRvp/a4TS8HJ+bxzR7ZJYQ==",
+ "dev": true
+ },
+ "node_modules/@typhonjs-config/eslint-config": {
+ "version": "0.3.4",
+ "resolved": "https://registry.npmjs.org/@typhonjs-config/eslint-config/-/eslint-config-0.3.4.tgz",
+ "integrity": "sha512-GGEjrOevGjBRZFM0b18AxtHbk2Ifuv3sx1AS8SLXKwWJo7zWRRfQiEInuIJ+O0g85Js4OP+magm/Lm4b5h6GSQ==",
+ "dev": true,
+ "dependencies": {
+ "eslint-plugin-jsdoc": "^37"
+ }
+ },
+ "node_modules/@typhonjs-fvtt/eslint-config-foundry.js": {
+ "version": "0.8.0",
+ "resolved": "https://registry.npmjs.org/@typhonjs-fvtt/eslint-config-foundry.js/-/eslint-config-foundry.js-0.8.0.tgz",
+ "integrity": "sha512-Fu1XDS747exX5zVwty4VSwlOwkuzdnnN15C5w66uG4hOpJnPCZU/jcyEOCf9bazRPp06Smimn+mKd9OjrCvuuw==",
+ "dev": true
+ },
+ "node_modules/@typhonjs-fvtt/runtime": {
+ "version": "0.0.19",
+ "resolved": "https://registry.npmjs.org/@typhonjs-fvtt/runtime/-/runtime-0.0.19.tgz",
+ "integrity": "sha512-8tuNDar/exfruiT45np7PYLvGUfihqyuYrekNn3rwo6prwOSise1J2Jr7c0VstrrJfprYPhBGQmGyJSkihZJtA==",
+ "dependencies": {
+ "@rollup/plugin-node-resolve": "^13",
+ "@sveltejs/vite-plugin-svelte": "^1",
+ "autoprefixer": "^10",
+ "cssnano": "^5",
+ "postcss": "^8",
+ "postcss-preset-env": "^7",
+ "rollup-plugin-postcss": "^4",
+ "rollup-plugin-sourcemaps": "^0.6",
+ "rollup-plugin-svelte": "^7",
+ "rollup-plugin-terser": "^7",
+ "sass": "^1"
+ },
+ "peerDependencies": {
+ "svelte": "^3.49.0",
+ "svelte-preprocess": "^4.10.0",
+ "vite": "^3"
+ }
+ },
+ "node_modules/@typhonjs-fvtt/svelte-standard": {
+ "version": "0.0.9",
+ "resolved": "https://registry.npmjs.org/@typhonjs-fvtt/svelte-standard/-/svelte-standard-0.0.9.tgz",
+ "integrity": "sha512-vhpisaTwuWcd2V1UQbIx96pkXhXe+7HhIsng2Nm5QvGA+bvYFkY3ruUSDj9b88pivo+UCnwaj7wN+xOfBW5Jng==",
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/acorn": {
+ "version": "8.8.0",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.0.tgz",
+ "integrity": "sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w==",
+ "bin": {
+ "acorn": "bin/acorn"
+ },
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/acorn-jsx": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
+ "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
+ "dev": true,
+ "peerDependencies": {
+ "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
+ }
+ },
+ "node_modules/ajv": {
+ "version": "6.12.6",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
+ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
+ "dev": true,
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
+ "node_modules/ansi-regex": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
+ "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/ansi-styles": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
+ "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
+ "dependencies": {
+ "color-convert": "^1.9.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/anymatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
+ "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
+ "dependencies": {
+ "normalize-path": "^3.0.0",
+ "picomatch": "^2.0.4"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/argparse": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
+ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
+ "dev": true
+ },
+ "node_modules/atob": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz",
+ "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==",
+ "bin": {
+ "atob": "bin/atob.js"
+ },
+ "engines": {
+ "node": ">= 4.5.0"
+ }
+ },
+ "node_modules/autoprefixer": {
+ "version": "10.4.7",
+ "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.7.tgz",
+ "integrity": "sha512-ypHju4Y2Oav95SipEcCcI5J7CGPuvz8oat7sUtYj3ClK44bldfvtvcxK6IEK++7rqB7YchDGzweZIBG+SD0ZAA==",
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/autoprefixer"
+ }
+ ],
+ "dependencies": {
+ "browserslist": "^4.20.3",
+ "caniuse-lite": "^1.0.30001335",
+ "fraction.js": "^4.2.0",
+ "normalize-range": "^0.1.2",
+ "picocolors": "^1.0.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "bin": {
+ "autoprefixer": "bin/autoprefixer"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/babel-plugin-dynamic-import-node": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz",
+ "integrity": "sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ==",
+ "dev": true,
+ "dependencies": {
+ "object.assign": "^4.1.0"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-corejs2": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.2.tgz",
+ "integrity": "sha512-LPnodUl3lS0/4wN3Rb+m+UK8s7lj2jcLRrjho4gLw+OJs+I4bvGXshINesY5xx/apM+biTnQ9reDI8yj+0M5+Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.17.7",
+ "@babel/helper-define-polyfill-provider": "^0.3.2",
+ "semver": "^6.1.1"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-corejs3": {
+ "version": "0.5.3",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.5.3.tgz",
+ "integrity": "sha512-zKsXDh0XjnrUEW0mxIHLfjBfnXSMr5Q/goMe/fxpQnLm07mcOZiIZHBNWCMx60HmdvjxfXcalac0tfFg0wqxyw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-define-polyfill-provider": "^0.3.2",
+ "core-js-compat": "^3.21.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-regenerator": {
+ "version": "0.3.1",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.3.1.tgz",
+ "integrity": "sha512-Y2B06tvgHYt1x0yz17jGkGeeMr5FeKUu+ASJ+N6nB5lQ8Dapfg42i0OVrf8PNGJ3zKL4A23snMi1IRwrqqND7A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-define-polyfill-provider": "^0.3.1"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/backo2": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz",
+ "integrity": "sha512-zj6Z6M7Eq+PBZ7PQxl5NT665MvJdAkzp0f60nAJ+sLaSCBPMwVak5ZegFbgVCzFcCJTKFoMizvM5Ld7+JrRJHA==",
+ "dev": true
+ },
+ "node_modules/balanced-match": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
+ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw=="
+ },
+ "node_modules/binary-extensions": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
+ "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/boolbase": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz",
+ "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww=="
+ },
+ "node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/braces": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
+ "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
+ "dependencies": {
+ "fill-range": "^7.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/browserslist": {
+ "version": "4.21.2",
+ "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.2.tgz",
+ "integrity": "sha512-MonuOgAtUB46uP5CezYbRaYKBNt2LxP0yX+Pmj4LkcDFGkn9Cbpi83d9sCjwQDErXsIJSzY5oKGDbgOlF/LPAA==",
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ }
+ ],
+ "dependencies": {
+ "caniuse-lite": "^1.0.30001366",
+ "electron-to-chromium": "^1.4.188",
+ "node-releases": "^2.0.6",
+ "update-browserslist-db": "^1.0.4"
+ },
+ "bin": {
+ "browserslist": "cli.js"
+ },
+ "engines": {
+ "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
+ }
+ },
+ "node_modules/buffer-crc32": {
+ "version": "0.2.13",
+ "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz",
+ "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==",
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/buffer-from": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
+ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ=="
+ },
+ "node_modules/builtin-modules": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.3.0.tgz",
+ "integrity": "sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw==",
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/call-bind": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz",
+ "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==",
+ "dev": true,
+ "dependencies": {
+ "function-bind": "^1.1.1",
+ "get-intrinsic": "^1.0.2"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/caniuse-api": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz",
+ "integrity": "sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw==",
+ "dependencies": {
+ "browserslist": "^4.0.0",
+ "caniuse-lite": "^1.0.0",
+ "lodash.memoize": "^4.1.2",
+ "lodash.uniq": "^4.5.0"
+ }
+ },
+ "node_modules/caniuse-lite": {
+ "version": "1.0.30001369",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001369.tgz",
+ "integrity": "sha512-OY1SBHaodJc4wflDIKnlkdqWzJZd1Ls/2zbVJHBSv3AT7vgOJ58yAhd2CN4d57l2kPJrgMb7P9+N1Mhy4tNSQA==",
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
+ }
+ ]
+ },
+ "node_modules/chalk": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
+ "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
+ "dependencies": {
+ "ansi-styles": "^3.2.1",
+ "escape-string-regexp": "^1.0.5",
+ "supports-color": "^5.3.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/chokidar": {
+ "version": "3.5.3",
+ "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
+ "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
+ "funding": [
+ {
+ "type": "individual",
+ "url": "https://paulmillr.com/funding/"
+ }
+ ],
+ "dependencies": {
+ "anymatch": "~3.1.2",
+ "braces": "~3.0.2",
+ "glob-parent": "~5.1.2",
+ "is-binary-path": "~2.1.0",
+ "is-glob": "~4.0.1",
+ "normalize-path": "~3.0.0",
+ "readdirp": "~3.6.0"
+ },
+ "engines": {
+ "node": ">= 8.10.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ }
+ },
+ "node_modules/chokidar/node_modules/glob-parent": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
+ "dependencies": {
+ "is-glob": "^4.0.1"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/color-convert": {
+ "version": "1.9.3",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
+ "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
+ "dependencies": {
+ "color-name": "1.1.3"
+ }
+ },
+ "node_modules/color-name": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
+ "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw=="
+ },
+ "node_modules/colord": {
+ "version": "2.9.2",
+ "resolved": "https://registry.npmjs.org/colord/-/colord-2.9.2.tgz",
+ "integrity": "sha512-Uqbg+J445nc1TKn4FoDPS6ZZqAvEDnwrH42yo8B40JSOgSLxMZ/gt3h4nmCtPLQeXhjJJkqBx7SCY35WnIixaQ=="
+ },
+ "node_modules/commander": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz",
+ "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==",
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/comment-parser": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/comment-parser/-/comment-parser-1.3.0.tgz",
+ "integrity": "sha512-hRpmWIKgzd81vn0ydoWoyPoALEOnF4wt8yKD35Ib1D6XC2siLiYaiqfGkYrunuKdsXGwpBpHU3+9r+RVw2NZfA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 12.0.0"
+ }
+ },
+ "node_modules/concat-map": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
+ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg=="
+ },
+ "node_modules/concat-with-sourcemaps": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/concat-with-sourcemaps/-/concat-with-sourcemaps-1.1.0.tgz",
+ "integrity": "sha512-4gEjHJFT9e+2W/77h/DS5SGUgwDaOwprX8L/gl5+3ixnzkVJJsZWDSelmN3Oilw3LNDZjZV0yqH1hLG3k6nghg==",
+ "dependencies": {
+ "source-map": "^0.6.1"
+ }
+ },
+ "node_modules/convert-source-map": {
+ "version": "1.8.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz",
+ "integrity": "sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==",
+ "devOptional": true,
+ "dependencies": {
+ "safe-buffer": "~5.1.1"
+ }
+ },
+ "node_modules/core-js-compat": {
+ "version": "3.23.5",
+ "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.23.5.tgz",
+ "integrity": "sha512-fHYozIFIxd+91IIbXJgWd/igXIc8Mf9is0fusswjnGIWVG96y2cwyUdlCkGOw6rMLHKAxg7xtCIVaHsyOUnJIg==",
+ "dev": true,
+ "dependencies": {
+ "browserslist": "^4.21.2",
+ "semver": "7.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/core-js"
+ }
+ },
+ "node_modules/core-js-compat/node_modules/semver": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz",
+ "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/cross-spawn": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
+ "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
+ "dev": true,
+ "dependencies": {
+ "path-key": "^3.1.0",
+ "shebang-command": "^2.0.0",
+ "which": "^2.0.1"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/css-blank-pseudo": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/css-blank-pseudo/-/css-blank-pseudo-3.0.3.tgz",
+ "integrity": "sha512-VS90XWtsHGqoM0t4KpH053c4ehxZ2E6HtGI7x68YFV0pTo/QmkV/YFA+NnlvK8guxZVNWGQhVNJGC39Q8XF4OQ==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.9"
+ },
+ "bin": {
+ "css-blank-pseudo": "dist/cli.cjs"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4"
+ }
+ },
+ "node_modules/css-declaration-sorter": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/css-declaration-sorter/-/css-declaration-sorter-6.3.0.tgz",
+ "integrity": "sha512-OGT677UGHJTAVMRhPO+HJ4oKln3wkBTwtDFH0ojbqm+MJm6xuDMHp2nkhh/ThaBqq20IbraBQSWKfSLNHQO9Og==",
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.0.9"
+ }
+ },
+ "node_modules/css-has-pseudo": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/css-has-pseudo/-/css-has-pseudo-3.0.4.tgz",
+ "integrity": "sha512-Vse0xpR1K9MNlp2j5w1pgWIJtm1a8qS0JwS9goFYcImjlHEmywP9VUF05aGBXzGpDJF86QXk4L0ypBmwPhGArw==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.9"
+ },
+ "bin": {
+ "css-has-pseudo": "dist/cli.cjs"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4"
+ }
+ },
+ "node_modules/css-prefers-color-scheme": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/css-prefers-color-scheme/-/css-prefers-color-scheme-6.0.3.tgz",
+ "integrity": "sha512-4BqMbZksRkJQx2zAjrokiGMd07RqOa2IxIrrN10lyBe9xhn9DEvjUK79J6jkeiv9D9hQFXKb6g1jwU62jziJZA==",
+ "bin": {
+ "css-prefers-color-scheme": "dist/cli.cjs"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4"
+ }
+ },
+ "node_modules/css-select": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/css-select/-/css-select-4.3.0.tgz",
+ "integrity": "sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==",
+ "dependencies": {
+ "boolbase": "^1.0.0",
+ "css-what": "^6.0.1",
+ "domhandler": "^4.3.1",
+ "domutils": "^2.8.0",
+ "nth-check": "^2.0.1"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/fb55"
+ }
+ },
+ "node_modules/css-tree": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.1.3.tgz",
+ "integrity": "sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q==",
+ "dependencies": {
+ "mdn-data": "2.0.14",
+ "source-map": "^0.6.1"
+ },
+ "engines": {
+ "node": ">=8.0.0"
+ }
+ },
+ "node_modules/css-what": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz",
+ "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==",
+ "engines": {
+ "node": ">= 6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/fb55"
+ }
+ },
+ "node_modules/cssdb": {
+ "version": "6.6.3",
+ "resolved": "https://registry.npmjs.org/cssdb/-/cssdb-6.6.3.tgz",
+ "integrity": "sha512-7GDvDSmE+20+WcSMhP17Q1EVWUrLlbxxpMDqG731n8P99JhnQZHR9YvtjPvEHfjFUjvQJvdpKCjlKOX+xe4UVA==",
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ }
+ },
+ "node_modules/cssesc": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz",
+ "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==",
+ "bin": {
+ "cssesc": "bin/cssesc"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/cssnano": {
+ "version": "5.1.12",
+ "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-5.1.12.tgz",
+ "integrity": "sha512-TgvArbEZu0lk/dvg2ja+B7kYoD7BBCmn3+k58xD0qjrGHsFzXY/wKTo9M5egcUCabPol05e/PVoIu79s2JN4WQ==",
+ "dependencies": {
+ "cssnano-preset-default": "^5.2.12",
+ "lilconfig": "^2.0.3",
+ "yaml": "^1.10.2"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/cssnano"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/cssnano-preset-default": {
+ "version": "5.2.12",
+ "resolved": "https://registry.npmjs.org/cssnano-preset-default/-/cssnano-preset-default-5.2.12.tgz",
+ "integrity": "sha512-OyCBTZi+PXgylz9HAA5kHyoYhfGcYdwFmyaJzWnzxuGRtnMw/kR6ilW9XzlzlRAtB6PLT/r+prYgkef7hngFew==",
+ "dependencies": {
+ "css-declaration-sorter": "^6.3.0",
+ "cssnano-utils": "^3.1.0",
+ "postcss-calc": "^8.2.3",
+ "postcss-colormin": "^5.3.0",
+ "postcss-convert-values": "^5.1.2",
+ "postcss-discard-comments": "^5.1.2",
+ "postcss-discard-duplicates": "^5.1.0",
+ "postcss-discard-empty": "^5.1.1",
+ "postcss-discard-overridden": "^5.1.0",
+ "postcss-merge-longhand": "^5.1.6",
+ "postcss-merge-rules": "^5.1.2",
+ "postcss-minify-font-values": "^5.1.0",
+ "postcss-minify-gradients": "^5.1.1",
+ "postcss-minify-params": "^5.1.3",
+ "postcss-minify-selectors": "^5.2.1",
+ "postcss-normalize-charset": "^5.1.0",
+ "postcss-normalize-display-values": "^5.1.0",
+ "postcss-normalize-positions": "^5.1.1",
+ "postcss-normalize-repeat-style": "^5.1.1",
+ "postcss-normalize-string": "^5.1.0",
+ "postcss-normalize-timing-functions": "^5.1.0",
+ "postcss-normalize-unicode": "^5.1.0",
+ "postcss-normalize-url": "^5.1.0",
+ "postcss-normalize-whitespace": "^5.1.1",
+ "postcss-ordered-values": "^5.1.3",
+ "postcss-reduce-initial": "^5.1.0",
+ "postcss-reduce-transforms": "^5.1.0",
+ "postcss-svgo": "^5.1.0",
+ "postcss-unique-selectors": "^5.1.1"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/cssnano-utils": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/cssnano-utils/-/cssnano-utils-3.1.0.tgz",
+ "integrity": "sha512-JQNR19/YZhz4psLX/rQ9M83e3z2Wf/HdJbryzte4a3NSuafyp9w/I4U+hx5C2S9g41qlstH7DEWnZaaj83OuEA==",
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/csso": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/csso/-/csso-4.2.0.tgz",
+ "integrity": "sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA==",
+ "dependencies": {
+ "css-tree": "^1.1.2"
+ },
+ "engines": {
+ "node": ">=8.0.0"
+ }
+ },
+ "node_modules/debug": {
+ "version": "4.3.4",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
+ "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
+ "dependencies": {
+ "ms": "2.1.2"
+ },
+ "engines": {
+ "node": ">=6.0"
+ },
+ "peerDependenciesMeta": {
+ "supports-color": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/decode-uri-component": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz",
+ "integrity": "sha512-hjf+xovcEn31w/EUYdTXQh/8smFL/dzYjohQGEIgjyNavaJfBY2p5F527Bo1VPATxv0VYTUC2bOcXvqFwk78Og==",
+ "engines": {
+ "node": ">=0.10"
+ }
+ },
+ "node_modules/deep-is": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
+ "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
+ "dev": true
+ },
+ "node_modules/deepmerge": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz",
+ "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/define-properties": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz",
+ "integrity": "sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA==",
+ "dev": true,
+ "dependencies": {
+ "has-property-descriptors": "^1.0.0",
+ "object-keys": "^1.1.1"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/detect-indent": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-6.1.0.tgz",
+ "integrity": "sha512-reYkTUJAZb9gUuZ2RvVCNhVHdg62RHnJ7WJl8ftMi4diZ6NWlciOzQN88pUhSELEwflJht4oQDv0F0BMlwaYtA==",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/doctrine": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz",
+ "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==",
+ "dev": true,
+ "dependencies": {
+ "esutils": "^2.0.2"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/dom-serializer": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.4.1.tgz",
+ "integrity": "sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag==",
+ "dependencies": {
+ "domelementtype": "^2.0.1",
+ "domhandler": "^4.2.0",
+ "entities": "^2.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1"
+ }
+ },
+ "node_modules/domelementtype": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz",
+ "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==",
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/fb55"
+ }
+ ]
+ },
+ "node_modules/domhandler": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.3.1.tgz",
+ "integrity": "sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==",
+ "dependencies": {
+ "domelementtype": "^2.2.0"
+ },
+ "engines": {
+ "node": ">= 4"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/domhandler?sponsor=1"
+ }
+ },
+ "node_modules/domutils": {
+ "version": "2.8.0",
+ "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.8.0.tgz",
+ "integrity": "sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==",
+ "dependencies": {
+ "dom-serializer": "^1.0.1",
+ "domelementtype": "^2.2.0",
+ "domhandler": "^4.2.0"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/domutils?sponsor=1"
+ }
+ },
+ "node_modules/earcut": {
+ "version": "2.2.4",
+ "resolved": "https://registry.npmjs.org/earcut/-/earcut-2.2.4.tgz",
+ "integrity": "sha512-/pjZsA1b4RPHbeWZQn66SWS8nZZWLQQ23oE3Eam7aroEFGEvwKAsJfZ9ytiEMycfzXWpca4FA9QIOehf7PocBQ==",
+ "dev": true
+ },
+ "node_modules/electron-to-chromium": {
+ "version": "1.4.199",
+ "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.199.tgz",
+ "integrity": "sha512-WIGME0Cs7oob3mxsJwHbeWkH0tYkIE/sjkJ8ML2BYmuRcjhRl/q5kVDXG7W9LOOKwzPU5M0LBlXRq9rlSgnNlg=="
+ },
+ "node_modules/engine.io-client": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/engine.io-client/-/engine.io-client-6.0.3.tgz",
+ "integrity": "sha512-IH8ZhDIwiLv0d/wXVzmjfV9Y82hbJIDhCGSVUV8o1kcpDe2I6Y3bZA3ZbJy4Ls7k7IVmcy/qn4k9RKWFhUGf5w==",
+ "dev": true,
+ "dependencies": {
+ "@socket.io/component-emitter": "~3.0.0",
+ "debug": "~4.3.1",
+ "engine.io-parser": "~5.0.0",
+ "has-cors": "1.1.0",
+ "parseqs": "0.0.6",
+ "parseuri": "0.0.6",
+ "ws": "~8.2.3",
+ "xmlhttprequest-ssl": "~2.0.0",
+ "yeast": "0.1.2"
+ }
+ },
+ "node_modules/engine.io-parser": {
+ "version": "5.0.4",
+ "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.0.4.tgz",
+ "integrity": "sha512-+nVFp+5z1E3HcToEnO7ZIj3g+3k9389DvWtvJZz0T6/eOCPIyyxehFcedoYrZQrp0LgQbD9pPXhpMBKMd5QURg==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/entities": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz",
+ "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==",
+ "funding": {
+ "url": "https://github.com/fb55/entities?sponsor=1"
+ }
+ },
+ "node_modules/es6-promise": {
+ "version": "3.3.1",
+ "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-3.3.1.tgz",
+ "integrity": "sha512-SOp9Phqvqn7jtEUxPWdWfWoLmyt2VaJ6MpvP9Comy1MceMXqE6bxvaTu4iaxpYYPzhny28Lc+M87/c2cPK6lDg=="
+ },
+ "node_modules/es6-promise-polyfill": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/es6-promise-polyfill/-/es6-promise-polyfill-1.2.0.tgz",
+ "integrity": "sha512-HHb0vydCpoclpd0ySPkRXMmBw80MRt1wM4RBJBlXkux97K7gleabZdsR0gvE1nNPM9mgOZIBTzjjXiPxf4lIqQ==",
+ "dev": true
+ },
+ "node_modules/esbuild": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.49.tgz",
+ "integrity": "sha512-/TlVHhOaq7Yz8N1OJrjqM3Auzo5wjvHFLk+T8pIue+fhnhIMpfAzsG6PLVMbFveVxqD2WOp3QHei+52IMUNmCw==",
+ "hasInstallScript": true,
+ "bin": {
+ "esbuild": "bin/esbuild"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "optionalDependencies": {
+ "esbuild-android-64": "0.14.49",
+ "esbuild-android-arm64": "0.14.49",
+ "esbuild-darwin-64": "0.14.49",
+ "esbuild-darwin-arm64": "0.14.49",
+ "esbuild-freebsd-64": "0.14.49",
+ "esbuild-freebsd-arm64": "0.14.49",
+ "esbuild-linux-32": "0.14.49",
+ "esbuild-linux-64": "0.14.49",
+ "esbuild-linux-arm": "0.14.49",
+ "esbuild-linux-arm64": "0.14.49",
+ "esbuild-linux-mips64le": "0.14.49",
+ "esbuild-linux-ppc64le": "0.14.49",
+ "esbuild-linux-riscv64": "0.14.49",
+ "esbuild-linux-s390x": "0.14.49",
+ "esbuild-netbsd-64": "0.14.49",
+ "esbuild-openbsd-64": "0.14.49",
+ "esbuild-sunos-64": "0.14.49",
+ "esbuild-windows-32": "0.14.49",
+ "esbuild-windows-64": "0.14.49",
+ "esbuild-windows-arm64": "0.14.49"
+ }
+ },
+ "node_modules/esbuild-android-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-android-64/-/esbuild-android-64-0.14.49.tgz",
+ "integrity": "sha512-vYsdOTD+yi+kquhBiFWl3tyxnj2qZJsl4tAqwhT90ktUdnyTizgle7TjNx6Ar1bN7wcwWqZ9QInfdk2WVagSww==",
+ "cpu": [
+ "x64"
+ ],
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-android-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.49.tgz",
+ "integrity": "sha512-g2HGr/hjOXCgSsvQZ1nK4nW/ei8JUx04Li74qub9qWrStlysaVmadRyTVuW32FGIpLQyc5sUjjZopj49eGGM2g==",
+ "cpu": [
+ "arm64"
+ ],
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-darwin-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.49.tgz",
+ "integrity": "sha512-3rvqnBCtX9ywso5fCHixt2GBCUsogNp9DjGmvbBohh31Ces34BVzFltMSxJpacNki96+WIcX5s/vum+ckXiLYg==",
+ "cpu": [
+ "x64"
+ ],
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-darwin-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.49.tgz",
+ "integrity": "sha512-XMaqDxO846srnGlUSJnwbijV29MTKUATmOLyQSfswbK/2X5Uv28M9tTLUJcKKxzoo9lnkYPsx2o8EJcTYwCs/A==",
+ "cpu": [
+ "arm64"
+ ],
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-freebsd-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.49.tgz",
+ "integrity": "sha512-NJ5Q6AjV879mOHFri+5lZLTp5XsO2hQ+KSJYLbfY9DgCu8s6/Zl2prWXVANYTeCDLlrIlNNYw8y34xqyLDKOmQ==",
+ "cpu": [
+ "x64"
+ ],
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-freebsd-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.49.tgz",
+ "integrity": "sha512-lFLtgXnAc3eXYqj5koPlBZvEbBSOSUbWO3gyY/0+4lBdRqELyz4bAuamHvmvHW5swJYL7kngzIZw6kdu25KGOA==",
+ "cpu": [
+ "arm64"
+ ],
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-linux-32": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.49.tgz",
+ "integrity": "sha512-zTTH4gr2Kb8u4QcOpTDVn7Z8q7QEIvFl/+vHrI3cF6XOJS7iEI1FWslTo3uofB2+mn6sIJEQD9PrNZKoAAMDiA==",
+ "cpu": [
+ "ia32"
+ ],
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-linux-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.49.tgz",
+ "integrity": "sha512-hYmzRIDzFfLrB5c1SknkxzM8LdEUOusp6M2TnuQZJLRtxTgyPnZZVtyMeCLki0wKgYPXkFsAVhi8vzo2mBNeTg==",
+ "cpu": [
+ "x64"
+ ],
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-linux-arm": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.49.tgz",
+ "integrity": "sha512-iE3e+ZVv1Qz1Sy0gifIsarJMQ89Rpm9mtLSRtG3AH0FPgAzQ5Z5oU6vYzhc/3gSPi2UxdCOfRhw2onXuFw/0lg==",
+ "cpu": [
+ "arm"
+ ],
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-linux-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.49.tgz",
+ "integrity": "sha512-KLQ+WpeuY+7bxukxLz5VgkAAVQxUv67Ft4DmHIPIW+2w3ObBPQhqNoeQUHxopoW/aiOn3m99NSmSV+bs4BSsdA==",
+ "cpu": [
+ "arm64"
+ ],
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-linux-mips64le": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.49.tgz",
+ "integrity": "sha512-n+rGODfm8RSum5pFIqFQVQpYBw+AztL8s6o9kfx7tjfK0yIGF6tm5HlG6aRjodiiKkH2xAiIM+U4xtQVZYU4rA==",
+ "cpu": [
+ "mips64el"
+ ],
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-linux-ppc64le": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.49.tgz",
+ "integrity": "sha512-WP9zR4HX6iCBmMFH+XHHng2LmdoIeUmBpL4aL2TR8ruzXyT4dWrJ5BSbT8iNo6THN8lod6GOmYDLq/dgZLalGw==",
+ "cpu": [
+ "ppc64"
+ ],
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-linux-riscv64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.14.49.tgz",
+ "integrity": "sha512-h66ORBz+Dg+1KgLvzTVQEA1LX4XBd1SK0Fgbhhw4akpG/YkN8pS6OzYI/7SGENiN6ao5hETRDSkVcvU9NRtkMQ==",
+ "cpu": [
+ "riscv64"
+ ],
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-linux-s390x": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-s390x/-/esbuild-linux-s390x-0.14.49.tgz",
+ "integrity": "sha512-DhrUoFVWD+XmKO1y7e4kNCqQHPs6twz6VV6Uezl/XHYGzM60rBewBF5jlZjG0nCk5W/Xy6y1xWeopkrhFFM0sQ==",
+ "cpu": [
+ "s390x"
+ ],
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-netbsd-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.49.tgz",
+ "integrity": "sha512-BXaUwFOfCy2T+hABtiPUIpWjAeWK9P8O41gR4Pg73hpzoygVGnj0nI3YK4SJhe52ELgtdgWP/ckIkbn2XaTxjQ==",
+ "cpu": [
+ "x64"
+ ],
+ "optional": true,
+ "os": [
+ "netbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-openbsd-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.49.tgz",
+ "integrity": "sha512-lP06UQeLDGmVPw9Rg437Btu6J9/BmyhdoefnQ4gDEJTtJvKtQaUcOQrhjTq455ouZN4EHFH1h28WOJVANK41kA==",
+ "cpu": [
+ "x64"
+ ],
+ "optional": true,
+ "os": [
+ "openbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-sunos-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.49.tgz",
+ "integrity": "sha512-4c8Zowp+V3zIWje329BeLbGh6XI9c/rqARNaj5yPHdC61pHI9UNdDxT3rePPJeWcEZVKjkiAS6AP6kiITp7FSw==",
+ "cpu": [
+ "x64"
+ ],
+ "optional": true,
+ "os": [
+ "sunos"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-windows-32": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.49.tgz",
+ "integrity": "sha512-q7Rb+J9yHTeKr9QTPDYkqfkEj8/kcKz9lOabDuvEXpXuIcosWCJgo5Z7h/L4r7rbtTH4a8U2FGKb6s1eeOHmJA==",
+ "cpu": [
+ "ia32"
+ ],
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-windows-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.49.tgz",
+ "integrity": "sha512-+Cme7Ongv0UIUTniPqfTX6mJ8Deo7VXw9xN0yJEN1lQMHDppTNmKwAM3oGbD/Vqff+07K2gN0WfNkMohmG+dVw==",
+ "cpu": [
+ "x64"
+ ],
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/esbuild-windows-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.49.tgz",
+ "integrity": "sha512-v+HYNAXzuANrCbbLFJ5nmO3m5y2PGZWLe3uloAkLt87aXiO2mZr3BTmacZdjwNkNEHuH3bNtN8cak+mzVjVPfA==",
+ "cpu": [
+ "arm64"
+ ],
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/escalade": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
+ "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/escape-string-regexp": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
+ "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/eslint": {
+ "version": "8.20.0",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.20.0.tgz",
+ "integrity": "sha512-d4ixhz5SKCa1D6SCPrivP7yYVi7nyD6A4vs6HIAul9ujBzcEmZVM3/0NN/yu5nKhmO1wjp5xQ46iRfmDGlOviA==",
+ "dev": true,
+ "dependencies": {
+ "@eslint/eslintrc": "^1.3.0",
+ "@humanwhocodes/config-array": "^0.9.2",
+ "ajv": "^6.10.0",
+ "chalk": "^4.0.0",
+ "cross-spawn": "^7.0.2",
+ "debug": "^4.3.2",
+ "doctrine": "^3.0.0",
+ "escape-string-regexp": "^4.0.0",
+ "eslint-scope": "^7.1.1",
+ "eslint-utils": "^3.0.0",
+ "eslint-visitor-keys": "^3.3.0",
+ "espree": "^9.3.2",
+ "esquery": "^1.4.0",
+ "esutils": "^2.0.2",
+ "fast-deep-equal": "^3.1.3",
+ "file-entry-cache": "^6.0.1",
+ "functional-red-black-tree": "^1.0.1",
+ "glob-parent": "^6.0.1",
+ "globals": "^13.15.0",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.0.0",
+ "imurmurhash": "^0.1.4",
+ "is-glob": "^4.0.0",
+ "js-yaml": "^4.1.0",
+ "json-stable-stringify-without-jsonify": "^1.0.1",
+ "levn": "^0.4.1",
+ "lodash.merge": "^4.6.2",
+ "minimatch": "^3.1.2",
+ "natural-compare": "^1.4.0",
+ "optionator": "^0.9.1",
+ "regexpp": "^3.2.0",
+ "strip-ansi": "^6.0.1",
+ "strip-json-comments": "^3.1.0",
+ "text-table": "^0.2.0",
+ "v8-compile-cache": "^2.0.3"
+ },
+ "bin": {
+ "eslint": "bin/eslint.js"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint-plugin-jsdoc": {
+ "version": "37.9.7",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-37.9.7.tgz",
+ "integrity": "sha512-8alON8yYcStY94o0HycU2zkLKQdcS+qhhOUNQpfONHHwvI99afbmfpYuPqf6PbLz5pLZldG3Te5I0RbAiTN42g==",
+ "dev": true,
+ "dependencies": {
+ "@es-joy/jsdoccomment": "~0.20.1",
+ "comment-parser": "1.3.0",
+ "debug": "^4.3.3",
+ "escape-string-regexp": "^4.0.0",
+ "esquery": "^1.4.0",
+ "regextras": "^0.8.0",
+ "semver": "^7.3.5",
+ "spdx-expression-parse": "^3.0.1"
+ },
+ "engines": {
+ "node": "^12 || ^14 || ^16 || ^17"
+ },
+ "peerDependencies": {
+ "eslint": "^7.0.0 || ^8.0.0"
+ }
+ },
+ "node_modules/eslint-plugin-jsdoc/node_modules/escape-string-regexp": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
+ "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint-plugin-jsdoc/node_modules/semver": {
+ "version": "7.3.7",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz",
+ "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==",
+ "dev": true,
+ "dependencies": {
+ "lru-cache": "^6.0.0"
+ },
+ "bin": {
+ "semver": "bin/semver.js"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/eslint-scope": {
+ "version": "7.1.1",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz",
+ "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==",
+ "dev": true,
+ "dependencies": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
+ "node_modules/eslint-utils": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz",
+ "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==",
+ "dev": true,
+ "dependencies": {
+ "eslint-visitor-keys": "^2.0.0"
+ },
+ "engines": {
+ "node": "^10.0.0 || ^12.0.0 || >= 14.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/mysticatea"
+ },
+ "peerDependencies": {
+ "eslint": ">=5"
+ }
+ },
+ "node_modules/eslint-utils/node_modules/eslint-visitor-keys": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz",
+ "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/eslint-visitor-keys": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz",
+ "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==",
+ "dev": true,
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
+ "node_modules/eslint/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/eslint/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/eslint/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/eslint/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/eslint/node_modules/escape-string-regexp": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
+ "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint/node_modules/globals": {
+ "version": "13.17.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-13.17.0.tgz",
+ "integrity": "sha512-1C+6nQRb1GwGMKm2dH/E7enFAMxGTmGI7/dEdhy/DNelv85w9B72t3uc5frtMNXIbzrarJJ/lTCjcaZwbLJmyw==",
+ "dev": true,
+ "dependencies": {
+ "type-fest": "^0.20.2"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/eslint/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/espree": {
+ "version": "9.3.2",
+ "resolved": "https://registry.npmjs.org/espree/-/espree-9.3.2.tgz",
+ "integrity": "sha512-D211tC7ZwouTIuY5x9XnS0E9sWNChB7IYKX/Xp5eQj3nFXhqmiUDB9q27y76oFl8jTg3pXcQx/bpxMfs3CIZbA==",
+ "dev": true,
+ "dependencies": {
+ "acorn": "^8.7.1",
+ "acorn-jsx": "^5.3.2",
+ "eslint-visitor-keys": "^3.3.0"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
+ "node_modules/esquery": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz",
+ "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==",
+ "dev": true,
+ "dependencies": {
+ "estraverse": "^5.1.0"
+ },
+ "engines": {
+ "node": ">=0.10"
+ }
+ },
+ "node_modules/esrecurse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
+ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
+ "dev": true,
+ "dependencies": {
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estree-walker": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz",
+ "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg=="
+ },
+ "node_modules/esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/eventemitter3": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-3.1.2.tgz",
+ "integrity": "sha512-tvtQIeLVHjDkJYnzf2dgVMxfuSGJeM/7UCG17TT4EumTfNtF+0nebF/4zWOIkCreAbtNqhGEboB6BWrwqNaw4Q==",
+ "dev": true
+ },
+ "node_modules/fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true
+ },
+ "node_modules/fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true
+ },
+ "node_modules/fast-levenshtein": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
+ "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
+ "dev": true
+ },
+ "node_modules/file-entry-cache": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz",
+ "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==",
+ "dev": true,
+ "dependencies": {
+ "flat-cache": "^3.0.4"
+ },
+ "engines": {
+ "node": "^10.12.0 || >=12.0.0"
+ }
+ },
+ "node_modules/fill-range": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
+ "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
+ "dependencies": {
+ "to-regex-range": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/flat-cache": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz",
+ "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==",
+ "dev": true,
+ "dependencies": {
+ "flatted": "^3.1.0",
+ "rimraf": "^3.0.2"
+ },
+ "engines": {
+ "node": "^10.12.0 || >=12.0.0"
+ }
+ },
+ "node_modules/flatted": {
+ "version": "3.2.6",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.6.tgz",
+ "integrity": "sha512-0sQoMh9s0BYsm+12Huy/rkKxVu4R1+r96YX5cG44rHV0pQ6iC3Q+mkoMFaGWObMFYQxCVT+ssG1ksneA2MI9KQ==",
+ "dev": true
+ },
+ "node_modules/fraction.js": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.0.tgz",
+ "integrity": "sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA==",
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "type": "patreon",
+ "url": "https://www.patreon.com/infusion"
+ }
+ },
+ "node_modules/fs.realpath": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
+ "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw=="
+ },
+ "node_modules/fsevents": {
+ "version": "2.3.2",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
+ "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
+ "hasInstallScript": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
+ }
+ },
+ "node_modules/function-bind": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
+ "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A=="
+ },
+ "node_modules/functional-red-black-tree": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz",
+ "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==",
+ "dev": true
+ },
+ "node_modules/generic-names": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/generic-names/-/generic-names-4.0.0.tgz",
+ "integrity": "sha512-ySFolZQfw9FoDb3ed9d80Cm9f0+r7qj+HJkWjeD9RBfpxEVTlVhol+gvaQB/78WbwYfbnNh8nWHHBSlg072y6A==",
+ "dependencies": {
+ "loader-utils": "^3.2.0"
+ }
+ },
+ "node_modules/gensync": {
+ "version": "1.0.0-beta.2",
+ "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
+ "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
+ "devOptional": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/get-intrinsic": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.2.tgz",
+ "integrity": "sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA==",
+ "dev": true,
+ "dependencies": {
+ "function-bind": "^1.1.1",
+ "has": "^1.0.3",
+ "has-symbols": "^1.0.3"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dependencies": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ },
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/glob-parent": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
+ "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
+ "dev": true,
+ "dependencies": {
+ "is-glob": "^4.0.3"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "devOptional": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/graceful-fs": {
+ "version": "4.2.10",
+ "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz",
+ "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA=="
+ },
+ "node_modules/handlebars": {
+ "version": "4.7.7",
+ "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.7.7.tgz",
+ "integrity": "sha512-aAcXm5OAfE/8IXkcZvCepKU3VzW1/39Fb5ZuqMtgI/hT8X2YgoMvBY5dLhq/cpOvw7Lk1nK/UF71aLG/ZnVYRA==",
+ "dev": true,
+ "dependencies": {
+ "minimist": "^1.2.5",
+ "neo-async": "^2.6.0",
+ "source-map": "^0.6.1",
+ "wordwrap": "^1.0.0"
+ },
+ "bin": {
+ "handlebars": "bin/handlebars"
+ },
+ "engines": {
+ "node": ">=0.4.7"
+ },
+ "optionalDependencies": {
+ "uglify-js": "^3.1.4"
+ }
+ },
+ "node_modules/has": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
+ "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
+ "dependencies": {
+ "function-bind": "^1.1.1"
+ },
+ "engines": {
+ "node": ">= 0.4.0"
+ }
+ },
+ "node_modules/has-cors": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/has-cors/-/has-cors-1.1.0.tgz",
+ "integrity": "sha512-g5VNKdkFuUuVCP9gYfDJHjK2nqdQJ7aDLTnycnc2+RvsOQbuLdF5pm7vuE5J76SEBIQjs4kQY/BWq74JUmjbXA==",
+ "dev": true
+ },
+ "node_modules/has-flag": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
+ "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/has-property-descriptors": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz",
+ "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==",
+ "dev": true,
+ "dependencies": {
+ "get-intrinsic": "^1.1.1"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/has-symbols": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
+ "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/icss-replace-symbols": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/icss-replace-symbols/-/icss-replace-symbols-1.1.0.tgz",
+ "integrity": "sha512-chIaY3Vh2mh2Q3RGXttaDIzeiPvaVXJ+C4DAh/w3c37SKZ/U6PGMmuicR2EQQp9bKG8zLMCl7I+PtIoOOPp8Gg=="
+ },
+ "node_modules/icss-utils": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-5.1.0.tgz",
+ "integrity": "sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA==",
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/ignore": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz",
+ "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/immutable": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.1.0.tgz",
+ "integrity": "sha512-oNkuqVTA8jqG1Q6c+UglTOD1xhC1BtjKI7XkCXRkZHrN5m18/XsnUp8Q89GkQO/z+0WjonSvl0FLhDYftp46nQ=="
+ },
+ "node_modules/import-cwd": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/import-cwd/-/import-cwd-3.0.0.tgz",
+ "integrity": "sha512-4pnzH16plW+hgvRECbDWpQl3cqtvSofHWh44met7ESfZ8UZOWWddm8hEyDTqREJ9RbYHY8gi8DqmaelApoOGMg==",
+ "dependencies": {
+ "import-from": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/import-fresh": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
+ "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
+ "dev": true,
+ "dependencies": {
+ "parent-module": "^1.0.0",
+ "resolve-from": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/import-from": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/import-from/-/import-from-3.0.0.tgz",
+ "integrity": "sha512-CiuXOFFSzkU5x/CR0+z7T91Iht4CXgfCxVOFRhh2Zyhg5wOpWvvDLQUsWl+gcN+QscYBjez8hDCt85O7RLDttQ==",
+ "dependencies": {
+ "resolve-from": "^5.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/import-from/node_modules/resolve-from": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz",
+ "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/imurmurhash": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
+ "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8.19"
+ }
+ },
+ "node_modules/inflight": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
+ "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==",
+ "dependencies": {
+ "once": "^1.3.0",
+ "wrappy": "1"
+ }
+ },
+ "node_modules/inherits": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
+ },
+ "node_modules/is-binary-path": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
+ "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
+ "dependencies": {
+ "binary-extensions": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-builtin-module": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-3.1.0.tgz",
+ "integrity": "sha512-OV7JjAgOTfAFJmHZLvpSTb4qi0nIILDV1gWPYDnDJUTNFM5aGlRAhk4QcT8i7TuAleeEV5Fdkqn3t4mS+Q11fg==",
+ "dependencies": {
+ "builtin-modules": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/is-core-module": {
+ "version": "2.9.0",
+ "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz",
+ "integrity": "sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==",
+ "dependencies": {
+ "has": "^1.0.3"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/is-extglob": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-glob": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
+ "dependencies": {
+ "is-extglob": "^2.1.1"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-module": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz",
+ "integrity": "sha512-51ypPSPCoTEIN9dy5Oy+h4pShgJmPCygKfyRCISBI+JoWT/2oJvK8QPxmwv7b/p239jXrm9M1mlQbyKJ5A152g=="
+ },
+ "node_modules/is-number": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
+ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
+ "engines": {
+ "node": ">=0.12.0"
+ }
+ },
+ "node_modules/isexe": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
+ "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
+ "dev": true
+ },
+ "node_modules/ismobilejs": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/ismobilejs/-/ismobilejs-1.1.1.tgz",
+ "integrity": "sha512-VaFW53yt8QO61k2WJui0dHf4SlL8lxBofUuUmwBo0ljPk0Drz2TiuDW4jo3wDcv41qy/SxrJ+VAzJ/qYqsmzRw==",
+ "dev": true
+ },
+ "node_modules/jest-worker": {
+ "version": "26.6.2",
+ "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-26.6.2.tgz",
+ "integrity": "sha512-KWYVV1c4i+jbMpaBC+U++4Va0cp8OisU185o73T1vo99hqi7w8tSJfUXYswwqqrjzwxa6KpRK54WhPvwf5w6PQ==",
+ "dependencies": {
+ "@types/node": "*",
+ "merge-stream": "^2.0.0",
+ "supports-color": "^7.0.0"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ }
+ },
+ "node_modules/jest-worker/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-worker/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/js-tokens": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
+ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ=="
+ },
+ "node_modules/js-yaml": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz",
+ "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
+ "dev": true,
+ "dependencies": {
+ "argparse": "^2.0.1"
+ },
+ "bin": {
+ "js-yaml": "bin/js-yaml.js"
+ }
+ },
+ "node_modules/jsdoc-type-pratt-parser": {
+ "version": "2.2.5",
+ "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-2.2.5.tgz",
+ "integrity": "sha512-2a6eRxSxp1BW040hFvaJxhsCMI9lT8QB8t14t+NY5tC5rckIR0U9cr2tjOeaFirmEOy6MHvmJnY7zTBHq431Lw==",
+ "dev": true,
+ "engines": {
+ "node": ">=12.0.0"
+ }
+ },
+ "node_modules/jsesc": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
+ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
+ "devOptional": true,
+ "bin": {
+ "jsesc": "bin/jsesc"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true
+ },
+ "node_modules/json-stable-stringify-without-jsonify": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
+ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
+ "dev": true
+ },
+ "node_modules/json5": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.1.tgz",
+ "integrity": "sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA==",
+ "devOptional": true,
+ "bin": {
+ "json5": "lib/cli.js"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/kleur": {
+ "version": "4.1.5",
+ "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz",
+ "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/levn": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
+ "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
+ "dev": true,
+ "dependencies": {
+ "prelude-ls": "^1.2.1",
+ "type-check": "~0.4.0"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/lilconfig": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.6.tgz",
+ "integrity": "sha512-9JROoBW7pobfsx+Sq2JsASvCo6Pfo6WWoUW79HuB1BCoBXD4PLWJPqDF6fNj67pqBYTbAHkE57M1kS/+L1neOg==",
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/loader-utils": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-3.2.0.tgz",
+ "integrity": "sha512-HVl9ZqccQihZ7JM85dco1MvO9G+ONvxoGa9rkhzFsneGLKSUg1gJf9bWzhRhcvm2qChhWpebQhP44qxjKIUCaQ==",
+ "engines": {
+ "node": ">= 12.13.0"
+ }
+ },
+ "node_modules/lodash.camelcase": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz",
+ "integrity": "sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA=="
+ },
+ "node_modules/lodash.debounce": {
+ "version": "4.0.8",
+ "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz",
+ "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==",
+ "dev": true
+ },
+ "node_modules/lodash.memoize": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz",
+ "integrity": "sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag=="
+ },
+ "node_modules/lodash.merge": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
+ "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
+ "dev": true
+ },
+ "node_modules/lodash.uniq": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/lodash.uniq/-/lodash.uniq-4.5.0.tgz",
+ "integrity": "sha512-xfBaXQd9ryd9dlSDvnvI0lvxfLJlYAZzXomUYzLKtUeOQvOP5piqAWuGtrhWeqaXK9hhoM/iyJc5AV+XfsX3HQ=="
+ },
+ "node_modules/lru-cache": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
+ "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/magic-string": {
+ "version": "0.26.2",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.26.2.tgz",
+ "integrity": "sha512-NzzlXpclt5zAbmo6h6jNc8zl2gNRGHvmsZW4IvZhTC4W7k4OlLP+S5YLussa/r3ixNT66KOQfNORlXHSOy/X4A==",
+ "dependencies": {
+ "sourcemap-codec": "^1.4.8"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/mdn-data": {
+ "version": "2.0.14",
+ "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.14.tgz",
+ "integrity": "sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow=="
+ },
+ "node_modules/merge-stream": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
+ "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w=="
+ },
+ "node_modules/min-indent": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz",
+ "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/mini-signals": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/mini-signals/-/mini-signals-1.2.0.tgz",
+ "integrity": "sha512-alffqMkGCjjTSwvYMVLx+7QeJ6sTuxbXqBkP21my4iWU5+QpTQAJt3h7htA1OKm9F3BpMM0vnu72QIoiJakrLA==",
+ "dev": true
+ },
+ "node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/minimist": {
+ "version": "1.2.6",
+ "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz",
+ "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q=="
+ },
+ "node_modules/mkdirp": {
+ "version": "0.5.6",
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz",
+ "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==",
+ "dependencies": {
+ "minimist": "^1.2.6"
+ },
+ "bin": {
+ "mkdirp": "bin/cmd.js"
+ }
+ },
+ "node_modules/ms": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
+ "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.4",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz",
+ "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==",
+ "bin": {
+ "nanoid": "bin/nanoid.cjs"
+ },
+ "engines": {
+ "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
+ }
+ },
+ "node_modules/natural-compare": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
+ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
+ "dev": true
+ },
+ "node_modules/neo-async": {
+ "version": "2.6.2",
+ "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz",
+ "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==",
+ "dev": true
+ },
+ "node_modules/node-releases": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.6.tgz",
+ "integrity": "sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg=="
+ },
+ "node_modules/normalize-path": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/normalize-range": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz",
+ "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/normalize-url": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-6.1.0.tgz",
+ "integrity": "sha512-DlL+XwOy3NxAQ8xuC0okPgK46iuVNAK01YN7RueYBqqFeGsBjV9XmCAzAdgt+667bCl5kPh9EqKKDwnaPG1I7A==",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/nth-check": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz",
+ "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==",
+ "dependencies": {
+ "boolbase": "^1.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/nth-check?sponsor=1"
+ }
+ },
+ "node_modules/object-assign": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
+ "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/object-keys": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz",
+ "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.4"
+ }
+ },
+ "node_modules/object.assign": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz",
+ "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==",
+ "dev": true,
+ "dependencies": {
+ "call-bind": "^1.0.0",
+ "define-properties": "^1.1.3",
+ "has-symbols": "^1.0.1",
+ "object-keys": "^1.1.1"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/once": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
+ "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
+ "dependencies": {
+ "wrappy": "1"
+ }
+ },
+ "node_modules/optionator": {
+ "version": "0.9.1",
+ "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz",
+ "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==",
+ "dev": true,
+ "dependencies": {
+ "deep-is": "^0.1.3",
+ "fast-levenshtein": "^2.0.6",
+ "levn": "^0.4.1",
+ "prelude-ls": "^1.2.1",
+ "type-check": "^0.4.0",
+ "word-wrap": "^1.2.3"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/p-finally": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz",
+ "integrity": "sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/p-queue": {
+ "version": "6.6.2",
+ "resolved": "https://registry.npmjs.org/p-queue/-/p-queue-6.6.2.tgz",
+ "integrity": "sha512-RwFpb72c/BhQLEXIZ5K2e+AhgNVmIejGlTgiB9MzZ0e93GRvqZ7uSi0dvRF7/XIXDeNkra2fNHBxTyPDGySpjQ==",
+ "dependencies": {
+ "eventemitter3": "^4.0.4",
+ "p-timeout": "^3.2.0"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-queue/node_modules/eventemitter3": {
+ "version": "4.0.7",
+ "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz",
+ "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw=="
+ },
+ "node_modules/p-timeout": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/p-timeout/-/p-timeout-3.2.0.tgz",
+ "integrity": "sha512-rhIwUycgwwKcP9yTOOFK/AKsAopjjCakVqLHePO3CC6Mir1Z99xT+R63jZxAT5lFZLa2inS5h+ZS2GvR99/FBg==",
+ "dependencies": {
+ "p-finally": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/parent-module": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
+ "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
+ "dev": true,
+ "dependencies": {
+ "callsites": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/parse-uri": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/parse-uri/-/parse-uri-1.0.7.tgz",
+ "integrity": "sha512-eWuZCMKNlVkXrEoANdXxbmqhu2SQO9jUMCSpdbJDObin0JxISn6e400EWsSRbr/czdKvWKkhZnMKEGUwf/Plmg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.10"
+ }
+ },
+ "node_modules/parseqs": {
+ "version": "0.0.6",
+ "resolved": "https://registry.npmjs.org/parseqs/-/parseqs-0.0.6.tgz",
+ "integrity": "sha512-jeAGzMDbfSHHA091hr0r31eYfTig+29g3GKKE/PPbEQ65X0lmMwlEoqmhzu0iztID5uJpZsFlUPDP8ThPL7M8w==",
+ "dev": true
+ },
+ "node_modules/parseuri": {
+ "version": "0.0.6",
+ "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.6.tgz",
+ "integrity": "sha512-AUjen8sAkGgao7UyCX6Ahv0gIK2fABKmYjvP4xmy5JaKvcbTRueIqIPHLAfq30xJddqSE033IOMUSOMCcK3Sow==",
+ "dev": true
+ },
+ "node_modules/path-is-absolute": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
+ "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/path-key": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
+ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-parse": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz",
+ "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw=="
+ },
+ "node_modules/picocolors": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
+ "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ=="
+ },
+ "node_modules/picomatch": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
+ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
+ "engines": {
+ "node": ">=8.6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/jonschlinkert"
+ }
+ },
+ "node_modules/pify": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/pify/-/pify-5.0.0.tgz",
+ "integrity": "sha512-eW/gHNMlxdSP6dmG6uJip6FXN0EQBwm2clYYd8Wul42Cwu/DK8HEftzsapcNdYe2MfLiIwZqsDk2RDEsTE79hA==",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/pixi-particles": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/pixi-particles/-/pixi-particles-4.3.1.tgz",
+ "integrity": "sha512-XSqDFgYwm/7FRCgP5I2Fc57d98qvb1ql/x4uTjdP4uXDUGgjdO8OW/2A0HVWS1CkOht/1x6dQzsM1oCJAUlaow==",
+ "dev": true,
+ "peerDependencies": {
+ "pixi.js": ">=4.0.0"
+ }
+ },
+ "node_modules/pixi.js": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/pixi.js/-/pixi.js-5.3.11.tgz",
+ "integrity": "sha512-/9td6IHDQqG0Po5lyQ5aKDzrnEVD1SvGourI4Nqp0mvNI0Cbm74tMHLjk1V5foqGPAS9pochENr6Y3ft/2cDiQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/accessibility": "5.3.11",
+ "@pixi/app": "5.3.11",
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/extract": "5.3.11",
+ "@pixi/filter-alpha": "5.3.11",
+ "@pixi/filter-blur": "5.3.11",
+ "@pixi/filter-color-matrix": "5.3.11",
+ "@pixi/filter-displacement": "5.3.11",
+ "@pixi/filter-fxaa": "5.3.11",
+ "@pixi/filter-noise": "5.3.11",
+ "@pixi/graphics": "5.3.11",
+ "@pixi/interaction": "5.3.11",
+ "@pixi/loaders": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/mesh": "5.3.11",
+ "@pixi/mesh-extras": "5.3.11",
+ "@pixi/mixin-cache-as-bitmap": "5.3.11",
+ "@pixi/mixin-get-child-by-name": "5.3.11",
+ "@pixi/mixin-get-global-position": "5.3.11",
+ "@pixi/particles": "5.3.11",
+ "@pixi/polyfill": "5.3.11",
+ "@pixi/prepare": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/sprite-animated": "5.3.11",
+ "@pixi/sprite-tiling": "5.3.11",
+ "@pixi/spritesheet": "5.3.11",
+ "@pixi/text": "5.3.11",
+ "@pixi/text-bitmap": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/pixi.js/node_modules/@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "node_modules/pixi.js/node_modules/@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/pixijs"
+ }
+ },
+ "node_modules/pixi.js/node_modules/@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/pixi.js/node_modules/@pixi/graphics": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/graphics/-/graphics-5.3.11.tgz",
+ "integrity": "sha512-HLu53LV6mRlY0uFSIM2OrCuL7xqXzeJs5d2QfmUJfKJVVZ9sbHDS+6/N/f0tXzvkRPYhSKXvcNPsNn4HmlIE9w==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/pixi.js/node_modules/@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "node_modules/pixi.js/node_modules/@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "node_modules/pixi.js/node_modules/@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "dependencies": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "node_modules/pixi.js/node_modules/@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "node_modules/pixi.js/node_modules/@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "node_modules/pixi.js/node_modules/@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "dependencies": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "node_modules/postcss": {
+ "version": "8.4.14",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.14.tgz",
+ "integrity": "sha512-E398TUmfAYFPBSdzgeieK2Y1+1cpdxJx8yXbK/m57nRhKSmk1GB2tO4lbLBtlkfPQTDKfe4Xqv1ASWPpayPEig==",
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/postcss"
+ }
+ ],
+ "dependencies": {
+ "nanoid": "^3.3.4",
+ "picocolors": "^1.0.0",
+ "source-map-js": "^1.0.2"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ }
+ },
+ "node_modules/postcss-attribute-case-insensitive": {
+ "version": "5.0.2",
+ "resolved": "https://registry.npmjs.org/postcss-attribute-case-insensitive/-/postcss-attribute-case-insensitive-5.0.2.tgz",
+ "integrity": "sha512-XIidXV8fDr0kKt28vqki84fRK8VW8eTuIa4PChv2MqKuT6C9UjmSKzen6KaWhWEoYvwxFCa7n/tC1SZ3tyq4SQ==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.10"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-calc": {
+ "version": "8.2.4",
+ "resolved": "https://registry.npmjs.org/postcss-calc/-/postcss-calc-8.2.4.tgz",
+ "integrity": "sha512-SmWMSJmB8MRnnULldx0lQIyhSNvuDl9HfrZkaqqE/WHAhToYsAvDq+yAsA/kIyINDszOp3Rh0GFoNuH5Ypsm3Q==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.9",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.2"
+ }
+ },
+ "node_modules/postcss-clamp": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-clamp/-/postcss-clamp-4.1.0.tgz",
+ "integrity": "sha512-ry4b1Llo/9zz+PKC+030KUnPITTJAHeOwjfAyyB60eT0AorGLdzp52s31OsPRHRf8NchkgFoG2y6fCfn1IV1Ow==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": ">=7.6.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4.6"
+ }
+ },
+ "node_modules/postcss-color-functional-notation": {
+ "version": "4.2.4",
+ "resolved": "https://registry.npmjs.org/postcss-color-functional-notation/-/postcss-color-functional-notation-4.2.4.tgz",
+ "integrity": "sha512-2yrTAUZUab9s6CpxkxC4rVgFEVaR6/2Pipvi6qcgvnYiVqZcbDHEoBDhrXzyb7Efh2CCfHQNtcqWcIruDTIUeg==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-color-hex-alpha": {
+ "version": "8.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-color-hex-alpha/-/postcss-color-hex-alpha-8.0.4.tgz",
+ "integrity": "sha512-nLo2DCRC9eE4w2JmuKgVA3fGL3d01kGq752pVALF68qpGLmx2Qrk91QTKkdUqqp45T1K1XV8IhQpcu1hoAQflQ==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4"
+ }
+ },
+ "node_modules/postcss-color-rebeccapurple": {
+ "version": "7.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-color-rebeccapurple/-/postcss-color-rebeccapurple-7.1.1.tgz",
+ "integrity": "sha512-pGxkuVEInwLHgkNxUc4sdg4g3py7zUeCQ9sMfwyHAT+Ezk8a4OaaVZ8lIY5+oNqA/BXXgLyXv0+5wHP68R79hg==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-colormin": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/postcss-colormin/-/postcss-colormin-5.3.0.tgz",
+ "integrity": "sha512-WdDO4gOFG2Z8n4P8TWBpshnL3JpmNmJwdnfP2gbk2qBA8PWwOYcmjmI/t3CmMeL72a7Hkd+x/Mg9O2/0rD54Pg==",
+ "dependencies": {
+ "browserslist": "^4.16.6",
+ "caniuse-api": "^3.0.0",
+ "colord": "^2.9.1",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-convert-values": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-convert-values/-/postcss-convert-values-5.1.2.tgz",
+ "integrity": "sha512-c6Hzc4GAv95B7suy4udszX9Zy4ETyMCgFPUDtWjdFTKH1SE9eFY/jEpHSwTH1QPuwxHpWslhckUQWbNRM4ho5g==",
+ "dependencies": {
+ "browserslist": "^4.20.3",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-custom-media": {
+ "version": "8.0.2",
+ "resolved": "https://registry.npmjs.org/postcss-custom-media/-/postcss-custom-media-8.0.2.tgz",
+ "integrity": "sha512-7yi25vDAoHAkbhAzX9dHx2yc6ntS4jQvejrNcC+csQJAXjj15e7VcWfMgLqBNAbOvqi5uIa9huOVwdHbf+sKqg==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.3"
+ }
+ },
+ "node_modules/postcss-custom-properties": {
+ "version": "12.1.8",
+ "resolved": "https://registry.npmjs.org/postcss-custom-properties/-/postcss-custom-properties-12.1.8.tgz",
+ "integrity": "sha512-8rbj8kVu00RQh2fQF81oBqtduiANu4MIxhyf0HbbStgPtnFlWn0yiaYTpLHrPnJbffVY1s9apWsIoVZcc68FxA==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4"
+ }
+ },
+ "node_modules/postcss-custom-selectors": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/postcss-custom-selectors/-/postcss-custom-selectors-6.0.3.tgz",
+ "integrity": "sha512-fgVkmyiWDwmD3JbpCmB45SvvlCD6z9CG6Ie6Iere22W5aHea6oWa7EM2bpnv2Fj3I94L3VbtvX9KqwSi5aFzSg==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.4"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.3"
+ }
+ },
+ "node_modules/postcss-dir-pseudo-class": {
+ "version": "6.0.5",
+ "resolved": "https://registry.npmjs.org/postcss-dir-pseudo-class/-/postcss-dir-pseudo-class-6.0.5.tgz",
+ "integrity": "sha512-eqn4m70P031PF7ZQIvSgy9RSJ5uI2171O/OO/zcRNYpJbvaeKFUlar1aJ7rmgiQtbm0FSPsRewjpdS0Oew7MPA==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.10"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-discard-comments": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-5.1.2.tgz",
+ "integrity": "sha512-+L8208OVbHVF2UQf1iDmRcbdjJkuBF6IS29yBDSiWUIzpYaAhtNl6JYnYm12FnkeCwQqF5LeklOu6rAqgfBZqQ==",
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-discard-duplicates": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-5.1.0.tgz",
+ "integrity": "sha512-zmX3IoSI2aoenxHV6C7plngHWWhUOV3sP1T8y2ifzxzbtnuhk1EdPwm0S1bIUNaJ2eNbWeGLEwzw8huPD67aQw==",
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-discard-empty": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-5.1.1.tgz",
+ "integrity": "sha512-zPz4WljiSuLWsI0ir4Mcnr4qQQ5e1Ukc3i7UfE2XcrwKK2LIPIqE5jxMRxO6GbI3cv//ztXDsXwEWT3BHOGh3A==",
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-discard-overridden": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-5.1.0.tgz",
+ "integrity": "sha512-21nOL7RqWR1kasIVdKs8HNqQJhFxLsyRfAnUDm4Fe4t4mCWL9OJiHvlHPjcd8zc5Myu89b/7wZDnOSjFgeWRtw==",
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-double-position-gradients": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-double-position-gradients/-/postcss-double-position-gradients-3.1.2.tgz",
+ "integrity": "sha512-GX+FuE/uBR6eskOK+4vkXgT6pDkexLokPaz/AbJna9s5Kzp/yl488pKPjhy0obB475ovfT1Wv8ho7U/cHNaRgQ==",
+ "dependencies": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-env-function": {
+ "version": "4.0.6",
+ "resolved": "https://registry.npmjs.org/postcss-env-function/-/postcss-env-function-4.0.6.tgz",
+ "integrity": "sha512-kpA6FsLra+NqcFnL81TnsU+Z7orGtDTxcOhl6pwXeEq1yFPpRMkCDpHhrz8CFQDr/Wfm0jLiNQ1OsGGPjlqPwA==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4"
+ }
+ },
+ "node_modules/postcss-focus-visible": {
+ "version": "6.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-focus-visible/-/postcss-focus-visible-6.0.4.tgz",
+ "integrity": "sha512-QcKuUU/dgNsstIK6HELFRT5Y3lbrMLEOwG+A4s5cA+fx3A3y/JTq3X9LaOj3OC3ALH0XqyrgQIgey/MIZ8Wczw==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.9"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4"
+ }
+ },
+ "node_modules/postcss-focus-within": {
+ "version": "5.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-focus-within/-/postcss-focus-within-5.0.4.tgz",
+ "integrity": "sha512-vvjDN++C0mu8jz4af5d52CB184ogg/sSxAFS+oUJQq2SuCe7T5U2iIsVJtsCp2d6R4j0jr5+q3rPkBVZkXD9fQ==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.9"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4"
+ }
+ },
+ "node_modules/postcss-font-variant": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-font-variant/-/postcss-font-variant-5.0.0.tgz",
+ "integrity": "sha512-1fmkBaCALD72CK2a9i468mA/+tr9/1cBxRRMXOUaZqO43oWPR5imcyPjXwuv7PXbCid4ndlP5zWhidQVVa3hmA==",
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-gap-properties": {
+ "version": "3.0.5",
+ "resolved": "https://registry.npmjs.org/postcss-gap-properties/-/postcss-gap-properties-3.0.5.tgz",
+ "integrity": "sha512-IuE6gKSdoUNcvkGIqdtjtcMtZIFyXZhmFd5RUlg97iVEvp1BZKV5ngsAjCjrVy+14uhGBQl9tzmi1Qwq4kqVOg==",
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-image-set-function": {
+ "version": "4.0.7",
+ "resolved": "https://registry.npmjs.org/postcss-image-set-function/-/postcss-image-set-function-4.0.7.tgz",
+ "integrity": "sha512-9T2r9rsvYzm5ndsBE8WgtrMlIT7VbtTfE7b3BQnudUqnBcBo7L758oc+o+pdj/dUV0l5wjwSdjeOH2DZtfv8qw==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-initial": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/postcss-initial/-/postcss-initial-4.0.1.tgz",
+ "integrity": "sha512-0ueD7rPqX8Pn1xJIjay0AZeIuDoF+V+VvMt/uOnn+4ezUKhZM/NokDeP6DwMNyIoYByuN/94IQnt5FEkaN59xQ==",
+ "peerDependencies": {
+ "postcss": "^8.0.0"
+ }
+ },
+ "node_modules/postcss-lab-function": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmjs.org/postcss-lab-function/-/postcss-lab-function-4.2.1.tgz",
+ "integrity": "sha512-xuXll4isR03CrQsmxyz92LJB2xX9n+pZJ5jE9JgcnmsCammLyKdlzrBin+25dy6wIjfhJpKBAN80gsTlCgRk2w==",
+ "dependencies": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-load-config": {
+ "version": "3.1.4",
+ "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-3.1.4.tgz",
+ "integrity": "sha512-6DiM4E7v4coTE4uzA8U//WhtPwyhiim3eyjEMFCnUpzbrkK9wJHgKDT2mR+HbtSrd/NubVaYTOpSpjUl8NQeRg==",
+ "dependencies": {
+ "lilconfig": "^2.0.5",
+ "yaml": "^1.10.2"
+ },
+ "engines": {
+ "node": ">= 10"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ "peerDependencies": {
+ "postcss": ">=8.0.9",
+ "ts-node": ">=9.0.0"
+ },
+ "peerDependenciesMeta": {
+ "postcss": {
+ "optional": true
+ },
+ "ts-node": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/postcss-logical": {
+ "version": "5.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-logical/-/postcss-logical-5.0.4.tgz",
+ "integrity": "sha512-RHXxplCeLh9VjinvMrZONq7im4wjWGlRJAqmAVLXyZaXwfDWP73/oq4NdIp+OZwhQUMj0zjqDfM5Fj7qby+B4g==",
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "peerDependencies": {
+ "postcss": "^8.4"
+ }
+ },
+ "node_modules/postcss-media-minmax": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-media-minmax/-/postcss-media-minmax-5.0.0.tgz",
+ "integrity": "sha512-yDUvFf9QdFZTuCUg0g0uNSHVlJ5X1lSzDZjPSFaiCWvjgsvu8vEVxtahPrLMinIDEEGnx6cBe6iqdx5YWz08wQ==",
+ "engines": {
+ "node": ">=10.0.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-merge-longhand": {
+ "version": "5.1.6",
+ "resolved": "https://registry.npmjs.org/postcss-merge-longhand/-/postcss-merge-longhand-5.1.6.tgz",
+ "integrity": "sha512-6C/UGF/3T5OE2CEbOuX7iNO63dnvqhGZeUnKkDeifebY0XqkkvrctYSZurpNE902LDf2yKwwPFgotnfSoPhQiw==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0",
+ "stylehacks": "^5.1.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-merge-rules": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-merge-rules/-/postcss-merge-rules-5.1.2.tgz",
+ "integrity": "sha512-zKMUlnw+zYCWoPN6yhPjtcEdlJaMUZ0WyVcxTAmw3lkkN/NDMRkOkiuctQEoWAOvH7twaxUUdvBWl0d4+hifRQ==",
+ "dependencies": {
+ "browserslist": "^4.16.6",
+ "caniuse-api": "^3.0.0",
+ "cssnano-utils": "^3.1.0",
+ "postcss-selector-parser": "^6.0.5"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-minify-font-values": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-minify-font-values/-/postcss-minify-font-values-5.1.0.tgz",
+ "integrity": "sha512-el3mYTgx13ZAPPirSVsHqFzl+BBBDrXvbySvPGFnQcTI4iNslrPaFq4muTkLZmKlGk4gyFAYUBMH30+HurREyA==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-minify-gradients": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-minify-gradients/-/postcss-minify-gradients-5.1.1.tgz",
+ "integrity": "sha512-VGvXMTpCEo4qHTNSa9A0a3D+dxGFZCYwR6Jokk+/3oB6flu2/PnPXAh2x7x52EkY5xlIHLm+Le8tJxe/7TNhzw==",
+ "dependencies": {
+ "colord": "^2.9.1",
+ "cssnano-utils": "^3.1.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-minify-params": {
+ "version": "5.1.3",
+ "resolved": "https://registry.npmjs.org/postcss-minify-params/-/postcss-minify-params-5.1.3.tgz",
+ "integrity": "sha512-bkzpWcjykkqIujNL+EVEPOlLYi/eZ050oImVtHU7b4lFS82jPnsCb44gvC6pxaNt38Els3jWYDHTjHKf0koTgg==",
+ "dependencies": {
+ "browserslist": "^4.16.6",
+ "cssnano-utils": "^3.1.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-minify-selectors": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmjs.org/postcss-minify-selectors/-/postcss-minify-selectors-5.2.1.tgz",
+ "integrity": "sha512-nPJu7OjZJTsVUmPdm2TcaiohIwxP+v8ha9NehQ2ye9szv4orirRU3SDdtUmKH+10nzn0bAyOXZ0UEr7OpvLehg==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.5"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-modules": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/postcss-modules/-/postcss-modules-4.3.1.tgz",
+ "integrity": "sha512-ItUhSUxBBdNamkT3KzIZwYNNRFKmkJrofvC2nWab3CPKhYBQ1f27XXh1PAPE27Psx58jeelPsxWB/+og+KEH0Q==",
+ "dependencies": {
+ "generic-names": "^4.0.0",
+ "icss-replace-symbols": "^1.1.0",
+ "lodash.camelcase": "^4.3.0",
+ "postcss-modules-extract-imports": "^3.0.0",
+ "postcss-modules-local-by-default": "^4.0.0",
+ "postcss-modules-scope": "^3.0.0",
+ "postcss-modules-values": "^4.0.0",
+ "string-hash": "^1.1.1"
+ },
+ "peerDependencies": {
+ "postcss": "^8.0.0"
+ }
+ },
+ "node_modules/postcss-modules-extract-imports": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz",
+ "integrity": "sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw==",
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-modules-local-by-default": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.0.tgz",
+ "integrity": "sha512-sT7ihtmGSF9yhm6ggikHdV0hlziDTX7oFoXtuVWeDd3hHObNkcHRo9V3yg7vCAY7cONyxJC/XXCmmiHHcvX7bQ==",
+ "dependencies": {
+ "icss-utils": "^5.0.0",
+ "postcss-selector-parser": "^6.0.2",
+ "postcss-value-parser": "^4.1.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-modules-scope": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz",
+ "integrity": "sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.4"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-modules-values": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-4.0.0.tgz",
+ "integrity": "sha512-RDxHkAiEGI78gS2ofyvCsu7iycRv7oqw5xMWn9iMoR0N/7mf9D50ecQqUo5BZ9Zh2vH4bCUR/ktCqbB9m8vJjQ==",
+ "dependencies": {
+ "icss-utils": "^5.0.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-nesting": {
+ "version": "10.1.10",
+ "resolved": "https://registry.npmjs.org/postcss-nesting/-/postcss-nesting-10.1.10.tgz",
+ "integrity": "sha512-lqd7LXCq0gWc0wKXtoKDru5wEUNjm3OryLVNRZ8OnW8km6fSNUuFrjEhU3nklxXE2jvd4qrox566acgh+xQt8w==",
+ "dependencies": {
+ "@csstools/selector-specificity": "^2.0.0",
+ "postcss-selector-parser": "^6.0.10"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-normalize-charset": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-5.1.0.tgz",
+ "integrity": "sha512-mSgUJ+pd/ldRGVx26p2wz9dNZ7ji6Pn8VWBajMXFf8jk7vUoSrZ2lt/wZR7DtlZYKesmZI680qjr2CeFF2fbUg==",
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-normalize-display-values": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-display-values/-/postcss-normalize-display-values-5.1.0.tgz",
+ "integrity": "sha512-WP4KIM4o2dazQXWmFaqMmcvsKmhdINFblgSeRgn8BJ6vxaMyaJkwAzpPpuvSIoG/rmX3M+IrRZEz2H0glrQNEA==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-normalize-positions": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-positions/-/postcss-normalize-positions-5.1.1.tgz",
+ "integrity": "sha512-6UpCb0G4eofTCQLFVuI3EVNZzBNPiIKcA1AKVka+31fTVySphr3VUgAIULBhxZkKgwLImhzMR2Bw1ORK+37INg==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-normalize-repeat-style": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-5.1.1.tgz",
+ "integrity": "sha512-mFpLspGWkQtBcWIRFLmewo8aC3ImN2i/J3v8YCFUwDnPu3Xz4rLohDO26lGjwNsQxB3YF0KKRwspGzE2JEuS0g==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-normalize-string": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-string/-/postcss-normalize-string-5.1.0.tgz",
+ "integrity": "sha512-oYiIJOf4T9T1N4i+abeIc7Vgm/xPCGih4bZz5Nm0/ARVJ7K6xrDlLwvwqOydvyL3RHNf8qZk6vo3aatiw/go3w==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-normalize-timing-functions": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-5.1.0.tgz",
+ "integrity": "sha512-DOEkzJ4SAXv5xkHl0Wa9cZLF3WCBhF3o1SKVxKQAa+0pYKlueTpCgvkFAHfk+Y64ezX9+nITGrDZeVGgITJXjg==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-normalize-unicode": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-unicode/-/postcss-normalize-unicode-5.1.0.tgz",
+ "integrity": "sha512-J6M3MizAAZ2dOdSjy2caayJLQT8E8K9XjLce8AUQMwOrCvjCHv24aLC/Lps1R1ylOfol5VIDMaM/Lo9NGlk1SQ==",
+ "dependencies": {
+ "browserslist": "^4.16.6",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-normalize-url": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-url/-/postcss-normalize-url-5.1.0.tgz",
+ "integrity": "sha512-5upGeDO+PVthOxSmds43ZeMeZfKH+/DKgGRD7TElkkyS46JXAUhMzIKiCa7BabPeIy3AQcTkXwVVN7DbqsiCew==",
+ "dependencies": {
+ "normalize-url": "^6.0.1",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-normalize-whitespace": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-whitespace/-/postcss-normalize-whitespace-5.1.1.tgz",
+ "integrity": "sha512-83ZJ4t3NUDETIHTa3uEg6asWjSBYL5EdkVB0sDncx9ERzOKBVJIUeDO9RyA9Zwtig8El1d79HBp0JEi8wvGQnA==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-opacity-percentage": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-opacity-percentage/-/postcss-opacity-percentage-1.1.2.tgz",
+ "integrity": "sha512-lyUfF7miG+yewZ8EAk9XUBIlrHyUE6fijnesuz+Mj5zrIHIEw6KcIZSOk/elVMqzLvREmXB83Zi/5QpNRYd47w==",
+ "funding": [
+ {
+ "type": "kofi",
+ "url": "https://ko-fi.com/mrcgrtz"
+ },
+ {
+ "type": "liberapay",
+ "url": "https://liberapay.com/mrcgrtz"
+ }
+ ],
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ }
+ },
+ "node_modules/postcss-ordered-values": {
+ "version": "5.1.3",
+ "resolved": "https://registry.npmjs.org/postcss-ordered-values/-/postcss-ordered-values-5.1.3.tgz",
+ "integrity": "sha512-9UO79VUhPwEkzbb3RNpqqghc6lcYej1aveQteWY+4POIwlqkYE21HKWaLDF6lWNuqCobEAyTovVhtI32Rbv2RQ==",
+ "dependencies": {
+ "cssnano-utils": "^3.1.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-overflow-shorthand": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-overflow-shorthand/-/postcss-overflow-shorthand-3.0.4.tgz",
+ "integrity": "sha512-otYl/ylHK8Y9bcBnPLo3foYFLL6a6Ak+3EQBPOTR7luMYCOsiVTUk1iLvNf6tVPNGXcoL9Hoz37kpfriRIFb4A==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-page-break": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-page-break/-/postcss-page-break-3.0.4.tgz",
+ "integrity": "sha512-1JGu8oCjVXLa9q9rFTo4MbeeA5FMe00/9C7lN4va606Rdb+HkxXtXsmEDrIraQ11fGz/WvKWa8gMuCKkrXpTsQ==",
+ "peerDependencies": {
+ "postcss": "^8"
+ }
+ },
+ "node_modules/postcss-place": {
+ "version": "7.0.5",
+ "resolved": "https://registry.npmjs.org/postcss-place/-/postcss-place-7.0.5.tgz",
+ "integrity": "sha512-wR8igaZROA6Z4pv0d+bvVrvGY4GVHihBCBQieXFY3kuSuMyOmEnnfFzHl/tQuqHZkfkIVBEbDvYcFfHmpSet9g==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-preset-env": {
+ "version": "7.7.2",
+ "resolved": "https://registry.npmjs.org/postcss-preset-env/-/postcss-preset-env-7.7.2.tgz",
+ "integrity": "sha512-1q0ih7EDsZmCb/FMDRvosna7Gsbdx8CvYO5hYT120hcp2ZAuOHpSzibujZ4JpIUcAC02PG6b+eftxqjTFh5BNA==",
+ "dependencies": {
+ "@csstools/postcss-cascade-layers": "^1.0.4",
+ "@csstools/postcss-color-function": "^1.1.0",
+ "@csstools/postcss-font-format-keywords": "^1.0.0",
+ "@csstools/postcss-hwb-function": "^1.0.1",
+ "@csstools/postcss-ic-unit": "^1.0.0",
+ "@csstools/postcss-is-pseudo-class": "^2.0.6",
+ "@csstools/postcss-normalize-display-values": "^1.0.0",
+ "@csstools/postcss-oklab-function": "^1.1.0",
+ "@csstools/postcss-progressive-custom-properties": "^1.3.0",
+ "@csstools/postcss-stepped-value-functions": "^1.0.0",
+ "@csstools/postcss-trigonometric-functions": "^1.0.1",
+ "@csstools/postcss-unset-value": "^1.0.1",
+ "autoprefixer": "^10.4.7",
+ "browserslist": "^4.21.0",
+ "css-blank-pseudo": "^3.0.3",
+ "css-has-pseudo": "^3.0.4",
+ "css-prefers-color-scheme": "^6.0.3",
+ "cssdb": "^6.6.3",
+ "postcss-attribute-case-insensitive": "^5.0.1",
+ "postcss-clamp": "^4.1.0",
+ "postcss-color-functional-notation": "^4.2.3",
+ "postcss-color-hex-alpha": "^8.0.4",
+ "postcss-color-rebeccapurple": "^7.1.0",
+ "postcss-custom-media": "^8.0.2",
+ "postcss-custom-properties": "^12.1.8",
+ "postcss-custom-selectors": "^6.0.3",
+ "postcss-dir-pseudo-class": "^6.0.4",
+ "postcss-double-position-gradients": "^3.1.1",
+ "postcss-env-function": "^4.0.6",
+ "postcss-focus-visible": "^6.0.4",
+ "postcss-focus-within": "^5.0.4",
+ "postcss-font-variant": "^5.0.0",
+ "postcss-gap-properties": "^3.0.3",
+ "postcss-image-set-function": "^4.0.6",
+ "postcss-initial": "^4.0.1",
+ "postcss-lab-function": "^4.2.0",
+ "postcss-logical": "^5.0.4",
+ "postcss-media-minmax": "^5.0.0",
+ "postcss-nesting": "^10.1.9",
+ "postcss-opacity-percentage": "^1.1.2",
+ "postcss-overflow-shorthand": "^3.0.3",
+ "postcss-page-break": "^3.0.4",
+ "postcss-place": "^7.0.4",
+ "postcss-pseudo-class-any-link": "^7.1.5",
+ "postcss-replace-overflow-wrap": "^4.0.0",
+ "postcss-selector-not": "^6.0.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-pseudo-class-any-link": {
+ "version": "7.1.6",
+ "resolved": "https://registry.npmjs.org/postcss-pseudo-class-any-link/-/postcss-pseudo-class-any-link-7.1.6.tgz",
+ "integrity": "sha512-9sCtZkO6f/5ML9WcTLcIyV1yz9D1rf0tWc+ulKcvV30s0iZKS/ONyETvoWsr6vnrmW+X+KmuK3gV/w5EWnT37w==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.10"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-reduce-initial": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-reduce-initial/-/postcss-reduce-initial-5.1.0.tgz",
+ "integrity": "sha512-5OgTUviz0aeH6MtBjHfbr57tml13PuedK/Ecg8szzd4XRMbYxH4572JFG067z+FqBIf6Zp/d+0581glkvvWMFw==",
+ "dependencies": {
+ "browserslist": "^4.16.6",
+ "caniuse-api": "^3.0.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-reduce-transforms": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-reduce-transforms/-/postcss-reduce-transforms-5.1.0.tgz",
+ "integrity": "sha512-2fbdbmgir5AvpW9RLtdONx1QoYG2/EtqpNQbFASDlixBbAYuTcJ0dECwlqNqH7VbaUnEnh8SrxOe2sRIn24XyQ==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-replace-overflow-wrap": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-replace-overflow-wrap/-/postcss-replace-overflow-wrap-4.0.0.tgz",
+ "integrity": "sha512-KmF7SBPphT4gPPcKZc7aDkweHiKEEO8cla/GjcBK+ckKxiZslIu3C4GCRW3DNfL0o7yW7kMQu9xlZ1kXRXLXtw==",
+ "peerDependencies": {
+ "postcss": "^8.0.3"
+ }
+ },
+ "node_modules/postcss-selector-not": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/postcss-selector-not/-/postcss-selector-not-6.0.1.tgz",
+ "integrity": "sha512-1i9affjAe9xu/y9uqWH+tD4r6/hDaXJruk8xn2x1vzxC2U3J3LKO3zJW4CyxlNhA56pADJ/djpEwpH1RClI2rQ==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.10"
+ },
+ "engines": {
+ "node": "^12 || ^14 || >=16"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/csstools"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2"
+ }
+ },
+ "node_modules/postcss-selector-parser": {
+ "version": "6.0.10",
+ "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.10.tgz",
+ "integrity": "sha512-IQ7TZdoaqbT+LCpShg46jnZVlhWD2w6iQYAcYXfHARZ7X1t/UGhhceQDs5X0cGqKvYlHNOuv7Oa1xmb0oQuA3w==",
+ "dependencies": {
+ "cssesc": "^3.0.0",
+ "util-deprecate": "^1.0.2"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/postcss-svgo": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-svgo/-/postcss-svgo-5.1.0.tgz",
+ "integrity": "sha512-D75KsH1zm5ZrHyxPakAxJWtkyXew5qwS70v56exwvw542d9CRtTo78K0WeFxZB4G7JXKKMbEZtZayTGdIky/eA==",
+ "dependencies": {
+ "postcss-value-parser": "^4.2.0",
+ "svgo": "^2.7.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-unique-selectors": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-unique-selectors/-/postcss-unique-selectors-5.1.1.tgz",
+ "integrity": "sha512-5JiODlELrz8L2HwxfPnhOWZYWDxVHWL83ufOv84NrcgipI7TaeRsatAhK4Tr2/ZiYldpK/wBvw5BD3qfaK96GA==",
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.5"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/postcss-value-parser": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz",
+ "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ=="
+ },
+ "node_modules/prelude-ls": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
+ "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/promise.series": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/promise.series/-/promise.series-0.2.0.tgz",
+ "integrity": "sha512-VWQJyU2bcDTgZw8kpfBpB/ejZASlCrzwz5f2hjb/zlujOEB4oeiAhHygAWq8ubsX2GVkD4kCU5V2dwOTaCY5EQ==",
+ "engines": {
+ "node": ">=0.12"
+ }
+ },
+ "node_modules/punycode": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz",
+ "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/querystring": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz",
+ "integrity": "sha512-X/xY82scca2tau62i9mDyU9K+I+djTMUsvwf7xnUX5GLvVzgJybOJf4Y6o9Zx3oJK/LSXg5tTZBjwzqVPaPO2g==",
+ "deprecated": "The querystring API is considered Legacy. new code should use the URLSearchParams API instead.",
+ "dev": true,
+ "engines": {
+ "node": ">=0.4.x"
+ }
+ },
+ "node_modules/randombytes": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz",
+ "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==",
+ "dependencies": {
+ "safe-buffer": "^5.1.0"
+ }
+ },
+ "node_modules/readdirp": {
+ "version": "3.6.0",
+ "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
+ "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
+ "dependencies": {
+ "picomatch": "^2.2.1"
+ },
+ "engines": {
+ "node": ">=8.10.0"
+ }
+ },
+ "node_modules/regenerate": {
+ "version": "1.4.2",
+ "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz",
+ "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==",
+ "dev": true
+ },
+ "node_modules/regenerate-unicode-properties": {
+ "version": "10.0.1",
+ "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.0.1.tgz",
+ "integrity": "sha512-vn5DU6yg6h8hP/2OkQo3K7uVILvY4iu0oI4t3HFa81UPkhGJwkRwM10JEc3upjdhHjs/k8GJY1sRBhk5sr69Bw==",
+ "dev": true,
+ "dependencies": {
+ "regenerate": "^1.4.2"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/regenerator-runtime": {
+ "version": "0.13.9",
+ "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz",
+ "integrity": "sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA==",
+ "dev": true
+ },
+ "node_modules/regenerator-transform": {
+ "version": "0.15.0",
+ "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.0.tgz",
+ "integrity": "sha512-LsrGtPmbYg19bcPHwdtmXwbW+TqNvtY4riE3P83foeHRroMbH6/2ddFBfab3t7kbzc7v7p4wbkIecHImqt0QNg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/runtime": "^7.8.4"
+ }
+ },
+ "node_modules/regexpp": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz",
+ "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/mysticatea"
+ }
+ },
+ "node_modules/regexpu-core": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.1.0.tgz",
+ "integrity": "sha512-bb6hk+xWd2PEOkj5It46A16zFMs2mv86Iwpdu94la4S3sJ7C973h2dHpYKwIBGaWSO7cIRJ+UX0IeMaWcO4qwA==",
+ "dev": true,
+ "dependencies": {
+ "regenerate": "^1.4.2",
+ "regenerate-unicode-properties": "^10.0.1",
+ "regjsgen": "^0.6.0",
+ "regjsparser": "^0.8.2",
+ "unicode-match-property-ecmascript": "^2.0.0",
+ "unicode-match-property-value-ecmascript": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/regextras": {
+ "version": "0.8.0",
+ "resolved": "https://registry.npmjs.org/regextras/-/regextras-0.8.0.tgz",
+ "integrity": "sha512-k519uI04Z3SaY0fLX843MRXnDeG2+vHOFsyhiPZvNLe7r8rD2YNRjq4BQLZZ0oAr2NrtvZlICsXysGNFPGa3CQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.1.14"
+ }
+ },
+ "node_modules/regjsgen": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.6.0.tgz",
+ "integrity": "sha512-ozE883Uigtqj3bx7OhL1KNbCzGyW2NQZPl6Hs09WTvCuZD5sTI4JY58bkbQWa/Y9hxIsvJ3M8Nbf7j54IqeZbA==",
+ "dev": true
+ },
+ "node_modules/regjsparser": {
+ "version": "0.8.4",
+ "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.8.4.tgz",
+ "integrity": "sha512-J3LABycON/VNEu3abOviqGHuB/LOtOQj8SKmfP9anY5GfAVw/SPjwzSjxGjbZXIxbGfqTHtJw58C2Li/WkStmA==",
+ "dev": true,
+ "dependencies": {
+ "jsesc": "~0.5.0"
+ },
+ "bin": {
+ "regjsparser": "bin/parser"
+ }
+ },
+ "node_modules/regjsparser/node_modules/jsesc": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz",
+ "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==",
+ "dev": true,
+ "bin": {
+ "jsesc": "bin/jsesc"
+ }
+ },
+ "node_modules/require-relative": {
+ "version": "0.8.7",
+ "resolved": "https://registry.npmjs.org/require-relative/-/require-relative-0.8.7.tgz",
+ "integrity": "sha512-AKGr4qvHiryxRb19m3PsLRGuKVAbJLUD7E6eOaHkfKhwc+vSgVOCY5xNvm9EkolBKTOf0GrQAZKLimOCz81Khg=="
+ },
+ "node_modules/resolve": {
+ "version": "1.22.1",
+ "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz",
+ "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==",
+ "dependencies": {
+ "is-core-module": "^2.9.0",
+ "path-parse": "^1.0.7",
+ "supports-preserve-symlinks-flag": "^1.0.0"
+ },
+ "bin": {
+ "resolve": "bin/resolve"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/resolve-from": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
+ "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/resource-loader": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/resource-loader/-/resource-loader-3.0.1.tgz",
+ "integrity": "sha512-fBuCRbEHdLCI1eglzQhUv9Rrdcmqkydr1r6uHE2cYHvRBrcLXeSmbE/qI/urFt8rPr/IGxir3BUwM5kUK8XoyA==",
+ "dev": true,
+ "dependencies": {
+ "mini-signals": "^1.2.0",
+ "parse-uri": "^1.0.0"
+ }
+ },
+ "node_modules/rimraf": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
+ "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
+ "dev": true,
+ "dependencies": {
+ "glob": "^7.1.3"
+ },
+ "bin": {
+ "rimraf": "bin.js"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/rollup": {
+ "version": "2.77.0",
+ "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.77.0.tgz",
+ "integrity": "sha512-vL8xjY4yOQEw79DvyXLijhnhh+R/O9zpF/LEgkCebZFtb6ELeN9H3/2T0r8+mp+fFTBHZ5qGpOpW2ela2zRt3g==",
+ "bin": {
+ "rollup": "dist/bin/rollup"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ }
+ },
+ "node_modules/rollup-plugin-postcss": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/rollup-plugin-postcss/-/rollup-plugin-postcss-4.0.2.tgz",
+ "integrity": "sha512-05EaY6zvZdmvPUDi3uCcAQoESDcYnv8ogJJQRp6V5kZ6J6P7uAVJlrTZcaaA20wTH527YTnKfkAoPxWI/jPp4w==",
+ "dependencies": {
+ "chalk": "^4.1.0",
+ "concat-with-sourcemaps": "^1.1.0",
+ "cssnano": "^5.0.1",
+ "import-cwd": "^3.0.0",
+ "p-queue": "^6.6.2",
+ "pify": "^5.0.0",
+ "postcss-load-config": "^3.0.0",
+ "postcss-modules": "^4.0.0",
+ "promise.series": "^0.2.0",
+ "resolve": "^1.19.0",
+ "rollup-pluginutils": "^2.8.2",
+ "safe-identifier": "^0.4.2",
+ "style-inject": "^0.3.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "postcss": "8.x"
+ }
+ },
+ "node_modules/rollup-plugin-postcss/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/rollup-plugin-postcss/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/rollup-plugin-postcss/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/rollup-plugin-postcss/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA=="
+ },
+ "node_modules/rollup-plugin-postcss/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/rollup-plugin-postcss/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/rollup-plugin-sourcemaps": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/rollup-plugin-sourcemaps/-/rollup-plugin-sourcemaps-0.6.3.tgz",
+ "integrity": "sha512-paFu+nT1xvuO1tPFYXGe+XnQvg4Hjqv/eIhG8i5EspfYYPBKL57X7iVbfv55aNVASg3dzWvES9dmWsL2KhfByw==",
+ "dependencies": {
+ "@rollup/pluginutils": "^3.0.9",
+ "source-map-resolve": "^0.6.0"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ },
+ "peerDependencies": {
+ "@types/node": ">=10.0.0",
+ "rollup": ">=0.31.2"
+ },
+ "peerDependenciesMeta": {
+ "@types/node": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/rollup-plugin-svelte": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/rollup-plugin-svelte/-/rollup-plugin-svelte-7.1.0.tgz",
+ "integrity": "sha512-vopCUq3G+25sKjwF5VilIbiY6KCuMNHP1PFvx2Vr3REBNMDllKHFZN2B9jwwC+MqNc3UPKkjXnceLPEjTjXGXg==",
+ "dependencies": {
+ "require-relative": "^0.8.7",
+ "rollup-pluginutils": "^2.8.2"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "rollup": ">=2.0.0",
+ "svelte": ">=3.5.0"
+ }
+ },
+ "node_modules/rollup-plugin-terser": {
+ "version": "7.0.2",
+ "resolved": "https://registry.npmjs.org/rollup-plugin-terser/-/rollup-plugin-terser-7.0.2.tgz",
+ "integrity": "sha512-w3iIaU4OxcF52UUXiZNsNeuXIMDvFrr+ZXK6bFZ0Q60qyVfq4uLptoS4bbq3paG3x216eQllFZX7zt6TIImguQ==",
+ "dependencies": {
+ "@babel/code-frame": "^7.10.4",
+ "jest-worker": "^26.2.1",
+ "serialize-javascript": "^4.0.0",
+ "terser": "^5.0.0"
+ },
+ "peerDependencies": {
+ "rollup": "^2.0.0"
+ }
+ },
+ "node_modules/rollup-pluginutils": {
+ "version": "2.8.2",
+ "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz",
+ "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==",
+ "dependencies": {
+ "estree-walker": "^0.6.1"
+ }
+ },
+ "node_modules/rollup-pluginutils/node_modules/estree-walker": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz",
+ "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w=="
+ },
+ "node_modules/safe-buffer": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
+ },
+ "node_modules/safe-identifier": {
+ "version": "0.4.2",
+ "resolved": "https://registry.npmjs.org/safe-identifier/-/safe-identifier-0.4.2.tgz",
+ "integrity": "sha512-6pNbSMW6OhAi9j+N8V+U715yBQsaWJ7eyEUaOrawX+isg5ZxhUlV1NipNtgaKHmFGiABwt+ZF04Ii+3Xjkg+8w=="
+ },
+ "node_modules/sander": {
+ "version": "0.5.1",
+ "resolved": "https://registry.npmjs.org/sander/-/sander-0.5.1.tgz",
+ "integrity": "sha512-3lVqBir7WuKDHGrKRDn/1Ye3kwpXaDOMsiRP1wd6wpZW56gJhsbp5RqQpA6JG/P+pkXizygnr1dKR8vzWaVsfA==",
+ "dependencies": {
+ "es6-promise": "^3.1.2",
+ "graceful-fs": "^4.1.3",
+ "mkdirp": "^0.5.1",
+ "rimraf": "^2.5.2"
+ }
+ },
+ "node_modules/sander/node_modules/rimraf": {
+ "version": "2.7.1",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz",
+ "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==",
+ "dependencies": {
+ "glob": "^7.1.3"
+ },
+ "bin": {
+ "rimraf": "bin.js"
+ }
+ },
+ "node_modules/sass": {
+ "version": "1.54.0",
+ "resolved": "https://registry.npmjs.org/sass/-/sass-1.54.0.tgz",
+ "integrity": "sha512-C4zp79GCXZfK0yoHZg+GxF818/aclhp9F48XBu/+bm9vXEVAYov9iU3FBVRMq3Hx3OA4jfKL+p2K9180mEh0xQ==",
+ "dependencies": {
+ "chokidar": ">=3.0.0 <4.0.0",
+ "immutable": "^4.0.0",
+ "source-map-js": ">=0.6.2 <2.0.0"
+ },
+ "bin": {
+ "sass": "sass.js"
+ },
+ "engines": {
+ "node": ">=12.0.0"
+ }
+ },
+ "node_modules/semver": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
+ "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
+ "devOptional": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/serialize-javascript": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-4.0.0.tgz",
+ "integrity": "sha512-GaNA54380uFefWghODBWEGisLZFj00nS5ACs6yHa9nLqlLpVLO8ChDGeKRjZnV4Nh4n0Qi7nhYZD/9fCPzEqkw==",
+ "dependencies": {
+ "randombytes": "^2.1.0"
+ }
+ },
+ "node_modules/shebang-command": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
+ "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
+ "dev": true,
+ "dependencies": {
+ "shebang-regex": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/shebang-regex": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
+ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/socket.io-client": {
+ "version": "4.3.2",
+ "resolved": "https://registry.npmjs.org/socket.io-client/-/socket.io-client-4.3.2.tgz",
+ "integrity": "sha512-2B9LqSunN60yV8F7S84CCEEcgbYNfrn7ejIInZtLZ7ppWtiX8rGZAjvdCvbnC8bqo/9RlCNOUsORLyskxSFP1g==",
+ "dev": true,
+ "dependencies": {
+ "@socket.io/component-emitter": "~3.0.0",
+ "backo2": "~1.0.2",
+ "debug": "~4.3.2",
+ "engine.io-client": "~6.0.1",
+ "parseuri": "0.0.6",
+ "socket.io-parser": "~4.1.1"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/socket.io-parser": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.1.2.tgz",
+ "integrity": "sha512-j3kk71QLJuyQ/hh5F/L2t1goqzdTL0gvDzuhTuNSwihfuFUrcSji0qFZmJJPtG6Rmug153eOPsUizeirf1IIog==",
+ "dev": true,
+ "dependencies": {
+ "@socket.io/component-emitter": "~3.0.0",
+ "debug": "~4.3.1"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/sorcery": {
+ "version": "0.10.0",
+ "resolved": "https://registry.npmjs.org/sorcery/-/sorcery-0.10.0.tgz",
+ "integrity": "sha512-R5ocFmKZQFfSTstfOtHjJuAwbpGyf9qjQa1egyhvXSbM7emjrtLXtGdZsDJDABC85YBfVvrOiGWKSYXPKdvP1g==",
+ "dependencies": {
+ "buffer-crc32": "^0.2.5",
+ "minimist": "^1.2.0",
+ "sander": "^0.5.0",
+ "sourcemap-codec": "^1.3.0"
+ },
+ "bin": {
+ "sorcery": "bin/index.js"
+ }
+ },
+ "node_modules/source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-js": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
+ "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-resolve": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.6.0.tgz",
+ "integrity": "sha512-KXBr9d/fO/bWo97NXsPIAW1bFSBOuCnjbNTBMO7N59hsv5i9yzRDfcYwwt0l04+VqnKC+EwzvJZIP/qkuMgR/w==",
+ "deprecated": "See https://github.com/lydell/source-map-resolve#deprecated",
+ "dependencies": {
+ "atob": "^2.1.2",
+ "decode-uri-component": "^0.2.0"
+ }
+ },
+ "node_modules/source-map-support": {
+ "version": "0.5.21",
+ "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz",
+ "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==",
+ "dependencies": {
+ "buffer-from": "^1.0.0",
+ "source-map": "^0.6.0"
+ }
+ },
+ "node_modules/sourcemap-codec": {
+ "version": "1.4.8",
+ "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz",
+ "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA=="
+ },
+ "node_modules/spdx-exceptions": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz",
+ "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==",
+ "dev": true
+ },
+ "node_modules/spdx-expression-parse": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz",
+ "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==",
+ "dev": true,
+ "dependencies": {
+ "spdx-exceptions": "^2.1.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "node_modules/spdx-license-ids": {
+ "version": "3.0.11",
+ "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.11.tgz",
+ "integrity": "sha512-Ctl2BrFiM0X3MANYgj3CkygxhRmr9mi6xhejbdO960nF6EDJApTYpn0BQnDKlnNBULKiCN1n3w9EBkHK8ZWg+g==",
+ "dev": true
+ },
+ "node_modules/stable": {
+ "version": "0.1.8",
+ "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz",
+ "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w==",
+ "deprecated": "Modern JS already guarantees Array#sort() is a stable sort, so this library is deprecated. See the compatibility table on MDN: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#browser_compatibility"
+ },
+ "node_modules/string-hash": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/string-hash/-/string-hash-1.1.3.tgz",
+ "integrity": "sha512-kJUvRUFK49aub+a7T1nNE66EJbZBMnBgoC1UbCZ5n6bsZKBRga4KgBRTMn/pFkeCZSYtNeSyMxPDM0AXWELk2A=="
+ },
+ "node_modules/strip-ansi": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
+ "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
+ "dev": true,
+ "dependencies": {
+ "ansi-regex": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-indent": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-3.0.0.tgz",
+ "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==",
+ "dependencies": {
+ "min-indent": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-json-comments": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
+ "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/style-inject": {
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/style-inject/-/style-inject-0.3.0.tgz",
+ "integrity": "sha512-IezA2qp+vcdlhJaVm5SOdPPTUu0FCEqfNSli2vRuSIBbu5Nq5UvygTk/VzeCqfLz2Atj3dVII5QBKGZRZ0edzw=="
+ },
+ "node_modules/stylehacks": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/stylehacks/-/stylehacks-5.1.0.tgz",
+ "integrity": "sha512-SzLmvHQTrIWfSgljkQCw2++C9+Ne91d/6Sp92I8c5uHTcy/PgeHamwITIbBW9wnFTY/3ZfSXR9HIL6Ikqmcu6Q==",
+ "dependencies": {
+ "browserslist": "^4.16.6",
+ "postcss-selector-parser": "^6.0.4"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14.0"
+ },
+ "peerDependencies": {
+ "postcss": "^8.2.15"
+ }
+ },
+ "node_modules/supports-color": {
+ "version": "5.5.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
+ "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
+ "dependencies": {
+ "has-flag": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/supports-preserve-symlinks-flag": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
+ "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==",
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/svelte": {
+ "version": "3.49.0",
+ "resolved": "https://registry.npmjs.org/svelte/-/svelte-3.49.0.tgz",
+ "integrity": "sha512-+lmjic1pApJWDfPCpUUTc1m8azDqYCG1JN9YEngrx/hUyIcFJo6VZhj0A1Ai0wqoHcEIuQy+e9tk+4uDgdtsFA==",
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/svelte-dnd-action": {
+ "version": "0.9.19",
+ "resolved": "https://registry.npmjs.org/svelte-dnd-action/-/svelte-dnd-action-0.9.19.tgz",
+ "integrity": "sha512-1Jsym2HN0TJVUl09wLGASkHg937+ZecnnekPiwC0J6K7mCzOxCuIQSVnIxoQLLeiXv74joNVNpVofX9Z0jM4Vw==",
+ "dev": true
+ },
+ "node_modules/svelte-hmr": {
+ "version": "0.14.12",
+ "resolved": "https://registry.npmjs.org/svelte-hmr/-/svelte-hmr-0.14.12.tgz",
+ "integrity": "sha512-4QSW/VvXuqVcFZ+RhxiR8/newmwOCTlbYIezvkeN6302YFRE8cXy0naamHcjz8Y9Ce3ITTZtrHrIL0AGfyo61w==",
+ "engines": {
+ "node": "^12.20 || ^14.13.1 || >= 16"
+ },
+ "peerDependencies": {
+ "svelte": ">=3.19.0"
+ }
+ },
+ "node_modules/svelte-preprocess": {
+ "version": "4.10.7",
+ "resolved": "https://registry.npmjs.org/svelte-preprocess/-/svelte-preprocess-4.10.7.tgz",
+ "integrity": "sha512-sNPBnqYD6FnmdBrUmBCaqS00RyCsCpj2BG58A1JBswNF7b0OKviwxqVrOL/CKyJrLSClrSeqQv5BXNg2RUbPOw==",
+ "hasInstallScript": true,
+ "dependencies": {
+ "@types/pug": "^2.0.4",
+ "@types/sass": "^1.16.0",
+ "detect-indent": "^6.0.0",
+ "magic-string": "^0.25.7",
+ "sorcery": "^0.10.0",
+ "strip-indent": "^3.0.0"
+ },
+ "engines": {
+ "node": ">= 9.11.2"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.10.2",
+ "coffeescript": "^2.5.1",
+ "less": "^3.11.3 || ^4.0.0",
+ "postcss": "^7 || ^8",
+ "postcss-load-config": "^2.1.0 || ^3.0.0 || ^4.0.0",
+ "pug": "^3.0.0",
+ "sass": "^1.26.8",
+ "stylus": "^0.55.0",
+ "sugarss": "^2.0.0",
+ "svelte": "^3.23.0",
+ "typescript": "^3.9.5 || ^4.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@babel/core": {
+ "optional": true
+ },
+ "coffeescript": {
+ "optional": true
+ },
+ "less": {
+ "optional": true
+ },
+ "node-sass": {
+ "optional": true
+ },
+ "postcss": {
+ "optional": true
+ },
+ "postcss-load-config": {
+ "optional": true
+ },
+ "pug": {
+ "optional": true
+ },
+ "sass": {
+ "optional": true
+ },
+ "stylus": {
+ "optional": true
+ },
+ "sugarss": {
+ "optional": true
+ },
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/svelte-preprocess/node_modules/magic-string": {
+ "version": "0.25.9",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz",
+ "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==",
+ "dependencies": {
+ "sourcemap-codec": "^1.4.8"
+ }
+ },
+ "node_modules/svgo": {
+ "version": "2.8.0",
+ "resolved": "https://registry.npmjs.org/svgo/-/svgo-2.8.0.tgz",
+ "integrity": "sha512-+N/Q9kV1+F+UeWYoSiULYo4xYSDQlTgb+ayMobAXPwMnLvop7oxKMo9OzIrX5x3eS4L4f2UHhc9axXwY8DpChg==",
+ "dependencies": {
+ "@trysound/sax": "0.2.0",
+ "commander": "^7.2.0",
+ "css-select": "^4.1.3",
+ "css-tree": "^1.1.3",
+ "csso": "^4.2.0",
+ "picocolors": "^1.0.0",
+ "stable": "^0.1.8"
+ },
+ "bin": {
+ "svgo": "bin/svgo"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/terser": {
+ "version": "5.14.2",
+ "resolved": "https://registry.npmjs.org/terser/-/terser-5.14.2.tgz",
+ "integrity": "sha512-oL0rGeM/WFQCUd0y2QrWxYnq7tfSuKBiqTjRPWrRgB46WD/kiwHwF8T23z78H6Q6kGCuuHcPB+KULHRdxvVGQA==",
+ "dependencies": {
+ "@jridgewell/source-map": "^0.3.2",
+ "acorn": "^8.5.0",
+ "commander": "^2.20.0",
+ "source-map-support": "~0.5.20"
+ },
+ "bin": {
+ "terser": "bin/terser"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/terser/node_modules/commander": {
+ "version": "2.20.3",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz",
+ "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ=="
+ },
+ "node_modules/text-table": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
+ "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
+ "dev": true
+ },
+ "node_modules/tinymce": {
+ "version": "5.10.1",
+ "resolved": "https://registry.npmjs.org/tinymce/-/tinymce-5.10.1.tgz",
+ "integrity": "sha512-aIsFTYiuESpoYkCgkoojpVtPwrSvYBxp4mMEGsj20CnUruLCWosywkbYHDII+j7KlQZZn3p+xK89f5gT3QyuGw==",
+ "dev": true
+ },
+ "node_modules/to-fast-properties": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
+ "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==",
+ "devOptional": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/to-regex-range": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
+ "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
+ "dependencies": {
+ "is-number": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=8.0"
+ }
+ },
+ "node_modules/type-check": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
+ "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
+ "dev": true,
+ "dependencies": {
+ "prelude-ls": "^1.2.1"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/type-fest": {
+ "version": "0.20.2",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
+ "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/uglify-js": {
+ "version": "3.16.2",
+ "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.16.2.tgz",
+ "integrity": "sha512-AaQNokTNgExWrkEYA24BTNMSjyqEXPSfhqoS0AxmHkCJ4U+Dyy5AvbGV/sqxuxficEfGGoX3zWw9R7QpLFfEsg==",
+ "dev": true,
+ "optional": true,
+ "bin": {
+ "uglifyjs": "bin/uglifyjs"
+ },
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/unicode-canonical-property-names-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unicode-match-property-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==",
+ "dev": true,
+ "dependencies": {
+ "unicode-canonical-property-names-ecmascript": "^2.0.0",
+ "unicode-property-aliases-ecmascript": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unicode-match-property-value-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-7Yhkc0Ye+t4PNYzOGKedDhXbYIBe1XEQYQxOPyhcXNMJ0WCABqqj6ckydd6pWRZTHV4GuCPKdBAUiMc60tsKVw==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unicode-property-aliases-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-5Zfuy9q/DFr4tfO7ZPeVXb1aPoeQSdeFMLpYuFebehDAhbuevLs5yxSZmIFN1tP5F9Wl4IpJrYojg85/zgyZHQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/update-browserslist-db": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.5.tgz",
+ "integrity": "sha512-dteFFpCyvuDdr9S/ff1ISkKt/9YZxKjI9WlRR99c180GaztJtRa/fn18FdxGVKVsnPY7/a/FDN68mcvUmP4U7Q==",
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ }
+ ],
+ "dependencies": {
+ "escalade": "^3.1.1",
+ "picocolors": "^1.0.0"
+ },
+ "bin": {
+ "browserslist-lint": "cli.js"
+ },
+ "peerDependencies": {
+ "browserslist": ">= 4.21.0"
+ }
+ },
+ "node_modules/uri-js": {
+ "version": "4.4.1",
+ "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
+ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
+ "dev": true,
+ "dependencies": {
+ "punycode": "^2.1.0"
+ }
+ },
+ "node_modules/url": {
+ "version": "0.11.0",
+ "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz",
+ "integrity": "sha512-kbailJa29QrtXnxgq+DdCEGlbTeYM2eJUxsz6vjZavrCYPMIFHMKQmSKYAIuUK2i7hgPm28a8piX5NTUtM/LKQ==",
+ "dev": true,
+ "dependencies": {
+ "punycode": "1.3.2",
+ "querystring": "0.2.0"
+ }
+ },
+ "node_modules/url/node_modules/punycode": {
+ "version": "1.3.2",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz",
+ "integrity": "sha512-RofWgt/7fL5wP1Y7fxE7/EmTLzQVnB0ycyibJ0OOHIlJqTNzglYFxVwETOcIoJqJmpDXJ9xImDv+Fq34F/d4Dw==",
+ "dev": true
+ },
+ "node_modules/util-deprecate": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
+ "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw=="
+ },
+ "node_modules/v8-compile-cache": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz",
+ "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==",
+ "dev": true
+ },
+ "node_modules/vite": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/vite/-/vite-3.0.2.tgz",
+ "integrity": "sha512-TAqydxW/w0U5AoL5AsD9DApTvGb2iNbGs3sN4u2VdT1GFkQVUfgUldt+t08TZgi23uIauh1TUOQJALduo9GXqw==",
+ "dependencies": {
+ "esbuild": "^0.14.47",
+ "postcss": "^8.4.14",
+ "resolve": "^1.22.1",
+ "rollup": "^2.75.6"
+ },
+ "bin": {
+ "vite": "bin/vite.js"
+ },
+ "engines": {
+ "node": "^14.18.0 || >=16.0.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ },
+ "peerDependencies": {
+ "less": "*",
+ "sass": "*",
+ "stylus": "*",
+ "terser": "^5.4.0"
+ },
+ "peerDependenciesMeta": {
+ "less": {
+ "optional": true
+ },
+ "sass": {
+ "optional": true
+ },
+ "stylus": {
+ "optional": true
+ },
+ "terser": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/node-which"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/word-wrap": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz",
+ "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/wordwrap": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz",
+ "integrity": "sha512-gvVzJFlPycKc5dZN4yPkP8w7Dc37BtP1yczEneOb4uq34pXZcvrtRTmWV8W+Ume+XCxKgbjM+nevkyFPMybd4Q==",
+ "dev": true
+ },
+ "node_modules/wrappy": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
+ "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ=="
+ },
+ "node_modules/ws": {
+ "version": "8.2.3",
+ "resolved": "https://registry.npmjs.org/ws/-/ws-8.2.3.tgz",
+ "integrity": "sha512-wBuoj1BDpC6ZQ1B7DWQBYVLphPWkm8i9Y0/3YdHjHKHiohOJ1ws+3OccDWtH+PoC9DZD5WOTrJvNbWvjS6JWaA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.0.0"
+ },
+ "peerDependencies": {
+ "bufferutil": "^4.0.1",
+ "utf-8-validate": "^5.0.2"
+ },
+ "peerDependenciesMeta": {
+ "bufferutil": {
+ "optional": true
+ },
+ "utf-8-validate": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/xmlhttprequest-ssl": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-2.0.0.tgz",
+ "integrity": "sha512-QKxVRxiRACQcVuQEYFsI1hhkrMlrXHPegbbd1yn9UHOmRxY+si12nQYzri3vbzt8VdTTRviqcKxcyllFas5z2A==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/yaml": {
+ "version": "1.10.2",
+ "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz",
+ "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==",
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/yeast": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/yeast/-/yeast-0.1.2.tgz",
+ "integrity": "sha512-8HFIh676uyGYP6wP13R/j6OJ/1HwJ46snpvzE7aHAN3Ryqh2yX6Xox2B4CUmTwwOIzlG3Bs7ocsP5dZH/R1Qbg==",
+ "dev": true
+ }
+ },
+ "dependencies": {
+ "@ampproject/remapping": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz",
+ "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==",
+ "devOptional": true,
+ "requires": {
+ "@jridgewell/gen-mapping": "^0.1.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ },
+ "@babel/code-frame": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz",
+ "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==",
+ "requires": {
+ "@babel/highlight": "^7.18.6"
+ }
+ },
+ "@babel/compat-data": {
+ "version": "7.18.8",
+ "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.18.8.tgz",
+ "integrity": "sha512-HSmX4WZPPK3FUxYp7g2T6EyO8j96HlZJlxmKPSh6KAcqwyDrfx7hKjXpAW/0FhFfTJsR0Yt4lAjLI2coMptIHQ==",
+ "devOptional": true
+ },
+ "@babel/core": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.18.9.tgz",
+ "integrity": "sha512-1LIb1eL8APMy91/IMW+31ckrfBM4yCoLaVzoDhZUKSM4cu1L1nIidyxkCgzPAgrC5WEz36IPEr/eSeSF9pIn+g==",
+ "devOptional": true,
+ "requires": {
+ "@ampproject/remapping": "^2.1.0",
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.18.9",
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-module-transforms": "^7.18.9",
+ "@babel/helpers": "^7.18.9",
+ "@babel/parser": "^7.18.9",
+ "@babel/template": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9",
+ "convert-source-map": "^1.7.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.1",
+ "semver": "^6.3.0"
+ }
+ },
+ "@babel/generator": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.18.9.tgz",
+ "integrity": "sha512-wt5Naw6lJrL1/SGkipMiFxJjtyczUWTP38deiP1PO60HsBjDeKk08CGC3S8iVuvf0FmTdgKwU1KIXzSKL1G0Ug==",
+ "devOptional": true,
+ "requires": {
+ "@babel/types": "^7.18.9",
+ "@jridgewell/gen-mapping": "^0.3.2",
+ "jsesc": "^2.5.1"
+ },
+ "dependencies": {
+ "@jridgewell/gen-mapping": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz",
+ "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==",
+ "devOptional": true,
+ "requires": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ }
+ }
+ },
+ "@babel/helper-annotate-as-pure": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz",
+ "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-builder-binary-assignment-operator-visitor": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.9.tgz",
+ "integrity": "sha512-yFQ0YCHoIqarl8BCRwBL8ulYUaZpz3bNsA7oFepAzee+8/+ImtADXNOmO5vJvsPff3qi+hvpkY/NYBTrBQgdNw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-explode-assignable-expression": "^7.18.6",
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helper-compilation-targets": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.18.9.tgz",
+ "integrity": "sha512-tzLCyVmqUiFlcFoAPLA/gL9TeYrF61VLNtb+hvkuVaB5SUjW7jcfrglBIX1vUIoT7CLP3bBlIMeyEsIl2eFQNg==",
+ "devOptional": true,
+ "requires": {
+ "@babel/compat-data": "^7.18.8",
+ "@babel/helper-validator-option": "^7.18.6",
+ "browserslist": "^4.20.2",
+ "semver": "^6.3.0"
+ }
+ },
+ "@babel/helper-create-class-features-plugin": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.18.9.tgz",
+ "integrity": "sha512-WvypNAYaVh23QcjpMR24CwZY2Nz6hqdOcFdPbNpV56hL5H6KiFheO7Xm1aPdlLQ7d5emYZX7VZwPp9x3z+2opw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-member-expression-to-functions": "^7.18.9",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/helper-replace-supers": "^7.18.9",
+ "@babel/helper-split-export-declaration": "^7.18.6"
+ }
+ },
+ "@babel/helper-create-regexp-features-plugin": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.18.6.tgz",
+ "integrity": "sha512-7LcpH1wnQLGrI+4v+nPp+zUvIkF9x0ddv1Hkdue10tg3gmRnLy97DXh4STiOf1qeIInyD69Qv5kKSZzKD8B/7A==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "regexpu-core": "^5.1.0"
+ }
+ },
+ "@babel/helper-define-polyfill-provider": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.2.tgz",
+ "integrity": "sha512-r9QJJ+uDWrd+94BSPcP6/de67ygLtvVy6cK4luE6MOuDsZIdoaPBnfSpbO/+LTifjPckbKXRuI9BB/Z2/y3iTg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-compilation-targets": "^7.17.7",
+ "@babel/helper-plugin-utils": "^7.16.7",
+ "debug": "^4.1.1",
+ "lodash.debounce": "^4.0.8",
+ "resolve": "^1.14.2",
+ "semver": "^6.1.2"
+ }
+ },
+ "@babel/helper-environment-visitor": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz",
+ "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==",
+ "devOptional": true
+ },
+ "@babel/helper-explode-assignable-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz",
+ "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-function-name": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.18.9.tgz",
+ "integrity": "sha512-fJgWlZt7nxGksJS9a0XdSaI4XvpExnNIgRP+rVefWh5U7BL8pPuir6SJUmFKRfjWQ51OtWSzwOxhaH/EBWWc0A==",
+ "devOptional": true,
+ "requires": {
+ "@babel/template": "^7.18.6",
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helper-hoist-variables": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz",
+ "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==",
+ "devOptional": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-member-expression-to-functions": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.18.9.tgz",
+ "integrity": "sha512-RxifAh2ZoVU67PyKIO4AMi1wTenGfMR/O/ae0CCRqwgBAt5v7xjdtRw7UoSbsreKrQn5t7r89eruK/9JjYHuDg==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helper-module-imports": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz",
+ "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==",
+ "devOptional": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-module-transforms": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.18.9.tgz",
+ "integrity": "sha512-KYNqY0ICwfv19b31XzvmI/mfcylOzbLtowkw+mfvGPAQ3kfCnMLYbED3YecL5tPd8nAYFQFAd6JHp2LxZk/J1g==",
+ "devOptional": true,
+ "requires": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-simple-access": "^7.18.6",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "@babel/template": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helper-optimise-call-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz",
+ "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-plugin-utils": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.18.9.tgz",
+ "integrity": "sha512-aBXPT3bmtLryXaoJLyYPXPlSD4p1ld9aYeR+sJNOZjJJGiOpb+fKfh3NkcCu7J54nUJwCERPBExCCpyCOHnu/w==",
+ "dev": true
+ },
+ "@babel/helper-remap-async-to-generator": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz",
+ "integrity": "sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-wrap-function": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helper-replace-supers": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.18.9.tgz",
+ "integrity": "sha512-dNsWibVI4lNT6HiuOIBr1oyxo40HvIVmbwPUm3XZ7wMh4k2WxrxTqZwSqw/eEmXDS9np0ey5M2bz9tBmO9c+YQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-member-expression-to-functions": "^7.18.9",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helper-simple-access": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz",
+ "integrity": "sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g==",
+ "devOptional": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-skip-transparent-expression-wrappers": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.18.9.tgz",
+ "integrity": "sha512-imytd2gHi3cJPsybLRbmFrF7u5BIEuI2cNheyKi3/iOBC63kNn3q8Crn2xVuESli0aM4KYsyEqKyS7lFL8YVtw==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helper-split-export-declaration": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz",
+ "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==",
+ "devOptional": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-validator-identifier": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz",
+ "integrity": "sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g=="
+ },
+ "@babel/helper-validator-option": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz",
+ "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==",
+ "devOptional": true
+ },
+ "@babel/helper-wrap-function": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.18.9.tgz",
+ "integrity": "sha512-cG2ru3TRAL6a60tfQflpEfs4ldiPwF6YW3zfJiRgmoFVIaC1vGnBBgatfec+ZUziPHkHSaXAuEck3Cdkf3eRpQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/template": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helpers": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.18.9.tgz",
+ "integrity": "sha512-Jf5a+rbrLoR4eNdUmnFu8cN5eNJT6qdTdOg5IHIzq87WwyRw9PwguLFOWYgktN/60IP4fgDUawJvs7PjQIzELQ==",
+ "devOptional": true,
+ "requires": {
+ "@babel/template": "^7.18.6",
+ "@babel/traverse": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/highlight": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz",
+ "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==",
+ "requires": {
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "chalk": "^2.0.0",
+ "js-tokens": "^4.0.0"
+ }
+ },
+ "@babel/parser": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.18.9.tgz",
+ "integrity": "sha512-9uJveS9eY9DJ0t64YbIBZICtJy8a5QrDEVdiLCG97fVLpDTpGX7t8mMSb6OWw6Lrnjqj4O8zwjELX3dhoMgiBg==",
+ "devOptional": true
+ },
+ "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz",
+ "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.18.9.tgz",
+ "integrity": "sha512-AHrP9jadvH7qlOj6PINbgSuphjQUAK7AOT7DPjBo9EHoLhQTnnK5u45e1Hd4DbSQEO9nqPWtQ89r+XEOWFScKg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.18.9",
+ "@babel/plugin-proposal-optional-chaining": "^7.18.9"
+ }
+ },
+ "@babel/plugin-proposal-async-generator-functions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.18.6.tgz",
+ "integrity": "sha512-WAz4R9bvozx4qwf74M+sfqPMKfSqwM0phxPTR6iJIi8robgzXwkEgmeJG1gEKhm6sDqT/U9aV3lfcqybIpev8w==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-environment-visitor": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-remap-async-to-generator": "^7.18.6",
+ "@babel/plugin-syntax-async-generators": "^7.8.4"
+ }
+ },
+ "@babel/plugin-proposal-class-properties": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz",
+ "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-proposal-class-static-block": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.18.6.tgz",
+ "integrity": "sha512-+I3oIiNxrCpup3Gi8n5IGMwj0gOCAjcJUSQEcotNnCCPMEnixawOQ+KeJPlgfjzx+FKQ1QSyZOWe7wmoJp7vhw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5"
+ }
+ },
+ "@babel/plugin-proposal-dynamic-import": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz",
+ "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-export-namespace-from": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz",
+ "integrity": "sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-json-strings": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz",
+ "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-json-strings": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-logical-assignment-operators": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.18.9.tgz",
+ "integrity": "sha512-128YbMpjCrP35IOExw2Fq+x55LMP42DzhOhX2aNNIdI9avSWl2PI0yuBWarr3RYpZBSPtabfadkH2yeRiMD61Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4"
+ }
+ },
+ "@babel/plugin-proposal-nullish-coalescing-operator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz",
+ "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-numeric-separator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz",
+ "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4"
+ }
+ },
+ "@babel/plugin-proposal-object-rest-spread": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.18.9.tgz",
+ "integrity": "sha512-kDDHQ5rflIeY5xl69CEqGEZ0KY369ehsCIEbTGb4siHG5BE9sga/T0r0OUwyZNLMmZE79E1kbsqAjwFCW4ds6Q==",
+ "dev": true,
+ "requires": {
+ "@babel/compat-data": "^7.18.8",
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-transform-parameters": "^7.18.8"
+ }
+ },
+ "@babel/plugin-proposal-optional-catch-binding": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz",
+ "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-optional-chaining": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.18.9.tgz",
+ "integrity": "sha512-v5nwt4IqBXihxGsW2QmCWMDS3B3bzGIk/EQVZz2ei7f3NJl8NzAJVvUmpDW5q1CRNY+Beb/k58UAH1Km1N411w==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.18.9",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-private-methods": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz",
+ "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-proposal-private-property-in-object": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.18.6.tgz",
+ "integrity": "sha512-9Rysx7FOctvT5ouj5JODjAFAkgGoudQuLPamZb0v1TGLpapdNaftzifU8NTWQm0IRjqoYypdrSmyWgkocDQ8Dw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5"
+ }
+ },
+ "@babel/plugin-proposal-unicode-property-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz",
+ "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-syntax-async-generators": {
+ "version": "7.8.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz",
+ "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-class-properties": {
+ "version": "7.12.13",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz",
+ "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.12.13"
+ }
+ },
+ "@babel/plugin-syntax-class-static-block": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz",
+ "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ }
+ },
+ "@babel/plugin-syntax-dynamic-import": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz",
+ "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-export-namespace-from": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz",
+ "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.3"
+ }
+ },
+ "@babel/plugin-syntax-import-assertions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.18.6.tgz",
+ "integrity": "sha512-/DU3RXad9+bZwrgWJQKbr39gYbJpLJHezqEzRzi/BHRlJ9zsQb4CK2CA/5apllXNomwA1qHwzvHl+AdEmC5krQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-syntax-json-strings": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz",
+ "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-logical-assignment-operators": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz",
+ "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ }
+ },
+ "@babel/plugin-syntax-nullish-coalescing-operator": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz",
+ "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-numeric-separator": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz",
+ "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ }
+ },
+ "@babel/plugin-syntax-object-rest-spread": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz",
+ "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-optional-catch-binding": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz",
+ "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-optional-chaining": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz",
+ "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-private-property-in-object": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz",
+ "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ }
+ },
+ "@babel/plugin-syntax-top-level-await": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz",
+ "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ }
+ },
+ "@babel/plugin-transform-arrow-functions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.18.6.tgz",
+ "integrity": "sha512-9S9X9RUefzrsHZmKMbDXxweEH+YlE8JJEuat9FdvW9Qh1cw7W64jELCtWNkPBPX5En45uy28KGvA/AySqUh8CQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-async-to-generator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.18.6.tgz",
+ "integrity": "sha512-ARE5wZLKnTgPW7/1ftQmSi1CmkqqHo2DNmtztFhvgtOWSDfq0Cq9/9L+KnZNYSNrydBekhW3rwShduf59RoXag==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-remap-async-to-generator": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-block-scoped-functions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz",
+ "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-block-scoping": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.18.9.tgz",
+ "integrity": "sha512-5sDIJRV1KtQVEbt/EIBwGy4T01uYIo4KRB3VUqzkhrAIOGx7AoctL9+Ux88btY0zXdDyPJ9mW+bg+v+XEkGmtw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-classes": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.18.9.tgz",
+ "integrity": "sha512-EkRQxsxoytpTlKJmSPYrsOMjCILacAjtSVkd4gChEe2kXjFCun3yohhW5I7plXJhCemM0gKsaGMcO8tinvCA5g==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-replace-supers": "^7.18.9",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "globals": "^11.1.0"
+ }
+ },
+ "@babel/plugin-transform-computed-properties": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.18.9.tgz",
+ "integrity": "sha512-+i0ZU1bCDymKakLxn5srGHrsAPRELC2WIbzwjLhHW9SIE1cPYkLCL0NlnXMZaM1vhfgA2+M7hySk42VBvrkBRw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-destructuring": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.18.9.tgz",
+ "integrity": "sha512-p5VCYNddPLkZTq4XymQIaIfZNJwT9YsjkPOhkVEqt6QIpQFZVM9IltqqYpOEkJoN1DPznmxUDyZ5CTZs/ZCuHA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-dotall-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz",
+ "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-duplicate-keys": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz",
+ "integrity": "sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-exponentiation-operator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz",
+ "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-for-of": {
+ "version": "7.18.8",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz",
+ "integrity": "sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-function-name": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz",
+ "integrity": "sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-literals": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz",
+ "integrity": "sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-member-expression-literals": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz",
+ "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-modules-amd": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.18.6.tgz",
+ "integrity": "sha512-Pra5aXsmTsOnjM3IajS8rTaLCy++nGM4v3YR4esk5PCsyg9z8NA5oQLwxzMUtDBd8F+UmVza3VxoAaWCbzH1rg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-transforms": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "babel-plugin-dynamic-import-node": "^2.3.3"
+ }
+ },
+ "@babel/plugin-transform-modules-commonjs": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.18.6.tgz",
+ "integrity": "sha512-Qfv2ZOWikpvmedXQJDSbxNqy7Xr/j2Y8/KfijM0iJyKkBTmWuvCA1yeH1yDM7NJhBW/2aXxeucLj6i80/LAJ/Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-transforms": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-simple-access": "^7.18.6",
+ "babel-plugin-dynamic-import-node": "^2.3.3"
+ }
+ },
+ "@babel/plugin-transform-modules-systemjs": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.18.9.tgz",
+ "integrity": "sha512-zY/VSIbbqtoRoJKo2cDTewL364jSlZGvn0LKOf9ntbfxOvjfmyrdtEEOAdswOswhZEb8UH3jDkCKHd1sPgsS0A==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-hoist-variables": "^7.18.6",
+ "@babel/helper-module-transforms": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "babel-plugin-dynamic-import-node": "^2.3.3"
+ }
+ },
+ "@babel/plugin-transform-modules-umd": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz",
+ "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-transforms": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-named-capturing-groups-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.18.6.tgz",
+ "integrity": "sha512-UmEOGF8XgaIqD74bC8g7iV3RYj8lMf0Bw7NJzvnS9qQhM4mg+1WHKotUIdjxgD2RGrgFLZZPCFPFj3P/kVDYhg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-new-target": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz",
+ "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-object-super": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz",
+ "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-replace-supers": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-parameters": {
+ "version": "7.18.8",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.18.8.tgz",
+ "integrity": "sha512-ivfbE3X2Ss+Fj8nnXvKJS6sjRG4gzwPMsP+taZC+ZzEGjAYlvENixmt1sZ5Ca6tWls+BlKSGKPJ6OOXvXCbkFg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-property-literals": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz",
+ "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-regenerator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.18.6.tgz",
+ "integrity": "sha512-poqRI2+qiSdeldcz4wTSTXBRryoq3Gc70ye7m7UD5Ww0nE29IXqMl6r7Nd15WBgRd74vloEMlShtH6CKxVzfmQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "regenerator-transform": "^0.15.0"
+ }
+ },
+ "@babel/plugin-transform-reserved-words": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz",
+ "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-shorthand-properties": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz",
+ "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-spread": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.18.9.tgz",
+ "integrity": "sha512-39Q814wyoOPtIB/qGopNIL9xDChOE1pNU0ZY5dO0owhiVt/5kFm4li+/bBtwc7QotG0u5EPzqhZdjMtmqBqyQA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-sticky-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz",
+ "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-template-literals": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz",
+ "integrity": "sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-typeof-symbol": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz",
+ "integrity": "sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-unicode-escapes": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.6.tgz",
+ "integrity": "sha512-XNRwQUXYMP7VLuy54cr/KS/WeL3AZeORhrmeZ7iewgu+X2eBqmpaLI/hzqr9ZxCeUoq0ASK4GUzSM0BDhZkLFw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-unicode-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz",
+ "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/preset-env": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.18.9.tgz",
+ "integrity": "sha512-75pt/q95cMIHWssYtyfjVlvI+QEZQThQbKvR9xH+F/Agtw/s4Wfc2V9Bwd/P39VtixB7oWxGdH4GteTTwYJWMg==",
+ "dev": true,
+ "requires": {
+ "@babel/compat-data": "^7.18.8",
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/helper-validator-option": "^7.18.6",
+ "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6",
+ "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.9",
+ "@babel/plugin-proposal-async-generator-functions": "^7.18.6",
+ "@babel/plugin-proposal-class-properties": "^7.18.6",
+ "@babel/plugin-proposal-class-static-block": "^7.18.6",
+ "@babel/plugin-proposal-dynamic-import": "^7.18.6",
+ "@babel/plugin-proposal-export-namespace-from": "^7.18.9",
+ "@babel/plugin-proposal-json-strings": "^7.18.6",
+ "@babel/plugin-proposal-logical-assignment-operators": "^7.18.9",
+ "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
+ "@babel/plugin-proposal-numeric-separator": "^7.18.6",
+ "@babel/plugin-proposal-object-rest-spread": "^7.18.9",
+ "@babel/plugin-proposal-optional-catch-binding": "^7.18.6",
+ "@babel/plugin-proposal-optional-chaining": "^7.18.9",
+ "@babel/plugin-proposal-private-methods": "^7.18.6",
+ "@babel/plugin-proposal-private-property-in-object": "^7.18.6",
+ "@babel/plugin-proposal-unicode-property-regex": "^7.18.6",
+ "@babel/plugin-syntax-async-generators": "^7.8.4",
+ "@babel/plugin-syntax-class-properties": "^7.12.13",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3",
+ "@babel/plugin-syntax-import-assertions": "^7.18.6",
+ "@babel/plugin-syntax-json-strings": "^7.8.3",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5",
+ "@babel/plugin-syntax-top-level-await": "^7.14.5",
+ "@babel/plugin-transform-arrow-functions": "^7.18.6",
+ "@babel/plugin-transform-async-to-generator": "^7.18.6",
+ "@babel/plugin-transform-block-scoped-functions": "^7.18.6",
+ "@babel/plugin-transform-block-scoping": "^7.18.9",
+ "@babel/plugin-transform-classes": "^7.18.9",
+ "@babel/plugin-transform-computed-properties": "^7.18.9",
+ "@babel/plugin-transform-destructuring": "^7.18.9",
+ "@babel/plugin-transform-dotall-regex": "^7.18.6",
+ "@babel/plugin-transform-duplicate-keys": "^7.18.9",
+ "@babel/plugin-transform-exponentiation-operator": "^7.18.6",
+ "@babel/plugin-transform-for-of": "^7.18.8",
+ "@babel/plugin-transform-function-name": "^7.18.9",
+ "@babel/plugin-transform-literals": "^7.18.9",
+ "@babel/plugin-transform-member-expression-literals": "^7.18.6",
+ "@babel/plugin-transform-modules-amd": "^7.18.6",
+ "@babel/plugin-transform-modules-commonjs": "^7.18.6",
+ "@babel/plugin-transform-modules-systemjs": "^7.18.9",
+ "@babel/plugin-transform-modules-umd": "^7.18.6",
+ "@babel/plugin-transform-named-capturing-groups-regex": "^7.18.6",
+ "@babel/plugin-transform-new-target": "^7.18.6",
+ "@babel/plugin-transform-object-super": "^7.18.6",
+ "@babel/plugin-transform-parameters": "^7.18.8",
+ "@babel/plugin-transform-property-literals": "^7.18.6",
+ "@babel/plugin-transform-regenerator": "^7.18.6",
+ "@babel/plugin-transform-reserved-words": "^7.18.6",
+ "@babel/plugin-transform-shorthand-properties": "^7.18.6",
+ "@babel/plugin-transform-spread": "^7.18.9",
+ "@babel/plugin-transform-sticky-regex": "^7.18.6",
+ "@babel/plugin-transform-template-literals": "^7.18.9",
+ "@babel/plugin-transform-typeof-symbol": "^7.18.9",
+ "@babel/plugin-transform-unicode-escapes": "^7.18.6",
+ "@babel/plugin-transform-unicode-regex": "^7.18.6",
+ "@babel/preset-modules": "^0.1.5",
+ "@babel/types": "^7.18.9",
+ "babel-plugin-polyfill-corejs2": "^0.3.1",
+ "babel-plugin-polyfill-corejs3": "^0.5.2",
+ "babel-plugin-polyfill-regenerator": "^0.3.1",
+ "core-js-compat": "^3.22.1",
+ "semver": "^6.3.0"
+ }
+ },
+ "@babel/preset-modules": {
+ "version": "0.1.5",
+ "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz",
+ "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.0.0",
+ "@babel/plugin-proposal-unicode-property-regex": "^7.4.4",
+ "@babel/plugin-transform-dotall-regex": "^7.4.4",
+ "@babel/types": "^7.4.4",
+ "esutils": "^2.0.2"
+ }
+ },
+ "@babel/runtime": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.18.9.tgz",
+ "integrity": "sha512-lkqXDcvlFT5rvEjiu6+QYO+1GXrEHRo2LOtS7E4GtX5ESIZOgepqsZBVIj6Pv+a6zqsya9VCgiK1KAK4BvJDAw==",
+ "dev": true,
+ "requires": {
+ "regenerator-runtime": "^0.13.4"
+ }
+ },
+ "@babel/template": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.18.6.tgz",
+ "integrity": "sha512-JoDWzPe+wgBsTTgdnIma3iHNFC7YVJoPssVBDjiHfNlyt4YcunDtcDOUmfVDfCK5MfdsaIoX9PkijPhjH3nYUw==",
+ "devOptional": true,
+ "requires": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/parser": "^7.18.6",
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/traverse": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.18.9.tgz",
+ "integrity": "sha512-LcPAnujXGwBgv3/WHv01pHtb2tihcyW1XuL9wd7jqh1Z8AQkTd+QVjMrMijrln0T7ED3UXLIy36P9Ao7W75rYg==",
+ "devOptional": true,
+ "requires": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.18.9",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-hoist-variables": "^7.18.6",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/parser": "^7.18.9",
+ "@babel/types": "^7.18.9",
+ "debug": "^4.1.0",
+ "globals": "^11.1.0"
+ }
+ },
+ "@babel/types": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.18.9.tgz",
+ "integrity": "sha512-WwMLAg2MvJmt/rKEVQBBhIVffMmnilX4oe0sRe7iPOHIGsqpruFHHdrfj4O1CMMtgMtCU4oPafZjDPCRgO57Wg==",
+ "devOptional": true,
+ "requires": {
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "to-fast-properties": "^2.0.0"
+ }
+ },
+ "@csstools/postcss-cascade-layers": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-cascade-layers/-/postcss-cascade-layers-1.0.5.tgz",
+ "integrity": "sha512-Id/9wBT7FkgFzdEpiEWrsVd4ltDxN0rI0QS0SChbeQiSuux3z21SJCRLu6h2cvCEUmaRi+VD0mHFj+GJD4GFnw==",
+ "requires": {
+ "@csstools/selector-specificity": "^2.0.2",
+ "postcss-selector-parser": "^6.0.10"
+ }
+ },
+ "@csstools/postcss-color-function": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-color-function/-/postcss-color-function-1.1.1.tgz",
+ "integrity": "sha512-Bc0f62WmHdtRDjf5f3e2STwRAl89N2CLb+9iAwzrv4L2hncrbDwnQD9PCq0gtAt7pOI2leIV08HIBUd4jxD8cw==",
+ "requires": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "@csstools/postcss-font-format-keywords": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-font-format-keywords/-/postcss-font-format-keywords-1.0.1.tgz",
+ "integrity": "sha512-ZgrlzuUAjXIOc2JueK0X5sZDjCtgimVp/O5CEqTcs5ShWBa6smhWYbS0x5cVc/+rycTDbjjzoP0KTDnUneZGOg==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "@csstools/postcss-hwb-function": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-hwb-function/-/postcss-hwb-function-1.0.2.tgz",
+ "integrity": "sha512-YHdEru4o3Rsbjmu6vHy4UKOXZD+Rn2zmkAmLRfPet6+Jz4Ojw8cbWxe1n42VaXQhD3CQUXXTooIy8OkVbUcL+w==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "@csstools/postcss-ic-unit": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-ic-unit/-/postcss-ic-unit-1.0.1.tgz",
+ "integrity": "sha512-Ot1rcwRAaRHNKC9tAqoqNZhjdYBzKk1POgWfhN4uCOE47ebGcLRqXjKkApVDpjifL6u2/55ekkpnFcp+s/OZUw==",
+ "requires": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "@csstools/postcss-is-pseudo-class": {
+ "version": "2.0.7",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-is-pseudo-class/-/postcss-is-pseudo-class-2.0.7.tgz",
+ "integrity": "sha512-7JPeVVZHd+jxYdULl87lvjgvWldYu+Bc62s9vD/ED6/QTGjy0jy0US/f6BG53sVMTBJ1lzKZFpYmofBN9eaRiA==",
+ "requires": {
+ "@csstools/selector-specificity": "^2.0.0",
+ "postcss-selector-parser": "^6.0.10"
+ }
+ },
+ "@csstools/postcss-normalize-display-values": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-normalize-display-values/-/postcss-normalize-display-values-1.0.1.tgz",
+ "integrity": "sha512-jcOanIbv55OFKQ3sYeFD/T0Ti7AMXc9nM1hZWu8m/2722gOTxFg7xYu4RDLJLeZmPUVQlGzo4jhzvTUq3x4ZUw==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "@csstools/postcss-oklab-function": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-oklab-function/-/postcss-oklab-function-1.1.1.tgz",
+ "integrity": "sha512-nJpJgsdA3dA9y5pgyb/UfEzE7W5Ka7u0CX0/HIMVBNWzWemdcTH3XwANECU6anWv/ao4vVNLTMxhiPNZsTK6iA==",
+ "requires": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "@csstools/postcss-progressive-custom-properties": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-progressive-custom-properties/-/postcss-progressive-custom-properties-1.3.0.tgz",
+ "integrity": "sha512-ASA9W1aIy5ygskZYuWams4BzafD12ULvSypmaLJT2jvQ8G0M3I8PRQhC0h7mG0Z3LI05+agZjqSR9+K9yaQQjA==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "@csstools/postcss-stepped-value-functions": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-stepped-value-functions/-/postcss-stepped-value-functions-1.0.1.tgz",
+ "integrity": "sha512-dz0LNoo3ijpTOQqEJLY8nyaapl6umbmDcgj4AD0lgVQ572b2eqA1iGZYTTWhrcrHztWDDRAX2DGYyw2VBjvCvQ==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "@csstools/postcss-trigonometric-functions": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-trigonometric-functions/-/postcss-trigonometric-functions-1.0.2.tgz",
+ "integrity": "sha512-woKaLO///4bb+zZC2s80l+7cm07M7268MsyG3M0ActXXEFi6SuhvriQYcb58iiKGbjwwIU7n45iRLEHypB47Og==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "@csstools/postcss-unset-value": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/@csstools/postcss-unset-value/-/postcss-unset-value-1.0.2.tgz",
+ "integrity": "sha512-c8J4roPBILnelAsdLr4XOAR/GsTm0GJi4XpcfvoWk3U6KiTCqiFYc63KhRMQQX35jYMp4Ao8Ij9+IZRgMfJp1g==",
+ "requires": {}
+ },
+ "@csstools/selector-specificity": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/@csstools/selector-specificity/-/selector-specificity-2.0.2.tgz",
+ "integrity": "sha512-IkpVW/ehM1hWKln4fCA3NzJU8KwD+kIOvPZA4cqxoJHtE21CCzjyp+Kxbu0i5I4tBNOlXPL9mjwnWlL0VEG4Fg==",
+ "requires": {}
+ },
+ "@es-joy/jsdoccomment": {
+ "version": "0.20.1",
+ "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.20.1.tgz",
+ "integrity": "sha512-oeJK41dcdqkvdZy/HctKklJNkt/jh+av3PZARrZEl+fs/8HaHeeYoAvEwOV0u5I6bArTF17JEsTZMY359e/nfQ==",
+ "dev": true,
+ "requires": {
+ "comment-parser": "1.3.0",
+ "esquery": "^1.4.0",
+ "jsdoc-type-pratt-parser": "~2.2.3"
+ }
+ },
+ "@eslint/eslintrc": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.3.0.tgz",
+ "integrity": "sha512-UWW0TMTmk2d7hLcWD1/e2g5HDM/HQ3csaLSqXCfqwh4uNDuNqlaKWXmEsL4Cs41Z0KnILNvwbHAah3C2yt06kw==",
+ "dev": true,
+ "requires": {
+ "ajv": "^6.12.4",
+ "debug": "^4.3.2",
+ "espree": "^9.3.2",
+ "globals": "^13.15.0",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.2.1",
+ "js-yaml": "^4.1.0",
+ "minimatch": "^3.1.2",
+ "strip-json-comments": "^3.1.1"
+ },
+ "dependencies": {
+ "globals": {
+ "version": "13.17.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-13.17.0.tgz",
+ "integrity": "sha512-1C+6nQRb1GwGMKm2dH/E7enFAMxGTmGI7/dEdhy/DNelv85w9B72t3uc5frtMNXIbzrarJJ/lTCjcaZwbLJmyw==",
+ "dev": true,
+ "requires": {
+ "type-fest": "^0.20.2"
+ }
+ }
+ }
+ },
+ "@humanwhocodes/config-array": {
+ "version": "0.9.5",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.5.tgz",
+ "integrity": "sha512-ObyMyWxZiCu/yTisA7uzx81s40xR2fD5Cg/2Kq7G02ajkNubJf6BopgDTmDyc3U7sXpNKM8cYOw7s7Tyr+DnCw==",
+ "dev": true,
+ "requires": {
+ "@humanwhocodes/object-schema": "^1.2.1",
+ "debug": "^4.1.1",
+ "minimatch": "^3.0.4"
+ }
+ },
+ "@humanwhocodes/object-schema": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz",
+ "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==",
+ "dev": true
+ },
+ "@jridgewell/gen-mapping": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz",
+ "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==",
+ "devOptional": true,
+ "requires": {
+ "@jridgewell/set-array": "^1.0.0",
+ "@jridgewell/sourcemap-codec": "^1.4.10"
+ }
+ },
+ "@jridgewell/resolve-uri": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz",
+ "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w=="
+ },
+ "@jridgewell/set-array": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz",
+ "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw=="
+ },
+ "@jridgewell/source-map": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.2.tgz",
+ "integrity": "sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==",
+ "requires": {
+ "@jridgewell/gen-mapping": "^0.3.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "dependencies": {
+ "@jridgewell/gen-mapping": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz",
+ "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==",
+ "requires": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ }
+ }
+ },
+ "@jridgewell/sourcemap-codec": {
+ "version": "1.4.14",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz",
+ "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw=="
+ },
+ "@jridgewell/trace-mapping": {
+ "version": "0.3.14",
+ "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz",
+ "integrity": "sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ==",
+ "requires": {
+ "@jridgewell/resolve-uri": "^3.0.3",
+ "@jridgewell/sourcemap-codec": "^1.4.10"
+ }
+ },
+ "@league-of-foundry-developers/foundry-vtt-types": {
+ "version": "9.269.0",
+ "resolved": "https://registry.npmjs.org/@league-of-foundry-developers/foundry-vtt-types/-/foundry-vtt-types-9.269.0.tgz",
+ "integrity": "sha512-M/rz86decPLXet9e6+bi0dm8WSGrT/5MM1QXUMEC7Z8vfKB9Y5D61B1J5laaqb3DdjVDS1kZtQEW3/sPg3EALw==",
+ "dev": true,
+ "requires": {
+ "@pixi/graphics-smooth": "0.0.22",
+ "@types/jquery": "~3.5.9",
+ "@types/simple-peer": "~9.11.1",
+ "handlebars": "4.7.7",
+ "pixi-particles": "4.3.1",
+ "pixi.js": "5.3.11",
+ "socket.io-client": "4.3.2",
+ "tinymce": "5.10.1"
+ }
+ },
+ "@pixi/accessibility": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/accessibility/-/accessibility-5.3.11.tgz",
+ "integrity": "sha512-/oSizd8/g6KUCeAlknMLJ9CRxBt+vWs6e2DrOctMoRupEHcmhICCjIyAp5GF6RZy9T9gNHDOU5p7vo7qEyVxgQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/app": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/app/-/app-5.3.11.tgz",
+ "integrity": "sha512-ZWrOjGvVl+lK5OJQT3OqSnSRtU2XgQSe/ULg2uGsSWUqMkJews33JIGOjvk4tIsjm4ekSKiPZRMdYFHzPfgEJg==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/constants": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-6.5.0.tgz",
+ "integrity": "sha512-rr2szhjkM/TEHFcq+I3sg3uvRDRCC+ggO0lOvbHt3B84QdSGltndI4GSefSRpmvb5KbrZP7R0NO6UY7AZ0NqQg==",
+ "dev": true,
+ "peer": true
+ },
+ "@pixi/core": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-6.5.0.tgz",
+ "integrity": "sha512-73dceDRGvdMs/i9t9sNAVKK2lkPZ/olaLp+Xa2vo+BsaBdr5e+11vnAzT7XUtZyGjWOm3o1KXABZ6jr9AuKdkg==",
+ "dev": true,
+ "peer": true,
+ "requires": {
+ "@types/offscreencanvas": "^2019.6.4"
+ }
+ },
+ "@pixi/display": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-6.5.0.tgz",
+ "integrity": "sha512-ksjGtleam+p319teRT1FL7MSwJ1w5L5xWyq1w8QIREKNxHuI8lOfYgxPABo6HUI8FZ4AysifnfAdnxDqbPtauw==",
+ "dev": true,
+ "peer": true,
+ "requires": {}
+ },
+ "@pixi/extract": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/extract/-/extract-5.3.11.tgz",
+ "integrity": "sha512-YeBrpIO3E5HUgcdKEldCUqwwDNHm5OBe98YFcdLr5Z0+dQaHnxp9Dm4n75/NojoGb5guYdrV00x+gU2UPHsVdw==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/filter-alpha": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-alpha/-/filter-alpha-5.3.11.tgz",
+ "integrity": "sha512-HC4PbiEqDWSi3A715av7knFqD3knSXRxPJKG9mWat2CU9eCizSw+JxXp/okMU/fL4ewooiqQWVU2l1wXOHhVFw==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/filter-blur": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-blur/-/filter-blur-5.3.11.tgz",
+ "integrity": "sha512-iW5cOMEcDiJidOV95bUfhxdcvwM9JzCoWAd+92gAie8L+ElRSHpu1jxXbKHjo/QczQV1LulOlheyDaJNpaBCDg==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/settings": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/filter-color-matrix": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-color-matrix/-/filter-color-matrix-5.3.11.tgz",
+ "integrity": "sha512-u9NT4+N1I3XV9ygwsmF8/jIwCLqNCLeFOdM4f73kbw/UmakZZ6i6xjjJMc5YFUpC25qDr1TFlqgdGGGHAPl4ug==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/filter-displacement": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-displacement/-/filter-displacement-5.3.11.tgz",
+ "integrity": "sha512-CTIy7C/L9I1X3VNx4nMzQbMFvznsGk2viQh0dSo8r5NLgmaAdxhkGI0KUpNjLBz30278tzFfNuRe59K1y1kHuw==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/math": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/filter-fxaa": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-fxaa/-/filter-fxaa-5.3.11.tgz",
+ "integrity": "sha512-0ahjui5385e1vRvd7zCc0n5W8ULtNI1uVbDJHP9ueeiF25TKC0GqtZzntNwrQPoU46q8zXdnIGjzMpikbbAasg==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/filter-noise": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/filter-noise/-/filter-noise-5.3.11.tgz",
+ "integrity": "sha512-98WC9Nd5u2F03Ned9T3vnbmO/YF1jLSioZ623z9wjqpd5DosZgRtYTSGxjVcXTSfpviIuiJpkyF+X097pbVprg==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/graphics": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/graphics/-/graphics-6.5.0.tgz",
+ "integrity": "sha512-8AoZDLlZtCQ2x/XmjnjdMUfri0L3oUoDWcMoa1CSqqzHBUhpWqrn5f/VeJnSS7xGixpGe1XeJXWwRoxSwN2D7A==",
+ "dev": true,
+ "peer": true,
+ "requires": {}
+ },
+ "@pixi/graphics-smooth": {
+ "version": "0.0.22",
+ "resolved": "https://registry.npmjs.org/@pixi/graphics-smooth/-/graphics-smooth-0.0.22.tgz",
+ "integrity": "sha512-qq2u+BJBIDBuuSTc2Xzm1D/8RiiKBdxnVDiMb7Go5v8achnV5ctC6m+rf8Mq0sWm66mbOqu1aq/9efT4A4sPrA==",
+ "dev": true,
+ "requires": {}
+ },
+ "@pixi/interaction": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/interaction/-/interaction-5.3.11.tgz",
+ "integrity": "sha512-n2K99CYyBcrf8NPxpzmZ5IlJ9TEplsSZfJ/uzMNOEnTObKl4wAhxs51Nb58raH3Ouzwu14YHOpqYrBTEoT1yPA==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/loaders": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/loaders/-/loaders-5.3.11.tgz",
+ "integrity": "sha512-1HAeb/NFXyhNhZWAbVkngsTPBGpjZEPhQflBTrKycRaub7XDSZ8F0fwPltpKKVRWNDT+HBgU/zDNE2fpjzqfYg==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/utils": "5.3.11",
+ "resource-loader": "^3.0.1"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/math": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-6.5.0.tgz",
+ "integrity": "sha512-NWOxO8my4KxdCyrR4UJGchwDkpWortMy8zUtXuds+92I+5fpBfctVkshf45o9QX2yX4pbtCPs0VupI2i5G3AOQ==",
+ "dev": true,
+ "peer": true
+ },
+ "@pixi/mesh": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mesh/-/mesh-5.3.11.tgz",
+ "integrity": "sha512-KWKKksEr0YuUX1uz1FmpIa/Y37b/0pvFUS+87LoyYq0mRtGbKsTY5i3lBPG/taHwN7a2DQAX3JZpw6yhGKoGpA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/mesh-extras": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mesh-extras/-/mesh-extras-5.3.11.tgz",
+ "integrity": "sha512-1GTCMMUW1xv/72x26cxRysblBXW0wU77TNgqtSIMZ1M6JbleObChklWTvwi9MzQO2vQ3S6Hvcsa5m5EiM2hSPQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/mesh": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/mixin-cache-as-bitmap": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mixin-cache-as-bitmap/-/mixin-cache-as-bitmap-5.3.11.tgz",
+ "integrity": "sha512-uQUxatGTTD5zfQ0pWdjibVjT+xEEZJ/xZDZtm/GxC7HSHd4jgoJBcTXWVhbhzwpLPVTnD8+sMnRrGlhoKcpTpQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/mixin-get-child-by-name": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mixin-get-child-by-name/-/mixin-get-child-by-name-5.3.11.tgz",
+ "integrity": "sha512-fWFVxWtMYcwJttrgDNmZ4CJrx316p8ToNliC2ILmJZW77me7I4GzJ57gSHQU1xFwdHoOYRC4fnlrZoK5qJ9lDw==",
+ "dev": true,
+ "requires": {
+ "@pixi/display": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/mixin-get-global-position": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/mixin-get-global-position/-/mixin-get-global-position-5.3.11.tgz",
+ "integrity": "sha512-wrS9i+UUodLM5XL2N0Y+XSKiqLRdJV3ltFUWG6+jPT5yoP0HsKtx3sFAzX526RwIYwRzRusbc/quxHfRA4tvgg==",
+ "dev": true,
+ "requires": {
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/particles": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/particles/-/particles-5.3.11.tgz",
+ "integrity": "sha512-+mkt/inWXtRrxQc07RZ29uNIDWV1oMsrRBVBIvHgpR92Kn8EjIDRgoSXNu0jiZ18gRKKCBhwsS4dCXGsZRQ/sA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/polyfill": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/polyfill/-/polyfill-5.3.11.tgz",
+ "integrity": "sha512-yQOngcnn+2/L7n6L/g45hCnIDLWdnWmmcCY3UKJrOgbNX+JtLru1RR8AGLifkdsa0R5u48x584YQGqkTAChWVA==",
+ "dev": true,
+ "requires": {
+ "es6-promise-polyfill": "^1.2.0",
+ "object-assign": "^4.1.1"
+ }
+ },
+ "@pixi/prepare": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/prepare/-/prepare-5.3.11.tgz",
+ "integrity": "sha512-TvjGeg7xPKjv5NxbM5NXReno9yxUCw/N0HtDEtEFRVeBLN3u0Q/dZsXxL6gIvkHoS09NFW+7AwsYQLZrVbppjA==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/graphics": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/text": "5.3.11",
+ "@pixi/ticker": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/graphics": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/graphics/-/graphics-5.3.11.tgz",
+ "integrity": "sha512-HLu53LV6mRlY0uFSIM2OrCuL7xqXzeJs5d2QfmUJfKJVVZ9sbHDS+6/N/f0tXzvkRPYhSKXvcNPsNn4HmlIE9w==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/runner": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-6.5.0.tgz",
+ "integrity": "sha512-jZEilMPQlROJgRvRaJZcxp/K3adn4gx2mXwqK8DPqAcc5epwLzF8D4Us20PmY+7ALTglMdFZ7hHQKAPngi/jRA==",
+ "dev": true,
+ "peer": true
+ },
+ "@pixi/settings": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-6.5.0.tgz",
+ "integrity": "sha512-fXbFYNJGv1v0ZS0kypziKFh2LJfI16aRBvqDqLFPvB0fkRkEOJuRTU4Lq77shgzP5v20oz7JShoVxyN5X9VNSw==",
+ "dev": true,
+ "peer": true
+ },
+ "@pixi/sprite": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-6.5.0.tgz",
+ "integrity": "sha512-hxoH6poGBU+pZ4uC3rUuu9BXaFGrxZcyDu48/5ZYXjNC5HcCNPycmffalEkPcDQF7ymr7/3vTZ73mybcq9EIMA==",
+ "dev": true,
+ "peer": true,
+ "requires": {}
+ },
+ "@pixi/sprite-animated": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite-animated/-/sprite-animated-5.3.11.tgz",
+ "integrity": "sha512-xU1b6H8nJ1l05h7cBGw2DGo4QdLj7xootstZUx2BrTVX5ZENn5mjAGVD0uRpk8yt7Q6Bj7M+PS7ktzAgBW/hmQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/ticker": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/sprite-tiling": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite-tiling/-/sprite-tiling-5.3.11.tgz",
+ "integrity": "sha512-KUiWsIumjrnp9QKGMe1BqtrV9Hxm91KoaiOlCBk/gw8753iKvuMmH+/Z0RnzeZylJ1sJsdonTWy/IaLi1jnd0g==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/spritesheet": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/spritesheet/-/spritesheet-5.3.11.tgz",
+ "integrity": "sha512-Y9Wiwcz/YOuS1v73Ij9KWQakYBzZfldEy3H8T4GPLK+S19/sypntdkNtRZbmR2wWfhJ4axYEB2/Df86aOAU2qA==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/loaders": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/text": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/text/-/text-5.3.11.tgz",
+ "integrity": "sha512-PmWvJv0wiKyyz3fahnxM19+m8IbF2vpDKIImqb5472WyxRGzKyVBW90xrADf5202tdKMk4b8hqvpof2XULr5PA==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/sprite": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/text-bitmap": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/text-bitmap/-/text-bitmap-5.3.11.tgz",
+ "integrity": "sha512-Bjc/G4VHaPXc9HJsvyYOm5cNTHdqmX6AgzBAlCfltuMAlnveUgUPuX8D/MJHRRnoVSDHSmCBtnJgTc0y/nIeCw==",
+ "dev": true,
+ "requires": {
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/loaders": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/mesh": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/text": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
+ "@pixi/constants": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
+ },
+ "@pixi/core": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/display": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
+ },
+ "@pixi/math": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
+ },
+ "@pixi/runner": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
+ },
+ "@pixi/settings": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
+ },
+ "@pixi/ticker": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
+ },
+ "@pixi/utils": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "@pixi/ticker": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-6.5.0.tgz",
+ "integrity": "sha512-sPoE2ra5bAS6WpFdHgAUzu2jDjW8bGuHlEtK+uQtD5KF07JViDEPnBqFXPWgZYHimnIFBnYw7+OtxPM1kTeKmQ==",
+ "dev": true,
+ "peer": true,
+ "requires": {}
+ },
+ "@pixi/utils": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-6.5.0.tgz",
+ "integrity": "sha512-ttJZwTh2LhvwMt4WkU6HAWh6UE3ELGds+DQW29KW2yrKZnUEMsA2Jnsq7uFn6x6LM7tzBvJbzGvTyKgFL/jvVg==",
+ "dev": true,
+ "peer": true,
+ "requires": {
+ "@types/earcut": "^2.1.0",
+ "earcut": "^2.2.4",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ },
+ "@rollup/plugin-babel": {
+ "version": "5.3.1",
+ "resolved": "https://registry.npmjs.org/@rollup/plugin-babel/-/plugin-babel-5.3.1.tgz",
+ "integrity": "sha512-WFfdLWU/xVWKeRQnKmIAQULUI7Il0gZnBIH/ZFO069wYIfPu+8zrfp/KMW0atmELoRDq8FbiP3VCss9MhCut7Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-imports": "^7.10.4",
+ "@rollup/pluginutils": "^3.1.0"
+ }
+ },
+ "@rollup/plugin-node-resolve": {
+ "version": "13.3.0",
+ "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-13.3.0.tgz",
+ "integrity": "sha512-Lus8rbUo1eEcnS4yTFKLZrVumLPY+YayBdWXgFSHYhTT2iJbMhoaaBL3xl5NCdeRytErGr8tZ0L71BMRmnlwSw==",
+ "requires": {
+ "@rollup/pluginutils": "^3.1.0",
+ "@types/resolve": "1.17.1",
+ "deepmerge": "^4.2.2",
+ "is-builtin-module": "^3.1.0",
+ "is-module": "^1.0.0",
+ "resolve": "^1.19.0"
+ }
+ },
+ "@rollup/pluginutils": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz",
+ "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==",
+ "requires": {
+ "@types/estree": "0.0.39",
+ "estree-walker": "^1.0.1",
+ "picomatch": "^2.2.2"
+ }
+ },
+ "@socket.io/component-emitter": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/@socket.io/component-emitter/-/component-emitter-3.0.0.tgz",
+ "integrity": "sha512-2pTGuibAXJswAPJjaKisthqS/NOK5ypG4LYT6tEAV0S/mxW0zOIvYvGK0V8w8+SHxAm6vRMSjqSalFXeBAqs+Q==",
+ "dev": true
+ },
+ "@sveltejs/vite-plugin-svelte": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte/-/vite-plugin-svelte-1.0.1.tgz",
+ "integrity": "sha512-PorCgUounn0VXcpeJu+hOweZODKmGuLHsLomwqSj+p26IwjjGffmYQfVHtiTWq+NqaUuuHWWG7vPge6UFw4Aeg==",
+ "requires": {
+ "@rollup/pluginutils": "^4.2.1",
+ "debug": "^4.3.4",
+ "deepmerge": "^4.2.2",
+ "kleur": "^4.1.5",
+ "magic-string": "^0.26.2",
+ "svelte-hmr": "^0.14.12"
+ },
+ "dependencies": {
+ "@rollup/pluginutils": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-4.2.1.tgz",
+ "integrity": "sha512-iKnFXr7NkdZAIHiIWE+BX5ULi/ucVFYWD6TbAV+rZctiRTY2PL6tsIKhoIOaoskiWAkgu+VsbXgUVDNLHf+InQ==",
+ "requires": {
+ "estree-walker": "^2.0.1",
+ "picomatch": "^2.2.2"
+ }
+ },
+ "estree-walker": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz",
+ "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w=="
+ }
+ }
+ },
+ "@trysound/sax": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/@trysound/sax/-/sax-0.2.0.tgz",
+ "integrity": "sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA=="
+ },
+ "@types/earcut": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/@types/earcut/-/earcut-2.1.1.tgz",
+ "integrity": "sha512-w8oigUCDjElRHRRrMvn/spybSMyX8MTkKA5Dv+tS1IE/TgmNZPqUYtvYBXGY8cieSE66gm+szeK+bnbxC2xHTQ==",
+ "dev": true,
+ "peer": true
+ },
+ "@types/estree": {
+ "version": "0.0.39",
+ "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz",
+ "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw=="
+ },
+ "@types/jquery": {
+ "version": "3.5.14",
+ "resolved": "https://registry.npmjs.org/@types/jquery/-/jquery-3.5.14.tgz",
+ "integrity": "sha512-X1gtMRMbziVQkErhTQmSe2jFwwENA/Zr+PprCkF63vFq+Yt5PZ4AlKqgmeNlwgn7dhsXEK888eIW2520EpC+xg==",
+ "dev": true,
+ "requires": {
+ "@types/sizzle": "*"
+ }
+ },
+ "@types/node": {
+ "version": "18.0.6",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-18.0.6.tgz",
+ "integrity": "sha512-/xUq6H2aQm261exT6iZTMifUySEt4GR5KX8eYyY+C4MSNPqSh9oNIP7tz2GLKTlFaiBbgZNxffoR3CVRG+cljw=="
+ },
+ "@types/offscreencanvas": {
+ "version": "2019.7.0",
+ "resolved": "https://registry.npmjs.org/@types/offscreencanvas/-/offscreencanvas-2019.7.0.tgz",
+ "integrity": "sha512-PGcyveRIpL1XIqK8eBsmRBt76eFgtzuPiSTyKHZxnGemp2yzGzWpjYKAfK3wIMiU7eH+851yEpiuP8JZerTmWg==",
+ "dev": true,
+ "peer": true
+ },
+ "@types/pug": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/@types/pug/-/pug-2.0.6.tgz",
+ "integrity": "sha512-SnHmG9wN1UVmagJOnyo/qkk0Z7gejYxOYYmaAwr5u2yFYfsupN3sg10kyzN8Hep/2zbHxCnsumxOoRIRMBwKCg=="
+ },
+ "@types/resolve": {
+ "version": "1.17.1",
+ "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.17.1.tgz",
+ "integrity": "sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==",
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/sass": {
+ "version": "1.43.1",
+ "resolved": "https://registry.npmjs.org/@types/sass/-/sass-1.43.1.tgz",
+ "integrity": "sha512-BPdoIt1lfJ6B7rw35ncdwBZrAssjcwzI5LByIrYs+tpXlj/CAkuVdRsgZDdP4lq5EjyWzwxZCqAoFyHKFwp32g==",
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/simple-peer": {
+ "version": "9.11.4",
+ "resolved": "https://registry.npmjs.org/@types/simple-peer/-/simple-peer-9.11.4.tgz",
+ "integrity": "sha512-Elje14YvM47k+XEaoyRAeUSvZN7TOLWYL233QCckUaXjT4lRESHnYs0iOK2JoosO5DnCvWu/0Vpl9qnw4KCLWw==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/sizzle": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/@types/sizzle/-/sizzle-2.3.3.tgz",
+ "integrity": "sha512-JYM8x9EGF163bEyhdJBpR2QX1R5naCJHC8ucJylJ3w9/CVBaskdQ8WqBf8MmQrd1kRvp/a4TS8HJ+bxzR7ZJYQ==",
+ "dev": true
+ },
+ "@typhonjs-config/eslint-config": {
+ "version": "0.3.4",
+ "resolved": "https://registry.npmjs.org/@typhonjs-config/eslint-config/-/eslint-config-0.3.4.tgz",
+ "integrity": "sha512-GGEjrOevGjBRZFM0b18AxtHbk2Ifuv3sx1AS8SLXKwWJo7zWRRfQiEInuIJ+O0g85Js4OP+magm/Lm4b5h6GSQ==",
+ "dev": true,
+ "requires": {
+ "eslint-plugin-jsdoc": "^37"
+ }
+ },
+ "@typhonjs-fvtt/eslint-config-foundry.js": {
+ "version": "0.8.0",
+ "resolved": "https://registry.npmjs.org/@typhonjs-fvtt/eslint-config-foundry.js/-/eslint-config-foundry.js-0.8.0.tgz",
+ "integrity": "sha512-Fu1XDS747exX5zVwty4VSwlOwkuzdnnN15C5w66uG4hOpJnPCZU/jcyEOCf9bazRPp06Smimn+mKd9OjrCvuuw==",
+ "dev": true
+ },
+ "@typhonjs-fvtt/runtime": {
+ "version": "0.0.19",
+ "resolved": "https://registry.npmjs.org/@typhonjs-fvtt/runtime/-/runtime-0.0.19.tgz",
+ "integrity": "sha512-8tuNDar/exfruiT45np7PYLvGUfihqyuYrekNn3rwo6prwOSise1J2Jr7c0VstrrJfprYPhBGQmGyJSkihZJtA==",
+ "requires": {
+ "@rollup/plugin-node-resolve": "^13",
+ "@sveltejs/vite-plugin-svelte": "^1",
+ "autoprefixer": "^10",
+ "cssnano": "^5",
+ "postcss": "^8",
+ "postcss-preset-env": "^7",
+ "rollup-plugin-postcss": "^4",
+ "rollup-plugin-sourcemaps": "^0.6",
+ "rollup-plugin-svelte": "^7",
+ "rollup-plugin-terser": "^7",
+ "sass": "^1"
+ }
+ },
+ "@typhonjs-fvtt/svelte-standard": {
+ "version": "0.0.9",
+ "resolved": "https://registry.npmjs.org/@typhonjs-fvtt/svelte-standard/-/svelte-standard-0.0.9.tgz",
+ "integrity": "sha512-vhpisaTwuWcd2V1UQbIx96pkXhXe+7HhIsng2Nm5QvGA+bvYFkY3ruUSDj9b88pivo+UCnwaj7wN+xOfBW5Jng=="
+ },
+ "acorn": {
+ "version": "8.8.0",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.0.tgz",
+ "integrity": "sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w=="
+ },
+ "acorn-jsx": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
+ "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
+ "dev": true,
+ "requires": {}
+ },
+ "ajv": {
+ "version": "6.12.6",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
+ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
+ "dev": true,
+ "requires": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ }
+ },
+ "ansi-regex": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
+ "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
+ "dev": true
+ },
+ "ansi-styles": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
+ "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
+ "requires": {
+ "color-convert": "^1.9.0"
+ }
+ },
+ "anymatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz",
+ "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==",
+ "requires": {
+ "normalize-path": "^3.0.0",
+ "picomatch": "^2.0.4"
+ }
+ },
+ "argparse": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
+ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
+ "dev": true
+ },
+ "atob": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz",
+ "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg=="
+ },
+ "autoprefixer": {
+ "version": "10.4.7",
+ "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.7.tgz",
+ "integrity": "sha512-ypHju4Y2Oav95SipEcCcI5J7CGPuvz8oat7sUtYj3ClK44bldfvtvcxK6IEK++7rqB7YchDGzweZIBG+SD0ZAA==",
+ "requires": {
+ "browserslist": "^4.20.3",
+ "caniuse-lite": "^1.0.30001335",
+ "fraction.js": "^4.2.0",
+ "normalize-range": "^0.1.2",
+ "picocolors": "^1.0.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "babel-plugin-dynamic-import-node": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz",
+ "integrity": "sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ==",
+ "dev": true,
+ "requires": {
+ "object.assign": "^4.1.0"
+ }
+ },
+ "babel-plugin-polyfill-corejs2": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.2.tgz",
+ "integrity": "sha512-LPnodUl3lS0/4wN3Rb+m+UK8s7lj2jcLRrjho4gLw+OJs+I4bvGXshINesY5xx/apM+biTnQ9reDI8yj+0M5+Q==",
+ "dev": true,
+ "requires": {
+ "@babel/compat-data": "^7.17.7",
+ "@babel/helper-define-polyfill-provider": "^0.3.2",
+ "semver": "^6.1.1"
+ }
+ },
+ "babel-plugin-polyfill-corejs3": {
+ "version": "0.5.3",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.5.3.tgz",
+ "integrity": "sha512-zKsXDh0XjnrUEW0mxIHLfjBfnXSMr5Q/goMe/fxpQnLm07mcOZiIZHBNWCMx60HmdvjxfXcalac0tfFg0wqxyw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-define-polyfill-provider": "^0.3.2",
+ "core-js-compat": "^3.21.0"
+ }
+ },
+ "babel-plugin-polyfill-regenerator": {
+ "version": "0.3.1",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.3.1.tgz",
+ "integrity": "sha512-Y2B06tvgHYt1x0yz17jGkGeeMr5FeKUu+ASJ+N6nB5lQ8Dapfg42i0OVrf8PNGJ3zKL4A23snMi1IRwrqqND7A==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-define-polyfill-provider": "^0.3.1"
+ }
+ },
+ "backo2": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz",
+ "integrity": "sha512-zj6Z6M7Eq+PBZ7PQxl5NT665MvJdAkzp0f60nAJ+sLaSCBPMwVak5ZegFbgVCzFcCJTKFoMizvM5Ld7+JrRJHA==",
+ "dev": true
+ },
+ "balanced-match": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
+ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw=="
+ },
+ "binary-extensions": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
+ "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA=="
+ },
+ "boolbase": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz",
+ "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww=="
+ },
+ "brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "requires": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "braces": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
+ "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
+ "requires": {
+ "fill-range": "^7.0.1"
+ }
+ },
+ "browserslist": {
+ "version": "4.21.2",
+ "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.2.tgz",
+ "integrity": "sha512-MonuOgAtUB46uP5CezYbRaYKBNt2LxP0yX+Pmj4LkcDFGkn9Cbpi83d9sCjwQDErXsIJSzY5oKGDbgOlF/LPAA==",
+ "requires": {
+ "caniuse-lite": "^1.0.30001366",
+ "electron-to-chromium": "^1.4.188",
+ "node-releases": "^2.0.6",
+ "update-browserslist-db": "^1.0.4"
+ }
+ },
+ "buffer-crc32": {
+ "version": "0.2.13",
+ "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz",
+ "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ=="
+ },
+ "buffer-from": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
+ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ=="
+ },
+ "builtin-modules": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.3.0.tgz",
+ "integrity": "sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw=="
+ },
+ "call-bind": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz",
+ "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==",
+ "dev": true,
+ "requires": {
+ "function-bind": "^1.1.1",
+ "get-intrinsic": "^1.0.2"
+ }
+ },
+ "callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "dev": true
+ },
+ "caniuse-api": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz",
+ "integrity": "sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw==",
+ "requires": {
+ "browserslist": "^4.0.0",
+ "caniuse-lite": "^1.0.0",
+ "lodash.memoize": "^4.1.2",
+ "lodash.uniq": "^4.5.0"
+ }
+ },
+ "caniuse-lite": {
+ "version": "1.0.30001369",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001369.tgz",
+ "integrity": "sha512-OY1SBHaodJc4wflDIKnlkdqWzJZd1Ls/2zbVJHBSv3AT7vgOJ58yAhd2CN4d57l2kPJrgMb7P9+N1Mhy4tNSQA=="
+ },
+ "chalk": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
+ "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
+ "requires": {
+ "ansi-styles": "^3.2.1",
+ "escape-string-regexp": "^1.0.5",
+ "supports-color": "^5.3.0"
+ }
+ },
+ "chokidar": {
+ "version": "3.5.3",
+ "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
+ "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
+ "requires": {
+ "anymatch": "~3.1.2",
+ "braces": "~3.0.2",
+ "fsevents": "~2.3.2",
+ "glob-parent": "~5.1.2",
+ "is-binary-path": "~2.1.0",
+ "is-glob": "~4.0.1",
+ "normalize-path": "~3.0.0",
+ "readdirp": "~3.6.0"
+ },
+ "dependencies": {
+ "glob-parent": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
+ "requires": {
+ "is-glob": "^4.0.1"
+ }
+ }
+ }
+ },
+ "color-convert": {
+ "version": "1.9.3",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
+ "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
+ "requires": {
+ "color-name": "1.1.3"
+ }
+ },
+ "color-name": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
+ "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw=="
+ },
+ "colord": {
+ "version": "2.9.2",
+ "resolved": "https://registry.npmjs.org/colord/-/colord-2.9.2.tgz",
+ "integrity": "sha512-Uqbg+J445nc1TKn4FoDPS6ZZqAvEDnwrH42yo8B40JSOgSLxMZ/gt3h4nmCtPLQeXhjJJkqBx7SCY35WnIixaQ=="
+ },
+ "commander": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz",
+ "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw=="
+ },
+ "comment-parser": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/comment-parser/-/comment-parser-1.3.0.tgz",
+ "integrity": "sha512-hRpmWIKgzd81vn0ydoWoyPoALEOnF4wt8yKD35Ib1D6XC2siLiYaiqfGkYrunuKdsXGwpBpHU3+9r+RVw2NZfA==",
+ "dev": true
+ },
+ "concat-map": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
+ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg=="
+ },
+ "concat-with-sourcemaps": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/concat-with-sourcemaps/-/concat-with-sourcemaps-1.1.0.tgz",
+ "integrity": "sha512-4gEjHJFT9e+2W/77h/DS5SGUgwDaOwprX8L/gl5+3ixnzkVJJsZWDSelmN3Oilw3LNDZjZV0yqH1hLG3k6nghg==",
+ "requires": {
+ "source-map": "^0.6.1"
+ }
+ },
+ "convert-source-map": {
+ "version": "1.8.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz",
+ "integrity": "sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==",
+ "devOptional": true,
+ "requires": {
+ "safe-buffer": "~5.1.1"
+ }
+ },
+ "core-js-compat": {
+ "version": "3.23.5",
+ "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.23.5.tgz",
+ "integrity": "sha512-fHYozIFIxd+91IIbXJgWd/igXIc8Mf9is0fusswjnGIWVG96y2cwyUdlCkGOw6rMLHKAxg7xtCIVaHsyOUnJIg==",
+ "dev": true,
+ "requires": {
+ "browserslist": "^4.21.2",
+ "semver": "7.0.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz",
+ "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==",
+ "dev": true
+ }
+ }
+ },
+ "cross-spawn": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
+ "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
+ "dev": true,
+ "requires": {
+ "path-key": "^3.1.0",
+ "shebang-command": "^2.0.0",
+ "which": "^2.0.1"
+ }
+ },
+ "css-blank-pseudo": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/css-blank-pseudo/-/css-blank-pseudo-3.0.3.tgz",
+ "integrity": "sha512-VS90XWtsHGqoM0t4KpH053c4ehxZ2E6HtGI7x68YFV0pTo/QmkV/YFA+NnlvK8guxZVNWGQhVNJGC39Q8XF4OQ==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.9"
+ }
+ },
+ "css-declaration-sorter": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/css-declaration-sorter/-/css-declaration-sorter-6.3.0.tgz",
+ "integrity": "sha512-OGT677UGHJTAVMRhPO+HJ4oKln3wkBTwtDFH0ojbqm+MJm6xuDMHp2nkhh/ThaBqq20IbraBQSWKfSLNHQO9Og==",
+ "requires": {}
+ },
+ "css-has-pseudo": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/css-has-pseudo/-/css-has-pseudo-3.0.4.tgz",
+ "integrity": "sha512-Vse0xpR1K9MNlp2j5w1pgWIJtm1a8qS0JwS9goFYcImjlHEmywP9VUF05aGBXzGpDJF86QXk4L0ypBmwPhGArw==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.9"
+ }
+ },
+ "css-prefers-color-scheme": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/css-prefers-color-scheme/-/css-prefers-color-scheme-6.0.3.tgz",
+ "integrity": "sha512-4BqMbZksRkJQx2zAjrokiGMd07RqOa2IxIrrN10lyBe9xhn9DEvjUK79J6jkeiv9D9hQFXKb6g1jwU62jziJZA==",
+ "requires": {}
+ },
+ "css-select": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/css-select/-/css-select-4.3.0.tgz",
+ "integrity": "sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==",
+ "requires": {
+ "boolbase": "^1.0.0",
+ "css-what": "^6.0.1",
+ "domhandler": "^4.3.1",
+ "domutils": "^2.8.0",
+ "nth-check": "^2.0.1"
+ }
+ },
+ "css-tree": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.1.3.tgz",
+ "integrity": "sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q==",
+ "requires": {
+ "mdn-data": "2.0.14",
+ "source-map": "^0.6.1"
+ }
+ },
+ "css-what": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz",
+ "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw=="
+ },
+ "cssdb": {
+ "version": "6.6.3",
+ "resolved": "https://registry.npmjs.org/cssdb/-/cssdb-6.6.3.tgz",
+ "integrity": "sha512-7GDvDSmE+20+WcSMhP17Q1EVWUrLlbxxpMDqG731n8P99JhnQZHR9YvtjPvEHfjFUjvQJvdpKCjlKOX+xe4UVA=="
+ },
+ "cssesc": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz",
+ "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg=="
+ },
+ "cssnano": {
+ "version": "5.1.12",
+ "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-5.1.12.tgz",
+ "integrity": "sha512-TgvArbEZu0lk/dvg2ja+B7kYoD7BBCmn3+k58xD0qjrGHsFzXY/wKTo9M5egcUCabPol05e/PVoIu79s2JN4WQ==",
+ "requires": {
+ "cssnano-preset-default": "^5.2.12",
+ "lilconfig": "^2.0.3",
+ "yaml": "^1.10.2"
+ }
+ },
+ "cssnano-preset-default": {
+ "version": "5.2.12",
+ "resolved": "https://registry.npmjs.org/cssnano-preset-default/-/cssnano-preset-default-5.2.12.tgz",
+ "integrity": "sha512-OyCBTZi+PXgylz9HAA5kHyoYhfGcYdwFmyaJzWnzxuGRtnMw/kR6ilW9XzlzlRAtB6PLT/r+prYgkef7hngFew==",
+ "requires": {
+ "css-declaration-sorter": "^6.3.0",
+ "cssnano-utils": "^3.1.0",
+ "postcss-calc": "^8.2.3",
+ "postcss-colormin": "^5.3.0",
+ "postcss-convert-values": "^5.1.2",
+ "postcss-discard-comments": "^5.1.2",
+ "postcss-discard-duplicates": "^5.1.0",
+ "postcss-discard-empty": "^5.1.1",
+ "postcss-discard-overridden": "^5.1.0",
+ "postcss-merge-longhand": "^5.1.6",
+ "postcss-merge-rules": "^5.1.2",
+ "postcss-minify-font-values": "^5.1.0",
+ "postcss-minify-gradients": "^5.1.1",
+ "postcss-minify-params": "^5.1.3",
+ "postcss-minify-selectors": "^5.2.1",
+ "postcss-normalize-charset": "^5.1.0",
+ "postcss-normalize-display-values": "^5.1.0",
+ "postcss-normalize-positions": "^5.1.1",
+ "postcss-normalize-repeat-style": "^5.1.1",
+ "postcss-normalize-string": "^5.1.0",
+ "postcss-normalize-timing-functions": "^5.1.0",
+ "postcss-normalize-unicode": "^5.1.0",
+ "postcss-normalize-url": "^5.1.0",
+ "postcss-normalize-whitespace": "^5.1.1",
+ "postcss-ordered-values": "^5.1.3",
+ "postcss-reduce-initial": "^5.1.0",
+ "postcss-reduce-transforms": "^5.1.0",
+ "postcss-svgo": "^5.1.0",
+ "postcss-unique-selectors": "^5.1.1"
+ }
+ },
+ "cssnano-utils": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/cssnano-utils/-/cssnano-utils-3.1.0.tgz",
+ "integrity": "sha512-JQNR19/YZhz4psLX/rQ9M83e3z2Wf/HdJbryzte4a3NSuafyp9w/I4U+hx5C2S9g41qlstH7DEWnZaaj83OuEA==",
+ "requires": {}
+ },
+ "csso": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/csso/-/csso-4.2.0.tgz",
+ "integrity": "sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA==",
+ "requires": {
+ "css-tree": "^1.1.2"
+ }
+ },
+ "debug": {
+ "version": "4.3.4",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
+ "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
+ "requires": {
+ "ms": "2.1.2"
+ }
+ },
+ "decode-uri-component": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz",
+ "integrity": "sha512-hjf+xovcEn31w/EUYdTXQh/8smFL/dzYjohQGEIgjyNavaJfBY2p5F527Bo1VPATxv0VYTUC2bOcXvqFwk78Og=="
+ },
+ "deep-is": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
+ "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
+ "dev": true
+ },
+ "deepmerge": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz",
+ "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg=="
+ },
+ "define-properties": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz",
+ "integrity": "sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA==",
+ "dev": true,
+ "requires": {
+ "has-property-descriptors": "^1.0.0",
+ "object-keys": "^1.1.1"
+ }
+ },
+ "detect-indent": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-6.1.0.tgz",
+ "integrity": "sha512-reYkTUJAZb9gUuZ2RvVCNhVHdg62RHnJ7WJl8ftMi4diZ6NWlciOzQN88pUhSELEwflJht4oQDv0F0BMlwaYtA=="
+ },
+ "doctrine": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz",
+ "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==",
+ "dev": true,
+ "requires": {
+ "esutils": "^2.0.2"
+ }
+ },
+ "dom-serializer": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.4.1.tgz",
+ "integrity": "sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag==",
+ "requires": {
+ "domelementtype": "^2.0.1",
+ "domhandler": "^4.2.0",
+ "entities": "^2.0.0"
+ }
+ },
+ "domelementtype": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz",
+ "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw=="
+ },
+ "domhandler": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.3.1.tgz",
+ "integrity": "sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==",
+ "requires": {
+ "domelementtype": "^2.2.0"
+ }
+ },
+ "domutils": {
+ "version": "2.8.0",
+ "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.8.0.tgz",
+ "integrity": "sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==",
+ "requires": {
+ "dom-serializer": "^1.0.1",
+ "domelementtype": "^2.2.0",
+ "domhandler": "^4.2.0"
+ }
+ },
+ "earcut": {
+ "version": "2.2.4",
+ "resolved": "https://registry.npmjs.org/earcut/-/earcut-2.2.4.tgz",
+ "integrity": "sha512-/pjZsA1b4RPHbeWZQn66SWS8nZZWLQQ23oE3Eam7aroEFGEvwKAsJfZ9ytiEMycfzXWpca4FA9QIOehf7PocBQ==",
+ "dev": true
+ },
+ "electron-to-chromium": {
+ "version": "1.4.199",
+ "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.199.tgz",
+ "integrity": "sha512-WIGME0Cs7oob3mxsJwHbeWkH0tYkIE/sjkJ8ML2BYmuRcjhRl/q5kVDXG7W9LOOKwzPU5M0LBlXRq9rlSgnNlg=="
+ },
+ "engine.io-client": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/engine.io-client/-/engine.io-client-6.0.3.tgz",
+ "integrity": "sha512-IH8ZhDIwiLv0d/wXVzmjfV9Y82hbJIDhCGSVUV8o1kcpDe2I6Y3bZA3ZbJy4Ls7k7IVmcy/qn4k9RKWFhUGf5w==",
+ "dev": true,
+ "requires": {
+ "@socket.io/component-emitter": "~3.0.0",
+ "debug": "~4.3.1",
+ "engine.io-parser": "~5.0.0",
+ "has-cors": "1.1.0",
+ "parseqs": "0.0.6",
+ "parseuri": "0.0.6",
+ "ws": "~8.2.3",
+ "xmlhttprequest-ssl": "~2.0.0",
+ "yeast": "0.1.2"
+ }
+ },
+ "engine.io-parser": {
+ "version": "5.0.4",
+ "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.0.4.tgz",
+ "integrity": "sha512-+nVFp+5z1E3HcToEnO7ZIj3g+3k9389DvWtvJZz0T6/eOCPIyyxehFcedoYrZQrp0LgQbD9pPXhpMBKMd5QURg==",
+ "dev": true
+ },
+ "entities": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz",
+ "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A=="
+ },
+ "es6-promise": {
+ "version": "3.3.1",
+ "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-3.3.1.tgz",
+ "integrity": "sha512-SOp9Phqvqn7jtEUxPWdWfWoLmyt2VaJ6MpvP9Comy1MceMXqE6bxvaTu4iaxpYYPzhny28Lc+M87/c2cPK6lDg=="
+ },
+ "es6-promise-polyfill": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/es6-promise-polyfill/-/es6-promise-polyfill-1.2.0.tgz",
+ "integrity": "sha512-HHb0vydCpoclpd0ySPkRXMmBw80MRt1wM4RBJBlXkux97K7gleabZdsR0gvE1nNPM9mgOZIBTzjjXiPxf4lIqQ==",
+ "dev": true
+ },
+ "esbuild": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.49.tgz",
+ "integrity": "sha512-/TlVHhOaq7Yz8N1OJrjqM3Auzo5wjvHFLk+T8pIue+fhnhIMpfAzsG6PLVMbFveVxqD2WOp3QHei+52IMUNmCw==",
+ "requires": {
+ "esbuild-android-64": "0.14.49",
+ "esbuild-android-arm64": "0.14.49",
+ "esbuild-darwin-64": "0.14.49",
+ "esbuild-darwin-arm64": "0.14.49",
+ "esbuild-freebsd-64": "0.14.49",
+ "esbuild-freebsd-arm64": "0.14.49",
+ "esbuild-linux-32": "0.14.49",
+ "esbuild-linux-64": "0.14.49",
+ "esbuild-linux-arm": "0.14.49",
+ "esbuild-linux-arm64": "0.14.49",
+ "esbuild-linux-mips64le": "0.14.49",
+ "esbuild-linux-ppc64le": "0.14.49",
+ "esbuild-linux-riscv64": "0.14.49",
+ "esbuild-linux-s390x": "0.14.49",
+ "esbuild-netbsd-64": "0.14.49",
+ "esbuild-openbsd-64": "0.14.49",
+ "esbuild-sunos-64": "0.14.49",
+ "esbuild-windows-32": "0.14.49",
+ "esbuild-windows-64": "0.14.49",
+ "esbuild-windows-arm64": "0.14.49"
+ }
+ },
+ "esbuild-android-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-android-64/-/esbuild-android-64-0.14.49.tgz",
+ "integrity": "sha512-vYsdOTD+yi+kquhBiFWl3tyxnj2qZJsl4tAqwhT90ktUdnyTizgle7TjNx6Ar1bN7wcwWqZ9QInfdk2WVagSww==",
+ "optional": true
+ },
+ "esbuild-android-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.49.tgz",
+ "integrity": "sha512-g2HGr/hjOXCgSsvQZ1nK4nW/ei8JUx04Li74qub9qWrStlysaVmadRyTVuW32FGIpLQyc5sUjjZopj49eGGM2g==",
+ "optional": true
+ },
+ "esbuild-darwin-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.49.tgz",
+ "integrity": "sha512-3rvqnBCtX9ywso5fCHixt2GBCUsogNp9DjGmvbBohh31Ces34BVzFltMSxJpacNki96+WIcX5s/vum+ckXiLYg==",
+ "optional": true
+ },
+ "esbuild-darwin-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.49.tgz",
+ "integrity": "sha512-XMaqDxO846srnGlUSJnwbijV29MTKUATmOLyQSfswbK/2X5Uv28M9tTLUJcKKxzoo9lnkYPsx2o8EJcTYwCs/A==",
+ "optional": true
+ },
+ "esbuild-freebsd-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.49.tgz",
+ "integrity": "sha512-NJ5Q6AjV879mOHFri+5lZLTp5XsO2hQ+KSJYLbfY9DgCu8s6/Zl2prWXVANYTeCDLlrIlNNYw8y34xqyLDKOmQ==",
+ "optional": true
+ },
+ "esbuild-freebsd-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.49.tgz",
+ "integrity": "sha512-lFLtgXnAc3eXYqj5koPlBZvEbBSOSUbWO3gyY/0+4lBdRqELyz4bAuamHvmvHW5swJYL7kngzIZw6kdu25KGOA==",
+ "optional": true
+ },
+ "esbuild-linux-32": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.49.tgz",
+ "integrity": "sha512-zTTH4gr2Kb8u4QcOpTDVn7Z8q7QEIvFl/+vHrI3cF6XOJS7iEI1FWslTo3uofB2+mn6sIJEQD9PrNZKoAAMDiA==",
+ "optional": true
+ },
+ "esbuild-linux-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.49.tgz",
+ "integrity": "sha512-hYmzRIDzFfLrB5c1SknkxzM8LdEUOusp6M2TnuQZJLRtxTgyPnZZVtyMeCLki0wKgYPXkFsAVhi8vzo2mBNeTg==",
+ "optional": true
+ },
+ "esbuild-linux-arm": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.49.tgz",
+ "integrity": "sha512-iE3e+ZVv1Qz1Sy0gifIsarJMQ89Rpm9mtLSRtG3AH0FPgAzQ5Z5oU6vYzhc/3gSPi2UxdCOfRhw2onXuFw/0lg==",
+ "optional": true
+ },
+ "esbuild-linux-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.49.tgz",
+ "integrity": "sha512-KLQ+WpeuY+7bxukxLz5VgkAAVQxUv67Ft4DmHIPIW+2w3ObBPQhqNoeQUHxopoW/aiOn3m99NSmSV+bs4BSsdA==",
+ "optional": true
+ },
+ "esbuild-linux-mips64le": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.49.tgz",
+ "integrity": "sha512-n+rGODfm8RSum5pFIqFQVQpYBw+AztL8s6o9kfx7tjfK0yIGF6tm5HlG6aRjodiiKkH2xAiIM+U4xtQVZYU4rA==",
+ "optional": true
+ },
+ "esbuild-linux-ppc64le": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.49.tgz",
+ "integrity": "sha512-WP9zR4HX6iCBmMFH+XHHng2LmdoIeUmBpL4aL2TR8ruzXyT4dWrJ5BSbT8iNo6THN8lod6GOmYDLq/dgZLalGw==",
+ "optional": true
+ },
+ "esbuild-linux-riscv64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.14.49.tgz",
+ "integrity": "sha512-h66ORBz+Dg+1KgLvzTVQEA1LX4XBd1SK0Fgbhhw4akpG/YkN8pS6OzYI/7SGENiN6ao5hETRDSkVcvU9NRtkMQ==",
+ "optional": true
+ },
+ "esbuild-linux-s390x": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-linux-s390x/-/esbuild-linux-s390x-0.14.49.tgz",
+ "integrity": "sha512-DhrUoFVWD+XmKO1y7e4kNCqQHPs6twz6VV6Uezl/XHYGzM60rBewBF5jlZjG0nCk5W/Xy6y1xWeopkrhFFM0sQ==",
+ "optional": true
+ },
+ "esbuild-netbsd-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.49.tgz",
+ "integrity": "sha512-BXaUwFOfCy2T+hABtiPUIpWjAeWK9P8O41gR4Pg73hpzoygVGnj0nI3YK4SJhe52ELgtdgWP/ckIkbn2XaTxjQ==",
+ "optional": true
+ },
+ "esbuild-openbsd-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.49.tgz",
+ "integrity": "sha512-lP06UQeLDGmVPw9Rg437Btu6J9/BmyhdoefnQ4gDEJTtJvKtQaUcOQrhjTq455ouZN4EHFH1h28WOJVANK41kA==",
+ "optional": true
+ },
+ "esbuild-sunos-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.49.tgz",
+ "integrity": "sha512-4c8Zowp+V3zIWje329BeLbGh6XI9c/rqARNaj5yPHdC61pHI9UNdDxT3rePPJeWcEZVKjkiAS6AP6kiITp7FSw==",
+ "optional": true
+ },
+ "esbuild-windows-32": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.49.tgz",
+ "integrity": "sha512-q7Rb+J9yHTeKr9QTPDYkqfkEj8/kcKz9lOabDuvEXpXuIcosWCJgo5Z7h/L4r7rbtTH4a8U2FGKb6s1eeOHmJA==",
+ "optional": true
+ },
+ "esbuild-windows-64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.49.tgz",
+ "integrity": "sha512-+Cme7Ongv0UIUTniPqfTX6mJ8Deo7VXw9xN0yJEN1lQMHDppTNmKwAM3oGbD/Vqff+07K2gN0WfNkMohmG+dVw==",
+ "optional": true
+ },
+ "esbuild-windows-arm64": {
+ "version": "0.14.49",
+ "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.49.tgz",
+ "integrity": "sha512-v+HYNAXzuANrCbbLFJ5nmO3m5y2PGZWLe3uloAkLt87aXiO2mZr3BTmacZdjwNkNEHuH3bNtN8cak+mzVjVPfA==",
+ "optional": true
+ },
+ "escalade": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
+ "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw=="
+ },
+ "escape-string-regexp": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
+ "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg=="
+ },
+ "eslint": {
+ "version": "8.20.0",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.20.0.tgz",
+ "integrity": "sha512-d4ixhz5SKCa1D6SCPrivP7yYVi7nyD6A4vs6HIAul9ujBzcEmZVM3/0NN/yu5nKhmO1wjp5xQ46iRfmDGlOviA==",
+ "dev": true,
+ "requires": {
+ "@eslint/eslintrc": "^1.3.0",
+ "@humanwhocodes/config-array": "^0.9.2",
+ "ajv": "^6.10.0",
+ "chalk": "^4.0.0",
+ "cross-spawn": "^7.0.2",
+ "debug": "^4.3.2",
+ "doctrine": "^3.0.0",
+ "escape-string-regexp": "^4.0.0",
+ "eslint-scope": "^7.1.1",
+ "eslint-utils": "^3.0.0",
+ "eslint-visitor-keys": "^3.3.0",
+ "espree": "^9.3.2",
+ "esquery": "^1.4.0",
+ "esutils": "^2.0.2",
+ "fast-deep-equal": "^3.1.3",
+ "file-entry-cache": "^6.0.1",
+ "functional-red-black-tree": "^1.0.1",
+ "glob-parent": "^6.0.1",
+ "globals": "^13.15.0",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.0.0",
+ "imurmurhash": "^0.1.4",
+ "is-glob": "^4.0.0",
+ "js-yaml": "^4.1.0",
+ "json-stable-stringify-without-jsonify": "^1.0.1",
+ "levn": "^0.4.1",
+ "lodash.merge": "^4.6.2",
+ "minimatch": "^3.1.2",
+ "natural-compare": "^1.4.0",
+ "optionator": "^0.9.1",
+ "regexpp": "^3.2.0",
+ "strip-ansi": "^6.0.1",
+ "strip-json-comments": "^3.1.0",
+ "text-table": "^0.2.0",
+ "v8-compile-cache": "^2.0.3"
+ },
+ "dependencies": {
+ "ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "requires": {
+ "color-convert": "^2.0.1"
+ }
+ },
+ "chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "requires": {
+ "color-name": "~1.1.4"
+ }
+ },
+ "color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "escape-string-regexp": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
+ "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
+ "dev": true
+ },
+ "globals": {
+ "version": "13.17.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-13.17.0.tgz",
+ "integrity": "sha512-1C+6nQRb1GwGMKm2dH/E7enFAMxGTmGI7/dEdhy/DNelv85w9B72t3uc5frtMNXIbzrarJJ/lTCjcaZwbLJmyw==",
+ "dev": true,
+ "requires": {
+ "type-fest": "^0.20.2"
+ }
+ },
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true
+ },
+ "supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ }
+ }
+ },
+ "eslint-plugin-jsdoc": {
+ "version": "37.9.7",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-37.9.7.tgz",
+ "integrity": "sha512-8alON8yYcStY94o0HycU2zkLKQdcS+qhhOUNQpfONHHwvI99afbmfpYuPqf6PbLz5pLZldG3Te5I0RbAiTN42g==",
+ "dev": true,
+ "requires": {
+ "@es-joy/jsdoccomment": "~0.20.1",
+ "comment-parser": "1.3.0",
+ "debug": "^4.3.3",
+ "escape-string-regexp": "^4.0.0",
+ "esquery": "^1.4.0",
+ "regextras": "^0.8.0",
+ "semver": "^7.3.5",
+ "spdx-expression-parse": "^3.0.1"
+ },
+ "dependencies": {
+ "escape-string-regexp": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
+ "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
+ "dev": true
+ },
+ "semver": {
+ "version": "7.3.7",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz",
+ "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==",
+ "dev": true,
+ "requires": {
+ "lru-cache": "^6.0.0"
+ }
+ }
+ }
+ },
+ "eslint-scope": {
+ "version": "7.1.1",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz",
+ "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==",
+ "dev": true,
+ "requires": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^5.2.0"
+ }
+ },
+ "eslint-utils": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz",
+ "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==",
+ "dev": true,
+ "requires": {
+ "eslint-visitor-keys": "^2.0.0"
+ },
+ "dependencies": {
+ "eslint-visitor-keys": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz",
+ "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==",
+ "dev": true
+ }
+ }
+ },
+ "eslint-visitor-keys": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz",
+ "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==",
+ "dev": true
+ },
+ "espree": {
+ "version": "9.3.2",
+ "resolved": "https://registry.npmjs.org/espree/-/espree-9.3.2.tgz",
+ "integrity": "sha512-D211tC7ZwouTIuY5x9XnS0E9sWNChB7IYKX/Xp5eQj3nFXhqmiUDB9q27y76oFl8jTg3pXcQx/bpxMfs3CIZbA==",
+ "dev": true,
+ "requires": {
+ "acorn": "^8.7.1",
+ "acorn-jsx": "^5.3.2",
+ "eslint-visitor-keys": "^3.3.0"
+ }
+ },
+ "esquery": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz",
+ "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==",
+ "dev": true,
+ "requires": {
+ "estraverse": "^5.1.0"
+ }
+ },
+ "esrecurse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
+ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
+ "dev": true,
+ "requires": {
+ "estraverse": "^5.2.0"
+ }
+ },
+ "estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true
+ },
+ "estree-walker": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz",
+ "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg=="
+ },
+ "esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true
+ },
+ "eventemitter3": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-3.1.2.tgz",
+ "integrity": "sha512-tvtQIeLVHjDkJYnzf2dgVMxfuSGJeM/7UCG17TT4EumTfNtF+0nebF/4zWOIkCreAbtNqhGEboB6BWrwqNaw4Q==",
+ "dev": true
+ },
+ "fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true
+ },
+ "fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true
+ },
+ "fast-levenshtein": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
+ "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
+ "dev": true
+ },
+ "file-entry-cache": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz",
+ "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==",
+ "dev": true,
+ "requires": {
+ "flat-cache": "^3.0.4"
+ }
+ },
+ "fill-range": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
+ "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
+ "requires": {
+ "to-regex-range": "^5.0.1"
+ }
+ },
+ "flat-cache": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz",
+ "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==",
+ "dev": true,
+ "requires": {
+ "flatted": "^3.1.0",
+ "rimraf": "^3.0.2"
+ }
+ },
+ "flatted": {
+ "version": "3.2.6",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.6.tgz",
+ "integrity": "sha512-0sQoMh9s0BYsm+12Huy/rkKxVu4R1+r96YX5cG44rHV0pQ6iC3Q+mkoMFaGWObMFYQxCVT+ssG1ksneA2MI9KQ==",
+ "dev": true
+ },
+ "fraction.js": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.0.tgz",
+ "integrity": "sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA=="
+ },
+ "fs.realpath": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
+ "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw=="
+ },
+ "fsevents": {
+ "version": "2.3.2",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
+ "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
+ "optional": true
+ },
+ "function-bind": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
+ "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A=="
+ },
+ "functional-red-black-tree": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz",
+ "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==",
+ "dev": true
+ },
+ "generic-names": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/generic-names/-/generic-names-4.0.0.tgz",
+ "integrity": "sha512-ySFolZQfw9FoDb3ed9d80Cm9f0+r7qj+HJkWjeD9RBfpxEVTlVhol+gvaQB/78WbwYfbnNh8nWHHBSlg072y6A==",
+ "requires": {
+ "loader-utils": "^3.2.0"
+ }
+ },
+ "gensync": {
+ "version": "1.0.0-beta.2",
+ "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
+ "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
+ "devOptional": true
+ },
+ "get-intrinsic": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.2.tgz",
+ "integrity": "sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA==",
+ "dev": true,
+ "requires": {
+ "function-bind": "^1.1.1",
+ "has": "^1.0.3",
+ "has-symbols": "^1.0.3"
+ }
+ },
+ "glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "requires": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ }
+ },
+ "glob-parent": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
+ "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
+ "dev": true,
+ "requires": {
+ "is-glob": "^4.0.3"
+ }
+ },
+ "globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "devOptional": true
+ },
+ "graceful-fs": {
+ "version": "4.2.10",
+ "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz",
+ "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA=="
+ },
+ "handlebars": {
+ "version": "4.7.7",
+ "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.7.7.tgz",
+ "integrity": "sha512-aAcXm5OAfE/8IXkcZvCepKU3VzW1/39Fb5ZuqMtgI/hT8X2YgoMvBY5dLhq/cpOvw7Lk1nK/UF71aLG/ZnVYRA==",
+ "dev": true,
+ "requires": {
+ "minimist": "^1.2.5",
+ "neo-async": "^2.6.0",
+ "source-map": "^0.6.1",
+ "uglify-js": "^3.1.4",
+ "wordwrap": "^1.0.0"
+ }
+ },
+ "has": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
+ "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
+ "requires": {
+ "function-bind": "^1.1.1"
+ }
+ },
+ "has-cors": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/has-cors/-/has-cors-1.1.0.tgz",
+ "integrity": "sha512-g5VNKdkFuUuVCP9gYfDJHjK2nqdQJ7aDLTnycnc2+RvsOQbuLdF5pm7vuE5J76SEBIQjs4kQY/BWq74JUmjbXA==",
+ "dev": true
+ },
+ "has-flag": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
+ "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw=="
+ },
+ "has-property-descriptors": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz",
+ "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==",
+ "dev": true,
+ "requires": {
+ "get-intrinsic": "^1.1.1"
+ }
+ },
+ "has-symbols": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
+ "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
+ "dev": true
+ },
+ "icss-replace-symbols": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/icss-replace-symbols/-/icss-replace-symbols-1.1.0.tgz",
+ "integrity": "sha512-chIaY3Vh2mh2Q3RGXttaDIzeiPvaVXJ+C4DAh/w3c37SKZ/U6PGMmuicR2EQQp9bKG8zLMCl7I+PtIoOOPp8Gg=="
+ },
+ "icss-utils": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-5.1.0.tgz",
+ "integrity": "sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA==",
+ "requires": {}
+ },
+ "ignore": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz",
+ "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==",
+ "dev": true
+ },
+ "immutable": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.1.0.tgz",
+ "integrity": "sha512-oNkuqVTA8jqG1Q6c+UglTOD1xhC1BtjKI7XkCXRkZHrN5m18/XsnUp8Q89GkQO/z+0WjonSvl0FLhDYftp46nQ=="
+ },
+ "import-cwd": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/import-cwd/-/import-cwd-3.0.0.tgz",
+ "integrity": "sha512-4pnzH16plW+hgvRECbDWpQl3cqtvSofHWh44met7ESfZ8UZOWWddm8hEyDTqREJ9RbYHY8gi8DqmaelApoOGMg==",
+ "requires": {
+ "import-from": "^3.0.0"
+ }
+ },
+ "import-fresh": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
+ "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
+ "dev": true,
+ "requires": {
+ "parent-module": "^1.0.0",
+ "resolve-from": "^4.0.0"
+ }
+ },
+ "import-from": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/import-from/-/import-from-3.0.0.tgz",
+ "integrity": "sha512-CiuXOFFSzkU5x/CR0+z7T91Iht4CXgfCxVOFRhh2Zyhg5wOpWvvDLQUsWl+gcN+QscYBjez8hDCt85O7RLDttQ==",
+ "requires": {
+ "resolve-from": "^5.0.0"
+ },
+ "dependencies": {
+ "resolve-from": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz",
+ "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw=="
}
+ }
},
- "dependencies": {
- "@league-of-foundry-developers/foundry-vtt-types": {
- "version": "9.238.1",
- "resolved": "https://registry.npmjs.org/@league-of-foundry-developers/foundry-vtt-types/-/foundry-vtt-types-9.238.1.tgz",
- "integrity": "sha512-ZnCay8eRsJTU7+y1x87BsGGEnVSSv2tW8+/8d0BHuULWOuu1HA3Tr1wIGUt++/bd6YKg0iR8jnGLtelXamj6+g==",
- "dev": true,
- "requires": {
- "@types/jquery": "~3.5.9",
- "@types/simple-peer": "~9.11.1",
- "handlebars": "4.7.7",
- "pixi-particles": "4.3.1",
- "pixi.js": "5.3.11",
- "socket.io-client": "4.3.2",
- "tinymce": "5.10.1"
- }
- },
- "@pixi/accessibility": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/accessibility/-/accessibility-5.3.11.tgz",
- "integrity": "sha512-/oSizd8/g6KUCeAlknMLJ9CRxBt+vWs6e2DrOctMoRupEHcmhICCjIyAp5GF6RZy9T9gNHDOU5p7vo7qEyVxgQ==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/app": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/app/-/app-5.3.11.tgz",
- "integrity": "sha512-ZWrOjGvVl+lK5OJQT3OqSnSRtU2XgQSe/ULg2uGsSWUqMkJews33JIGOjvk4tIsjm4ekSKiPZRMdYFHzPfgEJg==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11"
- }
- },
+ "imurmurhash": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
+ "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
+ "dev": true
+ },
+ "inflight": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
+ "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==",
+ "requires": {
+ "once": "^1.3.0",
+ "wrappy": "1"
+ }
+ },
+ "inherits": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
+ },
+ "is-binary-path": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
+ "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
+ "requires": {
+ "binary-extensions": "^2.0.0"
+ }
+ },
+ "is-builtin-module": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-3.1.0.tgz",
+ "integrity": "sha512-OV7JjAgOTfAFJmHZLvpSTb4qi0nIILDV1gWPYDnDJUTNFM5aGlRAhk4QcT8i7TuAleeEV5Fdkqn3t4mS+Q11fg==",
+ "requires": {
+ "builtin-modules": "^3.0.0"
+ }
+ },
+ "is-core-module": {
+ "version": "2.9.0",
+ "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz",
+ "integrity": "sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==",
+ "requires": {
+ "has": "^1.0.3"
+ }
+ },
+ "is-extglob": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ=="
+ },
+ "is-glob": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
+ "requires": {
+ "is-extglob": "^2.1.1"
+ }
+ },
+ "is-module": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz",
+ "integrity": "sha512-51ypPSPCoTEIN9dy5Oy+h4pShgJmPCygKfyRCISBI+JoWT/2oJvK8QPxmwv7b/p239jXrm9M1mlQbyKJ5A152g=="
+ },
+ "is-number": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
+ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng=="
+ },
+ "isexe": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
+ "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
+ "dev": true
+ },
+ "ismobilejs": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/ismobilejs/-/ismobilejs-1.1.1.tgz",
+ "integrity": "sha512-VaFW53yt8QO61k2WJui0dHf4SlL8lxBofUuUmwBo0ljPk0Drz2TiuDW4jo3wDcv41qy/SxrJ+VAzJ/qYqsmzRw==",
+ "dev": true
+ },
+ "jest-worker": {
+ "version": "26.6.2",
+ "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-26.6.2.tgz",
+ "integrity": "sha512-KWYVV1c4i+jbMpaBC+U++4Va0cp8OisU185o73T1vo99hqi7w8tSJfUXYswwqqrjzwxa6KpRK54WhPvwf5w6PQ==",
+ "requires": {
+ "@types/node": "*",
+ "merge-stream": "^2.0.0",
+ "supports-color": "^7.0.0"
+ },
+ "dependencies": {
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ=="
+ },
+ "supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ }
+ }
+ },
+ "js-tokens": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
+ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ=="
+ },
+ "js-yaml": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz",
+ "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
+ "dev": true,
+ "requires": {
+ "argparse": "^2.0.1"
+ }
+ },
+ "jsdoc-type-pratt-parser": {
+ "version": "2.2.5",
+ "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-2.2.5.tgz",
+ "integrity": "sha512-2a6eRxSxp1BW040hFvaJxhsCMI9lT8QB8t14t+NY5tC5rckIR0U9cr2tjOeaFirmEOy6MHvmJnY7zTBHq431Lw==",
+ "dev": true
+ },
+ "jsesc": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
+ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
+ "devOptional": true
+ },
+ "json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true
+ },
+ "json-stable-stringify-without-jsonify": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
+ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
+ "dev": true
+ },
+ "json5": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.1.tgz",
+ "integrity": "sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA==",
+ "devOptional": true
+ },
+ "kleur": {
+ "version": "4.1.5",
+ "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz",
+ "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ=="
+ },
+ "levn": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
+ "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
+ "dev": true,
+ "requires": {
+ "prelude-ls": "^1.2.1",
+ "type-check": "~0.4.0"
+ }
+ },
+ "lilconfig": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.6.tgz",
+ "integrity": "sha512-9JROoBW7pobfsx+Sq2JsASvCo6Pfo6WWoUW79HuB1BCoBXD4PLWJPqDF6fNj67pqBYTbAHkE57M1kS/+L1neOg=="
+ },
+ "loader-utils": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-3.2.0.tgz",
+ "integrity": "sha512-HVl9ZqccQihZ7JM85dco1MvO9G+ONvxoGa9rkhzFsneGLKSUg1gJf9bWzhRhcvm2qChhWpebQhP44qxjKIUCaQ=="
+ },
+ "lodash.camelcase": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz",
+ "integrity": "sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA=="
+ },
+ "lodash.debounce": {
+ "version": "4.0.8",
+ "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz",
+ "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==",
+ "dev": true
+ },
+ "lodash.memoize": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz",
+ "integrity": "sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag=="
+ },
+ "lodash.merge": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
+ "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
+ "dev": true
+ },
+ "lodash.uniq": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/lodash.uniq/-/lodash.uniq-4.5.0.tgz",
+ "integrity": "sha512-xfBaXQd9ryd9dlSDvnvI0lvxfLJlYAZzXomUYzLKtUeOQvOP5piqAWuGtrhWeqaXK9hhoM/iyJc5AV+XfsX3HQ=="
+ },
+ "lru-cache": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
+ "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ }
+ },
+ "magic-string": {
+ "version": "0.26.2",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.26.2.tgz",
+ "integrity": "sha512-NzzlXpclt5zAbmo6h6jNc8zl2gNRGHvmsZW4IvZhTC4W7k4OlLP+S5YLussa/r3ixNT66KOQfNORlXHSOy/X4A==",
+ "requires": {
+ "sourcemap-codec": "^1.4.8"
+ }
+ },
+ "mdn-data": {
+ "version": "2.0.14",
+ "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.14.tgz",
+ "integrity": "sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow=="
+ },
+ "merge-stream": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
+ "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w=="
+ },
+ "min-indent": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz",
+ "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg=="
+ },
+ "mini-signals": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/mini-signals/-/mini-signals-1.2.0.tgz",
+ "integrity": "sha512-alffqMkGCjjTSwvYMVLx+7QeJ6sTuxbXqBkP21my4iWU5+QpTQAJt3h7htA1OKm9F3BpMM0vnu72QIoiJakrLA==",
+ "dev": true
+ },
+ "minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "requires": {
+ "brace-expansion": "^1.1.7"
+ }
+ },
+ "minimist": {
+ "version": "1.2.6",
+ "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz",
+ "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q=="
+ },
+ "mkdirp": {
+ "version": "0.5.6",
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz",
+ "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==",
+ "requires": {
+ "minimist": "^1.2.6"
+ }
+ },
+ "ms": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
+ "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
+ },
+ "nanoid": {
+ "version": "3.3.4",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz",
+ "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw=="
+ },
+ "natural-compare": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
+ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
+ "dev": true
+ },
+ "neo-async": {
+ "version": "2.6.2",
+ "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz",
+ "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==",
+ "dev": true
+ },
+ "node-releases": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.6.tgz",
+ "integrity": "sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg=="
+ },
+ "normalize-path": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA=="
+ },
+ "normalize-range": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz",
+ "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA=="
+ },
+ "normalize-url": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-6.1.0.tgz",
+ "integrity": "sha512-DlL+XwOy3NxAQ8xuC0okPgK46iuVNAK01YN7RueYBqqFeGsBjV9XmCAzAdgt+667bCl5kPh9EqKKDwnaPG1I7A=="
+ },
+ "nth-check": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz",
+ "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==",
+ "requires": {
+ "boolbase": "^1.0.0"
+ }
+ },
+ "object-assign": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
+ "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==",
+ "dev": true
+ },
+ "object-keys": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz",
+ "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==",
+ "dev": true
+ },
+ "object.assign": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz",
+ "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==",
+ "dev": true,
+ "requires": {
+ "call-bind": "^1.0.0",
+ "define-properties": "^1.1.3",
+ "has-symbols": "^1.0.1",
+ "object-keys": "^1.1.1"
+ }
+ },
+ "once": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
+ "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
+ "requires": {
+ "wrappy": "1"
+ }
+ },
+ "optionator": {
+ "version": "0.9.1",
+ "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz",
+ "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==",
+ "dev": true,
+ "requires": {
+ "deep-is": "^0.1.3",
+ "fast-levenshtein": "^2.0.6",
+ "levn": "^0.4.1",
+ "prelude-ls": "^1.2.1",
+ "type-check": "^0.4.0",
+ "word-wrap": "^1.2.3"
+ }
+ },
+ "p-finally": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz",
+ "integrity": "sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow=="
+ },
+ "p-queue": {
+ "version": "6.6.2",
+ "resolved": "https://registry.npmjs.org/p-queue/-/p-queue-6.6.2.tgz",
+ "integrity": "sha512-RwFpb72c/BhQLEXIZ5K2e+AhgNVmIejGlTgiB9MzZ0e93GRvqZ7uSi0dvRF7/XIXDeNkra2fNHBxTyPDGySpjQ==",
+ "requires": {
+ "eventemitter3": "^4.0.4",
+ "p-timeout": "^3.2.0"
+ },
+ "dependencies": {
+ "eventemitter3": {
+ "version": "4.0.7",
+ "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz",
+ "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw=="
+ }
+ }
+ },
+ "p-timeout": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/p-timeout/-/p-timeout-3.2.0.tgz",
+ "integrity": "sha512-rhIwUycgwwKcP9yTOOFK/AKsAopjjCakVqLHePO3CC6Mir1Z99xT+R63jZxAT5lFZLa2inS5h+ZS2GvR99/FBg==",
+ "requires": {
+ "p-finally": "^1.0.0"
+ }
+ },
+ "parent-module": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
+ "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
+ "dev": true,
+ "requires": {
+ "callsites": "^3.0.0"
+ }
+ },
+ "parse-uri": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/parse-uri/-/parse-uri-1.0.7.tgz",
+ "integrity": "sha512-eWuZCMKNlVkXrEoANdXxbmqhu2SQO9jUMCSpdbJDObin0JxISn6e400EWsSRbr/czdKvWKkhZnMKEGUwf/Plmg==",
+ "dev": true
+ },
+ "parseqs": {
+ "version": "0.0.6",
+ "resolved": "https://registry.npmjs.org/parseqs/-/parseqs-0.0.6.tgz",
+ "integrity": "sha512-jeAGzMDbfSHHA091hr0r31eYfTig+29g3GKKE/PPbEQ65X0lmMwlEoqmhzu0iztID5uJpZsFlUPDP8ThPL7M8w==",
+ "dev": true
+ },
+ "parseuri": {
+ "version": "0.0.6",
+ "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.6.tgz",
+ "integrity": "sha512-AUjen8sAkGgao7UyCX6Ahv0gIK2fABKmYjvP4xmy5JaKvcbTRueIqIPHLAfq30xJddqSE033IOMUSOMCcK3Sow==",
+ "dev": true
+ },
+ "path-is-absolute": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
+ "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg=="
+ },
+ "path-key": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
+ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
+ "dev": true
+ },
+ "path-parse": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz",
+ "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw=="
+ },
+ "picocolors": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
+ "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ=="
+ },
+ "picomatch": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
+ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA=="
+ },
+ "pify": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/pify/-/pify-5.0.0.tgz",
+ "integrity": "sha512-eW/gHNMlxdSP6dmG6uJip6FXN0EQBwm2clYYd8Wul42Cwu/DK8HEftzsapcNdYe2MfLiIwZqsDk2RDEsTE79hA=="
+ },
+ "pixi-particles": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/pixi-particles/-/pixi-particles-4.3.1.tgz",
+ "integrity": "sha512-XSqDFgYwm/7FRCgP5I2Fc57d98qvb1ql/x4uTjdP4uXDUGgjdO8OW/2A0HVWS1CkOht/1x6dQzsM1oCJAUlaow==",
+ "dev": true,
+ "requires": {}
+ },
+ "pixi.js": {
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/pixi.js/-/pixi.js-5.3.11.tgz",
+ "integrity": "sha512-/9td6IHDQqG0Po5lyQ5aKDzrnEVD1SvGourI4Nqp0mvNI0Cbm74tMHLjk1V5foqGPAS9pochENr6Y3ft/2cDiQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/accessibility": "5.3.11",
+ "@pixi/app": "5.3.11",
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/extract": "5.3.11",
+ "@pixi/filter-alpha": "5.3.11",
+ "@pixi/filter-blur": "5.3.11",
+ "@pixi/filter-color-matrix": "5.3.11",
+ "@pixi/filter-displacement": "5.3.11",
+ "@pixi/filter-fxaa": "5.3.11",
+ "@pixi/filter-noise": "5.3.11",
+ "@pixi/graphics": "5.3.11",
+ "@pixi/interaction": "5.3.11",
+ "@pixi/loaders": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/mesh": "5.3.11",
+ "@pixi/mesh-extras": "5.3.11",
+ "@pixi/mixin-cache-as-bitmap": "5.3.11",
+ "@pixi/mixin-get-child-by-name": "5.3.11",
+ "@pixi/mixin-get-global-position": "5.3.11",
+ "@pixi/particles": "5.3.11",
+ "@pixi/polyfill": "5.3.11",
+ "@pixi/prepare": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/sprite-animated": "5.3.11",
+ "@pixi/sprite-tiling": "5.3.11",
+ "@pixi/spritesheet": "5.3.11",
+ "@pixi/text": "5.3.11",
+ "@pixi/text-bitmap": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ },
+ "dependencies": {
"@pixi/constants": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
- "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
- "dev": true
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/constants/-/constants-5.3.11.tgz",
+ "integrity": "sha512-KwutCRu8dRYn3956ygPJlvglHjJM99OS2Qhp4QYG8a4BsPcwfpInsHUtGHngtsTZbnx32pxCd3pg9nPiV8EuVA==",
+ "dev": true
},
"@pixi/core": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
- "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
- "dev": true,
- "requires": {
- "@pixi/constants": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/runner": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/ticker": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/core/-/core-5.3.11.tgz",
+ "integrity": "sha512-U71OiC3rNt45/h8kaLGAQL4XsNh/ISoZtxVQNbtKTXlgjEAy1Q01Ht80yl0UJdiVxYQFlanCS/IG4++OkygioA==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/runner": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/ticker": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
},
"@pixi/display": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
- "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
- "dev": true,
- "requires": {
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/extract": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/extract/-/extract-5.3.11.tgz",
- "integrity": "sha512-YeBrpIO3E5HUgcdKEldCUqwwDNHm5OBe98YFcdLr5Z0+dQaHnxp9Dm4n75/NojoGb5guYdrV00x+gU2UPHsVdw==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/filter-alpha": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-alpha/-/filter-alpha-5.3.11.tgz",
- "integrity": "sha512-HC4PbiEqDWSi3A715av7knFqD3knSXRxPJKG9mWat2CU9eCizSw+JxXp/okMU/fL4ewooiqQWVU2l1wXOHhVFw==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11"
- }
- },
- "@pixi/filter-blur": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-blur/-/filter-blur-5.3.11.tgz",
- "integrity": "sha512-iW5cOMEcDiJidOV95bUfhxdcvwM9JzCoWAd+92gAie8L+ElRSHpu1jxXbKHjo/QczQV1LulOlheyDaJNpaBCDg==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/settings": "5.3.11"
- }
- },
- "@pixi/filter-color-matrix": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-color-matrix/-/filter-color-matrix-5.3.11.tgz",
- "integrity": "sha512-u9NT4+N1I3XV9ygwsmF8/jIwCLqNCLeFOdM4f73kbw/UmakZZ6i6xjjJMc5YFUpC25qDr1TFlqgdGGGHAPl4ug==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11"
- }
- },
- "@pixi/filter-displacement": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-displacement/-/filter-displacement-5.3.11.tgz",
- "integrity": "sha512-CTIy7C/L9I1X3VNx4nMzQbMFvznsGk2viQh0dSo8r5NLgmaAdxhkGI0KUpNjLBz30278tzFfNuRe59K1y1kHuw==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/math": "5.3.11"
- }
- },
- "@pixi/filter-fxaa": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-fxaa/-/filter-fxaa-5.3.11.tgz",
- "integrity": "sha512-0ahjui5385e1vRvd7zCc0n5W8ULtNI1uVbDJHP9ueeiF25TKC0GqtZzntNwrQPoU46q8zXdnIGjzMpikbbAasg==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11"
- }
- },
- "@pixi/filter-noise": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/filter-noise/-/filter-noise-5.3.11.tgz",
- "integrity": "sha512-98WC9Nd5u2F03Ned9T3vnbmO/YF1jLSioZ623z9wjqpd5DosZgRtYTSGxjVcXTSfpviIuiJpkyF+X097pbVprg==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11"
- }
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/display/-/display-5.3.11.tgz",
+ "integrity": "sha512-rxUyB+RMJ7esEa11HdvzsularDGkYlRqpUn1ju9ZsRuB/Qo9JiVolywvWGSWxN/WnDGfrU2GjDpq9id10nwiag==",
+ "dev": true,
+ "requires": {
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
},
"@pixi/graphics": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/graphics/-/graphics-5.3.11.tgz",
- "integrity": "sha512-HLu53LV6mRlY0uFSIM2OrCuL7xqXzeJs5d2QfmUJfKJVVZ9sbHDS+6/N/f0tXzvkRPYhSKXvcNPsNn4HmlIE9w==",
- "dev": true,
- "requires": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/interaction": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/interaction/-/interaction-5.3.11.tgz",
- "integrity": "sha512-n2K99CYyBcrf8NPxpzmZ5IlJ9TEplsSZfJ/uzMNOEnTObKl4wAhxs51Nb58raH3Ouzwu14YHOpqYrBTEoT1yPA==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/ticker": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/loaders": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/loaders/-/loaders-5.3.11.tgz",
- "integrity": "sha512-1HAeb/NFXyhNhZWAbVkngsTPBGpjZEPhQflBTrKycRaub7XDSZ8F0fwPltpKKVRWNDT+HBgU/zDNE2fpjzqfYg==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/utils": "5.3.11",
- "resource-loader": "^3.0.1"
- }
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/graphics/-/graphics-5.3.11.tgz",
+ "integrity": "sha512-HLu53LV6mRlY0uFSIM2OrCuL7xqXzeJs5d2QfmUJfKJVVZ9sbHDS+6/N/f0tXzvkRPYhSKXvcNPsNn4HmlIE9w==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/sprite": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
},
"@pixi/math": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
- "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
- "dev": true
- },
- "@pixi/mesh": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mesh/-/mesh-5.3.11.tgz",
- "integrity": "sha512-KWKKksEr0YuUX1uz1FmpIa/Y37b/0pvFUS+87LoyYq0mRtGbKsTY5i3lBPG/taHwN7a2DQAX3JZpw6yhGKoGpA==",
- "dev": true,
- "requires": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/mesh-extras": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mesh-extras/-/mesh-extras-5.3.11.tgz",
- "integrity": "sha512-1GTCMMUW1xv/72x26cxRysblBXW0wU77TNgqtSIMZ1M6JbleObChklWTvwi9MzQO2vQ3S6Hvcsa5m5EiM2hSPQ==",
- "dev": true,
- "requires": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/mesh": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/mixin-cache-as-bitmap": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mixin-cache-as-bitmap/-/mixin-cache-as-bitmap-5.3.11.tgz",
- "integrity": "sha512-uQUxatGTTD5zfQ0pWdjibVjT+xEEZJ/xZDZtm/GxC7HSHd4jgoJBcTXWVhbhzwpLPVTnD8+sMnRrGlhoKcpTpQ==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/mixin-get-child-by-name": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mixin-get-child-by-name/-/mixin-get-child-by-name-5.3.11.tgz",
- "integrity": "sha512-fWFVxWtMYcwJttrgDNmZ4CJrx316p8ToNliC2ILmJZW77me7I4GzJ57gSHQU1xFwdHoOYRC4fnlrZoK5qJ9lDw==",
- "dev": true,
- "requires": {
- "@pixi/display": "5.3.11"
- }
- },
- "@pixi/mixin-get-global-position": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/mixin-get-global-position/-/mixin-get-global-position-5.3.11.tgz",
- "integrity": "sha512-wrS9i+UUodLM5XL2N0Y+XSKiqLRdJV3ltFUWG6+jPT5yoP0HsKtx3sFAzX526RwIYwRzRusbc/quxHfRA4tvgg==",
- "dev": true,
- "requires": {
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11"
- }
- },
- "@pixi/particles": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/particles/-/particles-5.3.11.tgz",
- "integrity": "sha512-+mkt/inWXtRrxQc07RZ29uNIDWV1oMsrRBVBIvHgpR92Kn8EjIDRgoSXNu0jiZ18gRKKCBhwsS4dCXGsZRQ/sA==",
- "dev": true,
- "requires": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/polyfill": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/polyfill/-/polyfill-5.3.11.tgz",
- "integrity": "sha512-yQOngcnn+2/L7n6L/g45hCnIDLWdnWmmcCY3UKJrOgbNX+JtLru1RR8AGLifkdsa0R5u48x584YQGqkTAChWVA==",
- "dev": true,
- "requires": {
- "es6-promise-polyfill": "^1.2.0",
- "object-assign": "^4.1.1"
- }
- },
- "@pixi/prepare": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/prepare/-/prepare-5.3.11.tgz",
- "integrity": "sha512-TvjGeg7xPKjv5NxbM5NXReno9yxUCw/N0HtDEtEFRVeBLN3u0Q/dZsXxL6gIvkHoS09NFW+7AwsYQLZrVbppjA==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/graphics": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/text": "5.3.11",
- "@pixi/ticker": "5.3.11"
- }
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/math/-/math-5.3.11.tgz",
+ "integrity": "sha512-GAupgFWVuOKxh8A322x8IctNgKi0/pLTJAXxmsLxcUw5PIQGgDw894HvzUriI+C0fsa9cEZHUbOCfyBKPQDLzw==",
+ "dev": true
},
"@pixi/runner": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
- "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
- "dev": true
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/runner/-/runner-5.3.11.tgz",
+ "integrity": "sha512-Mtb0rnSG+6KOIbr/48AtrILr8PZQepYwqYixVEXM6UHl+7+Z5NIx9fOByiicdjEKJvHIAYveu8yp2/L1vkF+qw==",
+ "dev": true
},
"@pixi/settings": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
- "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
- "dev": true,
- "requires": {
- "ismobilejs": "^1.1.0"
- }
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/settings/-/settings-5.3.11.tgz",
+ "integrity": "sha512-ny/rjSmP+64WqxwmoY17KsFplxpuWbiMQ5SNAgkpi36z6k+utIGT05nIIhyMx3AAGSY+6dRbKmLeKyqCj8q4zw==",
+ "dev": true,
+ "requires": {
+ "ismobilejs": "^1.1.0"
+ }
},
"@pixi/sprite": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
- "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
- "dev": true,
- "requires": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/sprite-animated": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/sprite-animated/-/sprite-animated-5.3.11.tgz",
- "integrity": "sha512-xU1b6H8nJ1l05h7cBGw2DGo4QdLj7xootstZUx2BrTVX5ZENn5mjAGVD0uRpk8yt7Q6Bj7M+PS7ktzAgBW/hmQ==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/ticker": "5.3.11"
- }
- },
- "@pixi/sprite-tiling": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/sprite-tiling/-/sprite-tiling-5.3.11.tgz",
- "integrity": "sha512-KUiWsIumjrnp9QKGMe1BqtrV9Hxm91KoaiOlCBk/gw8753iKvuMmH+/Z0RnzeZylJ1sJsdonTWy/IaLi1jnd0g==",
- "dev": true,
- "requires": {
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/spritesheet": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/spritesheet/-/spritesheet-5.3.11.tgz",
- "integrity": "sha512-Y9Wiwcz/YOuS1v73Ij9KWQakYBzZfldEy3H8T4GPLK+S19/sypntdkNtRZbmR2wWfhJ4axYEB2/Df86aOAU2qA==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/loaders": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/text": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/text/-/text-5.3.11.tgz",
- "integrity": "sha512-PmWvJv0wiKyyz3fahnxM19+m8IbF2vpDKIImqb5472WyxRGzKyVBW90xrADf5202tdKMk4b8hqvpof2XULr5PA==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
- "@pixi/text-bitmap": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/text-bitmap/-/text-bitmap-5.3.11.tgz",
- "integrity": "sha512-Bjc/G4VHaPXc9HJsvyYOm5cNTHdqmX6AgzBAlCfltuMAlnveUgUPuX8D/MJHRRnoVSDHSmCBtnJgTc0y/nIeCw==",
- "dev": true,
- "requires": {
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/loaders": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/mesh": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/text": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/sprite/-/sprite-5.3.11.tgz",
+ "integrity": "sha512-RM6Sp8kqzsBdX/hDAO25HZywe9VU4uhOronUOQ5Ve0zRe+trdBWQYfi7+5kAcvzqkp25Izc0C+e+4YCqe5OaHQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/core": "5.3.11",
+ "@pixi/display": "5.3.11",
+ "@pixi/math": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "@pixi/utils": "5.3.11"
+ }
},
"@pixi/ticker": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
- "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
- "dev": true,
- "requires": {
- "@pixi/settings": "5.3.11"
- }
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/ticker/-/ticker-5.3.11.tgz",
+ "integrity": "sha512-J1CChbSo1SQib1zL5f+FcFJZ6wN7LnWpztJVpKKYy3ZM/v4HSh48UnrGDKn5SLwSq4K7BxvZduwMQ8m4Paz1gQ==",
+ "dev": true,
+ "requires": {
+ "@pixi/settings": "5.3.11"
+ }
},
"@pixi/utils": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
- "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
- "dev": true,
- "requires": {
- "@pixi/constants": "5.3.11",
- "@pixi/settings": "5.3.11",
- "earcut": "^2.1.5",
- "eventemitter3": "^3.1.0",
- "url": "^0.11.0"
- }
- },
- "@socket.io/component-emitter": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/@socket.io/component-emitter/-/component-emitter-3.0.0.tgz",
- "integrity": "sha512-2pTGuibAXJswAPJjaKisthqS/NOK5ypG4LYT6tEAV0S/mxW0zOIvYvGK0V8w8+SHxAm6vRMSjqSalFXeBAqs+Q==",
- "dev": true
- },
- "@types/jquery": {
- "version": "3.5.13",
- "resolved": "https://registry.npmjs.org/@types/jquery/-/jquery-3.5.13.tgz",
- "integrity": "sha512-ZxJrup8nz/ZxcU0vantG+TPdboMhB24jad2uSap50zE7Q9rUeYlCF25kFMSmHR33qoeOgqcdHEp3roaookC0Sg==",
- "dev": true,
- "requires": {
- "@types/sizzle": "*"
- }
- },
- "@types/node": {
- "version": "17.0.8",
- "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.8.tgz",
- "integrity": "sha512-YofkM6fGv4gDJq78g4j0mMuGMkZVxZDgtU0JRdx6FgiJDG+0fY0GKVolOV8WqVmEhLCXkQRjwDdKyPxJp/uucg==",
- "dev": true
- },
- "@types/simple-peer": {
- "version": "9.11.4",
- "resolved": "https://registry.npmjs.org/@types/simple-peer/-/simple-peer-9.11.4.tgz",
- "integrity": "sha512-Elje14YvM47k+XEaoyRAeUSvZN7TOLWYL233QCckUaXjT4lRESHnYs0iOK2JoosO5DnCvWu/0Vpl9qnw4KCLWw==",
- "dev": true,
- "requires": {
- "@types/node": "*"
- }
- },
- "@types/sizzle": {
- "version": "2.3.3",
- "resolved": "https://registry.npmjs.org/@types/sizzle/-/sizzle-2.3.3.tgz",
- "integrity": "sha512-JYM8x9EGF163bEyhdJBpR2QX1R5naCJHC8ucJylJ3w9/CVBaskdQ8WqBf8MmQrd1kRvp/a4TS8HJ+bxzR7ZJYQ==",
- "dev": true
- },
- "backo2": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz",
- "integrity": "sha1-MasayLEpNjRj41s+u2n038+6eUc=",
- "dev": true
- },
- "base64-arraybuffer": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/base64-arraybuffer/-/base64-arraybuffer-1.0.1.tgz",
- "integrity": "sha512-vFIUq7FdLtjZMhATwDul5RZWv2jpXQ09Pd6jcVEOvIsqCWTRFD/ONHNfyOS8dA/Ippi5dsIgpyKWKZaAKZltbA==",
- "dev": true
- },
- "debug": {
- "version": "4.3.3",
- "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz",
- "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==",
- "dev": true,
- "requires": {
- "ms": "2.1.2"
- }
- },
- "earcut": {
- "version": "2.2.3",
- "resolved": "https://registry.npmjs.org/earcut/-/earcut-2.2.3.tgz",
- "integrity": "sha512-iRDI1QeCQIhMCZk48DRDMVgQSSBDmbzzNhnxIo+pwx3swkfjMh6vh0nWLq1NdvGHLKH6wIrAM3vQWeTj6qeoug==",
- "dev": true
- },
- "engine.io-client": {
- "version": "6.0.3",
- "resolved": "https://registry.npmjs.org/engine.io-client/-/engine.io-client-6.0.3.tgz",
- "integrity": "sha512-IH8ZhDIwiLv0d/wXVzmjfV9Y82hbJIDhCGSVUV8o1kcpDe2I6Y3bZA3ZbJy4Ls7k7IVmcy/qn4k9RKWFhUGf5w==",
- "dev": true,
- "requires": {
- "@socket.io/component-emitter": "~3.0.0",
- "debug": "~4.3.1",
- "engine.io-parser": "~5.0.0",
- "has-cors": "1.1.0",
- "parseqs": "0.0.6",
- "parseuri": "0.0.6",
- "ws": "~8.2.3",
- "xmlhttprequest-ssl": "~2.0.0",
- "yeast": "0.1.2"
- }
- },
- "engine.io-parser": {
- "version": "5.0.2",
- "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.0.2.tgz",
- "integrity": "sha512-wuiO7qO/OEkPJSFueuATIXtrxF7/6GTbAO9QLv7nnbjwZ5tYhLm9zxvLwxstRs0dcT0KUlWTjtIOs1T86jt12g==",
- "dev": true,
- "requires": {
- "base64-arraybuffer": "~1.0.1"
- }
- },
- "es6-promise-polyfill": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/es6-promise-polyfill/-/es6-promise-polyfill-1.2.0.tgz",
- "integrity": "sha1-84kl8jyz4+jObNqP93T867sJDN4=",
- "dev": true
- },
- "eventemitter3": {
- "version": "3.1.2",
- "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-3.1.2.tgz",
- "integrity": "sha512-tvtQIeLVHjDkJYnzf2dgVMxfuSGJeM/7UCG17TT4EumTfNtF+0nebF/4zWOIkCreAbtNqhGEboB6BWrwqNaw4Q==",
- "dev": true
- },
- "handlebars": {
- "version": "4.7.7",
- "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.7.7.tgz",
- "integrity": "sha512-aAcXm5OAfE/8IXkcZvCepKU3VzW1/39Fb5ZuqMtgI/hT8X2YgoMvBY5dLhq/cpOvw7Lk1nK/UF71aLG/ZnVYRA==",
- "dev": true,
- "requires": {
- "minimist": "^1.2.5",
- "neo-async": "^2.6.0",
- "source-map": "^0.6.1",
- "uglify-js": "^3.1.4",
- "wordwrap": "^1.0.0"
- }
- },
- "has-cors": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/has-cors/-/has-cors-1.1.0.tgz",
- "integrity": "sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk=",
- "dev": true
- },
- "ismobilejs": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/ismobilejs/-/ismobilejs-1.1.1.tgz",
- "integrity": "sha512-VaFW53yt8QO61k2WJui0dHf4SlL8lxBofUuUmwBo0ljPk0Drz2TiuDW4jo3wDcv41qy/SxrJ+VAzJ/qYqsmzRw==",
- "dev": true
- },
- "mini-signals": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/mini-signals/-/mini-signals-1.2.0.tgz",
- "integrity": "sha1-RbCAE8X65RokqhqTXNMXye1yHXQ=",
- "dev": true
- },
- "minimist": {
- "version": "1.2.5",
- "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
- "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
- "dev": true
- },
- "ms": {
- "version": "2.1.2",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
- "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
- "dev": true
- },
- "neo-async": {
- "version": "2.6.2",
- "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz",
- "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==",
- "dev": true
- },
- "object-assign": {
- "version": "4.1.1",
- "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
- "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=",
- "dev": true
- },
- "parse-uri": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/parse-uri/-/parse-uri-1.0.3.tgz",
- "integrity": "sha512-upMnGxNcm+45So85HoguwZTVZI9u11i36DdxJfGF2HYWS2eh3TIx7+/tTi7qrEq15qzGkVhsKjesau+kCk48pA==",
- "dev": true
- },
- "parseqs": {
- "version": "0.0.6",
- "resolved": "https://registry.npmjs.org/parseqs/-/parseqs-0.0.6.tgz",
- "integrity": "sha512-jeAGzMDbfSHHA091hr0r31eYfTig+29g3GKKE/PPbEQ65X0lmMwlEoqmhzu0iztID5uJpZsFlUPDP8ThPL7M8w==",
- "dev": true
- },
- "parseuri": {
- "version": "0.0.6",
- "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.6.tgz",
- "integrity": "sha512-AUjen8sAkGgao7UyCX6Ahv0gIK2fABKmYjvP4xmy5JaKvcbTRueIqIPHLAfq30xJddqSE033IOMUSOMCcK3Sow==",
- "dev": true
- },
- "pixi-particles": {
- "version": "4.3.1",
- "resolved": "https://registry.npmjs.org/pixi-particles/-/pixi-particles-4.3.1.tgz",
- "integrity": "sha512-XSqDFgYwm/7FRCgP5I2Fc57d98qvb1ql/x4uTjdP4uXDUGgjdO8OW/2A0HVWS1CkOht/1x6dQzsM1oCJAUlaow==",
- "dev": true,
- "requires": {}
- },
- "pixi.js": {
- "version": "5.3.11",
- "resolved": "https://registry.npmjs.org/pixi.js/-/pixi.js-5.3.11.tgz",
- "integrity": "sha512-/9td6IHDQqG0Po5lyQ5aKDzrnEVD1SvGourI4Nqp0mvNI0Cbm74tMHLjk1V5foqGPAS9pochENr6Y3ft/2cDiQ==",
- "dev": true,
- "requires": {
- "@pixi/accessibility": "5.3.11",
- "@pixi/app": "5.3.11",
- "@pixi/constants": "5.3.11",
- "@pixi/core": "5.3.11",
- "@pixi/display": "5.3.11",
- "@pixi/extract": "5.3.11",
- "@pixi/filter-alpha": "5.3.11",
- "@pixi/filter-blur": "5.3.11",
- "@pixi/filter-color-matrix": "5.3.11",
- "@pixi/filter-displacement": "5.3.11",
- "@pixi/filter-fxaa": "5.3.11",
- "@pixi/filter-noise": "5.3.11",
- "@pixi/graphics": "5.3.11",
- "@pixi/interaction": "5.3.11",
- "@pixi/loaders": "5.3.11",
- "@pixi/math": "5.3.11",
- "@pixi/mesh": "5.3.11",
- "@pixi/mesh-extras": "5.3.11",
- "@pixi/mixin-cache-as-bitmap": "5.3.11",
- "@pixi/mixin-get-child-by-name": "5.3.11",
- "@pixi/mixin-get-global-position": "5.3.11",
- "@pixi/particles": "5.3.11",
- "@pixi/polyfill": "5.3.11",
- "@pixi/prepare": "5.3.11",
- "@pixi/runner": "5.3.11",
- "@pixi/settings": "5.3.11",
- "@pixi/sprite": "5.3.11",
- "@pixi/sprite-animated": "5.3.11",
- "@pixi/sprite-tiling": "5.3.11",
- "@pixi/spritesheet": "5.3.11",
- "@pixi/text": "5.3.11",
- "@pixi/text-bitmap": "5.3.11",
- "@pixi/ticker": "5.3.11",
- "@pixi/utils": "5.3.11"
- }
- },
+ "version": "5.3.11",
+ "resolved": "https://registry.npmjs.org/@pixi/utils/-/utils-5.3.11.tgz",
+ "integrity": "sha512-25ZSCTrfV8da28IzvLnTK0BGWB4dHpq5P9IEgFymJvVLK7sAyT+RPz18ewRbBHgALHsszDpfC+qrHp3i+VZP0Q==",
+ "dev": true,
+ "requires": {
+ "@pixi/constants": "5.3.11",
+ "@pixi/settings": "5.3.11",
+ "earcut": "^2.1.5",
+ "eventemitter3": "^3.1.0",
+ "url": "^0.11.0"
+ }
+ }
+ }
+ },
+ "postcss": {
+ "version": "8.4.14",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.14.tgz",
+ "integrity": "sha512-E398TUmfAYFPBSdzgeieK2Y1+1cpdxJx8yXbK/m57nRhKSmk1GB2tO4lbLBtlkfPQTDKfe4Xqv1ASWPpayPEig==",
+ "requires": {
+ "nanoid": "^3.3.4",
+ "picocolors": "^1.0.0",
+ "source-map-js": "^1.0.2"
+ }
+ },
+ "postcss-attribute-case-insensitive": {
+ "version": "5.0.2",
+ "resolved": "https://registry.npmjs.org/postcss-attribute-case-insensitive/-/postcss-attribute-case-insensitive-5.0.2.tgz",
+ "integrity": "sha512-XIidXV8fDr0kKt28vqki84fRK8VW8eTuIa4PChv2MqKuT6C9UjmSKzen6KaWhWEoYvwxFCa7n/tC1SZ3tyq4SQ==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.10"
+ }
+ },
+ "postcss-calc": {
+ "version": "8.2.4",
+ "resolved": "https://registry.npmjs.org/postcss-calc/-/postcss-calc-8.2.4.tgz",
+ "integrity": "sha512-SmWMSJmB8MRnnULldx0lQIyhSNvuDl9HfrZkaqqE/WHAhToYsAvDq+yAsA/kIyINDszOp3Rh0GFoNuH5Ypsm3Q==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.9",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-clamp": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-clamp/-/postcss-clamp-4.1.0.tgz",
+ "integrity": "sha512-ry4b1Llo/9zz+PKC+030KUnPITTJAHeOwjfAyyB60eT0AorGLdzp52s31OsPRHRf8NchkgFoG2y6fCfn1IV1Ow==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-color-functional-notation": {
+ "version": "4.2.4",
+ "resolved": "https://registry.npmjs.org/postcss-color-functional-notation/-/postcss-color-functional-notation-4.2.4.tgz",
+ "integrity": "sha512-2yrTAUZUab9s6CpxkxC4rVgFEVaR6/2Pipvi6qcgvnYiVqZcbDHEoBDhrXzyb7Efh2CCfHQNtcqWcIruDTIUeg==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-color-hex-alpha": {
+ "version": "8.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-color-hex-alpha/-/postcss-color-hex-alpha-8.0.4.tgz",
+ "integrity": "sha512-nLo2DCRC9eE4w2JmuKgVA3fGL3d01kGq752pVALF68qpGLmx2Qrk91QTKkdUqqp45T1K1XV8IhQpcu1hoAQflQ==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-color-rebeccapurple": {
+ "version": "7.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-color-rebeccapurple/-/postcss-color-rebeccapurple-7.1.1.tgz",
+ "integrity": "sha512-pGxkuVEInwLHgkNxUc4sdg4g3py7zUeCQ9sMfwyHAT+Ezk8a4OaaVZ8lIY5+oNqA/BXXgLyXv0+5wHP68R79hg==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-colormin": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/postcss-colormin/-/postcss-colormin-5.3.0.tgz",
+ "integrity": "sha512-WdDO4gOFG2Z8n4P8TWBpshnL3JpmNmJwdnfP2gbk2qBA8PWwOYcmjmI/t3CmMeL72a7Hkd+x/Mg9O2/0rD54Pg==",
+ "requires": {
+ "browserslist": "^4.16.6",
+ "caniuse-api": "^3.0.0",
+ "colord": "^2.9.1",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-convert-values": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-convert-values/-/postcss-convert-values-5.1.2.tgz",
+ "integrity": "sha512-c6Hzc4GAv95B7suy4udszX9Zy4ETyMCgFPUDtWjdFTKH1SE9eFY/jEpHSwTH1QPuwxHpWslhckUQWbNRM4ho5g==",
+ "requires": {
+ "browserslist": "^4.20.3",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-custom-media": {
+ "version": "8.0.2",
+ "resolved": "https://registry.npmjs.org/postcss-custom-media/-/postcss-custom-media-8.0.2.tgz",
+ "integrity": "sha512-7yi25vDAoHAkbhAzX9dHx2yc6ntS4jQvejrNcC+csQJAXjj15e7VcWfMgLqBNAbOvqi5uIa9huOVwdHbf+sKqg==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-custom-properties": {
+ "version": "12.1.8",
+ "resolved": "https://registry.npmjs.org/postcss-custom-properties/-/postcss-custom-properties-12.1.8.tgz",
+ "integrity": "sha512-8rbj8kVu00RQh2fQF81oBqtduiANu4MIxhyf0HbbStgPtnFlWn0yiaYTpLHrPnJbffVY1s9apWsIoVZcc68FxA==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-custom-selectors": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/postcss-custom-selectors/-/postcss-custom-selectors-6.0.3.tgz",
+ "integrity": "sha512-fgVkmyiWDwmD3JbpCmB45SvvlCD6z9CG6Ie6Iere22W5aHea6oWa7EM2bpnv2Fj3I94L3VbtvX9KqwSi5aFzSg==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.4"
+ }
+ },
+ "postcss-dir-pseudo-class": {
+ "version": "6.0.5",
+ "resolved": "https://registry.npmjs.org/postcss-dir-pseudo-class/-/postcss-dir-pseudo-class-6.0.5.tgz",
+ "integrity": "sha512-eqn4m70P031PF7ZQIvSgy9RSJ5uI2171O/OO/zcRNYpJbvaeKFUlar1aJ7rmgiQtbm0FSPsRewjpdS0Oew7MPA==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.10"
+ }
+ },
+ "postcss-discard-comments": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-5.1.2.tgz",
+ "integrity": "sha512-+L8208OVbHVF2UQf1iDmRcbdjJkuBF6IS29yBDSiWUIzpYaAhtNl6JYnYm12FnkeCwQqF5LeklOu6rAqgfBZqQ==",
+ "requires": {}
+ },
+ "postcss-discard-duplicates": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-5.1.0.tgz",
+ "integrity": "sha512-zmX3IoSI2aoenxHV6C7plngHWWhUOV3sP1T8y2ifzxzbtnuhk1EdPwm0S1bIUNaJ2eNbWeGLEwzw8huPD67aQw==",
+ "requires": {}
+ },
+ "postcss-discard-empty": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-5.1.1.tgz",
+ "integrity": "sha512-zPz4WljiSuLWsI0ir4Mcnr4qQQ5e1Ukc3i7UfE2XcrwKK2LIPIqE5jxMRxO6GbI3cv//ztXDsXwEWT3BHOGh3A==",
+ "requires": {}
+ },
+ "postcss-discard-overridden": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-5.1.0.tgz",
+ "integrity": "sha512-21nOL7RqWR1kasIVdKs8HNqQJhFxLsyRfAnUDm4Fe4t4mCWL9OJiHvlHPjcd8zc5Myu89b/7wZDnOSjFgeWRtw==",
+ "requires": {}
+ },
+ "postcss-double-position-gradients": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-double-position-gradients/-/postcss-double-position-gradients-3.1.2.tgz",
+ "integrity": "sha512-GX+FuE/uBR6eskOK+4vkXgT6pDkexLokPaz/AbJna9s5Kzp/yl488pKPjhy0obB475ovfT1Wv8ho7U/cHNaRgQ==",
+ "requires": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-env-function": {
+ "version": "4.0.6",
+ "resolved": "https://registry.npmjs.org/postcss-env-function/-/postcss-env-function-4.0.6.tgz",
+ "integrity": "sha512-kpA6FsLra+NqcFnL81TnsU+Z7orGtDTxcOhl6pwXeEq1yFPpRMkCDpHhrz8CFQDr/Wfm0jLiNQ1OsGGPjlqPwA==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-focus-visible": {
+ "version": "6.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-focus-visible/-/postcss-focus-visible-6.0.4.tgz",
+ "integrity": "sha512-QcKuUU/dgNsstIK6HELFRT5Y3lbrMLEOwG+A4s5cA+fx3A3y/JTq3X9LaOj3OC3ALH0XqyrgQIgey/MIZ8Wczw==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.9"
+ }
+ },
+ "postcss-focus-within": {
+ "version": "5.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-focus-within/-/postcss-focus-within-5.0.4.tgz",
+ "integrity": "sha512-vvjDN++C0mu8jz4af5d52CB184ogg/sSxAFS+oUJQq2SuCe7T5U2iIsVJtsCp2d6R4j0jr5+q3rPkBVZkXD9fQ==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.9"
+ }
+ },
+ "postcss-font-variant": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-font-variant/-/postcss-font-variant-5.0.0.tgz",
+ "integrity": "sha512-1fmkBaCALD72CK2a9i468mA/+tr9/1cBxRRMXOUaZqO43oWPR5imcyPjXwuv7PXbCid4ndlP5zWhidQVVa3hmA==",
+ "requires": {}
+ },
+ "postcss-gap-properties": {
+ "version": "3.0.5",
+ "resolved": "https://registry.npmjs.org/postcss-gap-properties/-/postcss-gap-properties-3.0.5.tgz",
+ "integrity": "sha512-IuE6gKSdoUNcvkGIqdtjtcMtZIFyXZhmFd5RUlg97iVEvp1BZKV5ngsAjCjrVy+14uhGBQl9tzmi1Qwq4kqVOg==",
+ "requires": {}
+ },
+ "postcss-image-set-function": {
+ "version": "4.0.7",
+ "resolved": "https://registry.npmjs.org/postcss-image-set-function/-/postcss-image-set-function-4.0.7.tgz",
+ "integrity": "sha512-9T2r9rsvYzm5ndsBE8WgtrMlIT7VbtTfE7b3BQnudUqnBcBo7L758oc+o+pdj/dUV0l5wjwSdjeOH2DZtfv8qw==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-initial": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/postcss-initial/-/postcss-initial-4.0.1.tgz",
+ "integrity": "sha512-0ueD7rPqX8Pn1xJIjay0AZeIuDoF+V+VvMt/uOnn+4ezUKhZM/NokDeP6DwMNyIoYByuN/94IQnt5FEkaN59xQ==",
+ "requires": {}
+ },
+ "postcss-lab-function": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmjs.org/postcss-lab-function/-/postcss-lab-function-4.2.1.tgz",
+ "integrity": "sha512-xuXll4isR03CrQsmxyz92LJB2xX9n+pZJ5jE9JgcnmsCammLyKdlzrBin+25dy6wIjfhJpKBAN80gsTlCgRk2w==",
+ "requires": {
+ "@csstools/postcss-progressive-custom-properties": "^1.1.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-load-config": {
+ "version": "3.1.4",
+ "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-3.1.4.tgz",
+ "integrity": "sha512-6DiM4E7v4coTE4uzA8U//WhtPwyhiim3eyjEMFCnUpzbrkK9wJHgKDT2mR+HbtSrd/NubVaYTOpSpjUl8NQeRg==",
+ "requires": {
+ "lilconfig": "^2.0.5",
+ "yaml": "^1.10.2"
+ }
+ },
+ "postcss-logical": {
+ "version": "5.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-logical/-/postcss-logical-5.0.4.tgz",
+ "integrity": "sha512-RHXxplCeLh9VjinvMrZONq7im4wjWGlRJAqmAVLXyZaXwfDWP73/oq4NdIp+OZwhQUMj0zjqDfM5Fj7qby+B4g==",
+ "requires": {}
+ },
+ "postcss-media-minmax": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-media-minmax/-/postcss-media-minmax-5.0.0.tgz",
+ "integrity": "sha512-yDUvFf9QdFZTuCUg0g0uNSHVlJ5X1lSzDZjPSFaiCWvjgsvu8vEVxtahPrLMinIDEEGnx6cBe6iqdx5YWz08wQ==",
+ "requires": {}
+ },
+ "postcss-merge-longhand": {
+ "version": "5.1.6",
+ "resolved": "https://registry.npmjs.org/postcss-merge-longhand/-/postcss-merge-longhand-5.1.6.tgz",
+ "integrity": "sha512-6C/UGF/3T5OE2CEbOuX7iNO63dnvqhGZeUnKkDeifebY0XqkkvrctYSZurpNE902LDf2yKwwPFgotnfSoPhQiw==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0",
+ "stylehacks": "^5.1.0"
+ }
+ },
+ "postcss-merge-rules": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-merge-rules/-/postcss-merge-rules-5.1.2.tgz",
+ "integrity": "sha512-zKMUlnw+zYCWoPN6yhPjtcEdlJaMUZ0WyVcxTAmw3lkkN/NDMRkOkiuctQEoWAOvH7twaxUUdvBWl0d4+hifRQ==",
+ "requires": {
+ "browserslist": "^4.16.6",
+ "caniuse-api": "^3.0.0",
+ "cssnano-utils": "^3.1.0",
+ "postcss-selector-parser": "^6.0.5"
+ }
+ },
+ "postcss-minify-font-values": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-minify-font-values/-/postcss-minify-font-values-5.1.0.tgz",
+ "integrity": "sha512-el3mYTgx13ZAPPirSVsHqFzl+BBBDrXvbySvPGFnQcTI4iNslrPaFq4muTkLZmKlGk4gyFAYUBMH30+HurREyA==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-minify-gradients": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-minify-gradients/-/postcss-minify-gradients-5.1.1.tgz",
+ "integrity": "sha512-VGvXMTpCEo4qHTNSa9A0a3D+dxGFZCYwR6Jokk+/3oB6flu2/PnPXAh2x7x52EkY5xlIHLm+Le8tJxe/7TNhzw==",
+ "requires": {
+ "colord": "^2.9.1",
+ "cssnano-utils": "^3.1.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-minify-params": {
+ "version": "5.1.3",
+ "resolved": "https://registry.npmjs.org/postcss-minify-params/-/postcss-minify-params-5.1.3.tgz",
+ "integrity": "sha512-bkzpWcjykkqIujNL+EVEPOlLYi/eZ050oImVtHU7b4lFS82jPnsCb44gvC6pxaNt38Els3jWYDHTjHKf0koTgg==",
+ "requires": {
+ "browserslist": "^4.16.6",
+ "cssnano-utils": "^3.1.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-minify-selectors": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmjs.org/postcss-minify-selectors/-/postcss-minify-selectors-5.2.1.tgz",
+ "integrity": "sha512-nPJu7OjZJTsVUmPdm2TcaiohIwxP+v8ha9NehQ2ye9szv4orirRU3SDdtUmKH+10nzn0bAyOXZ0UEr7OpvLehg==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.5"
+ }
+ },
+ "postcss-modules": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/postcss-modules/-/postcss-modules-4.3.1.tgz",
+ "integrity": "sha512-ItUhSUxBBdNamkT3KzIZwYNNRFKmkJrofvC2nWab3CPKhYBQ1f27XXh1PAPE27Psx58jeelPsxWB/+og+KEH0Q==",
+ "requires": {
+ "generic-names": "^4.0.0",
+ "icss-replace-symbols": "^1.1.0",
+ "lodash.camelcase": "^4.3.0",
+ "postcss-modules-extract-imports": "^3.0.0",
+ "postcss-modules-local-by-default": "^4.0.0",
+ "postcss-modules-scope": "^3.0.0",
+ "postcss-modules-values": "^4.0.0",
+ "string-hash": "^1.1.1"
+ }
+ },
+ "postcss-modules-extract-imports": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz",
+ "integrity": "sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw==",
+ "requires": {}
+ },
+ "postcss-modules-local-by-default": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.0.tgz",
+ "integrity": "sha512-sT7ihtmGSF9yhm6ggikHdV0hlziDTX7oFoXtuVWeDd3hHObNkcHRo9V3yg7vCAY7cONyxJC/XXCmmiHHcvX7bQ==",
+ "requires": {
+ "icss-utils": "^5.0.0",
+ "postcss-selector-parser": "^6.0.2",
+ "postcss-value-parser": "^4.1.0"
+ }
+ },
+ "postcss-modules-scope": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz",
+ "integrity": "sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.4"
+ }
+ },
+ "postcss-modules-values": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-4.0.0.tgz",
+ "integrity": "sha512-RDxHkAiEGI78gS2ofyvCsu7iycRv7oqw5xMWn9iMoR0N/7mf9D50ecQqUo5BZ9Zh2vH4bCUR/ktCqbB9m8vJjQ==",
+ "requires": {
+ "icss-utils": "^5.0.0"
+ }
+ },
+ "postcss-nesting": {
+ "version": "10.1.10",
+ "resolved": "https://registry.npmjs.org/postcss-nesting/-/postcss-nesting-10.1.10.tgz",
+ "integrity": "sha512-lqd7LXCq0gWc0wKXtoKDru5wEUNjm3OryLVNRZ8OnW8km6fSNUuFrjEhU3nklxXE2jvd4qrox566acgh+xQt8w==",
+ "requires": {
+ "@csstools/selector-specificity": "^2.0.0",
+ "postcss-selector-parser": "^6.0.10"
+ }
+ },
+ "postcss-normalize-charset": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-5.1.0.tgz",
+ "integrity": "sha512-mSgUJ+pd/ldRGVx26p2wz9dNZ7ji6Pn8VWBajMXFf8jk7vUoSrZ2lt/wZR7DtlZYKesmZI680qjr2CeFF2fbUg==",
+ "requires": {}
+ },
+ "postcss-normalize-display-values": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-display-values/-/postcss-normalize-display-values-5.1.0.tgz",
+ "integrity": "sha512-WP4KIM4o2dazQXWmFaqMmcvsKmhdINFblgSeRgn8BJ6vxaMyaJkwAzpPpuvSIoG/rmX3M+IrRZEz2H0glrQNEA==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-normalize-positions": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-positions/-/postcss-normalize-positions-5.1.1.tgz",
+ "integrity": "sha512-6UpCb0G4eofTCQLFVuI3EVNZzBNPiIKcA1AKVka+31fTVySphr3VUgAIULBhxZkKgwLImhzMR2Bw1ORK+37INg==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-normalize-repeat-style": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-5.1.1.tgz",
+ "integrity": "sha512-mFpLspGWkQtBcWIRFLmewo8aC3ImN2i/J3v8YCFUwDnPu3Xz4rLohDO26lGjwNsQxB3YF0KKRwspGzE2JEuS0g==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-normalize-string": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-string/-/postcss-normalize-string-5.1.0.tgz",
+ "integrity": "sha512-oYiIJOf4T9T1N4i+abeIc7Vgm/xPCGih4bZz5Nm0/ARVJ7K6xrDlLwvwqOydvyL3RHNf8qZk6vo3aatiw/go3w==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-normalize-timing-functions": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-5.1.0.tgz",
+ "integrity": "sha512-DOEkzJ4SAXv5xkHl0Wa9cZLF3WCBhF3o1SKVxKQAa+0pYKlueTpCgvkFAHfk+Y64ezX9+nITGrDZeVGgITJXjg==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-normalize-unicode": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-unicode/-/postcss-normalize-unicode-5.1.0.tgz",
+ "integrity": "sha512-J6M3MizAAZ2dOdSjy2caayJLQT8E8K9XjLce8AUQMwOrCvjCHv24aLC/Lps1R1ylOfol5VIDMaM/Lo9NGlk1SQ==",
+ "requires": {
+ "browserslist": "^4.16.6",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-normalize-url": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-url/-/postcss-normalize-url-5.1.0.tgz",
+ "integrity": "sha512-5upGeDO+PVthOxSmds43ZeMeZfKH+/DKgGRD7TElkkyS46JXAUhMzIKiCa7BabPeIy3AQcTkXwVVN7DbqsiCew==",
+ "requires": {
+ "normalize-url": "^6.0.1",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-normalize-whitespace": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-normalize-whitespace/-/postcss-normalize-whitespace-5.1.1.tgz",
+ "integrity": "sha512-83ZJ4t3NUDETIHTa3uEg6asWjSBYL5EdkVB0sDncx9ERzOKBVJIUeDO9RyA9Zwtig8El1d79HBp0JEi8wvGQnA==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-opacity-percentage": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/postcss-opacity-percentage/-/postcss-opacity-percentage-1.1.2.tgz",
+ "integrity": "sha512-lyUfF7miG+yewZ8EAk9XUBIlrHyUE6fijnesuz+Mj5zrIHIEw6KcIZSOk/elVMqzLvREmXB83Zi/5QpNRYd47w=="
+ },
+ "postcss-ordered-values": {
+ "version": "5.1.3",
+ "resolved": "https://registry.npmjs.org/postcss-ordered-values/-/postcss-ordered-values-5.1.3.tgz",
+ "integrity": "sha512-9UO79VUhPwEkzbb3RNpqqghc6lcYej1aveQteWY+4POIwlqkYE21HKWaLDF6lWNuqCobEAyTovVhtI32Rbv2RQ==",
+ "requires": {
+ "cssnano-utils": "^3.1.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-overflow-shorthand": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-overflow-shorthand/-/postcss-overflow-shorthand-3.0.4.tgz",
+ "integrity": "sha512-otYl/ylHK8Y9bcBnPLo3foYFLL6a6Ak+3EQBPOTR7luMYCOsiVTUk1iLvNf6tVPNGXcoL9Hoz37kpfriRIFb4A==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-page-break": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/postcss-page-break/-/postcss-page-break-3.0.4.tgz",
+ "integrity": "sha512-1JGu8oCjVXLa9q9rFTo4MbeeA5FMe00/9C7lN4va606Rdb+HkxXtXsmEDrIraQ11fGz/WvKWa8gMuCKkrXpTsQ==",
+ "requires": {}
+ },
+ "postcss-place": {
+ "version": "7.0.5",
+ "resolved": "https://registry.npmjs.org/postcss-place/-/postcss-place-7.0.5.tgz",
+ "integrity": "sha512-wR8igaZROA6Z4pv0d+bvVrvGY4GVHihBCBQieXFY3kuSuMyOmEnnfFzHl/tQuqHZkfkIVBEbDvYcFfHmpSet9g==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-preset-env": {
+ "version": "7.7.2",
+ "resolved": "https://registry.npmjs.org/postcss-preset-env/-/postcss-preset-env-7.7.2.tgz",
+ "integrity": "sha512-1q0ih7EDsZmCb/FMDRvosna7Gsbdx8CvYO5hYT120hcp2ZAuOHpSzibujZ4JpIUcAC02PG6b+eftxqjTFh5BNA==",
+ "requires": {
+ "@csstools/postcss-cascade-layers": "^1.0.4",
+ "@csstools/postcss-color-function": "^1.1.0",
+ "@csstools/postcss-font-format-keywords": "^1.0.0",
+ "@csstools/postcss-hwb-function": "^1.0.1",
+ "@csstools/postcss-ic-unit": "^1.0.0",
+ "@csstools/postcss-is-pseudo-class": "^2.0.6",
+ "@csstools/postcss-normalize-display-values": "^1.0.0",
+ "@csstools/postcss-oklab-function": "^1.1.0",
+ "@csstools/postcss-progressive-custom-properties": "^1.3.0",
+ "@csstools/postcss-stepped-value-functions": "^1.0.0",
+ "@csstools/postcss-trigonometric-functions": "^1.0.1",
+ "@csstools/postcss-unset-value": "^1.0.1",
+ "autoprefixer": "^10.4.7",
+ "browserslist": "^4.21.0",
+ "css-blank-pseudo": "^3.0.3",
+ "css-has-pseudo": "^3.0.4",
+ "css-prefers-color-scheme": "^6.0.3",
+ "cssdb": "^6.6.3",
+ "postcss-attribute-case-insensitive": "^5.0.1",
+ "postcss-clamp": "^4.1.0",
+ "postcss-color-functional-notation": "^4.2.3",
+ "postcss-color-hex-alpha": "^8.0.4",
+ "postcss-color-rebeccapurple": "^7.1.0",
+ "postcss-custom-media": "^8.0.2",
+ "postcss-custom-properties": "^12.1.8",
+ "postcss-custom-selectors": "^6.0.3",
+ "postcss-dir-pseudo-class": "^6.0.4",
+ "postcss-double-position-gradients": "^3.1.1",
+ "postcss-env-function": "^4.0.6",
+ "postcss-focus-visible": "^6.0.4",
+ "postcss-focus-within": "^5.0.4",
+ "postcss-font-variant": "^5.0.0",
+ "postcss-gap-properties": "^3.0.3",
+ "postcss-image-set-function": "^4.0.6",
+ "postcss-initial": "^4.0.1",
+ "postcss-lab-function": "^4.2.0",
+ "postcss-logical": "^5.0.4",
+ "postcss-media-minmax": "^5.0.0",
+ "postcss-nesting": "^10.1.9",
+ "postcss-opacity-percentage": "^1.1.2",
+ "postcss-overflow-shorthand": "^3.0.3",
+ "postcss-page-break": "^3.0.4",
+ "postcss-place": "^7.0.4",
+ "postcss-pseudo-class-any-link": "^7.1.5",
+ "postcss-replace-overflow-wrap": "^4.0.0",
+ "postcss-selector-not": "^6.0.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-pseudo-class-any-link": {
+ "version": "7.1.6",
+ "resolved": "https://registry.npmjs.org/postcss-pseudo-class-any-link/-/postcss-pseudo-class-any-link-7.1.6.tgz",
+ "integrity": "sha512-9sCtZkO6f/5ML9WcTLcIyV1yz9D1rf0tWc+ulKcvV30s0iZKS/ONyETvoWsr6vnrmW+X+KmuK3gV/w5EWnT37w==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.10"
+ }
+ },
+ "postcss-reduce-initial": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-reduce-initial/-/postcss-reduce-initial-5.1.0.tgz",
+ "integrity": "sha512-5OgTUviz0aeH6MtBjHfbr57tml13PuedK/Ecg8szzd4XRMbYxH4572JFG067z+FqBIf6Zp/d+0581glkvvWMFw==",
+ "requires": {
+ "browserslist": "^4.16.6",
+ "caniuse-api": "^3.0.0"
+ }
+ },
+ "postcss-reduce-transforms": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-reduce-transforms/-/postcss-reduce-transforms-5.1.0.tgz",
+ "integrity": "sha512-2fbdbmgir5AvpW9RLtdONx1QoYG2/EtqpNQbFASDlixBbAYuTcJ0dECwlqNqH7VbaUnEnh8SrxOe2sRIn24XyQ==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "postcss-replace-overflow-wrap": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-replace-overflow-wrap/-/postcss-replace-overflow-wrap-4.0.0.tgz",
+ "integrity": "sha512-KmF7SBPphT4gPPcKZc7aDkweHiKEEO8cla/GjcBK+ckKxiZslIu3C4GCRW3DNfL0o7yW7kMQu9xlZ1kXRXLXtw==",
+ "requires": {}
+ },
+ "postcss-selector-not": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/postcss-selector-not/-/postcss-selector-not-6.0.1.tgz",
+ "integrity": "sha512-1i9affjAe9xu/y9uqWH+tD4r6/hDaXJruk8xn2x1vzxC2U3J3LKO3zJW4CyxlNhA56pADJ/djpEwpH1RClI2rQ==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.10"
+ }
+ },
+ "postcss-selector-parser": {
+ "version": "6.0.10",
+ "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.10.tgz",
+ "integrity": "sha512-IQ7TZdoaqbT+LCpShg46jnZVlhWD2w6iQYAcYXfHARZ7X1t/UGhhceQDs5X0cGqKvYlHNOuv7Oa1xmb0oQuA3w==",
+ "requires": {
+ "cssesc": "^3.0.0",
+ "util-deprecate": "^1.0.2"
+ }
+ },
+ "postcss-svgo": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/postcss-svgo/-/postcss-svgo-5.1.0.tgz",
+ "integrity": "sha512-D75KsH1zm5ZrHyxPakAxJWtkyXew5qwS70v56exwvw542d9CRtTo78K0WeFxZB4G7JXKKMbEZtZayTGdIky/eA==",
+ "requires": {
+ "postcss-value-parser": "^4.2.0",
+ "svgo": "^2.7.0"
+ }
+ },
+ "postcss-unique-selectors": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/postcss-unique-selectors/-/postcss-unique-selectors-5.1.1.tgz",
+ "integrity": "sha512-5JiODlELrz8L2HwxfPnhOWZYWDxVHWL83ufOv84NrcgipI7TaeRsatAhK4Tr2/ZiYldpK/wBvw5BD3qfaK96GA==",
+ "requires": {
+ "postcss-selector-parser": "^6.0.5"
+ }
+ },
+ "postcss-value-parser": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz",
+ "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ=="
+ },
+ "prelude-ls": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
+ "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
+ "dev": true
+ },
+ "promise.series": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/promise.series/-/promise.series-0.2.0.tgz",
+ "integrity": "sha512-VWQJyU2bcDTgZw8kpfBpB/ejZASlCrzwz5f2hjb/zlujOEB4oeiAhHygAWq8ubsX2GVkD4kCU5V2dwOTaCY5EQ=="
+ },
+ "punycode": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz",
+ "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==",
+ "dev": true
+ },
+ "querystring": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz",
+ "integrity": "sha512-X/xY82scca2tau62i9mDyU9K+I+djTMUsvwf7xnUX5GLvVzgJybOJf4Y6o9Zx3oJK/LSXg5tTZBjwzqVPaPO2g==",
+ "dev": true
+ },
+ "randombytes": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz",
+ "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==",
+ "requires": {
+ "safe-buffer": "^5.1.0"
+ }
+ },
+ "readdirp": {
+ "version": "3.6.0",
+ "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
+ "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
+ "requires": {
+ "picomatch": "^2.2.1"
+ }
+ },
+ "regenerate": {
+ "version": "1.4.2",
+ "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz",
+ "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==",
+ "dev": true
+ },
+ "regenerate-unicode-properties": {
+ "version": "10.0.1",
+ "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.0.1.tgz",
+ "integrity": "sha512-vn5DU6yg6h8hP/2OkQo3K7uVILvY4iu0oI4t3HFa81UPkhGJwkRwM10JEc3upjdhHjs/k8GJY1sRBhk5sr69Bw==",
+ "dev": true,
+ "requires": {
+ "regenerate": "^1.4.2"
+ }
+ },
+ "regenerator-runtime": {
+ "version": "0.13.9",
+ "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz",
+ "integrity": "sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA==",
+ "dev": true
+ },
+ "regenerator-transform": {
+ "version": "0.15.0",
+ "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.0.tgz",
+ "integrity": "sha512-LsrGtPmbYg19bcPHwdtmXwbW+TqNvtY4riE3P83foeHRroMbH6/2ddFBfab3t7kbzc7v7p4wbkIecHImqt0QNg==",
+ "dev": true,
+ "requires": {
+ "@babel/runtime": "^7.8.4"
+ }
+ },
+ "regexpp": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz",
+ "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==",
+ "dev": true
+ },
+ "regexpu-core": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.1.0.tgz",
+ "integrity": "sha512-bb6hk+xWd2PEOkj5It46A16zFMs2mv86Iwpdu94la4S3sJ7C973h2dHpYKwIBGaWSO7cIRJ+UX0IeMaWcO4qwA==",
+ "dev": true,
+ "requires": {
+ "regenerate": "^1.4.2",
+ "regenerate-unicode-properties": "^10.0.1",
+ "regjsgen": "^0.6.0",
+ "regjsparser": "^0.8.2",
+ "unicode-match-property-ecmascript": "^2.0.0",
+ "unicode-match-property-value-ecmascript": "^2.0.0"
+ }
+ },
+ "regextras": {
+ "version": "0.8.0",
+ "resolved": "https://registry.npmjs.org/regextras/-/regextras-0.8.0.tgz",
+ "integrity": "sha512-k519uI04Z3SaY0fLX843MRXnDeG2+vHOFsyhiPZvNLe7r8rD2YNRjq4BQLZZ0oAr2NrtvZlICsXysGNFPGa3CQ==",
+ "dev": true
+ },
+ "regjsgen": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.6.0.tgz",
+ "integrity": "sha512-ozE883Uigtqj3bx7OhL1KNbCzGyW2NQZPl6Hs09WTvCuZD5sTI4JY58bkbQWa/Y9hxIsvJ3M8Nbf7j54IqeZbA==",
+ "dev": true
+ },
+ "regjsparser": {
+ "version": "0.8.4",
+ "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.8.4.tgz",
+ "integrity": "sha512-J3LABycON/VNEu3abOviqGHuB/LOtOQj8SKmfP9anY5GfAVw/SPjwzSjxGjbZXIxbGfqTHtJw58C2Li/WkStmA==",
+ "dev": true,
+ "requires": {
+ "jsesc": "~0.5.0"
+ },
+ "dependencies": {
+ "jsesc": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz",
+ "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==",
+ "dev": true
+ }
+ }
+ },
+ "require-relative": {
+ "version": "0.8.7",
+ "resolved": "https://registry.npmjs.org/require-relative/-/require-relative-0.8.7.tgz",
+ "integrity": "sha512-AKGr4qvHiryxRb19m3PsLRGuKVAbJLUD7E6eOaHkfKhwc+vSgVOCY5xNvm9EkolBKTOf0GrQAZKLimOCz81Khg=="
+ },
+ "resolve": {
+ "version": "1.22.1",
+ "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz",
+ "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==",
+ "requires": {
+ "is-core-module": "^2.9.0",
+ "path-parse": "^1.0.7",
+ "supports-preserve-symlinks-flag": "^1.0.0"
+ }
+ },
+ "resolve-from": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
+ "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
+ "dev": true
+ },
+ "resource-loader": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/resource-loader/-/resource-loader-3.0.1.tgz",
+ "integrity": "sha512-fBuCRbEHdLCI1eglzQhUv9Rrdcmqkydr1r6uHE2cYHvRBrcLXeSmbE/qI/urFt8rPr/IGxir3BUwM5kUK8XoyA==",
+ "dev": true,
+ "requires": {
+ "mini-signals": "^1.2.0",
+ "parse-uri": "^1.0.0"
+ }
+ },
+ "rimraf": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
+ "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
+ "dev": true,
+ "requires": {
+ "glob": "^7.1.3"
+ }
+ },
+ "rollup": {
+ "version": "2.77.0",
+ "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.77.0.tgz",
+ "integrity": "sha512-vL8xjY4yOQEw79DvyXLijhnhh+R/O9zpF/LEgkCebZFtb6ELeN9H3/2T0r8+mp+fFTBHZ5qGpOpW2ela2zRt3g==",
+ "requires": {
+ "fsevents": "~2.3.2"
+ }
+ },
+ "rollup-plugin-postcss": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/rollup-plugin-postcss/-/rollup-plugin-postcss-4.0.2.tgz",
+ "integrity": "sha512-05EaY6zvZdmvPUDi3uCcAQoESDcYnv8ogJJQRp6V5kZ6J6P7uAVJlrTZcaaA20wTH527YTnKfkAoPxWI/jPp4w==",
+ "requires": {
+ "chalk": "^4.1.0",
+ "concat-with-sourcemaps": "^1.1.0",
+ "cssnano": "^5.0.1",
+ "import-cwd": "^3.0.0",
+ "p-queue": "^6.6.2",
+ "pify": "^5.0.0",
+ "postcss-load-config": "^3.0.0",
+ "postcss-modules": "^4.0.0",
+ "promise.series": "^0.2.0",
+ "resolve": "^1.19.0",
+ "rollup-pluginutils": "^2.8.2",
+ "safe-identifier": "^0.4.2",
+ "style-inject": "^0.3.0"
+ },
+ "dependencies": {
+ "ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "requires": {
+ "color-convert": "^2.0.1"
+ }
+ },
+ "chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "requires": {
+ "color-name": "~1.1.4"
+ }
+ },
+ "color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA=="
+ },
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ=="
+ },
+ "supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ }
+ }
+ },
+ "rollup-plugin-sourcemaps": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/rollup-plugin-sourcemaps/-/rollup-plugin-sourcemaps-0.6.3.tgz",
+ "integrity": "sha512-paFu+nT1xvuO1tPFYXGe+XnQvg4Hjqv/eIhG8i5EspfYYPBKL57X7iVbfv55aNVASg3dzWvES9dmWsL2KhfByw==",
+ "requires": {
+ "@rollup/pluginutils": "^3.0.9",
+ "source-map-resolve": "^0.6.0"
+ }
+ },
+ "rollup-plugin-svelte": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/rollup-plugin-svelte/-/rollup-plugin-svelte-7.1.0.tgz",
+ "integrity": "sha512-vopCUq3G+25sKjwF5VilIbiY6KCuMNHP1PFvx2Vr3REBNMDllKHFZN2B9jwwC+MqNc3UPKkjXnceLPEjTjXGXg==",
+ "requires": {
+ "require-relative": "^0.8.7",
+ "rollup-pluginutils": "^2.8.2"
+ }
+ },
+ "rollup-plugin-terser": {
+ "version": "7.0.2",
+ "resolved": "https://registry.npmjs.org/rollup-plugin-terser/-/rollup-plugin-terser-7.0.2.tgz",
+ "integrity": "sha512-w3iIaU4OxcF52UUXiZNsNeuXIMDvFrr+ZXK6bFZ0Q60qyVfq4uLptoS4bbq3paG3x216eQllFZX7zt6TIImguQ==",
+ "requires": {
+ "@babel/code-frame": "^7.10.4",
+ "jest-worker": "^26.2.1",
+ "serialize-javascript": "^4.0.0",
+ "terser": "^5.0.0"
+ }
+ },
+ "rollup-pluginutils": {
+ "version": "2.8.2",
+ "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz",
+ "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==",
+ "requires": {
+ "estree-walker": "^0.6.1"
+ },
+ "dependencies": {
+ "estree-walker": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz",
+ "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w=="
+ }
+ }
+ },
+ "safe-buffer": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
+ },
+ "safe-identifier": {
+ "version": "0.4.2",
+ "resolved": "https://registry.npmjs.org/safe-identifier/-/safe-identifier-0.4.2.tgz",
+ "integrity": "sha512-6pNbSMW6OhAi9j+N8V+U715yBQsaWJ7eyEUaOrawX+isg5ZxhUlV1NipNtgaKHmFGiABwt+ZF04Ii+3Xjkg+8w=="
+ },
+ "sander": {
+ "version": "0.5.1",
+ "resolved": "https://registry.npmjs.org/sander/-/sander-0.5.1.tgz",
+ "integrity": "sha512-3lVqBir7WuKDHGrKRDn/1Ye3kwpXaDOMsiRP1wd6wpZW56gJhsbp5RqQpA6JG/P+pkXizygnr1dKR8vzWaVsfA==",
+ "requires": {
+ "es6-promise": "^3.1.2",
+ "graceful-fs": "^4.1.3",
+ "mkdirp": "^0.5.1",
+ "rimraf": "^2.5.2"
+ },
+ "dependencies": {
+ "rimraf": {
+ "version": "2.7.1",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz",
+ "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==",
+ "requires": {
+ "glob": "^7.1.3"
+ }
+ }
+ }
+ },
+ "sass": {
+ "version": "1.54.0",
+ "resolved": "https://registry.npmjs.org/sass/-/sass-1.54.0.tgz",
+ "integrity": "sha512-C4zp79GCXZfK0yoHZg+GxF818/aclhp9F48XBu/+bm9vXEVAYov9iU3FBVRMq3Hx3OA4jfKL+p2K9180mEh0xQ==",
+ "requires": {
+ "chokidar": ">=3.0.0 <4.0.0",
+ "immutable": "^4.0.0",
+ "source-map-js": ">=0.6.2 <2.0.0"
+ }
+ },
+ "semver": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
+ "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
+ "devOptional": true
+ },
+ "serialize-javascript": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-4.0.0.tgz",
+ "integrity": "sha512-GaNA54380uFefWghODBWEGisLZFj00nS5ACs6yHa9nLqlLpVLO8ChDGeKRjZnV4Nh4n0Qi7nhYZD/9fCPzEqkw==",
+ "requires": {
+ "randombytes": "^2.1.0"
+ }
+ },
+ "shebang-command": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
+ "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
+ "dev": true,
+ "requires": {
+ "shebang-regex": "^3.0.0"
+ }
+ },
+ "shebang-regex": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
+ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
+ "dev": true
+ },
+ "socket.io-client": {
+ "version": "4.3.2",
+ "resolved": "https://registry.npmjs.org/socket.io-client/-/socket.io-client-4.3.2.tgz",
+ "integrity": "sha512-2B9LqSunN60yV8F7S84CCEEcgbYNfrn7ejIInZtLZ7ppWtiX8rGZAjvdCvbnC8bqo/9RlCNOUsORLyskxSFP1g==",
+ "dev": true,
+ "requires": {
+ "@socket.io/component-emitter": "~3.0.0",
+ "backo2": "~1.0.2",
+ "debug": "~4.3.2",
+ "engine.io-client": "~6.0.1",
+ "parseuri": "0.0.6",
+ "socket.io-parser": "~4.1.1"
+ }
+ },
+ "socket.io-parser": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.1.2.tgz",
+ "integrity": "sha512-j3kk71QLJuyQ/hh5F/L2t1goqzdTL0gvDzuhTuNSwihfuFUrcSji0qFZmJJPtG6Rmug153eOPsUizeirf1IIog==",
+ "dev": true,
+ "requires": {
+ "@socket.io/component-emitter": "~3.0.0",
+ "debug": "~4.3.1"
+ }
+ },
+ "sorcery": {
+ "version": "0.10.0",
+ "resolved": "https://registry.npmjs.org/sorcery/-/sorcery-0.10.0.tgz",
+ "integrity": "sha512-R5ocFmKZQFfSTstfOtHjJuAwbpGyf9qjQa1egyhvXSbM7emjrtLXtGdZsDJDABC85YBfVvrOiGWKSYXPKdvP1g==",
+ "requires": {
+ "buffer-crc32": "^0.2.5",
+ "minimist": "^1.2.0",
+ "sander": "^0.5.0",
+ "sourcemap-codec": "^1.3.0"
+ }
+ },
+ "source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g=="
+ },
+ "source-map-js": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
+ "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw=="
+ },
+ "source-map-resolve": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.6.0.tgz",
+ "integrity": "sha512-KXBr9d/fO/bWo97NXsPIAW1bFSBOuCnjbNTBMO7N59hsv5i9yzRDfcYwwt0l04+VqnKC+EwzvJZIP/qkuMgR/w==",
+ "requires": {
+ "atob": "^2.1.2",
+ "decode-uri-component": "^0.2.0"
+ }
+ },
+ "source-map-support": {
+ "version": "0.5.21",
+ "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz",
+ "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==",
+ "requires": {
+ "buffer-from": "^1.0.0",
+ "source-map": "^0.6.0"
+ }
+ },
+ "sourcemap-codec": {
+ "version": "1.4.8",
+ "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz",
+ "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA=="
+ },
+ "spdx-exceptions": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz",
+ "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==",
+ "dev": true
+ },
+ "spdx-expression-parse": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz",
+ "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==",
+ "dev": true,
+ "requires": {
+ "spdx-exceptions": "^2.1.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "spdx-license-ids": {
+ "version": "3.0.11",
+ "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.11.tgz",
+ "integrity": "sha512-Ctl2BrFiM0X3MANYgj3CkygxhRmr9mi6xhejbdO960nF6EDJApTYpn0BQnDKlnNBULKiCN1n3w9EBkHK8ZWg+g==",
+ "dev": true
+ },
+ "stable": {
+ "version": "0.1.8",
+ "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz",
+ "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w=="
+ },
+ "string-hash": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/string-hash/-/string-hash-1.1.3.tgz",
+ "integrity": "sha512-kJUvRUFK49aub+a7T1nNE66EJbZBMnBgoC1UbCZ5n6bsZKBRga4KgBRTMn/pFkeCZSYtNeSyMxPDM0AXWELk2A=="
+ },
+ "strip-ansi": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
+ "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^5.0.1"
+ }
+ },
+ "strip-indent": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-3.0.0.tgz",
+ "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==",
+ "requires": {
+ "min-indent": "^1.0.0"
+ }
+ },
+ "strip-json-comments": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
+ "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
+ "dev": true
+ },
+ "style-inject": {
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/style-inject/-/style-inject-0.3.0.tgz",
+ "integrity": "sha512-IezA2qp+vcdlhJaVm5SOdPPTUu0FCEqfNSli2vRuSIBbu5Nq5UvygTk/VzeCqfLz2Atj3dVII5QBKGZRZ0edzw=="
+ },
+ "stylehacks": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/stylehacks/-/stylehacks-5.1.0.tgz",
+ "integrity": "sha512-SzLmvHQTrIWfSgljkQCw2++C9+Ne91d/6Sp92I8c5uHTcy/PgeHamwITIbBW9wnFTY/3ZfSXR9HIL6Ikqmcu6Q==",
+ "requires": {
+ "browserslist": "^4.16.6",
+ "postcss-selector-parser": "^6.0.4"
+ }
+ },
+ "supports-color": {
+ "version": "5.5.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
+ "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
+ "requires": {
+ "has-flag": "^3.0.0"
+ }
+ },
+ "supports-preserve-symlinks-flag": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
+ "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w=="
+ },
+ "svelte": {
+ "version": "3.49.0",
+ "resolved": "https://registry.npmjs.org/svelte/-/svelte-3.49.0.tgz",
+ "integrity": "sha512-+lmjic1pApJWDfPCpUUTc1m8azDqYCG1JN9YEngrx/hUyIcFJo6VZhj0A1Ai0wqoHcEIuQy+e9tk+4uDgdtsFA=="
+ },
+ "svelte-dnd-action": {
+ "version": "0.9.19",
+ "resolved": "https://registry.npmjs.org/svelte-dnd-action/-/svelte-dnd-action-0.9.19.tgz",
+ "integrity": "sha512-1Jsym2HN0TJVUl09wLGASkHg937+ZecnnekPiwC0J6K7mCzOxCuIQSVnIxoQLLeiXv74joNVNpVofX9Z0jM4Vw==",
+ "dev": true
+ },
+ "svelte-hmr": {
+ "version": "0.14.12",
+ "resolved": "https://registry.npmjs.org/svelte-hmr/-/svelte-hmr-0.14.12.tgz",
+ "integrity": "sha512-4QSW/VvXuqVcFZ+RhxiR8/newmwOCTlbYIezvkeN6302YFRE8cXy0naamHcjz8Y9Ce3ITTZtrHrIL0AGfyo61w==",
+ "requires": {}
+ },
+ "svelte-preprocess": {
+ "version": "4.10.7",
+ "resolved": "https://registry.npmjs.org/svelte-preprocess/-/svelte-preprocess-4.10.7.tgz",
+ "integrity": "sha512-sNPBnqYD6FnmdBrUmBCaqS00RyCsCpj2BG58A1JBswNF7b0OKviwxqVrOL/CKyJrLSClrSeqQv5BXNg2RUbPOw==",
+ "requires": {
+ "@types/pug": "^2.0.4",
+ "@types/sass": "^1.16.0",
+ "detect-indent": "^6.0.0",
+ "magic-string": "^0.25.7",
+ "sorcery": "^0.10.0",
+ "strip-indent": "^3.0.0"
+ },
+ "dependencies": {
+ "magic-string": {
+ "version": "0.25.9",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz",
+ "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==",
+ "requires": {
+ "sourcemap-codec": "^1.4.8"
+ }
+ }
+ }
+ },
+ "svgo": {
+ "version": "2.8.0",
+ "resolved": "https://registry.npmjs.org/svgo/-/svgo-2.8.0.tgz",
+ "integrity": "sha512-+N/Q9kV1+F+UeWYoSiULYo4xYSDQlTgb+ayMobAXPwMnLvop7oxKMo9OzIrX5x3eS4L4f2UHhc9axXwY8DpChg==",
+ "requires": {
+ "@trysound/sax": "0.2.0",
+ "commander": "^7.2.0",
+ "css-select": "^4.1.3",
+ "css-tree": "^1.1.3",
+ "csso": "^4.2.0",
+ "picocolors": "^1.0.0",
+ "stable": "^0.1.8"
+ }
+ },
+ "terser": {
+ "version": "5.14.2",
+ "resolved": "https://registry.npmjs.org/terser/-/terser-5.14.2.tgz",
+ "integrity": "sha512-oL0rGeM/WFQCUd0y2QrWxYnq7tfSuKBiqTjRPWrRgB46WD/kiwHwF8T23z78H6Q6kGCuuHcPB+KULHRdxvVGQA==",
+ "requires": {
+ "@jridgewell/source-map": "^0.3.2",
+ "acorn": "^8.5.0",
+ "commander": "^2.20.0",
+ "source-map-support": "~0.5.20"
+ },
+ "dependencies": {
+ "commander": {
+ "version": "2.20.3",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz",
+ "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ=="
+ }
+ }
+ },
+ "text-table": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
+ "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
+ "dev": true
+ },
+ "tinymce": {
+ "version": "5.10.1",
+ "resolved": "https://registry.npmjs.org/tinymce/-/tinymce-5.10.1.tgz",
+ "integrity": "sha512-aIsFTYiuESpoYkCgkoojpVtPwrSvYBxp4mMEGsj20CnUruLCWosywkbYHDII+j7KlQZZn3p+xK89f5gT3QyuGw==",
+ "dev": true
+ },
+ "to-fast-properties": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
+ "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==",
+ "devOptional": true
+ },
+ "to-regex-range": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
+ "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
+ "requires": {
+ "is-number": "^7.0.0"
+ }
+ },
+ "type-check": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
+ "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
+ "dev": true,
+ "requires": {
+ "prelude-ls": "^1.2.1"
+ }
+ },
+ "type-fest": {
+ "version": "0.20.2",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
+ "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
+ "dev": true
+ },
+ "uglify-js": {
+ "version": "3.16.2",
+ "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.16.2.tgz",
+ "integrity": "sha512-AaQNokTNgExWrkEYA24BTNMSjyqEXPSfhqoS0AxmHkCJ4U+Dyy5AvbGV/sqxuxficEfGGoX3zWw9R7QpLFfEsg==",
+ "dev": true,
+ "optional": true
+ },
+ "unicode-canonical-property-names-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==",
+ "dev": true
+ },
+ "unicode-match-property-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==",
+ "dev": true,
+ "requires": {
+ "unicode-canonical-property-names-ecmascript": "^2.0.0",
+ "unicode-property-aliases-ecmascript": "^2.0.0"
+ }
+ },
+ "unicode-match-property-value-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-7Yhkc0Ye+t4PNYzOGKedDhXbYIBe1XEQYQxOPyhcXNMJ0WCABqqj6ckydd6pWRZTHV4GuCPKdBAUiMc60tsKVw==",
+ "dev": true
+ },
+ "unicode-property-aliases-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-5Zfuy9q/DFr4tfO7ZPeVXb1aPoeQSdeFMLpYuFebehDAhbuevLs5yxSZmIFN1tP5F9Wl4IpJrYojg85/zgyZHQ==",
+ "dev": true
+ },
+ "update-browserslist-db": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.5.tgz",
+ "integrity": "sha512-dteFFpCyvuDdr9S/ff1ISkKt/9YZxKjI9WlRR99c180GaztJtRa/fn18FdxGVKVsnPY7/a/FDN68mcvUmP4U7Q==",
+ "requires": {
+ "escalade": "^3.1.1",
+ "picocolors": "^1.0.0"
+ }
+ },
+ "uri-js": {
+ "version": "4.4.1",
+ "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
+ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
+ "dev": true,
+ "requires": {
+ "punycode": "^2.1.0"
+ }
+ },
+ "url": {
+ "version": "0.11.0",
+ "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz",
+ "integrity": "sha512-kbailJa29QrtXnxgq+DdCEGlbTeYM2eJUxsz6vjZavrCYPMIFHMKQmSKYAIuUK2i7hgPm28a8piX5NTUtM/LKQ==",
+ "dev": true,
+ "requires": {
+ "punycode": "1.3.2",
+ "querystring": "0.2.0"
+ },
+ "dependencies": {
"punycode": {
- "version": "1.3.2",
- "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz",
- "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=",
- "dev": true
- },
- "querystring": {
- "version": "0.2.0",
- "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz",
- "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=",
- "dev": true
- },
- "resource-loader": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/resource-loader/-/resource-loader-3.0.1.tgz",
- "integrity": "sha512-fBuCRbEHdLCI1eglzQhUv9Rrdcmqkydr1r6uHE2cYHvRBrcLXeSmbE/qI/urFt8rPr/IGxir3BUwM5kUK8XoyA==",
- "dev": true,
- "requires": {
- "mini-signals": "^1.2.0",
- "parse-uri": "^1.0.0"
- }
- },
- "socket.io-client": {
- "version": "4.3.2",
- "resolved": "https://registry.npmjs.org/socket.io-client/-/socket.io-client-4.3.2.tgz",
- "integrity": "sha512-2B9LqSunN60yV8F7S84CCEEcgbYNfrn7ejIInZtLZ7ppWtiX8rGZAjvdCvbnC8bqo/9RlCNOUsORLyskxSFP1g==",
- "dev": true,
- "requires": {
- "@socket.io/component-emitter": "~3.0.0",
- "backo2": "~1.0.2",
- "debug": "~4.3.2",
- "engine.io-client": "~6.0.1",
- "parseuri": "0.0.6",
- "socket.io-parser": "~4.1.1"
- }
- },
- "socket.io-parser": {
- "version": "4.1.1",
- "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.1.1.tgz",
- "integrity": "sha512-USQVLSkDWE5nbcY760ExdKaJxCE65kcsG/8k5FDGZVVxpD1pA7hABYXYkCUvxUuYYh/+uQw0N/fvBzfT8o07KA==",
- "dev": true,
- "requires": {
- "@socket.io/component-emitter": "~3.0.0",
- "debug": "~4.3.1"
- }
- },
- "source-map": {
- "version": "0.6.1",
- "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
- "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
- "dev": true
- },
- "tinymce": {
- "version": "5.10.1",
- "resolved": "https://registry.npmjs.org/tinymce/-/tinymce-5.10.1.tgz",
- "integrity": "sha512-aIsFTYiuESpoYkCgkoojpVtPwrSvYBxp4mMEGsj20CnUruLCWosywkbYHDII+j7KlQZZn3p+xK89f5gT3QyuGw==",
- "dev": true
- },
- "uglify-js": {
- "version": "3.14.5",
- "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.14.5.tgz",
- "integrity": "sha512-qZukoSxOG0urUTvjc2ERMTcAy+BiFh3weWAkeurLwjrCba73poHmG3E36XEjd/JGukMzwTL7uCxZiAexj8ppvQ==",
- "dev": true,
- "optional": true
- },
- "url": {
- "version": "0.11.0",
- "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz",
- "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=",
- "dev": true,
- "requires": {
- "punycode": "1.3.2",
- "querystring": "0.2.0"
- }
- },
- "wordwrap": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz",
- "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=",
- "dev": true
- },
- "ws": {
- "version": "8.2.3",
- "resolved": "https://registry.npmjs.org/ws/-/ws-8.2.3.tgz",
- "integrity": "sha512-wBuoj1BDpC6ZQ1B7DWQBYVLphPWkm8i9Y0/3YdHjHKHiohOJ1ws+3OccDWtH+PoC9DZD5WOTrJvNbWvjS6JWaA==",
- "dev": true,
- "requires": {}
- },
- "xmlhttprequest-ssl": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-2.0.0.tgz",
- "integrity": "sha512-QKxVRxiRACQcVuQEYFsI1hhkrMlrXHPegbbd1yn9UHOmRxY+si12nQYzri3vbzt8VdTTRviqcKxcyllFas5z2A==",
- "dev": true
- },
- "yeast": {
- "version": "0.1.2",
- "resolved": "https://registry.npmjs.org/yeast/-/yeast-0.1.2.tgz",
- "integrity": "sha1-AI4G2AlDIMNy28L47XagymyKxBk=",
- "dev": true
+ "version": "1.3.2",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz",
+ "integrity": "sha512-RofWgt/7fL5wP1Y7fxE7/EmTLzQVnB0ycyibJ0OOHIlJqTNzglYFxVwETOcIoJqJmpDXJ9xImDv+Fq34F/d4Dw==",
+ "dev": true
}
+ }
+ },
+ "util-deprecate": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
+ "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw=="
+ },
+ "v8-compile-cache": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz",
+ "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==",
+ "dev": true
+ },
+ "vite": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/vite/-/vite-3.0.2.tgz",
+ "integrity": "sha512-TAqydxW/w0U5AoL5AsD9DApTvGb2iNbGs3sN4u2VdT1GFkQVUfgUldt+t08TZgi23uIauh1TUOQJALduo9GXqw==",
+ "requires": {
+ "esbuild": "^0.14.47",
+ "fsevents": "~2.3.2",
+ "postcss": "^8.4.14",
+ "resolve": "^1.22.1",
+ "rollup": "^2.75.6"
+ }
+ },
+ "which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "requires": {
+ "isexe": "^2.0.0"
+ }
+ },
+ "word-wrap": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz",
+ "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==",
+ "dev": true
+ },
+ "wordwrap": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz",
+ "integrity": "sha512-gvVzJFlPycKc5dZN4yPkP8w7Dc37BtP1yczEneOb4uq34pXZcvrtRTmWV8W+Ume+XCxKgbjM+nevkyFPMybd4Q==",
+ "dev": true
+ },
+ "wrappy": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
+ "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ=="
+ },
+ "ws": {
+ "version": "8.2.3",
+ "resolved": "https://registry.npmjs.org/ws/-/ws-8.2.3.tgz",
+ "integrity": "sha512-wBuoj1BDpC6ZQ1B7DWQBYVLphPWkm8i9Y0/3YdHjHKHiohOJ1ws+3OccDWtH+PoC9DZD5WOTrJvNbWvjS6JWaA==",
+ "dev": true,
+ "requires": {}
+ },
+ "xmlhttprequest-ssl": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/xmlhttprequest-ssl/-/xmlhttprequest-ssl-2.0.0.tgz",
+ "integrity": "sha512-QKxVRxiRACQcVuQEYFsI1hhkrMlrXHPegbbd1yn9UHOmRxY+si12nQYzri3vbzt8VdTTRviqcKxcyllFas5z2A==",
+ "dev": true
+ },
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "yaml": {
+ "version": "1.10.2",
+ "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz",
+ "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg=="
+ },
+ "yeast": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/yeast/-/yeast-0.1.2.tgz",
+ "integrity": "sha512-8HFIh676uyGYP6wP13R/j6OJ/1HwJ46snpvzE7aHAN3Ryqh2yX6Xox2B4CUmTwwOIzlG3Bs7ocsP5dZH/R1Qbg==",
+ "dev": true
}
+ }
}
diff --git a/package.json b/package.json
index e39e662b..4a747765 100644
--- a/package.json
+++ b/package.json
@@ -1,5 +1,39 @@
{
- "devDependencies": {
- "@league-of-foundry-developers/foundry-vtt-types": "^9.238.1"
- }
+ "name": "essential-svelte-esm",
+ "version": "0.0.5",
+ "description": "Provides essential TRL demos for reactivity and beyond.",
+ "license": "MIT",
+ "private": true,
+ "type": "module",
+ "author": "Michael Leahy (https://github.com/typhonrt)",
+ "contributors": [
+ "Michael Leahy (https://github.com/typhonrt)"
+ ],
+ "dependencies": {
+ "@typhonjs-fvtt/runtime": "^0.0.19",
+ "@typhonjs-fvtt/svelte-standard": "^0.0.9",
+ "svelte": "^3.49.0"
+ },
+ "devDependencies": {
+ "@babel/core": "^7",
+ "@babel/preset-env": "^7",
+ "@league-of-foundry-developers/foundry-vtt-types": "^9.238.1",
+ "@rollup/plugin-babel": "^5",
+ "rollup": "^2",
+ "svelte-dnd-action": "^0.9.18",
+ "@typhonjs-config/eslint-config": "^0.3.0",
+ "@typhonjs-fvtt/eslint-config-foundry.js": "^0.8.0",
+ "eslint": "^8",
+ "svelte-preprocess": "^4.10.0",
+ "vite": "^3"
+ },
+ "browserslist": [
+ ">5%",
+ "not IE 11"
+ ],
+ "scripts": {
+ "build": "vite build",
+ "dev": "vite",
+ "eslint": "eslint ."
+ }
}
diff --git a/scripts/api.js b/scripts/api.js
deleted file mode 100644
index 92dd6e65..00000000
--- a/scripts/api.js
+++ /dev/null
@@ -1,2450 +0,0 @@
-import * as lib from "./lib/lib.js";
-import CONSTANTS from "./constants.js";
-import { itemPileSocket, SOCKET_HANDLERS } from "./socket.js";
-import { ItemPileInventory } from "./formapplications/item-pile-inventory.js";
-import DropItemDialog from "./formapplications/drop-item-dialog.js";
-import HOOKS from "./hooks.js";
-import { hotkeyState } from "./hotkeys.js";
-
-const preloadedFiles = new Set();
-
-const API = {
-
- /**
- * The actor class type used for the original item pile actor in this system
- *
- * @returns {String}
- */
- get ACTOR_CLASS_TYPE() {
- return game.settings.get(CONSTANTS.MODULE_NAME, "actorClassType");
- },
-
- /**
- * The currencies used in this system
- *
- * @returns {Array<{name: String, currency: String, img: String}>}
- */
- get CURRENCIES() {
- return game.settings.get(CONSTANTS.MODULE_NAME, "currencies");
- },
-
- /**
- * The attribute used to track the quantity of items in this system
- *
- * @returns {String}
- */
- get ITEM_QUANTITY_ATTRIBUTE() {
- return game.settings.get(CONSTANTS.MODULE_NAME, "itemQuantityAttribute");
- },
-
- /**
- * The filters for item types eligible for interaction within this system
- *
- * @returns {Array<{name: String, filters: String}>}
- */
- get ITEM_FILTERS() {
- return lib.cleanItemFilters(game.settings.get(CONSTANTS.MODULE_NAME, "itemFilters"));
- },
-
- /**
- * The attributes for detecting item similarities
- *
- * @returns {Array}
- */
- get ITEM_SIMILARITIES() {
- return game.settings.get(CONSTANTS.MODULE_NAME, "itemSimilarities");
- },
-
- /**
- * Sets the actor class type used for the original item pile actor in this system
- *
- * @param {String} inClassType
- * @returns {Promise}
- */
- async setActorClassType(inClassType) {
- if (typeof inClassType !== "string") {
- throw lib.custom_error("setActorTypeClass | inClassType must be of type string");
- }
- await game.settings.set(CONSTANTS.MODULE_NAME, "preconfiguredSystem", true);
- return game.settings.set(CONSTANTS.MODULE_NAME, "actorClassType", inClassType);
- },
-
- /**
- * Sets the currencies used in this system
- *
- * @param {Array<{name: String, currency: String, img: String}>} inCurrencies
- * @returns {Promise}
- */
- async setCurrencies(inCurrencies) {
- if (!Array.isArray(inCurrencies)) {
- throw lib.custom_error("setCurrencies | inCurrencies must be of type array");
- }
- inCurrencies.forEach(currency => {
- if (typeof currency !== "object") {
- throw lib.custom_error("setCurrencies | each entry in the inCurrencies array must be of type object");
- }
- if (typeof currency.name !== "string") {
- throw lib.custom_error("setCurrencies | currency.name must be of type string");
- }
- if (typeof currency.currency !== "string") {
- throw lib.custom_error("setCurrencies | currency.path must be of type string");
- }
- if (currency.img && typeof currency.img !== "string") {
- throw lib.custom_error("setCurrencies | currency.img must be of type string");
- }
- })
- await game.settings.set(CONSTANTS.MODULE_NAME, "preconfiguredSystem", true);
- return game.settings.set(CONSTANTS.MODULE_NAME, "currencies", inCurrencies);
- },
-
- /**
- * Sets the inAttribute used to track the quantity of items in this system
- *
- * @param {String} inAttribute
- * @returns {Promise}
- */
- async setItemQuantityAttribute(inAttribute) {
- if (typeof inAttribute !== "string") {
- throw lib.custom_error("setItemQuantityAttribute | inAttribute must be of type string");
- }
- await game.settings.set(CONSTANTS.MODULE_NAME, "preconfiguredSystem", true);
- return game.settings.set(CONSTANTS.MODULE_NAME, "itemQuantityAttribute", inAttribute);
- },
-
- /**
- * Sets the items filters for interaction within this system
- *
- * @param {Array<{path: String, filters: String}>} inFilters
- * @returns {Promise}
- */
- async setItemFilters(inFilters) {
- if (!Array.isArray(inFilters)) {
- throw lib.custom_error("setItemFilters | inFilters must be of type array");
- }
- inFilters.forEach(filter => {
- if (typeof filter?.path !== "string") {
- throw lib.custom_error("setItemFilters | each entry in inFilters must have a \"path\" property with a value that is of type string");
- }
- if (typeof filter?.filters !== "string") {
- throw lib.custom_error("setItemFilters | each entry in inFilters must have a \"filters\" property with a value that is of type string");
- }
- });
- await game.settings.set(CONSTANTS.MODULE_NAME, "preconfiguredSystem", true);
- return game.settings.set(CONSTANTS.MODULE_NAME, "itemFilters", inFilters);
- },
-
- /**
- * Sets the attributes for detecting item similarities
- *
- * @param {Array} inPaths
- * @returns {Promise}
- */
- async setItemSimilarities(inPaths) {
- if (!Array.isArray(inPaths)) {
- throw lib.custom_error("setItemSimilarities | inPaths must be of type array");
- }
- inPaths.forEach(path => {
- if (typeof path !== "string") {
- throw lib.custom_error("setItemSimilarities | each entry in inPaths must be of type string");
- }
- });
- await game.settings.set(CONSTANTS.MODULE_NAME, "preconfiguredSystem", true);
- return game.settings.set(CONSTANTS.MODULE_NAME, "itemSimilarities", inPaths);
- },
-
- /**
- * Creates the default item pile token at a location.
- *
- * @param {Object} position The position to create the item pile at
- * @param {String/Boolean} [sceneId=false] Which scene to create the item pile on
- * @param {Array/Boolean} [items=false] Any items to create on the item pile
- * @param {String/Boolean} [pileActorName=false] Whether to use an existing item pile actor as the basis of this new token
- *
- * @returns {Promise}
- */
- async createItemPile(position, { sceneId = game.user.viewedScene, items = false, pileActorName = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.PILE.PRE_CREATE, position, items, pileActorName);
- if (hookResult === false) return;
-
- if (pileActorName) {
- const pileActor = game.actors.getName(pileActorName);
- if (!pileActor) {
- throw lib.custom_error(`There is no actor of the name "${pileActorName}"`, true);
- } else if (!lib.isValidItemPile(pileActor)) {
- throw lib.custom_error(`The actor of name "${pileActorName}" is not a valid item pile actor.`, true);
- }
- }
-
- if (items) {
- items = items.map(item => {
- return item instanceof Item
- ? item.toObject()
- : item;
- })
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.CREATE_PILE, sceneId, position, { pileActorName, items });
- },
-
- /**
- * Turns tokens and its actors into item piles
- *
- * @param {Token/TokenDocument/Array} targets The targets to be turned into item piles
- * @param {Object} pileSettings Overriding settings to be put on the item piles' settings
- * @param {Object} tokenSettings Overriding settings that will update the tokens' settings
- *
- * @return {Promise} The uuids of the targets after they were turned into item piles
- */
- async turnTokensIntoItemPiles(targets, { pileSettings = {}, tokenSettings = {} } = {}) {
-
- const hookResult = Hooks.call(HOOKS.PILE.PRE_TURN_INTO, targets, pileSettings, tokenSettings);
- if (hookResult === false) return;
-
- if (!Array.isArray(targets)) targets = [targets];
-
- const targetUuids = targets.map(target => {
- if (!(target instanceof Token || target instanceof TokenDocument)) {
- throw lib.custom_error(`turnTokensIntoItemPiles | Target must be of type Token or TokenDocument`, true)
- }
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`turnTokensIntoItemPiles | Could not determine the UUID, please provide a valid target`, true)
- return targetUuid;
- })
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.TURN_INTO_PILE, targetUuids, pileSettings, tokenSettings);
- },
-
- /**
- * @private
- */
- async _turnTokensIntoItemPiles(targetUuids, pileSettings = {}, tokenSettings = {}) {
-
- const tokenUpdateGroups = {};
- const actorUpdateGroups = {};
- const defaults = foundry.utils.duplicate(CONSTANTS.PILE_DEFAULTS);
-
- for (const targetUuid of targetUuids) {
-
- let target = await fromUuid(targetUuid);
-
- const existingPileSettings = foundry.utils.mergeObject(defaults, lib.getItemPileData(target));
- pileSettings = foundry.utils.mergeObject(existingPileSettings, pileSettings);
- pileSettings.enabled = true;
-
- const targetItems = lib.getActorItems(target, pileSettings.overrideItemFilters);
- const targetCurrencies = lib.getActorCurrencies(target, pileSettings.overrideCurrencies);
-
- const data = { data: pileSettings, items: targetItems, currencies: targetCurrencies };
-
- tokenSettings = foundry.utils.mergeObject(tokenSettings, {
- "img": lib.getItemPileTokenImage(target, data),
- "scale": lib.getItemPileTokenScale(target, data),
- "name": lib.getItemPileName(target, data)
- });
-
- const sceneId = targetUuid.split('.')[1];
- const tokenId = targetUuid.split('.')[3];
-
- if (!tokenUpdateGroups[sceneId]) {
- tokenUpdateGroups[sceneId] = []
- }
-
- tokenUpdateGroups[sceneId].push({
- "_id": tokenId,
- ...tokenSettings,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileSettings,
- [`actorData.flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileSettings
- });
-
- if (target.isLinked) {
- if (actorUpdateGroups[target.actor.id]) continue;
- actorUpdateGroups[target.actor.id] = {
- "_id": target.actor.id,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileSettings
- }
- }
- }
-
- await Actor.updateDocuments(Object.values(actorUpdateGroups));
-
- for (const [sceneId, updateData] of Object.entries(tokenUpdateGroups)) {
- const scene = game.scenes.get(sceneId);
- await scene.updateEmbeddedDocuments("Token", updateData);
- }
-
- setTimeout(API.rerenderTokenHud, 100);
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.PILE.TURN_INTO, targetUuids);
-
- return targetUuids;
-
- },
-
- /**
- * Reverts tokens from an item pile into a normal token and actor
- *
- * @param {Token/TokenDocument/Array} targets The targets to be reverted from item piles
- * @param {Object} tokenSettings Overriding settings that will update the tokens
- *
- * @return {Promise} The uuids of the targets after they were reverted from being item piles
- */
- async revertTokensFromItemPiles(targets, { tokenSettings = {} } = {}) {
- const hookResult = Hooks.call(HOOKS.PILE.PRE_REVERT_FROM, targets, tokenSettings);
- if (hookResult === false) return;
-
- if (!Array.isArray(targets)) targets = [targets];
-
- const targetUuids = targets.map(target => {
- if (!(target instanceof Token || target instanceof TokenDocument)) {
- throw lib.custom_error(`revertTokensFromItemPiles | Target must be of type Token or TokenDocument`, true)
- }
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`revertTokensFromItemPiles | Could not determine the UUID, please provide a valid target`, true)
- return targetUuid;
- })
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.REVERT_FROM_PILE, targetUuids, tokenSettings);
- },
-
- /**
- * @private
- */
- async _revertTokensFromItemPiles(targetUuids, tokenSettings) {
-
- const actorUpdateGroups = {};
- const tokenUpdateGroups = {};
- const defaults = foundry.utils.duplicate(CONSTANTS.PILE_DEFAULTS);
-
- for (const targetUuid of targetUuids) {
-
- let target = await fromUuid(targetUuid);
-
- const pileSettings = foundry.utils.mergeObject(defaults, lib.getItemPileData(target));
- pileSettings.enabled = false;
-
- const sceneId = targetUuid.split('.')[1];
- const tokenId = targetUuid.split('.')[3];
-
- if (!tokenUpdateGroups[sceneId]) {
- tokenUpdateGroups[sceneId] = [];
- }
-
- tokenUpdateGroups[sceneId].push({
- "_id": tokenId,
- ...tokenSettings,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileSettings,
- [`actorData.flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileSettings
- });
-
- if (target.isLinked) {
- if (actorUpdateGroups[target.actor.id]) continue;
- actorUpdateGroups[target.actor.id] = {
- "_id": target.actor.id,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileSettings
- }
- }
-
- }
-
- await Actor.updateDocuments(Object.values(actorUpdateGroups));
-
- for (const [sceneId, updateData] of Object.entries(tokenUpdateGroups)) {
- const scene = game.scenes.get(sceneId);
- await scene.updateEmbeddedDocuments("Token", updateData);
- }
-
- setTimeout(API.rerenderTokenHud, 100);
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.PILE.REVERT_FROM, targetUuids);
-
- return targetUuids;
-
- },
-
- /**
- * Opens a pile if it is enabled and a container
- *
- * @param {Token/TokenDocument} target
- * @param {Token/TokenDocument/Boolean} [interactingToken=false]
- *
- * @return {Promise}
- */
- async openItemPile(target, interactingToken = false) {
- const targetDocument = lib.getDocument(target);
- const interactingTokenDocument = interactingToken ? lib.getDocument(interactingToken) : false;
-
- const data = lib.getItemPileData(targetDocument);
- if (!data?.enabled || !data?.isContainer) return false;
- const wasLocked = data.locked;
- const wasClosed = data.closed;
- data.closed = false;
- data.locked = false;
- if (wasLocked) {
- const hookResult = Hooks.call(HOOKS.PILE.PRE_UNLOCK, targetDocument, data, interactingTokenDocument);
- if (hookResult === false) return;
- }
- const hookResult = Hooks.call(HOOKS.PILE.PRE_OPEN, targetDocument, data, interactingTokenDocument);
- if (hookResult === false) return;
- if (wasClosed && data.openSound) {
- AudioHelper.play({ src: data.openSound })
- }
- return API.updateItemPile(targetDocument, data, { interactingToken: interactingTokenDocument });
- },
-
- /**
- * Closes a pile if it is enabled and a container
- *
- * @param {Token/TokenDocument} target Target pile to close
- * @param {Token/TokenDocument/Boolean} [interactingToken=false]
- *
- * @return {Promise}
- */
- async closeItemPile(target, interactingToken = false) {
- const targetDocument = lib.getDocument(target);
- const interactingTokenDocument = interactingToken ? lib.getDocument(interactingToken) : false;
-
- const data = lib.getItemPileData(targetDocument);
- if (!data?.enabled || !data?.isContainer) return false;
- const wasClosed = data.closed;
- data.closed = true;
- const hookResult = Hooks.call(HOOKS.PILE.PRE_CLOSE, targetDocument, data, interactingTokenDocument);
- if (hookResult === false) return;
- if (!wasClosed && data.closeSound) {
- AudioHelper.play({ src: data.closeSound })
- }
- return API.updateItemPile(targetDocument, data, { interactingToken: interactingTokenDocument });
- },
-
- /**
- * Toggles a pile's closed state if it is enabled and a container
- *
- * @param {Token/TokenDocument} target Target pile to open or close
- * @param {Token/TokenDocument/Boolean} [interactingToken=false]
- *
- * @return {Promise}
- */
- async toggleItemPileClosed(target, interactingToken = false) {
- const targetDocument = lib.getDocument(target);
- const interactingTokenDocument = interactingToken ? lib.getDocument(interactingToken) : false;
-
- const data = lib.getItemPileData(targetDocument);
- if (!data?.enabled || !data?.isContainer) return false;
- if (data.closed) {
- await API.openItemPile(targetDocument, interactingTokenDocument);
- } else {
- await API.closeItemPile(targetDocument, interactingTokenDocument);
- }
- return !data.closed;
- },
-
- /**
- * Locks a pile if it is enabled and a container
- *
- * @param {Token/TokenDocument} target Target pile to lock
- * @param {Token/TokenDocument/Boolean} [interactingToken=false]
- *
- * @return {Promise}
- */
- async lockItemPile(target, interactingToken = false) {
- const targetDocument = lib.getDocument(target);
- const interactingTokenDocument = interactingToken ? lib.getDocument(interactingToken) : false;
-
- const data = lib.getItemPileData(targetDocument);
- if (!data?.enabled || !data?.isContainer) return false;
- const wasClosed = data.closed;
- data.closed = true;
- data.locked = true;
- if (!wasClosed) {
- const hookResult = Hooks.call(HOOKS.PILE.PRE_CLOSE, targetDocument, data, interactingTokenDocument);
- if (hookResult === false) return;
- }
- const hookResult = Hooks.call(HOOKS.PILE.PRE_LOCK, targetDocument, data, interactingTokenDocument);
- if (hookResult === false) return;
- if (!wasClosed && data.closeSound) {
- AudioHelper.play({ src: data.closeSound })
- }
- return API.updateItemPile(targetDocument, data, { interactingToken: interactingTokenDocument });
- },
-
- /**
- * Unlocks a pile if it is enabled and a container
- *
- * @param {Token/TokenDocument} target Target pile to unlock
- * @param {Token/TokenDocument/Boolean} [interactingToken=false]
- *
- * @return {Promise}
- */
- async unlockItemPile(target, interactingToken = false) {
- const targetDocument = lib.getDocument(target);
- const interactingTokenDocument = interactingToken ? lib.getDocument(interactingToken) : false;
-
- const data = lib.getItemPileData(targetDocument);
- if (!data?.enabled || !data?.isContainer) return false;
- data.locked = false;
- Hooks.call(HOOKS.PILE.PRE_UNLOCK, targetDocument, data, interactingTokenDocument);
- return API.updateItemPile(targetDocument, data, { interactingToken: interactingTokenDocument });
- },
-
- /**
- * Toggles a pile's locked state if it is enabled and a container
- *
- * @param {Token/TokenDocument} target Target pile to lock or unlock
- * @param {Token/TokenDocument/Boolean} [interactingToken=false]
- *
- * @return {Promise}
- */
- async toggleItemPileLocked(target, interactingToken = false) {
- const targetDocument = lib.getDocument(target);
- const interactingTokenDocument = interactingToken ? lib.getDocument(interactingToken) : false;
-
- const data = lib.getItemPileData(targetDocument);
- if (!data?.enabled || !data?.isContainer) return false;
- if (data.locked) {
- return API.unlockItemPile(targetDocument, interactingTokenDocument);
- }
- return API.lockItemPile(targetDocument, interactingTokenDocument);
- },
-
- /**
- * Causes the item pile to play a sound as it was attempted to be opened, but was locked
- *
- * @param {Token/TokenDocument} target
- * @param {Token/TokenDocument/Boolean} [interactingToken=false]
- *
- * @return {Promise}
- */
- async rattleItemPile(target, interactingToken = false) {
- const targetDocument = lib.getDocument(target);
- const interactingTokenDocument = interactingToken ? lib.getDocument(interactingToken) : false;
-
- const data = lib.getItemPileData(targetDocument);
- if (!data?.enabled || !data?.isContainer || !data?.locked) return false;
- Hooks.call(HOOKS.PILE.PRE_RATTLE, targetDocument, data, interactingTokenDocument);
- if (data.lockedSound) {
- AudioHelper.play({ src: data.lockedSound })
- }
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.PILE.RATTLE, lib.getUuid(targetDocument), data, lib.getUuid(interactingTokenDocument));
- return true;
- },
-
- /**
- * Whether an item pile is locked. If it is not enabled or not a container, it is always false.
- *
- * @param {Token/TokenDocument} target
- *
- * @return {Boolean}
- */
- isItemPileLocked(target) {
- const targetDocument = lib.getDocument(target);
- const data = lib.getItemPileData(targetDocument);
- if (!data?.enabled || !data?.isContainer) return false;
- return data.locked;
- },
-
- /**
- * Whether an item pile is closed. If it is not enabled or not a container, it is always false.
- *
- * @param {Token/TokenDocument} target
- *
- * @return {Boolean}
- */
- isItemPileClosed(target) {
- const targetDocument = lib.getDocument(target);
- const data = lib.getItemPileData(targetDocument);
- if (!data?.enabled || !data?.isContainer) return false;
- return data.closed;
- },
-
- /**
- * Whether an item pile is a container. If it is not enabled, it is always false.
- *
- * @param {Token/TokenDocument} target
- *
- * @return {Boolean}
- */
- isItemPileContainer(target) {
- const targetDocument = lib.getDocument(target);
- const data = lib.getItemPileData(targetDocument);
- return data?.enabled && data?.isContainer;
- },
-
- /**
- * Updates a pile with new data.
- *
- * @param {Token/TokenDocument} target
- * @param {Object} newData
- * @param {Token/TokenDocument/Boolean} [interactingToken=false]
- * @param {Object/Boolean} [tokenSettings=false]
- *
- * @return {Promise}
- */
- async updateItemPile(target, newData, { interactingToken = false, tokenSettings = false } = {}) {
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`updateItemPile | Could not determine the UUID, please provide a valid target`, true);
-
- const interactingTokenUuid = interactingToken ? lib.getUuid(interactingToken) : false;
- if (interactingToken && !interactingTokenUuid) throw lib.custom_error(`updateItemPile | Could not determine the UUID, please provide a valid target`, true);
-
- const hookResult = Hooks.call(HOOKS.PILE.PRE_UPDATE, target, newData, interactingToken, tokenSettings);
- if (hookResult === false) return;
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.UPDATE_PILE, targetUuid, newData, {
- interactingTokenUuid,
- tokenSettings
- })
- },
-
- /**
- * @private
- */
- async _updateItemPile(targetUuid, newData, { interactingTokenUuid = false, tokenSettings = false } = {}) {
-
- const target = await fromUuid(targetUuid);
-
- const oldData = lib.getItemPileData(target);
-
- const data = foundry.utils.mergeObject(
- foundry.utils.duplicate(oldData),
- foundry.utils.duplicate(newData)
- );
-
- const diff = foundry.utils.diffObject(oldData, data);
-
- await lib.wait(15);
-
- await lib.updateItemPileData(target, data, tokenSettings);
-
- if (data.enabled && data.isContainer) {
- if (diff?.closed === true) {
- API._executeItemPileMacro(targetUuid, {
- action: "closeItemPile",
- source: interactingTokenUuid,
- target: targetUuid
- });
- }
- if (diff?.locked === true) {
- API._executeItemPileMacro(targetUuid, {
- action: "lockItemPile",
- source: interactingTokenUuid,
- target: targetUuid
- });
- }
- if (diff?.locked === false) {
- API._executeItemPileMacro(targetUuid, {
- action: "unlockItemPile",
- source: interactingTokenUuid,
- target: targetUuid
- });
- }
- if (diff?.closed === false) {
- API._executeItemPileMacro(targetUuid, {
- action: "openItemPile",
- source: interactingTokenUuid,
- target: targetUuid
- });
- }
- }
-
- return itemPileSocket.executeForEveryone(SOCKET_HANDLERS.UPDATED_PILE, targetUuid, diff, interactingTokenUuid);
- },
-
- /**
- * @private
- */
- async _updatedItemPile(targetUuid, diffData, interactingTokenUuid) {
-
- const target = await lib.getToken(targetUuid);
-
- const interactingToken = interactingTokenUuid ? await fromUuid(interactingTokenUuid) : false;
-
- if (foundry.utils.isObjectEmpty(diffData)) return;
-
- const data = lib.getItemPileData(target);
-
- Hooks.callAll(HOOKS.PILE.UPDATE, target, diffData, interactingToken)
-
- if (data.enabled && data.isContainer) {
- if (diffData?.closed === true) {
- Hooks.callAll(HOOKS.PILE.CLOSE, target, interactingToken)
- }
- if (diffData?.locked === true) {
- Hooks.callAll(HOOKS.PILE.LOCK, target, interactingToken)
- }
- if (diffData?.locked === false) {
- Hooks.callAll(HOOKS.PILE.UNLOCK, target, interactingToken)
- }
- if (diffData?.closed === false) {
- Hooks.callAll(HOOKS.PILE.OPEN, target, interactingToken)
- }
- }
- },
-
- /**
- * Deletes a pile, calling the relevant hooks.
- *
- * @param {Token/TokenDocument} target
- *
- * @return {Promise}
- */
- async deleteItemPile(target) {
- if (!lib.isValidItemPile(target)) {
- if (!targetUuid) throw lib.custom_error(`deleteItemPile | This is not an item pile, please provide a valid target`, true);
- }
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`deleteItemPile | Could not determine the UUID, please provide a valid target`, true);
- if (!targetUuid.includes("Token")) {
- throw lib.custom_error(`deleteItemPile | Please provide a Token or TokenDocument`, true);
- }
- const hookResult = Hooks.call(HOOKS.PILE.PRE_DELETE, target);
- if (hookResult === false) return;
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.DELETE_PILE, targetUuid);
- },
-
- async _deleteItemPile(targetUuid) {
- const target = await lib.getToken(targetUuid);
- return target.delete();
- },
-
- /**
- * @deprecated
- */
- async openItemPileInventory(...args) {
- lib.custom_warning("deprecation warning - openItemPileInventory has been renamed to renderItemPileInventory")
- return this.renderItemPileInterface(...args);
- },
-
- /**
- * Remotely opens an item pile's inventory, if you have permission to edit the item pile. Passing a user ID, or a list of user IDs, will cause those users to open the item pile.
- *
- * @param {Token/TokenDocument/Actor} target The item pile actor or token whose inventory to open
- * @param {Array} userIds The IDs of the users that should open this item pile inventory
- * @param {boolean/Token/TokenDocument/Actor} [inspectingTarget=false] This will force the users to inspect this item pile as a specific character
- * @param {Boolean} [useDefaultCharacter=true] Causes the users to inspect the item pile inventory as their default character
- * @returns {Promise}
- */
- async renderItemPileInterface(target, userIds = [game.user.id], {
- inspectingTarget = false,
- useDefaultCharacter = true
- } = {}) {
-
- const targetDocument = lib.getDocument(target);
- const targetUuid = lib.getUuid(targetDocument);
- if (!targetUuid) throw lib.custom_error(`renderItemPileInterface | Could not determine the UUID, please provide a valid target item pile`);
-
- if (!lib.isValidItemPile(targetDocument)) {
- throw lib.custom_error("renderItemPileInterface | This target is not a valid item pile")
- }
-
- if (inspectingTarget && useDefaultCharacter) {
- throw lib.custom_error("renderItemPileInterface | You cannot force users to use both their default character and a specific character to inspect the pile")
- }
-
- if (!Array.isArray(userIds)) userIds = [userIds];
-
- if (!game.user.isGM) {
- if (userIds.length > 1 || !userIds.includes(game.user.id)) {
- throw lib.custom_error(`renderItemPileInterface | You are not a GM, so you cannot force others to render an item pile's interface`);
- }
- userIds = [game.user.id];
- }
-
- for (const userId of userIds) {
- const user = game.users.get(userId);
- if (!user) throw lib.custom_error(`renderItemPileInterface | No user with ID "${userId}" exists`);
- if (useDefaultCharacter) {
- if (!user.character) {
- lib.custom_warning(`renderItemPileInterface | User with id "${userId}" has no default character`, true);
- return;
- }
- }
- }
-
- const inspectingTargetUuid = inspectingTarget ? lib.getUuid(inspectingTarget) : false;
- if (inspectingTarget && !inspectingTargetUuid) throw lib.custom_error(`renderItemPileInterface | Could not determine the UUID, please provide a valid inspecting target`);
-
- return itemPileSocket.executeForUsers(SOCKET_HANDLERS.RENDER_INTERFACE, userIds, targetUuid, inspectingTargetUuid, useDefaultCharacter)
- },
-
- async _renderItemPileInterface(targetUuid, inspectingTargetUuid, useDefaultCharacter) {
- const target = await fromUuid(targetUuid);
-
- let inspectingTarget;
- if (useDefaultCharacter && !game.user.isGM) {
- inspectingTarget = game.user.character;
- } else {
- inspectingTarget = inspectingTargetUuid ? (await fromUuid(inspectingTargetUuid)) : false;
- }
-
- return ItemPileInventory.show(target, inspectingTarget, { remote: true });
- },
-
- /**
- * Whether a given document is a valid pile or not
- *
- * @param {Token/TokenDocument/Actor} document
- * @return {Boolean}
- */
- isValidItemPile(document) {
- return lib.isValidItemPile(document);
- },
-
- /**
- * Whether the item pile is empty
- *
- * @param {Token/TokenDocument/Actor} target
- * @returns {Boolean}
- */
- isItemPileEmpty(target) {
- return lib.isItemPileEmpty(target);
- },
-
- /**
- * Returns the items this item pile can transfer
- *
- * @param {Token/TokenDocument/Actor} target
- * @param {Array/Boolean} [itemFilters=false] Array of item types disallowed - will default to pile settings or module settings if none provided
- * @returns {Array}
- */
- getItemPileItems(target, itemFilters = false) {
- return lib.getActorItems(target, itemFilters);
- },
-
- /**
- * Returns the currencies this item pile can transfer
- *
- * @param {Token/TokenDocument/Actor} target
- * @returns {Array}
- */
- getItemPileCurrencies(target) {
- return lib.getActorCurrencies(target);
- },
-
- /**
- * Refreshes the target image of an item pile, ensuring it remains in sync
- *
- * @param {Token/TokenDocument/Actor} target
- * @return {Promise}
- */
- async refreshItemPile(target) {
- if (!lib.isValidItemPile(target)) return;
- const targetUuid = lib.getUuid(target);
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.REFRESH_PILE, targetUuid)
- },
-
- /**
- * @private
- */
- async _refreshItemPile(targetUuid) {
- const targetDocument = await fromUuid(targetUuid);
-
- if (!lib.isValidItemPile(targetDocument)) return;
-
- let targets = [targetDocument]
- if (targetDocument instanceof Actor) {
- targets = Array.from(canvas.tokens.getDocuments()).filter(token => token.actor === targetDocument);
- }
-
- return Promise.allSettled(targets.map(_target => {
- return new Promise(async (resolve) => {
- const uuid = lib.getUuid(_target);
- const shouldBeDeleted = await API._checkItemPileShouldBeDeleted(uuid);
- if (!shouldBeDeleted) {
- await _target.update({
- "img": lib.getItemPileTokenImage(targetDocument),
- "scale": lib.getItemPileTokenScale(targetDocument),
- "name": lib.getItemPileName(targetDocument)
- })
- }
- resolve();
- })
- }));
- },
-
- /**
- * Causes all connected users to re-render a specific pile's inventory UI
- *
- * @param {String} inPileUuid The uuid of the pile to be re-rendered
- * @param {Boolean} [deleted=false] Whether the pile was deleted as a part of this re-render
- * @return {Promise}
- */
- async rerenderItemPileInventoryApplication(inPileUuid, deleted = false) {
- return itemPileSocket.executeForEveryone(SOCKET_HANDLERS.RERENDER_PILE_INVENTORY, inPileUuid, deleted);
- },
-
- /**
- * @private
- */
- async _rerenderItemPileInventoryApplication(inPileUuid, deleted = false) {
- return ItemPileInventory.rerenderActiveApp(inPileUuid, deleted);
- },
-
- /**
- * Splits an item pile's content between all players (or a specified set of target actors).
- *
- * @param itemPile {Token/TokenDocument/Actor} The item pile to split
- * @param targets {boolean/TokenDocument/Actor/Array} [targets=false] The targets to receive the split contents
- * @param instigator {boolean/TokenDocument/Actor} [instigator=false] Whether this was triggered by a specific actor
- * @returns {Promise}
- */
- async splitItemPileContents(itemPile, { targets = false, instigator = false } = {}) {
-
- if (!lib.isValidItemPile(itemPile)) return false;
-
- const itemPileUuid = lib.getUuid(itemPile);
- if (!itemPileUuid) throw lib.custom_error(`SplitItemPileContents | Could not determine the UUID, please provide a valid item pile`, true)
-
- const itemPileActor = itemPile?.actor ?? itemPile;
-
- if (targets) {
- if (!Array.isArray(targets)) {
- targets = [targets]
- }
- targets.forEach(actor => {
- if (!(actor instanceof TokenDocument || actor instanceof Actor)) {
- throw lib.custom_error("SplitItemPileContents | Each of the entries in targets must be of type TokenDocument or Actor")
- }
- })
- targets = targets.map(target => target?.character ?? target?.actor ?? target);
- }
-
- if (instigator && !(instigator instanceof TokenDocument || instigator instanceof Actor)) {
- throw lib.custom_error("SplitItemPileContents | splitter must be of type TokenDocument or Actor")
- }
-
- const actorUuids = (targets || lib.getPlayersForItemPile(itemPileActor).map(u => u.character)).map(actor => lib.getUuid(actor));
-
- const hookResult = Hooks.call(HOOKS.PILE.PRE_SPLIT_INVENTORY, itemPile, targets, game.user.id, instigator);
- if (hookResult === false) return;
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.SPLIT_PILE, itemPileUuid, actorUuids, game.user.id, instigator);
-
- },
-
- /**
- * @private
- */
- async _splitItemPileContents(itemPileUuid, actorUuids, userId, instigator) {
-
- const itemPile = await fromUuid(itemPileUuid);
-
- const itemPileActor = itemPile?.actor ?? itemPile;
-
- const actors = await Promise.all(actorUuids.map((uuid) => fromUuid(uuid)));
-
- const itemsToRemove = {};
- const currenciesToRemove = {}
-
- const transferData = {
- items: {},
- currencies: {},
- num_players: actors.length
- }
-
- for(const actor of actors){
-
- const itemsToTransfer = lib.getItemPileItemsForActor(itemPileActor, actor, true).filter(item => item.toShare).map(item => {
- itemsToRemove[item.id] = (itemsToRemove[item.id] ?? 0) + item.shareLeft;
- transferData.items[item.id] = {
- id: item.id,
- name: item.name,
- img: item.img,
- quantity: (transferData.items[item.id]?.quantity ?? 0) + (item.shareLeft + item.previouslyTaken)
- }
- return { _id: item.id, quantity: item.shareLeft };
- }).filter(item => item.quantity);
-
- const currenciesToTransfer = Object.fromEntries(lib.getItemPileCurrenciesForActor(itemPileActor, actor, true).filter(item => item.toShare).map(currency => {
- currenciesToRemove[currency.path] = (currenciesToRemove[currency.path] ?? 0) + currency.shareLeft;
- transferData.currencies[currency.path] = {
- path: currency.path,
- name: currency.name,
- img: currency.img,
- quantity: (transferData.currencies[currency.path]?.quantity ?? 0) + (currency.shareLeft + currency.previouslyTaken),
- index: currency.index
- }
- return [currency.path, currency.shareLeft]
- }).filter(currency => currency[1]));
-
- await API._addItems(actor.uuid, itemsToTransfer, userId, { runHooks: false });
- await API._addAttributes(actor.uuid, currenciesToTransfer, userId, { runHooks: false });
-
- }
-
- transferData.items = Object.values(transferData.items).map(item => {
- item.quantity = item.quantity / actors.length;
- return item;
- });
-
- transferData.currencies = Object.values(transferData.currencies).map(currency => {
- currency.quantity = currency.quantity / actors.length;
- return currency;
- });
-
- await lib.clearItemPileSharingData(itemPileActor);
-
- await API._removeItems(itemPileUuid, Object.entries(itemsToRemove).map(entry => ({ _id: entry[0], quantity: entry[1] })), userId, { runHooks: false });
- await API._removeAttributes(itemPileUuid, currenciesToRemove, userId, { runHooks: false });
-
- await itemPileSocket.executeForEveryone(
- SOCKET_HANDLERS.CALL_HOOK,
- HOOKS.PILE.SPLIT_INVENTORY,
- itemPileUuid,
- transferData,
- userId,
- instigator
- );
-
- const macroData = {
- action: "splitInventory",
- source: itemPileUuid,
- target: actorUuids,
- transfers: transferData,
- userId: userId,
- instigator: instigator
- };
-
- await API._executeItemPileMacro(itemPileUuid, macroData);
-
- const shouldBeDeleted = await API._checkItemPileShouldBeDeleted(itemPileUuid);
- await API.rerenderItemPileInventoryApplication(itemPileUuid, shouldBeDeleted);
-
- if (shouldBeDeleted) {
- await API._deleteItemPile(itemPileUuid);
- }
-
- return transferData;
-
- },
-
- /* --- ITEM AND ATTRIBUTE METHODS --- */
-
- /**
- * Adds item to an actor, increasing item quantities if matches were found
- *
- * @param {Actor/TokenDocument/Token} target The target to add an item to
- * @param {Array} items An array of objects, with the key "item" being an item object or an Item class (the foundry class), with an optional key of "quantity" being the amount of the item to add
- * @param {Boolean} [mergeSimilarItems=true] Whether to merge similar items based on their name and type
- * @param {String/Boolean} [interactionId=false] The interaction ID of this action
- *
- * @returns {Promise} An array of objects, each containing the item that was added or updated, and the quantity that was added
- */
- async addItems(target, items, { mergeSimilarItems = true, interactionId = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.ITEM.PRE_ADD, target, items, interactionId);
- if (hookResult === false) return;
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`AddItems | Could not determine the UUID, please provide a valid target`, true)
-
- const itemsToAdd = []
- items.forEach(itemData => {
-
- let item = itemData;
- if (itemData instanceof Item) {
- item = itemData.toObject();
- } else if (itemData.item instanceof Item) {
- item = itemData.item.toObject();
- } else if (itemData.item) {
- item = itemData.item;
- }
-
- if (itemData?.quantity !== undefined) {
- setProperty(item, API.ITEM_QUANTITY_ATTRIBUTE, itemData?.quantity)
- }
-
- const existingItems = mergeSimilarItems ? lib.findSimilarItem(itemsToAdd, item) : false;
- if (existingItems) {
- setProperty(existingItems, API.ITEM_QUANTITY_ATTRIBUTE, lib.getItemQuantity(existingItems) + lib.getItemQuantity(item))
- } else {
- itemsToAdd.push(item);
- }
-
- });
-
- if (interactionId) {
- if (typeof interactionId !== "string") throw lib.custom_error(`AddItems | interactionId must be of type string`);
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.ADD_ITEMS, targetUuid, itemsToAdd, game.user.id, { interactionId });
- },
-
- /**
- * @private
- */
- async _addItems(targetUuid, items, userId, { runHooks = true, interactionId = false } = {}) {
-
- const target = await fromUuid(targetUuid);
- const targetActor = target instanceof TokenDocument
- ? target.actor
- : target;
-
- const targetActorItems = Array.from(targetActor.items);
-
- const itemsAdded = [];
- const itemsToCreate = [];
- const itemsToUpdate = [];
- for (const itemData of items) {
-
- let item = itemData?.item ?? itemData;
- delete item._id;
-
- const foundItem = lib.findSimilarItem(targetActorItems, item);
-
- const incomingQuantity = Number(itemData?.quantity ?? lib.getItemQuantity(itemData));
-
- if (foundItem) {
- item = foundItem.toObject();
- const currentQuantity = lib.getItemQuantity(item);
- const newQuantity = currentQuantity + incomingQuantity;
- itemsToUpdate.push({
- "_id": item._id,
- [API.ITEM_QUANTITY_ATTRIBUTE]: newQuantity
- });
-
- setProperty(item, API.ITEM_QUANTITY_ATTRIBUTE, newQuantity)
- itemsAdded.push({
- item: item,
- quantity: incomingQuantity
- });
- } else {
- setProperty(item, API.ITEM_QUANTITY_ATTRIBUTE, incomingQuantity)
- itemsToCreate.push(item);
- }
-
- }
-
- const itemsCreated = await targetActor.createEmbeddedDocuments("Item", itemsToCreate);
- await targetActor.updateEmbeddedDocuments("Item", itemsToUpdate);
-
- itemsCreated.forEach(item => {
- const itemObject = item.toObject()
- itemsAdded.push({
- item: itemObject,
- quantity: lib.getItemQuantity(itemObject)
- })
- });
-
- if (runHooks) {
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.ITEM.ADD, targetUuid, itemsAdded, userId, interactionId);
-
- const macroData = {
- action: "addItems",
- target: targetUuid,
- items: itemsAdded,
- userId: userId,
- interactionId: interactionId
- };
-
- await API._executeItemPileMacro(targetUuid, macroData);
-
- await API.rerenderItemPileInventoryApplication(targetUuid);
-
- }
-
- return itemsAdded;
-
- },
-
- /**
- * Subtracts the quantity of items on an actor. If the quantity of an item reaches 0, the item is removed from the actor.
- *
- * @param {Actor/Token/TokenDocument} target The target to remove a items from
- * @param {Array} items An array of objects each containing the item id (key "_id") and the quantity to remove (key "quantity"), or Items (the foundry class) or strings of IDs to remove all quantities of
- * @param {String/Boolean} [interactionId=false] The interaction ID of this action
- *
- * @returns {Promise} An array of objects, each containing the item that was removed or updated, the quantity that was removed, and whether the item was deleted
- */
- async removeItems(target, items, { interactionId = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.ITEM.PRE_REMOVE, target, items, interactionId);
- if (hookResult === false) return;
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`RemoveItems | Could not determine the UUID, please provide a valid target`, true);
-
- const targetActorItems = API.getItemPileItems(target);
-
- items = items.map(itemData => {
-
- let item;
- if (typeof itemData === "string" || itemData._id) {
- const itemId = typeof itemData === "string" ? itemData : itemData._id;
- item = targetActorItems.find(actorItem => actorItem.id === itemId);
- if (!item) {
- throw lib.custom_error(`RemoveItems | Could not find item with id "${itemId}" on target "${targetUuid}"`, true)
- }
- item = item.toObject();
- } else {
- if (itemData.item instanceof Item) {
- item = itemData.item.toObject();
- } else {
- item = itemData.item;
- }
- let foundActorItem = targetActorItems.find(actorItem => actorItem.id === item._id);
- if (!foundActorItem) {
- throw lib.custom_error(`RemoveItems | Could not find item with id "${item._id}" on target "${targetUuid}"`, true)
- }
- }
-
- return {
- _id: item._id,
- quantity: itemData?.quantity ?? lib.getItemQuantity(item)
- }
- });
-
- if (interactionId) {
- if (typeof interactionId !== "string") throw lib.custom_error(`RemoveItems | interactionId must be of type string`);
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.REMOVE_ITEMS, targetUuid, items, game.user.id, { interactionId });
- },
-
- /**
- * @private
- */
- async _removeItems(targetUuid, items, userId, { runHooks = true, interactionId = false } = {}) {
-
- const target = await fromUuid(targetUuid);
- const targetActor = target instanceof TokenDocument
- ? target.actor
- : target;
-
- const itemsRemoved = [];
- const itemsToUpdate = [];
- const itemsToDelete = [];
- for (const itemData of items) {
-
- let item = targetActor.items.get(itemData._id);
-
- if (!item) continue;
-
- item = item.toObject();
-
- const currentQuantity = lib.getItemQuantity(item);
-
- const quantityToRemove = itemData.quantity;
-
- const newQuantity = Math.max(0, currentQuantity - quantityToRemove);
-
- if (newQuantity >= 1) {
- itemsToUpdate.push({ _id: item._id, [API.ITEM_QUANTITY_ATTRIBUTE]: newQuantity });
- setProperty(item, API.ITEM_QUANTITY_ATTRIBUTE, quantityToRemove);
- itemsRemoved.push({
- item: item,
- quantity: quantityToRemove,
- deleted: false
- });
- } else {
- itemsToDelete.push(item._id);
- setProperty(item, API.ITEM_QUANTITY_ATTRIBUTE, currentQuantity);
- itemsRemoved.push({
- item: item,
- quantity: currentQuantity,
- deleted: true
- });
- }
-
- }
-
- await targetActor.updateEmbeddedDocuments("Item", itemsToUpdate);
- await targetActor.deleteEmbeddedDocuments("Item", itemsToDelete);
-
- if (runHooks) {
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.ITEM.REMOVE, targetUuid, itemsRemoved, userId, interactionId);
-
- const macroData = {
- action: "removeItems",
- target: targetUuid,
- items: itemsRemoved,
- userId: userId,
- interactionId: interactionId
- };
-
- await API._executeItemPileMacro(targetUuid, macroData);
-
- const shouldBeDeleted = await API._checkItemPileShouldBeDeleted(targetUuid);
-
- await API.rerenderItemPileInventoryApplication(targetUuid, shouldBeDeleted);
-
- if (shouldBeDeleted) {
- await API._deleteItemPile(targetUuid);
- }
-
- }
-
- return itemsRemoved;
-
- },
-
- /**
- * Transfers items from the source to the target, subtracting a number of quantity from the source's item and adding it to the target's item, deleting items from the source if their quantity reaches 0
- *
- * @param {Actor/Token/TokenDocument} source The source to transfer the items from
- * @param {Actor/Token/TokenDocument} target The target to transfer the items to
- * @param {Array} items An array of objects each containing the item id (key "_id") and the quantity to transfer (key "quantity"), or Items (the foundry class) or strings of IDs to transfer all quantities of
- * @param {String/Boolean} [interactionId=false] The interaction ID of this action
- *
- * @returns {Promise} An array of objects, each containing the item that was added or updated, and the quantity that was transferred
- */
- async transferItems(source, target, items, { interactionId = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.ITEM.PRE_TRANSFER, source, target, items, interactionId);
- if (hookResult === false) return;
-
- const sourceUuid = lib.getUuid(source);
- if (!sourceUuid) throw lib.custom_error(`TransferItems | Could not determine the UUID, please provide a valid source`, true)
-
- const sourceActorItems = API.getItemPileItems(source);
-
- items = items.map(itemData => {
-
- let item;
- if (typeof itemData === "string" || itemData._id) {
- const itemId = typeof itemData === "string" ? itemData : itemData._id;
- item = sourceActorItems.find(actorItem => actorItem.id === itemId);
- if (!item) {
- throw lib.custom_error(`TransferItems | Could not find item with id "${itemId}" on target "${sourceUuid}"`, true)
- }
- item = item.toObject();
- } else if (itemData.item instanceof Item) {
- item = itemData.item.toObject();
- } else {
- item = itemData.item;
- }
-
- let foundActorItem = sourceActorItems.find(actorItem => actorItem.id === item._id);
- if (!foundActorItem) {
- throw lib.custom_error(`TransferItems | Could not find item with id "${item._id}" on target "${sourceUuid}"`, true)
- }
-
- return {
- _id: item._id,
- quantity: Math.max((itemData?.quantity ?? 0) ?? lib.getItemQuantity(itemData))
- }
- });
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`TransferItems | Could not determine the UUID, please provide a valid target`, true)
-
- if (interactionId) {
- if (typeof interactionId !== "string") throw lib.custom_error(`TransferItems | interactionId must be of type string`);
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.TRANSFER_ITEMS, sourceUuid, targetUuid, items, game.user.id, { interactionId });
-
- },
-
- /**
- * @private
- */
- async _transferItems(sourceUuid, targetUuid, items, userId, { runHooks = true, interactionId = false } = {}) {
-
- const itemsRemoved = await API._removeItems(sourceUuid, items, userId, { runHooks: false });
-
- const itemsAdded = await API._addItems(targetUuid, itemsRemoved, userId, { runHooks: false });
-
- if (runHooks) {
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.ITEM.TRANSFER, sourceUuid, targetUuid, itemsAdded, userId, interactionId);
-
- const macroData = {
- action: "transferItems",
- source: sourceUuid,
- target: targetUuid,
- itemsAdded: itemsAdded,
- userId: userId,
- interactionId: interactionId
- };
- await API._executeItemPileMacro(sourceUuid, macroData);
- await API._executeItemPileMacro(targetUuid, macroData);
-
- const shouldBeDeleted = await API._checkItemPileShouldBeDeleted(sourceUuid);
- await API.rerenderItemPileInventoryApplication(sourceUuid, shouldBeDeleted);
- await API.rerenderItemPileInventoryApplication(targetUuid);
-
- const itemPile = await fromUuid(sourceUuid);
-
- if (shouldBeDeleted) {
- await API._deleteItemPile(sourceUuid);
- } else if (lib.isItemPileEmpty(itemPile)) {
- await lib.clearItemPileSharingData(itemPile);
- } else {
- await lib.setItemPileSharingData(sourceUuid, targetUuid, { items: itemsAdded });
- }
-
- }
-
- return itemsAdded;
-
- },
-
- /**
- * Transfers all items between the source and the target.
- *
- * @param {Actor/Token/TokenDocument} source The actor to transfer all items from
- * @param {Actor/Token/TokenDocument} target The actor to receive all the items
- * @param {Array/Boolean} [itemFilters=false] Array of item types disallowed - will default to module settings if none provided
- * @param {String/Boolean} [interactionId=false] The interaction ID of this action
- *
- * @returns {Promise} An array containing all of the items that were transferred to the target
- */
- async transferAllItems(source, target, { itemFilters = false, interactionId = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.ITEM.PRE_TRANSFER_ALL, source, target, itemFilters, interactionId);
- if (hookResult === false) return;
-
- const sourceUuid = lib.getUuid(source);
- if (!sourceUuid) throw lib.custom_error(`TransferAllItems | Could not determine the UUID, please provide a valid source`, true)
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`TransferAllItems | Could not determine the UUID, please provide a valid target`, true)
-
- if (itemFilters) {
- if (!Array.isArray(itemFilters)) throw lib.custom_error(`TransferAllItems | itemFilters must be of type array`);
- itemFilters.forEach(entry => {
- if (typeof entry?.path !== "string") throw lib.custom_error(`TransferAllItems | each entry in the itemFilters must have a "path" property that is of type string`);
- if (typeof entry?.filter !== "string") throw lib.custom_error(`TransferAllItems | each entry in the itemFilters must have a "filter" property that is of type string`);
- })
- }
-
- if (interactionId) {
- if (typeof interactionId !== "string") throw lib.custom_error(`TransferAllItems | interactionId must be of type string`);
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.TRANSFER_ALL_ITEMS, sourceUuid, targetUuid, game.user.id, {
- itemFilters,
- interactionId
- });
- },
-
- /**
- * @private
- */
- async _transferAllItems(sourceUuid, targetUuid, userId, {
- itemFilters = false,
- runHooks = false,
- interactionId = false
- } = {}) {
-
- const source = await fromUuid(sourceUuid);
-
- const itemsToRemove = API.getItemPileItems(source, itemFilters).map(item => item.toObject());
-
- const itemsRemoved = await API._removeItems(sourceUuid, itemsToRemove, userId, {
- runHooks: false,
- interactionId
- });
- const itemAdded = await API._addItems(targetUuid, itemsRemoved, userId, { runHooks: false, interactionId });
-
- if (runHooks) {
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.TRANSFER_ALL_ITEMS, HOOKS.ITEM.TRANSFER_ALL, sourceUuid, targetUuid, itemAdded, userId, interactionId);
-
- const macroData = {
- action: "transferAllItems",
- source: sourceUuid,
- target: targetUuid,
- items: itemAdded,
- userId: userId,
- interactionId: interactionId
- };
- await API._executeItemPileMacro(sourceUuid, macroData);
- await API._executeItemPileMacro(targetUuid, macroData);
-
- const shouldBeDeleted = await API._checkItemPileShouldBeDeleted(sourceUuid);
- await API.rerenderItemPileInventoryApplication(sourceUuid, shouldBeDeleted);
- await API.rerenderItemPileInventoryApplication(targetUuid);
-
- if (shouldBeDeleted) {
- await API._deleteItemPile(sourceUuid);
- }
-
- }
-
- return itemAdded;
- },
-
- /**
- * Adds to attributes on an actor
- *
- * @param {Actor/Token/TokenDocument} target The target whose attribute will have a set quantity added to it
- * @param {Object} attributes An object with each key being an attribute path, and its value being the quantity to add
- * @param {String/Boolean} [interactionId=false] The interaction ID of this action
- *
- * @returns {Promise} An array containing a key value pair of the attribute path and the quantity of that attribute that was removed
- *
- */
- async addAttributes(target, attributes, { interactionId = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.ATTRIBUTE.PRE_ADD, target, attributes, interactionId);
- if (hookResult === false) return;
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`AddAttributes | Could not determine the UUID, please provide a valid target`, true)
-
- const targetActor = target instanceof TokenDocument
- ? target.actor
- : target;
-
- Object.entries(attributes).forEach(entry => {
- const [attribute, quantity] = entry;
- if (!hasProperty(targetActor.data, attribute)) {
- throw lib.custom_error(`AddAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
- }
- if (!lib.is_real_number(quantity) && quantity > 0) {
- throw lib.custom_error(`AddAttributes | Attribute "${attribute}" must be of type number and greater than 0`, true)
- }
- });
-
- if (interactionId) {
- if (typeof interactionId !== "string") throw lib.custom_error(`AddAttributes | interactionId must be of type string`);
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.ADD_ATTRIBUTE, targetUuid, attributes, game.user.id, { interactionId });
-
- },
-
- /**
- * @private
- */
- async _addAttributes(targetUuid, attributes, userId, { runHooks = true, interactionId = false } = {}) {
-
- const target = await fromUuid(targetUuid);
- const targetActor = target instanceof TokenDocument
- ? target.actor
- : target;
-
- const updates = {};
- const attributesAdded = {};
-
- for (const [attribute, quantityToAdd] of Object.entries(attributes)) {
-
- const currentQuantity = Number(getProperty(targetActor.data, attribute));
-
- updates[attribute] = currentQuantity + quantityToAdd;
- attributesAdded[attribute] = currentQuantity + quantityToAdd;
-
- }
-
- await targetActor.update(updates);
-
- if (runHooks) {
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.ATTRIBUTE.ADD, targetUuid, attributesAdded, userId, interactionId);
-
- const macroData = {
- action: "addAttributes",
- target: targetUuid,
- attributes: attributesAdded,
- userId: userId,
- interactionId: interactionId
- };
- await API._executeItemPileMacro(targetUuid, macroData);
-
- await API.rerenderItemPileInventoryApplication(targetUuid);
- }
-
- return attributesAdded;
-
- },
-
- /**
- * Subtracts attributes on the target
- *
- * @param {Token/TokenDocument} target The target whose attributes will be subtracted from
- * @param {Array/object} attributes This can be either an array of attributes to subtract (to zero out a given attribute), or an object with each key being an attribute path, and its value being the quantity to subtract
- * @param {String/Boolean} [interactionId=false] The interaction ID of this action
- *
- * @returns {Promise} An array containing a key value pair of the attribute path and the quantity of that attribute that was removed
- */
- async removeAttributes(target, attributes, { interactionId = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.ATTRIBUTE.PRE_REMOVE, target, attributes, interactionId);
- if (hookResult === false) return;
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`RemoveAttributes | Could not determine the UUID, please provide a valid target`, true)
-
- const targetActor = target instanceof TokenDocument
- ? target.actor
- : target;
-
- if (Array.isArray(attributes)) {
- attributes.forEach(attribute => {
- if (typeof attribute !== "string") {
- throw lib.custom_error(`RemoveAttributes | Each attribute in the array must be of type string`, true)
- }
- if (!hasProperty(targetActor.data, attribute)) {
- throw lib.custom_error(`RemoveAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
- }
- });
- } else {
- Object.entries(attributes).forEach(entry => {
- const [attribute, quantity] = entry;
- if (!hasProperty(targetActor.data, attribute)) {
- throw lib.custom_error(`RemoveAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
- }
- if (!lib.is_real_number(quantity) && quantity > 0) {
- throw lib.custom_error(`RemoveAttributes | Attribute "${attribute}" must be of type number and greater than 0`, true)
- }
- });
- }
-
- if (interactionId) {
- if (typeof interactionId !== "string") throw lib.custom_error(`RemoveAttributes | interactionId must be of type string`);
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.REMOVE_ATTRIBUTES, targetUuid, attributes, game.user.id, { interactionId });
-
- },
-
- /**
- * @private
- */
- async _removeAttributes(targetUuid, attributes, userId, { runHooks = true, interactionId = false } = {}) {
-
- const target = await fromUuid(targetUuid);
- const targetActor = target instanceof TokenDocument
- ? target.actor
- : target;
-
- const updates = {};
- const attributesRemoved = {};
-
- if (Array.isArray(attributes)) {
- attributes = Object.fromEntries(attributes.map(attribute => {
- return [attribute, Number(getProperty(targetActor.data, attribute))];
- }))
- }
-
- for (const [attribute, quantityToRemove] of Object.entries(attributes)) {
-
- const currentQuantity = Number(getProperty(targetActor.data, attribute));
- const newQuantity = Math.max(0, currentQuantity - quantityToRemove);
-
- updates[attribute] = newQuantity;
-
- // if the target's quantity is above 1, we've removed the amount we expected, otherwise however many were left
- attributesRemoved[attribute] = newQuantity ? quantityToRemove : currentQuantity;
- }
-
- await targetActor.update(updates);
-
- if (runHooks) {
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.ATTRIBUTE.REMOVE, targetUuid, attributesRemoved, userId, interactionId);
-
- const macroData = {
- action: "removeAttributes",
- target: targetUuid,
- attributes: attributesRemoved,
- userId: userId,
- interactionId: interactionId
- };
- await API._executeItemPileMacro(targetUuid, macroData);
-
- const shouldBeDeleted = await API._checkItemPileShouldBeDeleted(targetUuid);
- await API.rerenderItemPileInventoryApplication(targetUuid, shouldBeDeleted);
-
- if (shouldBeDeleted) {
- await API._deleteItemPile(targetUuid);
- }
- }
-
- return attributesRemoved;
-
- },
-
- /**
- * Transfers a set quantity of an attribute from a source to a target, removing it or subtracting from the source and adds it the target
- *
- * @param {Actor/Token/TokenDocument} source The source to transfer the attribute from
- * @param {Actor/Token/TokenDocument} target The target to transfer the attribute to
- * @param {Array/object} attributes This can be either an array of attributes to transfer (to transfer all of a given attribute), or an object with each key being an attribute path, and its value being the quantity to transfer
- * @param {String/Boolean} [interactionId=false] The interaction ID of this action
- *
- * @returns {Promise} An object containing a key value pair of each attribute transferred, the key being the attribute path and its value being the quantity that was transferred
- */
- async transferAttributes(source, target, attributes, { interactionId = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.ATTRIBUTE.PRE_TRANSFER, source, target, attributes, interactionId);
- if (hookResult === false) return;
-
- const sourceUuid = lib.getUuid(source);
- if (!sourceUuid) throw lib.custom_error(`TransferAttributes | Could not determine the UUID, please provide a valid source`, true)
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`TransferAttributes | Could not determine the UUID, please provide a valid target`, true)
-
- const sourceActor = source instanceof TokenDocument
- ? source.actor
- : source;
-
- const targetActor = target instanceof TokenDocument
- ? target.actor
- : target;
-
- if (Array.isArray(attributes)) {
- attributes.forEach(attribute => {
- if (typeof attribute !== "string") {
- throw lib.custom_error(`TransferAttributes | Each attribute in the array must be of type string`, true)
- }
- if (!hasProperty(sourceActor.data, attribute)) {
- throw lib.custom_error(`TransferAttributes | Could not find attribute ${attribute} on source's actor with UUID "${targetUuid}"`, true)
- }
- if (!hasProperty(targetActor.data, attribute)) {
- throw lib.custom_error(`TransferAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
- }
- });
- } else {
- Object.entries(attributes).forEach(entry => {
- const [attribute, quantity] = entry;
- if (!hasProperty(sourceActor.data, attribute)) {
- throw lib.custom_error(`TransferAttributes | Could not find attribute ${attribute} on source's actor with UUID "${targetUuid}"`, true)
- }
- if (!hasProperty(targetActor.data, attribute)) {
- throw lib.custom_error(`TransferAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
- }
- if (!lib.is_real_number(quantity) && quantity > 0) {
- throw lib.custom_error(`TransferAttributes | Attribute "${attribute}" must be of type number and greater than 0`, true)
- }
- });
- }
-
- if (interactionId) {
- if (typeof interactionId !== "string") throw lib.custom_error(`TransferAttributes | interactionId must be of type string`);
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.TRANSFER_ATTRIBUTES, sourceUuid, targetUuid, attributes, game.user.id, { interactionId });
-
- },
-
- /**
- * @private
- */
- async _transferAttributes(sourceUuid, targetUuid, attributes, userId, {
- runHooks = true,
- interactionId = false
- } = {}) {
-
- const attributesRemoved = await API._removeAttributes(sourceUuid, attributes, userId, { runHooks: false });
-
- await API._addAttributes(targetUuid, attributesRemoved, userId, { runHooks: false });
-
- if (runHooks) {
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.ATTRIBUTE.TRANSFER, sourceUuid, targetUuid, attributesRemoved, userId, interactionId);
-
- const macroData = {
- action: "transferAttributes",
- source: sourceUuid,
- target: targetUuid,
- attributes: attributesRemoved,
- userId: userId,
- interactionId: interactionId
- };
- await API._executeItemPileMacro(sourceUuid, macroData);
- await API._executeItemPileMacro(targetUuid, macroData);
-
- const shouldBeDeleted = await API._checkItemPileShouldBeDeleted(sourceUuid);
- await API.rerenderItemPileInventoryApplication(sourceUuid, shouldBeDeleted);
- await API.rerenderItemPileInventoryApplication(targetUuid);
-
- const itemPile = await fromUuid(sourceUuid)
-
- if (shouldBeDeleted) {
- await API._deleteItemPile(sourceUuid);
- } else if (lib.isItemPileEmpty(itemPile)) {
- await lib.clearItemPileSharingData(itemPile);
- } else {
- await lib.setItemPileSharingData(sourceUuid, targetUuid, { currencies: attributesRemoved });
- }
-
- }
-
- return attributesRemoved;
-
- },
-
- /**
- * Transfers all dynamic attributes from a source to a target, removing it or subtracting from the source and adding them to the target
- *
- * @param {Actor/Token/TokenDocument} source The source to transfer the attributes from
- * @param {Actor/Token/TokenDocument} target The target to transfer the attributes to
- * @param {String/Boolean} [interactionId=false] The interaction ID of this action
- *
- * @returns {Promise} An object containing a key value pair of each attribute transferred, the key being the attribute path and its value being the quantity that was transferred
- */
- async transferAllAttributes(source, target, { interactionId = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.ATTRIBUTE.PRE_TRANSFER_ALL, source, target, interactionId);
- if (hookResult === false) return;
-
- const sourceUuid = lib.getUuid(source);
- if (!sourceUuid) throw lib.custom_error(`TransferAllAttributes | Could not determine the UUID, please provide a valid source`, true);
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`TransferAllAttributes | Could not determine the UUID, please provide a valid target`, true);
-
- if (interactionId) {
- if (typeof interactionId !== "string") throw lib.custom_error(`TransferAllAttributes | interactionId must be of type string`);
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.TRANSFER_ALL_ATTRIBUTES, sourceUuid, targetUuid, game.user.id, { interactionId });
-
- },
-
- /**
- * @private
- */
- async _transferAllAttributes(sourceUuid, targetUuid, userId, { runHooks = true, interactionId = false } = {}) {
-
- const source = await fromUuid(sourceUuid);
-
- const sourceActor = source instanceof TokenDocument
- ? source.actor
- : source;
-
- const target = await fromUuid(targetUuid);
-
- const targetActor = target instanceof TokenDocument
- ? target.actor
- : target;
-
- const sourceAttributes = API.getItemPileCurrencies(sourceActor);
-
- const attributesToTransfer = sourceAttributes.filter(attribute => {
- return hasProperty(targetActor.data, attribute.path);
- }).map(attribute => attribute.path);
-
- const attributesRemoved = await API._removeAttributes(sourceUuid, attributesToTransfer, userId, { runHooks: false });
- const attributesAdded = await API._addAttributes(targetUuid, attributesRemoved, userId, { runHooks: false });
-
- if (runHooks) {
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.ATTRIBUTE.TRANSFER_ALL, sourceUuid, targetUuid, attributesAdded, userId, interactionId);
-
- const macroData = {
- action: "transferAllAttributes",
- source: sourceUuid,
- target: targetUuid,
- attributes: attributesAdded,
- userId: userId,
- interactionId: interactionId
- };
- await API._executeItemPileMacro(sourceUuid, macroData);
- await API._executeItemPileMacro(targetUuid, macroData);
-
- const shouldBeDeleted = await API._checkItemPileShouldBeDeleted(sourceUuid);
- await API.rerenderItemPileInventoryApplication(sourceUuid, shouldBeDeleted);
-
- if (shouldBeDeleted) {
- await API._deleteItemPile(sourceUuid);
- }
-
- }
-
- return attributesAdded;
-
- },
-
- /**
- * Transfers all items and attributes between the source and the target.
- *
- * @param {Actor/Token/TokenDocument} source The actor to transfer all items and attributes from
- * @param {Actor/Token/TokenDocument} target The actor to receive all the items and attributes
- * @param {Array/Boolean} [itemFilters=false] Array of item types disallowed - will default to module settings if none provided
- * @param {String/Boolean} [interactionId=false] The ID of this interaction
- *
- * @returns {Promise} An object containing all items and attributes transferred to the target
- */
- async transferEverything(source, target, { itemFilters = false, interactionId = false } = {}) {
-
- const hookResult = Hooks.call(HOOKS.PRE_TRANSFER_EVERYTHING, source, target, itemFilters, interactionId);
- if (hookResult === false) return;
-
- const sourceUuid = lib.getUuid(source);
- if (!sourceUuid) throw lib.custom_error(`TransferEverything | Could not determine the UUID, please provide a valid source`, true)
-
- const targetUuid = lib.getUuid(target);
- if (!targetUuid) throw lib.custom_error(`TransferEverything | Could not determine the UUID, please provide a valid target`, true)
-
- if (itemFilters) {
- if (!Array.isArray(itemFilters)) throw lib.custom_error(`TransferEverything | itemFilters must be of type array`);
- itemFilters.forEach(entry => {
- if (typeof entry?.path !== "string") throw lib.custom_error(`TransferEverything | each entry in the itemFilters must have a "path" property that is of type string`);
- if (typeof entry?.filter !== "string") throw lib.custom_error(`TransferEverything | each entry in the itemFilters must have a "filter" property that is of type string`);
- })
- }
-
- if (interactionId) {
- if (typeof interactionId !== "string") throw lib.custom_error(`TransferEverything | interactionId must be of type string`);
- }
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.TRANSFER_EVERYTHING, sourceUuid, targetUuid, game.user.id, {
- itemFilters,
- interactionId
- })
-
- },
-
- /**
- * @private
- */
- async _transferEverything(sourceUuid, targetUuid, userId, { itemFilters = false, interactionId } = {}) {
-
- const itemsTransferred = await API._transferAllItems(sourceUuid, targetUuid, userId, {
- itemFilters,
- isEverything: true,
- interactionId
- });
- const currenciesTransferred = await API._transferAllAttributes(sourceUuid, targetUuid, userId, {
- isEverything: true,
- interactionId
- });
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.TRANSFER_EVERYTHING, sourceUuid, targetUuid, itemsTransferred, currenciesTransferred, userId, interactionId);
-
- const macroData = {
- action: "transferEverything",
- source: sourceUuid,
- target: targetUuid,
- items: itemsTransferred,
- attributes: currenciesTransferred,
- userId: userId,
- interactionId: interactionId
- };
- await API._executeItemPileMacro(sourceUuid, macroData);
- await API._executeItemPileMacro(targetUuid, macroData);
-
- const shouldBeDeleted = await API._checkItemPileShouldBeDeleted(sourceUuid);
- await API.rerenderItemPileInventoryApplication(sourceUuid, shouldBeDeleted);
- await API.rerenderItemPileInventoryApplication(targetUuid);
-
- if (shouldBeDeleted) {
- await API._deleteItemPile(sourceUuid);
- }
-
- return {
- itemsTransferred,
- currenciesTransferred
- };
-
- },
-
- /* -------- UTILITY METHODS -------- */
-
- /**
- * Causes every user's token HUD to rerender
- *
- * @return {Promise}
- */
- async rerenderTokenHud() {
- return itemPileSocket.executeForEveryone(SOCKET_HANDLERS.RERENDER_TOKEN_HUD);
- },
-
- /**
- * @private
- */
- async _rerenderTokenHud() {
- if (!canvas.tokens.hud.rendered) return;
- await canvas.tokens.hud.render(true)
- return true;
- },
-
- /* -------- PRIVATE ITEM PILE METHODS -------- */
-
- /**
- * Initializes a pile on the client-side.
- *
- * @param {TokenDocument} tokenDocument
- * @return {Promise}
- * @private
- */
- async _initializeItemPile(tokenDocument) {
-
- if (!lib.isValidItemPile(tokenDocument)) return false;
-
- const pileData = lib.getItemPileData(tokenDocument);
-
- if (game.settings.get(CONSTANTS.MODULE_NAME, "preloadFiles")) {
- await Promise.allSettled(Object.entries(pileData).map(entry => {
- return new Promise(async (resolve) => {
- const [key, value] = entry;
- if (preloadedFiles.has(value) || !value) {
- return resolve();
- }
- if (key.toLowerCase().includes("image")) {
- preloadedFiles.add(value);
- lib.debug(`Preloaded image: ${value}`);
- await loadTexture(value);
- } else if (key.toLowerCase().includes("sound")) {
- preloadedFiles.add(value);
- lib.debug(`Preloaded sound: ${value}`);
- await AudioHelper.preloadSound(value);
- }
- return resolve();
- });
- }));
- }
-
- lib.debug(`Initialized item pile with uuid ${tokenDocument.uuid}`);
-
- return true;
- },
-
- /**
- * This executes any macro that is configured on the item pile, providing the macro with extra data relating to the
- * action that prompted the execution (if the advanced-macros module is installed)
- *
- * @param {String} targetUuid
- * @param {Object} macroData
- * @return {Promise}
- * @private
- */
- async _executeItemPileMacro(targetUuid, macroData) {
-
- const target = await fromUuid(targetUuid);
-
- if (!lib.isValidItemPile(target)) return;
-
- const pileData = lib.getItemPileData(target);
-
- if (!pileData.macro) return;
-
- const macro = game.macros.getName(pileData.macro);
-
- if (!macro) {
- throw lib.custom_error(`Could not find macro with name "${pileData.macro}" on target with UUID ${target.uuid}`);
- }
-
- // Reformat macro data to contain useful information
- if (macroData.source) {
- macroData.source = await fromUuid(macroData.source);
- }
-
- if (macroData.target) {
- macroData.target = await fromUuid(macroData.target);
- }
-
- const targetActor = macroData.target instanceof TokenDocument
- ? macroData.target.actor
- : macroData.target;
-
- if (macroData.item) {
- macroData.items = macroData.items.map(item => targetActor.items.get(item._id));
- }
-
- return macro.execute([macroData]);
-
- },
-
- /**
- * This handles any dropped data onto the canvas or a set item pile
- *
- * @param {canvas} canvas
- * @param {Object} data
- * @param {Actor/Token/TokenDocument/Boolean}[target=false]
- * @return {Promise}
- * @private
- */
- async _dropData(canvas, data, { target = false } = {}) {
-
- if (data.type !== "Item") return;
-
- let item = await Item.implementation.fromDropData(data)
- let itemData = item.toObject();
-
- if (!itemData) {
- console.error(data);
- throw lib.custom_error("Something went wrong when dropping this item!")
- }
-
- const dropData = {
- source: false,
- target: target,
- itemData: {
- item: itemData,
- quantity: 1
- },
- position: false
- }
-
- if (data.tokenId) {
- dropData.source = canvas.tokens.get(data.tokenId).actor;
- } else if (data.actorId) {
- dropData.source = game.actors.get(data.actorId);
- }
-
- if (!dropData.source && !game.user.isGM) {
- return lib.custom_warning(game.i18n.localize("ITEM-PILES.Errors.NoSourceDrop"), true)
- }
-
- const pre_drop_determined_hook = Hooks.call(HOOKS.ITEM.PRE_DROP_DETERMINED, dropData.source, dropData.target, dropData.position, dropData.itemData);
- if (pre_drop_determined_hook === false) return;
-
- let action;
- let droppableDocuments = [];
- let x;
- let y;
-
- if (dropData.target) {
-
- droppableDocuments.push(dropData.target);
-
- } else {
-
- const position = canvas.grid.getTopLeft(data.x, data.y);
- x = position[0];
- y = position[1];
-
- droppableDocuments = lib.getTokensAtLocation({ x, y })
- .map(token => token.document)
- .filter(token => lib.isValidItemPile(token));
-
- }
-
- if (droppableDocuments.length && game.modules.get("midi-qol")?.active && game.settings.get('midi-qol', "DragDropTarget")) {
- lib.custom_warning("You have Drag & Drop Targetting enabled in MidiQOL, which disables drag & drop items")
- return;
- }
-
- if (droppableDocuments.length > 0 && !game.user.isGM) {
-
- if (!(droppableDocuments[0] instanceof Actor && dropData.source instanceof Actor)) {
-
- const sourceToken = canvas.tokens.placeables.find(token => token.actor === dropData.source);
-
- if (sourceToken) {
-
- const targetToken = droppableDocuments[0];
-
- const distance = Math.floor(lib.distance_between_rect(sourceToken, targetToken.object) / canvas.grid.size) + 1
-
- const pileData = lib.getItemPileData(targetToken);
-
- const maxDistance = pileData.distance ? pileData.distance : Infinity;
-
- if (distance > maxDistance) {
- lib.custom_warning(game.i18n.localize("ITEM-PILES.Errors.PileTooFar"), true);
- return;
- }
- }
- }
-
- droppableDocuments = droppableDocuments.filter(token => !API.isItemPileLocked(token));
-
- if (!droppableDocuments.length) {
- lib.custom_warning(game.i18n.localize("ITEM-PILES.Errors.PileLocked"), true);
- return;
- }
- }
-
- const disallowedType = lib.isItemInvalid(droppableDocuments?.[0], item);
- if (disallowedType) {
- if (!game.user.isGM) {
- return lib.custom_warning(game.i18n.format("ITEM-PILES.Errors.DisallowedItemDrop", { type: disallowedType }), true)
- }
- if (!hotkeyState.shiftDown) {
- const force = await Dialog.confirm({
- title: game.i18n.localize("ITEM-PILES.Dialogs.DropTypeWarning.Title"),
- content: `${game.i18n.format("ITEM-PILES.Dialogs.DropTypeWarning.Content", { type: disallowedType })}
`,
- defaultYes: false
- });
- if (!force) {
- return;
- }
- }
- }
-
- if (hotkeyState.altDown) {
-
- if (droppableDocuments.length) {
- action = "addToPile";
- }
-
- setProperty(dropData.itemData.item, API.ITEM_QUANTITY_ATTRIBUTE, 1);
- dropData.itemData.quantity = 1;
-
- } else {
-
- const result = await DropItemDialog.query(item, droppableDocuments[0]);
-
- if (!result) return;
- action = result.action;
- setProperty(dropData.itemData.item, API.ITEM_QUANTITY_ATTRIBUTE, Number(result.quantity))
- dropData.itemData.quantity = Number(result.quantity);
-
- }
-
- if (action === "addToPile") {
- dropData.target = droppableDocuments[0];
- } else {
- dropData.position = { x, y };
- }
-
- const hookResult = Hooks.call(HOOKS.ITEM.PRE_DROP, dropData.source, dropData.target, dropData.position, dropData.itemData);
- if (hookResult === false) return;
-
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.DROP_ITEMS, {
- userId: game.user.id,
- sceneId: canvas.scene.id,
- sourceUuid: lib.getUuid(dropData.source),
- targetUuid: lib.getUuid(dropData.target),
- position: dropData.position,
- itemData: dropData.itemData
- });
-
- },
-
- /**
- * If not given an actor, this method creates an item pile at a location, then adds an item to it.
- *
- * If a target was provided, it will just add the item to that target actor.
- *
- * If an actor was provided, it will transfer the item from the actor to the target actor.
- *
- * @param {String} userId
- * @param {String} sceneId
- * @param {String/Boolean} [sourceUuid=false]
- * @param {String/Boolean} [targetUuid=false]
- * @param {Object/Boolean} [position=false]
- * @param {Object} [itemData=false]
- *
- * @returns {Promise<{sourceUuid: string/boolean, targetUuid: string/boolean, position: object/boolean, itemsDropped: array }>}
- * @private
- */
- async _dropItems({
- userId,
- sceneId,
- sourceUuid = false,
- targetUuid = false,
- itemData = false,
- position = false
- } = {}) {
-
- let itemsDropped;
-
- // If there's a source of the item (it wasn't dropped from the item bar)
- if (sourceUuid) {
-
- const itemsToTransfer = [{ _id: itemData.item._id, quantity: itemData.quantity }];
-
- // If there's a target token, add the item to it, otherwise create a new pile at the drop location
- if (targetUuid) {
- itemsDropped = await API._transferItems(sourceUuid, targetUuid, itemsToTransfer, userId);
- } else {
- itemsDropped = await API._removeItems(sourceUuid, itemsToTransfer, userId);
- targetUuid = await API._createItemPile(sceneId, position, { items: itemsDropped });
- }
-
- // If there's no source (it was dropped from the item bar)
- } else {
-
- // If there's a target token, add the item to it, otherwise create a new pile at the drop location
- if (targetUuid) {
- itemsDropped = await API._addItems(targetUuid, [itemData], userId);
- } else {
- targetUuid = await API._createItemPile(sceneId, position, { items: [itemData] });
- }
-
- }
-
- await itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.ITEM.DROP, sourceUuid, targetUuid, itemsDropped, position);
-
- return { sourceUuid, targetUuid, position, itemsDropped };
-
- },
-
- /**
- * @param {String} sceneId
- * @param {Object} position
- * @param {String/Boolean} [pileActorName=false]
- * @param {Array/Boolean} [items=false]
- * @returns {Promise}
- * @private
- */
- async _createItemPile(sceneId, position, { pileActorName = false, items = false } = {}) {
-
- let pileActor;
-
- if (!pileActorName) {
-
- pileActor = game.settings.get(CONSTANTS.MODULE_NAME, "defaultItemPileActorID") ? game.actors.get(game.settings.get(CONSTANTS.MODULE_NAME, "defaultItemPileActorID")) : false;
-
- if (!pileActor) {
-
- lib.custom_notify("A Default Item Pile has been added to your Actors list. You can configure the default look and behavior on it, or duplicate it to create different styles.")
-
- const pileDataDefaults = foundry.utils.duplicate(CONSTANTS.PILE_DEFAULTS);
-
- pileDataDefaults.enabled = true;
- pileDataDefaults.deleteWhenEmpty = true;
- pileDataDefaults.displayOne = true;
- pileDataDefaults.showItemName = true;
- pileDataDefaults.overrideSingleItemScale = true;
- pileDataDefaults.singleItemScale = 0.75;
-
- pileActor = await Actor.create({
- name: "Default Item Pile",
- type: game.settings.get(CONSTANTS.MODULE_NAME, "actorClassType"),
- img: "icons/svg/item-bag.svg",
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileDataDefaults
- });
-
- await pileActor.update({
- "token": {
- name: "Item Pile",
- actorLink: false,
- bar1: { attribute: "" },
- vision: false,
- displayName: 50,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileDataDefaults
- }
- })
-
- await game.settings.set(CONSTANTS.MODULE_NAME, "defaultItemPileActorID", pileActor.id);
-
- }
-
- } else {
-
- pileActor = game.actors.getName(pileActorName);
-
- }
-
- let overrideData = { ...position };
-
- const pileData = lib.getItemPileData(pileActor);
-
- if (!pileActor.data.token.actorLink) {
-
- items = items ? items.map(itemData => itemData.item ?? itemData) : [];
-
- overrideData['actorData'] = {
- items: items
- }
-
- const data = { data: pileData, items: items };
-
- overrideData = foundry.utils.mergeObject(overrideData, {
- "img": lib.getItemPileTokenImage(pileActor, data),
- "scale": lib.getItemPileTokenScale(pileActor, data),
- "name": lib.getItemPileName(pileActor, data),
- });
-
- }
-
- const tokenData = await pileActor.getTokenData(overrideData);
-
- const scene = game.scenes.get(sceneId);
-
- const [tokenDocument] = await scene.createEmbeddedDocuments("Token", [tokenData]);
-
- return lib.getUuid(tokenDocument);
-
- },
-
- /**
- * @private
- */
- async _itemPileClicked(pileDocument) {
-
- if (!lib.isValidItemPile(pileDocument)) return;
-
- const pileToken = pileDocument.object;
-
- if (!lib.isGMConnected()) {
- lib.custom_warning(`Item Piles requires a GM to be connected for players to be able to loot item piles.`, true)
- return;
- }
-
- lib.debug(`Clicked: ${pileDocument.uuid}`);
-
- const data = lib.getItemPileData(pileDocument);
-
- const maxDistance = data.distance ? data.distance : Infinity;
-
- let validTokens = [];
-
- if (canvas.tokens.controlled.length > 0) {
- validTokens = [...canvas.tokens.controlled];
- validTokens = validTokens.filter(token => token.document !== pileDocument);
- }
-
- if (!validTokens.length && !game.user.isGM) {
- validTokens.push(...canvas.tokens.placeables);
- if (_token) {
- validTokens.unshift(_token);
- }
- }
-
- validTokens = validTokens.filter(token => token.owner && token.document !== pileDocument).filter(token => {
- return lib.tokens_close_enough(pileToken, token, maxDistance) || game.user.isGM;
- });
-
- if (!validTokens.length && !game.user.isGM && maxDistance !== Infinity) {
- lib.custom_warning(game.i18n.localize("ITEM-PILES.Errors.PileTooFar"), true);
- return;
- }
-
- let interactingActor;
- if (validTokens.length) {
- if (validTokens.includes(_token)) {
- interactingActor = _token.actor;
- } else {
- validTokens.sort((potentialTargetA, potentialTargetB) => {
- return lib.grids_between_tokens(pileToken, potentialTargetA) - lib.grids_between_tokens(pileToken, potentialTargetB);
- })
- interactingActor = validTokens[0].actor;
- }
- } else if (game.user.character && !game.user.isGM) {
- interactingActor = game.user.character;
- }
-
- if (data.isContainer && interactingActor) {
-
- if (data.locked && !game.user.isGM) {
- lib.debug(`Attempted to locked item pile with UUID ${pileDocument.uuid}`);
- return API.rattleItemPile(pileDocument, interactingActor);
- }
-
- if (data.closed) {
- lib.debug(`Opened item pile with UUID ${pileDocument.uuid}`);
- await API.openItemPile(pileDocument, interactingActor);
- }
-
- }
-
- return ItemPileInventory.show(pileDocument, interactingActor);
-
- },
-
- /**
- * @private
- */
- async _checkItemPileShouldBeDeleted(targetUuid) {
-
- const target = await fromUuid(targetUuid);
-
- if (!(target instanceof TokenDocument)) return false;
-
- const pileData = lib.getItemPileData(target);
-
- const shouldDelete = {
- "default": game.settings.get(CONSTANTS.MODULE_NAME, "deleteEmptyPiles"),
- "true": true,
- "false": false
- }[pileData?.deleteWhenEmpty ?? "default"]
-
- return pileData?.enabled && shouldDelete && lib.isItemPileEmpty(target);
-
- }
-
-};
-
-export default API;
diff --git a/scripts/chathandler.js b/scripts/chathandler.js
deleted file mode 100644
index f522c4da..00000000
--- a/scripts/chathandler.js
+++ /dev/null
@@ -1,405 +0,0 @@
-import API from "./api.js";
-import CONSTANTS from "./constants.js";
-import * as lib from "./lib/lib.js";
-import { itemPileSocket, SOCKET_HANDLERS } from "./socket.js";
-import { TradeAPI } from "./trade-api.js";
-import HOOKS from "./hooks.js";
-
-const chatHandler = {
-
- init() {
-
- Hooks.on("preCreateChatMessage", chatHandler._preCreateChatMessage.bind(chatHandler));
- Hooks.on("renderChatMessage", chatHandler._renderChatMessage.bind(chatHandler));
- Hooks.on(HOOKS.ITEM.TRANSFER, chatHandler._outputTransferItem.bind(chatHandler));
- Hooks.on(HOOKS.ATTRIBUTE.TRANSFER, chatHandler._outputTransferCurrency.bind(chatHandler));
- Hooks.on(HOOKS.TRANSFER_EVERYTHING, chatHandler._outputTransferEverything.bind(chatHandler));
- Hooks.on(HOOKS.PILE.SPLIT_INVENTORY, chatHandler._outputSplitItemPileInventory.bind(chatHandler));
- Hooks.on(HOOKS.TRADE.STARTED, chatHandler._outputTradeStarted.bind(chatHandler));
- Hooks.on(HOOKS.TRADE.COMPLETE, chatHandler._outputTradeComplete.bind(chatHandler));
-
- $(document).on("click", ".item-piles-chat-card .item-piles-collapsible", async function () {
- if ($(this).attr("open")) return;
- await lib.wait(25);
- $(this).parent()[0].scrollIntoView({ behavior: 'smooth', block: 'nearest', inline: 'start' });
- });
-
- },
-
- _preCreateChatMessage(chatMessage) {
- if (!game.settings.get(CONSTANTS.MODULE_NAME, "enableTrading")) return;
-
- const content = chatMessage.data.content.toLowerCase();
-
- if (!(content.startsWith("!itempiles") || content.startsWith("!ip"))) return;
-
- const args = content.split(" ").slice(1);
-
- if (args[0] === "trade") {
- setTimeout(() => {
- TradeAPI.requestTrade();
- });
- }
-
- return false;
-
- },
-
- _renderChatMessage(app, html) {
- html.find(".item-piles-specate-trade").click(function () {
- TradeAPI.spectateTrade($(this).data());
- });
- },
-
-
- _disableTradingButton(publicTradeId) {
- const message = Array.from(game.messages).find(message => {
- return message.getFlag(CONSTANTS.MODULE_NAME, "publicTradeId") === publicTradeId;
- });
- if (!message) return;
- const html = $(message.data.content);
- html.find(".item-piles-specate-trade")
- .prop('disabled', true)
- .text(game.i18n.localize("ITEM-PILES.Chat.SpectateDisabled"));
- return message.update({
- content: html.prop("outerHTML")
- })
- },
-
- /**
- * Outputs to chat based on transferring an item from or to an item pile
- *
- * @param source
- * @param target
- * @param items
- * @param userId
- * @param interactionId
- * @returns {Promise}
- * @private
- */
- async _outputTransferItem(source, target, items, userId, interactionId) {
- if (!API.isValidItemPile(source)) return;
- if (!interactionId || game.user.id !== userId || game.settings.get(CONSTANTS.MODULE_NAME, "outputToChat") === "off") return;
- const itemData = await this._formatItemData(items);
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.PICKUP_CHAT_MESSAGE, source.uuid, target.uuid, itemData, [], userId, interactionId);
- },
-
- /**
- * Outputs to chat based on transferring a currency from or to an item pile
- *
- * @param source
- * @param target
- * @param currencies
- * @param userId
- * @param interactionId
- * @returns {Promise}
- * @private
- */
- _outputTransferCurrency(source, target, currencies, userId, interactionId) {
- if (!API.isValidItemPile(source)) return;
- if (!interactionId || game.user.id !== userId || game.settings.get(CONSTANTS.MODULE_NAME, "outputToChat") === "off") return;
- const currencyData = this._formatCurrencyData(source, currencies);
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.PICKUP_CHAT_MESSAGE, source.uuid, target.uuid, [], currencyData, userId, interactionId);
- },
-
- /**
- * Outputs to chat based on transferring everything from or to an item pile
- *
- * @param source
- * @param target
- * @param items
- * @param currencies
- * @param userId
- * @param interactionId
- * @returns {Promise}
- * @private
- */
- async _outputTransferEverything(source, target, items, currencies, userId, interactionId) {
- if (!API.isValidItemPile(source)) return;
- if (!interactionId || game.user.id !== userId || game.settings.get(CONSTANTS.MODULE_NAME, "outputToChat") === "off") return;
- const itemData = await this._formatItemData(items);
- const currencyData = this._formatCurrencyData(source, currencies);
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.PICKUP_CHAT_MESSAGE, source.uuid, target.uuid, itemData, currencyData, userId, interactionId);
- },
-
- _outputSplitItemPileInventory(source, transferData, userId) {
- if (!API.isValidItemPile(source)) return;
- if (game.user.id !== userId || game.settings.get(CONSTANTS.MODULE_NAME, "outputToChat") === "off") return;
- return itemPileSocket.executeAsGM(SOCKET_HANDLERS.SPLIT_CHAT_MESSAGE, source.uuid, transferData, userId);
- },
-
- async _outputTradeStarted(party_1, party_2, publicTradeId, isPrivate) {
- if (party_1.user !== game.user.id || game.settings.get(CONSTANTS.MODULE_NAME, "outputToChat") === "off" || isPrivate) return;
- return this._outputTradeStartedToChat(party_1, party_2, publicTradeId);
- },
-
- async _outputTradeComplete(party_1, party_2, publicTradeId, isPrivate) {
- if (game.settings.get(CONSTANTS.MODULE_NAME, "outputToChat") === "off") return;
- return this._outputTradeCompleteToChat(party_1, party_2, publicTradeId, isPrivate);
- },
-
- /**
- * Formats item data to a chat friendly structure
- *
- * @param items
- * @returns {Array}
- * @private
- */
- async _formatItemData(items) {
- const formattedItems = [];
- for(const itemData of items){
- const tempItem = await Item.implementation.create(itemData.item, { temporary: true });
- formattedItems.push({
- name: tempItem.name,
- img: itemData.item.img ?? "",
- quantity: itemData.quantity
- });
- }
- return formattedItems;
- },
-
- /**
- * Formats currency data to a chat friendly structure
- *
- * @param itemPile
- * @param currencies
- * @returns {Array}
- * @private
- */
- _formatCurrencyData(itemPile, currencies) {
- const currencyList = lib.getActorCurrencyList(itemPile);
- return Object.entries(currencies).map(entry => {
- const currency = currencyList.find(currency => currency.path === entry[0]);
- return {
- name: currency.name,
- img: currency.img ?? "",
- quantity: entry[1],
- index: currencyList.indexOf(currency)
- }
- });
- },
-
- /**
- * Outputs the transferred data in chat
- *
- * @param sourceUuid
- * @param targetUuid
- * @param items
- * @param currencies
- * @param userId
- * @param interactionId
- * @returns {Promise}
- * @private
- */
- async _outputPickupToChat(sourceUuid, targetUuid, items, currencies, userId, interactionId) {
-
- const source = await fromUuid(sourceUuid);
- const target = await fromUuid(targetUuid);
-
- const sourceActor = source?.actor ?? source;
- const targetActor = target?.actor ?? target;
-
- const now = (+new Date());
-
- // Get all messages younger than 3 hours, and grab the last 10, then reverse them (latest to oldest)
- const messages = Array.from(game.messages).filter(message => (now - message.data.timestamp) <= (1000 * 60 * 60 * 3)).slice(-10);
- messages.reverse()
-
- for (let [index, message] of messages.entries()) {
- const flags = message.getFlag(CONSTANTS.MODULE_NAME, CONSTANTS.PILE_DATA);
- if (flags && flags.source === sourceUuid && flags.target === targetUuid && (flags.interactionId === interactionId || index === 0)) {
- return this._updateExistingPickupMessage(message, sourceActor, targetActor, items, currencies, interactionId)
- }
- }
-
- const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/loot-chat-message.html", {
- message: game.i18n.format("ITEM-PILES.Chat.Pickup", { name: targetActor.name }),
- itemPile: sourceActor,
- actor: targetActor,
- items: items,
- currencies: currencies
- });
-
- return this._createNewChatMessage(userId, {
- user: game.user.id,
- type: CONST.CHAT_MESSAGE_TYPES.OTHER,
- content: chatCardHtml,
- flavor: "Item Piles",
- speaker: ChatMessage.getSpeaker({ alias: game.user.name }),
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: {
- source: sourceUuid,
- target: targetUuid,
- items: items,
- currencies: currencies,
- interactionId: interactionId
- }
- })
-
- },
-
- _matchEntries(existingEntries, incomingEntries) {
-
- const combinedEntries = existingEntries.map(existingEntry => {
- const foundEntry = incomingEntries.find(item => item.name === existingEntry.name && existingEntry.img === item.img);
- if (foundEntry) {
- existingEntry.quantity += foundEntry.quantity;
- incomingEntries.splice(incomingEntries.indexOf(foundEntry), 1)
- }
- return existingEntry;
- });
-
- incomingEntries.forEach(item => combinedEntries.push(item));
-
- return combinedEntries;
-
- },
-
- async _updateExistingPickupMessage(message, sourceActor, targetActor, items, currencies, interactionId) {
-
- const flags = message.getFlag(CONSTANTS.MODULE_NAME, CONSTANTS.PILE_DATA);
-
- const newItems = this._matchEntries(flags.items, items);
- const newCurrencies = this._matchEntries(flags.currencies, currencies);
-
- newCurrencies.sort((a, b) => {
- return a.index - b.index;
- })
-
- const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/loot-chat-message.html", {
- message: game.i18n.format("ITEM-PILES.Chat.Pickup", { name: targetActor.name }),
- itemPile: sourceActor,
- actor: targetActor,
- items: newItems,
- currencies: newCurrencies
- });
-
- return message.update({
- content: chatCardHtml,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}.interactionId`]: interactionId,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}.items`]: newItems,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}.currencies`]: newCurrencies,
- });
-
- },
-
- async _outputSplitToChat(sourceUuid, transferData, userId) {
-
- const source = await fromUuid(sourceUuid);
-
- const sourceActor = source?.actor ?? source;
-
- const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/loot-chat-message.html", {
- message: game.i18n.format("ITEM-PILES.Chat.Split", { num_players: transferData.num_players }),
- itemPile: sourceActor,
- items: transferData.items,
- currencies: transferData.currencies
- });
-
- return this._createNewChatMessage(userId, {
- user: game.user.id,
- type: CONST.CHAT_MESSAGE_TYPES.OTHER,
- content: chatCardHtml,
- flavor: "Item Piles",
- speaker: ChatMessage.getSpeaker({ alias: game.user.name })
- });
-
- },
-
- async _outputTradeStartedToChat(party_1, party_2, publicTradeId) {
-
- let party_1_actor = await fromUuid(party_1.actor);
- party_1_actor = party_1_actor?.actor ?? party_1_actor;
-
- let party_2_actor = await fromUuid(party_2.actor);
- party_2_actor = party_2_actor?.actor ?? party_2_actor;
-
- const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/trade-started-chat-message.html", {
- party_1_actor,
- party_2_actor,
- publicTradeId,
- userId: game.user.id
- });
-
- return this._createNewChatMessage(game.user.id, {
- user: game.user.id,
- type: CONST.CHAT_MESSAGE_TYPES.OTHER,
- content: chatCardHtml,
- flavor: "Item Piles",
- speaker: ChatMessage.getSpeaker({ alias: game.user.name }),
- [`flags.${CONSTANTS.MODULE_NAME}`]: {
- publicTradeId,
- tradeUsers: [party_1.user, party_2.user]
- }
- });
- },
-
- async _outputTradeCompleteToChat(party_1, party_2, publicTradeId, isPrivate) {
-
- if (party_1.user !== game.user.id) return;
-
- let party_1_actor = await fromUuid(party_1.actor);
- party_1_actor = party_1_actor?.actor ?? party_1_actor;
- const party_1_data = {
- actor: party_1_actor,
- items: party_2.items,
- currencies: party_2.currencies
- }
- party_1_data.got_nothing = !party_1_data.items.length && !party_1_data.currencies.length;
-
- let party_2_actor = await fromUuid(party_2.actor);
- party_2_actor = party_2_actor?.actor ?? party_2_actor;
- const party_2_data = {
- actor: party_2_actor,
- items: party_1.items,
- currencies: party_1.currencies
- }
- party_2_data.got_nothing = !party_2_data.items.length && !party_2_data.currencies.length;
-
- if (party_1.got_nothing && party_2.got_nothing) return;
-
- const enableCollapse = (party_1_data.items.length + party_1_data.currencies.length + party_2_data.items.length + party_2_data.currencies.length) > 6;
-
- const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/trade-complete-chat-message.html", {
- party_1: party_1_data,
- party_2: party_2_data,
- publicTradeId,
- isPrivate,
- enableCollapse
- });
-
- return this._createNewChatMessage(game.user.id, {
- user: game.user.id,
- type: isPrivate ? CONST.CHAT_MESSAGE_TYPES.WHISPER : CONST.CHAT_MESSAGE_TYPES.OTHER,
- content: chatCardHtml,
- flavor: "Item Piles" + (isPrivate ? ": " + game.i18n.localize("ITEM-PILES.Chat.PrivateTrade") : ""),
- speaker: ChatMessage.getSpeaker({ alias: game.user.name }),
- whisper: isPrivate ? [party_2.user] : []
- });
-
- },
-
- _createNewChatMessage(userId, chatData) {
-
- if (!chatData.whisper) {
-
- const mode = game.settings.get(CONSTANTS.MODULE_NAME, "outputToChat");
-
- if (mode > 1) {
- chatData.whisper = Array.from(game.users)
- .filter(user => user.isGM)
- .map(user => user.id);
- if (mode === 2) {
- chatData.whisper.push(userId);
- }
- chatData.type = CONST.CHAT_MESSAGE_TYPES.WHISPER;
- }
-
- }
-
- return ChatMessage.create(chatData);
-
- }
-
-}
-
-export default chatHandler;
\ No newline at end of file
diff --git a/scripts/constants.js b/scripts/constants.js
deleted file mode 100644
index b7a68170..00000000
--- a/scripts/constants.js
+++ /dev/null
@@ -1,47 +0,0 @@
-const CONSTANTS = {
- MODULE_NAME: "item-piles",
- PILE_DATA: "data",
- SHARING_DATA: "sharing",
- PILE_DEFAULTS: {
- // Core settings
- enabled: false,
- distance: 1,
- macro: "",
- deleteWhenEmpty: "default",
- canInspectItems: true,
-
- // Overrides
- overrideItemFilters: false,
- overrideCurrencies: false,
-
- // Token settings
- displayOne: false,
- showItemName: false,
- overrideSingleItemScale: false,
- singleItemScale: 1.0,
-
- // Container settings
- isContainer: false,
- closed: false,
- locked: false,
- closedImage: "",
- emptyImage: "",
- openedImage: "",
- lockedImage: "",
- closeSound: "",
- openSound: "",
- lockedSound: "",
- unlockedSound: "",
-
- // Sharing settings
- shareItemsEnabled: false,
- shareCurrenciesEnabled: true,
- takeAllEnabled: false,
- splitAllEnabled: true,
- activePlayers: false
- }
-}
-
-CONSTANTS.PATH = `modules/${CONSTANTS.MODULE_NAME}/`;
-
-export default CONSTANTS;
\ No newline at end of file
diff --git a/scripts/flagManager.js b/scripts/flagManager.js
deleted file mode 100644
index 2d19b91d..00000000
--- a/scripts/flagManager.js
+++ /dev/null
@@ -1,128 +0,0 @@
-import * as lib from "./lib/lib.js";
-import CONSTANTS from "./constants.js";
-
-const flagManager = {
-
- _latestFlagVersion: false,
- updateStack: new Map(),
- localStack: new Map(),
-
- get latestFlagVersion() {
- if (!this._latestFlagVersion) {
- const versions = Object.keys(this.migrations);
- versions.sort((a, b) => {
- return isNewerVersion(a, b) ? -1 : 1;
- })
- this._latestFlagVersion = versions[0];
- }
- return this._latestFlagVersion;
- },
-
- async migrateDocuments() {
-
- if (!lib.isResponsibleGM()) return;
-
- const currentVersion = game.settings.get(CONSTANTS.MODULE_NAME, "migrationVersion");
-
- if (this.latestFlagVersion === currentVersion) return;
-
- const scenes = Array.from(game.scenes);
-
- for (const scene of scenes) {
-
- const tokens = Array.from(scene.tokens)
-
- const updates = tokens.map(token => {
-
- let pileData = token.getFlag(CONSTANTS.MODULE_NAME, CONSTANTS.PILE_DATA);
-
- if (!pileData) return false;
-
- const pileVersion = pileData?.flagVersion || "1.0.0";
- if (pileVersion === this.latestFlagVersion) return false;
-
- for (let [version, migration] of Object.entries(this.migrations)) {
- if (!isNewerVersion(version, pileVersion)) continue;
- pileData = migration(token, pileData);
-
- lib.debug(`Migration token with UUID "${token.uuid}" to version ${version}`);
- }
-
- pileData.flagVersion = this.latestFlagVersion;
-
- return {
- "_id": token.id,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileData,
- [`actorData.flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileData
- };
-
- }).filter(Boolean);
-
- await scene.updateEmbeddedDocuments("Token", updates);
-
- }
-
- await game.actors.updateAll((actor) => {
-
- let pileData = actor.getFlag(CONSTANTS.MODULE_NAME, CONSTANTS.PILE_DATA);
-
- const pileVersion = pileData?.flagVersion || "1.0.0";
-
- for (let [version, migration] of Object.entries(this.migrations)) {
- if (!isNewerVersion(version, pileVersion)) continue;
- pileData = migration(actor, pileData);
-
- lib.debug(`Migration actor with UUID "${actor.uuid}" to version ${version}`);
- }
-
- pileData.flagVersion = this.latestFlagVersion;
-
- return {
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileData,
- [`token.flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: pileData
- };
-
- }, (actor) => {
- let pileData = actor.getFlag(CONSTANTS.MODULE_NAME, CONSTANTS.PILE_DATA);
- if (!pileData) return false;
- const pileVersion = pileData?.flagVersion || "1.0.0";
- return pileVersion !== this.latestFlagVersion;
- });
-
- await game.settings.set(CONSTANTS.MODULE_NAME, "migrationVersion", this.latestFlagVersion);
-
-
- },
-
- migrations: {
-
- "1.2.6": (inDocument, pileData) => {
- pileData.overrideItemFilters = pileData?.itemTypeFilters?.length
- ? [{ path: "type", filters: pileData.itemTypeFilters }]
- : false;
- delete pileData.itemTypeFilters;
-
- return foundry.utils.duplicate(pileData);
- },
-
- "1.3.0": (inDocument, pileData) => {
-
- const newPileData = foundry.utils.duplicate(CONSTANTS.PILE_DEFAULTS);
-
- for (const key of Object.keys(newPileData)) {
- newPileData[key] = pileData[key] ?? newPileData[key];
- }
-
- newPileData.overrideCurrencies = pileData?.overrideDynamicAttributes?.length
- ? [{ path: "type", filters: pileData.overrideDynamicAttributes }]
- : false;
-
- return foundry.utils.duplicate(newPileData);
-
- },
- },
-
-}
-
-
-export default flagManager;
\ No newline at end of file
diff --git a/scripts/formapplications/drop-currency-dialog.js b/scripts/formapplications/drop-currency-dialog.js
deleted file mode 100644
index a0f23636..00000000
--- a/scripts/formapplications/drop-currency-dialog.js
+++ /dev/null
@@ -1,118 +0,0 @@
-import CONSTANTS from "../constants.js";
-import * as lib from "../lib/lib.js";
-
-export default class DropCurrencyDialog extends FormApplication {
-
- constructor(resolve, {
- title,
- content,
- button,
- target,
- source,
- existingCurrencies = false,
- includeAllCurrencies = false
- } = {}) {
- super();
-
- this._title = title ?? game.i18n.localize("ITEM-PILES.DropCurrencies.Title");
- this._content = content ?? game.i18n.localize("ITEM-PILES.DropCurrencies.Player");
- this._button = button ?? game.i18n.localize("ITEM-PILES.DropCurrencies.AddToPile")
-
- this.resolve = resolve;
- this.target = target;
- this.source = source;
- this.existingCurrencies = existingCurrencies;
- this.includeAllCurrencies = includeAllCurrencies;
- }
-
- /** @inheritdoc */
- static get defaultOptions() {
- return foundry.utils.mergeObject(super.defaultOptions, {
- classes: ["dialog"],
- template: `${CONSTANTS.PATH}templates/drop-currency-dialog.html`,
- width: 430,
- height: "auto"
- });
- }
-
- get title() {
- return this._title;
- }
-
- /**
- * @param parameters
- * @returns {Promise}
- */
- static query(parameters) {
- return new Promise(resolve => {
- new DropCurrencyDialog(resolve, parameters).render(true);
- });
- }
-
- async getData(options) {
- const data = super.getData(options);
-
- data.source = this.source;
- data.target = this.target;
-
- let currencyList = { currencyList: lib.getActorCurrencyList(this.target), getAll: this.includeAllCurrencies };
-
- data.currencies = lib.getActorCurrencies(this.source, currencyList);
-
- if (!this.includeAllCurrencies) {
- data.currencies = data.currencies.filter(currency => currency.quantity)
- }
-
- data.currencies.map(currency => {
- currency.currentQuantity = 0;
- if (this.existingCurrencies) {
- const existingCurrency = this.existingCurrencies.find(existingCurrency => existingCurrency.path === currency.path);
- if (existingCurrency) {
- currency.currentQuantity = existingCurrency.quantity;
- }
- }
- return currency;
- })
-
- data.includeAllCurrencies = this.includeAllCurrencies;
- data.content = this._content;
- data.button = this._button;
-
- return data;
- }
-
- /* -------------------------------------------- */
-
- activateListeners(html) {
- super.activateListeners(html);
-
- html.find('.item-piles-slider-group').each(function () {
-
- const slider = $(this).find(".item-piles-range-slider")
- const input = $(this).find(".item-piles-range-input")
- slider.on("input", function () {
- input.val($(this).val());
- })
- input.keyup(function () {
- slider.val($(this).val());
- });
-
- })
- }
-
- async _updateObject(event, formData) {
-
- if (event.submitter.value === "cancel") {
- return this.resolve(false);
- }
-
- return this.resolve(formData);
-
- }
-
- async close(options) {
- super.close(options);
- this.resolve(false);
- }
-
-}
\ No newline at end of file
diff --git a/scripts/formapplications/drop-item-dialog.js b/scripts/formapplications/drop-item-dialog.js
deleted file mode 100644
index dc793894..00000000
--- a/scripts/formapplications/drop-item-dialog.js
+++ /dev/null
@@ -1,75 +0,0 @@
-import CONSTANTS from "../constants.js";
-import * as lib from "../lib/lib.js";
-
-export default class DropItemDialog extends FormApplication {
-
- constructor(resolve, droppedItem, itemPile) {
- super();
- this.resolve = resolve;
- this.droppedItem = droppedItem;
- this.itemPile = itemPile;
- }
-
- /** @inheritdoc */
- static get defaultOptions() {
- return foundry.utils.mergeObject(super.defaultOptions, {
- title: game.i18n.localize("ITEM-PILES.DropItem.Title"),
- classes: ["dialog"],
- template: `${CONSTANTS.PATH}templates/drop-item-dialog.html`,
- width: 430,
- height: "auto"
- });
- }
-
- static query(droppedItem, itemPile) {
-
- return new Promise(resolve => {
- new DropItemDialog(resolve, droppedItem, itemPile).render(true);
- });
-
- }
-
- async getData(options) {
- const data = super.getData(options);
-
- data.itemPile = this.itemPile;
- data.itemPileAtLocation = !!this.itemPile;
- data.droppedItem = this.droppedItem;
- data.itemQuantity = lib.getItemQuantity(this.droppedItem);
- data.itemQuantityMoreThanOne = data.itemQuantity > 1;
-
- return data;
- }
-
- /* -------------------------------------------- */
-
- activateListeners(html) {
- super.activateListeners(html);
- const slider = html.find(".rangeSlider");
- const input = html.find(".rangeValue")
- slider.on("input", function () {
- input.val($(this).val());
- })
- input.keyup(function () {
- slider.val($(this).val());
- })
- }
-
- async _updateObject(event, formData) {
-
- if (event.submitter.value === "cancel") {
- return this.resolve(false);
- }
-
- formData.action = event.submitter.value;
-
- return this.resolve(formData);
-
- }
-
- async close(options) {
- await super.close(options);
- this.resolve(false);
- }
-
-}
\ No newline at end of file
diff --git a/scripts/formapplications/item-pile-config.js b/scripts/formapplications/item-pile-config.js
deleted file mode 100644
index 0ccfec7c..00000000
--- a/scripts/formapplications/item-pile-config.js
+++ /dev/null
@@ -1,254 +0,0 @@
-import CONSTANTS from "../constants.js";
-import API from "../api.js";
-import * as lib from "../lib/lib.js";
-import { ItemPileCurrenciesEditor } from "./item-pile-currencies-editor.js";
-import { ItemPileFiltersEditor } from "./item-pile-filters-editor.js";
-
-export class ItemPileConfig extends FormApplication {
-
- constructor(actor) {
- super();
- this.document = actor?.token ?? actor;
- this.pileData = foundry.utils.mergeObject(CONSTANTS.PILE_DEFAULTS, lib.getItemPileData(this.document));
- this.currenciesEditor = false;
- this.itemFiltersEditor = false;
- }
-
- /** @inheritdoc */
- static get defaultOptions() {
- return foundry.utils.mergeObject(super.defaultOptions, {
- classes: ["sheet", "item-piles-config"],
- template: `${CONSTANTS.PATH}templates/item-pile-config.html`,
- width: 430,
- resizable: true,
- tabs: [{ navSelector: ".tabs", contentSelector: ".tab-body", initial: "mainsettings" }]
- });
- }
-
- get title() {
- return `${game.i18n.localize("ITEM-PILES.Defaults.Title")}: ${this.document.data.name}`
- }
-
- static show(actor) {
- const document = actor?.token ?? actor;
- for (let app of Object.values(ui.windows)) {
- if (app instanceof this && app.document === document) {
- return app.render(false, { focus: true });
- }
- }
- return new ItemPileConfig(actor).render(true);
- }
-
- /* -------------------------------------------- */
-
- async getData(options) {
- let data = super.getData(options);
- data.flagData = foundry.utils.mergeObject(foundry.utils.duplicate(data), foundry.utils.duplicate(this.pileData));
- return data;
- }
-
- activateListeners(html) {
- super.activateListeners(html);
- const self = this;
- const enabledCheckbox = html.find('input[name="enabled"]');
- const scaleCheckbox = html.find('input[name="overrideSingleItemScale"]');
- const displayOneCheckbox = html.find('input[name="displayOne"]');
- const containerCheckbox = html.find('input[name="isContainer"]');
- const overrideItemFiltersEnabledCheckbox = html.find('.item-piles-config-override-item-filters-checkbox');
- const overrideCurrenciesEnabledCheckbox = html.find('.item-piles-config-override-currencies-checkbox');
- const shareItemsEnabledCheckbox = html.find('input[name="shareItemsEnabled"]');
- const shareAttributesEnabledCheckbox = html.find('input[name="shareCurrenciesEnabled"]');
-
- const slider = html.find(".item-piles-scaleRange");
- const input = html.find(".item-piles-scaleInput");
-
- enabledCheckbox.change(async function () {
- let isEnabled = $(this).is(":checked");
- const existingData = lib.getItemPileData(self.document);
- if (isEnabled && !existingData?.enabled) {
- const isLinked = self.document instanceof Actor
- ? self.document.data.token.actorLink
- : self.document.isLinked;
- if (isLinked) {
- const doContinue = await Dialog.confirm({
- title: game.i18n.localize("ITEM-PILES.Dialogs.LinkedActorWarning.Title"),
- content: lib.dialogLayout({ message: game.i18n.localize("ITEM-PILES.Dialogs.LinkedActorWarning.Content") }),
- defaultYes: false
- });
- if (!doContinue) {
- $(this).prop("checked", false);
- }
- }
- }
- })
-
- scaleCheckbox.change(function () {
- let isDisabled = !$(this).is(":checked") || !displayOneCheckbox.is(":checked");
- slider.prop('disabled', isDisabled);
- input.prop('disabled', isDisabled);
- slider.parent().toggleClass("item-piles-disabled", isDisabled);
- }).change();
-
- displayOneCheckbox.change(function () {
- let isEnabled = $(this).is(":checked");
- let isScale = scaleCheckbox.is(":checked");
- let isContainer = containerCheckbox.is(":checked");
-
- slider.prop('disabled', !isEnabled || !isScale);
- input.prop('disabled', !isEnabled || !isScale);
- slider.parent().toggleClass("item-piles-disabled", !isEnabled || !isScale);
-
- scaleCheckbox.prop('disabled', !isEnabled);
- scaleCheckbox.parent().toggleClass("item-piles-disabled", !isEnabled);
-
- html.find('input[name="showItemName"]').prop('disabled', !isEnabled);
- html.find('input[name="showItemName"]').parent().toggleClass("item-piles-disabled", !isEnabled);
-
- html.find(".display-one-warning").css("display", isEnabled && isContainer ? "block" : "none");
- self.setPosition();
- }).change();
-
- containerCheckbox.change(function () {
- let isEnabled = $(this).is(":checked");
- let isDisplayOne = displayOneCheckbox.is(":checked");
- html.find(".display-one-warning").css("display", isEnabled && isDisplayOne ? "block" : "none");
- }).change();
-
- overrideCurrenciesEnabledCheckbox.change(function () {
- let isChecked = $(this).is(":checked");
- if (isChecked) {
- self.pileData.overrideCurrencies = game.settings.get(CONSTANTS.MODULE_NAME, "currencies");
- }
- html.find(".item-piles-config-configure-override-currencies").prop('disabled', !isChecked);
- })
-
- html.find(".item-piles-config-configure-override-currencies").click(function () {
- self.showCurrenciesEditor();
- })
-
- overrideItemFiltersEnabledCheckbox.change(function () {
- let isChecked = $(this).is(":checked");
- if (isChecked) {
- self.pileData.overrideItemFilters = game.settings.get(CONSTANTS.MODULE_NAME, "itemFilters");
- }
- html.find(".item-piles-config-configure-override-item-filters").prop('disabled', !isChecked);
- })
-
- html.find(".item-piles-config-configure-override-item-filters").click(function () {
- self.showItemFiltersEditor();
- })
-
- slider.on("input", function () {
- input.val($(this).val());
- })
- input.change(function () {
- slider.slider('value', $(this).val());
- })
-
- const takeAllButtonCheckbox = html.find('input[name="takeAllEnabled"]');
-
- shareItemsEnabledCheckbox.change(function () {
- const isDisabled = shareItemsEnabledCheckbox.is(":checked") || shareAttributesEnabledCheckbox.is(":checked");
- takeAllButtonCheckbox.prop("disabled", isDisabled).parent().toggleClass("item-piles-disabled", isDisabled);
- if (isDisabled && takeAllButtonCheckbox.is(':checked')) {
- takeAllButtonCheckbox.prop('checked', false)
- }
- });
-
- shareAttributesEnabledCheckbox.change(function () {
- const isDisabled = shareItemsEnabledCheckbox.is(":checked") || shareAttributesEnabledCheckbox.is(":checked");
- takeAllButtonCheckbox.prop("disabled", isDisabled).parent().toggleClass("item-piles-disabled", isDisabled);
- if (isDisabled && takeAllButtonCheckbox.is(':checked')) {
- takeAllButtonCheckbox.prop('checked', false)
- }
- }).change();
-
- html.find(".item-piles-config-reset-sharing-data").click(function () {
- self.resetSharingData();
- })
- }
-
- async showCurrenciesEditor() {
- if (this.currenciesEditor) {
- return this.currenciesEditor.render(false, { focus: true });
- }
- const [promise, UI] = ItemPileCurrenciesEditor.showForPile(this.pileData.overrideCurrencies);
- this.currenciesEditor = UI;
- promise.then(newSettings => {
- this.currenciesEditor = false;
- if (newSettings) {
- this.pileData.overrideCurrencies = newSettings;
- }
- });
- }
-
- async showItemFiltersEditor() {
- if (this.itemFiltersEditor) {
- return this.itemFiltersEditor.render(false, { focus: true });
- }
- const [promise, UI] = ItemPileFiltersEditor.showForPile(this.pileData.overrideItemFilters);
- this.itemFiltersEditor = UI;
- promise.then(newSettings => {
- this.itemFiltersEditor = false;
- if (newSettings) {
- this.pileData.overrideItemFilters = newSettings;
- }
- });
- }
-
- async resetSharingData() {
- return new Dialog({
- title: game.i18n.localize("ITEM-PILES.Dialogs.ResetSharingData.Title"),
- content: lib.dialogLayout({ message: game.i18n.localize("ITEM-PILES.Dialogs.ResetSharingData.Content") }),
- buttons: {
- confirm: {
- icon: ' ',
- label: game.i18n.localize("ITEM-PILES.Dialogs.ResetSharingData.Confirm"),
- callback: () => {
- lib.clearItemPileSharingData(this.document);
- }
- },
- cancel: {
- icon: ' ',
- label: game.i18n.localize("No")
- }
- },
- default: "cancel"
- }).render(true);
- }
-
- async _updateObject(event, formData) {
-
- let defaults = foundry.utils.duplicate(CONSTANTS.PILE_DEFAULTS);
-
- const data = foundry.utils.mergeObject(defaults, formData);
-
- const overrideCurrenciesChecked = this.element.find('.item-piles-config-override-currencies-checkbox').is(":checked");
- data.overrideCurrencies = overrideCurrenciesChecked ? this.pileData.overrideCurrencies : false;
-
- const overrideItemFiltersChecked = this.element.find('.item-piles-config-override-item-filters-checkbox').is(":checked");
- data.overrideItemFilters = overrideItemFiltersChecked ? this.pileData.overrideItemFilters : false;
-
- data.deleteWhenEmpty = {
- "default": "default",
- "true": true,
- "false": false
- }[data.deleteWhenEmpty];
-
- API.updateItemPile(this.document, data).then(() => {
- API.rerenderItemPileInventoryApplication(this.document.uuid);
- });
-
- }
-
- async close(...args) {
- super.close(...args);
- if (this.currenciesEditor) {
- this.currenciesEditor.close();
- }
- if (this.itemFiltersEditor) {
- this.itemFiltersEditor.close();
- }
- }
-
-}
\ No newline at end of file
diff --git a/scripts/formapplications/item-pile-currencies-editor.js b/scripts/formapplications/item-pile-currencies-editor.js
deleted file mode 100644
index 4871b114..00000000
--- a/scripts/formapplications/item-pile-currencies-editor.js
+++ /dev/null
@@ -1,97 +0,0 @@
-import CONSTANTS from "../constants.js";
-
-export class ItemPileCurrenciesEditor extends FormApplication {
-
- constructor(pileCurrencies = false, resolve = false) {
- super();
- this.resolve = resolve;
- this.currencies = pileCurrencies || game.settings.get(CONSTANTS.MODULE_NAME, "currencies");
- }
-
- /** @inheritdoc */
- static get defaultOptions() {
- return foundry.utils.mergeObject(super.defaultOptions, {
- title: game.i18n.localize("ITEM-PILES.CurrenciesEditor.Title"),
- classes: ["sheet", "item-pile-currencies-editor"],
- template: `${CONSTANTS.PATH}templates/currencies-editor.html`,
- width: 630,
- height: "auto",
- resizable: false
- });
- }
-
- static showForPile(pileCurrencies) {
- let resolve;
- const promise = new Promise(_resolve => {
- resolve = _resolve;
- });
- return [promise, new ItemPileCurrenciesEditor(foundry.utils.duplicate(pileCurrencies), resolve).render(true)]
- }
-
- async getData(options) {
- const data = super.getData(options);
- data.currencies = this.currencies;
- return data;
- }
-
- /* -------------------------------------------- */
-
- activateListeners(html) {
- super.activateListeners(html);
- const self = this;
- html.find('.item-piles-currency-remove').click(function () {
- const index = Number($(this).closest('.item-piles-currency-row').attr("data-currency-index"));
- self.currencies.splice(index, 1);
- $(this).closest('.item-piles-currency-row').remove();
- self.rerender();
- });
- html.find('.item-piles-add-new-currency').click(function () {
- self.currencies.push({
- name: "",
- path: "",
- img: ""
- })
- self.rerender();
- });
- }
-
- rerender() {
- const self = this;
- this.element.find('.item-piles-currency-row').each(function (index) {
- if (index === 0) return;
- self.currencies[index - 1] = {
- name: $(this).find('.item-piles-currency-name-input').val(),
- path: $(this).find('.item-piles-currency-path-input').val(),
- img: $(this).find('.item-piles-currency-img-input').val()
- }
- });
- return this.render(true);
- }
-
- async _updateObject(event, formData) {
-
- if (event.submitter.value === "cancel") {
- return this.resolve ? this.resolve() : false;
- }
-
- const newSettings = [];
- for (let [path, value] of Object.entries(formData)) {
- setProperty(newSettings, path, value)
- }
-
- if (!this.resolve) {
- game.settings.set(CONSTANTS.MODULE_NAME, "currencies", newSettings);
- } else {
- this.resolve(newSettings);
- }
-
- }
-
- async close(...args) {
- if (this.resolve) {
- this.resolve()
- }
- return super.close(...args)
- }
-
-}
\ No newline at end of file
diff --git a/scripts/formapplications/item-pile-filters-editor.js b/scripts/formapplications/item-pile-filters-editor.js
deleted file mode 100644
index 31bb5504..00000000
--- a/scripts/formapplications/item-pile-filters-editor.js
+++ /dev/null
@@ -1,91 +0,0 @@
-import CONSTANTS from "../constants.js";
-
-export class ItemPileFiltersEditor extends FormApplication {
-
- constructor(pileFilters = false, resolve = false) {
- super();
- this.resolve = resolve;
- this.filters = pileFilters || game.settings.get(CONSTANTS.MODULE_NAME, "itemFilters");
- }
-
- /** @inheritdoc */
- static get defaultOptions() {
- return foundry.utils.mergeObject(super.defaultOptions, {
- title: game.i18n.localize("ITEM-PILES.FilterEditor.Title"),
- classes: ["sheet", "item-pile-filters-editor"],
- template: `${CONSTANTS.PATH}templates/filter-editor.html`,
- width: 630,
- height: "auto",
- resizable: false
- });
- }
-
- static showForPile(pileFilters) {
- let resolve;
- const promise = new Promise(_resolve => {
- resolve = _resolve;
- });
- return [promise, new ItemPileFiltersEditor(foundry.utils.duplicate(pileFilters), resolve).render(true)]
- }
-
- async getData(options) {
- const data = super.getData(options);
- data.filters = this.filters;
- return data;
- }
-
- /* -------------------------------------------- */
-
- activateListeners(html) {
- super.activateListeners(html);
- const self = this;
- html.find('.item-pile-filters-remove').click(function () {
- const index = Number($(this).closest('.item-pile-filters-row').attr("data-filter-index"));
- self.filters.splice(index, 1);
- $(this).closest('.item-pile-filters-row').remove();
- self.rerender();
- });
- html.find('button[name="newFilter"]').click(function () {
- self.filters.push({
- path: "",
- filters: ""
- })
- self.render(true);
- });
- }
-
- rerender() {
- const self = this;
- this.element.find('.item-pile-filters-row').each(function (index) {
- if (index === 0) return;
- self.filters[index - 1] = {
- path: $(this).find('.item-pile-filters-path-input').val(),
- filters: $(this).find('.item-pile-filters-input').val()
- }
- });
- return this.render(true);
- }
-
- async _updateObject(event, formData) {
-
- const newSettings = [];
- for (let [path, value] of Object.entries(formData)) {
- setProperty(newSettings, path, value)
- }
-
- if (!this.resolve) {
- game.settings.set(CONSTANTS.MODULE_NAME, "itemFilters", newSettings);
- } else {
- this.resolve(newSettings);
- }
-
- }
-
- async close(...args) {
- if (this.resolve) {
- this.resolve()
- }
- return super.close(...args)
- }
-
-}
\ No newline at end of file
diff --git a/scripts/formapplications/item-pile-inventory.js b/scripts/formapplications/item-pile-inventory.js
deleted file mode 100644
index fb8c9848..00000000
--- a/scripts/formapplications/item-pile-inventory.js
+++ /dev/null
@@ -1,625 +0,0 @@
-import CONSTANTS from "../constants.js";
-import API from "../api.js";
-import * as lib from "../lib/lib.js";
-import { isPileInventoryOpenForOthers } from "../socket.js";
-import HOOKS from "../hooks.js";
-import { ItemPileConfig } from "./item-pile-config.js";
-import DropCurrencyDialog from "./drop-currency-dialog.js";
-
-export class ItemPileInventory extends FormApplication {
-
- /**
- *
- * @param pile
- * @param recipient
- * @param overrides
- */
- constructor(pile, recipient, overrides = {}) {
- super();
- this.pile = pile;
- this.recipient = recipient;
- this.items = [];
- this.currencies = [];
- this.deleted = false;
- this.overrides = overrides;
- this.pileData = lib.getItemPileData(this.pile);
- this.interactionId = randomID();
- Hooks.callAll(HOOKS.PILE.OPEN_INVENTORY, this, pile, recipient, overrides);
- }
-
- /** @inheritdoc */
- static get defaultOptions() {
- return foundry.utils.mergeObject(super.defaultOptions, {
- closeOnSubmit: false,
- classes: ["sheet"],
- template: `${CONSTANTS.PATH}templates/item-pile-inventory.html`,
- width: 550,
- height: "auto",
- dragDrop: [{ dragSelector: null, dropSelector: ".item-piles-item-drop-container" }],
- });
- }
-
- get title() {
- return this.pile.name;
- }
-
- /**
- *
- * @param inPileUuid
- * @param recipientUuid
- * @returns {Array[]|boolean}
- */
- static getActiveAppFromPile(inPileUuid, recipientUuid = false) {
-
- const openApps = Object.values(ui.windows).filter(app => {
- return app instanceof this
- && (app?.pile?.uuid === inPileUuid || app?.pile?.actor?.uuid === inPileUuid)
- && (!recipientUuid || (app?.recipient?.uuid === recipientUuid || app?.recipient?.actor?.uuid === recipientUuid))
- })
-
- if (openApps.length) {
- return openApps;
- }
-
- return false;
- }
-
- static async rerenderActiveApp(inPileUuid, deleted = false) {
- const openApps = ItemPileInventory.getActiveAppFromPile(inPileUuid);
- if (!openApps) return false;
- for (const app of openApps) {
- app.saveItems();
- app.saveCurrencies();
- app.deleted = app.deleted || deleted;
- app.render(true);
- }
- return true;
- }
-
- static async show(pile, recipient, overrides = {}) {
- const pileUuid = await lib.getUuid(pile);
- const recipientUuid = recipient ? await lib.getUuid(recipient) : false;
-
- let app = ItemPileInventory.getActiveAppFromPile(pileUuid, recipientUuid);
- if (app) {
- [app] = app;
- app.pileData = lib.getItemPileData(app.pile);
- return app.render(true, { focus: true });
- }
-
- const result = Hooks.call(HOOKS.PILE.PRE_OPEN_INVENTORY, pile, recipient, overrides);
- if (result === false) return;
-
- return new ItemPileInventory(pile, recipient, overrides).render(true);
- }
-
- async render(...args) {
- this.pileActor = this.pile?.actor ?? this.pile;
- this.recipientActor = this.recipient?.actor ?? this.recipient;
- this.editQuantities = !this.recipient && this.pile.isOwner && game.user.isGM;
- this.playerActors = game.actors.filter(actor => actor.isOwner && actor !== this.pileActor && actor.data.token.actorLink);
- super.render(...args);
- }
-
- /* -------------------------------------------- */
-
- /** @override */
- _getHeaderButtons() {
- let buttons = super._getHeaderButtons();
- const canConfigure = game.user.isGM;
- if (canConfigure) {
- buttons = [
- {
- label: "ITEM-PILES.Inspect.OpenSheet",
- class: "item-piles-open-actor-sheet",
- icon: "fas fa-user",
- onclick: () => {
- this.pileActor.sheet.render(true, { focus: true });
- }
- },
- {
- label: "ITEM-PILES.HUD.Configure",
- class: "item-piles-configure-pile",
- icon: "fas fa-box-open",
- onclick: () => {
- ItemPileConfig.show(this.pileActor);
- }
- },
- ].concat(buttons);
- }
- return buttons
- }
-
- saveItems() {
-
- // Get all of the items on the actor right now
- const newItems = this.getPileItemData();
-
- // If there are none, stop displaying them in the UI
- if (!newItems.length) {
- this.items = [];
- return;
- }
-
- // Otherwise, loop through the old items
- for (let oldItem of this.items) {
-
- // If we find an item that was previously listed
- const foundItem = lib.findSimilarItem(newItems, oldItem);
-
- // We update the previously listed attribute to reflect this
- oldItem.quantity = foundItem ? foundItem.quantity : 0;
- oldItem.shareLeft = foundItem ? foundItem.shareLeft : 0;
- oldItem.currentQuantity = foundItem ? Math.min(oldItem.currentQuantity, foundItem.shareLeft) : 0;
-
- // We then remove it from the incoming list, as we already have it
- if (foundItem) {
- newItems.splice(newItems.indexOf(foundItem), 1)
- }
-
- }
-
- // Add the new items to the list
- this.items = this.items.concat(newItems);
-
- }
-
- getPileItemData() {
- return lib.getItemPileItemsForActor(this.pile, this.recipientActor);
- }
-
- saveCurrencies() {
-
- // Get all of the currencies on the actor right now
- const newCurrencies = this.getPileCurrenciesData();
-
- // If there are none, stop displaying them in the UI
- if (!newCurrencies.length) {
- this.currencies = [];
- return;
- }
-
- // Otherwise, loop through the old currencies
- for (let oldCurrency of this.currencies) {
-
- // If we find an currency that was previously listed
- const foundCurrency = newCurrencies.find(newCurrency => newCurrency.path === oldCurrency.path);
-
- // We update the previously listed currency to reflect this
- oldCurrency.quantity = foundCurrency ? foundCurrency.quantity : 0;
- oldCurrency.shareLeft = foundCurrency ? foundCurrency.shareLeft : 0;
- oldCurrency.currentQuantity = foundCurrency ? Math.min(oldCurrency.currentQuantity, foundCurrency.shareLeft) : 0;
-
- if (foundCurrency) {
- // We then remove it from the incoming list, as we already have it
- newCurrencies.splice(newCurrencies.indexOf(foundCurrency), 1)
- }
-
- }
-
- // Add the new currencies to the list
- this.currencies = this.currencies.concat(newCurrencies);
-
- }
-
- getPileCurrenciesData() {
- return lib.getItemPileCurrenciesForActor(this.pile, this.recipientActor);
- }
-
- _onDrop(event) {
-
- super._onDrop(event);
-
- let data;
- try {
- data = JSON.parse(event.dataTransfer.getData('text/plain'));
- } catch (err) {
- return false;
- }
-
- return API._dropData(canvas, data, { target: this.pile });
-
- }
-
- getData(options) {
- const data = super.getData(options);
-
- data.isDeleted = this.deleted;
-
- data.name = !data.isDeleted ? this.pile.name : "Nonexistent pile";
-
- if (this.deleted) {
- return data;
- }
-
- data.systemHasCurrencies = !!API.CURRENCIES.length;
-
- data.playerActors = this.playerActors;
- data.moreThanOneInspectableActors = data.playerActors.length > 1;
-
- data.overrides = this.overrides;
- data.editQuantities = this.editQuantities;
- data.hasRecipient = !!this.recipientActor;
- data.recipient = this.recipientActor;
- data.isContainer = false;
-
- const pileData = lib.getItemPileData(this.pile);
-
- data.items = this.items.length ? this.items : this.getPileItemData();
- this.items = data.items;
-
- data.currencies = this.currencies.length ? this.currencies : this.getPileCurrenciesData();
- this.currencies = data.currencies;
-
- data.isContainer = pileData.isContainer;
- data.hasItems = data.items.length > 0;
- data.hasCurrencies = data?.currencies?.length;
- data.canInspectItems = pileData.canInspectItems || game.user.isGM;
-
- data.isEmpty = !data?.hasItems && !data?.hasCurrencies;
-
- data.shareItemsEnabled = pileData.shareItemsEnabled;
- data.shareCurrenciesEnabled = pileData.shareCurrenciesEnabled;
-
- const sharingData = lib.getItemPileSharingData(this.pile);
- const num_players = lib.getPlayersForItemPile(this.pile).length;
-
- const hasSplittableItems = pileData.shareItemsEnabled && data.items && !!data.items?.find(item => {
- let quantity = item.quantity;
- if(sharingData.currencies){
- const itemSharingData = sharingData.currencies.find(sharingCurrency => sharingCurrency.path === item.path);
- if(itemSharingData){
- quantity += itemSharingData.actors.reduce((acc, data) => acc + data.quantity, 0);
- }
- }
- return (quantity / num_players) >= 1;
- });
-
- const hasSplittableCurrencies = pileData.shareCurrenciesEnabled && data.currencies && !!data.currencies?.find(currency => {
- let quantity = currency.quantity;
- if(sharingData.currencies) {
- const currencySharingData = sharingData.currencies.find(sharingCurrency => sharingCurrency.path === currency.path);
- if (currencySharingData) {
- quantity += currencySharingData.actors.reduce((acc, data) => acc + data.quantity, 0);
- }
- }
- return (quantity / num_players) >= 1;
- });
-
- data.buttons = [];
-
- if (!data.hasRecipient && data.editQuantities) {
- data.buttons.push({
- value: "update",
- icon: "fas fa-save",
- text: game.i18n.localize("ITEM-PILES.Defaults.Update")
- });
- }
-
- if (pileData.splitAllEnabled && (data.hasRecipient || game.user.isGM)) {
-
- let buttonText;
- if (pileData.shareItemsEnabled && pileData.shareCurrenciesEnabled) {
- buttonText = game.i18n.format("ITEM-PILES.Inspect.SplitAll", { num_players });
- } else if (pileData.shareItemsEnabled) {
- buttonText = game.i18n.format("ITEM-PILES.Inspect.SplitItems", { num_players });
- } else {
- buttonText = game.i18n.format("ITEM-PILES.Inspect.SplitCurrencies", { num_players });
- }
-
- data.buttons.push({
- value: "splitAll",
- icon: "far fa-handshake",
- text: buttonText,
- disabled: !num_players || !(hasSplittableItems || hasSplittableCurrencies),
- type: "button"
- });
-
- }
-
- if (pileData.isContainer && !this.overrides.remote) {
- data.buttons.push({
- value: "close",
- icon: "fas fa-box",
- text: game.i18n.localize("ITEM-PILES.Inspect.Close")
- })
- }
-
- if (data.hasRecipient && !pileData.shareItemsEnabled && !pileData.shareCurrenciesEnabled && pileData.takeAllEnabled) {
-
- data.buttons.push({
- value: "takeAll",
- icon: "fas fa-fist-raised",
- text: game.i18n.localize("ITEM-PILES.Inspect.TakeAll")
- });
-
- }
-
- return data;
- }
-
- activateListeners(html) {
- super.activateListeners(html);
- let self = this;
- let timer;
- html.find('img').mouseenter(function () {
- const element = $(this);
- timer = setTimeout(function () {
- self.previewImage(html, element);
- }, 300);
- });
-
- html.find('img').mouseleave(function () {
- self.clearImage(html);
- clearTimeout(timer);
- });
-
- html.find('.item-piles-quantity').keyup(function () {
- if (!self.editQuantities) return;
-
- const itemId = $(this).closest(".item-piles-item-row").attr("data-item-id");
-
- const isItem = !!itemId;
-
- const currentQuantity = Number($(this).val());
-
- if (isItem) {
- const item = self.items.find(item => item.id === itemId)
- item.currentQuantity = currentQuantity;
- return;
- }
-
- const currencyPath = $(this).closest(".item-piles-item-row").attr('data-currency-path');
- const attribute = self.currencies.find(currency => currency.path === currencyPath)
-
- attribute.currentQuantity = currentQuantity;
- });
-
- html.find(".item-piles-name-container .item-piles-clickable").click(function () {
- const itemId = $(this).closest(".item-piles-item-row").attr('data-item-id');
- self.previewItem(itemId);
- })
-
- html.find(".item-piles-item-take-button").click(function () {
- const itemId = $(this).closest(".item-piles-item-row").attr('data-item-id');
- const inputQuantity = $(this).closest(".item-piles-item-row").find(".item-piles-quantity").val();
- self.takeItem(itemId, inputQuantity);
- })
-
- html.find(".item-piles-currency-take-button").click(function () {
- const currency = $(this).closest(".item-piles-item-row").attr('data-currency-path');
- const inputQuantity = $(this).closest(".item-piles-item-row").find(".item-piles-quantity").val();
- self.takeCurrency(currency, inputQuantity);
- })
-
- html.find('button[name="splitAll"]').click(function () {
- self.splitAll();
- })
-
- html.find('.item-piles-add-currency').click(function () {
- self.addCurrency();
- })
-
- if (this.playerActors.length > 1) {
- html.find('.item-piles-change-actor').click(function () {
- $(this).hide();
- let select = $(this).parent().find('.item-piles-change-actor-select');
- select.insertAfter($(this));
- select.css('display', 'inline-block');
- });
-
- html.find(".item-piles-change-actor-select").change(async function () {
- $(this).css('display', 'none');
- html.find('.item-piles-change-actor').show();
- const value = $(this).val();
- self.recipient = await fromUuid(value);
- if (!self.recipient) {
- return;
- }
- self.render(true);
- });
- } else {
- const element = html.find('.item-piles-change-actor');
- const innerHTML = element.html();
- element.removeClass(".item-piles-change-actor")
- .replaceWith($('' + innerHTML + ' '));
- html.find('.item-piles-change-actor-select').remove();
- }
-
- // Activate context menu
- this._contextMenu(html);
- }
-
- /* -------------------------------------------- */
-
- /** @inheritdoc */
- _contextMenu(html) {
- ContextMenu.create(this, html, ".item-piles-item-row", this._getEntryContextOptions());
- }
-
- /* -------------------------------------------- */
-
- /**
- * Get the Macro entry context options
- * @returns {object[]} The Macro entry context options
- * @private
- */
- _getEntryContextOptions() {
- return [
- {
- name: "JOURNAL.ActionShow",
- icon: ' ',
- condition: (div) => {
- return game.user.isGM && div.data("item-id");
- },
- callback: (div) => {
- const item = this.pileActor.items.get(div.data("item-id"));
- const popout = new ImagePopout(item.data.img, { title: item.name }).render(true);
- popout.shareImage();
- }
- }
- ];
- }
-
- previewImage(html, element) {
-
- const src = element.prop("src");
-
- const pos = element.position();
-
- const imageContainer = html.find("#item-piles-preview-image");
-
- imageContainer.prop("src", src);
-
- let container = html.find("#item-piles-preview-container");
-
- setTimeout(() => {
-
- container.css({
- position: "absolute",
- top: (pos.top - (container.outerHeight() / 2)) + "px",
- left: (-container.outerWidth() - pos.left) + "px"
- }).fadeIn(150);
-
- }, 10)
- }
-
- clearImage(html) {
- html.find("#item-piles-preview-container").fadeOut(150);
- }
-
- async previewItem(itemId) {
- const item = this.pileActor.items.get(itemId);
- if (game.user.isGM || item.data.permission[game.user.id] === 3) {
- return item.sheet.render(true);
- }
-
- const cls = item._getSheetClass()
- const sheet = new cls(item, { editable: false })
- return sheet._render(true);
- }
-
- async takeItem(itemId, inputQuantity) {
- const item = this.pileActor.items.get(itemId);
- let quantity = lib.getItemQuantity(item);
- quantity = Math.min(inputQuantity, quantity);
- return API.transferItems(this.pile, this.recipient, [{
- _id: itemId,
- quantity
- }], { interactionId: this.interactionId });
- }
-
- async takeCurrency(attribute, inputQuantity) {
- let quantity = Number(getProperty(this.pileActor.data, attribute) ?? 0);
- quantity = Math.min(inputQuantity, quantity);
- await API.transferAttributes(this.pile, this.recipient, { [attribute]: quantity }, { interactionId: this.interactionId });
- }
-
- async splitAll() {
- await API.splitItemPileContents(this.pile);
- }
-
- async addCurrency() {
-
- if (this.recipient) {
- const currencyToAdd = await DropCurrencyDialog.query({
- target: this.pile,
- source: this.recipient
- })
- return API.transferAttributes(this.recipient, this.pile, currencyToAdd);
- }
-
- if (game.user.isGM) {
- const currencyToAdd = await DropCurrencyDialog.query({
- target: this.pile,
- source: this.recipient,
- includeAllCurrencies: true
- })
- return API.addAttributes(this.pile, currencyToAdd);
- }
- }
-
- async _updateObject(event, formData) {
-
- if (event.submitter.value === "update") {
- lib.custom_notify("Item Pile successfully updated.");
- await this.updatePile(formData);
- return this.render(true);
- }
-
- if (event.submitter.value === "takeAll") {
- API.transferEverything(this.pile, this.recipient, { interactionId: this.interactionId });
- }
-
- if (event.submitter.value === "close") {
- isPileInventoryOpenForOthers.query(this.pile).then((result) => {
- if (!result) API.closeItemPile(this.pile, this.recipient);
- });
- }
-
- return this.close();
-
- }
-
- updatePile(data) {
-
- const items = [];
- const attributes = {};
-
- for (let [type, quantity] of Object.entries(data)) {
- if (type.startsWith("currency-")) {
- const path = type.replace("currency-", "");
- if (quantity === this.currencies.find(currency => currency.path === path).quantity) continue;
- attributes[path] = quantity;
- } else {
- const itemId = type.replace("item-", "");
- if (itemId === this.items.find(item => item.id === itemId).itemId) continue;
- items.push({
- _id: itemId,
- [API.ITEM_QUANTITY_ATTRIBUTE]: quantity
- })
- }
- }
-
- const pileSharingData = lib.getItemPileSharingData(this.pile);
-
- const hasAttributes = !foundry.utils.isObjectEmpty(attributes);
-
- if (hasAttributes) {
- this.pileActor.update(attributes);
- if (pileSharingData?.currencies) {
- pileSharingData.currencies = pileSharingData.currencies.map(currency => {
- if (attributes[currency.path] !== undefined) {
- currency.actors = currency.actors.map(actor => {
- actor.quantity = Math.max(0, Math.min(actor.quantity, attributes[currency.path]));
- return actor;
- })
- }
- return currency;
- })
- }
- }
-
- if (items.length) {
- this.pileActor.updateEmbeddedDocuments("Item", items);
- if (pileSharingData?.items) {
- pileSharingData.items = pileSharingData.items.map(item => {
- const sharingItem = items.find(item => item._id === item.id);
- if (sharingItem) {
- item.actors = item.actors.map(actor => {
- actor.quantity = Math.max(0, Math.min(actor.quantity, sharingItem.quantity));
- return actor;
- })
- }
- return item;
- })
- }
- }
-
- if (items.length || hasAttributes) {
- lib.updateItemPileSharingData(this.pile, pileSharingData);
- }
-
- }
-
-}
\ No newline at end of file
diff --git a/scripts/formapplications/item-pile-similarities-editor.js b/scripts/formapplications/item-pile-similarities-editor.js
deleted file mode 100644
index 841920e8..00000000
--- a/scripts/formapplications/item-pile-similarities-editor.js
+++ /dev/null
@@ -1,65 +0,0 @@
-import CONSTANTS from "../constants.js";
-
-export class ItemPileSimilaritiesEditor extends FormApplication {
-
- constructor() {
- super();
- this.similarities = game.settings.get(CONSTANTS.MODULE_NAME, "itemSimilarities");
- }
-
- /** @inheritdoc */
- static get defaultOptions() {
- return foundry.utils.mergeObject(super.defaultOptions, {
- title: game.i18n.localize("ITEM-PILES.SimilaritiesEditor.Title"),
- classes: ["sheet", "item-pile-similarities-editor"],
- template: `${CONSTANTS.PATH}templates/similarities-editor.html`,
- width: 400,
- height: "auto",
- resizable: false
- });
- }
-
- async getData(options) {
- const data = super.getData(options);
- data.similarities = this.similarities;
- return data;
- }
-
- /* -------------------------------------------- */
-
- activateListeners(html) {
- super.activateListeners(html);
- const self = this;
- html.find('.item-pile-similarities-remove').click(function () {
- const index = Number($(this).closest('.item-pile-similarities-row').attr("data-similarities-index"));
- self.similarities.splice(index, 1);
- $(this).closest('.item-pile-similarities-row').remove();
- self.rerender();
- });
- html.find('button[name="newPath"]').click(function () {
- self.similarities.push("")
- self.render(true);
- });
- }
-
- rerender() {
- const self = this;
- this.element.find('.item-pile-similarities-row').each(function (index) {
- if (index === 0) return;
- self.similarities[index - 1] = $(this).find('.item-pile-similarities-path-input').val()
- });
- return this.render(true);
- }
-
- async _updateObject(event, formData) {
-
- const newSettings = [];
- for (let [path, value] of Object.entries(formData)) {
- setProperty(newSettings, path, value)
- }
-
- game.settings.set(CONSTANTS.MODULE_NAME, "itemSimilarities", newSettings);
-
- }
-
-}
\ No newline at end of file
diff --git a/scripts/formapplications/trade-dialogs.js b/scripts/formapplications/trade-dialogs.js
deleted file mode 100644
index e40f9822..00000000
--- a/scripts/formapplications/trade-dialogs.js
+++ /dev/null
@@ -1,249 +0,0 @@
-import CONSTANTS from "../constants.js";
-import * as lib from "../lib/lib.js";
-
-export class TradePromptDialog extends FormApplication {
-
- constructor(resolve, { actors = false, actor = false, users = false, user = false } = {}) {
- super();
- this.resolve = resolve;
- this.users = users || game.users.filter(user => user.active && user !== game.user);
- this.user = user || users?.[0] || false;
- this.actors = actors || game.actors.filter(actor => actor.isOwner);
- this.actor = actor || game.user.character || (!game.user.isGM ? this.actors?.[0] : false);
- this.isGM = game.user.isGM;
-
- }
-
- /** @inheritdoc */
- static get defaultOptions() {
- return foundry.utils.mergeObject(super.defaultOptions, {
- title: game.i18n.localize("ITEM-PILES.Trade.Title"),
- classes: ["dialog"],
- template: `${CONSTANTS.PATH}templates/trade-dialog.html`,
- width: 400,
- height: "auto",
- dragDrop: [{ dragSelector: null, dropSelector: ".item-piles-actor-container" }],
- });
- }
-
- static show({ actors = false, actor = false, users = false, user = false }) {
- return new Promise(resolve => {
- new TradePromptDialog(resolve, { actors, actor, users, user }).render(true);
- })
- }
-
- activateListeners(html) {
- super.activateListeners(html);
- const self = this;
-
- html.find(".item-piles-actor-container").on("dragenter", function (event) {
- event = event.originalEvent || event;
- let newElement = document.elementFromPoint(event.pageX, event.pageY);
- if (!$.contains(this, newElement)) {
- $(this).addClass("item-piles-box-highlight");
- }
- })
-
- html.find(".item-piles-actor-container").on("dragleave", function (event) {
- event = event.originalEvent || event;
- let newElement = document.elementFromPoint(event.pageX, event.pageY);
- if (!$.contains(this, newElement)) {
- $(this).removeClass("item-piles-box-highlight");
- }
- })
-
- html.find(".item-piles-pick-selected-token").click(() => {
- if (canvas.tokens.controlled.length === 0) return;
- this.setActor(canvas.tokens.controlled[0].actor);
- });
-
- html.find('select[name="user"]').change(function () {
- const userId = $(this).val();
- self.user = game.users.get(userId);
- });
-
- html.find('input[name="private"]').change(function () {
- self.private = $(this).is(":checked");
- });
-
- html.find('.item-piles-change-actor').click(function () {
- $(this).hide();
- let select = $(this).parent().find('.item-piles-change-actor-select');
- select.insertAfter($(this));
- select.css('display', 'inline-block');
- });
-
- html.find(".item-piles-change-actor-select").change(async function () {
- $(this).css('display', 'none');
- html.find('.item-piles-change-actor').show();
- const actor = await fromUuid($(this).val());
- self.setActor(actor);
- });
- }
-
- async _onDrop(event) {
-
- super._onDrop(event);
-
- let data;
- try {
- data = JSON.parse(event.dataTransfer.getData('text/plain'));
- } catch (err) {
- return false;
- }
-
- if (data.type !== "Actor") return;
-
- this.setActor(game.actors.get(data.id));
-
- }
-
- setActor(actor) {
- if (!actor.isOwner) {
- return lib.custom_warning(game.i18n.localize("ITEM-PILES.Trade.ActorOwnerWarning"), true);
- }
- this.actor = actor;
- this.render(true);
- }
-
- async getData(options) {
- const data = await super.getData(options);
- data.user = this.user;
- data.users = this.users;
- data.actor = this.actor;
- data.actors = this.actors;
- data.private = this.private;
- data.multipleActors = this.actors.length > 1 && !game.user.isGM;
- data.hasUnlinkedTokenOwnership = this.actors.filter(a => !a.data.token.actorLink).length > 0;
- data.buttons = [{
- value: "accept",
- icon: "fas fa-check",
- text: game.i18n.localize("ITEM-PILES.Trade.Request.Label"),
- disabled: !data.actor
- }]
- return data;
- }
-
- async _updateObject(event, formData) {
- const actor = await fromUuid(formData?.actor || this.actor.uuid);
- return this.resolve({
- userId: formData.user,
- actor: actor,
- private: formData.private
- });
- }
-
- async close(...args) {
- super.close(...args);
- this.resolve(false);
- }
-
-}
-
-export class TradeRequestDialog extends TradePromptDialog {
-
- constructor(resolve, { tradeId, tradingUser, tradingActor, isPrivate } = {}) {
- super(resolve);
- this.tradeId = tradeId;
- this.tradingUser = tradingUser;
- this.tradingActor = tradingActor;
- this.isPrivate = isPrivate;
- this.progressbarTimeout = false
- this.timeout = false;
- this._hasClosed = false;
- this.interval = setInterval(() => {
- const user = game.users.get(this.tradingUser.id)
- if (!user.active) {
- lib.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Disconnected"), true)
- this.close();
- }
- }, 100)
- }
-
- static show({ tradeId, tradingUser, tradingActor, isPrivate } = {}) {
- return new Promise(resolve => {
- new TradeRequestDialog(resolve, { tradeId, tradingUser, tradingActor, isPrivate }).render(true);
- })
- }
-
- static cancel(tradeId) {
- for (const app of Object.values(ui.windows)) {
- if (app instanceof TradeRequestDialog && app.tradeId === tradeId) {
- return app.close({ type: "cancelled" });
- }
- }
- return false;
- }
-
- activateListeners(html) {
- super.activateListeners(html);
-
- const progressBarContainer = html.find(".item-piles-progress");
- const progressBar = html.find(".progress-bar");
- progressBarContainer.hide();
- this.progressbarTimeout = setTimeout(() => {
- if (this._hasClosed) return;
- progressBarContainer.fadeIn(1000)
- progressBar.css("transition", 'width 20s linear')
- progressBar.css("width", "100%")
- this.setPosition();
- }, 14000);
-
- this.timeout = setTimeout(() => {
- if (this._hasClosed) return;
- lib.custom_warning(game.i18n.localize("ITEM-PILES.Trade.AutoDecline"), true)
- html.find('button[name="decline"]').click();
- }, 35000)
-
- }
-
- async getData(options) {
- let data = await super.getData(options);
- data.isPrompt = true;
- data.tradingUser = this.tradingUser;
- data.tradingActor = this.tradingActor;
- data.isPrivate = this.isPrivate;
- data.buttons = [{
- value: "accept",
- icon: "fas fa-check",
- text: game.i18n.localize("ITEM-PILES.Trade.Accept")
- }, {
- value: "decline",
- icon: "fas fa-times",
- text: game.i18n.localize("ITEM-PILES.Trade.Decline")
- }, {
- value: "mute",
- icon: "fas fa-comment-slash",
- text: game.i18n.localize("ITEM-PILES.Trade.Mute")
- }];
- return data;
- }
-
- async _updateObject(event, formData) {
- this._hasClosed = true;
- clearInterval(this.interval);
- clearTimeout(this.progressbarTimeout);
- clearTimeout(this.timeout);
-
- if (event.submitter.value === "accept") {
- const actor = await fromUuid(formData?.actor || this.actor.uuid);
- return this.resolve(actor)
- }
-
- if (event.submitter.value === "mute") {
- return this.resolve("mute");
- }
-
- return this.resolve(false);
- }
-
- async close(options) {
- this._hasClosed = true;
- clearInterval(this.interval);
- clearTimeout(this.progressbarTimeout);
- clearTimeout(this.timeout);
- this.resolve(options?.type);
- return super.close(options);
- }
-
-}
\ No newline at end of file
diff --git a/scripts/formapplications/trading-app.js b/scripts/formapplications/trading-app.js
deleted file mode 100644
index 3526aa73..00000000
--- a/scripts/formapplications/trading-app.js
+++ /dev/null
@@ -1,489 +0,0 @@
-import CONSTANTS from "../constants.js";
-import * as lib from "../lib/lib.js";
-import { hotkeyState } from "../hotkeys.js";
-import DropCurrencyDialog from "./drop-currency-dialog.js";
-import { itemPileSocket, SOCKET_HANDLERS } from "../socket.js";
-import { TradeAPI } from "../trade-api.js";
-import API from "../api.js";
-
-export class TradingApp extends FormApplication {
-
- constructor(leftTrader, rightTrader, publicTradeId, privateTradeId = false, isPrivate = false) {
- super();
-
- this.leftTraderActor = leftTrader.actor;
- this.leftTraderUser = leftTrader.user;
- this.leftTraderActorItems = leftTrader.items ?? [];
- this.leftTraderActorCurrencies = leftTrader.currencies ?? [];
- this.leftTraderAccepted = leftTrader.accepted ?? false;
-
- this.rightTraderActor = rightTrader.actor;
- this.rightTraderUser = rightTrader.user;
- this.rightTraderActorItems = rightTrader.items ?? [];
- this.rightTraderActorCurrencies = rightTrader.currencies ?? [];
- this.rightTraderAccepted = rightTrader.accepted ?? false;
-
- this.publicTradeId = publicTradeId;
- this.privateTradeId = privateTradeId;
-
- this.isPrivate = isPrivate;
-
- this.editingInput = false;
- this.currencyWindow = false;
- }
-
-
- /** @inheritdoc */
- static get defaultOptions() {
- return foundry.utils.mergeObject(super.defaultOptions, {
- classes: ["dialog", "item-piles-trading-sheet"],
- width: 800,
- height: "auto",
- dragDrop: [{ dragSelector: null, dropSelector: ".item-piles-item-drop-container" }],
- closeOnSubmit: false
- });
- }
-
- get template() {
- return this.leftTraderUser === game.user || this.rightTraderUser === game.user
- ? `${CONSTANTS.PATH}templates/trading-app.html`
- : `${CONSTANTS.PATH}templates/trading-app-spectate.html`;
- }
-
- get title() {
- return game.i18n.format("ITEM-PILES.Trade.Between", {
- actor_1: this.leftTraderActor.name,
- actor_2: this.rightTraderActor.name
- });
- }
-
- static getAppByPublicTradeId(publicTradeId) {
- for (const app of Object.values(ui.windows)) {
- if (app instanceof TradingApp && app?.publicTradeId === publicTradeId) {
- return app;
- }
- }
- return false;
- }
-
- static _updateItems(publicTradeId, userId, itemData) {
- const app = TradingApp.getAppByPublicTradeId(publicTradeId);
- if (app) {
- return app.updateItems(userId, itemData);
- }
- return false;
- }
-
- static _updateCurrencies(publicTradeId, userId, currencyData) {
- const app = TradingApp.getAppByPublicTradeId(publicTradeId);
- if (app) {
- return app.updateCurrencies(userId, currencyData);
- }
- return false;
- }
-
- static _setAcceptedState(publicTradeId, userId, state) {
- const app = TradingApp.getAppByPublicTradeId(publicTradeId);
- if (app) {
- return app.setAcceptedState(userId, state);
- }
- return false;
- }
-
- static _tradeCompleted(party_1, party_2, publicTradeId) {
- const app = TradingApp.getAppByPublicTradeId(publicTradeId);
- if (app) {
- return app.close({ accepted: true });
- }
- return false;
- }
-
- static _tradeClosed(publicTradeId, userId) {
- const app = TradingApp.getAppByPublicTradeId(publicTradeId);
- if (app) {
- return app.close({ userId });
- }
- return false;
- }
-
- async executeSocketAction(socketHandler, ...args) {
- if (this.isPrivate) {
- return itemPileSocket.executeForUsers(socketHandler, [this.leftTraderUser.id, this.rightTraderUser.id], ...args);
- }
- return itemPileSocket.executeForEveryone(socketHandler, ...args);
- }
-
- async _onDrop(event) {
-
- if (game.user !== this.leftTraderUser) return;
-
- super._onDrop(event);
-
- let data;
- try {
- data = JSON.parse(event.dataTransfer.getData('text/plain'));
- } catch (err) {
- return false;
- }
-
- if (data.type !== "Item") return;
-
- if (!data.actorId) {
- if (!game.user.isGM) return lib.custom_warning(game.i18n.localize("ITEM-PILES.Errors.NoSourceDrop"), true)
- }
-
- if (!game.user.isGM && data.actorId && data.actorId !== this.leftTraderActor.id) {
- throw lib.custom_error(`You cannot drop items into the trade UI from a different actor than ${this.leftTraderActor.name}!`)
- }
-
- let itemData;
- if (data.pack) {
- const uuid = `Compendium.${data.pack}.${data.id}`;
- const item = await fromUuid(uuid);
- itemData = item.toObject();
- } else if (data.id) {
- itemData = game.items.get(data.id)?.toObject();
- } else {
- itemData = data.data;
- }
-
- if (!itemData) {
- console.error(data);
- throw lib.custom_error("Something went wrong when dropping this item!")
- }
-
- const disallowedType = lib.isItemInvalid(this.rightTraderActor, itemData);
- if (disallowedType) {
- if (!game.user.isGM) {
- return lib.custom_warning(game.i18n.format("ITEM-PILES.Errors.DisallowedItemTrade", { type: disallowedType }), true)
- }
- if (!hotkeyState.shiftDown) {
- const force = await Dialog.confirm({
- title: game.i18n.localize("ITEM-PILES.Dialogs.TradeTypeWarning.Title"),
- content: `${game.i18n.format("ITEM-PILES.Dialogs.TradeTypeWarning.Content", { type: disallowedType })}
`,
- defaultYes: false
- });
- if (!force) {
- return false;
- }
- }
- }
-
- return this.addItem(itemData, !!data.actorId && game.user.isGM);
-
- }
-
- async addItem(newItem, limitQuantity = true) {
-
- const item = lib.findSimilarItem(this.leftTraderActorItems, newItem)
-
- if (!item) {
- this.leftTraderActorItems.push({
- id: newItem._id,
- name: newItem.name,
- img: newItem?.img ?? "",
- quantity: 1,
- maxQuantity: limitQuantity ? lib.getItemQuantity(newItem) : Infinity,
- data: newItem
- })
- } else {
- if (item.quantity >= lib.getItemQuantity(newItem)) return;
- item.quantity = Math.min(item.quantity + 1, lib.getItemQuantity(newItem));
- }
-
- await itemPileSocket.executeForUsers(SOCKET_HANDLERS.PRIVATE.TRADE_UPDATE_ITEMS, [this.leftTraderUser.id, this.rightTraderUser.id], this.privateTradeId, game.user.id, this.leftTraderActorItems);
- return this.executeSocketAction(SOCKET_HANDLERS.PUBLIC.TRADE_UPDATE_ITEMS, this.publicTradeId, game.user.id, this.leftTraderActorItems);
-
- }
-
- updateItems(userId, inItems) {
- if (userId === this.leftTraderUser.id) {
- this.leftTraderActorItems = inItems;
- } else if (userId === this.rightTraderUser.id) {
- this.rightTraderActorItems = inItems;
- }
- this.leftTraderAccepted = false;
- this.rightTraderAccepted = false;
- this.render(true);
- }
-
- async addCurrency(asGM = false) {
-
- if (this.currencyWindow) {
- this.currencyWindow.close();
- }
-
- const currencyToAdd = await DropCurrencyDialog.query({
- source: this.leftTraderActor,
- target: this.rightTraderActor,
- existingCurrencies: this.leftTraderActorCurrencies,
- title: game.i18n.localize("ITEM-PILES.Trade.AddCurrency.Title"),
- content: game.i18n.format("ITEM-PILES.Trade.AddCurrency.Content", { trader_actor_name: this.rightTraderActor.name }),
- button: game.i18n.localize("ITEM-PILES.Trade.AddCurrency.Label"),
- includeAllCurrencies: asGM
- });
-
- if (!currencyToAdd) return;
-
- const currencies = lib.getActorCurrencies(this.leftTraderActor, { getAll: asGM });
-
- Object.entries(currencyToAdd).forEach(entry => {
-
- const existingCurrency = this.leftTraderActorCurrencies.find(currency => currency.path === entry[0]);
-
- if (existingCurrency) {
- existingCurrency.quantity = entry[1];
- return;
- }
-
- const currency = currencies.find(currency => currency.path === entry[0]);
-
- this.leftTraderActorCurrencies.push({
- path: entry[0],
- quantity: entry[1],
- name: currency.name,
- img: currency.img,
- maxQuantity: !asGM ? currency.quantity : Infinity,
- index: currency.index
- });
-
- });
-
- this.leftTraderActorCurrencies = this.leftTraderActorCurrencies.filter(currency => currency.quantity);
-
- this.leftTraderActorCurrencies.sort((a, b) => a.index - b.index);
-
- await itemPileSocket.executeForUsers(SOCKET_HANDLERS.PRIVATE.TRADE_UPDATE_CURRENCIES, [this.leftTraderUser.id, this.rightTraderUser.id], this.privateTradeId, game.user.id, this.leftTraderActorCurrencies);
- return this.executeSocketAction(SOCKET_HANDLERS.PUBLIC.TRADE_UPDATE_CURRENCIES, this.publicTradeId, game.user.id, this.leftTraderActorCurrencies);
-
- }
-
- updateCurrencies(userId, inCurrencies) {
- if (userId === this.leftTraderUser.id) {
- this.leftTraderActorCurrencies = inCurrencies;
- } else if (userId === this.rightTraderUser.id) {
- this.rightTraderActorCurrencies = inCurrencies;
- }
- this.leftTraderAccepted = false;
- this.rightTraderAccepted = false;
- this.render(true);
- }
-
- setAcceptedState(userId, state) {
- if (userId === this.leftTraderUser.id) {
- this.leftTraderAccepted = state;
- } else if (userId === this.rightTraderUser.id) {
- this.rightTraderAccepted = state;
- }
- this.render(true);
- }
-
- activateListeners(html) {
- super.activateListeners(html);
- let self = this;
-
- setTimeout(() => {
- let element = html.find(`.item-piles-item-row[data-item="${this.editingInput}"]`)
- element = element.length ? element : html.find(`.item-piles-item-row[data-currency="${this.editingInput}"]`)
- if (element.length) {
- element.find(".item-piles-quantity").focus()
- }
- }, 50);
-
- html.find('.item-piles-item-row .item-piles-quantity').keyup(function (event) {
- if (event.key === "Enter") {
- event.preventDefault();
- }
-
- const parent = $(this).closest(".item-piles-item-row");
-
- let quantity;
- const value = Number($(this).val());
- if (parent.attr('data-type') === "item") {
- const itemId = parent.attr("data-item");
- const item = self.leftTraderActorItems.find(item => item.id === itemId);
- quantity = Math.min(value, item.maxQuantity);
- item.quantity = quantity;
- } else {
- const currencyPath = parent.attr("data-currency");
- const currency = self.leftTraderActorCurrencies.find(currency => currency.path === currencyPath);
- quantity = Math.min(value, currency.maxQuantity);
- currency.quantity = quantity;
- }
-
- $(this).val(quantity);
-
- if (event.key === "Enter") {
- parent.find(".item-piles-confirm-quantity").click();
- }
-
- });
-
- html.find(".item-piles-quantity-text").dblclick(function () {
- self.resetInputs();
- const parent = $(this).closest(".item-piles-item-row");
- $(this).hide();
- parent.find(".item-piles-quantity-container").show();
- parent.find(".item-piles-confirm-quantity").show();
- const quantityInput = parent.find(".item-piles-quantity");
- quantityInput.focus().select();
- self.editingInput = parent.attr('data-type') === "item"
- ? parent.attr('data-item')
- : parent.attr('data-currency');
- });
-
- html.find(".item-piles-remove-item").click(function () {
- self.editingInput = false;
- const parent = $(this).closest(".item-piles-item-row");
- if (parent.attr('data-type') === "item") {
- return self.setItemQuantity(parent.attr('data-item'), 0)
- }
- return self.setCurrencyQuantity(parent.attr('data-currency'), 0)
- })
-
- html.find(".item-piles-confirm-quantity").click(function () {
- self.editingInput = false;
- const parent = $(this).closest(".item-piles-item-row");
- $(this).hide();
- parent.find(".item-piles-quantity-container").hide();
- parent.find(".item-piles-quantity-text").show();
- const value = Number(parent.find(".item-piles-quantity").val())
-
- parent.find(".item-piles-quantity-text").text(value);
-
- if (parent.attr('data-type') === "item") {
- return self.setItemQuantity(parent.attr('data-item'), value)
- }
-
- return self.setCurrencyQuantity(parent.attr('data-currency'), value)
- })
-
- html.find(".item-piles-add-currency").click(() => {
- this.addCurrency()
- });
-
- html.find(".item-piles-gm-add-currency").click(() => {
- this.addCurrency(true)
- });
-
- html.find(".item-piles-accept-button").click(async () => {
- await itemPileSocket.executeForUsers(SOCKET_HANDLERS.PRIVATE.TRADE_STATE, [this.leftTraderUser.id, this.rightTraderUser.id], this.privateTradeId, game.user.id, !this.leftTraderAccepted);
- return this.executeSocketAction(SOCKET_HANDLERS.PUBLIC.TRADE_STATE, this.publicTradeId, game.user.id, !this.leftTraderAccepted);
- });
-
- }
-
- resetInputs() {
- this.editingInput = false;
- this.element.find(".item-piles-confirm-quantity").each(function () {
- const parent = $(this).closest(".item-piles-item-row");
- $(this).hide();
- parent.find(".item-piles-quantity-container").hide();
- const quantityText = parent.find(".item-piles-quantity-text");
- quantityText.show();
- parent.find(".item-piles-quantity").val(quantityText.text());
- });
- }
-
- async setItemQuantity(itemId, quantity) {
- const item = this.leftTraderActorItems.find(item => item.id === itemId);
- item.quantity = quantity;
- if (!quantity) {
- this.leftTraderActorItems.splice(this.leftTraderActorItems.indexOf(item), 1);
- }
- await itemPileSocket.executeForUsers(SOCKET_HANDLERS.PRIVATE.TRADE_UPDATE_ITEMS, [this.leftTraderUser.id, this.rightTraderUser.id], this.privateTradeId, game.user.id, this.leftTraderActorItems);
- return this.executeSocketAction(SOCKET_HANDLERS.PUBLIC.TRADE_UPDATE_ITEMS, this.publicTradeId, game.user.id, this.leftTraderActorItems);
- }
-
- async setCurrencyQuantity(currencyPath, quantity) {
- const currency = this.leftTraderActorCurrencies.find(currency => currency.path === currencyPath);
- currency.quantity = quantity;
- if (!quantity) {
- this.leftTraderActorCurrencies.splice(this.leftTraderActorCurrencies.indexOf(currency), 1);
- }
- await itemPileSocket.executeForUsers(SOCKET_HANDLERS.PRIVATE.TRADE_UPDATE_CURRENCIES, [this.leftTraderUser.id, this.rightTraderUser.id], this.privateTradeId, game.user.id, this.leftTraderActorCurrencies);
- return this.executeSocketAction(SOCKET_HANDLERS.PUBLIC.TRADE_UPDATE_CURRENCIES, this.publicTradeId, game.user.id, this.leftTraderActorCurrencies);
- }
-
- getData(options) {
- const data = super.getData(options);
-
- data.isGM = this.leftTraderUser === game.user && game.user.isGM;
-
- data.leftActor = {
- name: this.leftTraderActor.name,
- img: this.leftTraderActor.data.img,
- items: foundry.utils.duplicate(this.leftTraderActorItems).map(item => {
- if (this.editingInput === item.id) {
- item.editing = true;
- }
- return item;
- }),
- currencies: foundry.utils.duplicate(this.leftTraderActorCurrencies).map(currency => {
- if (this.editingInput === currency.path) {
- currency.editing = true;
- }
- return currency;
- }),
- hasItems: !!this.leftTraderActorItems.length,
- accepted: this.leftTraderAccepted
- };
-
- data.leftActor.hasItems = !!data.leftActor.items.length;
-
- data.rightActor = {
- name: this.rightTraderActor.name,
- img: this.rightTraderActor.data.img,
- items: this.rightTraderActorItems,
- currencies: this.rightTraderActorCurrencies,
- hasItems: !!this.rightTraderActorItems.length,
- accepted: this.rightTraderAccepted
- };
-
- data.systemHasCurrencies = !!API.CURRENCIES.length;
-
- return data;
- }
-
- async close(options) {
- super.close(options);
- if (!options?.accepted) {
- if (!options?.userId && (this.leftTraderUser.id === game.user.id || this.rightTraderUser.id === game.user.id)) {
- if (this.isPrivate) {
- itemPileSocket.executeAsGM(SOCKET_HANDLERS.DISABLE_CHAT_TRADE_BUTTON, this.publicTradeId);
- itemPileSocket.executeForOthers(SOCKET_HANDLERS.TRADE_CLOSED, this.publicTradeId, game.user.id);
- } else {
- const otherUserId = this.leftTraderUser.id === game.user.id ? this.rightTraderUser.id : this.leftTraderUser.id;
- itemPileSocket.executeAsUser(SOCKET_HANDLERS.TRADE_CLOSED, otherUserId, this.publicTradeId, game.user.id);
- }
- TradeAPI._tradeClosed(this.privateTradeId);
- Dialog.prompt({
- title: game.i18n.localize("ITEM-PILES.Trade.Closed.Title"),
- content: lib.dialogLayout({ message: game.i18n.localize("ITEM-PILES.Trade.Closed.You") }),
- callback: () => {
- },
- rejectClose: false
- })
- } else {
- if (this.leftTraderUser.id === game.user.id && options?.userId === this.rightTraderUser.id) {
- TradeAPI._tradeClosed(this.privateTradeId);
- Dialog.prompt({
- title: game.i18n.localize("ITEM-PILES.Trade.Closed.Title"),
- content: lib.dialogLayout({ message: game.i18n.format("ITEM-PILES.Trade.Closed.Them", { user_name: this.rightTraderUser.name }) }),
- callback: () => {
- },
- rejectClose: false
- })
- } else {
- lib.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Closed.Someone"), true);
- }
- }
- }
- }
-
- _updateObject(event, formData) {
- return false;
- }
-
-
-}
\ No newline at end of file
diff --git a/scripts/hooks.js b/scripts/hooks.js
deleted file mode 100644
index ad115523..00000000
--- a/scripts/hooks.js
+++ /dev/null
@@ -1,65 +0,0 @@
-import CONSTANTS from "./constants.js";
-
-const prefix = (str) => (strs, ...exprs) => `${str}-${strs.reduce((a, c, i) => a + exprs[i - 1] + c)}`
-const module = prefix(CONSTANTS.MODULE_NAME);
-
-const HOOKS = {
- READY: module`ready`,
- PRE_TRANSFER_EVERYTHING: module`preTransferEverything`,
- TRANSFER_EVERYTHING: module`transferEverything`,
- PILE: {
- PRE_CREATE: module`preCreateItemPile`,
- CREATE: module`createItemPile`,
- PRE_UPDATE: module`preUpdateItemPile`,
- UPDATE: module`updateItemPile`,
- PRE_DELETE: module`preDeleteItemPile`,
- DELETE: module`deleteItemPile`,
- PRE_CLOSE: module`preCloseItemPile`,
- CLOSE: module`closeItemPile`,
- PRE_OPEN: module`preOpenItemPile`,
- OPEN: module`openItemPile`,
- PRE_LOCK: module`preLockItemPile`,
- LOCK: module`lockItemPile`,
- PRE_UNLOCK: module`preUnlockItemPile`,
- UNLOCK: module`unlockItemPile`,
- PRE_RATTLE: module`preRattleItemPile`,
- RATTLE: module`rattleItemPile`,
- PRE_TURN_INTO: module`preTurnIntoItemPiles`,
- TURN_INTO: module`turnIntoItemPiles`,
- PRE_REVERT_FROM: module`preRevertFromItemPiles`,
- REVERT_FROM: module`revertFromItemPiles`,
- PRE_OPEN_INVENTORY: module`preOpenItemPileInventory`,
- OPEN_INVENTORY: module`openItemPileInventory`,
- PRE_SPLIT_INVENTORY: module`preSplitItemPileContent`,
- SPLIT_INVENTORY: module`splitItemPileContent`,
- },
- ITEM: {
- PRE_DROP_DETERMINED: module`preDropItemDetermined`,
- PRE_DROP: module`preDropItem`,
- DROP: module`dropItem`,
- PRE_TRANSFER: module`preTransferItems`,
- TRANSFER: module`transferItems`,
- PRE_ADD: module`preAddItems`,
- ADD: module`addItems`,
- PRE_REMOVE: module`preRemoveItems`,
- REMOVE: module`removeItems`,
- PRE_TRANSFER_ALL: module`preTransferAllItems`,
- TRANSFER_ALL: module`transferAllItems`,
- },
- ATTRIBUTE: {
- PRE_TRANSFER: module`preTransferAttributes`,
- TRANSFER: module`transferAttributes`,
- PRE_ADD: module`preAddAttributes`,
- ADD: module`addAttributes`,
- PRE_REMOVE: module`preRemoveAttributes`,
- REMOVE: module`removeAttributes`,
- PRE_TRANSFER_ALL: module`preTransferAllAttributes`,
- TRANSFER_ALL: module`transferAllAttributes`,
- },
- TRADE: {
- STARTED: module`tradeStarted`,
- COMPLETE: module`tradeComplete`
- }
-}
-
-export default HOOKS;
\ No newline at end of file
diff --git a/scripts/hotkeys.js b/scripts/hotkeys.js
deleted file mode 100644
index 50d4bf11..00000000
--- a/scripts/hotkeys.js
+++ /dev/null
@@ -1,134 +0,0 @@
-import API from "./api.js";
-import * as lib from "./lib/lib.js";
-import CONSTANTS from "./constants.js";
-
-export const hotkeyActionState = {
- get openPileInventory() {
- return (!hotkeyState.ctrlDown && !game.settings.get(CONSTANTS.MODULE_NAME, "invertSheetOpen")) || (hotkeyState.ctrlDown && game.settings.get(CONSTANTS.MODULE_NAME, "invertSheetOpen"));
- }
-}
-
-export const hotkeyState = {
- ctrlDown: false,
- altDown: false,
- shiftDown: false
-}
-
-export function registerHotkeysPre() {
-
- if (lib.isVersion9()) {
-
- game.keybindings.register(CONSTANTS.MODULE_NAME, "force-open-item-pile-inventory", {
- name: "Force open inventory",
- uneditable: [
- { key: "ControlLeft" },
- ],
- onDown: () => {
- hotkeyState.ctrlDown = true;
- },
- onUp: () => {
- hotkeyState.ctrlDown = false;
- },
- reservedModifiers: ["SHIFT", "ALT"]
- });
-
- game.keybindings.register(CONSTANTS.MODULE_NAME, "force-drop-item", {
- name: "Force drop item (GM only)",
- uneditable: [
- { key: "ShiftLeft" },
- ],
- onDown: () => {
- hotkeyState.shiftDown = true;
- },
- onUp: () => {
- hotkeyState.shiftDown = false;
- },
- reservedModifiers: ["ALT", "CONTROL"]
- });
-
- game.keybindings.register(CONSTANTS.MODULE_NAME, "force-drop-one-item", {
- name: "Force drop one item",
- uneditable: [
- { key: "AltLeft" },
- ],
- onDown: () => {
- hotkeyState.altDown = true;
- },
- onUp: () => {
- hotkeyState.altDown = false;
- },
- reservedModifiers: ["SHIFT", "CONTROL"]
- });
-
- }
-
-}
-
-export function registerHotkeysPost() {
-
- if (!game.user.isGM) {
- let clicked = false;
- window.addEventListener("mousedown", (event) => {
- if (!canvas.ready) return;
- if (!(canvas.activeLayer instanceof TokenLayer)) return;
- if (game.activeTool !== "select") return;
- const hover = document.elementFromPoint(event.clientX, event.clientY);
- if (!hover || (hover.id !== "board")) return;
- if (event.button !== 0) return;
-
- const pos = canvas.app.renderer.plugins.interaction.mouse.getLocalPosition(canvas.app.stage);
- const tokens = lib.getTokensAtLocation(pos)
- .filter(token => {
- const canView = token._canView(game.user);
- const canSee = !token.data.hidden || game.user.isGM;
- return !canView && canSee;
- });
- if (!tokens.length) return;
- tokens.sort((a, b) => b.zIndex - a.zIndex);
- const token = tokens[0].document;
-
- if (clicked === token) {
- clicked = false;
- return API._itemPileClicked(token);
- }
-
- clicked = token;
- setTimeout(() => {
- clicked = false;
- }, 500);
- });
- }
-
- if (!lib.isVersion9()) {
-
- window.addEventListener("keydown", (event) => {
- switch (event.code) {
- case "ControlLeft":
- hotkeyState.ctrlDown = true;
- break;
- case "ShiftLeft":
- hotkeyState.shiftDown = true;
- break;
- case "AltLeft":
- hotkeyState.altDown = true;
- break;
- }
- });
-
- window.addEventListener("keyup", (event) => {
- switch (event.code) {
- case "ControlLeft":
- hotkeyState.ctrlDown = false;
- break;
- case "ShiftLeft":
- hotkeyState.shiftDown = false;
- break;
- case "AltLeft":
- hotkeyState.altDown = false;
- break;
- }
- });
-
- }
-
-}
\ No newline at end of file
diff --git a/scripts/lib/lib.js b/scripts/lib/lib.js
deleted file mode 100644
index f4129e77..00000000
--- a/scripts/lib/lib.js
+++ /dev/null
@@ -1,758 +0,0 @@
-import CONSTANTS from "../constants.js";
-import API from "../api.js";
-
-export function isGMConnected() {
- return !!Array.from(game.users).find(user => user.isGM && user.active);
-}
-
-export function wait(ms) {
- return new Promise(resolve => setTimeout(resolve, ms));
-}
-
-export function debug(msg, args = "") {
- if (game.settings.get(CONSTANTS.MODULE_NAME, "debug")) console.log(`DEBUG | Item Piles | ${msg}`, args)
-}
-
-export function custom_notify(message) {
- message = `Item Piles | ${message}`;
- ui.notifications.notify(message);
- console.log(message.replace(" ", "\n"));
-}
-
-export function custom_warning(warning, notify = false) {
- warning = `Item Piles | ${warning}`;
- if (notify) ui.notifications.warn(warning);
- console.warn(warning.replace(" ", "\n"));
-}
-
-export function custom_error(error, notify = true) {
- error = `Item Piles | ${error}`;
- if (notify) ui.notifications.error(error);
- return new Error(error.replace(" ", "\n"));
-}
-
-export function isVersion9() {
- return isNewerVersion((game?.version ?? game.data.version), "9.00");
-}
-
-export function getTokensAtLocation(position) {
- const tokens = [...canvas.tokens.placeables];
- return tokens.filter(token => {
- return position.x >= token.x && position.x < (token.x + (token.data.width * canvas.grid.size))
- && position.y >= token.y && position.y < (token.y + (token.data.height * canvas.grid.size));
- });
-}
-
-export function distance_between_rect(p1, p2) {
-
- const x1 = p1.x;
- const y1 = p1.y;
- const x1b = p1.x + p1.w;
- const y1b = p1.y + p1.h;
-
- const x2 = p2.x;
- const y2 = p2.y;
- const x2b = p2.x + p2.w;
- const y2b = p2.y + p2.h;
-
- const left = x2b < x1;
- const right = x1b < x2;
- const bottom = y2b < y1;
- const top = y1b < y2;
-
- if (top && left) {
- return distance_between({ x: x1, y: y1b }, { x: x2b, y: y2 });
- } else if (left && bottom) {
- return distance_between({ x: x1, y: y1 }, { x: x2b, y: y2b });
- } else if (bottom && right) {
- return distance_between({ x: x1b, y: y1 }, { x: x2, y: y2b });
- } else if (right && top) {
- return distance_between({ x: x1b, y: y1b }, { x: x2, y: y2 });
- } else if (left) {
- return x1 - x2b;
- } else if (right) {
- return x2 - x1b;
- } else if (bottom) {
- return y1 - y2b;
- } else if (top) {
- return y2 - y1b;
- }
-
- return 0;
-
-}
-
-export function distance_between(a, b) {
- return new Ray(a, b).distance;
-}
-
-export function grids_between_tokens(a, b) {
- return Math.floor(distance_between_rect(a, b) / canvas.grid.size) + 1
-}
-
-export function tokens_close_enough(a, b, maxDistance) {
- const distance = grids_between_tokens(a, b);
- return maxDistance >= distance;
-}
-
-export function findSimilarItem(items, findItem) {
-
- const itemSimilarities = API.ITEM_SIMILARITIES;
-
- const findItemId = findItem?.id ?? findItem?._id;
-
- return items.find(item => {
- const itemId = item.id ?? item._id;
- if (itemId === findItemId) return true;
-
- const itemData = item instanceof Item ? item.data : item;
- for (const path of itemSimilarities) {
- if (getProperty(itemData, path) !== getProperty(findItem, path)) return false;
- }
-
- return true;
- });
-}
-
-export async function getToken(documentUuid) {
- const document = await fromUuid(documentUuid);
- return document?.token ?? document;
-}
-
-export function is_UUID(inId) {
- return typeof inId === "string"
- && (inId.match(/\./g) || []).length
- && !inId.endsWith(".");
-}
-
-export function getUuid(target) {
- // If it's an actor, get its TokenDocument
- // If it's a token, get its Document
- // If it's a TokenDocument, just use it
- // Otherwise fail
- const document = getDocument(target);
- return document?.uuid ?? false;
-}
-
-export function getDocument(target) {
- if (target instanceof foundry.abstract.Document) return target;
- return target?.document;
-}
-
-export function is_real_number(inNumber) {
- return !isNaN(inNumber)
- && typeof inNumber === "number"
- && isFinite(inNumber);
-}
-
-export function dialogLayout({ title="Item Piles", message, icon = "fas fa-exclamation-triangle", extraHtml = "" }={}){
- return `
-
-
-
${title}
-
${message}
- ${extraHtml}
-
- `;
-}
-
-
-export function getItemPileData(target) {
- let inDocument = getDocument(target);
- if (inDocument instanceof TokenDocument) {
- inDocument = inDocument?.actor;
- }
- try {
- let data = foundry.utils.duplicate(inDocument.getFlag(CONSTANTS.MODULE_NAME, CONSTANTS.PILE_DATA));
- if (!data) return {};
- let defaults = foundry.utils.duplicate(CONSTANTS.PILE_DEFAULTS);
- return foundry.utils.mergeObject(defaults, data);
- } catch (err) {
- return {};
- }
-}
-
-export function getItemPileTokenImage(target, { data = false, items = false, currencies = false } = {}) {
-
- const pileDocument = getDocument(target);
-
- data = data || getItemPileData(pileDocument);
-
- let originalImg;
- if (pileDocument instanceof TokenDocument) {
- originalImg = pileDocument.data.img;
- } else {
- originalImg = pileDocument.data.token.img;
- }
-
- if (!isValidItemPile(pileDocument)) return originalImg;
-
- items = items || getActorItems(pileDocument).map(item => item.toObject());
- currencies = currencies || getActorCurrencies(pileDocument);
-
- const numItems = items.length + currencies.length;
-
- let img;
-
- if (data.displayOne && numItems === 1) {
- img = items.length > 0
- ? items[0].img
- : currencies[0].img;
- } else if (data.displayOne && numItems > 1) {
- img = (pileDocument.actor ?? pileDocument).data.token.img;
- }
-
- if (data.isContainer) {
-
- img = data.lockedImage || data.closedImage || data.openedImage || data.emptyImage;
-
- if (data.locked && data.lockedImage) {
- img = data.lockedImage;
- } else if (data.closed && data.closedImage) {
- img = data.closedImage;
- } else if (data.emptyImage && isItemPileEmpty(pileDocument)) {
- img = data.emptyImage;
- } else if (data.openedImage) {
- img = data.openedImage;
- }
-
- }
-
- return img || originalImg;
-
-}
-
-export function getItemPileTokenScale(target, { data = false, items = false, currencies = false } = {}) {
-
- const pileDocument = getDocument(target);
-
- data = data || getItemPileData(pileDocument);
-
- let baseScale;
- if (pileDocument instanceof TokenDocument) {
- baseScale = pileDocument.data.scale;
- } else {
- baseScale = pileDocument.data.token.scale;
- }
-
- items = items || getActorItems(pileDocument);
- currencies = currencies || getActorCurrencies(pileDocument);
-
- const numItems = items.length + currencies.length;
-
- if (!isValidItemPile(pileDocument, data) || data.isContainer || !data.displayOne || !data.overrideSingleItemScale || numItems > 1 || numItems === 0) return baseScale;
-
- return data.singleItemScale;
-
-}
-
-export function getItemPileName(target, { data = false, items = false, currencies = false } = {}) {
-
- const pileDocument = getDocument(target);
-
- data = data || getItemPileData(pileDocument);
-
- items = items || getActorItems(pileDocument);
- currencies = currencies || getActorCurrencies(pileDocument);
-
- const numItems = items.length + currencies.length;
-
- let name;
- if (pileDocument instanceof TokenDocument) {
- name = pileDocument.data.name;
- } else {
- name = pileDocument.data.token.name;
- }
-
- if (!isValidItemPile(pileDocument, data) || data.isContainer || !data.displayOne || !data.showItemName || numItems > 1 || numItems === 0) return name;
-
- const item = items.length > 0
- ? items[0]
- : currencies[0];
-
- return item.name;
-
-}
-
-
-export function getActorItems(target, itemFilters = false) {
-
- const pileItemFilters = itemFilters || getActorItemFilters(target);
-
- const inDocument = getDocument(target);
- const targetActor = inDocument instanceof TokenDocument
- ? inDocument.actor
- : inDocument;
-
- return Array.from(targetActor.items).filter(item => !isItemInvalid(inDocument, item, pileItemFilters));
-
-}
-
-export function isActiveGM(user) {
- return user.active && user.isGM;
-}
-
-export function getActiveGMs() {
- return game.users.filter(isActiveGM);
-}
-
-export function isResponsibleGM() {
- if (!game.user.isGM) return false;
- return !getActiveGMs().some(other => other.data._id < game.user.data._id);
-}
-
-export function getPlayersForItemPile(target) {
- const inDocument = getDocument(target);
- const pileData = getItemPileData(inDocument);
- if (!isValidItemPile(inDocument)) return [];
- return Array.from(game.users).filter(u => (u.active || !pileData.activePlayers) && u.character);
-}
-
-export function isItemInvalid(target, item, itemFilters = false) {
- const pileItemFilters = itemFilters || getActorItemFilters(target);
- const itemData = item instanceof Item ? item.data : item;
- for (const filter of pileItemFilters) {
- if (!hasProperty(itemData, filter.path)) continue;
- const attributeValue = getProperty(itemData, filter.path);
- if (filter.filters.has(attributeValue)) {
- return attributeValue;
- }
- }
- return false;
-}
-
-export function getActorItemFilters(target) {
- if (!target) return API.ITEM_FILTERS;
- const inDocument = getDocument(target);
- const pileData = getItemPileData(inDocument);
- return isValidItemPile(inDocument) && pileData?.overrideItemFilters
- ? cleanItemFilters(pileData.overrideItemFilters)
- : API.ITEM_FILTERS;
-}
-
-/**
- * Cleans item filters and prepares them for use in above functions
- *
- * @param {Array} itemFilters
- * @returns {Array}
- */
-export function cleanItemFilters(itemFilters) {
- return itemFilters ? foundry.utils.duplicate(itemFilters).map(filter => {
- filter.path = filter.path.trim();
- filter.filters = new Set(filter.filters.split(',').map(string => string.trim()));
- return filter;
- }) : [];
-}
-
-export function isValidItemPile(target, data = false) {
- const inDocument = getDocument(target);
- const documentActor = inDocument instanceof TokenDocument ? inDocument.actor : inDocument;
- return inDocument && !inDocument.destroyed && documentActor && (data || getItemPileData(inDocument))?.enabled;
-}
-
-export function isItemPileEmpty(target) {
-
- const inDocument = getDocument(target);
-
- const targetActor = inDocument instanceof TokenDocument
- ? inDocument.actor
- : inDocument;
-
- if (!targetActor) return false;
-
- const hasNoItems = getActorItems(inDocument).length === 0;
- const hasNoCurrencies = getActorCurrencies(inDocument).length === 0;
-
- return isValidItemPile(targetActor) && hasNoItems && hasNoCurrencies;
-
-}
-
-export function getActorCurrencyList(target) {
- const inDocument = getDocument(target);
- const pileData = getItemPileData(inDocument);
- return pileData.overrideCurrencies || API.CURRENCIES;
-}
-
-export function getActorCurrencies(target, { currencyList = false, getAll = false } = {}) {
- const inDocument = getDocument(target);
- const targetActor = inDocument?.actor ?? inDocument;
- const currencies = currencyList || getActorCurrencyList(targetActor);
- return currencies
- .filter(currency => {
- return hasProperty(targetActor.data, currency.path) && (Number(getProperty(targetActor.data, currency.path)) > 0 || getAll);
- }).map((currency, index) => {
- const localizedName = game.i18n.has(currency.name) ? game.i18n.localize(currency.name) : currency.name;
- const quantity = Number(getProperty(targetActor.data, currency.path) ?? 0);
- return {
- name: localizedName,
- path: currency.path,
- img: currency.img,
- quantity: quantity,
- index: index
- }
- });
-}
-
-function getRelevantTokensAndActor(target) {
-
- const inDocument = getDocument(target);
-
- let documentActor;
- let documentTokens = [];
-
- if (inDocument instanceof Actor) {
- documentActor = inDocument;
- if (inDocument.token) {
- documentToken.push(inDocument?.token);
- } else {
- documentTokens = canvas.tokens.placeables.filter(token => token.document.actor === documentActor).map(token => token.document);
- }
- } else {
- documentActor = inDocument.actor;
- if (inDocument.isLinked) {
- documentTokens = canvas.tokens.placeables.filter(token => token.document.actor === documentActor).map(token => token.document);
- } else {
- documentTokens.push(inDocument);
- }
- }
-
- return [documentActor, documentTokens]
-
-}
-
-export async function updateItemPileData(target, flagData, tokenData) {
-
- if (!tokenData) tokenData = {};
-
- const [documentActor, documentTokens] = getRelevantTokensAndActor(target);
-
- const targetItems = getActorItems(documentActor, flagData.itemFilters);
- const targetCurrencies = getActorCurrencies(documentActor, { currencyList: flagData.currencies });
-
- const data = { data: flagData, items: targetItems, currencies: targetCurrencies };
-
- const updates = documentTokens.map(tokenDocument => {
- const newTokenData = foundry.utils.mergeObject(tokenData, {
- "img": getItemPileTokenImage(tokenDocument, data),
- "scale": getItemPileTokenScale(tokenDocument, data),
- "name": getItemPileName(tokenDocument, data),
- });
- return {
- "_id": tokenDocument.id,
- ...newTokenData,
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: flagData
- }
- });
-
- await canvas.scene.updateEmbeddedDocuments("Token", updates);
-
- return documentActor.update({
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: flagData,
- [`token.flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: flagData
- });
-
-}
-
-
-/* -------------------------- Sharing Methods ------------------------- */
-
-
-export function getItemQuantity(item) {
- const itemData = item instanceof Item ? item.data : item;
- return Number(getProperty(itemData, API.ITEM_QUANTITY_ATTRIBUTE) ?? 0);
-}
-
-
-export function getItemPileSharingData(target) {
- let inDocument = getDocument(target);
- if (inDocument instanceof TokenDocument) {
- inDocument = inDocument?.actor;
- }
- return foundry.utils.duplicate(inDocument.getFlag(CONSTANTS.MODULE_NAME, CONSTANTS.SHARING_DATA) ?? {});
-}
-
-export function updateItemPileSharingData(target, data) {
- let inDocument = getDocument(target);
- if (inDocument instanceof TokenDocument) {
- inDocument = inDocument?.actor;
- }
- const sharingData = foundry.utils.duplicate(inDocument.getFlag(CONSTANTS.MODULE_NAME, CONSTANTS.SHARING_DATA) ?? {});
- const finalData = foundry.utils.mergeObject(sharingData, data);
- return inDocument.setFlag(CONSTANTS.MODULE_NAME, CONSTANTS.SHARING_DATA, finalData);
-}
-
-export function clearItemPileSharingData(target) {
- let inDocument = getDocument(target);
- if (inDocument instanceof TokenDocument) {
- inDocument = inDocument?.actor;
- }
- return inDocument.unsetFlag(CONSTANTS.MODULE_NAME, CONSTANTS.SHARING_DATA);
-}
-
-export async function setItemPileSharingData(sourceUuid, targetUuid, { items = [], currencies = [] } = {}) {
-
- const source = await fromUuid(sourceUuid);
- const target = await fromUuid(targetUuid);
-
- const sourceActor = source?.actor ?? source;
- const targetActor = target?.actor ?? target;
-
- const sourceIsItemPile = isValidItemPile(sourceActor);
- const targetIsItemPile = isValidItemPile(targetActor);
-
- if (sourceIsItemPile && targetIsItemPile) return;
-
- if (items.length) {
- items = items.map(itemData => {
- setProperty(itemData.item, API.ITEM_QUANTITY_ATTRIBUTE, itemData.quantity);
- return itemData.item;
- })
- }
-
- if (!Array.isArray(currencies) && typeof currencies === "object") {
- currencies = Object.entries(currencies).map(entry => {
- return {
- path: entry[0],
- quantity: entry[1]
- }
- })
- }
-
- if (sourceIsItemPile) {
-
- if (isItemPileEmpty(sourceIsItemPile)) {
- return clearItemPileSharingData(sourceIsItemPile);
- }
-
- const sharingData = addToItemPileSharingData(sourceActor, targetActor.uuid, { items, currencies });
-
- return updateItemPileSharingData(sourceActor, sharingData);
-
- }
-
- const sharingData = removeFromItemPileSharingData(targetActor, sourceActor.uuid, { items, currencies });
-
- return updateItemPileSharingData(targetActor, sharingData);
-
-}
-
-export function addToItemPileSharingData(itemPile, actorUuid, {
- sharingData = false,
- items = [],
- currencies = []
-} = {}) {
-
- const pileData = getItemPileData(itemPile);
-
- let pileSharingData = {};
- if (!sharingData && ((pileData.shareItemsEnabled && items.length) || (pileData.shareCurrenciesEnabled && currencies.length))) {
- pileSharingData = getItemPileSharingData(itemPile);
- }
-
- if (pileData.shareItemsEnabled && items.length) {
-
- if (!pileSharingData.items) {
- pileSharingData.items = [];
- }
-
- for (const item of items) {
-
- let existingItem = findSimilarItem(pileSharingData.items, item);
-
- if (!existingItem) {
- let itemIndex = pileSharingData.items.push({
- name: item.name,
- type: item.type,
- img: item.img,
- actors: [{ uuid: actorUuid, quantity: 0 }]
- })
- existingItem = pileSharingData.items[itemIndex - 1];
- } else if (!existingItem.actors) {
- existingItem.actors = [];
- }
-
- let actorData = existingItem.actors.find(data => data.uuid === actorUuid);
-
- const itemQuantity = getItemQuantity(item);
- if (!actorData) {
- if (itemQuantity > 0) {
- existingItem.actors.push({ uuid: actorUuid, quantity: itemQuantity })
- }
- } else {
- actorData.quantity += itemQuantity;
- if (actorData.quantity <= 0) {
- existingItem.actors.splice(existingItem.actors.indexOf(actorData), 1);
- }
- if (existingItem.actors.length === 0) {
- pileSharingData.items.splice(pileSharingData.items.indexOf(existingItem), 1)
- }
- }
-
- }
-
- }
-
- if (pileData.shareCurrenciesEnabled && currencies.length) {
-
- if (!pileSharingData.currencies) {
- pileSharingData.currencies = [];
- }
-
- for (const currency of currencies) {
-
- let existingCurrency = pileSharingData.currencies.find(sharingCurrency => sharingCurrency.path === currency.path);
-
- if (!existingCurrency) {
- let itemIndex = pileSharingData.currencies.push({
- path: currency.path,
- actors: [{ uuid: actorUuid, quantity: 0 }]
- })
- existingCurrency = pileSharingData.currencies[itemIndex - 1];
- } else {
- if (!existingCurrency.actors) {
- existingCurrency.actors = [];
- }
- }
-
- let actorData = existingCurrency.actors.find(data => data.uuid === actorUuid);
-
- if (!actorData) {
- if (currency.quantity > 0) {
- existingCurrency.actors.push({ uuid: actorUuid, quantity: currency.quantity })
- }
- } else {
- actorData.quantity += currency.quantity;
- if (actorData.quantity <= 0) {
- existingCurrency.actors.splice(existingCurrency.actors.indexOf(actorData), 1);
- }
- if (existingCurrency.actors.length === 0) {
- pileSharingData.currencies.splice(pileSharingData.currencies.indexOf(existingCurrency), 1)
- }
- }
-
- }
-
- }
-
- return pileSharingData;
-
-}
-
-export function removeFromItemPileSharingData(itemPile, actorUuid, { items = [], currencies = [] } = {}) {
-
- items = items.map(item => {
- setProperty(item, API.ITEM_QUANTITY_ATTRIBUTE, getItemQuantity(item) * -1)
- return item;
- });
-
- currencies = currencies.map(currency => {
- currency.quantity = currency.quantity * -1;
- return currency;
- });
-
- return addToItemPileSharingData(itemPile, actorUuid, { items, currencies });
-
-}
-
-export function getItemPileItemsForActor(pile, recipient, floor = false) {
-
- const pileData = getItemPileData(pile);
- const pileItems = getActorItems(pile);
-
- const players = getPlayersForItemPile(pile);
- const pileSharingData = getItemPileSharingData(pile);
- const storedItems = pileSharingData.items ?? [];
-
- const recipientUuid = getUuid(recipient);
-
- return pileItems.map(item => {
-
- const quantity = getItemQuantity(item);
- let data = {
- id: item.id,
- name: item.name,
- type: item.type,
- img: item.data?.img ?? "",
- currentQuantity: 1,
- quantity: quantity,
- shareLeft: quantity,
- previouslyTaken: 0,
- toShare: pileData.shareItemsEnabled && recipientUuid
- };
-
- if (data.toShare) {
-
- const foundItem = findSimilarItem(storedItems, item);
-
- let totalShares = quantity;
- if (foundItem) {
- totalShares += foundItem.actors.reduce((acc, actor) => {
- return acc + actor.quantity;
- }, 0);
- }
-
- let totalActorShare = totalShares / players.length;
- if (!Number.isInteger(totalActorShare) && !floor) {
- totalActorShare += 1;
- }
-
- const takenBefore = foundItem?.actors?.find(actor => actor.uuid === recipientUuid);
- data.previouslyTaken = takenBefore ? takenBefore.quantity : 0;
-
- data.shareLeft = Math.max(0, Math.min(quantity, Math.floor(totalActorShare - data.previouslyTaken)));
-
- }
-
- return data;
-
- });
-
-}
-
-export function getItemPileCurrenciesForActor(pile, recipient, floor) {
-
- const pileData = getItemPileData(pile);
- const pileCurrencies = getActorCurrencies(pile, { getAll: !recipient });
-
- const players = getPlayersForItemPile(pile);
- const pileSharingData = getItemPileSharingData(pile);
- const storedCurrencies = pileSharingData.currencies ?? [];
-
- const recipientUuid = getUuid(recipient);
-
- return pileCurrencies.filter(currency => {
- return !recipient || hasProperty(recipient?.data ?? {}, currency.path);
- }).map((currency, index) => {
-
- currency.currentQuantity = 1;
- currency.shareLeft = currency.quantity;
- currency.toShare = pileData.shareCurrenciesEnabled && !!recipientUuid;
- currency.previouslyTaken = 0;
- currency.index = index;
-
- if (currency.toShare) {
-
- const foundCurrency = storedCurrencies.find(storedCurrency => storedCurrency.path === currency.path);
-
- let totalShares = currency.quantity;
- if (foundCurrency) {
- totalShares += foundCurrency.actors.reduce((acc, actor) => acc + actor.quantity, 0);
- }
-
- let totalActorShare = totalShares / players.length;
- if (!Number.isInteger(totalActorShare) && !floor) {
- totalActorShare += 1;
- }
-
- const takenBefore = foundCurrency?.actors?.find(actor => actor.uuid === recipientUuid);
- currency.previouslyTaken = takenBefore ? takenBefore.quantity : 0;
-
- currency.shareLeft = Math.max(0, Math.min(currency.quantity, Math.floor(totalActorShare - currency.previouslyTaken)));
-
- }
-
- return currency;
-
- });
-
-}
diff --git a/scripts/libwrapper.js b/scripts/libwrapper.js
deleted file mode 100644
index 83aa362c..00000000
--- a/scripts/libwrapper.js
+++ /dev/null
@@ -1,33 +0,0 @@
-import API from "./api.js";
-import CONSTANTS from "./constants.js";
-import { hotkeyActionState } from "./hotkeys.js";
-import * as lib from "./lib/lib.js";
-import { ItemPileInventory } from "./formapplications/item-pile-inventory.js";
-
-export function registerLibwrappers() {
-
- libWrapper.register(CONSTANTS.MODULE_NAME, 'Token.prototype._onClickLeft2', function (wrapped, ...args) {
- if (API.isValidItemPile(this.document) && hotkeyActionState.openPileInventory) {
- return API._itemPileClicked(this.document);
- }
- return wrapped(...args);
- });
-
- const actorSidebarMethodName = lib.isVersion9() ? "_onClickDocumentName" : "_onClickEntityName";
-
- libWrapper.register(CONSTANTS.MODULE_NAME, `SidebarDirectory.prototype.${actorSidebarMethodName}`, function (wrapped, event) {
-
- event.preventDefault();
- const element = event.currentTarget;
- const documentId = element.parentElement.dataset.documentId;
- const document = this.constructor.collection.get(documentId);
-
- if (API.isValidItemPile(document) && hotkeyActionState.openPileInventory) {
- return ItemPileInventory.show(document, game.user.character);
- }
-
- return wrapped(event);
-
- });
-
-}
diff --git a/scripts/module.js b/scripts/module.js
deleted file mode 100644
index 3db9712b..00000000
--- a/scripts/module.js
+++ /dev/null
@@ -1,282 +0,0 @@
-import CONSTANTS from "./constants.js";
-import HOOKS from "./hooks.js";
-
-import flagManager from "./flagManager.js";
-import chatHandler from "./chathandler.js";
-import API from "./api.js";
-import * as lib from "./lib/lib.js";
-import { getActorCurrencies, getActorItems } from "./lib/lib.js";
-
-import { ItemPileConfig } from "./formapplications/item-pile-config.js";
-import { checkSystem, migrateSettings, registerHandlebarHelpers, registerSettings } from "./settings.js";
-import { registerSocket } from "./socket.js";
-import { registerLibwrappers } from "./libwrapper.js";
-import { registerHotkeysPost, registerHotkeysPre } from "./hotkeys.js";
-import { TradeAPI } from "./trade-api.js";
-
-Hooks.once("init", async () => {
-
- registerSettings();
- registerLibwrappers();
- registerHotkeysPre();
-
- Hooks.once("socketlib.ready", registerSocket);
- Hooks.on("canvasReady", module._canvasReady);
- Hooks.on("preCreateToken", module._preCreatePile);
- Hooks.on("createToken", module._createPile);
- Hooks.on("deleteToken", module._deletePile);
- Hooks.on("dropCanvasData", module._dropData);
- Hooks.on("updateActor", module._pileCurrencyChanged);
- Hooks.on("createItem", module._pileInventoryChanged);
- Hooks.on("updateItem", module._pileInventoryChanged);
- Hooks.on("deleteItem", module._pileInventoryChanged);
- Hooks.on("getActorSheetHeaderButtons", module._insertItemPileHeaderButtons);
- Hooks.on("getActorDirectoryEntryContext", module._handleActorContextMenu);
- Hooks.on("renderTokenHUD", module._renderPileHUD);
-
- chatHandler.init();
-
- if (game.settings.get(CONSTANTS.MODULE_NAME, "enableTrading") && game.settings.get(CONSTANTS.MODULE_NAME, "showTradeButton")) {
- Hooks.on("renderPlayerList", (app, html) => {
- const minimalUI = game.modules.get('minimal-ui')?.active;
- const classes = "item-piles-player-list-trade-button" + (minimalUI ? " item-piles-minimal-ui" : "")
- const text = !minimalUI ? " Request Trade" : ""
- const button = $(` ${text} `)
- button.click(() => {
- TradeAPI.requestTrade();
- });
- html.append(button);
- })
- }
-
- if (game.settings.get(CONSTANTS.MODULE_NAME, "debugHooks")) {
- for (let hook of Object.values(HOOKS)) {
- if (typeof hook === "string") {
- Hooks.on(hook, (...args) => lib.debug(`Hook called: ${hook}`, ...args));
- lib.debug(`Registered hook: ${hook}`)
- } else {
- for (let innerHook of Object.values(hook)) {
- Hooks.on(innerHook, (...args) => lib.debug(`Hook called: ${innerHook}`, ...args));
- lib.debug(`Registered hook: ${innerHook}`)
- }
- }
- }
- }
-
- window.ItemPiles = {
- API
- }
-
-});
-
-Hooks.once("ready", async () => {
-
- if (!game.modules.get('lib-wrapper')?.active && game.user.isGM) {
- let word = "install and activate";
- if (game.modules.get('lib-wrapper')) word = "activate";
- throw lib.custom_error(`Item Piles requires the 'libWrapper' module. Please ${word} it.`)
- }
- if (!game.modules.get('socketlib')?.active && game.user.isGM) {
- let word = "install and activate";
- if (game.modules.get('socketlib')) word = "activate";
- throw lib.custom_error(`Item Piles requires the 'socketlib' module. Please ${word} it.`)
- }
-
- if (!lib.isGMConnected()) {
- lib.custom_warning(`Item Piles requires a GM to be connected for players to be able to loot item piles.`, true)
- }
-
- await flagManager.migrateDocuments();
-
- checkSystem();
- registerHotkeysPost();
- registerHandlebarHelpers();
- migrateSettings();
- Hooks.callAll(HOOKS.READY);
-
-});
-
-const debounceManager = {
-
- debounces: {},
-
- setDebounce(id, method) {
- if (this.debounces[id]) {
- return this.debounces[id];
- }
- this.debounces[id] = debounce(function (...args) {
- delete debounceManager.debounces[id];
- return method(...args);
- }, 50);
- return this.debounces[id];
- }
-};
-
-const module = {
-
- async _pileCurrencyChanged(actor, changes) {
- const target = actor?.token ?? actor;
- if (!lib.isValidItemPile(target)) return;
- const sourceCurrencies = lib.getActorCurrencyList(target);
- const validCurrency = sourceCurrencies.find(currency => {
- return hasProperty(changes, currency.path);
- });
- if (!validCurrency) return;
- const targetUuid = target.uuid;
- return debounceManager.setDebounce(targetUuid, async function (uuid) {
- const deleted = await API._checkItemPileShouldBeDeleted(uuid);
- await API._rerenderItemPileInventoryApplication(uuid, deleted);
- if (deleted || !lib.isResponsibleGM()) return;
- return API._refreshItemPile(uuid);
- })(targetUuid);
- },
-
- async _pileInventoryChanged(item) {
- let target = item?.parent;
- if (!target) return;
- target = target?.token ?? target;
- if (!lib.isValidItemPile(target)) return;
- const targetUuid = target.uuid;
- return debounceManager.setDebounce(targetUuid, async function (uuid) {
- const deleted = await API._checkItemPileShouldBeDeleted(uuid);
- await API._rerenderItemPileInventoryApplication(uuid, deleted);
- if (deleted || !lib.isResponsibleGM()) return;
- return API._refreshItemPile(uuid);
- })(targetUuid);
- },
-
- async _canvasReady(canvas) {
- const tokens = [...canvas.tokens.placeables].map(token => token.document);
- for (const doc of tokens) {
- await API._initializeItemPile(doc);
- }
- },
-
- async _preCreatePile(document) {
- if (!document.isLinked) {
- document.data.update({
- [`actorData.flags.${CONSTANTS.MODULE_NAME}.-=${CONSTANTS.SHARING_DATA}`]: null
- });
- }
- },
-
- async _createPile(tokenDoc) {
- if (!lib.isResponsibleGM()) return;
- if (!lib.isValidItemPile(tokenDoc)) return;
- setTimeout(async () => {
- const itemPileConfig = lib.getItemPileData(tokenDoc.actor)
- Hooks.callAll(HOOKS.PILE.CREATE, tokenDoc, itemPileConfig);
-
- const targetItems = getActorItems(tokenDoc.actor);
- const targetCurrencies = getActorCurrencies(tokenDoc.actor);
- const data = { data: itemPileConfig, items: targetItems, currencies: targetCurrencies };
-
- await tokenDoc.update({
- "img": lib.getItemPileTokenImage(tokenDoc, data),
- "scale": lib.getItemPileTokenScale(tokenDoc, data),
- "name": lib.getItemPileName(tokenDoc, data),
- [`flags.${CONSTANTS.MODULE_NAME}.${CONSTANTS.PILE_DATA}`]: itemPileConfig
- });
- await API._initializeItemPile(tokenDoc);
- }, 50)
- },
-
- async _deletePile(doc) {
- if (!lib.isValidItemPile(doc)) return;
- Hooks.callAll(HOOKS.PILE.DELETE, doc);
- return API._rerenderItemPileInventoryApplication(doc.uuid, true);
- },
-
- _renderPileHUD(app, html) {
-
- const document = app?.object?.document;
-
- if (!document) return;
-
- if (!lib.isValidItemPile(document)) return;
-
- const pileData = lib.getItemPileData(document);
-
- const container = $(`
`);
-
- if (pileData.isContainer) {
-
- const lock_button = $(`
`);
- lock_button.click(async function () {
- $(this).find('.fas').toggleClass('fa-lock').toggleClass('fa-lock-open');
- await API.toggleItemPileLocked(document);
- });
- container.append(lock_button);
-
- const open_button = $(`
`);
- open_button.click(async function () {
- $(this).find('.fas').toggleClass('fa-box').toggleClass('fa-box-open');
- await API.toggleItemPileClosed(document);
- });
- container.append(open_button);
- }
-
- const configure_button = $(`
`);
- configure_button.click(async function () {
- ItemPileConfig.show(document);
- });
- container.append(configure_button);
-
- html.append(container)
-
- },
-
- _insertItemPileHeaderButtons(actorSheet, buttons) {
-
- if (!game.user.isGM) return;
-
- let obj = actorSheet.object;
-
- buttons.unshift({
- label: game.settings.get(CONSTANTS.MODULE_NAME, "hideActorHeaderText") ? "" : "ITEM-PILES.Defaults.Configure",
- icon: "fas fa-box-open",
- class: "item-piles-config-button",
- onclick: () => {
- ItemPileConfig.show(obj);
- }
- })
- },
-
- async _dropData(canvas, data) {
- return API._dropData(canvas, data);
- },
-
- _handleActorContextMenu(html, menuItems) {
-
- menuItems.push({
- name: "ITEM-PILES.ContextMenu.ShowToPlayers",
- icon: ` `,
- callback: (html) => {
- const actorId = html[0].dataset.documentId;
- const actor = game.actors.get(actorId);
- const users = Array.from(game.users).filter(u => u.active).map(u => u.id);
- return API.openItemPileInventory(actor, users, { useDefaultCharacter: true });
- },
- condition: (html) => {
- const actorId = html[0].dataset.documentId;
- const actor = game.actors.get(actorId);
- return game.user.isGM && API.isValidItemPile(actor);
- }
- }, {
- name: "ITEM-PILES.ContextMenu.RequestTrade",
- icon: ` `,
- callback: (html) => {
- const actorId = html[0].dataset.documentId;
- const actor = game.actors.get(actorId);
- const user = Array.from(game.users).find(u => u.character === actor && u.active);
- return TradeAPI.requestTrade(user);
- },
- condition: (html) => {
- const actorId = html[0].dataset.documentId;
- const actor = game.actors.get(actorId);
- return game.settings.get(CONSTANTS.MODULE_NAME, "enableTrading")
- && (game.user?.character !== actor || Array.from(game.users).find(u => u.character === actor && u.active));
- }
- });
- }
-}
\ No newline at end of file
diff --git a/scripts/settings.js b/scripts/settings.js
deleted file mode 100644
index c1171863..00000000
--- a/scripts/settings.js
+++ /dev/null
@@ -1,366 +0,0 @@
-import CONSTANTS from "./constants.js";
-import { ItemPileCurrenciesEditor } from "./formapplications/item-pile-currencies-editor.js";
-import { SYSTEMS } from "./systems.js";
-import * as lib from "./lib/lib.js";
-import { ItemPileFiltersEditor } from "./formapplications/item-pile-filters-editor.js";
-import flagManager from "./flagManager.js";
-import { ItemPileSimilaritiesEditor } from "./formapplications/item-pile-similarities-editor.js";
-
-const debounceReload = foundry.utils.debounce(() => {
- window.location.reload();
-}, 100);
-
-function defaultSettings(apply = false) {
- return {
- "currencies": {
- scope: "world",
- config: false,
- default: apply && SYSTEMS.DATA ? SYSTEMS.DATA.CURRENCIES : [],
- type: Array
- },
- "itemFilters": {
- scope: "world",
- config: false,
- default: apply && SYSTEMS.DATA ? SYSTEMS.DATA.ITEM_FILTERS : [],
- type: Array
- },
- "actorClassType": {
- name: "ITEM-PILES.Setting.ActorClass.Title",
- hint: "ITEM-PILES.Setting.ActorClass.Label",
- scope: "world",
- config: true,
- default: apply && SYSTEMS.DATA ? SYSTEMS.DATA.ACTOR_CLASS_TYPE : game.system.template.Actor.types[0],
- type: String
- },
- "itemQuantityAttribute": {
- name: "ITEM-PILES.Setting.Quantity.Title",
- hint: "ITEM-PILES.Setting.Quantity.Label",
- scope: "world",
- config: true,
- default: apply && SYSTEMS.DATA ? SYSTEMS.DATA.ITEM_QUANTITY_ATTRIBUTE : "",
- type: String
- },
- "itemSimilarities": {
- name: "ITEM-PILES.Setting.ItemSimilarities.Title",
- hint: "ITEM-PILES.Setting.ItemSimilarities.Label",
- scope: "world",
- config: false,
- default: apply && SYSTEMS.DATA ? SYSTEMS.DATA.ITEM_SIMILARITIES : ['name', 'type'],
- type: Array
- }
- }
-}
-
-const otherSettings = {
-
- "outputToChat": {
- name: "ITEM-PILES.Setting.OutputToChat.Title",
- hint: "ITEM-PILES.Setting.OutputToChat.Label",
- scope: "world",
- config: true,
- default: 1,
- choices: [
- "ITEM-PILES.Setting.OutputToChat.Off",
- "ITEM-PILES.Setting.OutputToChat.Public",
- "ITEM-PILES.Setting.OutputToChat.SelfGM",
- "ITEM-PILES.Setting.OutputToChat.Blind",
- ],
- type: Number
- },
-
- "deleteEmptyPiles": {
- name: "ITEM-PILES.Setting.DeleteEmptyPiles.Title",
- hint: "ITEM-PILES.Setting.DeleteEmptyPiles.Label",
- scope: "world",
- config: true,
- default: false,
- type: Boolean
- },
-
- "enableTrading": {
- name: "ITEM-PILES.Setting.EnableTrading.Title",
- hint: "ITEM-PILES.Setting.EnableTrading.Hint",
- scope: "world",
- config: true,
- default: true,
- type: Boolean,
- onChange: debounceReload
- },
-
- "showTradeButton": {
- name: "ITEM-PILES.Setting.ShowTradeButton.Title",
- hint: "ITEM-PILES.Setting.ShowTradeButton.Hint",
- scope: "world",
- config: true,
- default: true,
- type: Boolean,
- onChange: debounceReload
- },
-
- "invertSheetOpen": {
- name: "ITEM-PILES.Setting.InvertSheetOpen.Title",
- hint: "ITEM-PILES.Setting.InvertSheetOpen.Label",
- scope: "client",
- config: true,
- default: false,
- type: Boolean
- },
-
- "hideActorHeaderText": {
- name: "ITEM-PILES.Setting.HideActorHeaderText.Title",
- hint: "ITEM-PILES.Setting.HideActorHeaderText.Label",
- scope: "client",
- config: true,
- default: false,
- type: Boolean,
- onChange: debounceReload
- },
-
- "preloadFiles": {
- name: "ITEM-PILES.Setting.PreloadFiles.Title",
- hint: "ITEM-PILES.Setting.PreloadFiles.Label",
- scope: "client",
- config: true,
- default: true,
- type: Boolean
- },
-
- "defaultItemPileActorID": {
- scope: "world",
- config: false,
- default: "",
- type: String
- },
-
- "debug": {
- name: "ITEM-PILES.Setting.Debug.Title",
- hint: "ITEM-PILES.Setting.Debug.Label",
- scope: "client",
- config: true,
- default: false,
- type: Boolean
- },
-
- "debugHooks": {
- scope: "world",
- config: false,
- default: false,
- type: Boolean
- },
-
- "systemFound": {
- scope: "world",
- config: false,
- default: false,
- type: Boolean
- },
-
- "systemNotFoundWarningShown": {
- scope: "world",
- config: false,
- default: false,
- type: Boolean
- },
-
- "preconfiguredSystem": {
- scope: "world",
- config: false,
- default: false,
- type: Boolean
- }
-}
-
-export function registerSettings() {
-
- game.settings.registerMenu(CONSTANTS.MODULE_NAME, "resetAllSettings", {
- name: "ITEM-PILES.Setting.Reset.Title",
- label: "ITEM-PILES.Setting.Reset.Label",
- hint: "ITEM-PILES.Setting.Reset.Hint",
- icon: "fas fa-coins",
- type: ResetSettingsDialog,
- restricted: true
- });
-
- game.settings.registerMenu(CONSTANTS.MODULE_NAME, "openCurrenciesEditor", {
- name: "ITEM-PILES.Setting.Currencies.Title",
- label: "ITEM-PILES.Setting.Currencies.Label",
- hint: "ITEM-PILES.Setting.Currencies.Hint",
- icon: "fas fa-coins",
- type: ItemPileCurrenciesEditor,
- restricted: true
- });
-
- game.settings.registerMenu(CONSTANTS.MODULE_NAME, "openItemFiltersEditor", {
- name: "ITEM-PILES.Setting.ItemFilters.Title",
- label: "ITEM-PILES.Setting.ItemFilters.Label",
- hint: "ITEM-PILES.Setting.ItemFilters.Hint",
- icon: "fas fa-list-ul",
- type: ItemPileFiltersEditor,
- restricted: true
- });
-
- game.settings.registerMenu(CONSTANTS.MODULE_NAME, "openItemSimilaritiesEditor", {
- name: "ITEM-PILES.Setting.ItemSimilarities.Title",
- label: "ITEM-PILES.Setting.ItemSimilarities.Label",
- hint: "ITEM-PILES.Setting.ItemSimilarities.Hint",
- icon: "fas fa-list-ul",
- type: ItemPileSimilaritiesEditor,
- restricted: true
- });
-
- const settings = defaultSettings();
- for (const [name, data] of Object.entries(settings)) {
- game.settings.register(CONSTANTS.MODULE_NAME, name, data);
- }
-
- for (const [name, data] of Object.entries(otherSettings)) {
- game.settings.register(CONSTANTS.MODULE_NAME, name, data);
- }
-
- const hasFlagMigrationVersion = !!game.settings.storage.get("world").getSetting(`${CONSTANTS.MODULE_NAME}.migrationVersion`);
-
- game.settings.register(CONSTANTS.MODULE_NAME, "migrationVersion", {
- scope: "world",
- config: false,
- default: !hasFlagMigrationVersion ? flagManager.latestFlagVersion : "",
- type: String
- });
-
-}
-
-export async function migrateSettings() {
-
- const itemTypeAttribute = game.settings.storage.get("world").getSetting(`${CONSTANTS.MODULE_NAME}.itemTypeAttribute`);
- const itemTypeFilters = game.settings.storage.get("world").getSetting(`${CONSTANTS.MODULE_NAME}.itemTypeFilters`);
-
- if (itemTypeAttribute && itemTypeFilters) {
-
- const itemTypeAttributeValue = JSON.parse(itemTypeAttribute.data.value)
- const itemTypeFiltersValue = JSON.parse(itemTypeFilters.data.value)
-
- game.settings.set(CONSTANTS.MODULE_NAME, "itemFilters", [
- {
- "path": itemTypeAttributeValue,
- "filters": itemTypeFiltersValue
- }
- ])
-
- await itemTypeAttribute.delete();
- await itemTypeFilters.delete();
-
- }
-
- const dynamicAttributesSetting = game.settings.storage.get("world").getSetting(`${CONSTANTS.MODULE_NAME}.dynamicAttributes`);
-
- if (dynamicAttributesSetting) {
-
- const dynamicAttributesValue = JSON.parse(dynamicAttributesSetting.data.value)
-
- game.settings.set(CONSTANTS.MODULE_NAME, "currencies", dynamicAttributesValue)
-
- await dynamicAttributesSetting.delete();
-
- }
-
-}
-
-class ResetSettingsDialog extends FormApplication {
- constructor(...args) {
- super(...args);
- return new Dialog({
- title: game.i18n.localize("ITEM-PILES.Dialogs.ResetSettings.Title"),
- content: `${game.i18n.localize("ITEM-PILES.Dialogs.ResetSettings.Content")}
`,
- buttons: {
- confirm: {
- icon: ' ',
- label: game.i18n.localize("ITEM-PILES.Dialogs.ResetSettings.Confirm"),
- callback: async () => {
- await applyDefaultSettings();
- window.location.reload();
- }
- },
- cancel: {
- icon: ' ',
- label: game.i18n.localize("ITEM-PILES.Dialogs.Cancel")
- }
- },
- default: "cancel"
- })
- }
-}
-
-async function applyDefaultSettings() {
- const settings = defaultSettings(true);
- for (const [name, data] of Object.entries(settings)) {
- await game.settings.set(CONSTANTS.MODULE_NAME, name, data.default);
- }
-}
-
-export async function checkSystem() {
-
- await lib.wait(1000);
-
- if(game.settings.get(CONSTANTS.MODULE_NAME, "preconfiguredSystem")) return;
-
- if (!SYSTEMS.DATA) {
-
- if (game.settings.get(CONSTANTS.MODULE_NAME, "systemNotFoundWarningShown")) return;
-
- let settingsValid = true;
- for (const [name, data] of Object.entries(defaultSettings())) {
- settingsValid = settingsValid && game.settings.get(CONSTANTS.MODULE_NAME, name).length !== (new data.type).length
- }
-
- if(settingsValid) return;
-
- await game.settings.set(CONSTANTS.MODULE_NAME, "systemNotFoundWarningShown", true);
-
- return Dialog.prompt({
- title: game.i18n.localize("ITEM-PILES.Dialogs.NoSystemFound.Title"),
- content: lib.dialogLayout({ message: game.i18n.localize("ITEM-PILES.Dialogs.NoSystemFound.Content") }),
- callback: () => {
- }
- });
-
- }
-
- if (game.settings.get(CONSTANTS.MODULE_NAME, "systemFound")) return;
-
- game.settings.set(CONSTANTS.MODULE_NAME, "systemFound", true);
-
- if (game.settings.get(CONSTANTS.MODULE_NAME, "systemNotFoundWarningShown")) {
-
- return new Dialog({
- title: game.i18n.localize("ITEM-PILES.Dialogs.SystemFound.Title"),
- content: lib.dialogLayout({
- message: game.i18n.localize("ITEM-PILES.Dialogs.SystemFound.Content"),
- icon: "fas fa-search"
- }),
- buttons: {
- confirm: {
- icon: ' ',
- label: game.i18n.localize("ITEM-PILES.Dialogs.SystemFound.Confirm"),
- callback: () => {
- applyDefaultSettings();
- }
- },
- cancel: {
- icon: ' ',
- label: game.i18n.localize("No")
- }
- },
- default: "cancel"
- }).render(true);
-
- }
-
- return applyDefaultSettings();
-}
-
-export function registerHandlebarHelpers() {
-
- Handlebars.registerHelper('concat', function (...args) {
- return args.filter(str => typeof str !== "object").join("");
- });
-
-}
\ No newline at end of file
diff --git a/scripts/socket.js b/scripts/socket.js
deleted file mode 100644
index 0c8fa971..00000000
--- a/scripts/socket.js
+++ /dev/null
@@ -1,212 +0,0 @@
-import * as lib from "./lib/lib.js";
-import CONSTANTS from "./constants.js";
-import API from "./api.js";
-import { ItemPileInventory } from "./formapplications/item-pile-inventory.js";
-import chatHandler from "./chathandler.js";
-import { TradeAPI } from "./trade-api.js";
-import { TradingApp } from "./formapplications/trading-app.js";
-
-export const SOCKET_HANDLERS = {
- /**
- * Generic sockets
- */
- CALL_HOOK: "callHook",
-
- /**
- * Chat messages
- */
- PICKUP_CHAT_MESSAGE: "pickupChatMessage",
- SPLIT_CHAT_MESSAGE: "splitChatMessage",
- DISABLE_CHAT_TRADE_BUTTON: "disableChatTradeButton",
-
- /**
- * Item pile sockets
- */
- CREATE_PILE: "createItemPile",
- UPDATE_PILE: "updateItemPile",
- UPDATED_PILE: "updatedPile",
- DELETE_PILE: "deleteItemPile",
- TURN_INTO_PILE: "turnIntoPiles",
- REVERT_FROM_PILE: "revertFromPiles",
- REFRESH_PILE: "refreshItemPile",
- SPLIT_PILE: "splitItemPileContent",
-
- /**
- * UI sockets
- */
- RENDER_INTERFACE: "renderItemPileInterface",
- RERENDER_TOKEN_HUD: "rerenderTokenHud",
- RERENDER_PILE_INVENTORY: "rerenderItemPileInventory",
- QUERY_PILE_INVENTORY_OPEN: "queryItemPileInventoryOpen",
- RESPOND_PILE_INVENTORY_OPEN: "responseItemPileInventoryOpen",
-
- /**
- * Item & attribute sockets
- */
- DROP_ITEMS: "dropItems",
- ADD_ITEMS: "addItems",
- REMOVE_ITEMS: "removeItems",
- TRANSFER_ITEMS: "transferItems",
- TRANSFER_ALL_ITEMS: "transferAllItems",
- ADD_ATTRIBUTE: "addAttributes",
- REMOVE_ATTRIBUTES: "removeAttributes",
- TRANSFER_ATTRIBUTES: "transferAttributes",
- TRANSFER_ALL_ATTRIBUTES: "transferAllAttributes",
- TRANSFER_EVERYTHING: "transferEverything",
-
- /**
- * Trading sockets
- */
- TRADE_REQUEST_PROMPT: "tradePrompt",
- TRADE_REQUEST_CANCELLED: "tradeCancelled",
- TRADE_SPECTATE: "tradeSpectate",
- TRADE_CLOSED: "publicTradeClosed",
- PUBLIC: {
- TRADE_UPDATE_ITEMS: "publicTradeUpdateItems",
- TRADE_UPDATE_CURRENCIES: "publicTradeUpdateCurrencies",
- TRADE_STATE: "publicTradeAcceptedState",
- },
- PRIVATE: {
- TRADE_UPDATE_ITEMS: "privateTradeUpdateItems",
- TRADE_UPDATE_CURRENCIES: "privateTradeUpdateCurrencies",
- TRADE_STATE: "privateTradeAcceptedState",
- },
- TRADE_COMPLETED: "tradeCompleted",
-};
-
-export let itemPileSocket;
-
-export function registerSocket() {
- lib.debug("Registered itemPileSocket");
- itemPileSocket = socketlib.registerModule(CONSTANTS.MODULE_NAME);
-
- /**
- * Generic socket
- */
- itemPileSocket.register(SOCKET_HANDLERS.CALL_HOOK, (hook, ...args) => callHook(hook, ...args))
-
- /**
- * Chat sockets
- */
- itemPileSocket.register(SOCKET_HANDLERS.PICKUP_CHAT_MESSAGE, (...args) => chatHandler._outputPickupToChat(...args))
- itemPileSocket.register(SOCKET_HANDLERS.SPLIT_CHAT_MESSAGE, (...args) => chatHandler._outputSplitToChat(...args))
-
- /**
- * Item pile sockets
- */
- itemPileSocket.register(SOCKET_HANDLERS.CREATE_PILE, (...args) => API._createItemPile(...args))
- itemPileSocket.register(SOCKET_HANDLERS.UPDATE_PILE, (...args) => API._updateItemPile(...args))
- itemPileSocket.register(SOCKET_HANDLERS.UPDATED_PILE, (...args) => API._updatedItemPile(...args))
- itemPileSocket.register(SOCKET_HANDLERS.DELETE_PILE, (...args) => API._deleteItemPile(...args))
- itemPileSocket.register(SOCKET_HANDLERS.TURN_INTO_PILE, (...args) => API._turnTokensIntoItemPiles(...args))
- itemPileSocket.register(SOCKET_HANDLERS.REVERT_FROM_PILE, (...args) => API._revertTokensFromItemPiles(...args))
- itemPileSocket.register(SOCKET_HANDLERS.REFRESH_PILE, (...args) => API._refreshItemPile(...args))
- itemPileSocket.register(SOCKET_HANDLERS.SPLIT_PILE, (...args) => API._splitItemPileContents(...args))
-
- /**
- * UI sockets
- */
- itemPileSocket.register(SOCKET_HANDLERS.RENDER_INTERFACE, (...args) => API._renderItemPileInterface(...args))
- itemPileSocket.register(SOCKET_HANDLERS.RERENDER_TOKEN_HUD, (...args) => API._rerenderTokenHud(...args))
- itemPileSocket.register(SOCKET_HANDLERS.RERENDER_PILE_INVENTORY, (...args) => API._rerenderItemPileInventoryApplication(...args))
- itemPileSocket.register(SOCKET_HANDLERS.QUERY_PILE_INVENTORY_OPEN, (...args) => isPileInventoryOpenForOthers.respond(...args))
- itemPileSocket.register(SOCKET_HANDLERS.RESPOND_PILE_INVENTORY_OPEN, (...args) => isPileInventoryOpenForOthers.handleResponse(...args))
-
- /**
- * Item & attribute sockets
- */
- itemPileSocket.register(SOCKET_HANDLERS.DROP_ITEMS, (args) => API._dropItems(args))
- itemPileSocket.register(SOCKET_HANDLERS.ADD_ITEMS, (...args) => API._addItems(...args))
- itemPileSocket.register(SOCKET_HANDLERS.REMOVE_ITEMS, (...args) => API._removeItems(...args))
- itemPileSocket.register(SOCKET_HANDLERS.TRANSFER_ITEMS, (...args) => API._transferItems(...args))
- itemPileSocket.register(SOCKET_HANDLERS.TRANSFER_ALL_ITEMS, (...args) => API._transferAllItems(...args))
- itemPileSocket.register(SOCKET_HANDLERS.ADD_ATTRIBUTE, (...args) => API._addAttributes(...args))
- itemPileSocket.register(SOCKET_HANDLERS.REMOVE_ATTRIBUTES, (...args) => API._removeAttributes(...args))
- itemPileSocket.register(SOCKET_HANDLERS.TRANSFER_ATTRIBUTES, (...args) => API._transferAttributes(...args))
- itemPileSocket.register(SOCKET_HANDLERS.TRANSFER_ALL_ATTRIBUTES, (...args) => API._transferAllAttributes(...args))
- itemPileSocket.register(SOCKET_HANDLERS.TRANSFER_EVERYTHING, (...args) => API._transferEverything(...args))
-
- /**
- * Trading sockets
- */
- itemPileSocket.register(SOCKET_HANDLERS.TRADE_REQUEST_PROMPT, (...args) => TradeAPI._respondPrompt(...args));
- itemPileSocket.register(SOCKET_HANDLERS.TRADE_REQUEST_CANCELLED, (...args) => TradeAPI._tradeCancelled(...args));
-
- itemPileSocket.register(SOCKET_HANDLERS.PUBLIC.TRADE_UPDATE_ITEMS, (...args) => TradingApp._updateItems(...args));
- itemPileSocket.register(SOCKET_HANDLERS.PUBLIC.TRADE_UPDATE_CURRENCIES, (...args) => TradingApp._updateCurrencies(...args));
- itemPileSocket.register(SOCKET_HANDLERS.PUBLIC.TRADE_STATE, (...args) => TradingApp._setAcceptedState(...args));
-
- itemPileSocket.register(SOCKET_HANDLERS.PRIVATE.TRADE_UPDATE_ITEMS, (...args) => TradeAPI._updateItems(...args));
- itemPileSocket.register(SOCKET_HANDLERS.PRIVATE.TRADE_UPDATE_CURRENCIES, (...args) => TradeAPI._updateCurrencies(...args));
- itemPileSocket.register(SOCKET_HANDLERS.PRIVATE.TRADE_STATE, (...args) => TradeAPI._setAcceptedState(...args));
-
- itemPileSocket.register(SOCKET_HANDLERS.TRADE_CLOSED, (...args) => TradingApp._tradeClosed(...args));
-
- itemPileSocket.register(SOCKET_HANDLERS.TRADE_COMPLETED, (...args) => {
- TradingApp._tradeCompleted(...args)
- TradeAPI._tradeCompleted(...args)
- });
-
- itemPileSocket.register(SOCKET_HANDLERS.TRADE_SPECTATE, (...args) => TradeAPI._spectateTrade(...args));
-
- itemPileSocket.register(SOCKET_HANDLERS.DISABLE_CHAT_TRADE_BUTTON, (...args) => chatHandler._disableTradingButton(...args));
-}
-
-async function callHook(inHookName, ...args) {
- const newArgs = [];
- for (let arg of args) {
- if (lib.is_UUID(arg)) {
- const testArg = await fromUuid(arg);
- if (testArg) {
- arg = testArg;
- }
- }
- newArgs.push(arg);
- }
- return Hooks.callAll(inHookName, ...newArgs);
-}
-
-export const isPileInventoryOpenForOthers = {
-
- query(inPile) {
- const promise = new Promise(resolve => {
- this.resolve = resolve;
- });
-
- this.usersToRespond = new Set(game.users
- .filter(user => user.active && user !== game.user)
- .map(user => user.id));
- this.isOpen = false;
-
- itemPileSocket.executeForOthers(SOCKET_HANDLERS.QUERY_PILE_INVENTORY_OPEN, game.user.id, lib.getUuid(inPile));
-
- if (this.usersToRespond.size > 0) {
- setTimeout(this.resolve, 200);
- } else {
- this.resolve(false);
- this.usersToRespond = new Set();
- this.isOpen = false;
- this.resolve = () => {
- };
- }
-
- return promise;
- },
-
- async respond(inUserId, inPileUuid) {
- const app = ItemPileInventory.getActiveAppFromPile(inPileUuid);
- return itemPileSocket.executeAsUser(SOCKET_HANDLERS.RESPOND_PILE_INVENTORY_OPEN, inUserId, game.user.id, !!app);
- },
-
- handleResponse(inUserId, appOpen) {
- this.usersToRespond.delete(inUserId);
- this.isOpen = this.isOpen || appOpen;
- if (this.usersToRespond.size > 0) return;
- this.resolve(this.isOpen);
- this.usersToRespond = new Set();
- this.isOpen = false;
- this.resolve = () => {
- };
- }
-
-}
\ No newline at end of file
diff --git a/scripts/systems.js b/scripts/systems.js
deleted file mode 100644
index f85728fb..00000000
--- a/scripts/systems.js
+++ /dev/null
@@ -1,36 +0,0 @@
-import dnd5e from "./systems/dnd5e.js";
-
-// ā IMPORT SYSTEMS HERE ā
-import pf1 from "./systems/pf1.js";
-import pf2e from "./systems/pf2e.js";
-import ds4 from "./systems/ds4.js";
-import d35e from "./systems/d35e.js";
-import swade from "./systems/swade.js";
-import tormenta20 from "./systems/tormenta20.js";
-import wfrp4e from "./systems/wfrp4e.js"
-import splittermond from "./systems/splittermond.js"
-import sfrpg from "./systems/sfrpg.js"
-// ā IMPORT SYSTEMS HERE ā
-
-/**
- * NOTE: YOUR PULL REQUEST WILL NOT BE ACCEPTED IF YOU DO NOT
- * FOLLOW THE CONVENTION IN THE D&D 5E SYSTEM FILE
- */
-export const SYSTEMS = {
- get DATA() {
- return {
- dnd5e,
- // ā ADD SYSTEMS HERE ā
- pf1,
- pf2e,
- ds4,
- d35e,
- swade,
- tormenta20,
- wfrp4e,
- splittermond,
- sfrpg,
- // ā ADD SYSTEMS HERE ā
- }?.[game.system.id];
- }
-};
\ No newline at end of file
diff --git a/scripts/systems/d35e.js b/scripts/systems/d35e.js
deleted file mode 100644
index 92620166..00000000
--- a/scripts/systems/d35e.js
+++ /dev/null
@@ -1,42 +0,0 @@
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "npc",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
-
- // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "spell,feat,class,race,attack,full-attack,buff,aura,alignment,enhancement,damage-type,material"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": [
- {
- name: "D35E.CurrencyPP",
- path: "data.currency.pp",
- img: "icons/commodities/currency/coin-inset-snail-silver.webp"
- },
- {
- name: "D35E.CurrencyGP",
- path: "data.currency.gp",
- img: "icons/commodities/currency/coin-embossed-crown-gold.webp"
- },
- {
- name: "D35E.CurrencySP",
- path: "data.currency.sp",
- img: "icons/commodities/currency/coin-engraved-moon-silver.webp"
- },
- {
- name: "D35E.CurrencyCP",
- path: "data.currency.cp",
- img: "icons/commodities/currency/coin-engraved-waves-copper.webp"
- }
- ]
-}
\ No newline at end of file
diff --git a/scripts/systems/dnd5e.js b/scripts/systems/dnd5e.js
deleted file mode 100644
index 1a75a600..00000000
--- a/scripts/systems/dnd5e.js
+++ /dev/null
@@ -1,51 +0,0 @@
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "character",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
-
- // Item filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "spell,feat,class"
- },
- {
- "path": "data.weaponType",
- "filters": "natural"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": [
- {
- name: "DND5E.CurrencyPP",
- path: "data.currency.pp",
- img: "icons/commodities/currency/coin-inset-snail-silver.webp"
- },
- {
- name: "DND5E.CurrencyGP",
- path: "data.currency.gp",
- img: "icons/commodities/currency/coin-embossed-crown-gold.webp"
- },
- {
- name: "DND5E.CurrencyEP",
- path: "data.currency.ep",
- img: "icons/commodities/currency/coin-inset-copper-axe.webp"
- },
- {
- name: "DND5E.CurrencySP",
- path: "data.currency.sp",
- img: "icons/commodities/currency/coin-engraved-moon-silver.webp"
- },
- {
- name: "DND5E.CurrencyCP",
- path: "data.currency.cp",
- img: "icons/commodities/currency/coin-engraved-waves-copper.webp"
- }
- ]
-}
\ No newline at end of file
diff --git a/scripts/systems/ds4.js b/scripts/systems/ds4.js
deleted file mode 100644
index 633713b7..00000000
--- a/scripts/systems/ds4.js
+++ /dev/null
@@ -1,39 +0,0 @@
-// Item Piles Definitions for Foundry VTT Game System Dungeonslayers 4
-
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "character",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
-
- // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "spell,talent,racialAbility,language,alphabet,specialCreatureAbility"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": [
- {
- name: "DS4.CharacterCurrencyGold",
- path: "data.currency.gold",
- img: "icons/commodities/currency/coin-embossed-crown-gold.webp"
- },
- {
- name: "DS4.CharacterCurrencySilver",
- path: "data.currency.silver",
- img: "icons/commodities/currency/coin-inset-snail-silver.webp"
- },
- {
- name: "DS4.CharacterCurrencyCopper",
- path: "data.currency.copper",
- img: "icons/commodities/currency/coin-inset-copper-axe.webp"
- }
- ]
-}
\ No newline at end of file
diff --git a/scripts/systems/pf1.js b/scripts/systems/pf1.js
deleted file mode 100644
index f8fd3254..00000000
--- a/scripts/systems/pf1.js
+++ /dev/null
@@ -1,42 +0,0 @@
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "npc",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
-
- // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "attack,buff,class,feat,race,spell"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": [
- {
- name: "PF1.CurrencyPlatinumP",
- path: "data.currency.pp",
- img: "systems/pf1/icons/items/inventory/coins-silver.jpg"
- },
- {
- name: "PF1.CurrencyGoldP",
- path: "data.currency.gp",
- img: "systems/pf1/icons/items/inventory/coin-gold.jpg"
- },
- {
- name: "PF1.CurrencySilverP",
- path: "data.currency.sp",
- img: "systems/pf1/icons/items/inventory/coin-silver.jpg"
- },
- {
- name: "PF1.CurrencyCopperP",
- path: "data.currency.cp",
- img: "systems/pf1/icons/items/inventory/coin-copper.jpg"
- }
- ]
-}
\ No newline at end of file
diff --git a/scripts/systems/pf2e.js b/scripts/systems/pf2e.js
deleted file mode 100644
index 95081ce2..00000000
--- a/scripts/systems/pf2e.js
+++ /dev/null
@@ -1,21 +0,0 @@
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "loot",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
-
- // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "action,spell,melee,lore,heritage,feat,effect,class,background,ancestry"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type", "data.temporary.value"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": []
-}
diff --git a/scripts/systems/sfrpg.js b/scripts/systems/sfrpg.js
deleted file mode 100644
index 1dadc121..00000000
--- a/scripts/systems/sfrpg.js
+++ /dev/null
@@ -1,32 +0,0 @@
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "npc2",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
-
- // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "attack,buff,class,feat,race,spell"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": [
- {
- name: "SFRPG.Currencies.Credits",
- path: "data.currency.credit",
- img: "systems/sfrpg/icons/equipment/goods/credstick.jpg"
- },
- {
- name: "SFRPG.Currencies.UPBs",
- path: "data.currency.upb",
- img: "systems/sfrpg/icons/equipment/goods/upb.jpg"
- }
- ]
-}
\ No newline at end of file
diff --git a/scripts/systems/splittermond.js b/scripts/systems/splittermond.js
deleted file mode 100644
index ecdbaad0..00000000
--- a/scripts/systems/splittermond.js
+++ /dev/null
@@ -1,37 +0,0 @@
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "npc",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
-
- // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "spell,strength,weakness,mastery,species,culture,ancestry,education,resource,npcfeature,moonsign,language,culturelore,statuseffect,spelleffect"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type", "data.sufferedDamage", "data.quality"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": [
- {
- name: "Telare",
- path: "data.currency.T",
- img: "icons/commodities/currency/coins-assorted-mix-platinum.webp"
- },
- {
- name: "Lunare",
- path: "data.currency.L",
- img: "icons/commodities/currency/coin-embossed-unicorn-silver.webp"
- },
- {
- name: "Solare",
- path: "data.currency.S",
- img: "icons/commodities/currency/coins-assorted-mix-copper.webp"
- }
- ]
-}
\ No newline at end of file
diff --git a/scripts/systems/swade.js b/scripts/systems/swade.js
deleted file mode 100644
index fd709ace..00000000
--- a/scripts/systems/swade.js
+++ /dev/null
@@ -1,27 +0,0 @@
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "character",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
-
- // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "edge,hindrance,skill,power,ability"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": [
- {
- name: "SWADE.Currency",
- path: "data.details.currency",
- img: "icons/svg/coins.svg"
- }
- ]
-}
\ No newline at end of file
diff --git a/scripts/systems/tormenta20.js b/scripts/systems/tormenta20.js
deleted file mode 100644
index 56552ef0..00000000
--- a/scripts/systems/tormenta20.js
+++ /dev/null
@@ -1,41 +0,0 @@
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "character",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.qtd",
-
- // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "magia, poder, classe"
- },
- {
- "path": "data.tipoUso",
- "filters": "nat"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": [
- {
- name: "Ouro",
- path: "data.dinheiro.to",
- img: "icons/commodities/currency/coin-embossed-insect-gold.webp"
- },
- {
- name: "Prata",
- path: "data.dinheiro.tp",
- img: "icons/commodities/currency/coin-embossed-unicorn-silver.webp"
- },
- {
- name: "Cobre",
- path: "data.dinheiro.tc",
- img: "icons/commodities/currency/coin-engraved-waves-copper.webp"
- }
- ]
-}
\ No newline at end of file
diff --git a/scripts/systems/wfrp4e.js b/scripts/systems/wfrp4e.js
deleted file mode 100644
index 201e286e..00000000
--- a/scripts/systems/wfrp4e.js
+++ /dev/null
@@ -1,21 +0,0 @@
-export default {
- // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
- "ACTOR_CLASS_TYPE": "character",
-
- // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
- "ITEM_QUANTITY_ATTRIBUTE": "data.quantity.value",
-
- // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
- "ITEM_FILTERS": [
- {
- "path": "type",
- "filters": "career,container,critical,disease,injury,mutation,prayer,psychology,talent,skill,spell,trait,extendedTest,vehicleMod,cargo"
- }
- ],
-
- // Item similarities determines how item piles detect similarities and differences in the system
- "ITEM_SIMILARITIES": ["name", "type"],
-
- // Currencies in item piles are a list of names, attribute paths, and images - the attribute path is relative to the actor.data
- "CURRENCIES": []
-}
\ No newline at end of file
diff --git a/scripts/trade-api.js b/scripts/trade-api.js
deleted file mode 100644
index 27a741a0..00000000
--- a/scripts/trade-api.js
+++ /dev/null
@@ -1,464 +0,0 @@
-import { itemPileSocket, SOCKET_HANDLERS } from "./socket.js";
-import * as lib from "./lib/lib.js";
-import { TradePromptDialog, TradeRequestDialog } from "./formapplications/trade-dialogs.js";
-import { TradingApp } from "./formapplications/trading-app.js";
-import API from "./api.js";
-import HOOKS from "./hooks.js";
-
-export class TradeAPI {
-
- static async requestTrade(user = false) {
-
- // Grab all of the active users (not self)
- const users = game.users.filter(user => user.active && user !== game.user);
-
- // No users!
- if (!users.length) {
- return new Dialog({
- title: game.i18n.localize("ITEM-PILES.Trade.Title"),
- content: lib.dialogLayout({
- title: game.i18n.localize("ITEM-PILES.Trade.NoActiveUsers.Title"),
- message: game.i18n.localize("ITEM-PILES.Trade.NoActiveUsers.Content"),
- icon: "fas fa-heart-broken"
- }),
- buttons: {
- ok: {
- icon: ' ',
- label: game.i18n.localize("Okay")
- }
- }
- }).render(true);
- }
-
- let userId;
- let actor;
- let isPrivate;
-
- // Find actors you own
- const actors = game.actors.filter(actor => actor.isOwner);
-
- // If you only own one actor, and the user was already preselected (through the right click menu in the actors list)
- if (actors.length === 1 && user) {
- userId = user.id;
- actor = actors[0];
- isPrivate = false;
- } else {
- // If you have more than 1 owned actor, prompt to choose which one
- const result = await TradePromptDialog.show({ actors, users, user });
- if (!result) return;
- userId = result.userId;
- actor = result.actor;
- isPrivate = result.private;
- }
-
- if (!actor) return false;
-
- actor = actor?.actor ?? actor;
-
- const actorOwner = game.users.find(user => user.character === actor && user !== game.user);
- if (actorOwner) {
- // If you're not the only owner of the actor you chose, make sure you picked the correct one
- const doContinue = await Dialog.confirm({
- title: game.i18n.localize("ITEM-PILES.Trade.Title"),
- content: lib.dialogLayout({
- message: actorOwner.active
- ? game.i18n.format("ITEM-PILES.Trade.UserActiveCharacterWarning", {
- actor_name: actor.name,
- player_name: actorOwner.name
- })
- : game.i18n.format("ITEM-PILES.Trade.UserCharacterWarning", {
- actor_name: actor.name,
- player_name: actorOwner.name
- })
- }),
- defaultYes: false
- });
- if (!doContinue) {
- return;
- }
- }
-
- const privateTradeId = randomID();
- const publicTradeId = randomID();
-
- // Spawn a cancel dialog
- const cancelDialog = new Dialog({
- title: game.i18n.localize("ITEM-PILES.Trade.Title"),
- content: `${game.i18n.format("ITEM-PILES.Trade.OngoingRequest.Content", { user_name: game.users.get(userId).name })}
`,
- buttons: {
- confirm: {
- icon: ' ',
- label: game.i18n.localize("ITEM-PILES.Trade.OngoingRequest.Label"),
- callback: () => {
- itemPileSocket.executeAsUser(SOCKET_HANDLERS.TRADE_REQUEST_CANCELLED, userId, game.user.id, privateTradeId);
- }
- }
- }
- }, {
- top: 50,
- width: 300
- }).render(true);
-
- // Send out the request
- return itemPileSocket.executeAsUser(SOCKET_HANDLERS.TRADE_REQUEST_PROMPT, userId, game.user.id, actor.uuid, privateTradeId, publicTradeId, isPrivate)
- .then(async (data) => {
-
- if (data === "cancelled") return;
-
- cancelDialog.close();
-
- // If they declined, show warning
- if (!data || !data.fullPrivateTradeId.includes(privateTradeId)) {
- return lib.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Declined"), true);
- }
-
- let traderActor = await fromUuid(data.actorUuid);
- traderActor = traderActor?.actor ?? traderActor;
-
- // Otherwise, open trade interface and spawn private trade instance
- new TradingApp({ user: game.user, actor }, {
- user: game.users.get(userId),
- actor: traderActor
- }, data.fullPublicTradeId, data.fullPrivateTradeId, isPrivate).render(true, this.getAppOptions(actor).tradeApp);
- ongoingTrades[data.fullPrivateTradeId] = new OngoingTrade({
- user: game.user,
- actor
- }, {
- user: game.users.get(userId),
- actor: traderActor
- }, data.fullPublicTradeId, data.fullPrivateTradeId, isPrivate);
-
- actor.sheet.render(true, this.getAppOptions(actor).actorSheet);
-
- if (isPrivate) {
- return itemPileSocket.executeForUsers(SOCKET_HANDLERS.CALL_HOOK, [game.user.id, userId], HOOKS.TRADE.STARTED, {
- user: game.user.id,
- actor: actor.uuid
- }, { user: userId, actor: data.actorUuid }, data.fullPublicTradeId, isPrivate);
- }
-
- return itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.TRADE.STARTED, {
- user: game.user.id,
- actor: actor.uuid
- }, { user: userId, actor: data.actorUuid }, data.fullPublicTradeId, isPrivate);
-
- }).catch((err) => {
- // If the counterparty disconnected, show that and close dialog
- lib.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Disconnected"), true);
- cancelDialog.close()
- });
-
- }
-
- static async _respondPrompt(tradingUserId, tradingActorUuid, privateTradeId, publicTradeId, isPrivate) {
-
- // If the user was previously muted, wait for a random amount of time and respond with false
- if (mutedUsers.find(u => u === tradingUserId)) {
- await lib.wait(Math.random() * 10000);
- return false;
- }
-
- // Complete the private and public trade IDs
- const fullPrivateTradeId = privateTradeId + randomID();
- const fullPublicTradeId = publicTradeId + randomID();
-
- const tradingUser = game.users.get(tradingUserId);
- let tradingActor = await fromUuid(tradingActorUuid);
-
- tradingActor = tradingActor?.actor ?? tradingActor;
-
- // Make em pick an actor (if more than one) and accept/decline/mute
- const result = await TradeRequestDialog.show({ tradeId: privateTradeId, tradingUser, tradingActor, isPrivate });
-
- if (!result) return false;
-
- if (result === "cancelled") {
- return "cancelled";
- }
-
- // If muted, add user to blacklist locally
- if (result === "mute") {
- mutedUsers.push(tradingUserId);
- return false;
- }
-
- const actor = result?.actor ?? result;
-
- // Spawn trading app and new ongoing trade interface
- new TradingApp({ user: game.user, actor }, {
- user: tradingUser,
- actor: tradingActor
- }, fullPublicTradeId, fullPrivateTradeId, isPrivate).render(true, this.getAppOptions(actor).tradeApp);
- ongoingTrades[fullPrivateTradeId] = new OngoingTrade({ user: game.user, actor }, {
- user: tradingUser,
- actor: tradingActor
- }, fullPublicTradeId, fullPrivateTradeId, isPrivate);
-
- actor.sheet.render(true, this.getAppOptions(actor).actorSheet);
-
- return {
- fullPrivateTradeId,
- fullPublicTradeId,
- actorUuid: result.uuid
- };
-
- }
-
- static getAppOptions(actor) {
- const midPoint = (window.innerWidth / 2) - 200;
- return {
- actorSheet: { left: midPoint - actor.sheet.position.width - 25 },
- tradeApp: { left: midPoint + 25 }
- }
- }
-
- static async _tradeCancelled(userId, privateTradeId) {
-
- Dialog.prompt({
- title: game.i18n.localize("ITEM-PILES.Trade.Title"),
- content: lib.dialogLayout({
- message: game.i18n.format("ITEM-PILES.Trade.CancelledRequest.Content", { user_name: game.users.get(userId).name })
- }),
- callback: () => {
- },
- options: {
- width: 300
- }
- });
-
- return TradeRequestDialog.cancel(privateTradeId);
-
- }
-
- static async spectateTrade(data) {
-
- const { tradeId, tradeUser } = data;
-
- if (TradingApp.getAppByPublicTradeId(tradeId)) {
- return TradingApp.getAppByPublicTradeId(tradeId).render(false, { focus: true });
- }
-
- const user = game.users.get(tradeUser);
-
- if (!user.active) {
- itemPileSocket.executeAsGM(SOCKET_HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);
- return lib.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Over"), true);
- }
-
- const ongoingTrade = await itemPileSocket.executeAsUser(SOCKET_HANDLERS.TRADE_SPECTATE, tradeUser, tradeId);
-
- if (!ongoingTrade) {
- itemPileSocket.executeAsGM(SOCKET_HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);
- return lib.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Over"), true);
- }
-
- ongoingTrade[0].user = game.users.get(ongoingTrade[0].user);
- ongoingTrade[0].actor = await fromUuid(ongoingTrade[0].actor);
-
- ongoingTrade[1].user = game.users.get(ongoingTrade[1].user);
- ongoingTrade[1].actor = await fromUuid(ongoingTrade[1].actor);
-
- return new TradingApp(...ongoingTrade).render(true);
-
- }
-
- static async _spectateTrade(tradeId) {
- const trade = OngoingTrade.getActiveTrade(tradeId);
- if (!trade) return false;
- return [
- {
- user: trade[1].user.id,
- actor: trade[1].actor.uuid,
- items: trade[1].actorItems,
- currencies: trade[1].actorCurrencies,
- accepted: trade[1].accepted
- },
- {
- user: trade[1].traderUser.id,
- actor: trade[1].traderActor.uuid,
- items: trade[1].traderActorItems,
- currencies: trade[1].traderActorCurrencies,
- accepted: trade[1].traderAccepted
- },
- tradeId
- ]
- }
-
- static async _updateItems(privateTradeId, userId, items) {
- if (!ongoingTrades[privateTradeId]) return;
- return ongoingTrades[privateTradeId].updateItems(userId, items);
- }
-
- static async _updateCurrencies(privateTradeId, userId, items) {
- if (!ongoingTrades[privateTradeId]) return;
- return ongoingTrades[privateTradeId].updateCurrencies(userId, items);
- }
-
- static async _setAcceptedState(privateTradeId, userId, status) {
- if (!ongoingTrades[privateTradeId]) return;
- return ongoingTrades[privateTradeId].setAcceptedState(userId, status);
- }
-
- static async _tradeClosed(privateTradeId) {
- if (!ongoingTrades[privateTradeId]) return;
- return ongoingTrades[privateTradeId].tradeClosed();
- }
-
- static async _tradeCompleted(party_1, party_2, publicTradeId, isPrivate) {
- if (!lib.isResponsibleGM()) return;
-
- if (party_1.items.length) {
- const items = party_1.items.map(item => {
- return { _id: item.id, quantity: item.quantity, item: item.data }
- })
- await API._addItems(party_2.actor, items, party_1.user, { runHooks: false });
- await API._removeItems(party_1.actor, items, party_1.user, { runHooks: false });
- }
-
- if (party_2.items.length) {
- const items = party_2.items.map(item => {
- return { _id: item.id, quantity: item.quantity, item: item.data }
- })
- await API._addItems(party_1.actor, items, party_2.user, { runHooks: false });
- await API._removeItems(party_2.actor, items, party_2.user, { runHooks: false });
- }
-
- if (party_1.currencies.length) {
- const currencies = Object.fromEntries(party_1.currencies.map(currency => {
- return [currency.path, currency.quantity];
- }));
- await API._addAttributes(party_2.actor, currencies, party_1.user, { runHooks: false });
- await API._removeAttributes(party_1.actor, currencies, party_1.user, { runHooks: false });
- }
-
- if (party_2.currencies.length) {
- const currencies = Object.fromEntries(party_2.currencies.map(currency => {
- return [currency.path, currency.quantity];
- }));
- await API._addAttributes(party_1.actor, currencies, party_2.user, { runHooks: false });
- await API._removeAttributes(party_2.actor, currencies, party_2.user, { runHooks: false });
- }
-
- return itemPileSocket.executeForEveryone(SOCKET_HANDLERS.CALL_HOOK, HOOKS.TRADE.COMPLETE, party_1, party_2, publicTradeId, isPrivate);
-
- }
-
-}
-
-const mutedUsers = [];
-const ongoingTrades = {};
-
-export class OngoingTrade {
-
- constructor(self, rightTrader, publicTradeId, privateTradeId, isPrivate) {
-
- this.actor = self.actor;
- this.user = self.user;
- this.actorItems = [];
- this.actorCurrencies = [];
- this.accepted = false;
-
- this.traderActor = rightTrader.actor;
- this.traderUser = rightTrader.user;
- this.traderActorItems = [];
- this.traderActorCurrencies = [];
- this.traderAccepted = false;
-
- this.privateTradeId = privateTradeId;
- this.publicTradeId = publicTradeId;
-
- this.isPrivate = isPrivate;
-
- this.userHook = Hooks.on("renderPlayerList", this.userDisconnected.bind(this));
-
- }
-
- static getActiveTrade(publicId) {
- return Object.entries(ongoingTrades).find(trade => {
- return trade[1].publicTradeId === publicId;
- })
- }
-
- userDisconnected(app, html, data) {
- if (!data.users.find(u => u === this.traderUser)) {
- this.tradeClosed();
- if (!this.isPrivate) {
- itemPileSocket.executeAsGM(SOCKET_HANDLERS.DISABLE_CHAT_TRADE_BUTTON, this.publicTradeId);
- itemPileSocket.executeForEveryone(SOCKET_HANDLERS.TRADE_CLOSED, this.publicTradeId, this.traderUser.id);
- } else {
- TradingApp._tradeClosed(this.publicTradeId, this.traderUser.id);
- }
- }
- }
-
- tradeClosed() {
- Hooks.off("renderPlayerList", this.userHook);
- delete ongoingTrades[this.privateTradeId];
- }
-
- updateItems(userId, newItems) {
- this.accepted = false;
- this.traderAccepted = false;
- if (userId === this.user.id) {
- this.actorItems = newItems;
- } else if (userId === this.traderUser.id) {
- this.traderActorItems = newItems;
- }
- }
-
- updateCurrencies(userId, newItems) {
- this.accepted = false;
- this.traderAccepted = false;
- if (userId === this.user.id) {
- this.actorCurrencies = newItems;
- } else if (userId === this.traderUser.id) {
- this.traderActorCurrencies = newItems;
- }
- }
-
- setAcceptedState(userId, status) {
- if (userId === this.user.id) {
- this.accepted = status;
- } else if (userId === this.traderUser.id) {
- this.traderAccepted = status;
- }
- if (this.accepted && this.traderAccepted) {
- setTimeout(() => {
- if (this.accepted && this.traderAccepted) {
- this.execute(userId);
- }
- }, 2000);
- }
- }
-
- async execute(userId) {
-
- this.tradeClosed();
-
- if (game.user.id !== userId) return;
-
- const args = [
- {
- user: this.user.id,
- actor: this.actor.uuid,
- items: this.actorItems,
- currencies: this.actorCurrencies
- },
- {
- user: this.traderUser.id,
- actor: this.traderActor.uuid,
- items: this.traderActorItems,
- currencies: this.traderActorCurrencies
- },
- this.publicTradeId,
- this.isPrivate
- ]
-
- if (this.isPrivate) {
- return itemPileSocket.executeForUsers(SOCKET_HANDLERS.TRADE_COMPLETED, [this.user.id, this.traderUser.id], ...args);
- }
-
- await itemPileSocket.executeAsGM(SOCKET_HANDLERS.DISABLE_CHAT_TRADE_BUTTON, this.publicTradeId);
- return itemPileSocket.executeForEveryone(SOCKET_HANDLERS.TRADE_COMPLETED, ...args);
- }
-}
\ No newline at end of file
diff --git a/src/API/api.js b/src/API/api.js
new file mode 100644
index 00000000..590ce061
--- /dev/null
+++ b/src/API/api.js
@@ -0,0 +1,1146 @@
+import * as Helpers from "../helpers/helpers.js";
+import * as Utilities from "../helpers/utilities.js";
+import * as PileUtilities from "../helpers/pile-utilities.js";
+import * as SharingUtilities from "../helpers/sharing-utilities.js";
+import SETTINGS from "../constants/settings.js";
+import ItemPileSocket from "../socket.js";
+import HOOKS from "../constants/hooks.js";
+import TradeAPI from "./trade-api.js";
+import PrivateAPI from "./private-api.js";
+
+const API = {
+
+ /**
+ * The actor class type used for the original item pile actor in this system
+ *
+ * @returns {String}
+ */
+ get ACTOR_CLASS_TYPE() {
+ return Helpers.getSetting(SETTINGS.ACTOR_CLASS_TYPE);
+ },
+
+ /**
+ * The currencies used in this system
+ *
+ * @returns {Array<{primary: Boolean, name: String, data: Object, img: String, abbreviation: String, exchange: Number}>}
+ */
+ get CURRENCIES() {
+ return Helpers.getSetting(SETTINGS.CURRENCIES);
+ },
+
+ /**
+ * The attribute used to track the price of items in this system
+ *
+ * @returns {string}
+ */
+ get ITEM_PRICE_ATTRIBUTE() {
+ return Helpers.getSetting(SETTINGS.ITEM_PRICE_ATTRIBUTE);
+ },
+
+ /**
+ * The attribute used to track the quantity of items in this system
+ *
+ * @returns {String}
+ */
+ get ITEM_QUANTITY_ATTRIBUTE() {
+ return Helpers.getSetting(SETTINGS.ITEM_QUANTITY_ATTRIBUTE);
+ },
+
+ /**
+ * The filters for item types eligible for interaction within this system
+ *
+ * @returns {Array<{name: String, filters: String}>}
+ */
+ get ITEM_FILTERS() {
+ return Helpers.getSetting(SETTINGS.ITEM_FILTERS);
+ },
+
+ /**
+ * The attributes for detecting item similarities
+ *
+ * @returns {Array}
+ */
+ get ITEM_SIMILARITIES() {
+ return Helpers.getSetting(SETTINGS.ITEM_SIMILARITIES);
+ },
+
+ /**
+ * Sets the actor class type used for the original item pile actor in this system
+ *
+ * @param {String} inClassType
+ * @returns {Promise|Boolean}
+ */
+ setActorClassType(inClassType) {
+ if (typeof inClassType !== "string") {
+ throw Helpers.custom_error("setActorTypeClass | inClassType must be of type string");
+ }
+ return Helpers.setSetting(SETTINGS.ACTOR_CLASS_TYPE, inClassType);
+ },
+
+ /**
+ * Sets the currencies used in this system
+ *
+ * @param {Array} inCurrencies
+ * @returns {Promise}
+ */
+ setCurrencies(inCurrencies) {
+ if (!Array.isArray(inCurrencies)) {
+ throw Helpers.custom_error("setCurrencies | inCurrencies must be an array");
+ }
+
+ inCurrencies.forEach(currency => {
+ if (typeof currency !== "object") {
+ throw Helpers.custom_error("setCurrencies | each entry in inCurrencies must be of type object");
+ }
+ if (typeof currency.primary !== "boolean") {
+ throw Helpers.custom_error("setCurrencies | currency.primary must be of type boolean");
+ }
+ if (typeof currency.name !== "string") {
+ throw Helpers.custom_error("setCurrencies | currency.name must be of type string");
+ }
+ if (typeof currency.abbreviation !== "string") {
+ throw Helpers.custom_error("setCurrencies | currency.abbreviation must be of type string");
+ }
+ if (typeof currency.exchange !== "number") {
+ throw Helpers.custom_error("setCurrencies | currency.exchange must be of type number");
+ }
+ if (typeof currency.data !== "object") {
+ throw Helpers.custom_error("setCurrencies | currency.data must be of type object");
+ }
+ if (currency.img && typeof currency.img !== "string") {
+ throw Helpers.custom_error("setCurrencies | currency.img must be of type string");
+ }
+ });
+
+ return Helpers.setSetting(SETTINGS.CURRENCIES, inCurrencies);
+ },
+
+ /**
+ * Sets the attribute used to track the price of items in this system
+ *
+ * @param {string} inAttribute
+ * @returns {Promise}
+ */
+ setItemPriceAttribute(inAttribute) {
+ if (typeof inAttribute !== "string") {
+ throw Helpers.custom_error("setItemPriceAttribute | inAttribute must be of type string");
+ }
+ return Helpers.setSetting(SETTINGS.ITEM_PRICE_ATTRIBUTE, inAttribute);
+ },
+
+ /**
+ * Sets the attribute used to track the quantity of items in this system
+ *
+ * @param {String} inAttribute
+ * @returns {Promise}
+ */
+ setItemQuantityAttribute(inAttribute) {
+ if (typeof inAttribute !== "string") {
+ throw Helpers.custom_error("setItemQuantityAttribute | inAttribute must be of type string");
+ }
+ return Helpers.setSetting(SETTINGS.ITEM_QUANTITY_ATTRIBUTE, inAttribute);
+ },
+
+ /**
+ * Sets the items filters for interaction within this system
+ *
+ * @param {Array<{path: String, filters: String}>} inFilters
+ * @returns {Promise}
+ */
+ setItemFilters(inFilters) {
+ if (!Array.isArray(inFilters)) {
+ throw Helpers.custom_error("setItemFilters | inFilters must be of type array");
+ }
+ inFilters.forEach(filter => {
+ if (typeof filter?.path !== "string") {
+ throw Helpers.custom_error("setItemFilters | each entry in inFilters must have a \"path\" property with a value that is of type string");
+ }
+ if (typeof filter?.filters !== "string") {
+ throw Helpers.custom_error("setItemFilters | each entry in inFilters must have a \"filters\" property with a value that is of type string");
+ }
+ });
+ return Helpers.setSetting(SETTINGS.ITEM_FILTERS, inFilters);
+ },
+
+ /**
+ * Sets the attributes for detecting item similarities
+ *
+ * @param {Array} inPaths
+ * @returns {Promise}
+ */
+ setItemSimilarities(inPaths) {
+ if (!Array.isArray(inPaths)) {
+ throw Helpers.custom_error("setItemSimilarities | inPaths must be of type array");
+ }
+ inPaths.forEach(path => {
+ if (typeof path !== "string") {
+ throw Helpers.custom_error("setItemSimilarities | each entry in inPaths must be of type string");
+ }
+ });
+ return Helpers.setSetting(SETTINGS.ITEM_SIMILARITIES, inPaths);
+ },
+
+ getPrimaryCurrency(actor = false) {
+ if (actor && actor instanceof Actor) {
+ return PileUtilities.getActorPrimaryCurrency(actor);
+ }
+ return this.CURRENCIES.find(currency => currency.primary);
+ },
+
+ /* ================= ITEM PILE METHODS ================= */
+
+ /**
+ * Creates the default item pile token at a location.
+ *
+ * @param {Object} position The position to create the item pile at
+ * @param {String/Boolean} [sceneId=false] Which scene to create the item pile on
+ * @param {Array/Boolean} [items=false] Any items to create on the item pile
+ * @param {String/Boolean} [pileActorName=false] Whether to use an existing item pile actor as the basis of this new token
+ *
+ * @returns {Promise}
+ */
+ createItemPile(position, {
+ sceneId = game.user.viewedScene, items = false, pileActorName = false
+ } = {}) {
+
+ if (pileActorName) {
+ const pileActor = game.actors.getName(pileActorName);
+ if (!pileActor) {
+ throw Helpers.custom_error(`There is no actor of the name "${pileActorName}"`, true);
+ } else if (!PileUtilities.isValidItemPile(pileActor)) {
+ throw Helpers.custom_error(`The actor of name "${pileActorName}" is not a valid item pile actor.`, true);
+ }
+ }
+
+ if (items) {
+ items = items.map(item => {
+ return item instanceof Item ? item.toObject() : item;
+ })
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.CREATE_PILE, sceneId, position, { pileActorName, items });
+ },
+
+ /**
+ * Turns tokens and its actors into item piles
+ *
+ * @param {Token/TokenDocument/Array} targets The targets to be turned into item piles
+ * @param {Object} pileSettings Overriding settings to be put on the item piles' settings
+ * @param {Object} tokenSettings Overriding settings that will update the tokens' settings
+ *
+ * @return {Promise} The uuids of the targets after they were turned into item piles
+ */
+ turnTokensIntoItemPiles(targets, { pileSettings = {}, tokenSettings = {} } = {}) {
+
+ if (!Array.isArray(targets)) targets = [targets];
+
+ const targetUuids = targets.map(target => {
+ if (!(target instanceof Token || target instanceof TokenDocument)) {
+ throw Helpers.custom_error(`turnTokensIntoItemPiles | Target must be of type Token or TokenDocument`, true)
+ }
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`turnTokensIntoItemPiles | Could not determine the UUID, please provide a valid target`, true)
+ return targetUuid;
+ })
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TURN_INTO_PILE, targetUuids, pileSettings, tokenSettings);
+ },
+
+ /**
+ * Reverts tokens from an item pile into a normal token and actor
+ *
+ * @param {Token/TokenDocument/Array} targets The targets to be reverted from item piles
+ * @param {Object} tokenSettings Overriding settings that will update the tokens
+ *
+ * @return {Promise} The uuids of the targets after they were reverted from being item piles
+ */
+ revertTokensFromItemPiles(targets, { tokenSettings = {} } = {}) {
+
+ if (!Array.isArray(targets)) targets = [targets];
+
+ const targetUuids = targets.map(target => {
+ if (!(target instanceof Token || target instanceof TokenDocument)) {
+ throw Helpers.custom_error(`revertTokensFromItemPiles | Target must be of type Token or TokenDocument`, true)
+ }
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`revertTokensFromItemPiles | Could not determine the UUID, please provide a valid target`, true)
+ return targetUuid;
+ })
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.REVERT_FROM_PILE, targetUuids, tokenSettings);
+ },
+
+ /**
+ * Opens a pile if it is enabled and a container
+ *
+ * @param {Token/TokenDocument} target
+ * @param {Token/TokenDocument/Boolean} [interactingToken=false]
+ *
+ * @return {Promise/Boolean}
+ */
+ openItemPile(target, interactingToken = false) {
+ const targetActor = Utilities.getActor(target);
+ const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;
+ const pileData = PileUtilities.getActorFlagData(targetActor);
+ if (!pileData?.enabled || !pileData?.isContainer) return false;
+ const wasLocked = pileData.locked;
+ const wasClosed = pileData.closed;
+ pileData.closed = false;
+ pileData.locked = false;
+ if (wasLocked) {
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_UNLOCK, targetActor, pileData, interactingTokenDocument);
+ if (hookResult === false) return false;
+ }
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_OPEN, targetActor, pileData, interactingTokenDocument);
+ if (hookResult === false) return false;
+ if (wasClosed && pileData.openSound) {
+ let sound = pileData.openSound;
+ if (pileData.openSound.includes("*")) {
+ sound = Helpers.random_array_element(pileData.openSounds)
+ }
+ AudioHelper.play({ src: sound }, true)
+ }
+ return this.updateItemPile(targetActor, pileData, { interactingToken: interactingTokenDocument });
+ },
+
+ /**
+ * Closes a pile if it is enabled and a container
+ *
+ * @param {Token/TokenDocument} target Target pile to close
+ * @param {Token/TokenDocument/Boolean} [interactingToken=false]
+ *
+ * @return {Promise/Boolean}
+ */
+ closeItemPile(target, interactingToken = false) {
+ const targetActor = Utilities.getActor(target);
+ const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;
+ const pileData = PileUtilities.getActorFlagData(targetActor);
+ if (!pileData?.enabled || !pileData?.isContainer) return false;
+
+ const wasOpen = !pileData.closed;
+ pileData.closed = true;
+
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_CLOSE, targetActor, pileData, interactingTokenDocument);
+ if (hookResult === false) return false;
+
+ if (wasOpen && pileData.closeSound) {
+ let sound = pileData.closeSound;
+ if (pileData.closeSound.includes("*")) {
+ sound = Helpers.random_array_element(pileData.closeSounds)
+ }
+ AudioHelper.play({ src: sound }, true)
+ }
+
+ return this.updateItemPile(targetActor, pileData, { interactingToken: interactingTokenDocument });
+ },
+
+ /**
+ * Toggles a pile's closed state if it is enabled and a container
+ *
+ * @param {Token/TokenDocument} target Target pile to open or close
+ * @param {Token/TokenDocument/Boolean} [interactingToken=false]
+ *
+ * @return {Promise/Boolean}
+ */
+ async toggleItemPileClosed(target, interactingToken = false) {
+ const targetActor = Utilities.getActor(target);
+ const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;
+ const pileData = PileUtilities.getActorFlagData(targetActor);
+ if (!pileData?.enabled || !pileData?.isContainer) return false;
+ if (pileData.closed) {
+ await this.openItemPile(targetActor, interactingTokenDocument);
+ } else {
+ await this.closeItemPile(targetActor, interactingTokenDocument);
+ }
+ return !pileData.closed;
+ },
+
+ /**
+ * Locks a pile if it is enabled and a container
+ *
+ * @param {Token/TokenDocument} target Target pile to lock
+ * @param {Token/TokenDocument/Boolean} [interactingToken=false]
+ *
+ * @return {Promise/Boolean}
+ */
+ lockItemPile(target, interactingToken = false) {
+ const targetActor = Utilities.getActor(target);
+ const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;
+ const pileData = PileUtilities.getActorFlagData(targetActor);
+ if (!pileData?.enabled || !pileData?.isContainer) return false;
+ const wasClosed = pileData.closed;
+ pileData.closed = true;
+ pileData.locked = true;
+ if (!wasClosed) {
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_CLOSE, targetActor, pileData, interactingTokenDocument);
+ if (hookResult === false) return false;
+ }
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_LOCK, targetActor, pileData, interactingTokenDocument);
+ if (hookResult === false) return false;
+ if (!wasClosed && pileData.closeSound) {
+ let sound = pileData.closeSound;
+ if (pileData.closeSound.includes("*")) {
+ sound = Helpers.random_array_element(pileData.closeSounds)
+ }
+ AudioHelper.play({ src: sound }, true)
+ }
+ return this.updateItemPile(targetActor, pileData, { interactingToken: interactingTokenDocument });
+ },
+
+ /**
+ * Unlocks a pile if it is enabled and a container
+ *
+ * @param {Token/TokenDocument} target Target pile to unlock
+ * @param {Token/TokenDocument/Boolean} [interactingToken=false]
+ *
+ * @return {Promise/Boolean}
+ */
+ unlockItemPile(target, interactingToken = false) {
+ const targetActor = Utilities.getActor(target);
+ const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;
+ const pileData = PileUtilities.getActorFlagData(targetActor);
+ if (!pileData?.enabled || !pileData?.isContainer) return false;
+ pileData.locked = false;
+ Helpers.hooks.call(HOOKS.PILE.PRE_UNLOCK, targetActor, pileData, interactingTokenDocument);
+ return this.updateItemPile(targetActor, pileData, { interactingToken: interactingTokenDocument });
+ },
+
+ /**
+ * Toggles a pile's locked state if it is enabled and a container
+ *
+ * @param {Token/TokenDocument} target Target pile to lock or unlock
+ * @param {Token/TokenDocument/Boolean} [interactingToken=false]
+ *
+ * @return {Promise/Boolean}
+ */
+ toggleItemPileLocked(target, interactingToken = false) {
+ const targetActor = Utilities.getActor(target);
+ const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;
+ const pileData = PileUtilities.getActorFlagData(targetActor);
+ if (!pileData?.enabled || !pileData?.isContainer) return false;
+ if (pileData.locked) {
+ return this.unlockItemPile(targetActor, interactingTokenDocument);
+ }
+ return this.lockItemPile(targetActor, interactingTokenDocument);
+ },
+
+ /**
+ * Causes the item pile to play a sound as it was attempted to be opened, but was locked
+ *
+ * @param {Token/TokenDocument} target
+ * @param {Token/TokenDocument/Boolean} [interactingToken=false]
+ *
+ * @return {Promise}
+ */
+ rattleItemPile(target, interactingToken = false) {
+ const targetActor = Utilities.getActor(target);
+ const interactingTokenDocument = interactingToken ? Utilities.getActor(interactingToken) : false;
+
+ const pileData = PileUtilities.getActorFlagData(targetActor);
+
+ if (!pileData?.enabled || !pileData?.isContainer || !pileData?.locked) return false;
+
+ Helpers.hooks.call(HOOKS.PILE.PRE_RATTLE, targetActor, pileData, interactingTokenDocument);
+
+ if (pileData.lockedSound) {
+ let sound = pileData.lockedSound;
+ if (pileData.lockedSound.includes("*")) {
+ sound = Helpers.random_array_element(pileData.lockedSounds)
+ }
+ AudioHelper.play({ src: sound }, true);
+ }
+
+ return ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.CALL_HOOK, HOOKS.PILE.RATTLE, Utilities.getUuid(targetActor), pileData, Utilities.getUuid(interactingTokenDocument));
+ },
+
+ /**
+ * Whether an item pile is locked. If it is not enabled or not a container, it is always false.
+ *
+ * @param {Token/TokenDocument} target
+ *
+ * @return {Boolean}
+ */
+ isItemPileLocked(target) {
+ return PileUtilities.isItemPileLocked(target);
+ },
+
+ /**
+ * Whether an item pile is closed. If it is not enabled or not a container, it is always false.
+ *
+ * @param {Token/TokenDocument} target
+ *
+ * @return {Boolean}
+ */
+ isItemPileClosed(target) {
+ return PileUtilities.isItemPileClosed(target);
+ },
+
+ /**
+ * Whether an item pile is a container. If it is not enabled, it is always false.
+ *
+ * @param {Token/TokenDocument} target
+ *
+ * @return {Boolean}
+ */
+ isItemPileContainer(target) {
+ return PileUtilities.isItemPileContainer(target);
+ },
+
+ /**
+ * Updates a pile with new data.
+ *
+ * @param {Token/TokenDocument} target
+ * @param {Object} newData
+ * @param {Token/TokenDocument/Boolean} [interactingToken=false]
+ * @param {Object/Boolean} [tokenSettings=false]
+ *
+ * @return {Promise/Boolean}
+ */
+ updateItemPile(target, newData, { interactingToken = false, tokenSettings = false } = {}) {
+
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`updateItemPile | Could not determine the UUID, please provide a valid target`, true);
+
+ const interactingTokenUuid = interactingToken ? Utilities.getUuid(interactingToken) : false;
+ if (interactingToken && !interactingTokenUuid) throw Helpers.custom_error(`updateItemPile | Could not determine the UUID, please provide a valid target`, true);
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.UPDATE_PILE, targetUuid, newData, {
+ interactingTokenUuid, tokenSettings
+ });
+ },
+
+ /**
+ * Deletes a pile, calling the relevant hooks.
+ *
+ * @param {Token/TokenDocument} target
+ *
+ * @return {Promise/Boolean}
+ */
+ deleteItemPile(target) {
+ if (!PileUtilities.isValidItemPile(target)) {
+ throw Helpers.custom_error(`deleteItemPile | This is not an item pile, please provide a valid target`, true);
+ }
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`deleteItemPile | Could not determine the UUID, please provide a valid target`, true);
+ if (!targetUuid.includes("Token")) {
+ throw Helpers.custom_error(`deleteItemPile | Please provide a Token or TokenDocument`, true);
+ }
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DELETE_PILE, targetUuid);
+ },
+
+ /**
+ * Splits an item pile's content between all players (or a specified set of target actors).
+ *
+ * @param target {Token/TokenDocument/Actor} The item pile to split
+ * @param targets {boolean/TokenDocument/Actor/Array} [targets=false] The targets to receive the split contents
+ * @param instigator {boolean/TokenDocument/Actor} [instigator=false] Whether this was triggered by a specific actor
+ * @returns {Promise/Boolean}
+ */
+ splitItemPileContents(target, { targets = false, instigator = false } = {}) {
+
+ if (!PileUtilities.isValidItemPile(target)) return false;
+
+ const itemPileUuid = Utilities.getUuid(target);
+ if (!itemPileUuid) throw Helpers.custom_error(`SplitItemPileContents | Could not determine the UUID, please provide a valid item pile`, true)
+
+ const itemPileActor = Utilities.getActor(target);
+
+ if (targets) {
+ if (!Array.isArray(targets)) {
+ targets = [targets]
+ }
+ targets.forEach(actor => {
+ if (!(actor instanceof TokenDocument || actor instanceof Actor)) {
+ throw Helpers.custom_error("SplitItemPileContents | Each of the entries in targets must be of type TokenDocument or Actor")
+ }
+ })
+ targets = targets.map(target => target?.character ?? target?.actor ?? target);
+ }
+
+ if (instigator && !(instigator instanceof TokenDocument || instigator instanceof Actor)) {
+ throw Helpers.custom_error("SplitItemPileContents | instigator must be of type TokenDocument or Actor")
+ }
+
+ const actorUuids = (targets || SharingUtilities.getPlayersForItemPile(itemPileActor).map(u => u.character)).map(actor => Utilities.getUuid(actor));
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.SPLIT_PILE, itemPileUuid, actorUuids, game.user.id, instigator);
+
+ },
+
+ /* ================= ITEM AND ATTRIBUTE METHODS ================= */
+
+ /**
+ * Adds item to an actor, increasing item quantities if matches were found
+ *
+ * @param {Actor/TokenDocument/Token} target The target to add an item to
+ * @param {Array} items An array of objects, with the key "item" being an item object or an Item class (the foundry class), with an optional key of "quantity" being the amount of the item to add
+ * @param {Boolean} [mergeSimilarItems=true] Whether to merge similar items based on their name and type
+ * @param {String/Boolean} [interactionId=false] The interaction ID of this action
+ *
+ * @returns {Promise} An array of objects, each containing the item that was added or updated, and the quantity that was added
+ */
+ addItems(target, items, { mergeSimilarItems = true, interactionId = false } = {}) {
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`AddItems | Could not determine the UUID, please provide a valid target`, true)
+
+ const itemsToAdd = []
+ items.forEach(itemData => {
+
+ let item = itemData;
+ if (itemData instanceof Item) {
+ item = itemData.toObject();
+ } else if (itemData.item instanceof Item) {
+ item = itemData.item.toObject();
+ } else if (itemData.item) {
+ item = itemData.item;
+ }
+
+ if (itemData?.quantity !== undefined) {
+ setProperty(item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, itemData?.quantity)
+ }
+
+ const existingItems = mergeSimilarItems ? Utilities.findSimilarItem(itemsToAdd, item) : false;
+ if (existingItems) {
+ setProperty(existingItems, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, Utilities.getItemQuantity(existingItems) + Utilities.getItemQuantity(item))
+ } else {
+ itemsToAdd.push(item);
+ }
+
+ });
+
+ if (interactionId) {
+ if (typeof interactionId !== "string") throw Helpers.custom_error(`AddItems | interactionId must be of type string`);
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.ADD_ITEMS, targetUuid, itemsToAdd, game.user.id, { interactionId });
+ },
+
+ /**
+ * Subtracts the quantity of items on an actor. If the quantity of an item reaches 0, the item is removed from the actor.
+ *
+ * @param {Actor/Token/TokenDocument} target The target to remove a items from
+ * @param {Array} items An array of objects each containing the item id (key "_id") and the quantity to remove (key "quantity"), or Items (the foundry class) or strings of IDs to remove all quantities of
+ * @param {String/Boolean} [interactionId=false] The interaction ID of this action
+ *
+ * @returns {Promise} An array of objects, each containing the item that was removed or updated, the quantity that was removed, and whether the item was deleted
+ */
+ removeItems(target, items, { interactionId = false } = {}) {
+
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`RemoveItems | Could not determine the UUID, please provide a valid target`, true);
+
+ const targetActorItems = game.itempiles.getActorItems(target);
+
+ items = items.map(itemData => {
+
+ let item;
+ if (typeof itemData === "string" || itemData._id) {
+ const itemId = typeof itemData === "string" ? itemData : itemData._id;
+ item = targetActorItems.find(actorItem => actorItem.id === itemId);
+ if (!item) {
+ throw Helpers.custom_error(`RemoveItems | Could not find item with id "${itemId}" on target "${targetUuid}"`, true)
+ }
+ item = item.toObject();
+ } else {
+ if (itemData.item instanceof Item) {
+ item = itemData.item.toObject();
+ } else if (itemData instanceof Item) {
+ item = itemData.toObject();
+ } else {
+ item = itemData.item;
+ }
+ let foundActorItem = targetActorItems.find(actorItem => actorItem.id === item._id);
+ if (!foundActorItem) {
+ throw Helpers.custom_error(`RemoveItems | Could not find item with id "${item._id}" on target "${targetUuid}"`, true)
+ }
+ }
+
+ return {
+ _id: item._id, quantity: itemData?.quantity ?? Utilities.getItemQuantity(item)
+ }
+ });
+
+ if (interactionId) {
+ if (typeof interactionId !== "string") throw Helpers.custom_error(`RemoveItems | interactionId must be of type string`);
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.REMOVE_ITEMS, targetUuid, items, game.user.id, { interactionId });
+ },
+
+ /**
+ * Transfers items from the source to the target, subtracting a number of quantity from the source's item and adding it to the target's item, deleting items from the source if their quantity reaches 0
+ *
+ * @param {Actor/Token/TokenDocument} source The source to transfer the items from
+ * @param {Actor/Token/TokenDocument} target The target to transfer the items to
+ * @param {Array} items An array of objects each containing the item id (key "_id") and the quantity to transfer (key "quantity"), or Items (the foundry class) or strings of IDs to transfer all quantities of
+ * @param {String/Boolean} [interactionId=false] The interaction ID of this action
+ *
+ * @returns {Promise} An array of objects, each containing the item that was added or updated, and the quantity that was transferred
+ */
+ transferItems(source, target, items, { interactionId = false } = {}) {
+
+ const sourceUuid = Utilities.getUuid(source);
+ if (!sourceUuid) throw Helpers.custom_error(`TransferItems | Could not determine the UUID, please provide a valid source`, true)
+
+ const sourceActorItems = PileUtilities.getActorItems(source);
+
+ items = items.map(itemData => {
+
+ let item;
+ if (typeof itemData === "string" || itemData._id) {
+ const itemId = typeof itemData === "string" ? itemData : itemData._id;
+ item = sourceActorItems.find(actorItem => actorItem.id === itemId);
+ if (!item) {
+ throw Helpers.custom_error(`TransferItems | Could not find item with id "${itemId}" on target "${sourceUuid}"`, true)
+ }
+ item = item.toObject();
+ } else if (itemData instanceof Item) {
+ item = itemData.toObject();
+ } else if (itemData.item instanceof Item) {
+ item = itemData.item.toObject();
+ } else {
+ item = itemData.item;
+ }
+
+ let foundActorItem = sourceActorItems.find(actorItem => actorItem.id === item._id);
+ if (!foundActorItem) {
+ throw Helpers.custom_error(`TransferItems | Could not find item with id "${item._id}" on target "${sourceUuid}"`, true)
+ }
+
+ return {
+ _id: item._id, quantity: Math.max((itemData?.quantity ?? 0) ?? Utilities.getItemQuantity(itemData))
+ }
+ });
+
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`TransferItems | Could not determine the UUID, please provide a valid target`, true)
+
+ if (interactionId) {
+ if (typeof interactionId !== "string") throw Helpers.custom_error(`TransferItems | interactionId must be of type string`);
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_ITEMS, sourceUuid, targetUuid, items, game.user.id, { interactionId });
+
+ },
+
+ /**
+ * Transfers all items between the source and the target.
+ *
+ * @param {Actor/Token/TokenDocument} source The actor to transfer all items from
+ * @param {Actor/Token/TokenDocument} target The actor to receive all the items
+ * @param {Array/Boolean} [itemFilters=false] Array of item types disallowed - will default to module settings if none provided
+ * @param {String/Boolean} [interactionId=false] The interaction ID of this action
+ *
+ * @returns {Promise} An array containing all of the items that were transferred to the target
+ */
+ transferAllItems(source, target, { itemFilters = false, interactionId = false } = {}) {
+
+ const sourceUuid = Utilities.getUuid(source);
+ if (!sourceUuid) throw Helpers.custom_error(`TransferAllItems | Could not determine the UUID, please provide a valid source`, true)
+
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`TransferAllItems | Could not determine the UUID, please provide a valid target`, true)
+
+ if (itemFilters) {
+ if (!Array.isArray(itemFilters)) throw Helpers.custom_error(`TransferAllItems | itemFilters must be of type array`);
+ itemFilters.forEach(entry => {
+ if (typeof entry?.path !== "string") throw Helpers.custom_error(`TransferAllItems | each entry in the itemFilters must have a "path" property that is of type string`);
+ if (typeof entry?.filter !== "string") throw Helpers.custom_error(`TransferAllItems | each entry in the itemFilters must have a "filter" property that is of type string`);
+ })
+ }
+
+ if (interactionId) {
+ if (typeof interactionId !== "string") throw Helpers.custom_error(`TransferAllItems | interactionId must be of type string`);
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_ALL_ITEMS, sourceUuid, targetUuid, game.user.id, {
+ itemFilters, interactionId
+ });
+ },
+
+ /**
+ * Adds attributes on an actor
+ *
+ * @param {Actor/Token/TokenDocument} target The target whose attribute will have a set quantity added to it
+ * @param {Object} attributes An object with each key being an attribute path, and its value being the quantity to add
+ * @param {String/Boolean} [interactionId=false] The interaction ID of this action
+ *
+ * @returns {Promise} An array containing a key value pair of the attribute path and the quantity of that attribute that was removed
+ *
+ */
+ addAttributes(target, attributes, { interactionId = false } = {}) {
+
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`AddAttributes | Could not determine the UUID, please provide a valid target`, true)
+
+ const targetActor = Utilities.getActor(target);
+
+ Object.entries(attributes).forEach(entry => {
+ const [attribute, quantity] = entry;
+ if (!hasProperty(targetActor.data, attribute)) {
+ throw Helpers.custom_error(`AddAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
+ }
+ if (!Helpers.isRealNumber(quantity) && quantity > 0) {
+ throw Helpers.custom_error(`AddAttributes | Attribute "${attribute}" must be of type number and greater than 0`, true)
+ }
+ });
+
+ if (interactionId) {
+ if (typeof interactionId !== "string") throw Helpers.custom_error(`AddAttributes | interactionId must be of type string`);
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.ADD_ATTRIBUTE, targetUuid, attributes, game.user.id, { interactionId });
+
+ },
+
+ /**
+ * Subtracts attributes on the target
+ *
+ * @param {Token/TokenDocument} target The target whose attributes will be subtracted from
+ * @param {Array/object} attributes This can be either an array of attributes to subtract (to zero out a given attribute), or an object with each key being an attribute path, and its value being the quantity to subtract
+ * @param {String/Boolean} [interactionId=false] The interaction ID of this action
+ *
+ * @returns {Promise} An array containing a key value pair of the attribute path and the quantity of that attribute that was removed
+ */
+ removeAttributes(target, attributes, { interactionId = false } = {}) {
+
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`RemoveAttributes | Could not determine the UUID, please provide a valid target`, true)
+
+ const targetActor = Utilities.getActor(target);
+
+ if (Array.isArray(attributes)) {
+ attributes.forEach(attribute => {
+ if (typeof attribute !== "string") {
+ throw Helpers.custom_error(`RemoveAttributes | Each attribute in the array must be of type string`, true)
+ }
+ if (!hasProperty(targetActor.data, attribute)) {
+ throw Helpers.custom_error(`RemoveAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
+ }
+ });
+ } else {
+ Object.entries(attributes).forEach(entry => {
+ const [attribute, quantity] = entry;
+ if (!hasProperty(targetActor.data, attribute)) {
+ throw Helpers.custom_error(`RemoveAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
+ }
+ if (!is_real_number(quantity) && quantity > 0) {
+ throw Helpers.custom_error(`RemoveAttributes | Attribute "${attribute}" must be of type number and greater than 0`, true)
+ }
+ });
+ }
+
+ if (interactionId) {
+ if (typeof interactionId !== "string") throw Helpers.custom_error(`RemoveAttributes | interactionId must be of type string`);
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.REMOVE_ATTRIBUTES, targetUuid, attributes, game.user.id, { interactionId });
+
+ },
+
+ /**
+ * Transfers a set quantity of an attribute from a source to a target, removing it or subtracting from the source and adds it the target
+ *
+ * @param {Actor/Token/TokenDocument} source The source to transfer the attribute from
+ * @param {Actor/Token/TokenDocument} target The target to transfer the attribute to
+ * @param {Array/object} attributes This can be either an array of attributes to transfer (to transfer all of a given attribute), or an object with each key being an attribute path, and its value being the quantity to transfer
+ * @param {String/Boolean} [interactionId=false] The interaction ID of this action
+ *
+ * @returns {Promise} An object containing a key value pair of each attribute transferred, the key being the attribute path and its value being the quantity that was transferred
+ */
+ transferAttributes(source, target, attributes, { interactionId = false } = {}) {
+
+ const sourceUuid = Utilities.getUuid(source);
+ if (!sourceUuid) throw Helpers.custom_error(`TransferAttributes | Could not determine the UUID, please provide a valid source`, true)
+ const sourceActor = Utilities.getActor(source);
+
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`TransferAttributes | Could not determine the UUID, please provide a valid target`, true)
+ const targetActor = Utilities.getActor(target);
+
+ if (Array.isArray(attributes)) {
+ attributes.forEach(attribute => {
+ if (typeof attribute !== "string") {
+ throw Helpers.custom_error(`TransferAttributes | Each attribute in the array must be of type string`, true)
+ }
+ if (!hasProperty(sourceActor.data, attribute)) {
+ throw Helpers.custom_error(`TransferAttributes | Could not find attribute ${attribute} on source's actor with UUID "${targetUuid}"`, true)
+ }
+ if (!hasProperty(targetActor.data, attribute)) {
+ throw Helpers.custom_error(`TransferAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
+ }
+ });
+ } else {
+ Object.entries(attributes).forEach(entry => {
+ const [attribute, quantity] = entry;
+ if (!hasProperty(sourceActor.data, attribute)) {
+ throw Helpers.custom_error(`TransferAttributes | Could not find attribute ${attribute} on source's actor with UUID "${targetUuid}"`, true)
+ }
+ if (!hasProperty(targetActor.data, attribute)) {
+ throw Helpers.custom_error(`TransferAttributes | Could not find attribute ${attribute} on target's actor with UUID "${targetUuid}"`, true)
+ }
+ if (!Helpers.isRealNumber(quantity) && quantity > 0) {
+ throw Helpers.custom_error(`TransferAttributes | Attribute "${attribute}" must be of type number and greater than 0`, true)
+ }
+ });
+ }
+
+ if (interactionId) {
+ if (typeof interactionId !== "string") throw Helpers.custom_error(`TransferAttributes | interactionId must be of type string`);
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_ATTRIBUTES, sourceUuid, targetUuid, attributes, game.user.id, { interactionId });
+
+ },
+
+ /**
+ * Transfers all dynamic attributes from a source to a target, removing it or subtracting from the source and adding them to the target
+ *
+ * @param {Actor/Token/TokenDocument} source The source to transfer the attributes from
+ * @param {Actor/Token/TokenDocument} target The target to transfer the attributes to
+ * @param {String/Boolean} [interactionId=false] The interaction ID of this action
+ *
+ * @returns {Promise} An object containing a key value pair of each attribute transferred, the key being the attribute path and its value being the quantity that was transferred
+ */
+ transferAllAttributes(source, target, { interactionId = false } = {}) {
+
+ const sourceUuid = Utilities.getUuid(source);
+ if (!sourceUuid) throw Helpers.custom_error(`TransferAllAttributes | Could not determine the UUID, please provide a valid source`, true);
+
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`TransferAllAttributes | Could not determine the UUID, please provide a valid target`, true);
+
+ if (interactionId) {
+ if (typeof interactionId !== "string") throw Helpers.custom_error(`TransferAllAttributes | interactionId must be of type string`);
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_ALL_ATTRIBUTES, sourceUuid, targetUuid, game.user.id, { interactionId });
+
+ },
+
+ /**
+ * Transfers all items and attributes between the source and the target.
+ *
+ * @param {Actor/Token/TokenDocument} source The actor to transfer all items and attributes from
+ * @param {Actor/Token/TokenDocument} target The actor to receive all the items and attributes
+ * @param {Array/Boolean} [itemFilters=false] Array of item types disallowed - will default to module settings if none provided
+ * @param {String/Boolean} [interactionId=false] The ID of this interaction
+ *
+ * @returns {Promise} An object containing all items and attributes transferred to the target
+ */
+ transferEverything(source, target, { itemFilters = false, interactionId = false } = {}) {
+
+ const sourceUuid = Utilities.getUuid(source);
+ if (!sourceUuid) throw Helpers.custom_error(`TransferEverything | Could not determine the UUID, please provide a valid source`, true)
+
+ const targetUuid = Utilities.getUuid(target);
+ if (!targetUuid) throw Helpers.custom_error(`TransferEverything | Could not determine the UUID, please provide a valid target`, true)
+
+ if (itemFilters) {
+ if (!Array.isArray(itemFilters)) throw Helpers.custom_error(`TransferEverything | itemFilters must be of type array`);
+ itemFilters.forEach(entry => {
+ if (typeof entry?.path !== "string") throw Helpers.custom_error(`TransferEverything | each entry in the itemFilters must have a "path" property that is of type string`);
+ if (typeof entry?.filter !== "string") throw Helpers.custom_error(`TransferEverything | each entry in the itemFilters must have a "filter" property that is of type string`);
+ })
+ }
+
+ if (interactionId) {
+ if (typeof interactionId !== "string") throw Helpers.custom_error(`TransferEverything | interactionId must be of type string`);
+ }
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRANSFER_EVERYTHING, sourceUuid, targetUuid, game.user.id, {
+ itemFilters, interactionId
+ });
+
+ },
+
+ getActorItems(actor) {
+ return PileUtilities.getActorItems(actor);
+ },
+
+ getActorCurrencies(actor) {
+ return PileUtilities.getActorCurrencies(actor);
+ },
+
+ updateTokenHud() {
+ return ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.RERENDER_TOKEN_HUD);
+ },
+
+ requestTrade(user) {
+ return TradeAPI._requestTrade(user);
+ },
+
+ spectateTrade(tradeId) {
+ return TradeAPI._spectateTrade(tradeId);
+ },
+
+ renderItemPileInterface(target, {
+ userIds = null, inspectingTarget = null, useDefaultCharacter = null
+ } = {}) {
+
+ const targetDocument = Utilities.getDocument(target);
+ const targetUuid = Utilities.getUuid(targetDocument);
+ if (!targetUuid) throw Helpers.custom_error(`renderItemPileInterface | Could not determine the UUID, please provide a valid target item pile`);
+
+ if (!PileUtilities.isValidItemPile(targetDocument)) {
+ throw Helpers.custom_error("renderItemPileInterface | This target is not a valid item pile")
+ }
+
+ if (!inspectingTarget && !useDefaultCharacter) {
+ useDefaultCharacter = true;
+ }
+
+ if (inspectingTarget && useDefaultCharacter) {
+ throw Helpers.custom_error("renderItemPileInterface | You cannot force users to use both their default character and a specific character to inspect the pile")
+ }
+
+ const inspectingTargetUuid = inspectingTarget ? Utilities.getUuid(inspectingTarget) : false;
+ if (inspectingTarget && !inspectingTargetUuid) throw Helpers.custom_error(`renderItemPileInterface | Could not determine the UUID, please provide a valid inspecting target`);
+
+ if (!Array.isArray(userIds)) userIds = [game.user.id];
+
+ if (!game.user.isGM) {
+ if (userIds.length > 1 || !userIds.includes(game.user.id)) {
+ throw Helpers.custom_error(`renderItemPileInterface | You are not a GM, so you cannot force others to render an item pile's interface`);
+ }
+ userIds = [game.user.id];
+ }
+
+ if (userIds.length === 1 && userIds[0] === game.user.id) {
+ return PrivateAPI._renderItemPileInterface(targetUuid, {
+ inspectingTargetUuid,
+ useDefaultCharacter,
+ remote: true
+ })
+ }
+
+ for (const userId of userIds) {
+ const user = game.users.get(userId);
+ if (!user) throw Helpers.custom_error(`renderItemPileInterface | No user with ID "${userId}" exists`);
+ if (useDefaultCharacter) {
+ if (!user.character) {
+ Helpers.custom_warning(`renderItemPileInterface | User "${user.name}" has no default character`, true);
+ return;
+ }
+ }
+ }
+
+ return ItemPileSocket.executeForUsers(ItemPileSocket.HANDLERS.RENDER_INTERFACE, userIds, targetUuid, {
+ inspectingTargetUuid,
+ useDefaultCharacter,
+ remote: true
+ });
+
+ },
+
+ getPricesForItem(item, { seller = false, buyer = false, quantity = 1 } = {}) {
+
+ if (!(item instanceof Item)) {
+ throw Helpers.custom_error("getPricesForItem | The given item must be of type Item");
+ }
+
+ if (seller) {
+ seller = Utilities.getActor(seller);
+ if (!seller) {
+ throw Helpers.custom_error("getPricesForItem | Could not determine actor for the seller");
+ }
+ } else {
+ if (!item.parent) {
+ throw Helpers.custom_error("getPricesForItem | If no seller was given, the item must belong to an actor");
+ }
+ seller = Utilities.getActor(item.parent);
+ }
+
+ if (buyer) {
+ buyer = Utilities.getActor(buyer);
+ if (!buyer) {
+ throw Helpers.custom_error(`getPricesForItem | Could not determine the actor for the buyer`);
+ }
+ }
+
+ return PileUtilities.getItemPrices(item, { seller, buyer, quantity });
+
+ },
+
+ /**
+ * Trades a single item between one actor to another, and currencies and/or change is exchanged between them
+ *
+ * @param {Actor/Token/TokenDocument} seller The actor that is selling the item
+ * @param {Actor/Token/TokenDocument} buyer The actor that is buying the item
+ * @param {Array>} items An array of objects containing the item or the id of the
+ * item to be sold, the quantity to be sold, and the payment
+ * index to be used
+ * @param {String/Boolean} [interactionId=false] The ID of this interaction
+ *
+ * @returns {Promise} The items that were created and the attributes that were changed
+ */
+ tradeItems(seller, buyer, items, { interactionId = false } = {}) {
+
+ const sellerActor = Utilities.getActor(seller);
+ const sellerUuid = Utilities.getUuid(sellerActor);
+ if (!sellerUuid) {
+ throw Helpers.custom_error(`tradeItems | Could not determine the UUID of the seller, please provide a valid actor or token`, true);
+ }
+
+ const buyerActor = Utilities.getActor(buyer);
+ const buyerUuid = Utilities.getUuid(buyer);
+ if (!buyerUuid) {
+ throw Helpers.custom_error(`tradeItems | Could not determine the UUID of the buyer, please provide a valid actor or token`, true);
+ }
+
+ const itemsToSell = items.map(data => {
+
+ data = foundry.utils.mergeObject({
+ item: "",
+ quantity: 1,
+ paymentIndex: 0
+ }, data);
+
+ if (!data.item) {
+ throw Helpers.custom_error(`tradeItems | You must provide an item!`, true);
+ }
+
+ let actorItem;
+ if (typeof data.item === "string") {
+ actorItem = sellerActor.items.get(data.item) || sellerActor.items.getName(data.item);
+ if (!actorItem) {
+ throw Helpers.custom_error(`tradeItems | Could not find item on seller with identifier "${data.item}"`);
+ }
+ } else {
+ actorItem = sellerActor.items.get(data.item instanceof Item ? data.item.id : data.item._id) || sellerActor.items.getName(data.item.name);
+ if (!actorItem) {
+ throw Helpers.custom_error(`tradeItems | Could not find provided item on seller`);
+ }
+ }
+
+ const itemPrices = PileUtilities.getItemPrices(actorItem, {
+ seller: sellerActor,
+ buyer: buyerActor,
+ quantity: data.quantity
+ });
+ if (itemPrices.length) {
+ if (data.paymentIndex >= itemPrices.length || data.paymentIndex < 0) {
+ throw Helpers.custom_error(`tradeItems | That payment index does not exist on ${actorItem.name}`, true);
+ }
+
+ const selectedPrice = itemPrices[data.paymentIndex];
+ if (data.quantity > selectedPrice.maxQuantity) {
+ throw Helpers.custom_error(`tradeItems | The buyer actor cannot afford ${data.quantity} of ${actorItem.name} (max ${selectedPrice.maxQuantity})`, true);
+ }
+ }
+
+ return {
+ id: actorItem.id,
+ quantity: data.quantity,
+ paymentIndex: data.paymentIndex
+ };
+
+ });
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.TRADE_ITEMS, sellerUuid, buyerUuid, itemsToSell, game.user.id, { interactionId });
+
+ },
+
+}
+
+export default API;
\ No newline at end of file
diff --git a/src/API/chat-api.js b/src/API/chat-api.js
new file mode 100644
index 00000000..33efe5d1
--- /dev/null
+++ b/src/API/chat-api.js
@@ -0,0 +1,519 @@
+import SETTINGS from "../constants/settings.js";
+import * as Helpers from "../helpers/helpers.js";
+import CONSTANTS from "../constants/constants.js";
+import HOOKS from "../constants/hooks.js";
+import ItemPileSocket from "../socket.js";
+import * as PileUtilities from "../helpers/pile-utilities.js";
+import * as Utilities from "../helpers/utilities.js";
+import TradeAPI from "./trade-api.js";
+
+export default class ChatAPI {
+
+ static initialize() {
+
+ Hooks.on("preCreateChatMessage", this._preCreateChatMessage.bind(this));
+ Hooks.on("renderChatMessage", this._renderChatMessage.bind(this));
+ Hooks.on(HOOKS.ITEM.TRANSFER, this._outputTransferItem.bind(this));
+ Hooks.on(HOOKS.ATTRIBUTE.TRANSFER, this._outputTransferCurrency.bind(this));
+ Hooks.on(HOOKS.TRANSFER_EVERYTHING, this._outputTransferEverything.bind(this));
+ Hooks.on(HOOKS.PILE.SPLIT_INVENTORY, this._outputSplitItemPileInventory.bind(this));
+ Hooks.on(HOOKS.TRADE.STARTED, this._outputTradeStarted.bind(this));
+ Hooks.on(HOOKS.TRADE.COMPLETE, this._outputTradeComplete.bind(this));
+ Hooks.on(HOOKS.ITEM.TRADE, this._outputMerchantTradeComplete.bind(this));
+
+ $(document).on("click", ".item-piles-chat-card .item-piles-collapsible", async function () {
+ if ($(this).attr("open")) return;
+ await Helpers.wait(25);
+ $(this).parent()[0].scrollIntoView({ behavior: 'smooth', block: 'nearest', inline: 'start' });
+ });
+ }
+
+ static _preCreateChatMessage(chatMessage) {
+
+ if (!Helpers.getSetting(SETTINGS.ENABLE_TRADING)) return;
+
+ const content = chatMessage.data.content.toLowerCase();
+
+ if (!(content.startsWith("!itempiles") || content.startsWith("!ip"))) return;
+
+ const args = content.split(" ").slice(1);
+
+ if (args[0] === "trade") {
+ setTimeout(() => {
+ game.itempiles.requestTrade();
+ });
+ }
+
+ return false;
+
+ }
+
+ static _renderChatMessage(app, html) {
+ html.find(".item-piles-specate-trade").click(function () {
+ game.itempiles.spectateTrade($(this).data());
+ });
+ }
+
+ static _disableTradingButton(publicTradeId) {
+ const message = Array.from(game.messages).find(message => {
+ return getProperty(message.data, CONSTANTS.FLAGS.PUBLIC_TRADE_ID) === publicTradeId;
+ });
+ if (!message) return;
+ const update = this._replaceChatContent(message);
+ return message.update(update)
+ }
+
+ static async disablePastTradingButtons() {
+ if (!game.user.isGM) return;
+
+ const messages = Array.from(game.messages).filter(message => {
+ return getProperty(message.data, CONSTANTS.FLAGS.PUBLIC_TRADE_ID);
+ });
+
+ if (!messages.length) return;
+ const updates = [];
+ for (let message of messages) {
+ const update = this._replaceChatContent(message);
+ const tradeId = getProperty(message.data, CONSTANTS.FLAGS.PUBLIC_TRADE_ID);
+ const tradeUsers = getProperty(message.data, CONSTANTS.FLAGS.TRADE_USERS);
+ const bothUsersActive = tradeUsers.filter(userId => game.users.get(userId).active).length === tradeUsers.length;
+ if (!bothUsersActive) {
+ updates.push(update);
+ } else {
+ const otherUsers = tradeUsers.filter(userId => userId !== game.user.id);
+ const tradeData = await TradeAPI._requestTradeData({ tradeId, tradeUser: otherUsers[0] });
+ if (!tradeData) {
+ updates.push(update);
+ }
+ }
+ }
+
+ if (!updates.length) return;
+
+ return ChatMessage.updateDocuments(updates);
+
+ }
+
+ static _replaceChatContent(message) {
+ const tradeId = getProperty(message.data, CONSTANTS.FLAGS.PUBLIC_TRADE_ID);
+ const stringToFind = `data-trade-id="${tradeId}"`;
+ let content = message.data.content;
+ content = content.replace(stringToFind, "");
+ content = content.replace(stringToFind, "disabled");
+ content = content.replace(game.i18n.localize("ITEM-PILES.Chat.TradeSpectate"), game.i18n.localize("ITEM-PILES.Chat.SpectateDisabled"));
+ return {
+ _id: message.id,
+ content,
+ [`flags.-=${CONSTANTS.MODULE_NAME}`]: null
+ };
+ }
+
+
+ /**
+ * Outputs to chat based on transferring an item from or to an item pile
+ *
+ * @param source
+ * @param target
+ * @param items
+ * @param userId
+ * @param interactionId
+ * @returns {Promise}
+ */
+ static async _outputTransferItem(source, target, items, userId, interactionId) {
+ if (!PileUtilities.isValidItemPile(source)) return;
+ if (!interactionId || game.user.id !== userId || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;
+ const itemData = await this._formatItemData(items);
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.PICKUP_CHAT_MESSAGE, source.uuid, target.uuid, itemData, [], userId, interactionId);
+ }
+
+ /**
+ * Outputs to chat based on transferring a currency from or to an item pile
+ *
+ * @param source
+ * @param target
+ * @param currencies
+ * @param userId
+ * @param interactionId
+ * @returns {Promise}
+ */
+ static async _outputTransferCurrency(source, target, currencies, userId, interactionId) {
+ if (!PileUtilities.isValidItemPile(source)) return;
+ if (!interactionId || game.user.id !== userId || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;
+ const currencyData = this._formatCurrencyData(source, currencies);
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.PICKUP_CHAT_MESSAGE, source.uuid, target.uuid, [], currencyData, userId, interactionId);
+ }
+
+ /**
+ * Outputs to chat based on transferring everything from or to an item pile
+ *
+ * @param source
+ * @param target
+ * @param items
+ * @param currencies
+ * @param userId
+ * @param interactionId
+ * @returns {Promise}
+ */
+ static async _outputTransferEverything(source, target, items, currencies, userId, interactionId) {
+ if (!PileUtilities.isValidItemPile(source)) return;
+ if (!interactionId || game.user.id !== userId || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;
+ const itemData = await this._formatItemData(items);
+ const currencyData = this._formatCurrencyData(source, currencies);
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.PICKUP_CHAT_MESSAGE, source.uuid, target.uuid, itemData, currencyData, userId, interactionId);
+ }
+
+ static _outputSplitItemPileInventory(source, transferData, userId) {
+ if (!PileUtilities.isValidItemPile(source)) return;
+ if (game.user.id !== userId || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.SPLIT_CHAT_MESSAGE, source.uuid, transferData, userId);
+ }
+
+ static async _outputTradeStarted(party_1, party_2, publicTradeId, isPrivate) {
+ if (party_1.user !== game.user.id || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT) || isPrivate) return;
+ return this._outputTradeStartedToChat(party_1, party_2, publicTradeId);
+ }
+
+ static async _outputTradeComplete(party_1, party_2, publicTradeId, isPrivate) {
+ if (!Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;
+ return this._outputTradeCompleteToChat(party_1, party_2, publicTradeId, isPrivate);
+ }
+
+ static async _outputMerchantTradeComplete(source, target, priceInformation, userId, interactionId) {
+ if (!Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;
+ if (!PileUtilities.isItemPileMerchant(source)) return;
+ if (!interactionId || game.user.id !== userId || !Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT)) return;
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.MERCHANT_TRADE_CHAT_MESSAGE, source.uuid, target.uuid, priceInformation, userId, interactionId);
+ }
+
+ /**
+ * Formats item data to a chat friendly structure
+ *
+ * @param items
+ * @returns {Promise}
+ */
+ static async _formatItemData(items) {
+ const formattedItems = [];
+ for (const itemData of items) {
+ const tempItem = await Item.implementation.create(itemData.item, { temporary: true });
+ formattedItems.push({
+ name: game.i18n.localize(tempItem.name),
+ img: itemData.item.img ?? "",
+ quantity: itemData.quantity
+ });
+ }
+ return formattedItems;
+ }
+
+ /**
+ * Formats currency data to a chat friendly structure
+ *
+ * @param itemPile
+ * @param currencies
+ * @returns {Array}
+ */
+ static _formatCurrencyData(itemPile, currencies) {
+ const currencyList = PileUtilities.getActorCurrencies(itemPile);
+ return Object.entries(currencies).map(entry => {
+ const currency = currencyList.find(currency => currency.id === entry[0]);
+ return {
+ name: game.i18n.localize(currency.name),
+ img: currency.img ?? "",
+ quantity: entry[1],
+ index: currencyList.indexOf(currency)
+ }
+ });
+ }
+
+ /**
+ * Outputs the transferred data in chat
+ *
+ * @param sourceUuid
+ * @param targetUuid
+ * @param items
+ * @param currencies
+ * @param userId
+ * @param interactionId
+ * @returns {Promise}
+ */
+ static async _outputPickupToChat(sourceUuid, targetUuid, items, currencies, userId, interactionId) {
+
+ const sourceActor = Utilities.getActor(sourceUuid);
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const now = (+new Date());
+
+ // Get all messages younger than 3 hours, and grab the last 10, then reverse them (latest to oldest)
+ const messages = Array.from(game.messages).filter(message => (now - message.data.timestamp) <= (10800000)).slice(-10);
+ messages.reverse()
+
+ for (let [index, message] of messages.entries()) {
+ const flags = getProperty(message.data, CONSTANTS.FLAGS.PILE);
+ if (flags && flags.source === sourceUuid && flags.target === targetUuid && (flags.interactionId === interactionId || index === 0)) {
+ return this._updateExistingPickupMessage(message, sourceActor, targetActor, items, currencies, interactionId)
+ }
+ }
+
+ const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/chat/looted.html", {
+ message: game.i18n.format("ITEM-PILES.Chat.Pickup", { name: targetActor.name }),
+ itemPile: sourceActor,
+ actor: targetActor,
+ items: items,
+ currencies: currencies
+ });
+
+ return this._createNewChatMessage(userId, {
+ user: game.user.id,
+ type: CONST.CHAT_MESSAGE_TYPES.OTHER,
+ content: chatCardHtml,
+ flavor: "Item Piles",
+ speaker: ChatMessage.getSpeaker({ alias: game.user.name }),
+ [CONSTANTS.FLAGS.PILE]: {
+ source: sourceUuid,
+ target: targetUuid,
+ items: items,
+ currencies: currencies,
+ interactionId: interactionId
+ }
+ })
+
+ }
+
+ static _matchEntries(existingEntries, incomingEntries) {
+
+ const combinedEntries = existingEntries.map(existingEntry => {
+ const foundEntry = incomingEntries.find(item => item.name === existingEntry.name && existingEntry.img === item.img);
+ if (foundEntry) {
+ existingEntry.quantity += foundEntry.quantity;
+ incomingEntries.splice(incomingEntries.indexOf(foundEntry), 1)
+ }
+ return existingEntry;
+ });
+
+ incomingEntries.forEach(item => combinedEntries.push(item));
+
+ return combinedEntries;
+
+ }
+
+ static async _updateExistingPickupMessage(message, sourceActor, targetActor, items, currencies, interactionId) {
+
+ const flags = getProperty(message.data, CONSTANTS.FLAGS.PILE);
+
+ const newItems = this._matchEntries(flags.items, items);
+ const newCurrencies = this._matchEntries(flags.currencies, currencies);
+
+ newCurrencies.sort((a, b) => {
+ return a.index - b.index;
+ })
+
+ const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/chat/looted.html", {
+ message: game.i18n.format("ITEM-PILES.Chat.Pickup", { name: targetActor.name }),
+ itemPile: sourceActor,
+ actor: targetActor,
+ items: newItems,
+ currencies: newCurrencies
+ });
+
+ return message.update({
+ content: chatCardHtml,
+ [`${CONSTANTS.FLAGS.PILE}.interactionId`]: interactionId,
+ [`${CONSTANTS.FLAGS.PILE}.items`]: newItems,
+ [`${CONSTANTS.FLAGS.PILE}.currencies`]: newCurrencies,
+ });
+
+ }
+
+ static async _outputSplitToChat(sourceUuid, transferData, userId) {
+
+ const source = await fromUuid(sourceUuid);
+
+ const sourceActor = source?.actor ?? source;
+
+ const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/chat/looted.html", {
+ message: game.i18n.format("ITEM-PILES.Chat.Split", { num_players: transferData.num_players }),
+ itemPile: sourceActor,
+ items: transferData.items,
+ currencies: transferData.currencies
+ });
+
+ return this._createNewChatMessage(userId, {
+ user: game.user.id,
+ type: CONST.CHAT_MESSAGE_TYPES.OTHER,
+ content: chatCardHtml,
+ flavor: "Item Piles",
+ speaker: ChatMessage.getSpeaker({ alias: game.user.name })
+ });
+
+ }
+
+ static async _outputTradeStartedToChat(party_1, party_2, publicTradeId) {
+
+ const party_1_actor = Utilities.getActor(party_1.actor);
+ const party_2_actor = Utilities.getActor(party_2.actor);
+
+ const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/chat/trade-started.html", {
+ party_1_actor,
+ party_2_actor,
+ publicTradeId,
+ userId: game.user.id
+ });
+
+ return this._createNewChatMessage(game.user.id, {
+ user: game.user.id,
+ type: CONST.CHAT_MESSAGE_TYPES.OTHER,
+ content: chatCardHtml,
+ flavor: "Item Piles",
+ speaker: ChatMessage.getSpeaker({ alias: game.user.name }),
+ [CONSTANTS.FLAGS.PUBLIC_TRADE_ID]: publicTradeId,
+ [CONSTANTS.FLAGS.TRADE_USERS]: [party_1.user, party_2.user]
+ });
+ }
+
+ static async _outputTradeCompleteToChat(party_1, party_2, publicTradeId, isPrivate) {
+
+ if (party_1.user !== game.user.id) return;
+
+ let party_1_actor = await fromUuid(party_1.actor);
+ party_1_actor = party_1_actor?.actor ?? party_1_actor;
+ const party_1_data = {
+ actor: party_1_actor,
+ items: party_2.items,
+ currencies: party_2.currencies
+ }
+ party_1_data.got_nothing = !party_1_data.items.length && !party_1_data.currencies.length;
+
+ let party_2_actor = await fromUuid(party_2.actor);
+ party_2_actor = party_2_actor?.actor ?? party_2_actor;
+ const party_2_data = {
+ actor: party_2_actor,
+ items: party_1.items,
+ currencies: party_1.currencies
+ }
+ party_2_data.got_nothing = !party_2_data.items.length && !party_2_data.currencies.length;
+
+ if (party_1.got_nothing && party_2.got_nothing) return;
+
+ const enableCollapse = (party_1_data.items.length + party_1_data.currencies.length + party_2_data.items.length + party_2_data.currencies.length) > 6;
+
+ const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/chat/trade-complete.html", {
+ party_1: party_1_data,
+ party_2: party_2_data,
+ publicTradeId,
+ isPrivate,
+ enableCollapse
+ });
+
+ return this._createNewChatMessage(game.user.id, {
+ user: game.user.id,
+ type: isPrivate ? CONST.CHAT_MESSAGE_TYPES.WHISPER : CONST.CHAT_MESSAGE_TYPES.OTHER,
+ content: chatCardHtml,
+ flavor: "Item Piles" + (isPrivate ? ": " + game.i18n.localize("ITEM-PILES.Chat.PrivateTrade") : ""),
+ speaker: ChatMessage.getSpeaker({ alias: game.user.name }),
+ whisper: isPrivate ? [party_2.user] : []
+ });
+
+ }
+
+ static async _outputMerchantTradeToChat(sourceUuid, targetUuid, priceInformation, userId, interactionId) {
+
+ const sourceActor = Utilities.getActor(sourceUuid);
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const newItems = priceInformation.buyerReceive;
+
+ const now = (+new Date());
+
+ // Get all messages younger than 3 hours, and grab the last 10, then reverse them (latest to oldest)
+ const messages = Array.from(game.messages).filter(message => (now - message.data.timestamp) <= (10800000)).slice(-10);
+ messages.reverse()
+
+ for (let [index, message] of messages.entries()) {
+ const flags = getProperty(message.data, CONSTANTS.FLAGS.PILE);
+ if (flags && flags.source === sourceUuid && flags.target === targetUuid && (flags.interactionId === interactionId || index === 0)) {
+ return this._updateExistingMerchantMessage(message, sourceActor, targetActor, newItems, interactionId)
+ }
+ }
+
+ const pileData = PileUtilities.getActorFlagData(sourceActor);
+
+ const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/chat/merchant-traded.html", {
+ message: game.i18n.format("ITEM-PILES.Chat.MerchantTraded", {
+ name: targetActor.name,
+ merchant: sourceActor.name
+ }),
+ merchant: {
+ name: sourceActor.name,
+ img: pileData.merchantImage || sourceActor.img
+ },
+ actor: targetActor,
+ items: newItems
+ });
+
+ return this._createNewChatMessage(userId, {
+ user: game.user.id,
+ type: CONST.CHAT_MESSAGE_TYPES.OTHER,
+ content: chatCardHtml,
+ flavor: "Item Piles",
+ speaker: ChatMessage.getSpeaker({ alias: game.user.name }),
+ [CONSTANTS.FLAGS.PILE]: {
+ source: sourceUuid,
+ target: targetUuid,
+ items: newItems,
+ interactionId: interactionId
+ }
+ })
+
+ }
+
+ static async _updateExistingMerchantMessage(message, sourceActor, targetActor, newItems, interactionId) {
+
+ const flags = getProperty(message.data, CONSTANTS.FLAGS.PILE);
+
+ const mergedItems = this._matchEntries(flags.items, newItems);
+
+ const pileData = PileUtilities.getActorFlagData(sourceActor);
+
+ const chatCardHtml = await renderTemplate(CONSTANTS.PATH + "templates/chat/merchant-traded.html", {
+ message: game.i18n.format("ITEM-PILES.Chat.MerchantTraded", {
+ name: targetActor.name,
+ merchant: sourceActor.name
+ }),
+ merchant: {
+ name: sourceActor.name,
+ img: pileData.merchantImage || sourceActor.img
+ },
+ actor: targetActor,
+ items: mergedItems
+ });
+
+ return message.update({
+ content: chatCardHtml,
+ [`${CONSTANTS.FLAGS.PILE}.interactionId`]: interactionId,
+ [`${CONSTANTS.FLAGS.PILE}.items`]: mergedItems
+ });
+
+ }
+
+ static _createNewChatMessage(userId, chatData) {
+
+ if (!chatData.whisper) {
+
+ const mode = Helpers.getSetting(SETTINGS.OUTPUT_TO_CHAT);
+
+ if (mode > 1) {
+ chatData.whisper = Array.from(game.users)
+ .filter(user => user.isGM)
+ .map(user => user.id);
+ if (mode === 2) {
+ chatData.whisper.push(userId);
+ }
+ chatData.type = CONST.CHAT_MESSAGE_TYPES.WHISPER;
+ }
+
+ }
+
+ return ChatMessage.create(chatData);
+
+ }
+
+}
\ No newline at end of file
diff --git a/src/API/private-api.js b/src/API/private-api.js
new file mode 100644
index 00000000..02afaf2d
--- /dev/null
+++ b/src/API/private-api.js
@@ -0,0 +1,1457 @@
+import * as Helpers from "../helpers/helpers.js";
+import * as Utilities from "../helpers/utilities.js";
+import * as PileUtilities from "../helpers/pile-utilities.js";
+import * as SharingUtilities from "../helpers/sharing-utilities.js";
+import HOOKS from "../constants/hooks.js";
+import ItemPileSocket from "../socket.js";
+import SETTINGS from "../constants/settings.js";
+import CONSTANTS from "../constants/constants.js";
+import { hotkeyState } from "../hotkeys.js";
+import DropItemDialog from "../applications/dialogs/drop-item-dialog/drop-item-dialog.js";
+import { ItemPileInventoryApp } from "../applications/item-pile-inventory-app/item-pile-inventory-app.js";
+import Transaction from "../helpers/transaction.js";
+import ItemPileStore from "../stores/item-pile-store.js";
+import MerchantApp from "../applications/merchant-app/merchant-app.js";
+import { SYSTEMS } from "../systems.js";
+
+const preloadedFiles = new Set();
+
+export default class PrivateAPI {
+
+ /**
+ * Initializes the API for Foundry's core hooks
+ */
+ static initialize() {
+ Helpers.hooks.on("canvasReady", this._onCanvasReady.bind(this));
+ Helpers.hooks.on("createItem", this._onCreateItem.bind(this));
+ Helpers.hooks.on("updateItem", this._onUpdateItem.bind(this));
+ Helpers.hooks.on("deleteItem", this._onDeleteItem.bind(this));
+ Helpers.hooks.on("updateActor", this._onUpdateActor.bind(this));
+ Helpers.hooks.on("deleteToken", this._onDeleteToken.bind(this));
+ Helpers.hooks.on("deleteActor", this._onDeleteActor.bind(this));
+ Helpers.hooks.on("preCreateToken", this._onPreCreateToken.bind(this))
+ Helpers.hooks.on("createToken", this._onCreateToken.bind(this))
+ Helpers.hooks.on("dropCanvasData", this._dropData.bind(this));
+ }
+
+ /**
+ * @private
+ */
+ static async _onCanvasReady(canvas) {
+ const tokens = [...canvas.tokens.placeables].map(token => token.document);
+ for (const doc of tokens) {
+ await this._preloadItemPileFiles(doc);
+ }
+ }
+
+ /**
+ * @private
+ */
+ static _onCreateItem(doc) {
+ if (!doc.parent) return;
+ ItemPileStore.notifyChanges("createItem", doc.parent, doc);
+ if (!PileUtilities.isValidItemPile(doc.parent)) return;
+ this._evaluateItemPileChange(doc.parent);
+ }
+
+ /**
+ * @private
+ */
+ static _onUpdateItem(doc) {
+ if (!doc.parent) return;
+ if (!PileUtilities.isValidItemPile(doc.parent)) return;
+ this._evaluateItemPileChange(doc.parent);
+ }
+
+ /**
+ * @private
+ */
+ static _onDeleteItem(doc) {
+ if (!doc.parent) return;
+ ItemPileStore.notifyChanges("deleteItem", doc.parent, doc);
+ if (!PileUtilities.isValidItemPile(doc.parent)) return;
+ this._evaluateItemPileChange(doc.parent);
+ }
+
+ /**
+ * @private
+ */
+ static _onUpdateActor(doc, changes) {
+ if (!PileUtilities.isValidItemPile(doc)) return;
+ this._evaluateItemPileChange(doc, changes);
+ }
+
+ /**
+ * @private
+ */
+ static _onDeleteToken(doc) {
+ ItemPileStore.notifyChanges("delete", doc.actor)
+ if (!PileUtilities.isValidItemPile(doc)) return;
+ Helpers.hooks.callAll(HOOKS.PILE.DELETE, doc);
+ }
+
+ /**
+ * @private
+ */
+ static _onDeleteActor(doc) {
+ ItemPileStore.notifyChanges("delete", doc)
+ }
+
+ /**
+ * @private
+ */
+ static _onPreCreateToken(doc) {
+ if (!doc.isLinked) {
+ doc.data.update({
+ [`actorData.flags.${CONSTANTS.MODULE_NAME}.-=sharing`]: null
+ });
+ }
+ const itemPileConfig = PileUtilities.getActorFlagData(doc.actor)
+ if (itemPileConfig.closedImage.includes("*")) {
+ itemPileConfig.closedImage = Helpers.random_array_element(itemPileConfig.closedImages);
+ itemPileConfig.closedImages = [];
+ }
+ if (itemPileConfig.emptyImage.includes("*")) {
+ itemPileConfig.emptyImage = Helpers.random_array_element(itemPileConfig.emptyImages);
+ itemPileConfig.emptyImages = [];
+ }
+ if (itemPileConfig.openedImage.includes("*")) {
+ itemPileConfig.openedImage = Helpers.random_array_element(itemPileConfig.openedImages);
+ itemPileConfig.openedImages = [];
+ }
+ if (itemPileConfig.lockedImage.includes("*")) {
+ itemPileConfig.lockedImage = Helpers.random_array_element(itemPileConfig.lockedImages);
+ itemPileConfig.lockedImages = [];
+ }
+ const targetItems = PileUtilities.getActorItems(doc.actor);
+ const targetCurrencies = PileUtilities.getActorCurrencies(doc.actor);
+ const data = { data: itemPileConfig, items: targetItems, currencies: targetCurrencies };
+ doc.data.update({
+ "img": PileUtilities.getItemPileTokenImage(doc, data),
+ "scale": PileUtilities.getItemPileTokenScale(doc, data),
+ "name": PileUtilities.getItemPileName(doc, data),
+ [CONSTANTS.FLAGS.PILE]: itemPileConfig,
+ ["actorData." + CONSTANTS.FLAGS.PILE]: itemPileConfig
+ });
+ }
+
+ /**
+ * @private
+ */
+ static _onCreateToken(doc) {
+ if (!PileUtilities.isValidItemPile(doc)) return;
+ const itemPileConfig = PileUtilities.getActorFlagData(doc.actor)
+ Helpers.hooks.callAll(HOOKS.PILE.CREATE, doc, itemPileConfig);
+ return this._preloadItemPileFiles(doc);
+ }
+
+ static async _addItems(targetUuid, items, userId, { interactionId = false } = {}) {
+
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const transaction = new Transaction(targetActor);
+
+ await transaction.appendItemChanges(items);
+
+ const { itemsToUpdate, itemsToCreate } = transaction.prepare(); // Prepare data
+
+ const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_ADD, targetActor, itemsToCreate, itemsToUpdate, userId);
+ if (hookResult === false) return false; // Call pre-hook to allow user to interrupt it
+
+ const { itemDeltas } = await transaction.commit(); // Actually add the items to the actor
+
+ await ItemPileSocket.callHook(HOOKS.ITEM.ADD, targetUuid, itemDeltas, userId, interactionId);
+
+ await this._executeItemPileMacro(targetUuid, {
+ action: "addItems", target: targetUuid, items: itemDeltas, userId: userId, interactionId: interactionId
+ });
+
+ return itemDeltas;
+
+ }
+
+ static async _removeItems(targetUuid, items, userId, { interactionId = false } = {}) {
+
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const transaction = new Transaction(targetActor);
+
+ await transaction.appendItemChanges(items, { remove: true });
+
+ const { itemsToUpdate, itemsToDelete } = transaction.prepare();
+
+ const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_REMOVE, targetActor, itemsToUpdate, itemsToDelete, userId);
+ if (hookResult === false) return false;
+
+ const { itemDeltas } = await transaction.commit();
+
+ await ItemPileSocket.callHook(HOOKS.ITEM.REMOVE, targetUuid, itemDeltas, userId, interactionId);
+
+ await this._executeItemPileMacro(targetUuid, {
+ action: "removeItems", target: targetUuid, items: itemDeltas, userId: userId, interactionId: interactionId
+ });
+
+ const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(targetUuid);
+ if (shouldBeDeleted) {
+ await this._deleteItemPile(targetUuid);
+ }
+
+ return itemDeltas;
+
+ }
+
+ static async _transferItems(sourceUuid, targetUuid, items, userId, { interactionId = false } = {}) {
+
+ const sourceActor = Utilities.getActor(sourceUuid);
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const sourceTransaction = new Transaction(sourceActor);
+ await sourceTransaction.appendItemChanges(items, { remove: true });
+ const sourceUpdates = sourceTransaction.prepare();
+
+ const targetTransaction = new Transaction(targetActor);
+ await targetTransaction.appendItemChanges(sourceUpdates.itemDeltas);
+ const targetUpdates = targetTransaction.prepare();
+
+ const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_TRANSFER, sourceActor, sourceUpdates, targetActor, targetUpdates, userId);
+ if (hookResult === false) return false;
+
+ await sourceTransaction.commit();
+ const { itemDeltas } = await targetTransaction.commit();
+
+ await ItemPileSocket.callHook(HOOKS.ITEM.TRANSFER, sourceUuid, targetUuid, itemDeltas, userId, interactionId);
+
+ const macroData = {
+ action: "transferItems",
+ source: sourceUuid,
+ target: targetUuid,
+ items: itemDeltas,
+ userId: userId,
+ interactionId: interactionId
+ };
+
+ await this._executeItemPileMacro(sourceUuid, macroData);
+ await this._executeItemPileMacro(targetUuid, macroData);
+
+ const itemPile = Utilities.getToken(sourceUuid);
+
+ const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);
+ if (shouldBeDeleted) {
+ await this._deleteItemPile(sourceUuid);
+ } else if (PileUtilities.isItemPileEmpty(itemPile)) {
+ await SharingUtilities.clearItemPileSharingData(itemPile);
+ } else {
+ await SharingUtilities.setItemPileSharingData(sourceUuid, targetUuid, {
+ items: itemDeltas
+ });
+ }
+
+ return itemDeltas;
+
+ }
+
+ static async _transferAllItems(sourceUuid, targetUuid, userId, { itemFilters = false, interactionId = false } = {}) {
+
+ const sourceActor = Utilities.getActor(sourceUuid);
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const itemsToTransfer = PileUtilities.getActorItems(sourceActor, { itemFilters }).map(item => item.toObject());
+
+ const sourceTransaction = new Transaction(sourceActor);
+ await sourceTransaction.appendItemChanges(itemsToTransfer, { remove: true });
+ const sourceUpdates = sourceTransaction.prepare();
+
+ const targetTransaction = new Transaction(targetActor);
+ await targetTransaction.appendItemChanges(sourceUpdates.itemDeltas);
+ const targetUpdates = targetTransaction.prepare();
+
+ const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_TRANSFER_ALL, sourceActor, sourceUpdates, targetActor, targetUpdates, userId);
+ if (hookResult === false) return false;
+
+ await sourceTransaction.commit();
+ const { itemDeltas } = await targetTransaction.commit();
+
+ await ItemPileSocket.callHook(HOOKS.ITEM.TRANSFER_ALL, sourceUuid, targetUuid, itemDeltas, userId, interactionId);
+
+ const macroData = {
+ action: "transferAllItems",
+ source: sourceUuid,
+ target: targetUuid,
+ items: itemDeltas,
+ userId: userId,
+ interactionId: interactionId
+ };
+ await this._executeItemPileMacro(sourceUuid, macroData);
+ await this._executeItemPileMacro(targetUuid, macroData);
+
+ const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);
+ if (shouldBeDeleted) {
+ await this._deleteItemPile(sourceUuid);
+ }
+
+ return itemDeltas;
+ }
+
+ static async _addAttributes(targetUuid, attributes, userId, { interactionId = false } = {}) {
+
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const transaction = new Transaction(targetActor);
+ await transaction.appendActorChanges(attributes);
+ const { actorUpdates } = transaction.prepare();
+
+ const hookResult = Helpers.hooks.call(HOOKS.ATTRIBUTE.PRE_ADD, targetActor, actorUpdates, interactionId);
+ if (hookResult === false) return false;
+
+ const { attributeDeltas } = await transaction.commit();
+
+ await ItemPileSocket.callHook(HOOKS.ATTRIBUTE.ADD, targetUuid, attributeDeltas, userId, interactionId);
+
+ await this._executeItemPileMacro(targetUuid, {
+ action: "addAttributes",
+ target: targetUuid,
+ attributes: attributeDeltas,
+ userId: userId,
+ interactionId: interactionId
+ });
+
+ return attributeDeltas;
+
+ }
+
+ static async _removeAttributes(targetUuid, attributes, userId, { interactionId = false } = {}) {
+
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const transaction = new Transaction(targetActor);
+ await transaction.appendActorChanges(attributes, { remove: true });
+ const { actorUpdates } = transaction.prepare();
+
+ const hookResult = Helpers.hooks.call(HOOKS.ATTRIBUTE.PRE_REMOVE, targetActor, actorUpdates, interactionId);
+ if (hookResult === false) return false;
+
+ const { attributeDeltas } = await transaction.commit();
+
+ await ItemPileSocket.callHook(HOOKS.ATTRIBUTE.REMOVE, targetUuid, attributeDeltas, userId, interactionId);
+
+ await this._executeItemPileMacro(targetUuid, {
+ action: "removeAttributes",
+ target: targetUuid,
+ attributes: attributeDeltas,
+ userId: userId,
+ interactionId: interactionId
+ });
+
+ const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(targetUuid);
+ if (shouldBeDeleted) {
+ await this._deleteItemPile(targetUuid);
+ }
+
+ return attributeDeltas;
+
+ }
+
+ static async _transferAttributes(sourceUuid, targetUuid, attributes, userId, { interactionId = false } = {}) {
+
+ const sourceActor = Utilities.getActor(sourceUuid);
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const sourceTransaction = new Transaction(sourceActor);
+ await sourceTransaction.appendActorChanges(attributes, { remove: true });
+ const sourceUpdates = sourceTransaction.prepare();
+
+ const targetTransaction = new Transaction(targetActor);
+ await targetTransaction.appendActorChanges(sourceUpdates.attributeDeltas);
+ const targetUpdates = targetTransaction.prepare();
+
+ const hookResult = Helpers.hooks.call(HOOKS.ATTRIBUTE.PRE_TRANSFER, sourceActor, sourceUpdates.actorUpdates, targetActor, targetUpdates.actorUpdates, interactionId);
+ if (hookResult === false) return false;
+
+ await sourceTransaction.commit();
+ const { attributeDeltas } = await targetTransaction.commit();
+
+ await ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.CALL_HOOK, HOOKS.ATTRIBUTE.TRANSFER, sourceUuid, targetUuid, attributeDeltas, userId, interactionId);
+
+ const macroData = {
+ action: "transferAttributes",
+ source: sourceUuid,
+ target: targetUuid,
+ attributes: attributeDeltas,
+ userId: userId,
+ interactionId: interactionId
+ };
+ await this._executeItemPileMacro(sourceUuid, macroData);
+ await this._executeItemPileMacro(targetUuid, macroData);
+
+ const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);
+
+ const itemPile = await fromUuid(sourceUuid)
+
+ if (shouldBeDeleted) {
+ await this._deleteItemPile(sourceUuid);
+ } else if (PileUtilities.isItemPileEmpty(itemPile)) {
+ await SharingUtilities.clearItemPileSharingData(itemPile);
+ } else {
+ await SharingUtilities.setItemPileSharingData(sourceUuid, targetUuid, {
+ attributes: attributeDeltas
+ });
+ }
+
+ return attributeDeltas;
+
+ }
+
+ static async _transferAllAttributes(sourceUuid, targetUuid, userId, { interactionId = false } = {}) {
+
+ const sourceActor = Utilities.getActor(sourceUuid);
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const sourceAttributes = PileUtilities.getActorCurrencies(sourceActor).filter(entry => entry.type === "attribute");
+ const attributesToTransfer = sourceAttributes.filter(attribute => {
+ return hasProperty(targetActor.data, attribute.data.path);
+ }).map(attribute => attribute.data.path);
+
+ const sourceTransaction = new Transaction(sourceActor);
+ await sourceTransaction.appendActorChanges(attributesToTransfer, { remove: true });
+ const sourceUpdates = sourceTransaction.prepare();
+
+ const targetTransaction = new Transaction(targetActor);
+ await targetTransaction.appendActorChanges(sourceUpdates.attributeDeltas);
+ const targetUpdates = targetTransaction.prepare();
+
+ const hookResult = Helpers.hooks.call(HOOKS.ATTRIBUTE.PRE_TRANSFER_ALL, sourceActor, sourceUpdates.actorUpdates, targetActor, targetUpdates.actorUpdates, interactionId);
+ if (hookResult === false) return false;
+
+ await sourceTransaction.commit();
+ const { attributeDeltas } = await targetTransaction.commit();
+
+ await ItemPileSocket.callHook(HOOKS.ATTRIBUTE.TRANSFER_ALL, sourceUuid, targetUuid, attributeDeltas, userId, interactionId);
+
+ const macroData = {
+ action: "transferAllAttributes",
+ source: sourceUuid,
+ target: targetUuid,
+ attributes: attributeDeltas,
+ userId: userId,
+ interactionId: interactionId
+ };
+ await this._executeItemPileMacro(sourceUuid, macroData);
+ await this._executeItemPileMacro(targetUuid, macroData);
+
+ const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);
+
+ if (shouldBeDeleted) {
+ await this._deleteItemPile(sourceUuid);
+ }
+
+ return attributeDeltas;
+
+ }
+
+ static async _transferEverything(sourceUuid, targetUuid, userId, { itemFilters = false, interactionId } = {}) {
+
+ const sourceActor = Utilities.getActor(sourceUuid);
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const itemsToTransfer = PileUtilities.getActorItems(sourceActor, { itemFilters }).map(item => item.toObject());
+
+ const sourceAttributes = PileUtilities.getActorCurrencies(sourceActor).filter(entry => entry.type === "attribute");
+ const attributesToTransfer = sourceAttributes.filter(attribute => {
+ return hasProperty(targetActor.data, attribute.data.path);
+ }).map(attribute => attribute.data.path);
+
+ const sourceTransaction = new Transaction(sourceActor);
+ await sourceTransaction.appendItemChanges(itemsToTransfer, { remove: true });
+ await sourceTransaction.appendActorChanges(attributesToTransfer, { remove: true });
+ const sourceUpdates = sourceTransaction.prepare();
+
+ const targetTransaction = new Transaction(targetActor);
+ await targetTransaction.appendItemChanges(sourceUpdates.itemDeltas);
+ await targetTransaction.appendActorChanges(sourceUpdates.attributeDeltas);
+ const targetUpdates = targetTransaction.prepare();
+
+ const hookResult = Helpers.hooks.call(HOOKS.PRE_TRANSFER_EVERYTHING, sourceActor, sourceUpdates, targetActor, targetUpdates, userId);
+ if (hookResult === false) return false;
+
+ await sourceTransaction.commit();
+ const { itemDeltas, attributeDeltas } = await targetTransaction.commit();
+
+ await ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.CALL_HOOK, HOOKS.TRANSFER_EVERYTHING, sourceUuid, targetUuid, itemDeltas, attributeDeltas, userId, interactionId);
+
+ const macroData = {
+ action: "transferEverything",
+ source: sourceUuid,
+ target: targetUuid,
+ items: itemDeltas,
+ attributes: attributeDeltas,
+ userId: userId,
+ interactionId: interactionId
+ };
+ await this._executeItemPileMacro(sourceUuid, macroData);
+ await this._executeItemPileMacro(targetUuid, macroData);
+
+ const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(sourceUuid);
+ if (shouldBeDeleted) {
+ await this._deleteItemPile(sourceUuid);
+ }
+
+ return {
+ itemsTransferred: itemDeltas, attributesTransferred: attributeDeltas
+ };
+
+ }
+
+ static async _commitActorChanges(actorUuid, actorUpdates, itemsToUpdate, itemsToDelete, itemsToCreate) {
+ const actor = Utilities.getActor(actorUuid);
+ await actor.update(actorUpdates);
+ await actor.updateEmbeddedDocuments("Item", itemsToUpdate);
+ await actor.deleteEmbeddedDocuments("Item", itemsToDelete);
+ const createdItems = await actor.createEmbeddedDocuments("Item", itemsToCreate);
+ return createdItems.map(item => item.toObject());
+ }
+
+ /**
+ * If not given an actor, this method creates an item pile at a location, then adds an item to it.
+ *
+ * If a target was provided, it will just add the item to that target actor.
+ *
+ * If an actor was provided, it will transfer the item from the actor to the target actor.
+ *
+ * @param {String} userId
+ * @param {String} sceneId
+ * @param {String/Boolean} [sourceUuid=false]
+ * @param {String/Boolean} [targetUuid=false]
+ * @param {Object/Boolean} [position=false]
+ * @param {Object} [itemData=false]
+ *
+ * @returns {sourceUuid: string/boolean, targetUuid: string/boolean, position: object/boolean, itemsDropped: array }
+ */
+ static async _dropItems({
+ userId, sceneId, sourceUuid = false, targetUuid = false, itemData = false, position = false
+ } = {}) {
+
+ let itemsDropped;
+
+ // If there's a source of the item (it wasn't dropped from the item bar)
+ if (sourceUuid) {
+
+ const itemsToTransfer = [{ _id: itemData.item._id, quantity: itemData.quantity }];
+
+ // If there's a target token, add the item to it, otherwise create a new pile at the drop location
+ if (targetUuid) {
+ itemsDropped = await this._transferItems(sourceUuid, targetUuid, itemsToTransfer, userId);
+ } else {
+ itemsDropped = (await this._removeItems(sourceUuid, itemsToTransfer, userId)).map(item => {
+ item.quantity = Math.abs(item.quantity)
+ setProperty(item.item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, Math.abs(item.quantity))
+ return item;
+ });
+ targetUuid = await this._createItemPile(sceneId, position, { items: itemsDropped });
+ }
+
+ // If there's no source (it was dropped from the item bar)
+ } else {
+
+ // If there's a target token, add the item to it, otherwise create a new pile at the drop location
+ if (targetUuid) {
+ itemsDropped = await this._addItems(targetUuid, [itemData], userId);
+ } else {
+ targetUuid = await this._createItemPile(sceneId, position, { items: [itemData] });
+ }
+
+ }
+
+ await ItemPileSocket.callHook(HOOKS.ITEM.DROP, sourceUuid, targetUuid, itemsDropped, position);
+
+ return { sourceUuid, targetUuid, position, itemsDropped };
+
+ }
+
+
+ static async _createItemPile(sceneId, position, { pileActorName = false, items = false } = {}) {
+
+ let pileActor;
+
+ if (!pileActorName) {
+
+ pileActor = game.actors.get(Helpers.getSetting(SETTINGS.DEFAULT_ITEM_PILE_ACTOR_ID));
+
+ if (!pileActor) {
+
+ Helpers.custom_notify("A Default Item Pile has been added to your Actors list. You can configure the default look and behavior on it, or duplicate it to create different styles.")
+
+ const pileDataDefaults = foundry.utils.duplicate(CONSTANTS.PILE_DEFAULTS);
+
+ pileDataDefaults.enabled = true;
+ pileDataDefaults.deleteWhenEmpty = "true";
+ pileDataDefaults.displayOne = true;
+ pileDataDefaults.showItemName = true;
+ pileDataDefaults.overrideSingleItemScale = true;
+ pileDataDefaults.singleItemScale = 0.75;
+
+ pileActor = await Actor.create({
+ name: "Default Item Pile",
+ type: Helpers.getSetting("actorClassType"),
+ img: "icons/svg/item-bag.svg",
+ [CONSTANTS.FLAGS.PILE]: pileDataDefaults
+ });
+
+ await pileActor.update({
+ "token": {
+ name: "Item Pile",
+ actorLink: false,
+ bar1: { attribute: "" },
+ vision: false,
+ displayName: 50,
+ [CONSTANTS.FLAGS.PILE]: pileDataDefaults
+ }
+ })
+
+ await game.settings.set(CONSTANTS.MODULE_NAME, "defaultItemPileActorID", pileActor.id);
+
+ }
+
+ } else {
+
+ pileActor = game.actors.getName(pileActorName);
+
+ }
+
+ let overrideData = { ...position };
+
+ const pileData = PileUtilities.getActorFlagData(pileActor);
+
+ if (!pileActor.data.token.actorLink) {
+
+ if (items) {
+ for (let i = 0; i < items.length; i++) {
+ const itemData = items[i]?.item ?? items[i];
+ if (SYSTEMS.DATA.ITEM_TRANSFORMER) {
+ items[i] = await SYSTEMS.DATA.ITEM_TRANSFORMER(itemData);
+ }
+ }
+ } else {
+ items = []
+ }
+
+ items = items ? items.map(item => {
+ return item.item ?? item;
+ }) : [];
+
+ overrideData['actorData'] = {
+ items: items
+ }
+
+ const data = { data: pileData, items: items };
+
+ overrideData = foundry.utils.mergeObject(overrideData, {
+ "img": PileUtilities.getItemPileTokenImage(pileActor, data),
+ "scale": PileUtilities.getItemPileTokenScale(pileActor, data),
+ "name": PileUtilities.getItemPileName(pileActor, data),
+ });
+
+ }
+
+ const tokenData = await pileActor.getTokenData(overrideData);
+
+ const scene = game.scenes.get(sceneId);
+
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_CREATE, tokenData);
+ if (hookResult === false) return false;
+
+ const [tokenDocument] = await scene.createEmbeddedDocuments("Token", [tokenData]);
+
+ return Utilities.getUuid(tokenDocument);
+
+ }
+
+ static async _turnTokensIntoItemPiles(targetUuids, pileSettings = {}, tokenSettings = {}) {
+
+ const tokenUpdateGroups = {};
+ const actorUpdateGroups = {};
+
+ for (const targetUuid of targetUuids) {
+
+ let target = Utilities.fromUuidFast(targetUuid);
+
+ pileSettings = foundry.utils.mergeObject(PileUtilities.getActorFlagData(target), pileSettings);
+ pileSettings.enabled = true;
+
+ const targetItems = PileUtilities.getActorItems(target, { itemFilters: pileSettings.overrideItemFilters });
+ const targetCurrencies = PileUtilities.getActorCurrencies(target, { currencyList: pileSettings.overrideCurrencies });
+
+ const data = { data: pileSettings, items: targetItems, currencies: targetCurrencies };
+
+ tokenSettings = foundry.utils.mergeObject(tokenSettings, {
+ "img": PileUtilities.getItemPileTokenImage(target, data),
+ "scale": PileUtilities.getItemPileTokenScale(target, data),
+ "name": PileUtilities.getItemPileName(target, data)
+ });
+
+ const sceneId = targetUuid.split('.')[1];
+ const tokenId = targetUuid.split('.')[3];
+
+ if (!tokenUpdateGroups[sceneId]) {
+ tokenUpdateGroups[sceneId] = []
+ }
+
+ tokenUpdateGroups[sceneId].push({
+ "_id": tokenId, ...tokenSettings,
+ [CONSTANTS.FLAGS.PILE]: pileSettings,
+ [`actorData.${CONSTANTS.FLAGS.PILE}`]: pileSettings
+ });
+
+ if (target.isLinked) {
+ if (actorUpdateGroups[target.actor.id]) continue;
+ actorUpdateGroups[target.actor.id] = {
+ "_id": target.actor.id, [CONSTANTS.FLAGS.PILE]: pileSettings
+ }
+ }
+ }
+
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_TURN_INTO, tokenUpdateGroups, actorUpdateGroups);
+ if (hookResult === false) return false;
+
+ await Actor.updateDocuments(Object.values(actorUpdateGroups));
+
+ for (const [sceneId, updateData] of Object.entries(tokenUpdateGroups)) {
+ const scene = game.scenes.get(sceneId);
+ await scene.updateEmbeddedDocuments("Token", updateData);
+ }
+
+ await ItemPileSocket.callHook(HOOKS.PILE.TURN_INTO, tokenUpdateGroups, actorUpdateGroups);
+
+ return targetUuids;
+
+ }
+
+ static async _revertTokensFromItemPiles(targetUuids, tokenSettings) {
+
+ const actorUpdateGroups = {};
+ const tokenUpdateGroups = {};
+
+ for (const targetUuid of targetUuids) {
+
+ let target = Utilities.fromUuidFast(targetUuid);
+
+ const pileSettings = PileUtilities.getActorFlagData(target);
+ pileSettings.enabled = false;
+
+ const sceneId = targetUuid.split('.')[1];
+ const tokenId = targetUuid.split('.')[3];
+
+ if (!tokenUpdateGroups[sceneId]) {
+ tokenUpdateGroups[sceneId] = [];
+ }
+
+ tokenUpdateGroups[sceneId].push({
+ "_id": tokenId, ...tokenSettings,
+ [CONSTANTS.FLAGS.PILE]: pileSettings,
+ [`actorData.${CONSTANTS.FLAGS.PILE}`]: pileSettings
+ });
+
+ if (target.isLinked) {
+ if (actorUpdateGroups[target.actor.id]) continue;
+ actorUpdateGroups[target.actor.id] = {
+ "_id": target.actor.id, [CONSTANTS.FLAGS.PILE]: pileSettings
+ }
+ }
+ }
+
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_REVERT_FROM, tokenUpdateGroups, actorUpdateGroups);
+ if (hookResult === false) return false;
+
+ await Actor.updateDocuments(Object.values(actorUpdateGroups));
+
+ for (const [sceneId, updateData] of Object.entries(tokenUpdateGroups)) {
+ const scene = game.scenes.get(sceneId);
+ await scene.updateEmbeddedDocuments("Token", updateData);
+ }
+
+ await ItemPileSocket.callHook(HOOKS.PILE.REVERT_FROM, tokenUpdateGroups, actorUpdateGroups);
+
+ return targetUuids;
+
+ }
+
+ static async _updateItemPile(targetUuid, newData, { interactingTokenUuid = false, tokenSettings = false } = {}) {
+
+ const targetActor = Utilities.getActor(targetUuid);
+ const interactingToken = interactingTokenUuid ? Utilities.getToken(interactingTokenUuid) : false;
+
+ const oldData = PileUtilities.getActorFlagData(targetActor);
+
+ const data = foundry.utils.mergeObject(foundry.utils.duplicate(oldData), foundry.utils.duplicate(newData));
+
+ const diff = foundry.utils.diffObject(oldData, data);
+
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_UPDATE, targetActor, data, interactingToken, tokenSettings);
+ if (hookResult === false) return false;
+
+ await Helpers.wait(15);
+
+ await PileUtilities.updateItemPileData(targetActor, data, tokenSettings);
+
+ if (data.enabled && data.isContainer) {
+ if (diff?.closed === true) {
+ await this._executeItemPileMacro(targetUuid, {
+ action: "closeItemPile", source: interactingTokenUuid, target: targetUuid
+ });
+ }
+ if (diff?.locked === true) {
+ await this._executeItemPileMacro(targetUuid, {
+ action: "lockItemPile", source: interactingTokenUuid, target: targetUuid
+ });
+ }
+ if (diff?.locked === false) {
+ await this._executeItemPileMacro(targetUuid, {
+ action: "unlockItemPile", source: interactingTokenUuid, target: targetUuid
+ });
+ }
+ if (diff?.closed === false) {
+ await this._executeItemPileMacro(targetUuid, {
+ action: "openItemPile", source: interactingTokenUuid, target: targetUuid
+ });
+ }
+ }
+
+ return ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.UPDATED_PILE, targetUuid, diff, interactingTokenUuid);
+ }
+
+ static _updatedItemPile(targetUuid, diffData, interactingTokenUuid) {
+
+ const target = Utilities.getToken(targetUuid);
+
+ const interactingToken = interactingTokenUuid ? Utilities.fromUuidFast(interactingTokenUuid) : false;
+
+ if (foundry.utils.isObjectEmpty(diffData)) return false;
+
+ const data = PileUtilities.getActorFlagData(target);
+
+ Helpers.hooks.callAll(HOOKS.PILE.UPDATE, target, diffData, interactingToken)
+
+ if (data.enabled && data.isContainer) {
+ if (diffData?.closed === true) {
+ Helpers.hooks.callAll(HOOKS.PILE.CLOSE, target, interactingToken)
+ }
+ if (diffData?.locked === true) {
+ Helpers.hooks.callAll(HOOKS.PILE.LOCK, target, interactingToken)
+ }
+ if (diffData?.locked === false) {
+ Helpers.hooks.callAll(HOOKS.PILE.UNLOCK, target, interactingToken)
+ }
+ if (diffData?.closed === false) {
+ Helpers.hooks.callAll(HOOKS.PILE.OPEN, target, interactingToken)
+ }
+ }
+ }
+
+ static async _deleteItemPile(targetUuid) {
+ const target = Utilities.getToken(targetUuid);
+ if (!target) return false;
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_DELETE, target);
+ if (hookResult === false) return false;
+ return target.document.delete();
+ }
+
+ /* -------- PRIVATE ITEM PILE METHODS -------- */
+
+ /**
+ * Checks whether a given item pile would need to update its images, text, and/or scale
+ *
+ * @param {foundry.abstract.Document} doc
+ * @param [changes]
+ * @returns {*}
+ * @private
+ */
+ static _evaluateItemPileChange(doc, changes) {
+ const target = doc?.token ?? doc;
+ if (!Helpers.isResponsibleGM()) return;
+ if (!PileUtilities.isValidItemPile(target)) return;
+ const targetUuid = target.uuid;
+ return Helpers.debounceManager.setDebounce(targetUuid, async (uuid) => {
+ const deleted = PileUtilities.shouldItemPileBeDeleted(uuid);
+ if (deleted) return;
+ await Helpers.hooks.runWithout(async () => {
+ await PileUtilities.updateItemPileData(uuid);
+ });
+ })(targetUuid);
+
+ }
+
+ /**
+ * Pre-loads all images and sounds related to a given token document on the client-side.
+ *
+ * @param {TokenDocument} tokenDocument
+ * @return {Promise}
+ */
+ static async _preloadItemPileFiles(tokenDocument) {
+
+ if (!PileUtilities.isValidItemPile(tokenDocument)) return false;
+
+ const pileData = PileUtilities.getActorFlagData(tokenDocument);
+
+ if (Helpers.getSetting("preloadFiles")) {
+ await Promise.allSettled(Object.entries(pileData).map(entry => {
+ return new Promise(async (resolve) => {
+ const [property, filePath] = entry;
+ if (Array.isArray(filePath)) {
+ return resolve();
+ }
+ const isImage = property.toLowerCase().includes("image");
+ const isSound = property.toLowerCase().includes("sound");
+ if ((!isImage && !isSound) || (!filePath || preloadedFiles.has(filePath))) return resolve();
+ preloadedFiles.add(filePath);
+ if (isImage) {
+ await loadTexture(filePath);
+ Helpers.debug(`Preloaded image: ${filePath}`);
+ } else if (isSound) {
+ Helpers.debug(`Preloaded sound: ${filePath}`);
+ await AudioHelper.preloadSound(filePath);
+ }
+ resolve();
+ });
+ }));
+ }
+
+ Helpers.debug(`Initialized item pile with uuid ${tokenDocument.uuid}`);
+ }
+
+ /**
+ * This executes any macro that is configured on the item pile, providing the macro with extra data relating to the
+ * action that prompted the execution (if the advanced-macros module is installed)
+ *
+ * @param {String} targetUuid
+ * @param {Object} macroData
+ * @return {Promise/Boolean}
+ */
+ static _executeItemPileMacro(targetUuid, macroData) {
+
+ const target = Utilities.getToken(targetUuid);
+
+ if (!PileUtilities.isValidItemPile(target)) return false;
+
+ const pileData = PileUtilities.getActorFlagData(target);
+
+ if (!pileData.macro) return false;
+
+ const macro = game.macros.getName(pileData.macro);
+
+ if (!macro) {
+ throw Helpers.custom_error(`Could not find macro with name "${pileData.macro}" on target with UUID ${target.uuid}`);
+ }
+
+ // Reformat macro data to contain useful information
+ if (macroData.source) {
+ macroData.source = Utilities.fromUuidFast(macroData.source);
+ }
+
+ if (macroData.target) {
+ macroData.target = Utilities.fromUuidFast(macroData.target);
+ }
+
+ const targetActor = macroData.target instanceof TokenDocument ? macroData.target.actor : macroData.target;
+
+ if (macroData.item) {
+ macroData.items = macroData.items.map(item => targetActor.items.get(item._id));
+ }
+
+ return macro.execute([macroData]);
+
+ }
+
+ /**
+ * This handles any dropped data onto the canvas or a set item pile
+ *
+ * @param {canvas} canvas
+ * @param {Object} data
+ * @param {Actor/Token/TokenDocument/Boolean}[target=false]
+ * @return {Promise/Boolean}
+ */
+ static async _dropData(canvas, data, { target = false } = {}) {
+
+ if (data.type !== "Item") return false;
+
+ let item = await Item.implementation.fromDropData(data);
+ let itemData = item.toObject();
+
+ if (!itemData) {
+ console.error(data);
+ throw Helpers.custom_error("Something went wrong when dropping this item!")
+ }
+
+ const dropData = {
+ source: false, target: target, itemData: {
+ item: itemData, quantity: 1
+ }, position: false
+ }
+
+ if (data.tokenId) {
+ dropData.source = canvas.tokens.get(data.tokenId).actor;
+ } else if (data.actorId) {
+ dropData.source = game.actors.get(data.actorId);
+ }
+
+ if (!dropData.source && !game.user.isGM) {
+ return Helpers.custom_warning(game.i18n.localize("ITEM-PILES.Errors.NoSourceDrop"), true)
+ }
+
+ const pre_drop_determined_hook = Helpers.hooks.call(HOOKS.ITEM.PRE_DROP_DETERMINED, dropData.source, dropData.target, dropData.position, dropData.itemData);
+ if (pre_drop_determined_hook === false) return false;
+
+ let action;
+ let droppableDocuments = [];
+ let x;
+ let y;
+
+ if (dropData.target) {
+
+ droppableDocuments.push(dropData.target);
+
+ } else {
+
+ const position = canvas.grid.getTopLeft(data.x, data.y);
+ x = position[0];
+ y = position[1];
+
+ droppableDocuments = Utilities.getTokensAtLocation({ x, y })
+ .map(token => Utilities.getDocument(token))
+ .filter(token => PileUtilities.isValidItemPile(token));
+
+ }
+
+ if (droppableDocuments.length && game.modules.get("midi-qol")?.active && game.settings.get("midi-qol", "DragDropTarget")) {
+ Helpers.custom_warning("You have Drag & Drop Targetting enabled in MidiQOL, which disables drag & drop items")
+ return false;
+ }
+
+ if (droppableDocuments.length > 0 && !game.user.isGM) {
+
+ if (!(droppableDocuments[0] instanceof Actor && dropData.source instanceof Actor)) {
+
+ const sourceToken = canvas.tokens.placeables.find(token => token.actor === dropData.source);
+
+ if (sourceToken) {
+
+ const targetToken = droppableDocuments[0];
+
+ const distance = Math.floor(Utilities.distance_between_rect(sourceToken, targetToken.object) / canvas.grid.size) + 1
+
+ const pileData = PileUtilities.getActorFlagData(targetToken);
+
+ const maxDistance = pileData.distance ? pileData.distance : Infinity;
+
+ if (distance > maxDistance) {
+ Helpers.custom_warning(game.i18n.localize("ITEM-PILES.Errors.PileTooFar"), true);
+ return false;
+ }
+ }
+ }
+
+ droppableDocuments = droppableDocuments.filter(token => !game.itempiles.isItemPileLocked(token));
+
+ if (!droppableDocuments.length) {
+ Helpers.custom_warning(game.i18n.localize("ITEM-PILES.Errors.PileLocked"), true);
+ return false;
+ }
+ }
+
+ const disallowedType = PileUtilities.isItemInvalid(droppableDocuments?.[0], dropData.itemData.item);
+ if (disallowedType) {
+ if (!game.user.isGM) {
+ return Helpers.custom_warning(game.i18n.format("ITEM-PILES.Errors.DisallowedItemDrop", { type: disallowedType }), true)
+ }
+
+ if (SYSTEMS.DATA.ITEM_TRANSFORMER) {
+ dropData.itemData.item = await SYSTEMS.DATA.ITEM_TRANSFORMER(dropData.itemData.item);
+ }
+
+ const newDisallowedType = PileUtilities.isItemInvalid(droppableDocuments?.[0], dropData.itemData.item);
+
+ if (newDisallowedType && !hotkeyState.shiftDown) {
+ const force = await Dialog.confirm({
+ title: game.i18n.localize("ITEM-PILES.Dialogs.TypeWarning.Title"),
+ content: `${game.i18n.format("ITEM-PILES.Dialogs.TypeWarning.DropContent", { type: newDisallowedType })}
`,
+ defaultYes: false
+ });
+ if (!force) {
+ return false;
+ }
+ }
+ } else {
+ if (SYSTEMS.DATA.ITEM_TRANSFORMER) {
+ dropData.itemData.item = await SYSTEMS.DATA.ITEM_TRANSFORMER(dropData.itemData.item);
+ }
+ }
+
+ let newPile = !!droppableDocuments.length;
+
+ if (hotkeyState.altDown) {
+
+ setProperty(dropData.itemData.item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, 1);
+ dropData.itemData.quantity = 1;
+
+ } else {
+
+ const quantity = Utilities.getItemQuantity(dropData.itemData.item);
+
+ let result = { newPile, quantity: 1 }
+ if (quantity > 1) {
+ result = await DropItemDialog.show(item, droppableDocuments[0]);
+ if (!result) return false;
+ newPile = result.newPile;
+ }
+
+ setProperty(dropData.itemData.item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, Number(result.quantity))
+ dropData.itemData.quantity = Number(result.quantity);
+
+ }
+
+ if (newPile) {
+ dropData.position = { x, y };
+ } else {
+ dropData.target = droppableDocuments[0];
+ }
+
+ const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_DROP, dropData.source, dropData.target, dropData.position, dropData.itemData);
+ if (hookResult === false) return false;
+
+ return ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DROP_ITEMS, {
+ userId: game.user.id,
+ sceneId: canvas.scene.id,
+ sourceUuid: Utilities.getUuid(dropData.source),
+ targetUuid: Utilities.getUuid(dropData.target),
+ position: dropData.position,
+ itemData: dropData.itemData
+ });
+
+ }
+
+ static async _itemPileClicked(pileDocument) {
+
+ if (!PileUtilities.isValidItemPile(pileDocument)) return false;
+
+ const pileToken = pileDocument.object;
+
+ if (!Helpers.isGMConnected()) {
+ Helpers.custom_warning(`Item Piles requires a GM to be connected for players to be able to loot item piles.`, true)
+ return false;
+ }
+
+ Helpers.debug(`Clicked: ${pileDocument.uuid}`);
+
+ const pileData = PileUtilities.getActorFlagData(pileDocument);
+
+ const maxDistance = pileData.distance ? pileData.distance : Infinity;
+
+ let validTokens = [];
+
+ if (canvas.tokens.controlled.length > 0) {
+ validTokens = [...canvas.tokens.controlled];
+ validTokens = validTokens.filter(token => token.document !== pileDocument);
+ }
+
+ if (!validTokens.length && !game.user.isGM) {
+ validTokens.push(...canvas.tokens.placeables);
+ if (_token) {
+ validTokens.unshift(_token);
+ }
+ }
+
+ validTokens = validTokens.filter(token => token.owner && token.document !== pileDocument).filter(token => {
+ return Utilities.tokens_close_enough(pileToken, token, maxDistance) || game.user.isGM;
+ });
+
+ if (!validTokens.length && !game.user.isGM && maxDistance !== Infinity) {
+ Helpers.custom_warning(game.i18n.localize("ITEM-PILES.Errors.PileTooFar"), true);
+ return false;
+ }
+
+ let interactingActor;
+ if (validTokens.length) {
+ if (validTokens.includes(_token)) {
+ interactingActor = _token.actor;
+ } else {
+ validTokens.sort((potentialTargetA, potentialTargetB) => {
+ return Utilities.grids_between_tokens(pileToken, potentialTargetA) - Utilities.grids_between_tokens(pileToken, potentialTargetB);
+ })
+ interactingActor = validTokens[0].actor;
+ }
+ } else if (game.user.character && !game.user.isGM) {
+ interactingActor = game.user.character;
+ }
+
+ if (pileData.isContainer && interactingActor) {
+
+ if (pileData.locked && !game.user.isGM) {
+ Helpers.debug(`Attempted to locked item pile with UUID ${pileDocument.uuid}`);
+ return game.itempiles.rattleItemPile(pileDocument, interactingActor);
+ }
+
+ if (pileData.closed) {
+ Helpers.debug(`Opened item pile with UUID ${pileDocument.uuid}`);
+ await game.itempiles.openItemPile(pileDocument, interactingActor);
+ }
+
+ }
+
+ return this._renderItemPileInterface(pileDocument.uuid, { inspectingTargetUuid: interactingActor?.uuid });
+
+ }
+
+ static async _splitItemPileContents(itemPileUuid, actorUuids, userId, instigator) {
+
+ const itemPileActor = Utilities.getActor(itemPileUuid);
+
+ const items = PileUtilities.getActorItems(itemPileActor);
+ const currencies = PileUtilities.getActorCurrencies(itemPileActor);
+
+ const pileData = PileUtilities.getActorFlagData(itemPileActor);
+ const shareData = SharingUtilities.getItemPileSharingData(itemPileActor);
+
+ const pileTransaction = new Transaction(itemPileActor);
+
+ const transactionMap = actorUuids.map(uuid => {
+ return [uuid, new Transaction(Utilities.getActor(uuid))];
+ });
+
+ if (pileData.shareItemsEnabled) {
+ await pileTransaction.appendItemChanges(items, { remove: true });
+ }
+
+ if (pileData.shareCurrenciesEnabled) {
+ const currencyItems = currencies.filter(entry => entry.type === "item");
+ await pileTransaction.appendItemChanges(currencyItems, { remove: true, type: "currency" });
+
+ const attributes = currencies.filter(entry => entry.type === "attribute");
+ await pileTransaction.appendActorChanges(attributes, { remove: true });
+ }
+
+ const preparedData = pileTransaction.prepare();
+
+ for (const [uuid, transaction] of transactionMap) {
+ if (pileData.shareItemsEnabled) {
+ await transaction.appendItemChanges(preparedData.itemDeltas.filter(delta => delta.type === "item").map(delta => {
+ delta.quantity = SharingUtilities.getItemSharesLeftForActor(itemPileActor, delta.item, uuid, {
+ players: actorUuids.length,
+ shareData: shareData,
+ floor: true
+ });
+ return delta;
+ }));
+ }
+
+ if (pileData.shareCurrenciesEnabled) {
+ await transaction.appendItemChanges(preparedData.itemDeltas.filter(delta => delta.type === "currency").map(delta => {
+ delta.quantity = SharingUtilities.getItemSharesLeftForActor(itemPileActor, delta.item, uuid, {
+ players: actorUuids.length,
+ shareData: shareData,
+ floor: true
+ });
+ return delta;
+ }), { type: "currency" });
+
+ await transaction.appendActorChanges(Object.entries(preparedData.attributeDeltas).map(entry => {
+ let [path] = entry;
+ const quantity = SharingUtilities.getAttributeSharesLeftForActor(itemPileActor, path, uuid, {
+ players: actorUuids.length,
+ shareData: shareData,
+ floor: true
+ });
+ return { path, quantity };
+ }));
+ }
+ }
+
+ const actorPreparedData = Object.fromEntries(transactionMap.map(entry => [entry[0], entry[1].prepare()]));
+
+ const hookResult = Helpers.hooks.call(HOOKS.PILE.PRE_SPLIT_INVENTORY, itemPileActor, preparedData, actorPreparedData, userId, instigator);
+ if (hookResult === false) return false;
+
+ const pileDeltas = await pileTransaction.commit();
+ const actorDeltas = {};
+ for (const [uuid, transaction] of transactionMap) {
+ actorDeltas[uuid] = await transaction.commit();
+ }
+
+ await SharingUtilities.clearItemPileSharingData(itemPileActor);
+
+ await ItemPileSocket.callHook(HOOKS.PILE.SPLIT_INVENTORY, itemPileUuid, pileDeltas, actorDeltas, userId, instigator);
+
+ await this._executeItemPileMacro(itemPileUuid, {
+ action: "splitInventory",
+ source: itemPileUuid,
+ target: actorUuids,
+ transfers: {
+ pileDeltas,
+ actorDeltas
+ },
+ userId: userId,
+ instigator: instigator
+ });
+
+ const shouldBeDeleted = PileUtilities.shouldItemPileBeDeleted(itemPileUuid);
+ if (shouldBeDeleted) {
+ await this._deleteItemPile(itemPileUuid);
+ }
+
+ return {
+ pileDeltas,
+ actorDeltas
+ };
+
+ }
+
+ static async _updateTokenHud() {
+ if (!canvas.tokens.hud.rendered) return;
+ return canvas.tokens.hud.render(true);
+ }
+
+ static async _renderItemPileInterface(targetUuid, {
+ inspectingTargetUuid = false, useDefaultCharacter = false, remote = false
+ } = {}) {
+
+ const target = Utilities.getActor(targetUuid);
+
+ let inspectingTarget;
+ if (useDefaultCharacter && !game.user.isGM) {
+ inspectingTarget = game.user.character;
+ } else {
+ inspectingTarget = inspectingTargetUuid ? Utilities.fromUuidFast(inspectingTargetUuid) : false;
+ }
+
+ const merchant = PileUtilities.isItemPileMerchant(target);
+ if (merchant) {
+ return MerchantApp.show(target, inspectingTarget)
+ }
+
+ return ItemPileInventoryApp.show(target, inspectingTarget, { remote });
+
+ }
+
+ static async _tradeItems(sellerUuid, buyerUuid, items, userId, {
+ interactionId = false
+ } = {}) {
+
+ const sellingActor = Utilities.getActor(sellerUuid);
+ const buyingActor = Utilities.getActor(buyerUuid);
+
+ const itemPrices = PileUtilities.getPricesForItems(items.map(data => ({
+ ...data,
+ item: sellingActor.items.get(data.id)
+ })), { seller: sellingActor, buyer: buyingActor });
+
+ const preCalcHookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_CALC_TRADE, sellingActor, buyingActor, itemPrices, userId);
+ if (preCalcHookResult === false) return false;
+
+ const sellerTransaction = new Transaction(sellingActor);
+ const sellerFlagData = PileUtilities.getActorFlagData(sellerTransaction);
+ const sellerInfiniteQuantity = sellerFlagData.enabled && sellerFlagData.merchant && sellerFlagData.infiniteQuantity;
+ const sellerInfiniteCurrencies = sellerFlagData.enabled && sellerFlagData.merchant && sellerFlagData.infiniteCurrencies;
+
+ for (const payment of itemPrices.sellerReceive) {
+ if (!payment.quantity) continue;
+ if (payment.type === "attribute") {
+ await sellerTransaction.appendActorChanges([{
+ path: payment.data.path,
+ quantity: payment.quantity
+ }], { type: payment.isCurrency ? "currency" : payment.type });
+ } else {
+ await sellerTransaction.appendItemChanges([{
+ item: payment.data.item,
+ quantity: payment.quantity
+ }], { type: payment.isCurrency ? "currency" : payment.type });
+ }
+ }
+
+ for (const entry of itemPrices.buyerReceive) {
+ if (!entry.quantity || (sellerInfiniteCurrencies && entry.isCurrency) || (sellerInfiniteQuantity && !entry.isCurrency)) {
+ continue;
+ }
+ if (entry.type === "attribute") {
+ await sellerTransaction.appendActorChanges([{
+ path: entry.data.path,
+ quantity: entry.quantity
+ }], { remove: true, type: entry.isCurrency ? "currency" : entry.type });
+ } else {
+ await sellerTransaction.appendItemChanges([{
+ item: entry.item,
+ quantity: entry.quantity
+ }], { remove: true, type: entry.isCurrency ? "currency" : entry.type });
+ }
+ }
+
+ const buyerTransaction = new Transaction(buyingActor);
+ const buyerFlagData = PileUtilities.getActorFlagData(buyingActor);
+ const buyerIsMerchant = buyerFlagData.enabled && buyerFlagData.isMerchant;
+ const buyerInfiniteCurrencies = buyerIsMerchant && buyerFlagData.infiniteCurrencies;
+ const buyerInfiniteQuantity = buyerIsMerchant && buyerFlagData.infiniteQuantity;
+ const buyerHidesNewItems = buyerIsMerchant && buyerFlagData.hideNewItems;
+
+ for (const price of itemPrices.finalPrices) {
+ if (!price.quantity || (buyerInfiniteCurrencies && price.isCurrency) || (buyerInfiniteQuantity && !price.isCurrency)) {
+ continue;
+ }
+ if (price.type === "attribute") {
+ await buyerTransaction.appendActorChanges([{
+ path: price.data.path,
+ quantity: price.quantity
+ }], { remove: true, type: price.isCurrency ? "currency" : price.type });
+ } else {
+ await buyerTransaction.appendItemChanges([{
+ item: price.data.item,
+ quantity: price.quantity
+ }], { remove: true, type: price.isCurrency ? "currency" : price.type });
+ }
+ }
+
+ for (const entry of itemPrices.buyerReceive) {
+ if (!entry.quantity) continue;
+ if (entry.type === "attribute") {
+ await buyerTransaction.appendActorChanges([{
+ path: entry.data.path,
+ quantity: entry.quantity
+ }], { type: entry.type });
+ } else {
+ const item = entry.item.toObject();
+ if (buyerHidesNewItems) {
+ setProperty(item, CONSTANTS.FLAGS.ITEM + '.hidden', true);
+ }
+ await buyerTransaction.appendItemChanges([{
+ item: item,
+ quantity: entry.quantity
+ }], { type: entry.type });
+ }
+ }
+
+ for (const change of itemPrices.buyerChange) {
+ if (!change.quantity) continue;
+ if (change.type === "attribute") {
+ await buyerTransaction.appendActorChanges([{
+ path: change.data.path,
+ quantity: change.quantity
+ }], { type: "currency" });
+ } else {
+ await buyerTransaction.appendItemChanges([{
+ item: change.item,
+ quantity: change.quantity
+ }], { type: "currency" });
+ }
+ }
+
+ const sellerUpdates = sellerTransaction.prepare();
+ const buyerUpdates = buyerTransaction.prepare();
+
+ const hookResult = Helpers.hooks.call(HOOKS.ITEM.PRE_TRADE, sellingActor, sellerUpdates, buyingActor, buyerUpdates, userId);
+ if (hookResult === false) return false;
+
+ await sellerTransaction.commit();
+ const { itemDeltas, attributeDeltas } = await buyerTransaction.commit();
+
+ await ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.CALL_HOOK, HOOKS.ITEM.TRADE, sellerUuid, buyerUuid, itemPrices, userId, interactionId);
+
+ return { itemDeltas, attributeDeltas, itemPrices };
+
+ }
+
+}
\ No newline at end of file
diff --git a/src/API/trade-api.js b/src/API/trade-api.js
new file mode 100644
index 00000000..63c5d38c
--- /dev/null
+++ b/src/API/trade-api.js
@@ -0,0 +1,446 @@
+import { TJSDialog } from "@typhonjs-fvtt/runtime/svelte/application";
+import CustomDialog from "../applications/components/CustomDialog.svelte";
+import { TradePromptDialog, TradeRequestDialog } from "../applications/trade-dialogs/trade-dialogs.js";
+
+import ItemPileSocket from "../socket.js";
+import * as Helpers from "../helpers/helpers.js";
+import * as Utilities from "../helpers/utilities.js";
+import HOOKS from "../constants/hooks.js";
+import TradeStore from "../applications/trading-app/trade-store.js";
+import TradingApp from "../applications/trading-app/trading-app.js";
+import PrivateAPI from "./private-api.js";
+import Transaction from "../helpers/transaction.js";
+import { isGMConnected } from "../helpers/helpers.js";
+
+const mutedUsers = new Set();
+const ongoingTrades = new Map();
+
+export default class TradeAPI {
+
+ static initialize() {
+ Hooks.on("renderPlayerList", this._userDisconnected.bind(this));
+ }
+
+ static async _requestTrade(user = false) {
+
+ // Grab all the active users (not self)
+ const users = game.users.filter(user => user.active && user !== game.user);
+
+ // No users!
+ if (!users.length) {
+ return TJSDialog.prompt({
+ title: game.i18n.localize("ITEM-PILES.Trade.Title"), content: {
+ class: CustomDialog, props: {
+ header: game.i18n.localize("ITEM-PILES.Trade.NoActiveUsers.Title"),
+ content: game.i18n.localize("ITEM-PILES.Trade.NoActiveUsers.Content"),
+ icon: "fas fa-heart-broken"
+ }
+ }, modal: true, draggable: false, options: {
+ height: "auto"
+ }
+ });
+ }
+
+ let userId;
+ let actor;
+ let isPrivate;
+
+ // Find actors you own
+ const actors = game.actors.filter(actor => actor.isOwner);
+
+ // If you only own one actor, and the user was already preselected (through the right click menu in the actors list)
+ if (actors.length === 1 && user) {
+ userId = user.id;
+ actor = actors[0];
+ isPrivate = false;
+ } else {
+ // If you have more than 1 owned actor, prompt to choose which one
+ const result = await TradePromptDialog.show({ actors, users, user });
+ if (!result) return;
+ userId = result.user.id;
+ actor = result.actor;
+ isPrivate = result.private;
+ }
+
+ if (!actor) return false;
+
+ actor = actor?.actor ?? actor;
+
+ const actorOwner = game.users.find(user => user.character === actor && user !== game.user);
+ if (actorOwner) {
+
+ const doContinue = TJSDialog.confirm({
+ title: game.i18n.localize("ITEM-PILES.Trade.Title"), content: {
+ class: CustomDialog, props: {
+ header: game.i18n.localize("ITEM-PILES.Trade.Title"),
+ content: actorOwner.active ? game.i18n.format("ITEM-PILES.Trade.UserActiveCharacterWarning", {
+ actor_name: actor.name, player_name: actorOwner.name
+ }) : game.i18n.format("ITEM-PILES.Trade.UserCharacterWarning", {
+ actor_name: actor.name, player_name: actorOwner.name
+ }),
+ icon: "fas fa-exclamation-triangle",
+ }
+ }, modal: true, draggable: false, rejectClose: false, defaultYes: true, options: {
+ height: "auto"
+ }
+ });
+ if (!doContinue) {
+ return;
+ }
+ }
+
+ const privateTradeId = randomID();
+ const publicTradeId = randomID();
+
+ // Spawn a cancel dialog
+ const cancelDialog = new Dialog({
+ title: game.i18n.localize("ITEM-PILES.Trade.Title"),
+ content: `${game.i18n.format("ITEM-PILES.Trade.OngoingRequest.Content", { user_name: game.users.get(userId).name })}
`,
+ buttons: {
+ confirm: {
+ icon: ' ',
+ label: game.i18n.localize("ITEM-PILES.Trade.OngoingRequest.Label"),
+ callback: () => {
+ ItemPileSocket.executeAsUser(ItemPileSocket.HANDLERS.TRADE_REQUEST_CANCELLED, userId, game.user.id, privateTradeId);
+ }
+ }
+ }
+ }, {
+ top: 50, width: 300
+ }).render(true);
+
+ // Send out the request
+ return ItemPileSocket.executeAsUser(ItemPileSocket.HANDLERS.TRADE_REQUEST_PROMPT, userId, game.user.id, actor.uuid, privateTradeId, publicTradeId, isPrivate)
+ .then(async (data) => {
+
+ if (data === "cancelled") return;
+ cancelDialog.close();
+
+ // If they declined, show warning
+ if (!data || !data.fullPrivateTradeId.includes(privateTradeId)) {
+ return Helpers.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Declined"), true);
+ }
+
+ const traderActor = Utilities.getActor(data.actorUuid);
+
+ const store = new TradeStore({
+ user: game.user, actor
+ }, {
+ user: game.users.get(userId), actor: traderActor
+ }, data.fullPublicTradeId, data.fullPrivateTradeId, isPrivate);
+
+ const app = new TradingApp(store, this.getAppOptions(actor).tradeApp).render(true);
+
+ ongoingTrades.set(data.fullPublicTradeId, { app, store });
+
+ actor.sheet.render(true, this.getAppOptions(actor).actorSheet);
+
+ if (isPrivate) {
+ return ItemPileSocket.callHookForUsers(HOOKS.TRADE.STARTED, [game.user.id, userId], {
+ user: game.user.id, actor: actor.uuid
+ }, { user: userId, actor: data.actorUuid }, data.fullPublicTradeId, isPrivate);
+ }
+
+ return ItemPileSocket.callHook(HOOKS.TRADE.STARTED, {
+ user: game.user.id, actor: actor.uuid
+ }, { user: userId, actor: data.actorUuid }, data.fullPublicTradeId, isPrivate);
+
+ }).catch((err) => {
+ console.error(err);
+ // If the counterparty disconnected, show that and close dialog
+ Helpers.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Disconnected"), true);
+ cancelDialog.close()
+ });
+
+ }
+
+ static async _respondPrompt(tradingUserId, tradingActorUuid, privateTradeId, publicTradeId, isPrivate) {
+
+ // If the user was previously muted, wait for a random amount of time and respond with false
+ if (mutedUsers.has(tradingUserId)) {
+ await Helpers.wait(Math.random() * 15000);
+ return false;
+ }
+
+ // Complete the private and public trade IDs
+ const fullPrivateTradeId = privateTradeId + randomID();
+ const fullPublicTradeId = publicTradeId + randomID();
+
+ const tradingUser = game.users.get(tradingUserId);
+ let tradingActor = Utilities.fromUuidFast(tradingActorUuid);
+
+ tradingActor = tradingActor?.actor ?? tradingActor;
+
+ // Make em pick an actor (if more than one) and accept/decline/mute
+ const result = await TradeRequestDialog.show({ tradeId: privateTradeId, tradingUser, tradingActor, isPrivate });
+
+ if (!result) return false;
+
+ if (result === "cancelled") {
+ return "cancelled";
+ }
+
+ // If muted, add user to blacklist locally
+ if (result === "mute") {
+ mutedUsers.push(tradingUserId);
+ return false;
+ }
+
+ const actor = result.actor ?? result;
+
+ const store = new TradeStore({ user: game.user, actor }, {
+ user: tradingUser, actor: tradingActor
+ }, fullPublicTradeId, fullPrivateTradeId, isPrivate);
+
+ const app = new TradingApp(store, this.getAppOptions(actor).tradeApp).render(true);
+
+ ongoingTrades.set(fullPublicTradeId, { app, store });
+
+ actor.sheet.render(true, this.getAppOptions(actor).actorSheet);
+
+ return {
+ fullPrivateTradeId, fullPublicTradeId, actorUuid: result.uuid
+ };
+
+ }
+
+ static getAppOptions(actor) {
+ const midPoint = (window.innerWidth / 2) - 200;
+ return {
+ actorSheet: { left: midPoint - actor.sheet.position.width - 25 }, tradeApp: { left: midPoint + 25 }
+ }
+ }
+
+ static async _tradeCancelled(userId, privateTradeId) {
+
+ TJSDialog.prompt({
+ title: game.i18n.localize("ITEM-PILES.Trade.Title"), content: {
+ class: CustomDialog, props: {
+ header: game.i18n.localize("ITEM-PILES.Trade.Title"),
+ content: game.i18n.format("ITEM-PILES.Trade.CancelledRequest.Content", { user_name: game.users.get(userId).name }),
+ icon: "fas fa-exclamation-triangle"
+ }
+ }, modal: true, draggable: false, options: {
+ height: "auto"
+ }
+ });
+
+ return TradeRequestDialog.cancel(privateTradeId);
+
+ }
+
+ static async _requestTradeData({ tradeId, tradeUser } = {}) {
+
+ const ongoingTrade = this._getOngoingTrade(tradeId);
+ if (ongoingTrade) {
+ return ongoingTrade.store.export();
+ }
+
+ const user = game.users.get(tradeUser);
+ if (!user?.active) {
+ return false;
+ }
+
+ const ongoingTradeData = await ItemPileSocket.executeAsUser(ItemPileSocket.HANDLERS.REQUEST_TRADE_DATA, tradeUser, tradeId, game.user.id);
+ if (!ongoingTradeData) {
+ return false;
+ }
+
+ return ongoingTradeData;
+
+ }
+
+ static async _spectateTrade({ tradeId, tradeUser } = {}) {
+
+ const app = TradingApp.getActiveApp(tradeId);
+ if (app) {
+ return app.render(false, { focus: true });
+ }
+
+ const ongoingTradeData = await this._requestTradeData({ tradeId, tradeUser });
+ if (!ongoingTradeData) {
+ if (Helpers.isGMConnected()) {
+ ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);
+ }
+ return Helpers.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Over"), true);
+ }
+
+ const store = TradeStore.import(...ongoingTradeData);
+ return new TradingApp(store).render(true);
+
+ }
+
+ static async _respondActiveTradeData(tradeId, requesterId) {
+ const trade = this._getOngoingTrade(tradeId, requesterId);
+ if (!trade) return;
+ return trade.store.export();
+ }
+
+ static _getOngoingTrade(tradeId, requesterId = game.user.id) {
+ if (!ongoingTrades.has(tradeId)) return false;
+ const trade = ongoingTrades.get(tradeId);
+ if (!trade.store.isPrivate) {
+ return trade;
+ }
+ if (trade.store.leftTraderUser.id !== requesterId && trade.store.rightTraderUser.id !== requesterId) return false;
+ return trade;
+ }
+
+ static async _updateItems(tradeId, userId, items) {
+ const trade = this._getOngoingTrade(tradeId);
+ if (!trade) return;
+ trade.store.updateItems(userId, items);
+ }
+
+ static async _updateItemCurrencies(tradeId, userId, items) {
+ const trade = this._getOngoingTrade(tradeId);
+ if (!trade) return;
+ trade.store.updateItemCurrencies(userId, items);
+ }
+
+ static async _updateCurrencies(tradeId, userId, currencies) {
+ const trade = this._getOngoingTrade(tradeId);
+ if (!trade) return;
+ trade.store.updateCurrencies(userId, currencies);
+ }
+
+ static async _updateAcceptedState(tradeId, userId, status) {
+ const trade = this._getOngoingTrade(tradeId);
+ if (!trade) return;
+ trade.store.updateAcceptedState(userId, status);
+ if (userId === game.user.id && (trade.store.leftTraderUser.id === game.user.id || trade.store.rightTraderUser.id === game.user.id)) {
+ if (trade.store.tradeIsAccepted) {
+ setTimeout(async () => {
+ if (trade.store.tradeIsAccepted) {
+ ItemPileSocket.executeForUsers(
+ ItemPileSocket.HANDLERS.EXECUTE_TRADE,
+ [trade.store.leftTraderUser.id, trade.store.rightTraderUser.id],
+ trade.store.publicTradeId,
+ trade.store.privateTradeId,
+ userId);
+ }
+ }, 2000);
+ }
+ }
+ }
+
+ static async _userDisconnected(app, html, data) {
+ const tradesToDelete = [];
+ for (let [tradeId, trade] of ongoingTrades) {
+ const foundLeft = data.users.find(u => u === trade.store.leftTraderUser);
+ const foundRight = data.users.find(u => u === trade.store.rightTraderUser);
+ if (foundLeft && foundRight) continue;
+ tradesToDelete.push(tradeId);
+ Helpers.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Disconnected"), true);
+ await trade.app.close({ callback: true });
+ if (foundLeft === game.user || foundRight === game.user) {
+ if (Helpers.isGMConnected()) {
+ await ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);
+ }
+ }
+ }
+ tradesToDelete.forEach(tradeId => ongoingTrades.delete(tradeId));
+ }
+
+ static async _tradeClosed(tradeId, closeUserId) {
+ const trade = this._getOngoingTrade(tradeId);
+ if (!trade) return;
+
+ if (trade.store.leftTraderUser.id === game.user.id || trade.store.rightTraderUser.id === game.user.id) {
+
+ if (closeUserId === trade.store.rightTraderUser.id) {
+
+ TJSDialog.prompt({
+ title: game.i18n.localize("ITEM-PILES.Trade.Closed.Title"), content: {
+ class: CustomDialog, props: {
+ header: game.i18n.localize("ITEM-PILES.Trade.Closed.Title"),
+ content: game.i18n.format("ITEM-PILES.Trade.Closed.Them", {
+ user_name: trade.store.rightTraderUser.name
+ }),
+ icon: "fas fa-exclamation-triangle",
+ }
+ }, modal: false, draggable: true, options: {
+ height: "auto"
+ }
+ });
+
+ } else {
+
+ if (trade.store.isPrivate) {
+ const otherUserId = trade.store.leftTraderUser.id === game.user.id ? trade.store.rightTraderUser.id : trade.store.leftTraderUser.id;
+ ItemPileSocket.executeAsUser(ItemPileSocket.HANDLERS.TRADE_CLOSED, otherUserId, tradeId, game.user.id);
+ } else {
+ ItemPileSocket.executeForOthers(ItemPileSocket.HANDLERS.TRADE_CLOSED, tradeId, game.user.id);
+ }
+
+ TJSDialog.prompt({
+ title: game.i18n.localize("ITEM-PILES.Trade.Closed.Title"), content: {
+ class: CustomDialog, props: {
+ header: game.i18n.localize("ITEM-PILES.Trade.Closed.Title"),
+ content: game.i18n.format("ITEM-PILES.Trade.Closed.You"),
+ icon: "fas fa-exclamation-triangle",
+ }
+ }, modal: false, draggable: true, options: {
+ height: "auto"
+ }
+ });
+
+ if (Helpers.isGMConnected()) {
+ await ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);
+ }
+ }
+
+ } else {
+
+ Helpers.custom_warning(game.i18n.localize("ITEM-PILES.Trade.Closed.Someone"), true);
+
+ }
+
+ trade.app.close({ callback: true });
+ ongoingTrades.delete(tradeId);
+ }
+
+ static async _executeTrade(tradeId, privateId, userId) {
+ const trade = this._getOngoingTrade(tradeId);
+ if (!trade) return;
+ if (trade.store.privateTradeId !== privateId) return;
+ const updates = trade.store.getTradeData();
+
+ const itemsToAdd = updates.add.items.map(entry => {
+ const itemData = updates.targetActor.items.get(entry.id).toObject();
+ return Utilities.setItemQuantity(itemData, entry.quantity);
+ });
+
+ const itemsToRemove = updates.remove.items.map(entry => {
+ const itemData = updates.sourceActor.items.get(entry.id).toObject();
+ return Utilities.setItemQuantity(itemData, entry.quantity);
+ });
+
+ const transaction = new Transaction(updates.sourceActor);
+ transaction.appendItemChanges(itemsToAdd);
+ transaction.appendItemChanges(itemsToRemove, { remove: true });
+ transaction.appendActorChanges(updates.add.attributes);
+ transaction.appendActorChanges(updates.remove.attributes, { remove: true });
+ await transaction.commit();
+
+ if (trade.store.isPrivate) {
+ trade.app.close({ callback: true });
+ ongoingTrades.delete(tradeId);
+ } else if (userId === game.user.id) {
+ if (Helpers.isGMConnected()) {
+ await ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.DISABLE_CHAT_TRADE_BUTTON, tradeId);
+ }
+ return ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.TRADE_COMPLETED, tradeId, updates);
+ }
+ }
+
+ static async _tradeCompleted(tradeId, updates) {
+ const trade = this._getOngoingTrade(tradeId);
+ if (!trade) return;
+ Helpers.hooks.callAll(HOOKS.TRADE.COMPLETE, updates, tradeId)
+ trade.app.close({ callback: true });
+ ongoingTrades.delete(tradeId);
+ }
+
+}
+
diff --git a/src/applications/components/CustomDialog.svelte b/src/applications/components/CustomDialog.svelte
new file mode 100644
index 00000000..29975520
--- /dev/null
+++ b/src/applications/components/CustomDialog.svelte
@@ -0,0 +1,50 @@
+
+
+
+
+
+ {#if icon}
+
+ {/if}
+ {#if header}
+
+ {/if}
+ {#if Array.isArray(content)}
+ {#each content as part}
+
{@html part}
+ {/each}
+ {:else}
+
{@html content}
+ {/if}
+
+
+
+
diff --git a/src/applications/components/DropZone.svelte b/src/applications/components/DropZone.svelte
new file mode 100644
index 00000000..b2d6a445
--- /dev/null
+++ b/src/applications/components/DropZone.svelte
@@ -0,0 +1,44 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/components/FilePicker.svelte b/src/applications/components/FilePicker.svelte
new file mode 100644
index 00000000..01c75699
--- /dev/null
+++ b/src/applications/components/FilePicker.svelte
@@ -0,0 +1,54 @@
+
+
+
+ {#if showImage}
+
+
+
+ {/if}
+ {#if showInput}
+
+ {/if}
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/components/PriceList.svelte b/src/applications/components/PriceList.svelte
new file mode 100644
index 00000000..d6239f95
--- /dev/null
+++ b/src/applications/components/PriceList.svelte
@@ -0,0 +1,290 @@
+
+
+
+
+
+
+
+
Name
+
Cost
+
Fixed
+
%
+
Short
+
Icon
+
Data
+
+
+
+ {#if isHovering}
+ Drop to add
+ {/if}
+ {#each prices as price, index (price.id)}
+
+
+
+
+
+
+
+
+
+
+
+ {#if price.type === "attribute"}
+
+ {:else}
+ editItem(index)}>
+ View item
+
+ {/if}
+
+
+ removeEntry(index)}>
+
+
+ {/each}
+
+
+ {#if presetPrices.length && presets}
+
+ {localize("ITEM-PILES.Applications.ItemEditor.PricePreset")}
+ { addPreset(selectedPreset); selectedPreset = ""; }}>
+ {localize("ITEM-PILES.Applications.ItemEditor.SelectPreset")}
+ {#each presetPrices as price, index (index)}
+ {price.name}
+ {/each}
+
+
+ {/if}
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/components/PriceSelector.svelte b/src/applications/components/PriceSelector.svelte
new file mode 100644
index 00000000..028cac15
--- /dev/null
+++ b/src/applications/components/PriceSelector.svelte
@@ -0,0 +1,108 @@
+
+
+
+ {#if $prices.length > 1}
+
+ 1 && !standalone}
+ class:cant-afford={cantAfford}
+ class:cant-afford-multiple-prices={cantAffordMultiplePrices}
+ class:item-piles-clickable-link={$prices.length > 1}>
+ {@html labelText}
+
+
+
+ {#each $prices as priceGroup, index (index)}
+
+ {#each priceGroup.prices.filter(price => price.cost) as price (price.id)}
+
{
+ $selectedPriceGroup = index;
+ $priceSelector = "";
+ }}
+ class:cant-afford={!priceGroup.maxQuantity && item.store.recipient}>
+
+
+
+
+ {price.baseCost + (priceGroup.prices.length === 0 && price.percent ? "%" : "")} {price.name}
+
+
+ {/each}
+
+ {/each}
+
+
+
+ {:else}
+
{@html labelText }
+ {/if}
+
+
+
\ No newline at end of file
diff --git a/src/applications/components/SliderInput.svelte b/src/applications/components/SliderInput.svelte
new file mode 100644
index 00000000..09cd04de
--- /dev/null
+++ b/src/applications/components/SliderInput.svelte
@@ -0,0 +1,42 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/components/Tabs.svelte b/src/applications/components/Tabs.svelte
new file mode 100644
index 00000000..590bbb36
--- /dev/null
+++ b/src/applications/components/Tabs.svelte
@@ -0,0 +1,59 @@
+
+
+
+ {#each tabs.filter(tab => !tab.hidden) as tab, index (tab.value)}
+ {#if separateElements && index > 0}
+
+ {/if}
+ { activeTab = tab.value}}
+ class="item item-piles-flexrow item-piles-clickable-link"
+ class:underscore={underscore}
+ class:active={activeTab === tab.value}
+ data-tab="rest">
+ {#if tab.icon}
{/if}
+ {localize(tab.label)}
+ {#if tab.highlight}
+
+ {/if}
+
+ {/each}
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/dialogs/drop-currency-dialog/drop-currency-dialog-shell.svelte b/src/applications/dialogs/drop-currency-dialog/drop-currency-dialog-shell.svelte
new file mode 100644
index 00000000..eb3ffa39
--- /dev/null
+++ b/src/applications/dialogs/drop-currency-dialog/drop-currency-dialog-shell.svelte
@@ -0,0 +1,159 @@
+
+
+
+
+
+
+
+
+
diff --git a/src/applications/dialogs/drop-currency-dialog/drop-currency-dialog.js b/src/applications/dialogs/drop-currency-dialog/drop-currency-dialog.js
new file mode 100644
index 00000000..e507dadf
--- /dev/null
+++ b/src/applications/dialogs/drop-currency-dialog/drop-currency-dialog.js
@@ -0,0 +1,58 @@
+import DropCurrencyDialogShell from "./drop-currency-dialog-shell.svelte";
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+
+export default class DropCurrencyDialog extends SvelteApplication {
+
+ /**
+ *
+ * @param sourceActor
+ * @param targetActor
+ * @param settings
+ * @param options
+ * @param dialogData
+ */
+ constructor(sourceActor, targetActor, settings = {}, options = {}) {
+ super({
+ id: `item-pile-drop-currency-${targetActor.id}-${targetActor.id}`,
+ title: settings?.title ?? game.i18n.localize("ITEM-PILES.Applications.DropCurrencies.Title"),
+ svelte: {
+ class: DropCurrencyDialogShell,
+ target: document.body,
+ props: {
+ sourceActor,
+ targetActor,
+ settings
+ }
+ },
+ close: () => this.options.resolve?.(null),
+ ...options
+ })
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ width: 430,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static getActiveApps(id) {
+ return Object.values(ui.windows).filter(app => app.id === `item-pile-drop-currency-${id}`);
+ }
+
+ static async show(sourceActor, targetActor, settings = {}, options = {}) {
+ const apps = this.getActiveApps(sourceActor.id + "-" + targetActor.id);
+ if (apps.length) {
+ for (let app of apps) {
+ app.render(false, { focus: true });
+ }
+ return;
+ }
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(sourceActor, targetActor, settings, options).render(true, { focus: true });
+ })
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/dialogs/drop-item-dialog/drop-item-dialog-shell.svelte b/src/applications/dialogs/drop-item-dialog/drop-item-dialog-shell.svelte
new file mode 100644
index 00000000..35b456e3
--- /dev/null
+++ b/src/applications/dialogs/drop-item-dialog/drop-item-dialog-shell.svelte
@@ -0,0 +1,82 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/dialogs/drop-item-dialog/drop-item-dialog.js b/src/applications/dialogs/drop-item-dialog/drop-item-dialog.js
new file mode 100644
index 00000000..39a99f1d
--- /dev/null
+++ b/src/applications/dialogs/drop-item-dialog/drop-item-dialog.js
@@ -0,0 +1,58 @@
+import DropItemDialogShell from "./drop-item-dialog-shell.svelte";
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+
+export default class DropItemDialog extends SvelteApplication {
+
+ /**
+ *
+ * @param droppedItem
+ * @param itemPile
+ * @param options
+ * @param dialogData
+ */
+ constructor(droppedItem, itemPile, options = {}) {
+ super({
+ id: `item-pile-drop-item-${droppedItem.id}${itemPile ? "-" + itemPile.id : ""}`,
+ svelte: {
+ class: DropItemDialogShell,
+ target: document.body,
+ props: {
+ droppedItem,
+ itemPile
+ }
+ },
+ close: () => this.options.resolve?.(null),
+ ...options
+ });
+ this.droppedItem = droppedItem;
+ this.itemPile = itemPile;
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ title: game.i18n.localize("ITEM-PILES.Applications.DropItem.Title"),
+ width: 430,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static getActiveApps(id) {
+ return Object.values(ui.windows).filter(app => app.id === `item-pile-drop-item-${id}`);
+ }
+
+ static async show(droppedItem, itemPile, options = {}) {
+ const apps = this.getActiveApps(droppedItem.id + (itemPile ? "-" + itemPile.id : ""));
+ if (apps.length) {
+ for (let app of apps) {
+ app.render(false, { focus: true });
+ }
+ return;
+ }
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(droppedItem, itemPile, options).render(true, { focus: true });
+ })
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/dialogs/text-editor-dialog/text-editor-dialog-shell.svelte b/src/applications/dialogs/text-editor-dialog/text-editor-dialog-shell.svelte
new file mode 100644
index 00000000..d34f148f
--- /dev/null
+++ b/src/applications/dialogs/text-editor-dialog/text-editor-dialog-shell.svelte
@@ -0,0 +1,44 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/dialogs/text-editor-dialog/text-editor-dialog.js b/src/applications/dialogs/text-editor-dialog/text-editor-dialog.js
new file mode 100644
index 00000000..d1215d89
--- /dev/null
+++ b/src/applications/dialogs/text-editor-dialog/text-editor-dialog.js
@@ -0,0 +1,56 @@
+import CONSTANTS from "../../../constants/constants.js";
+
+export default class TextEditorDialog extends FormApplication {
+
+ constructor(text, options) {
+ super();
+ this.text = text;
+ this.resolve = options.resolve;
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ title: game.i18n.localize("ITEM-PILES.Applications.DropItem.Title"),
+ template: `${CONSTANTS.PATH}templates/text-editor.html`,
+ width: 430,
+ height: 350,
+ classes: ["item-piles-app"],
+ resizable: true
+ })
+ }
+
+ async getData(options) {
+ const data = super.getData(options);
+ data.text = this.text;
+ return data;
+ }
+
+ static getActiveApps(id) {
+ return Object.values(ui.windows).filter(app => app.id === `item-pile-text-editor-${id}`);
+ }
+
+ async _updateObject(event, formData) {
+ this.resolve(formData.text);
+ return this.close();
+ }
+
+ async close(options) {
+ this.resolve(null);
+ return super.close(options);
+ }
+
+ static async show(text, options = {}) {
+ const apps = options.id ? this.getActiveApps(options.id) : [];
+ if (apps.length) {
+ for (let app of apps) {
+ app.render(false, { focus: true });
+ }
+ return;
+ }
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(text, options).render(true, { focus: true });
+ })
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog-shell.svelte b/src/applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog-shell.svelte
new file mode 100644
index 00000000..b37deec7
--- /dev/null
+++ b/src/applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog-shell.svelte
@@ -0,0 +1,189 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
{localize($itemName)}
+
+
+
+ {#if maxItemQuantity}
+
+ {localize("ITEM-PILES.Applications.TradeMerchantItem.Quantity")}
+
+ ({localize("ITEM-PILES.Applications.TradeMerchantItem.MaxQuantity", {
+ quantity: maxItemPurchaseQuantity
+ })})
+
+
+
{
+ $quantityToBuy = Math.max(1, Math.min(currentQuantityToBuy, maxItemPurchaseQuantity));
+ currentQuantityToBuy = $quantityToBuy;
+ }}/>
+ {/if}
+
+
+
+ {#if maxItemQuantity}
+ {#if $quantityToBuy > 1 && paymentData.primary}
+ {paymentData.basePriceString}
+ {/if}
+ {:else}
+ {localize(`ITEM-PILES.Applications.TradeMerchantItem.${settings.selling ? "They" : "You"}CantAfford`)}
+ {/if}
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.TradeMerchantItem." + (settings.selling ? "YouReceive" : "YouPay"))}:
+
+
+
+ {localize("ITEM-PILES.Applications.TradeMerchantItem." + (settings.selling ? "TheyReceive" : "YouReceive"))}:
+
+
+
+ {#each paymentData.finalPrices as price}
+ {#if price.quantity}
+
+
+
+
+
{price.quantity} {localize(price.name)}
+
+ {/if}
+ {/each}
+
+
+
+
+
{$quantityToBuy > 1 ? $quantityToBuy + " " : ""}{$itemName}
+
+
+
+
+ {#if paymentData.buyerChange.length}
+
+ {localize("ITEM-PILES.Applications.TradeMerchantItem.Change")}:
+
+ {#each paymentData.buyerChange as change}
+ {#if change.quantity}
+
+
{change.quantity} {localize(change.name)}
+
+
+
+
+ {/if}
+ {/each}
+ {/if}
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog.js b/src/applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog.js
new file mode 100644
index 00000000..e34495a8
--- /dev/null
+++ b/src/applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog.js
@@ -0,0 +1,60 @@
+import TradeMerchantItemDialogShell from "./trade-merchant-item-dialog-shell.svelte";
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+import { get } from "svelte/store";
+
+export default class TradeMerchantItemDialog extends SvelteApplication {
+
+ /**
+ *
+ * @param item
+ * @param seller
+ * @param buyer
+ * @param settings
+ * @param options
+ */
+ constructor(item, seller, buyer, settings = {}, options = {}) {
+ super({
+ id: `item-pile-buy-item-dialog-${item.id}-${seller.id}-${buyer.id}`,
+ title: game.i18n.format("ITEM-PILES.Applications.TradeMerchantItem.Title", { item_name: get(item.name) }),
+ svelte: {
+ class: TradeMerchantItemDialogShell,
+ target: document.body,
+ props: {
+ item,
+ seller,
+ buyer,
+ settings
+ }
+ },
+ close: () => this.options.resolve?.(null),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ width: 330,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static getActiveApps(id) {
+ return Object.values(ui.windows).filter(app => app.id === `item-pile-buy-item-dialog-${id}`);
+ }
+
+ static async show(item, seller, buyer, settings = {}, options = {}) {
+ const apps = this.getActiveApps(item.id + "-" + seller.id + "-" + buyer.id);
+ if (apps.length) {
+ for (let app of apps) {
+ app.render(false, { focus: true });
+ }
+ return;
+ }
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(item, seller, buyer, settings, options).render(true, { focus: true });
+ })
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/editors/currencies-editor/CurrencyList.svelte b/src/applications/editors/currencies-editor/CurrencyList.svelte
new file mode 100644
index 00000000..46a0ebdd
--- /dev/null
+++ b/src/applications/editors/currencies-editor/CurrencyList.svelte
@@ -0,0 +1,116 @@
+
+
+
+
+
Primary
+
Name
+
Exchange
+
Short
+
Icon
+
Data
+
+
+
+ {#if isHovering}
+
Drop to add
+ {/if}
+ {#if !currencies.length}
+
+
+ Drop an item or click the plus button to get started!
+
+
+ {/if}
+ {#each currencies as item, index (item.id)}
+
+
store.setPrimary(index)}/>
+
+
+
+
+
+
+
+ {#if item.type === "attribute"}
+
+ {:else}
+ store.editItem(index)}>
+ View item
+
+ {/if}
+
+
+ store.removeEntry(index)}>
+
+
+
+
+ {/each}
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/editors/currencies-editor/currencies-editor-shell.svelte b/src/applications/editors/currencies-editor/currencies-editor-shell.svelte
new file mode 100644
index 00000000..0a446f2c
--- /dev/null
+++ b/src/applications/editors/currencies-editor/currencies-editor-shell.svelte
@@ -0,0 +1,77 @@
+
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.CurrenciesEditor.Explanation")}
+
+ {localize("ITEM-PILES.Applications.CurrenciesEditor.ExplanationSmallAttributes")}
+
+ {localize("ITEM-PILES.Applications.CurrenciesEditor.ExplanationSmallItems")}
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.CurrenciesEditor.Submit")}
+
+ { application.close(); }}>
+ { localize("Cancel") }
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/editors/currencies-editor/currencies-editor.js b/src/applications/editors/currencies-editor/currencies-editor.js
new file mode 100644
index 00000000..6e6c1a35
--- /dev/null
+++ b/src/applications/editors/currencies-editor/currencies-editor.js
@@ -0,0 +1,35 @@
+import CurrenciesEditorShell from './currencies-editor-shell.svelte';
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+
+export default class CurrenciesEditor extends SvelteApplication {
+
+ constructor(data = false, options = {}) {
+ super({
+ svelte: {
+ class: CurrenciesEditorShell,
+ target: document.body,
+ props: {
+ data
+ }
+ },
+ close: () => this.options.resolve?.(null),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ title: game.i18n.localize("ITEM-PILES.Applications.CurrenciesEditor.Title"),
+ width: 630,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static async show(data = false, options = {}) {
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(data, options).render(true, { focus: true });
+ })
+ }
+}
\ No newline at end of file
diff --git a/src/applications/editors/currencies-editor/currency-store.js b/src/applications/editors/currencies-editor/currency-store.js
new file mode 100644
index 00000000..fb98c8ed
--- /dev/null
+++ b/src/applications/editors/currencies-editor/currency-store.js
@@ -0,0 +1,128 @@
+import { writable, get } from 'svelte/store';
+import * as Utilities from "../../../helpers/utilities.js";
+import CONSTANTS from "../../../constants/constants.js";
+import * as Helpers from "../../../helpers/helpers.js";
+import { localize } from "@typhonjs-fvtt/runtime/svelte/helper";
+
+export default class CurrencyStore {
+
+ constructor(data) {
+ this.currencies = writable(data.map((entry, index) => {
+ return {
+ ...entry,
+ index,
+ id: entry.data?.path ?? entry.data?._id ?? randomID()
+ }
+ }));
+ }
+
+ setPrimary(index) {
+ const currencies = get(this.currencies);
+ currencies.forEach((entry, entryIndex) => {
+ entry.primary = entryIndex === index;
+ });
+ this.currencies.set(currencies);
+ }
+
+ sortCurrencies() {
+ const currencies = get(this.currencies);
+ currencies.sort((a, b) => {
+ return b.exchangeRate - a.exchangeRate;
+ });
+ this.currencies.set(currencies);
+ }
+
+ addAttribute() {
+ const currencies = get(this.currencies);
+ this.currencies.set([...currencies, {
+ type: "attribute",
+ name: "New Attribute",
+ img: "",
+ abbreviation: "{#}N",
+ data: {
+ path: ""
+ },
+ primary: !currencies.length,
+ exchangeRate: 1
+ }]);
+ this.sortCurrencies();
+ }
+
+ async addItem(data) {
+
+ let uuid = false;
+ if (data.pack) {
+ uuid = "Compendium" + data.pack + "." + data.id;
+ }
+
+ let item = await Item.implementation.fromDropData(data);
+ let itemData = item.toObject();
+
+ if (!itemData) {
+ console.error(data);
+ throw Helpers.custom_error("Something went wrong when dropping this item!")
+ }
+
+ let currencies = get(this.currencies);
+
+ const itemCurrencies = currencies.map(entry => entry.data?.item ?? {});
+ const foundItem = Utilities.findSimilarItem(itemCurrencies, itemData);
+
+ if (foundItem) {
+ const index = itemCurrencies.indexOf(foundItem);
+ currencies[index].data = {
+ uuid,
+ item: itemData
+ }
+ Helpers.custom_notify(`Updated item data for ${localize(currencies[index].name)} (item name ${itemData.name})`)
+ } else {
+ currencies = [...currencies, {
+ id: randomID(),
+ type: "item",
+ name: itemData.name,
+ img: itemData.img,
+ abbreviation: "{#} " + itemData.name,
+ data: {
+ uuid,
+ item: itemData
+ },
+ primary: !currencies.length,
+ exchangeRate: 1
+ }];
+ }
+ this.currencies.set(currencies);
+ this.sortCurrencies();
+ }
+
+ async editItem(index) {
+ const currencies = get(this.currencies);
+ const data = currencies[index].data;
+ let item;
+ if (data.uuid) {
+ item = await fromUuid(data.uuid);
+ } else {
+ let itemData = data.itemData;
+ if (itemData._id) delete itemData._id;
+ if (itemData.permission) delete itemData._id;
+ const items = Array.from(game.items);
+ item = Utilities.findSimilarItem(items, itemData);
+ if (!item) {
+ setProperty(itemData, CONSTANTS.FLAGS.TEMPORARY_ITEM, true);
+ item = await Item.implementation.create(itemData);
+ Helpers.custom_notify(`An item has been created for ${item.name} - drag and drop it into the list to update the stored item data`)
+ }
+ }
+ item.sheet.render(true);
+ }
+
+ removeEntry(index) {
+ const currencies = get(this.currencies);
+ currencies.splice(index, 1);
+ this.currencies.set(currencies);
+ }
+
+ export() {
+ return get(this.currencies);
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/editors/index.js b/src/applications/editors/index.js
new file mode 100644
index 00000000..fa24986a
--- /dev/null
+++ b/src/applications/editors/index.js
@@ -0,0 +1,13 @@
+import CurrenciesEditor from "./currencies-editor/currencies-editor.js";
+import ItemFiltersEditor from "./item-filters-editor/item-filters-editor.js";
+import ItemSimilaritiesEditor from "./item-similarities-editor/item-similarities-editor.js";
+import PriceModifiersEditor from "./price-modifiers-editor/price-modifiers-editor.js";
+import PricePresetEditor from "./price-preset-editor/price-preset-editor.js";
+
+export default {
+ "currencies": CurrenciesEditor,
+ "item-filters": ItemFiltersEditor,
+ "item-similarities": ItemSimilaritiesEditor,
+ "price-modifiers": PriceModifiersEditor,
+ "price-presets": PricePresetEditor
+}
\ No newline at end of file
diff --git a/src/applications/editors/item-editor/ItemPriceStore.js b/src/applications/editors/item-editor/ItemPriceStore.js
new file mode 100644
index 00000000..b89d92c6
--- /dev/null
+++ b/src/applications/editors/item-editor/ItemPriceStore.js
@@ -0,0 +1,63 @@
+import { TJSDocument } from "@typhonjs-fvtt/runtime/svelte/store";
+import { writable, get } from "svelte/store";
+import CONSTANTS from "../../../constants/constants.js";
+import * as PileUtilities from "../../../helpers/pile-utilities.js";
+
+const existingStores = new Map();
+
+export default class ItemPriceStore {
+
+ static make(item) {
+ if (existingStores.has(item.id)) {
+ return existingStores.get(item.id);
+ }
+ return new this(item);
+ }
+
+ constructor(item) {
+
+ this.item = item;
+ this.itemDoc = new TJSDocument(this.item);
+
+ this.price = writable(0);
+
+ const data = PileUtilities.getItemFlagData(this.item);
+
+ data.prices.forEach(group => {
+ group.forEach(price => {
+ if (!price.id) {
+ price.id = randomID();
+ }
+ });
+ });
+
+ this.data = writable(data);
+
+ this.itemDoc.subscribe((item, changes) => {
+ const { data } = changes;
+ if (hasProperty(data, CONSTANTS.FLAGS.ITEM)) {
+ const newData = getProperty(data, CONSTANTS.FLAGS.ITEM);
+ const oldData = get(this.data);
+ this.data.set(foundry.utils.mergeObject(oldData, newData));
+ }
+ this.price.set(getProperty(this.item.toObject(), game.itempiles.ITEM_PRICE_ATTRIBUTE));
+ });
+
+ }
+
+ removeGroup(groupIndex) {
+ const data = get(this.data);
+ data.prices.splice(groupIndex, 1);
+ this.data.set(data);
+ }
+
+ export() {
+ return {
+ data: {
+ [game.itempiles.ITEM_PRICE_ATTRIBUTE]: get(this.price),
+ },
+ flags: get(this.data)
+ };
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/editors/item-editor/item-editor-shell.svelte b/src/applications/editors/item-editor/item-editor-shell.svelte
new file mode 100644
index 00000000..b2ddfae4
--- /dev/null
+++ b/src/applications/editors/item-editor/item-editor-shell.svelte
@@ -0,0 +1,229 @@
+
+
+
+
+
+
+
+
+
+
+
+
+ {#if activeTab === 'general'}
+
+
+
+ {/if}
+
+ {#if activeTab === 'price'}
+
+
+
+
+
+
+
+
+
+
+
+ {#if itemFlagData.prices.length}
+ {#each itemFlagData.prices as prices, groupIndex (groupIndex)}
+
{ store.removeGroup(groupIndex) }}/>
+ {/each}
+ {/if}
+
+
+
+ {/if}
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.ItemEditor.Update")}
+
+ { application.close(); }}>
+ { localize("Cancel") }
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/editors/item-editor/item-editor.js b/src/applications/editors/item-editor/item-editor.js
new file mode 100644
index 00000000..e850cea3
--- /dev/null
+++ b/src/applications/editors/item-editor/item-editor.js
@@ -0,0 +1,42 @@
+import ItemEditorShell from './item-editor-shell.svelte';
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+
+export default class ItemEditor extends SvelteApplication {
+
+ constructor(item = false, options) {
+ super({
+ id: `item-pile-item-editor-${item.id}`,
+ title: game.i18n.format("ITEM-PILES.Applications.ItemEditor.Title", { item_name: item.name }),
+ svelte: {
+ class: ItemEditorShell,
+ target: document.body,
+ props: {
+ item
+ }
+ },
+ close: () => this.options.resolve(null),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ width: 500,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static getActiveApp(id) {
+ return Object.values(ui.windows).find(app => app.id === `item-pile-item-editor-${id}`)
+ }
+
+ static async show(item = false, options = {}, dialogData = {}) {
+ const app = this.getActiveApp(item.id);
+ if (app) return app.render(false, { focus: true });
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(item, options, dialogData).render(true, { focus: true });
+ })
+ }
+}
\ No newline at end of file
diff --git a/src/applications/editors/item-filters-editor/item-filters-editor.js b/src/applications/editors/item-filters-editor/item-filters-editor.js
new file mode 100644
index 00000000..4ac1f62d
--- /dev/null
+++ b/src/applications/editors/item-filters-editor/item-filters-editor.js
@@ -0,0 +1,36 @@
+import ItemFiltersShell from './item-filters-editor.svelte';
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+
+export default class ItemFiltersEditor extends SvelteApplication {
+
+ constructor(itemFilters, options) {
+ super({
+ title: "ITEM-PILES.Applications.FilterEditor.Title",
+ svelte: {
+ class: ItemFiltersShell,
+ target: document.body,
+ props: {
+ itemFilters
+ }
+ },
+ close: () => this.options.resolve(null),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ title: game.i18n.localize("ITEM-PILES.Applications.FilterEditor.Title"),
+ width: 400,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static async show(itemFilters, options = {}) {
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(itemFilters, options).render(true, { focus: true });
+ })
+ }
+}
\ No newline at end of file
diff --git a/src/applications/editors/item-filters-editor/item-filters-editor.svelte b/src/applications/editors/item-filters-editor/item-filters-editor.svelte
new file mode 100644
index 00000000..b58347b8
--- /dev/null
+++ b/src/applications/editors/item-filters-editor/item-filters-editor.svelte
@@ -0,0 +1,104 @@
+
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.FilterEditor.Explanation")}
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.FilterEditor.Submit")}
+
+ { application.close(); }}>
+ { localize("Cancel") }
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/editors/item-similarities-editor/item-similarities-editor.js b/src/applications/editors/item-similarities-editor/item-similarities-editor.js
new file mode 100644
index 00000000..1321d9ba
--- /dev/null
+++ b/src/applications/editors/item-similarities-editor/item-similarities-editor.js
@@ -0,0 +1,35 @@
+import ItemSimilaritiesShell from './item-similarities-editor.svelte';
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+
+export default class ItemSimilaritiesEditor extends SvelteApplication {
+
+ constructor(itemSimilarities, options) {
+ super({
+ svelte: {
+ class: ItemSimilaritiesShell,
+ target: document.body,
+ props: {
+ itemSimilarities
+ }
+ },
+ close: () => this.options.resolve(null),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ title: game.i18n.localize("ITEM-PILES.Applications.SimilaritiesEditor.Title"),
+ width: 400,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static async show(itemSimilarities, options = {}) {
+ return new Promise(resolve => {
+ options.resolve = resolve;
+ return new this(itemSimilarities, options).render(true, { focus: true });
+ });
+ }
+}
\ No newline at end of file
diff --git a/src/applications/editors/item-similarities-editor/item-similarities-editor.svelte b/src/applications/editors/item-similarities-editor/item-similarities-editor.svelte
new file mode 100644
index 00000000..f99e9746
--- /dev/null
+++ b/src/applications/editors/item-similarities-editor/item-similarities-editor.svelte
@@ -0,0 +1,96 @@
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.SimilaritiesEditor.Explanation_P1")}
+ {localize("ITEM-PILES.Applications.SimilaritiesEditor.Explanation_P2")}
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.SimilaritiesEditor.Submit")}
+
+ { application.close(); }}>
+ { localize("Cancel") }
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/editors/item-type-price-modifiers-editor/item-type-price-modifiers-editor.js b/src/applications/editors/item-type-price-modifiers-editor/item-type-price-modifiers-editor.js
new file mode 100644
index 00000000..e7dcd3cc
--- /dev/null
+++ b/src/applications/editors/item-type-price-modifiers-editor/item-type-price-modifiers-editor.js
@@ -0,0 +1,37 @@
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+import ItemTypePriceModifiersShell from './item-type-price-modifiers-editor.svelte';
+
+export default class ItemTypePriceModifiersEditor extends SvelteApplication {
+
+ constructor(itemTypePriceModifiers, options) {
+
+ super({
+ svelte: {
+ class: ItemTypePriceModifiersShell,
+ target: document.body,
+ props: {
+ itemTypePriceModifiers
+ }
+ },
+ close: () => this.options.resolve?.(false),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ title: game.i18n.localize("ITEM-PILES.Applications.ItemTypePriceModifiersEditor.Title"),
+ width: 600,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static async show(itemTypePriceModifiers, options = {}) {
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(itemTypePriceModifiers, options).render(true, { focus: true });
+ })
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/editors/item-type-price-modifiers-editor/item-type-price-modifiers-editor.svelte b/src/applications/editors/item-type-price-modifiers-editor/item-type-price-modifiers-editor.svelte
new file mode 100644
index 00000000..d9ceed8c
--- /dev/null
+++ b/src/applications/editors/item-type-price-modifiers-editor/item-type-price-modifiers-editor.svelte
@@ -0,0 +1,147 @@
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.ItemTypePriceModifiersEditor.Explanation")}
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.ItemTypePriceModifiersEditor.Override")}
+ {localize("ITEM-PILES.Applications.ItemTypePriceModifiersEditor.ItemType")}
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Merchant.BuyPriceModifier")}
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Merchant.SellPriceModifier")}
+
+
+
+
+
+
+ {#each itemTypePriceModifiers as priceData, index (index)}
+
+
+
+
+
+
+
+
+
+ {#each systemTypes as [itemType, label] (itemType)}
+
+ {localize(label)}
+
+ {/each}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {/each}
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.ItemTypePriceModifiersEditor.Submit")}
+
+ { application.close(); }}>
+ { localize("Cancel") }
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/editors/price-modifiers-editor/price-modifiers-editor.js b/src/applications/editors/price-modifiers-editor/price-modifiers-editor.js
new file mode 100644
index 00000000..25bc5b79
--- /dev/null
+++ b/src/applications/editors/price-modifiers-editor/price-modifiers-editor.js
@@ -0,0 +1,43 @@
+import PriceModifiersShell from './price-modifiers-editor.svelte';
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+
+export default class PriceModifiersEditor extends SvelteApplication {
+
+ constructor(priceModifiers, options) {
+
+ priceModifiers = priceModifiers.map(data => {
+ data.actor = game.actors.get(data.actor);
+ if (!data.actor) return false;
+ return data;
+ }).filter(Boolean);
+
+ super({
+ svelte: {
+ class: PriceModifiersShell,
+ target: document.body,
+ props: {
+ priceModifiers
+ }
+ },
+ close: () => this.options.resolve?.(false),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ title: game.i18n.localize("ITEM-PILES.Applications.PriceModifiersEditor.Title"),
+ width: 600,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static async show(data = false, options = {}) {
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(data, options).render(true, { focus: true });
+ })
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/editors/price-modifiers-editor/price-modifiers-editor.svelte b/src/applications/editors/price-modifiers-editor/price-modifiers-editor.svelte
new file mode 100644
index 00000000..2ff6bc62
--- /dev/null
+++ b/src/applications/editors/price-modifiers-editor/price-modifiers-editor.svelte
@@ -0,0 +1,158 @@
+
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.PriceModifiersEditor.Explanation")}
+
+
+
+ {#if priceModifiers.length}
+
+
+ {localize("ITEM-PILES.Applications.PriceModifiersEditor.Actor")}
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Merchant.BuyPriceModifier")}
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Merchant.SellPriceModifier")}
+
+
+ {#each priceModifiers as priceData, index (index)}
+
+
+ {priceData.actor.name}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {/each}
+
+ {/if}
+
+
{localize("ITEM-PILES.Applications.PriceModifiersEditor.DragDrop")}
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.PriceModifiersEditor.Submit")}
+
+ { application.close(); }}>
+ { localize("Cancel") }
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/editors/price-preset-editor/price-preset-editor-shell.svelte b/src/applications/editors/price-preset-editor/price-preset-editor-shell.svelte
new file mode 100644
index 00000000..b299c60e
--- /dev/null
+++ b/src/applications/editors/price-preset-editor/price-preset-editor-shell.svelte
@@ -0,0 +1,93 @@
+
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.PricePresetEditor.Explanation")}
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.PricePresetEditor.Update")}
+
+ { application.close(); }}>
+ { localize("Cancel") }
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/editors/price-preset-editor/price-preset-editor.js b/src/applications/editors/price-preset-editor/price-preset-editor.js
new file mode 100644
index 00000000..d406cdd1
--- /dev/null
+++ b/src/applications/editors/price-preset-editor/price-preset-editor.js
@@ -0,0 +1,42 @@
+import PricePresetEditorShell from "./price-preset-editor-shell.svelte";
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+
+export default class PricePresetEditor extends SvelteApplication {
+
+ constructor(prices, options) {
+ super({
+ id: `item-pile-price-preset-editor`,
+ title: game.i18n.format("ITEM-PILES.Applications.PricePresetEditor.Title"),
+ svelte: {
+ class: PricePresetEditorShell,
+ target: document.body,
+ props: {
+ prices
+ }
+ },
+ close: () => this.options.resolve(null),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ width: 500,
+ height: "auto",
+ classes: ["item-piles-app"]
+ })
+ }
+
+ static getActiveApp() {
+ return Object.values(ui.windows).find(app => app.id === `item-pile-price-preset-editor`)
+ }
+
+ static async show(prices, options = {}, dialogData = {}) {
+ const app = this.getActiveApp();
+ if (app) return app.render(false, { focus: true });
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(prices, options, dialogData).render(true, { focus: true });
+ })
+ }
+}
\ No newline at end of file
diff --git a/src/applications/item-pile-config/item-pile-config.js b/src/applications/item-pile-config/item-pile-config.js
new file mode 100644
index 00000000..58923fc8
--- /dev/null
+++ b/src/applications/item-pile-config/item-pile-config.js
@@ -0,0 +1,55 @@
+import * as Utilities from "../../helpers/utilities.js";
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+import ItemPileConfigShell from './item-pile-config.svelte';
+
+export default class ItemPileConfig extends SvelteApplication {
+
+ constructor(pileActor, options = {}) {
+
+ super({
+ id: `item-pile-config-${pileActor.id}`,
+ title: game.i18n.format("ITEM-PILES.Applications.ItemPileConfig.Title", { actor_name: pileActor.name }),
+ svelte: {
+ class: ItemPileConfigShell,
+ target: document.body,
+ props: {
+ pileActor
+ }
+ },
+ close: () => this.options.resolve?.(null),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ width: 430,
+ height: 627,
+ classes: ["item-piles-config"],
+ resizable: true
+ })
+ }
+
+ static getActiveApp(id) {
+ return Object.values(ui.windows).find(app => app.id === `item-pile-config-${id}`)
+ }
+
+ static async show(target, options = {}, dialogData = {}) {
+ const targetActor = Utilities.getActor(target);
+ const app = this.getActiveApp(targetActor.id);
+ if (app) return app.render(false, { focus: true });
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(targetActor, options, dialogData).render(true);
+ })
+ }
+
+ async close(options) {
+ Object.values(ui.windows).forEach(app => {
+ if (app !== this && app.rendered && app.options?.parentApp === this) {
+ app.close();
+ }
+ })
+ return super.close(options);
+ }
+}
\ No newline at end of file
diff --git a/src/applications/item-pile-config/item-pile-config.svelte b/src/applications/item-pile-config/item-pile-config.svelte
new file mode 100644
index 00000000..72db3a40
--- /dev/null
+++ b/src/applications/item-pile-config/item-pile-config.svelte
@@ -0,0 +1,651 @@
+
+
+
+
+
+
+
+
+
+
+
+
+ {#if activeTab === 'mainsettings'}
+
+
+
+
+
+
+
+
+
+
+
+
+
+ { showDescriptionDialog() }}>
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Main.EditDescription")}
+
+
+
+
+
+
+ { showCurrenciesEditor() }}
+ disabled={!hasOverrideCurrencies} style="flex:4;">
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Main.ConfigureOverrideCurrencies")}
+
+
+
+
+
+
+ { showItemFiltersEditor() }}
+ disabled={!hasOverrideItemFilters} style="flex:4;">
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Main.ConfigureOverrideItemFilters")}
+
+
+
+
+ {/if}
+
+ {#if activeTab === "merchant"}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Merchant.BuyPriceModifier")}
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Merchant.SellPriceModifier")}
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {/if}
+
+ {#if activeTab === 'othersettings'}
+
+
+
+ {/if}
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Update")}
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/item-pile-inventory-app/ActorPicker.svelte b/src/applications/item-pile-inventory-app/ActorPicker.svelte
new file mode 100644
index 00000000..3fb77305
--- /dev/null
+++ b/src/applications/item-pile-inventory-app/ActorPicker.svelte
@@ -0,0 +1,50 @@
+
+
+
+
+ {#if editQuantities}
+
{localize("ITEM-PILES.Inspect.Owner")}
+ {:else}
+
+ {localize("ITEM-PILES.Inspect.AsActor", { actorName: store.recipient.name })}
+ {#if playerActors.length > 1}
+ {#if !changingActor}
+ { changingActor = true }} class:active={!changingActor}>Change
+ actor.
+ {:else}
+
+ {#each playerActors as actor, index (index)}
+ {actor.name}
+ {/each}
+
+ {/if}
+ {/if}
+
+ {/if}
+
+
\ No newline at end of file
diff --git a/src/applications/item-pile-inventory-app/CurrencyList.svelte b/src/applications/item-pile-inventory-app/CurrencyList.svelte
new file mode 100644
index 00000000..b4f87675
--- /dev/null
+++ b/src/applications/item-pile-inventory-app/CurrencyList.svelte
@@ -0,0 +1,47 @@
+
+
+
+
+
+ {#if $numCurrencies > 0 || editQuantities}
+
+ {#each $currencies as currency, index (currency.identifier)}
+
+ {/each}
+
+ {/if}
+
+
\ No newline at end of file
diff --git a/src/applications/item-pile-inventory-app/ItemList.svelte b/src/applications/item-pile-inventory-app/ItemList.svelte
new file mode 100644
index 00000000..2dae2bf3
--- /dev/null
+++ b/src/applications/item-pile-inventory-app/ItemList.svelte
@@ -0,0 +1,23 @@
+
+
+
+
+ {#if $numItems > 0}
+
{localize("ITEM-PILES.Items")}:
+
+ {#each $items as item (item.identifier)}
+
+ {/each}
+
+ {/if}
+
+
\ No newline at end of file
diff --git a/src/applications/item-pile-inventory-app/ListEntry.svelte b/src/applications/item-pile-inventory-app/ListEntry.svelte
new file mode 100644
index 00000000..b541ef39
--- /dev/null
+++ b/src/applications/item-pile-inventory-app/ListEntry.svelte
@@ -0,0 +1,99 @@
+
+
+
+
+
+
+
+
+
+
+
+
{$name}
+ {#if !editQuantities}
+
(x{$quantity})
+ {/if}
+
+
+
+
+
+ {#if editQuantities}
+
+
+
+
+
+ {:else}
+
+ {#if $quantityLeft}
+
+
+
+
+ / {$quantityLeft}
+
+
+ {:else}
+
+ {localize(`ITEM-PILES.Inspect.${entry.toShare ? "NoShareLeft" : "NoneLeft"}`)}
+
+ {/if}
+ {/if}
+
+
+
+ {#if !editQuantities}
+
+
{ entry.take() }}
+ class="item-piles-item-take-button"
+ type="button"
+ disabled={!$quantityLeft}>
+ {localize("ITEM-PILES.Inspect.Take")}
+
+
+ {/if}
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/item-pile-inventory-app/item-pile-inventory-app.js b/src/applications/item-pile-inventory-app/item-pile-inventory-app.js
new file mode 100644
index 00000000..c48bcdca
--- /dev/null
+++ b/src/applications/item-pile-inventory-app/item-pile-inventory-app.js
@@ -0,0 +1,110 @@
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+import ItemPileInventoryShell from "./item-pile-inventory-shell.svelte";
+import * as Utilities from "../../helpers/utilities.js";
+import ItemPileConfig from "../item-pile-config/item-pile-config.js";
+import HOOKS from "../../constants/hooks.js";
+import * as Helpers from "../../helpers/helpers.js";
+
+export class ItemPileInventoryApp extends SvelteApplication {
+
+ /**
+ *
+ * @param actor
+ * @param recipient
+ * @param overrides
+ * @param options
+ * @param dialogData
+ */
+ constructor(actor, recipient, overrides = {}, options = {}, dialogData = {}) {
+ super({
+ id: `item-pile-inventory-${actor.id}`,
+ title: actor.name,
+ svelte: {
+ class: ItemPileInventoryShell,
+ target: document.body,
+ props: {
+ actor,
+ recipient,
+ overrides
+ }
+ },
+ zIndex: 100,
+ ...options
+ }, dialogData);
+
+ this.actor = actor;
+ this.recipient = recipient;
+
+ Helpers.hooks.callAll(HOOKS.OPEN_INTERFACE, this, actor, recipient, overrides);
+
+ }
+
+ /** @inheritdoc */
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ closeOnSubmit: false,
+ classes: ["app window-app sheet item-pile-inventory"],
+ width: 550,
+ height: "auto",
+ });
+ }
+
+ static getActiveApps(id) {
+ return Object.values(ui.windows).filter(app => app.id === `item-pile-inventory-${id}`);
+ }
+
+ static async show(source, recipient = false, overrides = {}, options = {}, dialogData = {}) {
+ source = Utilities.getActor(source)
+ recipient = Utilities.getActor(recipient);
+ const result = Helpers.hooks.call(HOOKS.PRE_OPEN_INTERFACE, source, recipient, overrides);
+ if (result === false) return;
+ const apps = this.getActiveApps(source.id);
+ if (apps.length) {
+ for (let app of apps) {
+ app.render(false, { focus: true });
+ }
+ return
+ }
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(source, recipient, overrides, options, dialogData).render(true, { focus: true });
+ })
+ }
+
+ async close(options) {
+ const result = Helpers.hooks.call(HOOKS.PRE_CLOSE_INTERFACE, this, this.actor, this.recipient);
+ if (result === false) return;
+ Helpers.hooks.callAll(HOOKS.CLOSE_INTERFACE, this, this.actor, this.recipient);
+ return super.close(options);
+ }
+
+ /* -------------------------------------------- */
+
+ /** @override */
+ _getHeaderButtons() {
+ let buttons = super._getHeaderButtons();
+ const canConfigure = game.user.isGM;
+ if (canConfigure) {
+ buttons = [
+ {
+ label: "ITEM-PILES.Inspect.OpenSheet",
+ class: "item-piles-open-actor-sheet",
+ icon: "fas fa-user",
+ onclick: () => {
+ this.actor.sheet.render(true, { focus: true });
+ }
+ },
+ {
+ label: "ITEM-PILES.HUD.Configure",
+ class: "item-piles-configure-pile",
+ icon: "fas fa-box-open",
+ onclick: () => {
+ ItemPileConfig.show(this.actor);
+ }
+ },
+ ].concat(buttons);
+ }
+ return buttons
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/item-pile-inventory-app/item-pile-inventory-shell.svelte b/src/applications/item-pile-inventory-app/item-pile-inventory-shell.svelte
new file mode 100644
index 00000000..a0fb513d
--- /dev/null
+++ b/src/applications/item-pile-inventory-app/item-pile-inventory-shell.svelte
@@ -0,0 +1,219 @@
+
+
+
+
+
+
+
+
+
+
+ {#if $deleted}
+
+ {localize("ITEM-PILES.Inspect.Destroyed")}
+
+ {:else}
+
+
+
+ {#if showSearchBar}
+
+ Search:
+
+
+ {/if}
+
+ {#if isPileEmpty}
+
+ {localize("ITEM-PILES.Inspect.Empty")}
+
+
+ {/if}
+
+
+
+ {#if scrolled}
+
+
+ {/if}
+
+
+
+ {#if hasItems}
+
+ {/if}
+
+
+
+
+
+ {/if}
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/ItemEntry.svelte b/src/applications/merchant-app/ItemEntry.svelte
new file mode 100644
index 00000000..713927ce
--- /dev/null
+++ b/src/applications/merchant-app/ItemEntry.svelte
@@ -0,0 +1,66 @@
+
+
+
+
+
+
+
+
+
+ {#if $pileData.canInspectItems || game.user.isGM}
+
{$itemName}
+ {:else}
+ {$itemName}
+ {/if}
+ {#if displayQuantity}
+ {#if itemFlagData.infiniteQuantity}
+
(ā)
+ {:else if !showEditQuantity}
+
{ if(game.user.isGM) showEditQuantity = true; }}>(x{quantity})
+ {/if}
+ {/if}
+ {#if showEditQuantity}
+
+
+ { showEditQuantity = false; item.updateQuantity(editQuantity); }}
+ on:keydown={(evt) => { if(evt.key === "Enter") showEditQuantity = false; }}/>
+
+
+ {/if}
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/MerchantBuyTab.svelte b/src/applications/merchant-app/MerchantBuyTab.svelte
new file mode 100644
index 00000000..4a72e9b9
--- /dev/null
+++ b/src/applications/merchant-app/MerchantBuyTab.svelte
@@ -0,0 +1,107 @@
+
+
+
+
+
+
+ {localize("ITEM-PILES.Merchant.AllTypes")}
+ {#each $itemCategoriesStore as category (category.type)}
+ {category.label}
+ {/each}
+
+
+
+{#each $categoryStore as category, index (category.type)}
+
+
+
+ {localize(category.label)}
+
+
+
+ {#if $editPrices}
+ {#if $priceModifiersPerType[category.type]}
+ { store.removeOverrideTypePrice(category.type) }}>
+ {:else}
+ { store.addOverrideTypePrice(category.type) }}>
+ {/if}
+ {/if}
+
+
+
+
+ {#each $itemsPerCategoryStore[category.type] as item (item.id)}
+
+ {/each}
+
+
+{/each}
+
+{#if !$categoryStore.length}
+
+
+
+
+ {localize("ITEM-PILES.Merchant.NoItemsForSale")}
+
+
+
+
+{/if}
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/MerchantCurrencyColumn.svelte b/src/applications/merchant-app/MerchantCurrencyColumn.svelte
new file mode 100644
index 00000000..9c650bec
--- /dev/null
+++ b/src/applications/merchant-app/MerchantCurrencyColumn.svelte
@@ -0,0 +1,28 @@
+
+
+
+
+
+
+
+
+
+
+ {#if abbreviation}
+ {abbreviation.replace("{#}", $quantity)}
+ {:else}
+ {$name} (x{$quantity})
+ {/if}
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/MerchantItemBuyEntry.svelte b/src/applications/merchant-app/MerchantItemBuyEntry.svelte
new file mode 100644
index 00000000..597f108d
--- /dev/null
+++ b/src/applications/merchant-app/MerchantItemBuyEntry.svelte
@@ -0,0 +1,138 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/MerchantItemSellEntry.svelte b/src/applications/merchant-app/MerchantItemSellEntry.svelte
new file mode 100644
index 00000000..14172eeb
--- /dev/null
+++ b/src/applications/merchant-app/MerchantItemSellEntry.svelte
@@ -0,0 +1,149 @@
+
+
+
+
+
+
+
+
+
+
+ {#if $pileData.canInspectItems || game.user.isGM}
+
{$itemName}
+ {:else}
+ {$itemName}
+ {/if}
+ {#if displayQuantity}
+ {#if itemFlagData.infiniteQuantity}
+
(ā)
+ {:else if !showEditQuantity}
+
{ if(game.user.isGM) showEditQuantity = true; }}>(x{quantity})
+ {/if}
+ {/if}
+ {#if showEditQuantity}
+
+
+ { showEditQuantity = false; item.updateQuantity(editQuantity); }}
+ on:keydown={(evt) => { if(evt.key === "Enter") showEditQuantity = false; }}/>
+
+
+ {/if}
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/MerchantLeftPane.svelte b/src/applications/merchant-app/MerchantLeftPane.svelte
new file mode 100644
index 00000000..ad7bfb77
--- /dev/null
+++ b/src/applications/merchant-app/MerchantLeftPane.svelte
@@ -0,0 +1,194 @@
+
+
+
+
+
+
+
+
+ {#if activeSidebarTab}
+
+
+
+
+
+
+
+ {#if activeSidebarTab === 'description'}
+
+ {@html description || ""}
+ {#if !description}
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Main.EditDescription")}
+ {/if}
+
+ {/if}
+
+ {#if activeSidebarTab === 'settings'}
+
+
+
+
+
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Merchant.BuyPriceModifier")}
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.ItemPileConfig.Merchant.SellPriceModifier")}
+
+
+
+
+
+
+
{ store.update(); }}>
+ Update
+
+
+ {/if}
+
+
+
+
+
+ {/if}
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/MerchantPopulateItemsTab.svelte b/src/applications/merchant-app/MerchantPopulateItemsTab.svelte
new file mode 100644
index 00000000..5e5a1d33
--- /dev/null
+++ b/src/applications/merchant-app/MerchantPopulateItemsTab.svelte
@@ -0,0 +1,294 @@
+
+
+
+
+
+
+
+ {#each $tables as table (table.id)}
+ {table.name}
+ {/each}
+ {#if !$tables.length}
+ {localize("ITEM-PILES.Merchant.NoRollTables")}
+ {/if}
+
+
+
+
+
+ {localize("Roll")}
+
+
+
+
+
+
+
+
+
+ {localize(currentItems.length ? "ITEM-PILES.Merchant.CurrentItems" : "ITEM-PILES.Merchant.BuyNoItems")}
+
+
+ {#each currentItems as item (item.id)}
+
+
+
+ {/each}
+
+ {#if currentItems.length}
+
clearAllItems()}>
+ {localize("ITEM-PILES.Merchant.ClearAllItems")}
+
+ {/if}
+
+
+
+
+
+
+
+
+ {#if $itemsRolled.length}
+ {#each $itemsRolled as item (item.resultId)}
+
+
addItem(item)}>
+
+
+
+
+
+
+
+
+
+
+
+
removeItem(item)}>
+
+
+
+ {/each}
+
+
addAllItems()}>
+ {localize("ITEM-PILES.Merchant.AddAll")}
+
+
+ {/if}
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/MerchantRightPane.svelte b/src/applications/merchant-app/MerchantRightPane.svelte
new file mode 100644
index 00000000..d53ff8d6
--- /dev/null
+++ b/src/applications/merchant-app/MerchantRightPane.svelte
@@ -0,0 +1,85 @@
+
+
+
+
+
+
+
+
+ {#if activeTab === "buy"}
+
+ {:else if activeTab === "sell"}
+
+ {:else if activeTab === "tables"}
+
+ {/if}
+
+
+
+
+ {#if recipientStore && $currencies.length}
+
+ {#each $currencies as currency (currency.identifier)}
+
+ {/each}
+
+ {/if}
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/MerchantSellTab.svelte b/src/applications/merchant-app/MerchantSellTab.svelte
new file mode 100644
index 00000000..a6b2f508
--- /dev/null
+++ b/src/applications/merchant-app/MerchantSellTab.svelte
@@ -0,0 +1,71 @@
+
+
+{#each $categoryStore as category, index (category.type)}
+
+
+
+ {localize(category.label)}
+
+
+
+
+ {#each $itemsPerCategoryStore[category.type] as item (item.id)}
+
+ {/each}
+
+
+{/each}
+
+{#if !$categoryStore.length}
+
+
+
+
+ {localize("ITEM-PILES.Merchant.NoItemsToSell")}
+
+
+
+
+{/if}
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/MerchantTopBar.svelte b/src/applications/merchant-app/MerchantTopBar.svelte
new file mode 100644
index 00000000..f74ec6e2
--- /dev/null
+++ b/src/applications/merchant-app/MerchantTopBar.svelte
@@ -0,0 +1,49 @@
+
+
+
+
{$merchantName}
+ {#if $pileDataStore.openTimes.enabled}
+
+ {localize("ITEM-PILES.Merchant.OpenTimes")}
+ {openTimeText}
+
+ {/if}
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/merchant-app-shell.svelte b/src/applications/merchant-app/merchant-app-shell.svelte
new file mode 100644
index 00000000..b2bf41fc
--- /dev/null
+++ b/src/applications/merchant-app/merchant-app-shell.svelte
@@ -0,0 +1,109 @@
+
+
+
+
+ { $priceSelector = ""; }}/>
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/merchant-app/merchant-app.js b/src/applications/merchant-app/merchant-app.js
new file mode 100644
index 00000000..9067dc98
--- /dev/null
+++ b/src/applications/merchant-app/merchant-app.js
@@ -0,0 +1,91 @@
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+import ItemPileConfig from "../item-pile-config/item-pile-config";
+import MerchantAppShell from "./merchant-app-shell.svelte";
+
+export default class MerchantApp extends SvelteApplication {
+
+ constructor(merchant, recipient = false, options = {}, dialogData = {}) {
+ super({
+ title: `Merchant: ${merchant.name}`,
+ id: `item-pile-merchant-${merchant.id}`,
+ svelte: {
+ class: MerchantAppShell,
+ target: document.body,
+ props: {
+ merchant,
+ recipient
+ }
+ },
+ zIndex: 100,
+ ...options
+ }, dialogData);
+ this.merchant = merchant;
+ }
+
+ /** @inheritdoc */
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ classes: ["app window-app sheet", "item-piles-merchant-sheet"],
+ width: 800,
+ height: 700,
+ closeOnSubmit: false,
+ resizable: true
+ });
+ }
+
+ static getActiveApp(id) {
+ return Object.values(ui.windows).find(app => app.id === `item-pile-merchant-${id}`);
+ }
+
+ static async show(merchant, recipient = false, options = {}, dialogData = {}) {
+ merchant = merchant?.actor ?? merchant;
+ recipient = recipient?.actor ?? recipient
+ const app = this.getActiveApp(merchant.id);
+ if (app) return app.render(false, { focus: true });
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(merchant, recipient, options, dialogData).render(true, { focus: true });
+ })
+ }
+
+ refreshItems() {
+ this.svelte.applicationShell.store.refreshItems();
+ }
+
+ /** @override */
+ _getHeaderButtons() {
+ let buttons = super._getHeaderButtons();
+ const canConfigure = game.user.isGM;
+ if (canConfigure) {
+ buttons = [
+ {
+ label: "ITEM-PILES.Inspect.OpenSheet",
+ class: "item-piles-open-actor-sheet",
+ icon: "fas fa-user",
+ onclick: () => {
+ this.merchant.sheet.render(true, { focus: true });
+ }
+ },
+ {
+ label: "ITEM-PILES.HUD.Configure",
+ class: "item-piles-configure-pile",
+ icon: "fas fa-box-open",
+ onclick: () => {
+ ItemPileConfig.show(this.merchant);
+ }
+ },
+ ].concat(buttons);
+ }
+ return buttons
+ }
+
+ async close(options) {
+ for (const app of Object.values(ui.windows)) {
+ if (app !== this && this.svelte.applicationShell.store === app?.svelte?.applicationShell?.store) {
+ app.close();
+ }
+ }
+ return super.close(options);
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/settings-app/Setting.svelte b/src/applications/settings-app/Setting.svelte
new file mode 100644
index 00000000..353c3909
--- /dev/null
+++ b/src/applications/settings-app/Setting.svelte
@@ -0,0 +1,115 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/settings-app/SettingButton.svelte b/src/applications/settings-app/SettingButton.svelte
new file mode 100644
index 00000000..e4e3314d
--- /dev/null
+++ b/src/applications/settings-app/SettingButton.svelte
@@ -0,0 +1,97 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/settings-app/settings-app.js b/src/applications/settings-app/settings-app.js
new file mode 100644
index 00000000..b2ef13a0
--- /dev/null
+++ b/src/applications/settings-app/settings-app.js
@@ -0,0 +1,50 @@
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+import SettingsShell from './settings-shell.svelte';
+
+class SettingsApp extends SvelteApplication {
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ id: `item-piles-application-system-settings`,
+ title: "Item Piles Module Configuration",
+ width: 600,
+ svelte: {
+ class: SettingsShell,
+ target: document.body
+ },
+ zIndex: 100,
+ });
+ }
+
+ static getActiveApp() {
+ return Object.values(ui.windows).find(app => app.id === "item-piles-application-system-settings");
+ }
+
+ static async show(options = {}, dialogData = {}) {
+ const app = this.getActiveApp()
+ if (app) return app.render(false, { focus: true });
+ return new Promise((resolve) => {
+ options.resolve = resolve;
+ new this(options, dialogData).render(true, { focus: true });
+ })
+ }
+}
+
+export default class SettingsShim extends FormApplication {
+
+ /**
+ * @inheritDoc
+ */
+ constructor() {
+ super({});
+ SettingsApp.show();
+ }
+
+ async _updateObject(event, formData) {
+ }
+
+ render() {
+ this.close();
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/settings-app/settings-shell.svelte b/src/applications/settings-app/settings-shell.svelte
new file mode 100644
index 00000000..4248f154
--- /dev/null
+++ b/src/applications/settings-app/settings-shell.svelte
@@ -0,0 +1,195 @@
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Applications.Settings.Title")}
+
+
+
+
+
+
+
+ {#if userIsGM}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {/if}
+
+
+
+
+ {localize("ITEM-PILES.Applications.Settings.Submit")}
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/trade-dialogs/ActorDropSelect.svelte b/src/applications/trade-dialogs/ActorDropSelect.svelte
new file mode 100644
index 00000000..9217ac30
--- /dev/null
+++ b/src/applications/trade-dialogs/ActorDropSelect.svelte
@@ -0,0 +1,131 @@
+
+
+
+
+
+ {#if hasUnlinkedTokenOwnership}
+
+
+
+ {localize("ITEM-PILES.Trade.Prompt.PickToken")}
+
+
+ {/if}
+
+
+
\ No newline at end of file
diff --git a/src/applications/trade-dialogs/trade-dialog-prompt.svelte b/src/applications/trade-dialogs/trade-dialog-prompt.svelte
new file mode 100644
index 00000000..377eb795
--- /dev/null
+++ b/src/applications/trade-dialogs/trade-dialog-prompt.svelte
@@ -0,0 +1,134 @@
+
+
+
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Trade.Prompt.Title")}
+
+
+
+
{localize("ITEM-PILES.Trade.Prompt.User")}
+
+
+
+
+ {#each users as potentialUser (potentialUser.id)}
+ {potentialUser.name}
+ {/each}
+
+
+
+
+
+
+
+ {localize("ITEM-PILES.Trade.Private")}
+
+ {localize("ITEM-PILES.Trade.PrivateExplanation")}
+
+
+
+ {#if actor}
+
{localize("ITEM-PILES.Trade.Prompt.PickedActor")}
+ {:else}
+
{localize("ITEM-PILES.Trade.Prompt.PickActor")}
+ {/if}
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/trade-dialogs/trade-dialog-request.svelte b/src/applications/trade-dialogs/trade-dialog-request.svelte
new file mode 100644
index 00000000..f6459d7e
--- /dev/null
+++ b/src/applications/trade-dialogs/trade-dialog-request.svelte
@@ -0,0 +1,172 @@
+
+
+
+
+
+
+
+
+
+
+ { localize("ITEM-PILES.Trade.Request.Title") }
+
+
+
+
+ {#if isPrivate}
+
{@html localize("ITEM-PILES.Trade.Request.PrivateContent", {
+ trading_user_name: tradingUser.name,
+ trading_actor_name: tradingActor.name
+ })}
+ {:else}
+
{localize("ITEM-PILES.Trade.Request.Content", {
+ trading_user_name: tradingUser.name,
+ trading_actor_name: tradingActor.name
+ })}
+ {/if}
+
{localize("ITEM-PILES.Trade.Request.AcceptQuery")}
+
+
+ {#if actor}
+
{localize("ITEM-PILES.Trade.Prompt.PickedActor")}
+ {:else}
+
{localize("ITEM-PILES.Trade.Prompt.PickActor")}
+ {/if}
+
+
+
+
+
+
0}>
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/trade-dialogs/trade-dialogs.js b/src/applications/trade-dialogs/trade-dialogs.js
new file mode 100644
index 00000000..5643ad7e
--- /dev/null
+++ b/src/applications/trade-dialogs/trade-dialogs.js
@@ -0,0 +1,82 @@
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+import TradeDialogPrompt from './trade-dialog-prompt.svelte';
+import TradeDialogRequest from './trade-dialog-request.svelte';
+
+export class TradePromptDialog extends SvelteApplication {
+
+ constructor(tradeOptions, options = {}) {
+ super({
+ svelte: {
+ class: TradeDialogPrompt,
+ target: document.body,
+ props: {
+ ...tradeOptions
+ }
+ },
+ close: () => this.options.resolve?.(null),
+ ...options
+ });
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ title: game.i18n.localize("ITEM-PILES.Trade.Title"),
+ width: 400,
+ height: "auto",
+ classes: ["dialog"],
+ })
+ }
+
+ static show(tradeOptions, options = {}, dialogData = {}) {
+ return new Promise(resolve => {
+ options.resolve = resolve;
+ new this(tradeOptions, options, dialogData).render(true);
+ })
+ }
+}
+
+export class TradeRequestDialog extends SvelteApplication {
+
+ constructor(tradeOptions, options = {}) {
+
+ super({
+ svelte: {
+ class: TradeDialogRequest,
+ target: document.body,
+ props: {
+ ...tradeOptions
+ }
+ },
+ close: () => this.options.resolve?.(null),
+ ...options
+ });
+ this.tradeId = tradeOptions.tradeId;
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ title: game.i18n.localize("ITEM-PILES.Trade.Title"),
+ width: 400,
+ height: "auto",
+ classes: ["dialog"],
+ })
+ }
+
+ static show(tradeOptions, options = {}) {
+ return new Promise(resolve => {
+ options.resolve = resolve;
+ new this(tradeOptions, options).render(true);
+ })
+ }
+
+ static cancel(tradeId) {
+ for (const app of Object.values(ui.windows)) {
+ if (app instanceof this && app.tradeId === tradeId) {
+ app.options.resolve({ type: "cancelled" });
+ return app.close();
+ }
+ }
+ return false;
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/trading-app/TradeEntry.svelte b/src/applications/trading-app/TradeEntry.svelte
new file mode 100644
index 00000000..39b5d0b1
--- /dev/null
+++ b/src/applications/trading-app/TradeEntry.svelte
@@ -0,0 +1,92 @@
+
+
+
+
+ {#if editable}
+
+ {/if}
+
+
+
+
+
+
+
+
+ {#if data.editing}
+
+
+
+ {/if}
+
+
+
+ {#if editable}
+
+ {#if data.editing}
+
+
+
+ {:else}
+
+ {data.quantity}
+
+ {/if}
+
+ {:else}
+
{data.quantity}
+ {/if}
+
+
\ No newline at end of file
diff --git a/src/applications/trading-app/trade-store.js b/src/applications/trading-app/trade-store.js
new file mode 100644
index 00000000..9545fac4
--- /dev/null
+++ b/src/applications/trading-app/trade-store.js
@@ -0,0 +1,225 @@
+import { writable, get } from 'svelte/store';
+import * as Utilities from "../../helpers/utilities.js";
+
+export default class TradeStore {
+
+ constructor(leftTrader, rightTrader, publicTradeId, privateTradeId = false, isPrivate = false) {
+
+ this.publicTradeId = publicTradeId;
+ this.privateTradeId = privateTradeId;
+ this.isPrivate = isPrivate;
+
+ this.leftTraderUser = leftTrader.user;
+ this.leftTraderActor = leftTrader.actor;
+ this.leftTraderItems = writable(leftTrader.items ?? []);
+ this.leftTraderCurrencies = writable(leftTrader.currencies ?? []);
+ this.leftTraderItemCurrencies = writable(leftTrader.itemCurrencies ?? []);
+ this.leftTraderAccepted = writable(leftTrader.accepted ?? false);
+
+ this.rightTraderUser = rightTrader.user;
+ this.rightTraderActor = rightTrader.actor;
+ this.rightTraderItems = writable(rightTrader.items ?? []);
+ this.rightTraderCurrencies = writable(rightTrader.currencies ?? []);
+ this.rightTraderItemCurrencies = writable(rightTrader.itemCurrencies ?? []);
+ this.rightTraderAccepted = writable(rightTrader?.accepted ?? false);
+
+ }
+
+ static import(leftTraderData, rightTraderData, publicTradeId) {
+
+ const leftTrader = {
+ user: game.users.get(leftTraderData.user),
+ actor: Utilities.fromUuidFast(leftTraderData.actorUiid),
+ items: leftTraderData.items,
+ currencies: leftTraderData.currencies,
+ itemCurrencies: leftTraderData.itemCurrencies,
+ accepted: leftTraderData.accepted
+ };
+
+ const rightTrader = {
+ user: game.users.get(rightTraderData.user),
+ actor: Utilities.fromUuidFast(rightTraderData.actorUiid),
+ items: rightTraderData.items,
+ currencies: rightTraderData.currencies,
+ itemCurrencies: rightTraderData.itemCurrencies,
+ accepted: rightTraderData.accepted
+ };
+
+ return new this(leftTrader, rightTrader, publicTradeId);
+ }
+
+ export() {
+ return [{
+ userId: this.leftTraderUser.id,
+ actorUiid: Utilities.getUuid(this.leftTraderActor),
+ items: get(this.leftTraderItems),
+ currencies: get(this.leftTraderCurrencies),
+ itemCurrencies: get(this.leftTraderItemCurrencies),
+ accepted: get(this.leftTraderAccepted)
+ }, {
+ userId: this.rightTraderUser.id,
+ actorUiid: Utilities.getUuid(this.rightTraderActor),
+ items: get(this.rightTraderItems),
+ currencies: get(this.rightTraderCurrencies),
+ itemCurrencies: get(this.rightTraderItemCurrencies),
+ accepted: get(this.rightTraderAccepted)
+ }, this.publicTradeId]
+ }
+
+ getTradeData() {
+ return {
+ sourceActor: this.leftTraderActor,
+ targetActor: this.rightTraderActor,
+ remove: {
+ items: get(this.leftTraderItems).concat(get(this.leftTraderItemCurrencies)),
+ attributes: get(this.leftTraderCurrencies)
+ }, add: {
+ items: get(this.rightTraderItems).concat(get(this.rightTraderItemCurrencies)),
+ attributes: get(this.rightTraderCurrencies)
+ }
+ };
+ }
+
+ getExistingCurrencies() {
+ return [...get(this.leftTraderCurrencies), ...get(this.leftTraderItemCurrencies)]
+ }
+
+ get tradeIsAccepted() {
+ return get(this.leftTraderAccepted) && get(this.rightTraderAccepted);
+ }
+
+ async toggleAccepted() {
+ this.leftTraderAccepted.set(!get(this.leftTraderAccepted));
+ }
+
+ updateItems(userId, inItems) {
+ if (userId === game.user.id) return;
+ this.leftTraderAccepted.set(false);
+ this.rightTraderAccepted.set(false);
+ if (userId === this.leftTraderUser.id) {
+ this.leftTraderItems.set(inItems)
+ }
+ if (userId === this.rightTraderUser.id) {
+ this.rightTraderItems.set(inItems)
+ }
+ }
+
+ updateItemCurrencies(userId, itemCurrencies) {
+ if (userId === game.user.id) return;
+ this.leftTraderAccepted.set(false);
+ this.rightTraderAccepted.set(false);
+ if (userId === this.leftTraderUser.id) {
+ this.leftTraderItemCurrencies.set(itemCurrencies)
+ }
+ if (userId === this.rightTraderUser.id) {
+ this.rightTraderItemCurrencies.set(itemCurrencies)
+ }
+ }
+
+ updateCurrencies(userId, inCurrencies) {
+ if (userId === game.user.id) return;
+ this.leftTraderAccepted.set(false);
+ this.rightTraderAccepted.set(false);
+ if (userId === this.leftTraderUser.id) {
+ this.leftTraderCurrencies.set(inCurrencies)
+ }
+ if (userId === this.rightTraderUser.id) {
+ this.rightTraderCurrencies.set(inCurrencies)
+ }
+ }
+
+ updateAcceptedState(userId, state) {
+ if (userId === game.user.id) return;
+ if (userId === this.leftTraderUser.id) {
+ this.leftTraderAccepted.set(state);
+ }
+ if (userId === this.rightTraderUser.id) {
+ this.rightTraderAccepted.set(state);
+ }
+ }
+
+ addItem(newItem, { quantity = false, currency = false } = {}) {
+
+ const items = !currency ? get(this.leftTraderItems) : get(this.leftTraderItemCurrencies);
+
+ const item = Utilities.findSimilarItem(items, newItem)
+
+ const maxQuantity = game.user.isGM ? Infinity : Utilities.getItemQuantity(newItem);
+
+ if (!item) {
+ items.push({
+ id: newItem._id,
+ name: newItem.name,
+ img: newItem?.img ?? "",
+ currency: currency,
+ quantity: quantity ? quantity : 1,
+ newQuantity: quantity ? quantity : 1,
+ maxQuantity: maxQuantity,
+ data: newItem
+ })
+ } else {
+ if (item.quantity >= maxQuantity) return;
+ item.quantity = Math.min(quantity ? quantity : item.quantity + 1, maxQuantity);
+ item.newQuantity = item.quantity;
+ item.maxQuantity = maxQuantity;
+ }
+
+ if (!currency) {
+ this.leftTraderItems.set(items);
+ } else {
+ this.leftTraderItemCurrencies.set(items);
+ }
+
+ }
+
+ addAttribute(newCurrency) {
+
+ const currencies = get(this.leftTraderCurrencies);
+
+ const existingCurrency = currencies.find(currency => currency.path === newCurrency.path);
+
+ if (existingCurrency) {
+ existingCurrency.quantity = newCurrency.quantity;
+ existingCurrency.newQuantity = newCurrency.quantity;
+ } else {
+ currencies.push(newCurrency);
+ }
+
+ currencies.sort((a, b) => a.index - b.index);
+
+ this.leftTraderCurrencies.set(currencies);
+
+ }
+
+ removeEntry(entry) {
+
+ if (entry.id) {
+
+ if (!entry.currency) {
+
+ const items = get(this.leftTraderItems)
+ .filter(item => item.id !== entry.id);
+
+ this.leftTraderItems.set(items);
+
+ } else {
+
+ const items = get(this.leftTraderItemCurrencies)
+ .filter(item => item.id !== entry.id);
+
+ this.leftTraderItemCurrencies.set(items);
+
+ }
+
+ } else {
+
+ const items = get(this.leftTraderCurrencies)
+ .filter(currency => currency.path !== entry.path);
+
+ this.leftTraderCurrencies.set(items);
+
+ }
+
+ }
+
+}
\ No newline at end of file
diff --git a/src/applications/trading-app/trading-app-shell.svelte b/src/applications/trading-app/trading-app-shell.svelte
new file mode 100644
index 00000000..61df783a
--- /dev/null
+++ b/src/applications/trading-app/trading-app-shell.svelte
@@ -0,0 +1,398 @@
+
+
+
+
+
+
+ {#if $leftTraderAccepted && $rightTraderAccepted}
+
+ {/if}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {#if !$leftItems.length}
+
+
{localize("ITEM-PILES.Trade.DragDrop")}
+
+ {/if}
+
+ {#each $leftItems as item (item.id)}
+
+ {/each}
+
+
+
+ {#if systemHasCurrencies}
+
+
+
+ {#if !spectator}
+
+ {/if}
+
+ {#each $leftCurrencies as currency (currency.path)}
+
+ {/each}
+
+ {#each $leftItemCurrencies as item (item.path)}
+
+ {/each}
+
+
+
+ {/if}
+
+
+
+
{ store.toggleAccepted(store.leftTraderUser.id) }}>
+ {#if $leftTraderAccepted}
+
+ {localize("Cancel")}
+ {:else}
+
+ {localize("ITEM-PILES.Trade.Accept")}
+ {/if}
+
+
+
+
+
+
+
+
+
+
+
+
+ {#each $rightItems as item (item.id)}
+
+ {/each}
+
+
+
+ {#if systemHasCurrencies}
+
+
+
+ {#if $rightCurrencies.length }
+
+ {/if}
+
+ {#each $rightCurrencies as currency (currency.path)}
+
+ {/each}
+
+ {#each $rightItemCurrencies as item (item.path)}
+
+ {/each}
+
+
+
+ {/if}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/applications/trading-app/trading-app.js b/src/applications/trading-app/trading-app.js
new file mode 100644
index 00000000..7a97b763
--- /dev/null
+++ b/src/applications/trading-app/trading-app.js
@@ -0,0 +1,50 @@
+import { SvelteApplication } from '@typhonjs-fvtt/runtime/svelte/application';
+import TradingAppShell from "./trading-app-shell.svelte";
+import ItemPileSocket from "../../socket.js";
+
+export default class TradingApp extends SvelteApplication {
+ constructor(store, options = {}, dialogData = {}) {
+ super({
+ title: game.i18n.format("ITEM-PILES.Trade.Between", {
+ actor_1: store.leftTraderActor.name,
+ actor_2: store.rightTraderActor.name
+ }),
+ svelte: {
+ class: TradingAppShell,
+ target: document.body,
+ props: {
+ store
+ }
+ },
+ ...options
+ }, dialogData);
+
+ this.publicTradeId = store.publicTradeId;
+ }
+
+ static get defaultOptions() {
+ return foundry.utils.mergeObject(super.defaultOptions, {
+ zIndex: 100,
+ classes: ["dialog", "item-piles-trading-sheet"],
+ width: 800,
+ height: "auto",
+ closeOnSubmit: false
+ });
+ }
+
+ async close(options = {}) {
+ if (!options?.callback) {
+ await ItemPileSocket.executeForEveryone(ItemPileSocket.HANDLERS.TRADE_CLOSED, this.publicTradeId, game.user.id);
+ }
+ return super.close(options)
+ }
+
+ static getActiveApp(publicTradeId) {
+ for (const app of Object.values(ui.windows)) {
+ if (app instanceof this && app?.publicTradeId === publicTradeId) {
+ return app;
+ }
+ }
+ return false;
+ }
+}
\ No newline at end of file
diff --git a/src/constants/constants.js b/src/constants/constants.js
new file mode 100644
index 00000000..f4b7215c
--- /dev/null
+++ b/src/constants/constants.js
@@ -0,0 +1,105 @@
+const module_name = "item-piles";
+const module_path = `modules/${module_name}/`;
+const baseFlag = `flags.${module_name}.`
+
+const CONSTANTS = {
+
+ MODULE_NAME: module_name,
+ PATH: module_path,
+
+ FLAGS: {
+ PILE: baseFlag + "data",
+ SHARING: baseFlag + "sharing",
+ ITEM: baseFlag + "item",
+ PUBLIC_TRADE_ID: baseFlag + "publicTradeId",
+ TRADE_USERS: baseFlag + "tradeUsers",
+ TEMPORARY_ITEM: baseFlag + "temporary_item"
+ },
+
+ ITEM_DEFAULTS: {
+ hidden: false,
+ notForSale: false,
+ infiniteQuantity: false,
+ displayQuantity: "default",
+ free: false,
+ disableNormalCost: false,
+ cantBeSoldToMerchants: false,
+ prices: []
+ },
+
+ PILE_DEFAULTS: {
+ // Core settings
+ enabled: false,
+ distance: 1,
+ macro: "",
+ deleteWhenEmpty: "default",
+ canInspectItems: true,
+ description: "",
+
+ // Overrides
+ overrideItemFilters: false,
+ overrideCurrencies: false,
+
+ // Token settings
+ displayOne: false,
+ showItemName: false,
+ overrideSingleItemScale: false,
+ singleItemScale: 1.0,
+
+ // Sharing settings
+ shareItemsEnabled: false,
+ shareCurrenciesEnabled: true,
+ takeAllEnabled: false,
+ splitAllEnabled: true,
+ activePlayers: false,
+
+ // Container settings
+ isContainer: false,
+ closed: false,
+ locked: false,
+ closedImage: "",
+ closedImages: [],
+ emptyImage: "",
+ emptyImages: [],
+ openedImage: "",
+ openedImages: [],
+ lockedImage: "",
+ lockedImages: [],
+ closeSound: "",
+ closeSounds: [],
+ openSound: "",
+ openSounds: [],
+ lockedSound: "",
+ lockedSounds: [],
+ unlockedSound: "",
+ unlockedSounds: [],
+
+ // Merchant settings
+ isMerchant: false,
+ merchantImage: "",
+ isClosed: false,
+ infiniteQuantity: false,
+ infiniteCurrencies: true,
+ purchaseOnly: false,
+ hideNewItems: false,
+ onlyAcceptBasePrice: true,
+ displayQuantity: "yes",
+ buyPriceModifier: 1,
+ sellPriceModifier: 0.5,
+ itemTypePriceModifiers: [],
+ actorPriceModifiers: [],
+ openTimes: {
+ enabled: false,
+ open: {
+ hour: 9,
+ minute: 0
+ },
+ close: {
+ hour: 18,
+ minute: 0
+ }
+ }
+ }
+}
+
+export default CONSTANTS;
\ No newline at end of file
diff --git a/src/constants/hooks.js b/src/constants/hooks.js
new file mode 100644
index 00000000..91bb8c04
--- /dev/null
+++ b/src/constants/hooks.js
@@ -0,0 +1,70 @@
+import CONSTANTS from "./constants.js";
+
+const prefix = (string) => (strings, ...expressions) => `${string}-${strings.reduce((a, c, i) => a + expressions[i - 1] + c)}`
+const module = prefix(CONSTANTS.MODULE_NAME);
+
+const HOOKS = {
+ READY: module`ready`,
+ PRE_TRANSFER_EVERYTHING: module`preTransferEverything`,
+ TRANSFER_EVERYTHING: module`transferEverything`,
+ PRE_OPEN_INTERFACE: module`preOpenInterface`,
+ OPEN_INTERFACE: module`openInterface`,
+ PRE_CLOSE_INTERFACE: module`preCloseInterface`,
+ CLOSE_INTERFACE: module`closeInterface`,
+ PILE: {
+ PRE_CREATE: module`preCreateItemPile`,
+ CREATE: module`createItemPile`,
+ PRE_UPDATE: module`preUpdateItemPile`,
+ UPDATE: module`updateItemPile`,
+ PRE_DELETE: module`preDeleteItemPile`,
+ DELETE: module`deleteItemPile`,
+ PRE_CLOSE: module`preCloseItemPile`,
+ CLOSE: module`closeItemPile`,
+ PRE_OPEN: module`preOpenItemPile`,
+ OPEN: module`openItemPile`,
+ PRE_LOCK: module`preLockItemPile`,
+ LOCK: module`lockItemPile`,
+ PRE_UNLOCK: module`preUnlockItemPile`,
+ UNLOCK: module`unlockItemPile`,
+ PRE_RATTLE: module`preRattleItemPile`,
+ RATTLE: module`rattleItemPile`,
+ PRE_TURN_INTO: module`preTurnIntoItemPiles`,
+ TURN_INTO: module`turnIntoItemPiles`,
+ PRE_REVERT_FROM: module`preRevertFromItemPiles`,
+ REVERT_FROM: module`revertFromItemPiles`,
+ PRE_SPLIT_INVENTORY: module`preSplitItemPileContent`,
+ SPLIT_INVENTORY: module`splitItemPileContent`,
+ },
+ ITEM: {
+ PRE_DROP_DETERMINED: module`preDropItemDetermined`,
+ PRE_DROP: module`preDropItem`,
+ DROP: module`dropItem`,
+ PRE_TRANSFER: module`preTransferItems`,
+ TRANSFER: module`transferItems`,
+ PRE_ADD: module`preAddItems`,
+ ADD: module`addItems`,
+ PRE_REMOVE: module`preRemoveItems`,
+ REMOVE: module`removeItems`,
+ PRE_TRANSFER_ALL: module`preTransferAllItems`,
+ TRANSFER_ALL: module`transferAllItems`,
+ PRE_TRADE: module`preTradeItems`,
+ PRE_CALC_TRADE: module`preCalculateTradeItems`,
+ TRADE: module`tradeItems`,
+ },
+ ATTRIBUTE: {
+ PRE_TRANSFER: module`preTransferAttributes`,
+ TRANSFER: module`transferAttributes`,
+ PRE_ADD: module`preAddAttributes`,
+ ADD: module`addAttributes`,
+ PRE_REMOVE: module`preRemoveAttributes`,
+ REMOVE: module`removeAttributes`,
+ PRE_TRANSFER_ALL: module`preTransferAllAttributes`,
+ TRANSFER_ALL: module`transferAllAttributes`,
+ },
+ TRADE: {
+ STARTED: module`tradeStarted`,
+ COMPLETE: module`tradeComplete`
+ }
+}
+
+export default HOOKS;
\ No newline at end of file
diff --git a/src/constants/settings.js b/src/constants/settings.js
new file mode 100644
index 00000000..48dbbffc
--- /dev/null
+++ b/src/constants/settings.js
@@ -0,0 +1,282 @@
+import { SYSTEMS } from "../systems.js";
+
+const SETTINGS = {
+
+ // Client settings
+ OUTPUT_TO_CHAT: "outputToChat",
+ INVERT_SHEET_OPEN: "invertSheetOpen",
+ HIDE_ACTOR_HEADER_TEXT: "hideActorHeaderText",
+ PRELOAD_FILES: "preloadFiles",
+ DEBUG: "debug",
+ DEBUG_HOOKS: "debugHooks",
+
+ // Module Settings
+ ENABLE_DROPPING_ITEMS: "enableDroppingItems",
+ ENABLE_TRADING: "enableTrading",
+ SHOW_TRADE_BUTTON: "showTradeButton",
+ DELETE_EMPTY_PILES: "deleteEmptyPiles",
+ INSPECT_ITEMS_IN_TRADE: "inspectItemsInTrade",
+
+ // System Settings
+ CURRENCIES: "currencies",
+ ITEM_FILTERS: "itemFilters",
+ ACTOR_CLASS_TYPE: "actorClassType",
+ ITEM_QUANTITY_ATTRIBUTE: "itemQuantityAttribute",
+ ITEM_PRICE_ATTRIBUTE: "itemPriceAttribute",
+ ITEM_SIMILARITIES: "itemSimilarities",
+ PRICE_PRESETS: "pricePresets",
+
+ // Hidden settings
+ DEFAULT_ITEM_PILE_JOURNAL_ID: "defaultItemPileJournalID",
+ DEFAULT_ITEM_PILE_ACTOR_ID: "defaultItemPileActorID",
+ SYSTEM_FOUND: "systemFound",
+ SYSTEM_NOT_FOUND_WARNING_SHOWN: "systemNotFoundWarningShown",
+ PRECONFIGURED_SYSTEM: "preconfiguredSystem",
+ SYSTEM_VERSION: "systemVersion",
+
+ GET_DEFAULT() {
+ return foundry.utils.deepClone(SETTINGS.DEFAULTS())
+ },
+
+ GET_SYSTEM_DEFAULTS() {
+ return Object.fromEntries(Object.entries(SETTINGS.GET_DEFAULT()).filter(entry => {
+ return entry[1].system;
+ }));
+ },
+
+ DEFAULTS: () => ({
+
+ [SETTINGS.CURRENCIES]: {
+ name: "ITEM-PILES.Settings.Currencies.Title",
+ label: "ITEM-PILES.Settings.Currencies.Label",
+ hint: "ITEM-PILES.Settings.Currencies.Hint",
+ icon: "fa fa-money-bill-alt",
+ application: "currencies",
+ scope: "world",
+ config: false,
+ system: true,
+ default: SYSTEMS.DATA.CURRENCIES,
+ type: Object
+ },
+
+ [SETTINGS.ITEM_FILTERS]: {
+ name: "ITEM-PILES.Settings.ItemFilters.Title",
+ label: "ITEM-PILES.Settings.ItemFilters.Label",
+ hint: "ITEM-PILES.Settings.ItemFilters.Hint",
+ icon: "fa fa-filter",
+ application: "item-filters",
+ scope: "world",
+ config: false,
+ system: true,
+ default: SYSTEMS.DATA.ITEM_FILTERS,
+ type: Array
+ },
+
+ [SETTINGS.ITEM_SIMILARITIES]: {
+ name: "ITEM-PILES.Settings.ItemSimilarities.Title",
+ label: "ITEM-PILES.Settings.ItemSimilarities.Label",
+ hint: "ITEM-PILES.Settings.ItemSimilarities.Hint",
+ icon: "fa fa-equals",
+ application: "item-similarities",
+ scope: "world",
+ config: false,
+ system: true,
+ default: SYSTEMS.DATA.ITEM_SIMILARITIES,
+ type: Array
+ },
+
+ [SETTINGS.PRICE_PRESETS]: {
+ name: "ITEM-PILES.Settings.PricePresets.Title",
+ label: "ITEM-PILES.Settings.PricePresets.Label",
+ hint: "ITEM-PILES.Settings.PricePresets.Hint",
+ scope: "world",
+ icon: "fa fa-tags",
+ application: "price-presets",
+ config: false,
+ system: true,
+ default: [],
+ type: Array
+ },
+
+ [SETTINGS.ACTOR_CLASS_TYPE]: {
+ name: "ITEM-PILES.Settings.ActorClass.Title",
+ hint: "ITEM-PILES.Settings.ActorClass.Hint",
+ scope: "world",
+ config: false,
+ system: true,
+ default: SYSTEMS.DATA.ACTOR_CLASS_TYPE,
+ type: String
+ },
+
+ [SETTINGS.ITEM_QUANTITY_ATTRIBUTE]: {
+ name: "ITEM-PILES.Settings.Quantity.Title",
+ hint: "ITEM-PILES.Settings.Quantity.Hint",
+ scope: "world",
+ config: false,
+ system: true,
+ default: SYSTEMS.DATA.ITEM_QUANTITY_ATTRIBUTE,
+ type: String
+ },
+
+ [SETTINGS.ITEM_PRICE_ATTRIBUTE]: {
+ name: "ITEM-PILES.Settings.Price.Title",
+ hint: "ITEM-PILES.Settings.Price.Hint",
+ scope: "world",
+ config: false,
+ system: true,
+ default: SYSTEMS.DATA.ITEM_PRICE_ATTRIBUTE,
+ type: String
+ },
+
+ [SETTINGS.SYSTEM_VERSION]: {
+ scope: "world",
+ config: false,
+ default: "0.0.0",
+ type: String
+ },
+
+ [SETTINGS.DEFAULT_ITEM_PILE_ACTOR_ID]: {
+ scope: "world",
+ config: false,
+ default: "",
+ type: String
+ },
+
+ [SETTINGS.DEFAULT_ITEM_PILE_JOURNAL_ID]: {
+ scope: "world",
+ config: false,
+ default: "",
+ type: String
+ },
+
+ [SETTINGS.SYSTEM_FOUND]: {
+ scope: "world",
+ config: false,
+ default: false,
+ type: Boolean
+ },
+
+ [SETTINGS.SYSTEM_NOT_FOUND_WARNING_SHOWN]: {
+ scope: "world",
+ config: false,
+ default: false,
+ type: Boolean
+ },
+
+ [SETTINGS.PRECONFIGURED_SYSTEM]: {
+ scope: "world",
+ config: false,
+ default: false,
+ type: Boolean
+ },
+
+ [SETTINGS.OUTPUT_TO_CHAT]: {
+ name: "ITEM-PILES.Settings.OutputToChat.Title",
+ hint: "ITEM-PILES.Settings.OutputToChat.Hint",
+ scope: "world",
+ config: false,
+ default: 1,
+ choices: [
+ "ITEM-PILES.Settings.OutputToChat.Off",
+ "ITEM-PILES.Settings.OutputToChat.Public",
+ "ITEM-PILES.Settings.OutputToChat.SelfGM",
+ "ITEM-PILES.Settings.OutputToChat.Blind",
+ ],
+ type: Number
+ },
+
+ [SETTINGS.INSPECT_ITEMS_IN_TRADE]: {
+ name: "ITEM-PILES.Settings.InspectItemsTrade.Title",
+ hint: "ITEM-PILES.Settings.InspectItemsTrade.Hint",
+ scope: "world",
+ config: false,
+ default: true,
+ type: Boolean
+ },
+
+ [SETTINGS.DELETE_EMPTY_PILES]: {
+ name: "ITEM-PILES.Settings.DeleteEmptyPiles.Title",
+ hint: "ITEM-PILES.Settings.DeleteEmptyPiles.Hint",
+ scope: "world",
+ config: false,
+ default: false,
+ type: Boolean
+ },
+
+ [SETTINGS.ENABLE_DROPPING_ITEMS]: {
+ name: "ITEM-PILES.Settings.EnableDroppingItems.Title",
+ hint: "ITEM-PILES.Settings.EnableDroppingItems.Hint",
+ scope: "world",
+ config: false,
+ default: true,
+ type: Boolean
+ },
+
+ [SETTINGS.ENABLE_TRADING]: {
+ name: "ITEM-PILES.Settings.EnableTrading.Title",
+ hint: "ITEM-PILES.Settings.EnableTrading.Hint",
+ scope: "world",
+ config: false,
+ default: true,
+ type: Boolean
+ },
+
+ [SETTINGS.SHOW_TRADE_BUTTON]: {
+ name: "ITEM-PILES.Settings.ShowTradeButton.Title",
+ hint: "ITEM-PILES.Settings.ShowTradeButton.Hint",
+ scope: "world",
+ config: false,
+ default: true,
+ type: Boolean
+ },
+
+ [SETTINGS.INVERT_SHEET_OPEN]: {
+ name: "ITEM-PILES.Settings.InvertSheetOpen.Title",
+ hint: "ITEM-PILES.Settings.InvertSheetOpen.Hint",
+ scope: "client",
+ config: false,
+ default: false,
+ type: Boolean
+ },
+
+ [SETTINGS.HIDE_ACTOR_HEADER_TEXT]: {
+ name: "ITEM-PILES.Settings.HideActorHeaderText.Title",
+ hint: "ITEM-PILES.Settings.HideActorHeaderText.Hint",
+ scope: "client",
+ config: false,
+ default: false,
+ type: Boolean
+ },
+
+ [SETTINGS.PRELOAD_FILES]: {
+ name: "ITEM-PILES.Settings.PreloadFiles.Title",
+ hint: "ITEM-PILES.Settings.PreloadFiles.Hint",
+ scope: "client",
+ config: false,
+ default: true,
+ type: Boolean
+ },
+
+ [SETTINGS.DEBUG]: {
+ name: "ITEM-PILES.Settings.Debug.Title",
+ hint: "ITEM-PILES.Settings.Debug.Hint",
+ scope: "client",
+ config: false,
+ default: false,
+ type: Boolean
+ },
+
+
+ [SETTINGS.DEBUG_HOOKS]: {
+ name: "ITEM-PILES.Settings.DebugHooks.Title",
+ hint: "ITEM-PILES.Settings.DebugHooks.Hint",
+ scope: "client",
+ config: false,
+ default: false,
+ type: Boolean
+ },
+
+ })
+}
+
+export default SETTINGS;
\ No newline at end of file
diff --git a/src/foundry-ui-overrides.js b/src/foundry-ui-overrides.js
new file mode 100644
index 00000000..d3ff9f6e
--- /dev/null
+++ b/src/foundry-ui-overrides.js
@@ -0,0 +1,109 @@
+import SETTINGS from "./constants/settings.js";
+import * as Helpers from "./helpers/helpers.js";
+import * as PileUtilities from "./helpers/pile-utilities.js";
+import ItemPileConfig from "./applications/item-pile-config/item-pile-config.js";
+import ItemEditor from "./applications/editors/item-editor/item-editor.js";
+import CONSTANTS from "./constants/constants.js";
+
+export default function registerUIOverrides() {
+ Hooks.on("renderPlayerList", addTradeButton);
+ Hooks.on("getActorDirectoryEntryContext", insertActorContextMenuItems);
+ Hooks.on("getActorSheetHeaderButtons", insertActorHeaderButtons);
+ Hooks.on("getItemSheetHeaderButtons", insertItemHeaderButtons);
+ Hooks.on("renderSidebarTab", hideTemporaryItems);
+}
+
+function hideTemporaryItems(sidebar) {
+ if (sidebar.tabName !== "items") return;
+ Array.from(game.items).filter(item => {
+ return getProperty(item.toObject(), CONSTANTS.FLAGS.TEMPORARY_ITEM);
+ })
+ .forEach(item => {
+ const element = sidebar.element.find(`.directory-item[data-document-id="${item.id}"]`);
+ if (!element.length) return;
+ if (element.parent().children().length === 1) {
+ return element.parent().empty();
+ }
+ element.find(`.directory-item[data-document-id="${item.id}"]`).remove();
+ });
+}
+
+function addTradeButton(app, html) {
+ if (!Helpers.getSetting(SETTINGS.ENABLE_TRADING) || !Helpers.getSetting(SETTINGS.SHOW_TRADE_BUTTON)) return;
+
+ const minimalUI = game.modules.get('minimal-ui')?.active;
+ const classes = "item-piles-player-list-trade-button" + (minimalUI ? " item-piles-minimal-ui" : "")
+ const text = !minimalUI ? " Request Trade" : ""
+ const button = $(` ${text} `)
+
+ button.click(() => {
+ game.itempiles.requestTrade();
+ });
+ html.append(button);
+}
+
+function insertActorContextMenuItems(html, menuItems) {
+
+ menuItems.push({
+ name: "ITEM-PILES.ContextMenu.ShowToPlayers",
+ icon: ` `,
+ callback: (html) => {
+ const actorId = html[0].dataset.documentId;
+ const actor = game.actors.get(actorId);
+ const users = Array.from(game.users).filter(u => u.active).map(u => u.id);
+ return game.itempiles.renderItemPileInterface(actor, { users, useDefaultCharacter: true });
+ },
+ condition: (html) => {
+ const actorId = html[0].dataset.documentId;
+ const actor = game.actors.get(actorId);
+ return game.user.isGM && PileUtilities.isValidItemPile(actor);
+ }
+ }, {
+ name: "ITEM-PILES.ContextMenu.RequestTrade",
+ icon: ` `,
+ callback: (html) => {
+ const actorId = html[0].dataset.documentId;
+ const actor = game.actors.get(actorId);
+ const user = Array.from(game.users).find(u => u.character === actor && u.active);
+ return game.itempiles.requestTrade(user);
+ },
+ condition: (html) => {
+ const actorId = html[0].dataset.documentId;
+ const actor = game.actors.get(actorId);
+ return Helpers.getSetting(SETTINGS.ENABLE_TRADING)
+ && (game.user?.character !== actor || Array.from(game.users).find(u => u.character === actor && u.active));
+ }
+ });
+}
+
+function insertActorHeaderButtons(actorSheet, buttons) {
+
+ if (!game.user.isGM) return;
+
+ let obj = actorSheet.object;
+
+ buttons.unshift({
+ label: Helpers.getSetting(SETTINGS.HIDE_ACTOR_HEADER_TEXT) ? "" : "Configure",
+ icon: "fas fa-box-open",
+ class: "item-piles-config-button",
+ onclick: () => {
+ ItemPileConfig.show(obj);
+ }
+ })
+}
+
+function insertItemHeaderButtons(itemSheet, buttons) {
+
+ if (!game.user.isGM) return;
+
+ let obj = itemSheet.object;
+
+ buttons.unshift({
+ label: Helpers.getSetting(SETTINGS.HIDE_ACTOR_HEADER_TEXT) ? "" : "Configure",
+ icon: "fas fa-box-open",
+ class: "item-piles-config-button",
+ onclick: () => {
+ ItemEditor.show(obj);
+ }
+ })
+}
\ No newline at end of file
diff --git a/src/helpers/helpers.js b/src/helpers/helpers.js
new file mode 100644
index 00000000..552d0a82
--- /dev/null
+++ b/src/helpers/helpers.js
@@ -0,0 +1,201 @@
+import CONSTANTS from "../constants/constants.js";
+
+export const debounceManager = {
+
+ debounces: {},
+
+ setDebounce(id, method) {
+ if (this.debounces[id]) {
+ return this.debounces[id];
+ }
+ this.debounces[id] = debounce(function (...args) {
+ delete debounceManager.debounces[id];
+ return method(...args);
+ }, 50);
+ return this.debounces[id];
+ }
+};
+
+export const hooks = {
+ run: true,
+ _hooks: {},
+
+ async runWithout(callback) {
+ this.run = false;
+ await callback();
+ this.run = true;
+ },
+
+ call(hook, ...args) {
+ if (!this.run) return;
+ return Hooks.call(hook, ...args);
+ },
+
+ callAll(hook, ...args) {
+ if (!this.run) return;
+ return Hooks.callAll(hook, ...args);
+ },
+
+ on(hook, callback) {
+ Hooks.on(hook, (...args) => {
+ if (!this.run) return;
+ callback(...args);
+ });
+ }
+}
+
+export function wait(ms) {
+ return new Promise(resolve => setTimeout(resolve, ms));
+}
+
+export function getSetting(key) {
+ return game.settings.get(CONSTANTS.MODULE_NAME, key);
+}
+
+export function setSetting(key, value) {
+ if (value === undefined) throw new Error("setSetting | value must not be undefined!");
+ return game.settings.set(CONSTANTS.MODULE_NAME, key, value);
+}
+
+export function debug(msg, args = "") {
+ if (game.settings.get(CONSTANTS.MODULE_NAME, "debug")) {
+ console.log(`DEBUG | Item Piles | ${msg}`, args)
+ }
+}
+
+export function custom_notify(message) {
+ message = `Item Piles | ${message}`;
+ ui.notifications.notify(message);
+ console.log(message.replace(" ", "\n"));
+}
+
+export function custom_warning(warning, notify = false) {
+ warning = `Item Piles | ${warning}`;
+ if (notify) {
+ ui.notifications.warn(warning);
+ }
+ console.warn(warning.replace(" ", "\n"));
+}
+
+export function custom_error(error, notify = true) {
+ error = `Item Piles | ${error}`;
+ if (notify) {
+ ui.notifications.error(error);
+ }
+ return new Error(error.replace(" ", "\n"));
+}
+
+export function dialogLayout({
+ title = "Item Piles",
+ message,
+ icon = "fas fa-exclamation-triangle",
+ extraHtml = ""
+ } = {}) {
+ return `
+
+
+
${title}
+
${message}
+ ${extraHtml}
+
+ `;
+}
+
+
+export function isRealNumber(inNumber) {
+ return !isNaN(inNumber)
+ && typeof inNumber === "number"
+ && isFinite(inNumber);
+}
+
+export function isActiveGM(user) {
+ return user.active && user.isGM;
+}
+
+export function getActiveGMs() {
+ return game.users.filter(isActiveGM);
+}
+
+export function isResponsibleGM() {
+ if (!game.user.isGM) {
+ return false;
+ }
+ return !getActiveGMs().some(other => other.data._id < game.user.data._id);
+}
+
+export function isGMConnected() {
+ return !!Array.from(game.users).find(user => user.isGM && user.active);
+}
+
+export function roundToDecimals(num, decimals) {
+ return Number(num.toFixed(decimals));
+}
+
+/**
+ * This function linearly interpolates between p1 and p2 based on a normalized value of t
+ *
+ * @param {string} inFile The start value
+ * @param {object} inOptions The end value
+ * @return {array|boolean} Interpolated value
+ */
+export async function getFiles(inFile, { applyWildCard = false, softFail = false } = {}) {
+
+ let source = 'data';
+ const browseOptions = { wildcard: applyWildCard };
+
+ if (/\.s3\./.test(inFile)) {
+ source = 's3'
+ const { bucket, keyPrefix } = FilePicker.parseS3URL(inFile);
+ if (bucket) {
+ browseOptions.bucket = bucket;
+ inFile = keyPrefix;
+ }
+ }
+
+ try {
+ return (await FilePicker.browse(source, inFile, browseOptions)).files;
+ } catch (err) {
+ if (softFail) return false;
+ throw custom_error("Sequencer", `getFiles | ${err}`);
+ }
+}
+
+/**
+ * Returns a floating point number between a minimum and maximum value
+ *
+ * @param {number} min The minimum value
+ * @param {number} max The maximum value
+ * @return {number} A random value between the range given
+ */
+export function random_float_between(min, max) {
+ const random = Math.random();
+ const _max = Math.max(max, min);
+ const _min = Math.min(max, min);
+ return random * (_max - _min) + _min;
+}
+
+/**
+ * Returns an integer between a minimum and maximum value
+ *
+ * @param {number} min The minimum value
+ * @param {number} max The maximum value
+ * @return {int} A random integer between the range given
+ */
+export function random_int_between(min, max) {
+ return Math.floor(random_float_between(min, max));
+}
+
+/**
+ * Returns a random element in the given array
+ *
+ * @param {array} inArray An array
+ * @param {boolean} recurse Whether to recurse if the randomly chosen element is also an array
+ * @return {object} A random element from the array
+ */
+export function random_array_element(inArray, { recurse = false } = {}) {
+ let choice = inArray[random_int_between(0, inArray.length)];
+ if (recurse && Array.isArray(choice)) {
+ return random_array_element(choice, { recurse: true });
+ }
+ return choice;
+}
\ No newline at end of file
diff --git a/src/helpers/pile-utilities.js b/src/helpers/pile-utilities.js
new file mode 100644
index 00000000..a325bef2
--- /dev/null
+++ b/src/helpers/pile-utilities.js
@@ -0,0 +1,880 @@
+import * as Utilities from "./utilities.js"
+import CONSTANTS from "../constants/constants.js";
+import * as Helpers from "./helpers.js";
+
+function getFlagData(inDocument, flag, defaults, existing = false) {
+ const defaultFlags = foundry.utils.duplicate(defaults);
+ const flags = existing || (getProperty(inDocument.data, flag) ?? {});
+ const data = foundry.utils.duplicate(flags);
+ return foundry.utils.mergeObject(defaultFlags, data);
+}
+
+export function getItemFlagData(item) {
+ return getFlagData(Utilities.getDocument(item), CONSTANTS.FLAGS.ITEM, CONSTANTS.ITEM_DEFAULTS);
+}
+
+export function getActorFlagData(target, data = false) {
+ return getFlagData(Utilities.getActor(target), CONSTANTS.FLAGS.PILE, CONSTANTS.PILE_DEFAULTS, data);
+}
+
+export function isValidItemPile(target, data = false) {
+ const targetActor = Utilities.getActor(target);
+ const pileData = getActorFlagData(targetActor, data);
+ return targetActor && pileData?.enabled;
+}
+
+export function isItemPileContainer(target, data = false) {
+ const targetActor = Utilities.getActor(target);
+ const pileData = getActorFlagData(targetActor, data);
+ return pileData?.enabled && pileData?.isContainer;
+}
+
+export function isItemPileMerchant(target, data = false) {
+ const targetActor = Utilities.getActor(target);
+ const pileData = getActorFlagData(targetActor, data);
+ return pileData?.enabled && pileData?.isMerchant;
+}
+
+export function isItemPileClosed(target, data = false) {
+ const targetActor = Utilities.getActor(target);
+ const pileData = getActorFlagData(targetActor, data);
+ if (!pileData?.enabled || !pileData?.isContainer) return false;
+ return pileData.closed;
+}
+
+export function isItemPileLocked(target, data = false) {
+ const targetActor = Utilities.getActor(target);
+ const pileData = getActorFlagData(targetActor, data);
+ if (!pileData?.enabled || !pileData?.isContainer) return false;
+ return pileData.locked;
+}
+
+export function isItemPileEmpty(target) {
+
+ const targetActor = Utilities.getActor(target);
+ if (!targetActor) return false;
+
+ const validItemPile = isValidItemPile(targetActor);
+ if (!validItemPile) return false;
+
+ const hasNoItems = getActorItems(targetActor).length === 0;
+ const hasNoAttributes = getActorCurrencies(targetActor).length === 0;
+
+ return validItemPile && hasNoItems && hasNoAttributes;
+
+}
+
+export function shouldItemPileBeDeleted(targetUuid) {
+
+ const target = Utilities.fromUuidFast(targetUuid);
+
+ if (!(target instanceof TokenDocument)) return false;
+
+ if (!isItemPileEmpty(target)) return false;
+
+ const pileData = getActorFlagData(target);
+
+ return {
+ "default": Helpers.getSetting("deleteEmptyPiles"), "true": true, "false": false
+ }[pileData?.deleteWhenEmpty ?? "default"];
+
+}
+
+export function getActorItems(target, { itemFilters = false } = {}) {
+ const actor = Utilities.getActor(target);
+ const actorItemFilters = itemFilters ? cleanItemFilters(itemFilters) : getActorItemFilters(actor);
+ const currencies = getActorCurrencies(actor).map(entry => entry.id);
+ return actor.items.filter(item => currencies.indexOf(item.id) === -1 && !isItemInvalid(actor, item, actorItemFilters));
+}
+
+export function getActorCurrencies(target, { forActor = false, currencyList = false, getAll = false } = {}) {
+ const actor = Utilities.getActor(target);
+ const actorItems = Array.from(actor.items);
+ currencyList = currencyList || getActorCurrencyList(forActor || actor);
+ let currencies = currencyList.map((currency, index) => {
+ if (currency.type === "attribute") {
+ return {
+ ...currency,
+ quantity: getProperty(actor.data, currency.data.path) ?? 0,
+ path: currency.data.path,
+ id: currency.data.path,
+ index
+ }
+ }
+ const item = Utilities.findSimilarItem(actorItems, currency.data.item);
+ return {
+ ...currency, quantity: item ? Utilities.getItemQuantity(item) : 0, id: item?.id || null, item, index
+ }
+ });
+ if (!getAll) {
+ currencies = currencies.filter(currency => currency.quantity);
+ }
+ return currencies;
+}
+
+export function getActorPrimaryCurrency(target) {
+ const actor = Utilities.getActor(target);
+ return getActorCurrencies(actor).find(currency => currency.primary);
+}
+
+export function getActorCurrencyList(target, pileData = false) {
+ const targetActor = Utilities.getActor(target);
+ pileData = getActorFlagData(targetActor, pileData);
+ return (pileData.overrideCurrencies || game.itempiles.CURRENCIES).map(currency => {
+ currency.name = game.i18n.localize(currency.name);
+ return currency;
+ });
+}
+
+
+export function getActorItemFilters(target, pileData = false) {
+ if (!target) return cleanItemFilters(game.itempiles.ITEM_FILTERS);
+ const targetActor = Utilities.getActor(target);
+ pileData = getActorFlagData(targetActor, pileData);
+ return isValidItemPile(targetActor, pileData) && pileData?.overrideItemFilters ? cleanItemFilters(pileData.overrideItemFilters) : cleanItemFilters(game.itempiles.ITEM_FILTERS);
+}
+
+export function cleanItemFilters(itemFilters) {
+ return itemFilters ? foundry.utils.duplicate(itemFilters).map(filter => {
+ filter.path = filter.path.trim();
+ filter.filters = Array.isArray(filter.filters) ? filter.filters : filter.filters.split(',').map(string => string.trim());
+ filter.filters = new Set(filter.filters)
+ return filter;
+ }) : [];
+}
+
+export function isItemInvalid(targetActor, item, itemFilters = false) {
+ const pileItemFilters = itemFilters ? itemFilters : getActorItemFilters(targetActor)
+ const itemData = item instanceof Item ? item.toObject() : item;
+ for (const filter of pileItemFilters) {
+ if (!hasProperty(itemData, filter.path)) continue;
+ const attributeValue = getProperty(itemData, filter.path);
+ if (filter.filters.has(attributeValue)) {
+ return attributeValue;
+ }
+ }
+ return false;
+}
+
+export function isItemCurrency(item, { target = false } = {}) {
+ const actor = Utilities.getActor(target ? target : item.parent);
+ const currencies = getActorCurrencies(actor, { getAll: true })
+ .filter(currency => currency.type === "item")
+ .map(item => item.data.item);
+ return !!Utilities.findSimilarItem(currencies, item);
+}
+
+
+export function getItemPileTokenImage(token, { data = false, items = false, currencies = false } = {}) {
+
+ const tokenDocument = Utilities.getDocument(token);
+
+ const itemPileData = getActorFlagData(tokenDocument, data);
+
+ let originalImg;
+ if (tokenDocument instanceof TokenDocument) {
+ originalImg = tokenDocument.data.img;
+ } else {
+ originalImg = tokenDocument.data.token.img;
+ }
+
+ if (!isValidItemPile(tokenDocument)) return originalImg;
+
+ items = items || getActorItems(tokenDocument).map(item => item.toObject());
+ currencies = currencies || getActorCurrencies(tokenDocument);
+
+ const numItems = items.length + currencies.length;
+
+ let img;
+
+ if (itemPileData.displayOne && numItems === 1) {
+ img = items.length > 0 ? items[0].img : currencies[0].img;
+ } else if (itemPileData.displayOne && numItems > 1) {
+ img = (tokenDocument.actor ?? tokenDocument).data.token.img;
+ }
+
+ if (itemPileData.isContainer) {
+
+ img = itemPileData.lockedImage || itemPileData.closedImage || itemPileData.openedImage || itemPileData.emptyImage;
+
+ if (itemPileData.locked && itemPileData.lockedImage) {
+ img = itemPileData.lockedImage;
+ } else if (itemPileData.closed && itemPileData.closedImage) {
+ img = itemPileData.closedImage;
+ } else if (itemPileData.emptyImage && isItemPileEmpty(tokenDocument)) {
+ img = itemPileData.emptyImage;
+ } else if (itemPileData.openedImage) {
+ img = itemPileData.openedImage;
+ }
+
+ }
+
+ return img || originalImg;
+
+}
+
+export function getItemPileTokenScale(target, { data = false, items = false, currencies = false } = {}) {
+
+ const pileDocument = Utilities.getDocument(target);
+
+ let itemPileData = getActorFlagData(pileDocument, data);
+
+ let baseScale;
+ if (pileDocument instanceof TokenDocument) {
+ baseScale = pileDocument.data.scale;
+ } else {
+ baseScale = pileDocument.data.token.scale;
+ }
+
+ if (!isValidItemPile(pileDocument, itemPileData)) {
+ return baseScale;
+ }
+
+ items = items || getActorItems(pileDocument);
+ currencies = currencies || getActorCurrencies(pileDocument);
+
+ const numItems = items.length + currencies.length;
+
+ if (itemPileData.isContainer || !itemPileData.displayOne || !itemPileData.overrideSingleItemScale || numItems > 1 || numItems === 0) {
+ return baseScale;
+ }
+
+ return itemPileData.singleItemScale;
+
+}
+
+export function getItemPileName(target, { data = false, items = false, currencies = false } = {}) {
+
+ const pileDocument = Utilities.getDocument(target);
+
+ const itemPileData = getActorFlagData(pileDocument, data);
+
+ let name = pileDocument instanceof TokenDocument ? pileDocument.data.name : pileDocument.data.token.name;
+
+ if (!isValidItemPile(pileDocument, itemPileData)) {
+ return name;
+ }
+
+ items = items || getActorItems(pileDocument);
+ currencies = currencies || getActorCurrencies(pileDocument);
+
+ const numItems = items.length + currencies.length;
+
+ if (itemPileData.isContainer || !itemPileData.displayOne || !itemPileData.showItemName || numItems > 1 || numItems === 0) {
+ return name;
+ }
+
+ const item = items.length > 0 ? items[0] : currencies[0];
+
+ return item.name;
+
+}
+
+function getRelevantTokensAndActor(target) {
+
+ const relevantDocument = Utilities.getDocument(target);
+
+ let documentActor;
+ let documentTokens = [];
+
+ if (relevantDocument instanceof Actor) {
+ documentActor = relevantDocument;
+ if (relevantDocument.token) {
+ documentTokens.push(relevantDocument?.token);
+ } else {
+ documentTokens = canvas.tokens.placeables.filter(token => token.document.actor === documentActor).map(token => token.document);
+ }
+ } else {
+ documentActor = relevantDocument.actor;
+ if (relevantDocument.isLinked) {
+ documentTokens = canvas.tokens.placeables.filter(token => token.document.actor === documentActor).map(token => token.document);
+ } else {
+ documentTokens.push(relevantDocument);
+ }
+ }
+
+ return [documentActor, documentTokens]
+
+}
+
+export async function updateItemPileData(target, flagData, tokenData) {
+
+ if (!flagData) flagData = getActorFlagData(target);
+ if (!tokenData) tokenData = {};
+
+ let [documentActor, documentTokens] = getRelevantTokensAndActor(target);
+
+ const items = getActorItems(documentActor, { itemFilters: flagData.overrideItemFilters });
+ const currencies = getActorCurrencies(documentActor, { currencyList: flagData.overrideCurrencies });
+
+ const pileData = { data: flagData, items, currencies };
+
+ const updates = documentTokens.map(tokenDocument => {
+ const newTokenData = foundry.utils.mergeObject(tokenData, {
+ "img": getItemPileTokenImage(tokenDocument, pileData),
+ "scale": getItemPileTokenScale(tokenDocument, pileData),
+ "name": getItemPileName(tokenDocument, pileData),
+ });
+ const data = {
+ "_id": tokenDocument.id, ...newTokenData
+ };
+ if (!foundry.utils.isObjectEmpty(flagData)) {
+ data[CONSTANTS.FLAGS.PILE] = flagData;
+ }
+ if (!tokenDocument.data.actorLink) {
+ data["actorData." + CONSTANTS.FLAGS.PILE] = flagData;
+ if (tokenDocument.actor === documentActor) {
+ documentActor = false;
+ }
+ }
+ return data;
+ });
+
+ await canvas.scene.updateEmbeddedDocuments("Token", updates);
+
+ if (!foundry.utils.isObjectEmpty(flagData) && documentActor) {
+ await documentActor.update({
+ [CONSTANTS.FLAGS.PILE]: flagData, [`token.${CONSTANTS.FLAGS.PILE}`]: flagData
+ });
+ }
+
+ return true;
+}
+
+export async function updateItemData(item, update) {
+ const flagData = foundry.utils.mergeObject(getItemFlagData(item), update.flags ?? {});
+ return item.update({
+ ...update?.data ?? {}, [CONSTANTS.FLAGS.ITEM]: flagData
+ });
+}
+
+/* -------------------------- Merchant Methods ------------------------- */
+
+export function getMerchantModifiersForActor(merchant, { item = false, actor = false, pileFlagData = false } = {}) {
+
+ let {
+ buyPriceModifier, sellPriceModifier, itemTypePriceModifiers, actorPriceModifiers
+ } = getActorFlagData(merchant, pileFlagData);
+
+ if (item) {
+ const itemTypePriceModifier = itemTypePriceModifiers.find(priceData => priceData.type === item.type);
+ if (itemTypePriceModifier) {
+ buyPriceModifier = itemTypePriceModifier.override ? itemTypePriceModifier.buyPriceModifier : buyPriceModifier * itemTypePriceModifier.buyPriceModifier;
+ sellPriceModifier = itemTypePriceModifier.override ? itemTypePriceModifier.sellPriceModifier : sellPriceModifier * itemTypePriceModifier.sellPriceModifier;
+ }
+ }
+
+ if (actor && actorPriceModifiers) {
+ const actorSpecificModifiers = actorPriceModifiers?.find(data => data.actorUuid === Utilities.getUuid(actor));
+ if (actorSpecificModifiers) {
+ buyPriceModifier = actorSpecificModifiers.override ? actorSpecificModifiers.buyPriceModifier : buyPriceModifier * actorSpecificModifiers.buyPriceModifier;
+ sellPriceModifier = actorSpecificModifiers.override ? actorSpecificModifiers.sellPriceModifier : sellPriceModifier * actorSpecificModifiers.sellPriceModifier;
+ }
+ }
+
+ return {
+ buyPriceModifier, sellPriceModifier
+ }
+}
+
+function getPriceArray(totalCost, currencies) {
+
+ const smallestExchangeRate = Math.min(...currencies.map(currency => currency.exchangeRate));
+ const decimals = smallestExchangeRate.toString().split(".")[1].length;
+
+ let fraction = Helpers.roundToDecimals(totalCost % 1, decimals);
+ let cost = Math.round(totalCost - fraction);
+
+ const prices = [];
+
+ let skipPrimary = false;
+ const primaryCurrency = currencies.find(currency => currency.primary)
+ if (cost) {
+ skipPrimary = true;
+ prices.push({
+ ...primaryCurrency,
+ cost: cost,
+ baseCost: cost,
+ maxCurrencyCost: totalCost,
+ string: primaryCurrency.abbreviation.replace('{#}', cost)
+ });
+ }
+
+ for (const currency of currencies) {
+
+ if (currency === primaryCurrency && skipPrimary) continue;
+
+ const numCurrency = Math.floor(Helpers.roundToDecimals(fraction / currency.exchangeRate, decimals));
+
+ fraction = Helpers.roundToDecimals(fraction - (numCurrency * currency.exchangeRate), decimals);
+
+ prices.push({
+ ...currency,
+ cost: Math.round(numCurrency),
+ baseCost: Math.round(numCurrency),
+ maxCurrencyCost: Math.ceil(totalCost / currency.exchangeRate),
+ string: currency.abbreviation.replace("{#}", numCurrency)
+ });
+ }
+
+ prices.sort((a, b) => b.exchangeRate - a.exchangeRate);
+
+ return prices;
+}
+
+export function getItemPrices(item, {
+ seller = false, buyer = false, sellerFlagData = false, buyerFlagData = false, itemFlagData = false, quantity = 1
+} = {}) {
+
+ let priceData = [];
+
+ buyerFlagData = getActorFlagData(buyer, buyerFlagData);
+ if (!buyerFlagData?.enabled || !buyerFlagData?.isMerchant) {
+ buyerFlagData = false;
+ }
+
+ sellerFlagData = getActorFlagData(seller, sellerFlagData);
+ if (!sellerFlagData?.enabled || !sellerFlagData?.isMerchant) {
+ sellerFlagData = false;
+ }
+
+ itemFlagData = itemFlagData || getItemFlagData(item);
+
+ let merchant = sellerFlagData ? seller : buyer;
+
+ if (merchant === buyer && itemFlagData.cantBeSoldToMerchants) {
+ priceData.push({
+ free: false,
+ basePrices: [],
+ basePriceString: "",
+ prices: [],
+ priceString: "",
+ totalCost: 0,
+ baseCost: 0,
+ primary: true,
+ maxQuantity: 0,
+ quantity
+ })
+ return priceData;
+ }
+
+ // Retrieve the item price modifiers
+ let modifier = 1;
+ if (sellerFlagData) {
+
+ modifier = getMerchantModifiersForActor(seller, {
+ item, actor: buyer, pileFlagData: sellerFlagData
+ }).buyPriceModifier;
+
+ } else if (buyerFlagData) {
+
+ modifier = getMerchantModifiersForActor(buyer, {
+ item, actor: seller, pileFlagData: buyerFlagData
+ }).sellPriceModifier;
+
+ }
+
+ if (!modifier) {
+ return priceData;
+ }
+
+ const overallCost = Number(getProperty(item.toObject(), game.itempiles.ITEM_PRICE_ATTRIBUTE));
+ const disableNormalCost = itemFlagData.disableNormalCost && !sellerFlagData.onlyAcceptBasePrice;
+ const hasOtherPrices = itemFlagData.prices.filter(priceGroup => priceGroup.length).length > 0;
+
+ const currencyList = getActorCurrencyList(merchant);
+ const currencies = getActorCurrencies(merchant, { currencyList, getAll: true });
+
+ // In order to easily calculate an item's total worth, we can use the smallest exchange rate and convert all prices
+ // to it, in order have a stable form of exchange calculation
+ const smallestExchangeRate = Math.min(...currencies.map(currency => currency.exchangeRate));
+ const decimals = smallestExchangeRate.toString().split(".")[1].length;
+
+ if (itemFlagData?.free || (!disableNormalCost && (overallCost === 0 || overallCost < smallestExchangeRate) && !hasOtherPrices)) {
+ priceData.push({
+ free: true,
+ basePrices: [],
+ basePriceString: "",
+ prices: [],
+ priceString: "",
+ totalCost: 0,
+ baseCost: 0,
+ primary: true,
+ maxQuantity: Infinity,
+ quantity
+ })
+ return priceData;
+ }
+
+ // !(itemFlagData.disableNormalCost || (merchant === buyer && sellerFlagData.onlyAcceptBasePrice)) &&
+
+ // If the item does include its normal cost, we calculate that here
+ if (overallCost >= smallestExchangeRate && (!itemFlagData.disableNormalCost || (merchant === buyer && buyerFlagData.onlyAcceptBasePrice))) {
+
+ // Base prices is the displayed price, without quantity taken into account
+ const baseCost = Helpers.roundToDecimals(overallCost * modifier, decimals);
+ const basePrices = getPriceArray(baseCost, currencies);
+
+ // Prices is the cost with the amount of quantity taken into account, which may change the number of the different
+ // types of currencies it costs (eg, an item wouldn't cost 1 gold and 100 silver, it would cost 11 gold
+ let totalCost = Helpers.roundToDecimals(overallCost * modifier * quantity, decimals);
+ let prices = getPriceArray(totalCost, currencies);
+
+ if (baseCost) {
+
+ priceData.push({
+ basePrices,
+ basePriceString: basePrices.filter(price => price.cost).map(price => price.string).join(" "),
+ prices,
+ priceString: prices.filter(price => price.cost).map(price => price.string).join(" "),
+ totalCost,
+ baseCost,
+ primary: true,
+ maxQuantity: 0,
+ quantity
+ });
+
+ }
+ }
+
+ // If the item has custom prices, we include them here
+ if (itemFlagData.prices.length && !(merchant === buyer && buyerFlagData.onlyAcceptBasePrice)) {
+
+ priceData = priceData.concat(itemFlagData.prices.map(priceGroup => {
+ const prices = priceGroup.map(price => {
+ const itemModifier = price.fixed ? 1 : modifier;
+ const cost = Math.round(price.quantity * itemModifier * quantity);
+ const baseCost = Math.round(price.quantity * itemModifier);
+ price.name = game.i18n.localize(price.name);
+ return {
+ ...price,
+ cost,
+ baseCost,
+ modifier: itemModifier,
+ priceString: cost ? price.abbreviation.replace("{#}", cost) : "",
+ basePriceString: baseCost ? price.abbreviation.replace("{#}", baseCost) : ""
+ };
+ });
+
+ return {
+ prices,
+ priceString: prices.filter(price => price.priceString).map(price => price.priceString).join(" "),
+ basePriceString: prices.filter(price => price.basePriceString).map(price => price.basePriceString).join(" "),
+ maxQuantity: 0,
+ quantity
+ }
+ }));
+ }
+
+ const buyerInfiniteCurrencies = buyerFlagData?.infiniteCurrencies;
+ const buyerInfiniteQuantity = buyerFlagData?.infiniteQuantity;
+
+ // If there's a buyer, we also calculate how many of the item the buyer can afford
+ if (!buyer) return priceData;
+
+ const recipientCurrencies = getActorCurrencies(buyer, { currencyList });
+ const totalCurrencies = recipientCurrencies.map(currency => currency.quantity * currency.exchangeRate).reduce((acc, num) => acc + num, 0);
+
+ // For each price group, check for properties and items and make sure that the actor can afford it
+ for (const priceGroup of priceData) {
+ priceGroup.maxQuantity = Infinity;
+ if (priceGroup.baseCost !== undefined) {
+ if (buyerInfiniteCurrencies) continue;
+ priceGroup.maxQuantity = Math.floor(totalCurrencies / priceGroup.baseCost);
+ priceGroup.prices.forEach(price => {
+ price.maxQuantity = priceGroup.maxQuantity;
+ });
+ } else {
+ if (buyerInfiniteQuantity) continue;
+ for (const price of priceGroup.prices) {
+ if (price.type === "attribute") {
+ const attributeQuantity = Number(getProperty(buyer.data, price.data.path));
+ price.buyerQuantity = attributeQuantity;
+
+ if (price.percent) {
+ const percent = Math.min(1, price.baseCost / 100);
+ const percentQuantity = Math.max(0, Math.floor(attributeQuantity * percent));
+ price.maxQuantity = Math.floor(attributeQuantity / percentQuantity);
+ price.baseCost = !buyer ? price.baseCost : percentQuantity;
+ price.cost = !buyer ? price.cost : percentQuantity * quantity;
+ price.quantity = !buyer ? price.quantity : percentQuantity;
+ } else {
+ price.maxQuantity = Math.floor(attributeQuantity / price.baseCost);
+ }
+
+ priceGroup.maxQuantity = Math.min(priceGroup.maxQuantity, price.maxQuantity)
+
+ } else {
+ const foundItem = Utilities.findSimilarItem(buyer.items, price.data.item);
+ const itemQuantity = foundItem ? Utilities.getItemQuantity(foundItem) : 0;
+ price.buyerQuantity = itemQuantity;
+
+ if (price.percent) {
+ const percent = Math.min(1, price.baseCost / 100);
+ const percentQuantity = Math.max(0, Math.floor(itemQuantity * percent));
+ price.maxQuantity = Math.floor(itemQuantity / percentQuantity);
+ price.baseCost = !buyer ? price.baseCost : percentQuantity;
+ price.cost = !buyer ? price.cost : percentQuantity * quantity;
+ price.quantity = !buyer ? price.quantity : percentQuantity;
+ } else {
+ price.maxQuantity = Math.floor(itemQuantity / price.baseCost);
+ }
+
+ priceGroup.maxQuantity = Math.min(priceGroup.maxQuantity, price.maxQuantity);
+ }
+ }
+ }
+ }
+
+ return priceData;
+}
+
+export function getPricesForItems(itemsToBuy, {
+ seller = false, buyer = false, sellerFlagData = false, buyerFlagData = false
+} = {}) {
+
+ sellerFlagData = getActorFlagData(seller, sellerFlagData);
+ if (!sellerFlagData?.enabled || !sellerFlagData?.isMerchant) {
+ sellerFlagData = false;
+ }
+
+ buyerFlagData = getActorFlagData(buyer, buyerFlagData);
+ if (!buyerFlagData?.enabled || !buyerFlagData?.isMerchant) {
+ buyerFlagData = false;
+ }
+
+ const merchant = sellerFlagData ? seller : buyer;
+ const currencyList = getActorCurrencyList(merchant);
+ const currencies = getActorCurrencies(merchant, { currencyList, getAll: true });
+ const smallestExchangeRate = Math.min(...currencies.map(currency => currency.exchangeRate));
+ const decimals = smallestExchangeRate.toString().split(".")[1].length;
+
+ const recipientCurrencies = getActorCurrencies(buyer, { currencyList, getAll: true });
+
+ const buyerInfiniteCurrencies = buyerFlagData?.infiniteCurrencies;
+
+ const paymentData = itemsToBuy.map(data => {
+ const prices = getItemPrices(data.item, {
+ seller, buyer, sellerFlagData, buyerFlagData, itemFlagData: data.itemFlagData, quantity: data.quantity || 1
+ })[data.paymentIndex || 0];
+ return {
+ ...prices, item: data.item
+ };
+ })
+ .reduce((priceData, priceGroup) => {
+
+ if (!priceGroup.maxQuantity) return priceData;
+
+ if (priceGroup.primary) {
+
+ priceData.totalCurrencyCost = Helpers.roundToDecimals(priceData.totalCurrencyCost + priceGroup.totalCost, decimals);
+ priceData.primary = true;
+
+ } else {
+
+ for (const price of priceGroup.prices) {
+
+ let existingPrice = priceData.otherPrices.find(otherPrice => {
+ return otherPrice.id === price.id || (otherPrice.name === price.name && otherPrice.img === price.img && otherPrice.type === price.type);
+ });
+
+ if (existingPrice) {
+ existingPrice.cost += price.cost;
+ } else {
+ const index = priceData.otherPrices.push(price);
+ existingPrice = priceData.otherPrices[index - 1];
+ existingPrice.quantity = 0;
+ }
+
+ existingPrice.quantity += price.cost;
+ existingPrice.buyerQuantity -= price.cost;
+
+ if (existingPrice.buyerQuantity < 0) {
+ priceData.canBuy = false;
+ }
+ }
+ }
+
+ priceData.buyerReceive.push({
+ type: "item",
+ name: priceGroup.item.name,
+ img: priceGroup.item.img,
+ quantity: priceGroup.quantity,
+ item: priceGroup.item,
+ });
+
+ return priceData;
+
+ }, {
+ totalCurrencyCost: 0, canBuy: true, primary: false, finalPrices: [], otherPrices: [],
+
+ buyerReceive: [], buyerChange: [], sellerReceive: []
+ });
+
+ if (paymentData.totalCurrencyCost) {
+
+ // The price array that we need to fill
+ const prices = getPriceArray(paymentData.totalCurrencyCost, recipientCurrencies);
+
+ // This is the target price amount we need to hit
+ let priceLeft = paymentData.totalCurrencyCost;
+
+ // Starting from the smallest currency increment in the price
+ for (let i = prices.length - 1; i >= 0; i--) {
+
+ const price = prices[i];
+
+ const buyerPrice = {
+ ...price, buyerQuantity: buyerInfiniteCurrencies ? Infinity : price.quantity, quantity: 0, isCurrency: true
+ }
+
+ if (price.type === "item") {
+ buyerPrice.item = price.data.item;
+ }
+
+ // If we have met the price target (or exceeded it, eg, we need change), populate empty entry
+ if (priceLeft <= 0 || !price.cost) {
+ paymentData.finalPrices.push(buyerPrice);
+ continue;
+ }
+
+ // If the buyer does not have enough to cover the cost, put what we can into it, otherwise all of it
+ buyerPrice.quantity = buyerPrice.buyerQuantity < price.cost ? buyerPrice.buyerQuantity : price.cost;
+
+ // If it's the primary currency
+ if (price.primary) {
+ // And the buyer has enough of the primary currency to cover the rest of the price, use that
+ const totalCurrencyValue = Helpers.roundToDecimals(buyerPrice.buyerQuantity * price.exchangeRate, decimals);
+ if (totalCurrencyValue > priceLeft) {
+ buyerPrice.quantity = Math.ceil(priceLeft);
+ }
+ }
+
+ paymentData.finalPrices.push(buyerPrice);
+
+ // Then adjust the remaining price - if this goes below zero, we will need change back
+ priceLeft = Helpers.roundToDecimals(priceLeft - (buyerPrice.quantity * price.exchangeRate), decimals);
+
+ }
+
+ // If there's STILL some remaining price (eg, we haven't been able to scrounge up enough currency to pay for it)
+ // we can start using the larger currencies, such as platinum in D&D 5e
+ while (priceLeft > 0) {
+
+ // We then need to loop through each price, and check if we have any more left over
+ for (const buyerPrice of paymentData.finalPrices) {
+
+ // If we don't, look for the next one
+ let buyerCurrencyQuantity = buyerPrice.buyerQuantity - buyerPrice.quantity;
+ if (!buyerCurrencyQuantity) continue;
+
+ // Otherwise, add enough to cover the remaining cost
+ const newQuantity = Math.ceil(Math.min(buyerCurrencyQuantity, priceLeft / buyerPrice.exchangeRate));
+ buyerPrice.quantity += newQuantity;
+ priceLeft = Helpers.roundToDecimals(priceLeft - (newQuantity * buyerPrice.exchangeRate), decimals);
+
+ if (priceLeft <= 0) break;
+
+ }
+
+ if (priceLeft > 0) {
+ paymentData.finalPrices = paymentData.finalPrices.sort((a, b) => b.exchangeRate - a.exchangeRate);
+ } else {
+ break;
+ }
+ }
+
+ paymentData.finalPrices = paymentData.finalPrices.sort((a, b) => b.exchangeRate - a.exchangeRate);
+
+ // Since the change will be negative, we'll need to flip it, since this is what we'll get back
+ let change = Math.abs(priceLeft);
+ for (const currency of currencies) {
+
+ if (!change) break;
+
+ // Get the remaining price, and normalize it to this currency
+ let numCurrency = Math.floor(Helpers.roundToDecimals(change / currency.exchangeRate, decimals));
+ change = Helpers.roundToDecimals(change - (numCurrency * currency.exchangeRate), decimals);
+
+ // If there's some currencies to be gotten back
+ if (numCurrency) {
+ // We check if we've paid with this currency
+ const payment = paymentData.finalPrices.find(payment => {
+ return payment.id === currency.id || (payment.name === currency.name && payment.img === currency.img && payment.type === currency.type);
+ });
+ if (!payment) continue;
+
+ // If we have paid with this currency, and we're getting some back, we can do one of two things:
+ if ((payment.quantity - numCurrency) >= 0) {
+ // Either just subtract it from the total paid if some of our payment will still remain
+ // IE, the change we got back didn't cancel out the payment
+ payment.quantity -= numCurrency;
+ } else {
+ // Or if it does cancel out our payment, we add that to the change we'll get back and remove the payment entirely
+ paymentData.buyerChange.push({
+ ...currency, isCurrency: true, quantity: numCurrency - payment.quantity
+ });
+ payment.quantity = 0;
+ }
+ }
+ }
+
+ // Copy the final currencies that the seller will get
+ paymentData.sellerReceive = paymentData.finalPrices.map(price => {
+ return { ...price };
+ });
+
+ // But, we'll need to make sure they have enough change to _give_ to the buyer
+ // We collate the total amount of change needed
+ let changeNeeded = paymentData.buyerChange.reduce((acc, change) => {
+ const currency = currencies.find(currency => {
+ return change.id === currency.id || (change.name === currency.name && change.img === currency.img && change.type === currency.type);
+ });
+ return acc + currency.quantity >= change.quantity ? 0 : (change.quantity - currency.quantity) * change.exchangeRate;
+ }, 0);
+
+ // If the seller needs give the buyer some change, we'll modify the payment they'll get to cover for it
+ if (changeNeeded) {
+
+ // If the seller is being given enough of the primary currency to cover for the cost, we use that
+ const primaryCurrency = paymentData.sellerReceive.find(price => price.primary && (price.quantity * price.exchangeRate) > changeNeeded);
+ if (primaryCurrency) {
+ primaryCurrency.quantity--;
+ changeNeeded -= 1 * primaryCurrency.exchangeRate;
+ } else {
+ // Otherwise, we'll use the biggest currency we can find to cover for it
+ const biggestCurrency = paymentData.sellerReceive.find(price => price.quantity && (price.quantity * price.exchangeRate) > changeNeeded);
+ biggestCurrency.quantity--;
+ changeNeeded -= 1 * biggestCurrency.exchangeRate;
+ }
+
+ changeNeeded = Math.abs(changeNeeded);
+
+ // Then loop through each currency and add enough currency so that the total adds up
+ for (const currency of paymentData.sellerReceive) {
+ if (!changeNeeded) break;
+ let numCurrency = Math.floor(Helpers.roundToDecimals(changeNeeded / currency.exchangeRate, decimals));
+ changeNeeded = Helpers.roundToDecimals(changeNeeded - (numCurrency * currency.exchangeRate), decimals);
+ currency.quantity += numCurrency;
+ }
+ }
+ }
+
+ paymentData.finalPrices = paymentData.finalPrices.concat(paymentData.otherPrices);
+ paymentData.sellerReceive = paymentData.sellerReceive.concat(paymentData.otherPrices);
+
+ paymentData.basePriceString = paymentData.finalPrices
+ .filter(price => price.cost)
+ .map(price => {
+ let abbreviation = price.abbreviation;
+ if (price.percent && abbreviation.includes("%")) {
+ abbreviation = abbreviation.replaceAll("%", "")
+ }
+ return abbreviation.replace("{#}", price.cost)
+ }).join(" ");
+
+ delete paymentData.otherPrices;
+
+ return paymentData;
+
+}
\ No newline at end of file
diff --git a/src/helpers/sharing-utilities.js b/src/helpers/sharing-utilities.js
new file mode 100644
index 00000000..8d15a502
--- /dev/null
+++ b/src/helpers/sharing-utilities.js
@@ -0,0 +1,281 @@
+import CONSTANTS from "../constants/constants.js";
+import * as Utilities from "./utilities.js"
+import * as PileUtilities from "./pile-utilities.js"
+import { setSimilarityProperties } from "./utilities.js";
+
+/**
+ * Gets the players that can interact with this item pile
+ *
+ * @param {Actor|TokenDocument|String} target
+ * @returns {Array}
+ */
+export function getPlayersForItemPile(target) {
+ const targetActor = Utilities.getActor(target);
+ if (!PileUtilities.isValidItemPile(targetActor)) return [];
+ const pileData = PileUtilities.getActorFlagData(targetActor);
+ return Array.from(game.users).filter(u => (u.active || !pileData.activePlayers) && u.character);
+}
+
+/**
+ * Retrieves an item pile's sharing data
+ *
+ * @param {Actor|TokenDocument|String} target
+ * @returns {Object}
+ */
+export function getItemPileSharingData(target) {
+ const targetActor = Utilities.getActor(target);
+ return foundry.utils.duplicate(getProperty(targetActor.data, CONSTANTS.FLAGS.SHARING) ?? {});
+}
+
+/**
+ * Updates an item pile's sharing data
+ *
+ * @param {Actor|TokenDocument|String} target
+ * @param {Object} incomingSharingData
+ * @returns {Promise}
+ */
+export function updateItemPileSharingData(target, incomingSharingData) {
+ const targetActor = Utilities.getActor(target);
+ const currentSharingData = getItemPileSharingData(targetActor);
+ const newSharingData = foundry.utils.mergeObject(currentSharingData, incomingSharingData);
+ return targetActor.update({
+ [CONSTANTS.FLAGS.SHARING]: newSharingData
+ });
+}
+
+/**
+ * Clears an item pile's sharing data
+ *
+ * @param {Actor|TokenDocument|String} target
+ * @returns {Promise}
+ */
+export function clearItemPileSharingData(target) {
+ const targetActor = Utilities.getActor(target);
+ return targetActor.update({
+ [CONSTANTS.FLAGS.SHARING]: null
+ });
+}
+
+/**
+ * Merges and resolves existing sharing data on a given item pile
+ *
+ * @param {String} sourceUuid
+ * @param {String} targetUuid
+ * @param {Array} [items]
+ * @param {Array} [attributes]
+ */
+export async function setItemPileSharingData(sourceUuid, targetUuid, { items = [], attributes = [] } = {}) {
+
+ const sourceActor = Utilities.getActor(sourceUuid);
+ const targetActor = Utilities.getActor(targetUuid);
+
+ const sourceIsItemPile = PileUtilities.isValidItemPile(sourceActor);
+ const targetIsItemPile = PileUtilities.isValidItemPile(targetActor);
+
+ // If both the source and target are item piles, we want to ignore this execution
+ if (sourceIsItemPile && targetIsItemPile) return;
+
+ if (items.length) {
+ items = items.map(itemData => {
+ setProperty(itemData.item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, Math.abs(itemData.quantity));
+ return itemData.item;
+ })
+ }
+
+ if (!Array.isArray(attributes) && typeof attributes === "object") {
+ attributes = Object.entries(attributes).map(entry => {
+ return {
+ path: entry[0],
+ quantity: Math.abs(entry[1])
+ }
+ })
+ }
+
+ if (sourceIsItemPile) {
+
+ if (PileUtilities.isItemPileEmpty(sourceIsItemPile)) {
+ return clearItemPileSharingData(sourceIsItemPile);
+ }
+
+ const sharingData = addToItemPileSharingData(sourceActor, targetActor.uuid, { items, attributes });
+ return updateItemPileSharingData(sourceActor, sharingData);
+
+ }
+
+ const sharingData = removeFromItemPileSharingData(targetActor, sourceActor.uuid, { items, attributes });
+ return updateItemPileSharingData(targetActor, sharingData);
+
+}
+
+export function addToItemPileSharingData(itemPile, actorUuid, {
+ sharingData = false,
+ items = [],
+ attributes = []
+} = {}) {
+
+ const pileData = PileUtilities.getActorFlagData(itemPile);
+
+ let pileSharingData = {};
+ if (!sharingData && ((pileData.shareItemsEnabled && items.length) || (pileData.shareCurrenciesEnabled && attributes.length))) {
+ pileSharingData = getItemPileSharingData(itemPile);
+ }
+
+ if (pileData.shareItemsEnabled && items.length) {
+
+ if (!pileSharingData.items) {
+ pileSharingData.items = [];
+ }
+
+ for (const item of items) {
+
+ let existingItem = Utilities.findSimilarItem(pileSharingData.items, item);
+
+ if (!existingItem) {
+ let itemIndex = pileSharingData.items.push(Utilities.setSimilarityProperties({
+ actors: [{ uuid: actorUuid, quantity: 0 }]
+ }, item))
+ existingItem = pileSharingData.items[itemIndex - 1];
+ } else if (!existingItem.actors) {
+ existingItem.actors = [];
+ existingItem._id = item.id;
+ }
+
+ let actorData = existingItem.actors.find(data => data.uuid === actorUuid);
+
+ const itemQuantity = Utilities.getItemQuantity(item);
+ if (!actorData) {
+ if (itemQuantity > 0) {
+ existingItem.actors.push({ uuid: actorUuid, quantity: itemQuantity })
+ }
+ } else {
+ actorData.quantity += itemQuantity;
+ if (actorData.quantity <= 0) {
+ existingItem.actors.splice(existingItem.actors.indexOf(actorData), 1);
+ }
+ if (existingItem.actors.length === 0) {
+ pileSharingData.items.splice(pileSharingData.items.indexOf(existingItem), 1)
+ }
+ }
+
+ }
+
+ }
+
+ if (pileData.shareCurrenciesEnabled && attributes.length) {
+
+ if (!pileSharingData.attributes) {
+ pileSharingData.attributes = [];
+ }
+
+ for (const attribute of attributes) {
+
+ let existingCurrency = pileSharingData.attributes.find(sharingCurrency => sharingCurrency.path === attribute.path);
+
+ if (!existingCurrency) {
+ let itemIndex = pileSharingData.attributes.push({
+ path: attribute.path,
+ actors: [{ uuid: actorUuid, quantity: 0 }]
+ })
+ existingCurrency = pileSharingData.attributes[itemIndex - 1];
+ } else {
+ if (!existingCurrency.actors) {
+ existingCurrency.actors = [];
+ }
+ }
+
+ let actorData = existingCurrency.actors.find(data => data.uuid === actorUuid);
+
+ if (!actorData) {
+ if (attribute.quantity > 0) {
+ existingCurrency.actors.push({ uuid: actorUuid, quantity: attribute.quantity })
+ }
+ } else {
+ actorData.quantity += attribute.quantity;
+ if (actorData.quantity <= 0) {
+ existingCurrency.actors.splice(existingCurrency.actors.indexOf(actorData), 1);
+ }
+ if (existingCurrency.actors.length === 0) {
+ pileSharingData.attributes.splice(pileSharingData.attributes.indexOf(existingCurrency), 1)
+ }
+ }
+ }
+ }
+
+
+ return pileSharingData;
+
+}
+
+export function removeFromItemPileSharingData(itemPile, actorUuid, { items = [], attributes = [] } = {}) {
+
+ items = items.map(item => {
+ setProperty(item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, Utilities.getItemQuantity(item) * -1)
+ return item;
+ });
+
+ attributes = attributes.map(attribute => {
+ attribute.quantity = attribute.quantity * -1;
+ return attribute;
+ });
+
+ return addToItemPileSharingData(itemPile, actorUuid, { items, attributes });
+
+}
+
+export function getItemSharesLeftForActor(pile, item, recipient, { currentQuantity = null, floor = null, players = null, shareData = null }={}) {
+
+ if(item instanceof String){
+ item = pile.items.get(item);
+ }
+ let previouslyTaken = 0;
+ let recipientUuid = Utilities.getUuid(recipient);
+ currentQuantity = currentQuantity ?? Utilities.getItemQuantity(item);
+ let totalShares = currentQuantity;
+
+ shareData = shareData ?? getItemPileSharingData(pile);
+ if (shareData?.items?.length) {
+ const foundItem = Utilities.findSimilarItem(shareData.items, item);
+ if (foundItem) {
+ totalShares = foundItem.actors.reduce((acc, actor) => acc + actor.quantity, currentQuantity);
+ const quantityTakenBefore = foundItem.actors.find(actor => actor.uuid === recipientUuid);
+ previouslyTaken = quantityTakenBefore ? quantityTakenBefore.quantity : 0;
+ }
+ }
+
+ players = players ?? getPlayersForItemPile(pile).length;
+ let totalActorShare = totalShares / players;
+ if (!Number.isInteger(totalActorShare) && !floor) {
+ totalActorShare += 1;
+ }
+
+ return Math.max(0, Math.min(currentQuantity, Math.floor(totalActorShare - previouslyTaken)));
+
+}
+
+export function getAttributeSharesLeftForActor(pile, path, recipient, { currentQuantity = null, floor = null, players = null, shareData = null }={}) {
+
+ let previouslyTaken = 0;
+ let recipientUuid = Utilities.getUuid(recipient);
+ currentQuantity = currentQuantity ?? Number(getProperty(pile.data, path) ?? 0);
+ let totalShares = currentQuantity;
+
+ shareData = shareData ?? getItemPileSharingData(pile);
+ if (shareData?.attributes?.length) {
+ const existingCurrency = shareData.attributes.find(storedCurrency => storedCurrency.path === path);
+ if (existingCurrency) {
+ totalShares = existingCurrency.actors.reduce((acc, actor) => acc + actor.quantity, currentQuantity);
+
+ const quantityTakenBefore = existingCurrency?.actors?.find(actor => actor.uuid === recipientUuid);
+ previouslyTaken = quantityTakenBefore ? quantityTakenBefore.quantity : 0;
+ }
+ }
+
+ players = players ?? getPlayersForItemPile(pile).length;
+ let totalActorShare = totalShares / players;
+ if (!Number.isInteger(totalActorShare) && !floor) {
+ totalActorShare += 1;
+ }
+
+ return Math.max(0, Math.min(currentQuantity, Math.floor(totalActorShare - previouslyTaken)));
+
+}
\ No newline at end of file
diff --git a/src/helpers/transaction.js b/src/helpers/transaction.js
new file mode 100644
index 00000000..d27b930a
--- /dev/null
+++ b/src/helpers/transaction.js
@@ -0,0 +1,140 @@
+import * as Utilities from "./utilities.js";
+import ItemPileSocket from "../socket.js";
+import PrivateAPI from "../API/private-api.js";
+import { SYSTEMS } from "../systems.js";
+
+export default class Transaction {
+
+ constructor(actor) {
+ this.actor = actor;
+ this.itemsToCreate = [];
+ this.itemsToUpdate = [];
+ this.itemsToDelete = [];
+ this.itemsDeleted = new Map();
+ this.actorUpdates = {};
+ this.attributeDeltas = new Map();
+ this.attributeTypeMap = new Map();
+ this.itemDeltas = new Map();
+ this.itemTypeMap = new Map();
+ this.preCommitted = false;
+ }
+
+ async appendItemChanges(items, { remove = false, type = "item" } = {}) {
+ for (let data of items) {
+ let item = data.item ?? data;
+ let itemData = item instanceof Item ? item.toObject() : item;
+ if (SYSTEMS.DATA.ITEM_TRANSFORMER && !remove) {
+ itemData = await SYSTEMS.DATA.ITEM_TRANSFORMER(itemData);
+ }
+ const incomingQuantity = Math.abs(data.quantity ?? Utilities.getItemQuantity(itemData)) * (remove ? -1 : 1);
+ const actorExistingItem = Utilities.findSimilarItem(this.actor.items, itemData);
+ if (actorExistingItem) {
+ const existingItemUpdate = Utilities.findSimilarItem(this.itemsToUpdate, itemData);
+ if (existingItemUpdate) {
+ const newQuantity = Utilities.getItemQuantity(existingItemUpdate) + incomingQuantity;
+ Utilities.setItemQuantity(existingItemUpdate, newQuantity);
+ } else {
+ const newQuantity = Utilities.getItemQuantity(actorExistingItem) + incomingQuantity;
+ const update = Utilities.setItemQuantity({ _id: actorExistingItem.id }, newQuantity);
+ this.itemTypeMap.set(actorExistingItem.id, type)
+ this.itemsToUpdate.push(update)
+ this.itemDeltas.set(actorExistingItem.id,
+ (this.itemDeltas.has(actorExistingItem.id) ? this.itemDeltas.get(actorExistingItem.id) : 0) + incomingQuantity
+ );
+ }
+ } else {
+ const existingItemCreation = Utilities.findSimilarItem(this.itemsToCreate, itemData);
+ if (existingItemCreation) {
+ const newQuantity = Utilities.getItemQuantity(existingItemCreation) + incomingQuantity;
+ Utilities.setItemQuantity(existingItemCreation, newQuantity);
+ } else {
+ setProperty(itemData, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, incomingQuantity);
+ this.itemsToCreate.push(itemData);
+ this.itemTypeMap.set(itemData._id, type)
+ }
+ }
+ }
+ }
+
+ async appendActorChanges(attributes, { remove = false, type = "attribute" } = {}) {
+ if (!Array.isArray(attributes)) {
+ attributes = Object.entries(attributes).map(entry => ({ path: entry[0], quantity: entry[1] }));
+ }
+ this.actorUpdates = attributes.reduce((acc, attribute) => {
+ const incomingQuantity = Math.abs(attribute.quantity) * (remove ? -1 : 1);
+ acc[attribute.path] = acc[attribute.path] ?? Number(getProperty(this.actor.data, attribute.path));
+ acc[attribute.path] += incomingQuantity
+ this.attributeDeltas.set(attribute.path,
+ (this.attributeDeltas.has(attribute.path) ? this.attributeDeltas.get(attribute.path) : 0) + incomingQuantity
+ );
+ this.attributeTypeMap.set(attribute.path, type)
+ return acc;
+ }, this.actorUpdates);
+ }
+
+ prepare() {
+ this.actorUpdates = Object.fromEntries(Object.entries(this.actorUpdates).filter(entry => {
+ if (this.attributeDeltas.get(entry[0]) === 0) {
+ this.attributeDeltas.delete(entry[0]);
+ }
+ return Number(getProperty(this.actor.data, entry[0])) !== entry[1];
+ }))
+ this.itemsToCreate = this.itemsToCreate.filter(item => {
+ return Utilities.getItemQuantity(item) > 0 || this.itemTypeMap.get(item._id) === "currency"
+ });
+ this.itemsToDelete = this.itemsToUpdate.filter(item => {
+ return Utilities.getItemQuantity(item) <= 0 && this.itemTypeMap.get(item._id) !== "currency";
+ }).map(item => item._id);
+ this.itemDeltas = Array.from(this.itemDeltas).map(([id, quantity]) => {
+ const item = this.actor.items.get(id).toObject();
+ const type = this.itemTypeMap.get(id);
+ setProperty(item, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, quantity);
+ return { item, quantity, type };
+ });
+ this.itemsDeleted = Array.from(this.itemsDeleted).map(([id, quantity]) => {
+ const item = this.actor.items.get(id).toObject();
+ const type = this.itemTypeMap.get(id);
+ return { item, quantity, type };
+ });
+ this.itemsToUpdate = this.itemsToUpdate.filter(item => Utilities.getItemQuantity(item) > 0).filter(itemData => {
+ const item = this.actor.items.get(itemData._id)
+ return Utilities.getItemQuantity(item) !== Utilities.getItemQuantity(itemData);
+ });
+ this.attributeDeltas = Object.fromEntries(this.attributeDeltas);
+ this.preCommitted = true;
+ return {
+ actorUpdates: this.actorUpdates,
+ itemsToCreate: this.itemsToCreate,
+ itemsToDelete: this.itemsToDelete,
+ itemsToUpdate: this.itemsToUpdate,
+ itemsDeleted: this.itemsDeleted,
+ attributeDeltas: this.attributeDeltas,
+ itemDeltas: this.itemDeltas,
+ }
+ }
+
+ async commit() {
+
+ if (!this.preCommitted) {
+ this.prepare();
+ }
+
+ let itemsCreated;
+ const actorUuid = Utilities.getUuid(this.actor);
+ if (!this.actor.owner) {
+ itemsCreated = await ItemPileSocket.executeAsGM(ItemPileSocket.HANDLERS.COMMIT_ACTOR_CHANGES, actorUuid, this.actorUpdates, this.itemsToUpdate, this.itemsToDelete, this.itemsToCreate);
+ } else {
+ itemsCreated = await PrivateAPI._commitActorChanges(actorUuid, this.actorUpdates, this.itemsToUpdate, this.itemsToDelete, this.itemsToCreate)
+ }
+
+ return {
+ attributeDeltas: this.attributeDeltas,
+ itemDeltas: this.itemDeltas.concat(itemsCreated.map(item => {
+ return {
+ item,
+ quantity: Utilities.getItemQuantity(item)
+ }
+ }))
+ }
+ }
+}
\ No newline at end of file
diff --git a/src/helpers/utilities.js b/src/helpers/utilities.js
new file mode 100644
index 00000000..f13d34ac
--- /dev/null
+++ b/src/helpers/utilities.js
@@ -0,0 +1,193 @@
+export function getActor(target) {
+ if (target instanceof Actor) return target;
+ if (stringIsUuid(target)) {
+ target = fromUuidFast(target);
+ }
+ target = getDocument(target);
+ return target?.actor ?? target;
+}
+
+export function getToken(documentUuid) {
+ const document = fromUuidFast(documentUuid);
+ return document instanceof TokenDocument ? document.object : document;
+}
+
+export function getDocument(target) {
+ if (stringIsUuid(target)) {
+ target = fromUuidFast(target);
+ }
+ return target?.document ?? target;
+}
+
+export function stringIsUuid(inId) {
+ return typeof inId === "string"
+ && (inId.match(/\./g) || []).length
+ && !inId.endsWith(".");
+}
+
+/**
+ * Retrieves an object from the scene using its UUID, avoiding compendiums as they would have to be async'd
+ *
+ * @param uuid
+ * @returns {null}
+ */
+export function fromUuidFast(uuid) {
+ let parts = uuid.split(".");
+ let doc;
+
+ const [docName, docId] = parts.slice(0, 2);
+ parts = parts.slice(2);
+ const collection = CONFIG[docName].collection.instance;
+ doc = collection.get(docId);
+
+ // Embedded Documents
+ while (doc && (parts.length > 1)) {
+ const [embeddedName, embeddedId] = parts.slice(0, 2);
+ doc = doc.getEmbeddedDocument(embeddedName, embeddedId);
+ parts = parts.slice(2);
+ }
+ return doc || null;
+}
+
+export function getUuid(target) {
+ if (stringIsUuid(target)) return target;
+ const document = getDocument(target);
+ return document?.uuid ?? false;
+}
+
+/**
+ * Find and retrieves an item in a list of items
+ *
+ * @param {Array- } items
+ * @param {Item|Object} findItem
+ * @returns {*}
+ */
+export function findSimilarItem(items, findItem) {
+
+ const itemSimilarities = game.itempiles.ITEM_SIMILARITIES;
+
+ const findItemId = findItem instanceof Item ? findItem.id : findItem._id;
+
+ return items.find(item => {
+ const itemId = item instanceof Item ? item.id : item._id;
+ if (itemId && findItemId && itemId === findItemId) {
+ return true;
+ }
+
+ const itemData = item instanceof Item ? item.toObject() : item;
+ for (const path of itemSimilarities) {
+ if (!hasProperty(itemData, path) || !hasProperty(findItem, path) || getProperty(itemData, path) !== getProperty(findItem, path)) {
+ return false;
+ }
+ }
+
+ return true;
+ });
+}
+
+export function setSimilarityProperties(obj, item) {
+ const itemData = item instanceof Item ? item.toObject() : item;
+ setProperty(obj, "_id", itemData._id);
+ game.itempiles.ITEM_SIMILARITIES.forEach(prop => {
+ setProperty(obj, prop, getProperty(itemData, prop));
+ })
+ return obj;
+}
+
+/**
+ * Returns a given item's quantity
+ *
+ * @param {Item/Object} item
+ * @returns {number}
+ */
+export function getItemQuantity(item) {
+ const itemData = item instanceof Item ? item.toObject() : item;
+ return Number(getProperty(itemData, game.itempiles.ITEM_QUANTITY_ATTRIBUTE) ?? 0);
+}
+
+/**
+ * Returns a given item's quantity
+ *
+ * @param {Object} itemData
+ * @param {Number} quantity
+ * @returns {Object}
+ */
+export function setItemQuantity(itemData, quantity) {
+ setProperty(itemData, game.itempiles.ITEM_QUANTITY_ATTRIBUTE, quantity)
+ return itemData;
+}
+
+/**
+ * Retrieves all visible tokens on a given location
+ *
+ * @param position
+ * @returns {Array
}
+ */
+export function getTokensAtLocation(position) {
+ const tokens = [...canvas.tokens.placeables].filter(token => token.visible);
+ return tokens.filter(token => {
+ return position.x >= token.x && position.x < (token.x + (token.data.width * canvas.grid.size))
+ && position.y >= token.y && position.y < (token.y + (token.data.height * canvas.grid.size));
+ });
+}
+
+export function distance_between_rect(p1, p2) {
+
+ const x1 = p1.x;
+ const y1 = p1.y;
+ const x1b = p1.x + p1.w;
+ const y1b = p1.y + p1.h;
+
+ const x2 = p2.x;
+ const y2 = p2.y;
+ const x2b = p2.x + p2.w;
+ const y2b = p2.y + p2.h;
+
+ const left = x2b < x1;
+ const right = x1b < x2;
+ const bottom = y2b < y1;
+ const top = y1b < y2;
+
+ if (top && left) {
+ return distance_between({ x: x1, y: y1b }, { x: x2b, y: y2 });
+ } else if (left && bottom) {
+ return distance_between({ x: x1, y: y1 }, { x: x2b, y: y2b });
+ } else if (bottom && right) {
+ return distance_between({ x: x1b, y: y1 }, { x: x2, y: y2b });
+ } else if (right && top) {
+ return distance_between({ x: x1b, y: y1b }, { x: x2, y: y2 });
+ } else if (left) {
+ return x1 - x2b;
+ } else if (right) {
+ return x2 - x1b;
+ } else if (bottom) {
+ return y1 - y2b;
+ } else if (top) {
+ return y2 - y1b;
+ }
+
+ return 0;
+
+}
+
+export function distance_between(a, b) {
+ return new Ray(a, b).distance;
+}
+
+export function grids_between_tokens(a, b) {
+ return Math.floor(distance_between_rect(a, b) / canvas.grid.size) + 1
+}
+
+export function tokens_close_enough(a, b, maxDistance) {
+ const distance = grids_between_tokens(a, b);
+ return maxDistance >= distance;
+}
+
+export function refreshAppsWithDocument(doc, callback) {
+ const apps = Object.values(ui.windows).filter(app => app.id.endsWith(doc.id));
+ for (const app of apps) {
+ if (app[callback]) {
+ app[callback]();
+ }
+ }
+}
\ No newline at end of file
diff --git a/src/hotkeys.js b/src/hotkeys.js
new file mode 100644
index 00000000..9ad96d21
--- /dev/null
+++ b/src/hotkeys.js
@@ -0,0 +1,98 @@
+import CONSTANTS from "./constants/constants.js";
+import * as Utilities from "./helpers/utilities.js";
+import PrivateAPI from "./API/private-api.js";
+
+export const hotkeyActionState = {
+ get openPileInventory() {
+ return (!hotkeyState.ctrlDown && !game.settings.get(CONSTANTS.MODULE_NAME, "invertSheetOpen"))
+ || (hotkeyState.ctrlDown && game.settings.get(CONSTANTS.MODULE_NAME, "invertSheetOpen"));
+ }
+}
+
+export const hotkeyState = {
+ ctrlDown: false,
+ altDown: false,
+ shiftDown: false
+}
+
+export function registerHotkeysPre() {
+
+ game.keybindings.register(CONSTANTS.MODULE_NAME, "force-open-item-pile-inventory", {
+ name: "Force open inventory",
+ uneditable: [
+ { key: "ControlLeft" },
+ ],
+ onDown: () => {
+ hotkeyState.ctrlDown = true;
+ },
+ onUp: () => {
+ hotkeyState.ctrlDown = false;
+ },
+ reservedModifiers: ["SHIFT", "ALT"]
+ });
+
+ game.keybindings.register(CONSTANTS.MODULE_NAME, "force-drop-item", {
+ name: "Force drop item (GM only)",
+ uneditable: [
+ { key: "ShiftLeft" },
+ ],
+ onDown: () => {
+ hotkeyState.shiftDown = true;
+ },
+ onUp: () => {
+ hotkeyState.shiftDown = false;
+ },
+ reservedModifiers: ["ALT", "CONTROL"]
+ });
+
+ game.keybindings.register(CONSTANTS.MODULE_NAME, "force-drop-one-item", {
+ name: "Force drop one item",
+ uneditable: [
+ { key: "AltLeft" },
+ ],
+ onDown: () => {
+ hotkeyState.altDown = true;
+ },
+ onUp: () => {
+ hotkeyState.altDown = false;
+ },
+ reservedModifiers: ["SHIFT", "CONTROL"]
+ });
+
+}
+
+export function registerHotkeysPost() {
+
+ if (!game.user.isGM) {
+ let clicked = false;
+ window.addEventListener("mousedown", (event) => {
+ if (!canvas.ready) return;
+ if (!(canvas.activeLayer instanceof TokenLayer)) return;
+ if (game.activeTool !== "select") return;
+ const hover = document.elementFromPoint(event.clientX, event.clientY);
+ if (!hover || (hover.id !== "board")) return;
+ if (event.button !== 0) return;
+
+ const pos = canvas.app.renderer.plugins.interaction.mouse.getLocalPosition(canvas.app.stage);
+ const tokens = Utilities.getTokensAtLocation(pos)
+ .filter(token => {
+ const canView = token._canView(game.user);
+ const canSee = token.visible || game.user.isGM;
+ return !canView && canSee;
+ });
+ if (!tokens.length) return;
+ tokens.sort((a, b) => b.zIndex - a.zIndex);
+ const token = Utilities.getDocument(tokens[0]);
+
+ if (clicked === token) {
+ clicked = false;
+ return PrivateAPI._itemPileClicked(token);
+ }
+
+ clicked = token;
+ setTimeout(() => {
+ clicked = false;
+ }, 500);
+ });
+ }
+}
\ No newline at end of file
diff --git a/src/libwrapper.js b/src/libwrapper.js
new file mode 100644
index 00000000..623c3bd4
--- /dev/null
+++ b/src/libwrapper.js
@@ -0,0 +1,28 @@
+import CONSTANTS from "./constants/constants.js";
+import { hotkeyActionState } from "./hotkeys.js";
+import * as PileUtilities from "./helpers/pile-utilities.js";
+import PrivateAPI from "./API/private-api.js";
+
+export default function registerLibwrappers() {
+
+ libWrapper.register(CONSTANTS.MODULE_NAME, 'Token.prototype._onClickLeft2', function (wrapped, ...args) {
+ if (PileUtilities.isValidItemPile(this.document) && hotkeyActionState.openPileInventory) {
+ return PrivateAPI._itemPileClicked(this.document);
+ }
+ return wrapped(...args);
+ }, "MIXED");
+
+ libWrapper.register(CONSTANTS.MODULE_NAME, `SidebarDirectory.prototype._onClickDocumentName`, function (wrapped, event) {
+
+ event.preventDefault();
+ const element = event.currentTarget;
+ const documentId = element.parentElement.dataset.documentId;
+ const document = this.constructor.collection.get(documentId);
+
+ if (PileUtilities.isValidItemPile(document) && hotkeyActionState.openPileInventory) {
+ return game.itempiles.renderItemPileInterface(document, { useDefaultCharacter: true });
+ }
+ return wrapped(event);
+ }, "MIXED");
+
+}
diff --git a/src/module.js b/src/module.js
new file mode 100644
index 00000000..61611105
--- /dev/null
+++ b/src/module.js
@@ -0,0 +1,91 @@
+import "./styles/styles.scss";
+
+import registerUIOverrides from "./foundry-ui-overrides.js";
+import registerLibwrappers from "./libwrapper.js";
+import { registerSettings, checkSystem, patchCurrencySettings } from "./settings.js";
+import { registerHotkeysPost, registerHotkeysPre } from "./hotkeys.js";
+import Socket from "./socket.js";
+import API from "./API/api.js";
+import TradeAPI from "./API/trade-api.js";
+import ChatAPI from "./API/chat-api.js";
+import PrivateAPI from "./API/private-api.js";
+import HOOKS from "./constants/hooks.js";
+import * as Helpers from "./helpers/helpers.js";
+import MerchantApp from "./applications/merchant-app/merchant-app.js";
+import ItemEditor from "./applications/editors/item-editor/item-editor.js";
+import { getItemPrices, getPricesForItems } from "./helpers/pile-utilities.js";
+import { SYSTEMS } from "./systems.js";
+
+Hooks.once("init", async () => {
+ registerSettings();
+ registerHotkeysPre();
+ registerUIOverrides();
+ registerLibwrappers();
+
+ PrivateAPI.initialize();
+ TradeAPI.initialize();
+ ChatAPI.initialize();
+
+ game.itempiles = API;
+ window.ItemPiles = {
+ API: API
+ };
+});
+
+Hooks.once("ready", async () => {
+
+ if (!game.modules.get('lib-wrapper')?.active && game.user.isGM) {
+ let word = "install and activate";
+ if (game.modules.get('lib-wrapper')) word = "activate";
+ throw Helpers.custom_error(`Item Piles requires the 'libWrapper' module. Please ${word} it.`)
+ }
+ if (!game.modules.get('socketlib')?.active && game.user.isGM) {
+ let word = "install and activate";
+ if (game.modules.get('socketlib')) word = "activate";
+ throw Helpers.custom_error(`Item Piles requires the 'socketlib' module. Please ${word} it.`)
+ }
+
+ if (!Helpers.isGMConnected()) {
+ Helpers.custom_warning(`Item Piles requires a GM to be connected for players to be able to loot item piles.`, true)
+ }
+
+ if (game.user.isGM) {
+ patchCurrencySettings();
+ checkSystem();
+ }
+ registerHotkeysPost();
+ Hooks.callAll(HOOKS.READY);
+
+ ChatAPI.disablePastTradingButtons();
+
+ // const merchant = game.actors.get("4jh4e6K5TobGeoni");
+ // const actor = game.actors.getName("Player Token");
+
+ // game.itempiles.tradeItems(actor, merchant, [{
+ // item: actor.items.getName("Scimitar")
+ // }]);
+
+ // console.log(getPricesForItems([{
+ // item: actor.items.getName("Alms Box"),
+ // quantity: 1,
+ // paymentIndex: 0
+ // }], {
+ // seller: actor,
+ // buyer: merchant
+ // }))
+
+ // game.itempiles.renderItemPileInterface(merchant, { inspectingTarget: actor });
+
+ // ItemEditor.show(source.items.getName("Antitoxin"));
+
+});
+
+Hooks.once("socketlib.ready", () => {
+ Socket.initialize();
+});
+
+Hooks.on("reset-item-pile-settings", async () => {
+ for (let setting of game.settings.storage.get("world").filter(setting => setting.data.key.includes('item-piles'))) {
+ await setting.delete();
+ }
+})
\ No newline at end of file
diff --git a/src/settings.js b/src/settings.js
new file mode 100644
index 00000000..457893c7
--- /dev/null
+++ b/src/settings.js
@@ -0,0 +1,127 @@
+import CONSTANTS from "./constants/constants.js";
+import SETTINGS from "./constants/settings.js";
+import * as Helpers from "./helpers/helpers.js";
+import { SYSTEMS } from "./systems.js";
+import SettingsShim from "./applications/settings-app/settings-app.js";
+
+export function registerSettings() {
+
+ game.settings.registerMenu(CONSTANTS.MODULE_NAME, "configure-settings", {
+ name: "ITEM-PILES.Settings.Configure.Title",
+ label: "ITEM-PILES.Settings.Configure.Label",
+ hint: "ITEM-PILES.Settings.Configure.Hint",
+ icon: "fas fa-cog",
+ type: SettingsShim,
+ restricted: false
+ });
+
+ for (let [name, data] of Object.entries(SETTINGS.GET_DEFAULT())) {
+ game.settings.register(CONSTANTS.MODULE_NAME, name, data);
+ }
+
+}
+
+async function applyDefaultSettings() {
+ const settings = SETTINGS.GET_SYSTEM_DEFAULTS();
+ for (const [name, data] of Object.entries(settings)) {
+ await Helpers.setSetting(name, data.default);
+ }
+ await Helpers.setSetting(SETTINGS.SYSTEM_VERSION, SYSTEMS.DATA.VERSION);
+ await patchCurrencySettings();
+}
+
+export async function patchCurrencySettings() {
+ const currencies = Helpers.getSetting(SETTINGS.CURRENCIES);
+ for (let currency of currencies) {
+ if (currency.type !== "item" || !currency.data.uuid || currency.data.item) continue;
+ const item = await fromUuid(currency.data.uuid);
+ if (!item) continue;
+ currency.data.item = item.toObject();
+ }
+ await Helpers.setSetting(SETTINGS.CURRENCIES, currencies);
+}
+
+export async function checkSystem() {
+
+ if (Helpers.getSetting(SETTINGS.PRECONFIGURED_SYSTEM)) return;
+
+ if (!SYSTEMS.HAS_SYSTEM_SUPPORT) {
+
+ if (Helpers.getSetting(SETTINGS.SYSTEM_NOT_FOUND_WARNING_SHOWN)) return;
+
+ let settingsValid = true;
+ for (const [name, data] of Object.entries(SETTINGS.GET_DEFAULT())) {
+ settingsValid = settingsValid && Helpers.getSetting(name).length !== (new data.type).length
+ }
+
+ if (settingsValid) return;
+
+ Dialog.prompt({
+ title: game.i18n.localize("ITEM-PILES.Dialogs.NoSystemFound.Title"),
+ content: Helpers.dialogLayout({ message: game.i18n.localize("ITEM-PILES.Dialogs.NoSystemFound.Content") }),
+ callback: () => {
+ }
+ });
+
+ return Helpers.setSetting(SETTINGS.SYSTEM_NOT_FOUND_WARNING_SHOWN, true);
+
+ }
+
+ if (Helpers.getSetting(SETTINGS.SYSTEM_FOUND)) {
+ const currentVersion = Helpers.getSetting(SETTINGS.SYSTEM_VERSION);
+ const newVersion = SYSTEMS.DATA.VERSION;
+ if (isNewerVersion(newVersion, currentVersion)) {
+ return new Dialog({
+ title: game.i18n.localize("ITEM-PILES.Dialogs.NewSystemVersion.Title"),
+ content: Helpers.dialogLayout({
+ message: game.i18n.localize("ITEM-PILES.Dialogs.NewSystemVersion.Content"),
+ }),
+ buttons: {
+ confirm: {
+ icon: ' ',
+ label: game.i18n.localize("ITEM-PILES.Dialogs.NewSystemVersion.Confirm"),
+ callback: () => {
+ applyDefaultSettings();
+ }
+ },
+ cancel: {
+ icon: ' ',
+ label: game.i18n.localize("No")
+ }
+ },
+ default: "cancel"
+ }).render(true);
+ }
+ return;
+ }
+
+ await Helpers.setSetting(SETTINGS.SYSTEM_FOUND, true);
+
+ if (Helpers.getSetting(SETTINGS.SYSTEM_NOT_FOUND_WARNING_SHOWN)) {
+
+ return new Dialog({
+ title: game.i18n.localize("ITEM-PILES.Dialogs.SystemFound.Title"),
+ content: Helpers.dialogLayout({
+ message: game.i18n.localize("ITEM-PILES.Dialogs.SystemFound.Content"),
+ icon: "fas fa-search"
+ }),
+ buttons: {
+ confirm: {
+ icon: ' ',
+ label: game.i18n.localize("ITEM-PILES.Dialogs.SystemFound.Confirm"),
+ callback: () => {
+ applyDefaultSettings();
+ }
+ },
+ cancel: {
+ icon: ' ',
+ label: game.i18n.localize("No")
+ }
+ },
+ default: "cancel"
+ }).render(true);
+
+ }
+
+ return applyDefaultSettings();
+}
\ No newline at end of file
diff --git a/src/socket.js b/src/socket.js
new file mode 100644
index 00000000..7e60d761
--- /dev/null
+++ b/src/socket.js
@@ -0,0 +1,238 @@
+import CONSTANTS from "./constants/constants.js";
+import { debug } from "./helpers/helpers.js";
+import { fromUuidFast, stringIsUuid } from "./helpers/utilities.js";
+import PrivateAPI from "./API/private-api.js";
+import TradeAPI from "./API/trade-api.js";
+import ChatAPI from "./API/chat-api.js";
+import * as Helpers from "./helpers/helpers.js";
+import HOOKS from "./constants/hooks.js";
+
+export default class ItemPileSocket {
+
+ static HANDLERS = {
+ /**
+ * Generic sockets
+ */
+ CALL_HOOK: "callHook",
+
+ /**
+ * Chat messages
+ */
+ PICKUP_CHAT_MESSAGE: "pickupChatMessage",
+ SPLIT_CHAT_MESSAGE: "splitChatMessage",
+ MERCHANT_TRADE_CHAT_MESSAGE: "merchantTradeChatMessage",
+ DISABLE_CHAT_TRADE_BUTTON: "disableChatTradeButton",
+
+ /**
+ * Item pile sockets
+ */
+ CREATE_PILE: "createItemPile",
+ UPDATE_PILE: "updateItemPile",
+ UPDATED_PILE: "updatedPile",
+ DELETE_PILE: "deleteItemPile",
+ TURN_INTO_PILE: "turnIntoPiles",
+ REVERT_FROM_PILE: "revertFromPiles",
+ REFRESH_PILE: "refreshItemPile",
+ SPLIT_PILE: "splitItemPileContent",
+
+ /**
+ * UI sockets
+ */
+ RENDER_INTERFACE: "renderItemPileApplication",
+ RERENDER_TOKEN_HUD: "rerenderTokenHud",
+ USER_OPENED_INTERFACE: "userOpenedInterface",
+ USER_CLOSED_INTERFACE: "userClosedInterface",
+
+ /**
+ * Item & attribute sockets
+ */
+ DROP_ITEMS: "dropItems",
+ ADD_ITEMS: "addItems",
+ REMOVE_ITEMS: "removeItems",
+ TRANSFER_ITEMS: "transferItems",
+ TRANSFER_ALL_ITEMS: "transferAllItems",
+ ADD_ATTRIBUTE: "addAttributes",
+ REMOVE_ATTRIBUTES: "removeAttributes",
+ TRANSFER_ATTRIBUTES: "transferAttributes",
+ TRANSFER_ALL_ATTRIBUTES: "transferAllAttributes",
+ TRANSFER_EVERYTHING: "transferEverything",
+ COMMIT_ACTOR_CHANGES: "commitActorChanges",
+
+ /**
+ * Trading sockets
+ */
+ TRADE_REQUEST_PROMPT: "tradePrompt",
+ TRADE_REQUEST_CANCELLED: "tradeCancelled",
+ REQUEST_TRADE_DATA: "requestTradeData",
+ TRADE_CLOSED: "publicTradeClosed",
+ PUBLIC_TRADE_UPDATE_ITEMS: "publicTradeUpdateItems",
+ PUBLIC_TRADE_UPDATE_ITEM_CURRENCIES: "publicTradeUpdateItemCurrencies",
+ PUBLIC_TRADE_UPDATE_CURRENCIES: "publicTradeUpdateCurrencies",
+ PUBLIC_TRADE_STATE: "publicTradeAcceptedState",
+ PRIVATE_TRADE_UPDATE_ITEMS: "privateTradeUpdateItems",
+ PRIVATE_TRADE_UPDATE_ITEM_CURRENCIES: "privateTradeUpdateItemCurrencies",
+ PRIVATE_TRADE_UPDATE_CURRENCIES: "privateTradeUpdateCurrencies",
+ PRIVATE_TRADE_STATE: "privateTradeAcceptedState",
+ EXECUTE_TRADE: "executeTrade",
+ TRADE_COMPLETED: "tradeCompleted",
+
+ /**
+ * Merchant sockets
+ */
+ TRADE_ITEMS: "tradeItems"
+ }
+
+ static BINDINGS = {
+ [this.HANDLERS.CALL_HOOK]: (hook, response, ...args) => callHook(hook, response, ...args),
+
+ [this.HANDLERS.DROP_ITEMS]: (args) => PrivateAPI._dropItems(args),
+ [this.HANDLERS.ADD_ITEMS]: (...args) => PrivateAPI._addItems(...args),
+ [this.HANDLERS.REMOVE_ITEMS]: (...args) => PrivateAPI._removeItems(...args),
+ [this.HANDLERS.TRANSFER_ITEMS]: (...args) => PrivateAPI._transferItems(...args),
+ [this.HANDLERS.TRANSFER_ALL_ITEMS]: (...args) => PrivateAPI._transferAllItems(...args),
+ [this.HANDLERS.ADD_ATTRIBUTE]: (...args) => PrivateAPI._addAttributes(...args),
+ [this.HANDLERS.REMOVE_ATTRIBUTES]: (...args) => PrivateAPI._removeAttributes(...args),
+ [this.HANDLERS.TRANSFER_ATTRIBUTES]: (...args) => PrivateAPI._transferAttributes(...args),
+ [this.HANDLERS.TRANSFER_ALL_ATTRIBUTES]: (...args) => PrivateAPI._transferAllAttributes(...args),
+ [this.HANDLERS.TRANSFER_EVERYTHING]: (...args) => PrivateAPI._transferEverything(...args),
+ [this.HANDLERS.COMMIT_ACTOR_CHANGES]: (...args) => PrivateAPI._commitActorChanges(...args),
+
+ [this.HANDLERS.CREATE_PILE]: (...args) => PrivateAPI._createItemPile(...args),
+ [this.HANDLERS.UPDATE_PILE]: (...args) => PrivateAPI._updateItemPile(...args),
+ [this.HANDLERS.UPDATED_PILE]: (...args) => PrivateAPI._updatedItemPile(...args),
+ [this.HANDLERS.DELETE_PILE]: (...args) => PrivateAPI._deleteItemPile(...args),
+ [this.HANDLERS.TURN_INTO_PILE]: (...args) => PrivateAPI._turnTokensIntoItemPiles(...args),
+ [this.HANDLERS.REVERT_FROM_PILE]: (...args) => PrivateAPI._revertTokensFromItemPiles(...args),
+ [this.HANDLERS.SPLIT_PILE]: (...args) => PrivateAPI._splitItemPileContents(...args),
+
+ [this.HANDLERS.TRADE_REQUEST_PROMPT]: (...args) => TradeAPI._respondPrompt(...args),
+ [this.HANDLERS.TRADE_REQUEST_CANCELLED]: (...args) => TradeAPI._tradeCancelled(...args),
+ [this.HANDLERS.EXECUTE_TRADE]: (...args) => TradeAPI._executeTrade(...args),
+ [this.HANDLERS.TRADE_COMPLETED]: (...args) => TradeAPI._tradeCompleted(...args),
+ [this.HANDLERS.REQUEST_TRADE_DATA]: (...args) => TradeAPI._respondActiveTradeData(...args),
+ [this.HANDLERS.TRADE_CLOSED]: (...args) => TradeAPI._tradeClosed(...args),
+
+ [this.HANDLERS.PUBLIC_TRADE_UPDATE_ITEMS]: (...args) => TradeAPI._updateItems(...args),
+ [this.HANDLERS.PUBLIC_TRADE_UPDATE_ITEM_CURRENCIES]: (...args) => TradeAPI._updateItemCurrencies(...args),
+ [this.HANDLERS.PUBLIC_TRADE_UPDATE_CURRENCIES]: (...args) => TradeAPI._updateCurrencies(...args),
+ [this.HANDLERS.PUBLIC_TRADE_STATE]: (...args) => TradeAPI._updateAcceptedState(...args),
+
+ [this.HANDLERS.PRIVATE_TRADE_UPDATE_ITEMS]: (...args) => TradeAPI._updateItems(...args),
+ [this.HANDLERS.PRIVATE_TRADE_UPDATE_ITEM_CURRENCIES]: (...args) => TradeAPI._updateItemCurrencies(...args),
+ [this.HANDLERS.PRIVATE_TRADE_UPDATE_CURRENCIES]: (...args) => TradeAPI._updateCurrencies(...args),
+ [this.HANDLERS.PRIVATE_TRADE_STATE]: (...args) => TradeAPI._updateAcceptedState(...args),
+
+ [this.HANDLERS.PICKUP_CHAT_MESSAGE]: (...args) => ChatAPI._outputPickupToChat(...args),
+ [this.HANDLERS.SPLIT_CHAT_MESSAGE]: (...args) => ChatAPI._outputSplitToChat(...args),
+ [this.HANDLERS.MERCHANT_TRADE_CHAT_MESSAGE]: (...args) => ChatAPI._outputMerchantTradeToChat(...args),
+ [this.HANDLERS.DISABLE_CHAT_TRADE_BUTTON]: (...args) => ChatAPI._disableTradingButton(...args),
+
+ [this.HANDLERS.RENDER_INTERFACE]: (...args) => PrivateAPI._renderItemPileInterface(...args),
+ [this.HANDLERS.RERENDER_TOKEN_HUD]: (...args) => PrivateAPI._updateTokenHud(...args),
+ [this.HANDLERS.USER_OPENED_INTERFACE]: (...args) => InterfaceTracker.userOpened(...args),
+ [this.HANDLERS.USER_CLOSED_INTERFACE]: (...args) => InterfaceTracker.userClosed(...args),
+
+ [this.HANDLERS.TRADE_ITEMS]: (...args) => PrivateAPI._tradeItems(...args),
+ }
+
+ static _socket;
+
+ static initialize() {
+ InterfaceTracker.initialize();
+ this._socket = socketlib.registerModule(CONSTANTS.MODULE_NAME);
+ for (let [key, callback] of Object.entries(this.BINDINGS)) {
+ this._socket.register(key, callback);
+ debug(`Registered itemPileSocket: ${key}`);
+ }
+ }
+
+ static executeAsGM(handler, ...args) {
+ return this._socket.executeAsGM(handler, ...args);
+ }
+
+ static executeAsUser(handler, userId, ...args) {
+ return this._socket.executeAsUser(handler, userId, ...args);
+ }
+
+ static executeForAllGMs(handler, ...args) {
+ return this._socket.executeForAllGMs(handler, ...args);
+ }
+
+ static executeForOtherGMs(handler, ...args) {
+ return this._socket.executeForOtherGMs(handler, ...args);
+ }
+
+ static executeForEveryone(handler, ...args) {
+ return this._socket.executeForEveryone(handler, ...args);
+ }
+
+ static executeForOthers(handler, ...args) {
+ return this._socket.executeForOthers(handler, ...args);
+ }
+
+ static executeForUsers(handler, userIds, ...args) {
+ return this._socket.executeForUsers(handler, userIds, ...args);
+ }
+
+ static callHook(hook, ...args) {
+ if (!Helpers.hooks.run) return;
+ return this._socket.executeForEveryone(this.HANDLERS.CALL_HOOK, hook, ...args);
+ }
+
+ static callHookForUsers(hook, users, ...args) {
+ if (!Helpers.hooks.run) return;
+ return this._socket.executeForUsers(this.HANDLERS.CALL_HOOK, users, hook, ...args);
+ }
+
+}
+
+async function callHook(hook, ...args) {
+ const newArgs = [];
+ for (let arg of args) {
+ if (stringIsUuid(arg)) {
+ const testArg = fromUuidFast(arg);
+ if (testArg) {
+ arg = testArg;
+ }
+ }
+ newArgs.push(arg);
+ }
+ return Hooks.callAll(hook, ...newArgs);
+}
+
+export const InterfaceTracker = {
+
+ users: {},
+
+ initialize() {
+ this.users = {};
+ Hooks.on("renderPlayerList", () => {
+ Array.from(game.users).forEach(user => {
+ if (!this.users[user.id] || !user.active) {
+ this.users[user.id] = new Set();
+ }
+ });
+ });
+ Hooks.on(HOOKS.OPEN_INTERFACE, (app) => {
+ ItemPileSocket.executeForOthers(ItemPileSocket.HANDLERS.USER_OPENED_INTERFACE, game.user.id, app.id);
+ });
+ Hooks.on(HOOKS.CLOSE_INTERFACE, (app) => {
+ ItemPileSocket.executeForOthers(ItemPileSocket.HANDLERS.USER_CLOSED_INTERFACE, game.user.id, app.id);
+ });
+ },
+
+ userOpened(userId, id) {
+ this.users[userId].add(id);
+ },
+
+ userClosed(userId, id) {
+ this.users[userId].delete(id);
+ },
+
+ isOpened(id) {
+ return Object.values(this.users).find(interfaceList => {
+ return interfaceList.has(id);
+ })
+ }
+
+}
\ No newline at end of file
diff --git a/src/stores/item-pile-store.js b/src/stores/item-pile-store.js
new file mode 100644
index 00000000..b76a2d71
--- /dev/null
+++ b/src/stores/item-pile-store.js
@@ -0,0 +1,305 @@
+import { get, writable } from "svelte/store";
+import { TJSDocument } from '@typhonjs-fvtt/runtime/svelte/store';
+import CONSTANTS from "../constants/constants.js";
+import * as Utilities from "../helpers/utilities.js";
+import * as PileUtilities from "../helpers/pile-utilities.js";
+import * as SharingUtilities from "../helpers/sharing-utilities.js";
+import * as Helpers from "../helpers/helpers.js";
+import { InterfaceTracker } from "../socket.js";
+import { PileAttribute, PileItem } from "./pile-item.js";
+
+const __STORES__ = new Map();
+
+export default class ItemPileStore {
+
+ constructor(application, source, recipient = false, { recipientPileData = false } = {}) {
+
+ this.subscriptions = [];
+
+ this.interactionId = randomID();
+ this.application = application;
+
+ this.uuid = Utilities.getUuid(source);
+ this.actor = Utilities.getActor(source);
+
+ this.recipient = recipient ? Utilities.getActor(recipient) : false;
+
+ this.document = new TJSDocument(this.actor);
+ this.recipientDocument = recipient ? new TJSDocument(this.recipient) : false;
+ this.recipientPileData = recipientPileData;
+
+ __STORES__.set(this.uuid, this);
+
+ this.setupStores();
+ this.setupSubscriptions();
+ }
+
+ get ItemClass() {
+ return PileItem;
+ };
+
+ get AttributeClass() {
+ return PileAttribute;
+ };
+
+ setupStores() {
+
+ this.pileData = writable(PileUtilities.getActorFlagData(this.actor));
+ this.shareData = writable(SharingUtilities.getItemPileSharingData(this.actor));
+
+ this.recipientPileData = this.recipientPileData || writable(this.recipient ? PileUtilities.getActorFlagData(this.recipient) : {});
+ this.recipientShareData = writable(this.recipient ? SharingUtilities.getItemPileSharingData(this.recipient) : {});
+
+ this.deleted = writable(false);
+
+ this.search = writable("");
+ this.editQuantities = !this.recipient;
+
+ this.allItems = writable([]);
+ this.attributes = writable([]);
+
+ this.items = writable([]);
+ this.currencies = writable([]);
+ this.allCurrencies = writable([]);
+
+ this.numItems = writable(0);
+ this.numCurrencies = writable(0);
+
+ this.name = writable("");
+ this.img = writable("");
+
+ }
+
+ getActorImage() {
+ return this.actor.img;
+ }
+
+ setupSubscriptions() {
+
+ this.subscribeTo(this.document, () => {
+ const { data } = this.document.updateOptions;
+ if (hasProperty(data, CONSTANTS.FLAGS.SHARING)) {
+ this.shareData.set(SharingUtilities.getItemPileSharingData(this.actor));
+ this.refreshItems();
+ }
+ if (hasProperty(data, CONSTANTS.FLAGS.PILE)) {
+ this.pileData.set(PileUtilities.getActorFlagData(this.actor));
+ this.refreshItems();
+ }
+ this.name.set(this.actor.name);
+ this.img.set(this.getActorImage());
+ });
+
+ if (this.recipientDocument) {
+ this.subscribeTo(this.recipientDocument, () => {
+ const { data } = this.document.updateOptions;
+ if (hasProperty(data, CONSTANTS.FLAGS.SHARING)) {
+ this.recipientShareData.set(SharingUtilities.getItemPileSharingData(this.recipient));
+ this.refreshItems();
+ }
+ if (hasProperty(data, CONSTANTS.FLAGS.PILE)) {
+ this.recipientPileData.set(PileUtilities.getActorFlagData(this.recipient));
+ this.refreshItems();
+ }
+ });
+ }
+
+ const items = [];
+ const attributes = [];
+
+ PileUtilities.getActorItems(this.actor).map(item => {
+ items.push(new this.ItemClass(this, item));
+ });
+
+ PileUtilities.getActorCurrencies(this.actor, { forActor: this.recipient, getAll: true }).forEach(currency => {
+ if (currency.type === "item") {
+ if (!currency.item) return;
+ items.push(new this.ItemClass(this, currency.item ?? currency.data));
+ } else {
+ attributes.push(new this.AttributeClass(this, currency));
+ }
+ });
+
+ this.allItems.set(items);
+ this.attributes.set(attributes);
+
+ this.subscribeTo(this.allItems, (val) => {
+ if (!val) return;
+ this.refreshItems();
+ });
+ this.subscribeTo(this.attributes, (val) => {
+ if (!val) return;
+ this.refreshItems();
+ });
+
+ const filterDebounce = foundry.utils.debounce(() => {
+ this.refreshItems();
+ }, 300);
+ this.subscribeTo(this.search, (val) => {
+ if (!val) return;
+ filterDebounce()
+ });
+
+ }
+
+ static getStore(actor) {
+ const uuid = Utilities.getUuid(actor);
+ return __STORES__.get(uuid);
+ }
+
+ static notifyChanges(event, actor, ...args) {
+ const store = this.getStore(actor);
+ if (store) {
+ store[event](...args);
+ }
+ }
+
+ refreshItems() {
+ const allItems = get(this.allItems);
+
+ const items = allItems.filter(entry => !entry.isCurrency);
+ const itemCurrencies = allItems.filter(entry => entry.isCurrency);
+
+ this.numItems.set(items.filter(entry => get(entry.quantity) > 0).length);
+ this.items.set(items.filter(entry => !get(entry.filtered)));
+
+ const currencies = get(this.attributes).concat(itemCurrencies);
+ this.numCurrencies.set(currencies.filter(entry => get(entry.quantity) > 0).length);
+ this.currencies.set(currencies.filter(entry => !get(entry.filtered)));
+ this.allCurrencies.set(currencies);
+ }
+
+ createItem(item) {
+ if (PileUtilities.isItemInvalid(this.actor, item)) return;
+ const items = get(this.allItems);
+ const deletedItems = items
+ .filter(item => item.id === null)
+ .map(item => ({
+ pileItem: item,
+ ...item.similarities
+ }));
+ const previouslyDeletedItem = Utilities.findSimilarItem(deletedItems, item);
+ if (previouslyDeletedItem) {
+ previouslyDeletedItem.pileItem.setup(item);
+ } else {
+ items.push(new PileItem(this, item));
+ }
+ this.allItems.set(items);
+ this.refreshItems();
+ }
+
+ deleteItem(item) {
+ if (PileUtilities.isItemInvalid(this.actor, item)) return;
+ const items = get(this.allItems);
+ const pileItem = items.find(pileItem => pileItem.id === item.id);
+ if (!pileItem) return;
+ if (this.editQuantities || !InterfaceTracker.isOpened(this.application.id)) {
+ items.splice(items.indexOf(pileItem), 1);
+ this.allItems.set(items);
+ } else {
+ pileItem.id = null;
+ pileItem.quantity.set(0);
+ pileItem.quantityLeft.set(0);
+ }
+ pileItem.unsubscribe();
+ this.refreshItems();
+ }
+
+ delete() {
+ this.deleted.set(true);
+ }
+
+ async update() {
+
+ const itemsToUpdate = [];
+ const itemsToDelete = [];
+ const attributesToUpdate = {};
+
+ const items = get(this.allItems).filter(item => item.id);
+ for (let item of items) {
+ const itemQuantity = get(item.quantity);
+ if (itemQuantity === 0) {
+ itemsToDelete.push(item.id);
+ } else {
+ itemsToUpdate.push({
+ _id: item.id,
+ [game.itempiles.ITEM_QUANTITY_ATTRIBUTE]: itemQuantity
+ })
+ }
+ }
+
+ const attributes = get(this.attributes);
+ for (let attribute of attributes) {
+ attributesToUpdate[attribute.path] = get(attribute.quantity);
+ }
+
+ const pileSharingData = SharingUtilities.getItemPileSharingData(this.actor);
+
+ await this.actor.update(attributesToUpdate);
+ if (pileSharingData?.currencies) {
+ pileSharingData.currencies = pileSharingData.currencies.map(currency => {
+ if (attributesToUpdate[currency.path] !== undefined) {
+ currency.actors = currency.actors.map(actor => {
+ actor.quantity = Math.max(0, Math.min(actor.quantity, attributesToUpdate[currency.path]));
+ return actor;
+ })
+ }
+ return currency;
+ })
+ }
+
+ await this.actor.updateEmbeddedDocuments("Item", itemsToUpdate);
+ await this.actor.deleteEmbeddedDocuments("Item", itemsToDelete);
+ if (pileSharingData?.items) {
+ pileSharingData.items = pileSharingData.items.map(item => {
+ const sharingItem = itemsToUpdate.find(item => item._id === item.id);
+ if (sharingItem) {
+ item.actors = item.actors.map(actor => {
+ actor.quantity = Math.max(0, Math.min(actor.quantity, sharingItem.quantity));
+ return actor;
+ })
+ }
+ return item;
+ })
+ }
+
+ await SharingUtilities.updateItemPileSharingData(this.actor, pileSharingData);
+
+ Helpers.custom_notify("Item Pile successfully updated.");
+
+ this.refreshItems();
+
+ }
+
+ takeAll() {
+ game.itempiles.transferEverything(
+ this.actor,
+ this.recipient,
+ { interactionId: this.interactionId }
+ );
+ }
+
+ splitAll() {
+ return game.itempiles.splitItemPileContents(this.actor, { instigator: this.recipient });
+ }
+
+ closeContainer() {
+ if (!InterfaceTracker.isOpened(this.application.id)) {
+ return game.itempiles.closeItemPile(this.actor);
+ }
+ }
+
+ subscribeTo(target, callback) {
+ this.subscriptions.push(target.subscribe(callback));
+ }
+
+ unsubscribe() {
+ this.subscriptions.forEach(unsubscribe => unsubscribe());
+ this.subscriptions = [];
+ }
+
+ onDestroy() {
+ this.unsubscribe();
+ __STORES__.delete(this.uuid);
+ }
+}
\ No newline at end of file
diff --git a/src/stores/merchant-store.js b/src/stores/merchant-store.js
new file mode 100644
index 00000000..07680335
--- /dev/null
+++ b/src/stores/merchant-store.js
@@ -0,0 +1,272 @@
+import ItemPileStore from "./item-pile-store.js";
+import { get, writable } from "svelte/store";
+import { localize } from "@typhonjs-fvtt/runtime/svelte/helper";
+import { PileItem } from "./pile-item.js";
+import * as PileUtilities from "../helpers/pile-utilities.js";
+import CONSTANTS from "../constants/constants.js";
+import * as Helpers from "../helpers/helpers.js";
+import TradeMerchantItemDialog from "../applications/dialogs/trade-merchant-item-dialog/trade-merchant-item-dialog.js";
+
+export default class MerchantStore extends ItemPileStore {
+
+ setupStores() {
+ super.setupStores();
+ this.editPrices = writable(false);
+ this.itemsPerCategory = writable({});
+ this.categories = writable([]);
+ this.itemCategories = writable([]);
+ this.typeFilter = writable("all")
+ this.priceModifiersPerType = writable({});
+ this.priceModifiersForActor = writable({});
+ this.priceSelector = writable("");
+ }
+
+ get ItemClass() {
+ return PileMerchantItem;
+ }
+
+ getActorImage() {
+ const pileData = get(this.pileData);
+ return pileData?.merchantImage || this.actor.img;
+ }
+
+ setupSubscriptions() {
+ super.setupSubscriptions();
+ this.subscribeTo(this.pileData, (pileData) => {
+ this.updatePriceModifiers();
+ });
+ if (this.recipientDocument) {
+ this.subscribeTo(this.recipientPileData, () => {
+ this.updatePriceModifiers();
+ });
+ this.subscribeTo(this.recipientDocument, () => {
+ this.refreshItemPrices();
+ })
+ }
+ this.subscribeTo(this.typeFilter, () => {
+ this.refreshItems();
+ })
+ }
+
+ refreshItems() {
+ super.refreshItems();
+ const items = get(this.items).filter(item => {
+ return game.user.isGM || !get(item.itemFlagData).hidden;
+ });
+ this.itemCategories.set(Array.from(new Set(get(this.allItems).filter(entry => !entry.isCurrency).map(item => item.type))).map(type => ({
+ label: localize(CONFIG.Item.typeLabels[type]), type
+ })));
+ const itemsPerCategory = items.reduce((acc, item) => {
+ if (!acc[item.type]) {
+ acc[item.type] = [];
+ }
+ acc[item.type].push(item);
+ return acc;
+ }, {});
+ this.itemsPerCategory.set(itemsPerCategory);
+ let categories = Object.keys(itemsPerCategory);
+ categories.sort()
+ this.categories.set(categories.map(type => {
+ return {
+ label: localize(CONFIG.Item.typeLabels[type]), type
+ }
+ }));
+ }
+
+ refreshItemPrices() {
+ get(this.allItems).forEach(item => {
+ item.refreshPriceData();
+ });
+ }
+
+ createItem(item) {
+ if (PileUtilities.isItemInvalid(this.actor, item)) return;
+ const items = get(this.allItems);
+ const itemClass = new this.ItemClass(this, item);
+ itemClass.refreshPriceData();
+ items.push(itemClass);
+ this.allItems.set(items);
+ this.refreshItems();
+ }
+
+ deleteItem(item) {
+ if (PileUtilities.isItemInvalid(this.actor, item)) return;
+ const items = get(this.allItems);
+ const pileItem = items.find(pileItem => pileItem.id === item.id);
+ if (!pileItem) return;
+ pileItem.unsubscribe();
+ items.splice(items.indexOf(pileItem), 1);
+ this.allItems.set(items);
+ this.refreshItems();
+ }
+
+ updatePriceModifiers() {
+ let pileData = get(this.pileData);
+ this.priceModifiersPerType.set(pileData.itemTypePriceModifiers.reduce((acc, priceData) => {
+ acc[priceData.type] = priceData;
+ return acc;
+ }, {}));
+ if (this.recipient && pileData.actorPriceModifiers) {
+ const actorSpecificModifiers = pileData.actorPriceModifiers?.find(data => data.actorUuid === this.recipientUuid);
+ if (actorSpecificModifiers) {
+ this.priceModifiersForActor.set(actorSpecificModifiers);
+ }
+ }
+ }
+
+ addOverrideTypePrice(type) {
+ const pileData = get(this.pileData);
+ pileData.itemTypePriceModifiers.push({
+ type: type,
+ override: false,
+ buyPriceModifier: 1,
+ sellPriceModifier: 1
+ })
+ this.pileData.set(pileData);
+ }
+
+ removeOverrideTypePrice(type) {
+ const pileData = get(this.pileData);
+ const priceMods = pileData.itemTypePriceModifiers;
+ const typeEntry = priceMods.find(entry => entry.type === type);
+ priceMods.splice(priceMods.indexOf(typeEntry), 1);
+ this.pileData.set(pileData);
+ }
+
+ async update() {
+ const pileData = get(this.pileData);
+ const priceModPerType = get(this.priceModifiersPerType);
+ pileData.itemTypePriceModifiers = Object.values(priceModPerType);
+ await PileUtilities.updateItemPileData(this.actor, pileData);
+ Helpers.custom_notify(localize("ITEM-PILES.Notifications.UpdateMerchantSuccess"));
+ }
+
+ tradeItem(pileItem, selling) {
+ if (get(pileItem.itemFlagData).notForSale && !game.user.isGM) return;
+ TradeMerchantItemDialog.show(
+ pileItem,
+ this.actor,
+ this.recipient,
+ { selling }
+ );
+ }
+
+}
+
+class PileMerchantItem extends PileItem {
+
+ setupStores(item) {
+ super.setupStores(item);
+ this.itemFlagData = writable({});
+ this.prices = writable({});
+ this.displayQuantity = writable(false);
+ this.selectedPriceGroup = writable(-1);
+ this.quantityToBuy = writable(1);
+ }
+
+ setupSubscriptions() {
+ let setup = false;
+ super.setupSubscriptions();
+ this.itemFlagData.set(PileUtilities.getItemFlagData(this.item));
+ this.subscribeTo(this.store.pileData, () => {
+ if (!setup) return;
+ this.refreshPriceData();
+ this.refreshDisplayQuantity();
+ });
+ if (this.store.recipient) {
+ this.subscribeTo(this.store.recipientPileData, () => {
+ if (!setup) return
+ this.refreshPriceData();
+ this.refreshDisplayQuantity();
+ });
+ }
+ this.subscribeTo(this.store.priceModifiersPerType, () => {
+ if (!setup) return;
+ this.refreshPriceData();
+ });
+ this.subscribeTo(this.quantityToBuy, () => {
+ if (!setup) return;
+ this.refreshPriceData();
+ });
+ this.subscribeTo(this.itemDocument, () => {
+ if (!setup) return;
+ const { data } = this.itemDocument.updateOptions;
+ if (hasProperty(data, CONSTANTS.FLAGS.ITEM)) {
+ this.itemFlagData.set(PileUtilities.getItemFlagData(this.item));
+ this.refreshDisplayQuantity();
+ }
+ if (hasProperty(data, CONSTANTS.FLAGS.ITEM + ".prices")) {
+ this.refreshPriceData();
+ }
+ if (hasProperty(data, game.itempiles.ITEM_PRICE_ATTRIBUTE)) {
+ this.refreshPriceData();
+ }
+ });
+ setup = true;
+ this.refreshDisplayQuantity();
+ this.subscribeTo(this.store.typeFilter, this.filter.bind(this));
+ }
+
+ refreshDisplayQuantity() {
+
+ const merchantDisplayQuantity = get(this.store.pileData).displayQuantity;
+
+ const itemFlagDataQuantity = get(this.itemFlagData).displayQuantity;
+
+ if (itemFlagDataQuantity === "always") {
+ return this.displayQuantity.set(true);
+ }
+
+ const itemDisplayQuantity = {
+ "default": merchantDisplayQuantity === "yes",
+ "yes": true,
+ "no": false
+ }[itemFlagDataQuantity ?? "default"];
+
+ if (merchantDisplayQuantity.startsWith("always")) {
+ return this.displayQuantity.set(merchantDisplayQuantity.endsWith("yes"));
+ }
+
+ this.displayQuantity.set(itemDisplayQuantity)
+ }
+
+ refreshPriceData() {
+
+ const quantityToBuy = get(this.quantityToBuy);
+ const itemFlagData = get(this.itemFlagData);
+ const sellerFlagData = get(this.store.pileData);
+ const buyerFlagData = get(this.store.recipientPileData);
+ const priceData = PileUtilities.getItemPrices(this.item, {
+ seller: this.store.actor,
+ buyer: this.store.recipient,
+ sellerFlagData,
+ buyerFlagData,
+ itemFlagData,
+ quantity: quantityToBuy
+ });
+
+ let selectedPriceGroup = get(this.selectedPriceGroup);
+ if (selectedPriceGroup === -1) {
+ selectedPriceGroup = Math.max(0, priceData.findIndex(price => price.maxQuantity));
+ this.selectedPriceGroup.set(selectedPriceGroup)
+ }
+
+ this.prices.set(priceData);
+
+ }
+
+ filter() {
+ const name = get(this.name);
+ const search = get(this.store.search);
+ const searchFiltered = !name.toLowerCase().includes(search.toLowerCase());
+ const typeFilter = get(this.store.typeFilter);
+ const typeFiltered = typeFilter !== "all" && typeFilter.toLowerCase() !== this.type.toLowerCase();
+ this.filtered.set(searchFiltered || typeFiltered);
+ }
+
+ async updateItemFlagData() {
+ const itemFlagData = get(this.itemFlagData);
+ await PileUtilities.updateItemData(this.item, { flags: itemFlagData });
+ }
+
+}
\ No newline at end of file
diff --git a/src/stores/pile-item.js b/src/stores/pile-item.js
new file mode 100644
index 00000000..9345f6b6
--- /dev/null
+++ b/src/stores/pile-item.js
@@ -0,0 +1,208 @@
+import { get, writable } from "svelte/store";
+import * as Utilities from "../helpers/utilities.js";
+import { TJSDocument } from '@typhonjs-fvtt/runtime/svelte/store';
+import * as PileUtilities from "../helpers/pile-utilities.js";
+import * as SharingUtilities from "../helpers/sharing-utilities.js";
+
+class PileBaseItem {
+
+ constructor(store, data) {
+ this.store = store;
+ this.subscriptions = [];
+ this.setup(data);
+ }
+
+ setupStores() {
+ this.quantity = writable(1);
+ this.currentQuantity = writable(1);
+ this.quantityLeft = writable(1);
+ this.filtered = writable(true);
+ this.presentFromTheStart = writable(false);
+ }
+
+ setupSubscriptions() {
+ // Higher order implementation
+ }
+
+ setup(data) {
+ this.unsubscribe();
+ this.setupStores(data);
+ this.setupSubscriptions(data);
+ }
+
+ subscribeTo(target, callback) {
+ this.subscriptions.push(target.subscribe(callback));
+ }
+
+ unsubscribe() {
+ this.subscriptions.forEach(unsubscribe => unsubscribe());
+ this.subscriptions = [];
+ }
+}
+
+export class PileItem extends PileBaseItem {
+
+ setupStores(item) {
+ super.setupStores();
+ this.item = item;
+ this.itemDocument = new TJSDocument(this.item);
+ this.presentFromTheStart.set(Utilities.getItemQuantity(this.item) > 0);
+ this.quantity.set(Utilities.getItemQuantity(this.item));
+ this.currentQuantity.set(Math.min(get(this.currentQuantity), get(this.quantityLeft), get(this.quantity)));
+ this.id = this.item.id;
+ this.type = this.item.type;
+ this.name = writable(this.item.name);
+ this.img = writable(this.item.img);
+ this.abbreviation = this.item.abbreviation;
+ this.identifier = this.id;
+ }
+
+ setupSubscriptions() {
+ super.setupSubscriptions();
+
+ this.subscribeTo(this.store.shareData, () => {
+ if (!this.toShare) {
+ this.quantityLeft.set(get(this.quantity));
+ return;
+ }
+ const quantityLeft = SharingUtilities.getItemSharesLeftForActor(this.store.actor, this.item, this.store.recipient);
+ this.quantityLeft.set(quantityLeft);
+ });
+
+ this.subscribeTo(this.itemDocument, () => {
+ const { data } = this.itemDocument.updateOptions;
+ this.name.set(this.item.name);
+ this.img.set(this.item.img);
+ this.similarities = Utilities.setSimilarityProperties({}, this.item);
+ if (hasProperty(data, game.itempiles.ITEM_QUANTITY_ATTRIBUTE)) {
+ this.quantity.set(Utilities.getItemQuantity(data));
+ const quantity = Math.min(get(this.currentQuantity), get(this.quantityLeft), get(this.quantity));
+ this.currentQuantity.set(quantity);
+ }
+ });
+
+ this.subscribeTo(this.quantity, this.filter.bind(this));
+ this.subscribeTo(this.store.search, this.filter.bind(this));
+ this.subscribeTo(this.store.pileData, this.setupProperties.bind(this));
+ }
+
+ setupProperties() {
+ this.isCurrency = PileUtilities.isItemCurrency(this.item, { target: this.store.actor });
+ this.similarities = Utilities.setSimilarityProperties({}, this.item);
+ this.toShare = this.isCurrency
+ ? get(this.store.pileData).shareCurrenciesEnabled && !!this.store.recipient
+ : get(this.store.pileData).shareItemsEnabled && !!this.store.recipient;
+ }
+
+ filter() {
+ const search = get(this.store.search);
+ const presentFromTheSTart = get(this.presentFromTheStart);
+ const quantity = get(this.quantity);
+ if (quantity === 0 && !presentFromTheSTart) {
+ this.filtered.set(true);
+ } else if (search) {
+ this.filtered.set(!this.name.toLowerCase().includes(search.toLowerCase()));
+ } else {
+ this.filtered.set(!presentFromTheSTart && quantity === 0);
+ }
+ }
+
+
+ take() {
+ const quantity = Math.min(get(this.currentQuantity), get(this.quantityLeft));
+ if (!quantity) return;
+ return game.itempiles.transferItems(
+ this.store.actor,
+ this.store.recipient,
+ [{ _id: this.id, quantity }],
+ { interactionId: this.store.interactionId }
+ );
+ }
+
+ updateQuantity(quantity) {
+ const roll = new Roll(quantity).evaluate({ async: false });
+ this.quantity.set(roll.total);
+ return this.item.update({
+ [game.itempiles.ITEM_QUANTITY_ATTRIBUTE]: roll.total
+ });
+ }
+}
+
+export class PileAttribute extends PileBaseItem {
+
+ setupStores(attribute) {
+ super.setupStores();
+ this.attribute = attribute;
+ this.path = this.attribute.path;
+ this.name = writable(this.attribute.name);
+ this.img = writable(this.attribute.img);
+ this.abbreviation = this.attribute.abbreviation;
+ this.identifier = this.attribute.path;
+ this.presentFromTheStart.set(Number(getProperty(this.store.actor.data, this.attribute.path) ?? 0) > 0);
+ this.quantity.set(Number(getProperty(this.store.actor.data, this.path) ?? 0));
+ this.currentQuantity.set(Math.min(get(this.currentQuantity), get(this.quantityLeft), get(this.quantity)));
+ }
+
+ setupSubscriptions() {
+ super.setupSubscriptions();
+
+ this.subscribeTo(this.store.shareData, (val) => {
+ if (!this.toShare) {
+ this.quantityLeft.set(get(this.quantity));
+ return;
+ }
+ const quantityLeft = SharingUtilities.getAttributeSharesLeftForActor(this.store.actor, this.path, this.store.recipient);
+ this.quantityLeft.set(quantityLeft);
+ });
+
+ this.subscribeTo(this.store.document, () => {
+ const { data } = this.store.document.updateOptions;
+ this.path = this.attribute.path;
+ this.name.set(this.attribute.name);
+ this.img.set(this.attribute.img);
+ if (hasProperty(data, this.path)) {
+ this.quantity.set(Number(getProperty(data, this.path) ?? 0));
+ this.currentQuantity.set(Math.min(get(this.currentQuantity), get(this.quantityLeft), get(this.quantity)));
+ }
+ });
+
+ this.subscribeTo(this.quantity, this.filter.bind(this));
+ this.subscribeTo(this.store.search, this.filter.bind(this));
+ this.subscribeTo(this.store.pileData, this.setupProperties.bind(this));
+ }
+
+ setupProperties() {
+ this.toShare = get(this.store.pileData).shareCurrenciesEnabled && !!this.store.recipient;
+ }
+
+ filter() {
+ const name = get(this.name);
+ const search = get(this.store.search);
+ const presentFromTheSTart = get(this.presentFromTheStart);
+ const quantity = get(this.quantity);
+ if (quantity === 0 && !presentFromTheSTart && !this.store.editQuantities) {
+ this.filtered.set(true);
+ } else if (search) {
+ this.filtered.set(!name.toLowerCase().includes(search.toLowerCase()));
+ } else {
+ this.filtered.set(!presentFromTheSTart && quantity === 0 && !this.store.editQuantities);
+ }
+ }
+
+ take() {
+ const quantity = Math.min(get(this.currentQuantity), get(this.quantityLeft));
+ return game.itempiles.transferAttributes(
+ this.store.actor,
+ this.store.recipient,
+ { [this.path]: quantity },
+ { interactionId: this.interactionId }
+ );
+ }
+
+ updateQuantity() {
+ return this.store.actor.update({
+ [this.path]: get(this.quantity)
+ });
+ }
+
+}
\ No newline at end of file
diff --git a/src/styles/styles.scss b/src/styles/styles.scss
new file mode 100644
index 00000000..726669d1
--- /dev/null
+++ b/src/styles/styles.scss
@@ -0,0 +1,677 @@
+/* ----------------------- Generic ----------------------- */
+
+.break {
+ flex-basis: 100% !important;
+}
+
+.item-piles {
+
+ &-flexrow {
+ display: flex;
+ flex-direction: row;
+ flex-wrap: wrap;
+ justify-content: flex-start;
+
+ & > * {
+ flex: 1;
+ }
+ }
+
+ &-flexcol {
+ display: flex;
+ flex-direction: column;
+ flex-wrap: nowrap;
+ justify-content: flex-start;
+
+ & > * {
+ flex: 1;
+ }
+ }
+
+ &-player-list-trade-button {
+ line-height: inherit;
+ font-size: 0.85rem;
+ width: calc(100% - 0.5rem);
+ margin: 0.25rem;
+
+ &.item-piles-minimal-ui {
+ padding: 2px 0 0 0;
+ text-align: center;
+
+ i {
+ width: 100%;
+ }
+ }
+ }
+
+ &-specate-trade:disabled {
+ background-color: rgba(0, 0, 0, 0.25);
+ }
+
+ &-dialog {
+ text-align: center;
+ font-size: 0.9rem;
+ margin-bottom: 1rem;
+ }
+
+ &-disabled {
+ opacity: 0.75;
+ background-color: var(--color-bg-btn-minor-inactive, #c9c7b8);
+ }
+
+ &-clickable {
+ cursor: pointer;
+
+ &-red {
+ cursor: pointer;
+ color: red;
+ }
+
+ &-green {
+ cursor: pointer;
+ color: green;
+ }
+
+ &-link {
+ cursor: pointer;
+
+ &-disabled {
+ cursor: not-allowed;
+ opacity: 0.65;
+ }
+ }
+
+ &-green:hover {
+ text-shadow: 0 0 8px rgba(0, 125, 0, 1);
+ }
+
+ &-link:hover {
+ text-shadow: 0 0 8px var(--color-shadow-primary);
+ }
+ }
+
+ &-moveable {
+ cursor: move;
+ }
+
+ &-highlight {
+ color: var(--color-text-hyperlink, #ff6400);
+ text-decoration: underline;
+ }
+
+ &-grow {
+ flex-grow: 1;
+ }
+
+ &-text {
+ &-right {
+ text-align: right;
+ }
+
+ &-center {
+ text-align: center;
+ }
+ }
+
+ &-small-text {
+ font-size: 0.75rem;
+ }
+
+ &-middle {
+ vertical-align: middle;
+ }
+
+ &-even-color:nth-child(even) {
+ background-color: var(--color-text-light-highlight, #f0f0e0);
+ }
+
+ &-odd-color:nth-child(odd) {
+ background-color: var(--color-text-light-highlight, #f0f0e0);
+ }
+
+ &-bottom-divider {
+ border-bottom: 1px solid rgba(0, 0, 0, 0.35);
+ margin-bottom: 0.5rem;
+ padding-bottom: 0.5rem;
+ }
+
+ &-top-divider {
+ border-top: 1px solid rgba(0, 0, 0, 0.35);
+ margin-top: 0.5rem;
+ padding-top: 0.5rem;
+ }
+
+ &-quantity-container {
+ align-items: center;
+ display: flex;
+ }
+
+ &-sortable-list-columns {
+ position: relative;
+ display: grid;
+ margin: 0.2em 0;
+ z-index: 99999 !important;
+ vertical-align: middle;
+
+ &.header {
+ text-align: center;
+ font-style: italic;
+ }
+
+ div {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ }
+
+ button {
+ height: 28px;
+ line-height: 19px;
+ }
+
+ .delete-button {
+ width: 28px;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ }
+
+ }
+
+}
+
+.item-piles-app {
+
+ footer {
+ display: flex;
+ }
+}
+
+.align-center {
+ &-col {
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ flex-direction: column;
+ }
+
+ &-row {
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ flex-direction: row;
+ }
+}
+
+.item-piles-slider-group {
+ padding: 0 5px 0 0;
+ margin-bottom: 0.25rem;
+ margin-right: 5px;
+ border-radius: 4px;
+}
+
+.item-piles-img-container {
+ min-height: 24px;
+ min-width: 24px;
+ max-width: 24px;
+ max-height: 24px;
+ margin: 2px;
+ overflow: hidden;
+ border-radius: 4px;
+ border: 1px solid black;
+
+ .item-piles-img {
+ border: 0;
+ width: auto;
+ height: 100%;
+ }
+
+ &.not-for-sale {
+ position: relative;
+
+ &::before {
+ position: absolute;
+ content: "";
+ left: -10px;
+ top: calc(50% - 2px);
+ right: -10px;
+ border-top: 4px solid red;
+
+ -webkit-transform: rotate(-45deg);
+ -moz-transform: rotate(-45deg);
+ -ms-transform: rotate(-45deg);
+ -o-transform: rotate(-45deg);
+ transform: rotate(-45deg);
+ }
+ }
+}
+
+/* ----------------------- UTILITIES ----------------------- */
+
+.blob {
+ margin-left: 0.5rem;
+ color: white;
+ display: grid;
+ place-items: center;
+ width: 0.8rem;
+ height: 0.8rem;
+ font-size: 0.5rem;
+ box-shadow: 0 0 0 0 rgba(217, 49, 49, 1);
+ animation: pulse 1s infinite;
+ background-color: rgb(217, 49, 49);
+ border-radius: 50%;
+}
+
+@keyframes pulse {
+ 0% {
+ box-shadow: 0 0 0 0 rgba(217, 49, 49, 0.7);
+ }
+
+ 70% {
+ box-shadow: 0 0 0 10px rgba(217, 49, 49, 0);
+ }
+
+ 100% {
+ box-shadow: 0 0 0 0 rgba(217, 49, 49, 0);
+ }
+}
+
+
+/* ----------------------- INVENTORY ----------------------- */
+
+.item-piles-item-row {
+ padding: 0 2px 0 0;
+ border-radius: 4px;
+ align-items: center;
+
+ .item-piles-disabled {
+ background-color: var(--color-bg-btn-minor-inactive, #c9c7b8)
+ }
+
+ .item-piles-disabled {
+ background-color: var(--color-bg-btn-minor-inactive, #c9c7b8)
+ }
+
+ .item-piles-name {
+
+ margin-left: 5px;
+ text-wrap: normal;
+ flex: 1 0 45%;
+ display: inline-flex;
+ flex-direction: column;
+ align-items: flex-start;
+
+ .item-piles-name-container {
+ flex: 1;
+ display: inline-flex;
+ flex-direction: row;
+ align-items: center;
+ word-break: break-word;
+
+ p {
+ margin: 0;
+ }
+
+ span {
+ margin: 2px 5px 0 5px;
+ flex: 1 0 auto;
+ }
+ }
+
+ span {
+ line-height: 1;
+ flex: 0;
+ }
+ }
+
+ .item-piles-quantity-container {
+
+ align-items: center;
+ display: flex;
+
+ .item-piles-quantity-input-container {
+
+ height: 100%;
+ display: flex;
+ flex: 1;
+ align-items: center;
+ flex-direction: row;
+ padding: 2px;
+
+ .item-piles-quantity {
+ height: 20px;
+ flex: 1;
+ margin-left: 0.5rem;
+ text-align: right;
+ }
+
+ }
+ }
+
+ .item-piles-input-divider {
+ flex: 1;
+ margin: 0.1rem 0.5rem 0 0.25rem;
+ font-size: 0.8rem;
+ line-height: 1.25rem;
+ }
+
+ .item-piles-item-take-button, .item-piles-currency-take-button {
+ flex: 0;
+ min-width: 4rem;
+ height: 22px;
+ padding: 1px 3px;
+ margin: 3px;
+ line-height: inherit;
+ border-radius: 4px;
+ }
+
+}
+
+/* ----------------------- CONFIG ----------------------- */
+
+
+.item-piles-config {
+ min-width: 430px;
+ min-height: 627px;
+
+ .dialog-content {
+ height: 100%;
+ overflow: hidden;
+ }
+}
+
+.item-piles-collapsible {
+
+ &:not(:last-child) {
+ margin-bottom: 0.75rem;
+ padding-bottom: 0.75rem;
+ border-bottom: 1px solid var(--color-border-light-primary, #b5b3a4);
+ }
+
+ & > summary {
+ display: block;
+ font-weight: 900;
+
+ &::before {
+ font-family: "Font Awesome 5 Free";
+ font-weight: 900;
+ content: "\f054";
+ margin-right: 0.5rem;
+ }
+ }
+
+ &[open] > summary {
+ margin-bottom: 0.5rem;
+
+ &::before {
+ font-family: "Font Awesome 5 Free";
+ font-weight: 900;
+ content: "\f078";
+ margin-right: 0.275rem;
+ }
+ }
+}
+
+.item-piles-config-container {
+
+ display: flex;
+ flex-direction: column;
+ justify-content: flex-start;
+ overflow: hidden;
+ height: calc(100%);
+ max-height: calc(100%);
+
+ nav {
+ margin-bottom: 0.25rem;
+ padding-bottom: 0.25rem;
+ border-bottom: 1px solid var(--color-border-light-primary, #b5b3a4);
+ }
+
+ .form-group {
+ align-items: center;
+ }
+
+ section {
+ height: calc(100% - 70px);
+ max-height: calc(100% - 70px);
+ overflow-y: auto;
+
+ .tab {
+ padding: 0.25rem;
+ }
+ }
+
+ p {
+ flex: 0;
+ line-height: 14px;
+ font-size: var(--font-size-12);
+ color: var(--color-text-dark-secondary);
+ padding-right: 1rem;
+ margin-top: 0;
+ overflow-y: hidden;
+ margin-bottom: 0.25rem;
+ }
+
+ footer {
+ margin-top: 0.5rem;
+ padding-top: 0.5rem;
+ border-top: 1px solid var(--color-border-light-primary, #b5b3a4);
+ }
+}
+
+/* ---------------------- CHAT CARDS ---------------------- */
+
+.item-piles-chat-card {
+ padding: 0.5rem;
+
+ img {
+ border: 0;
+ vertical-align: middle;
+ }
+
+ .item-piles-chat-card-title {
+ i {
+ line-height: 1rem;
+ font-size: 1.25rem;
+ margin: 0 0.5rem;
+ }
+
+ img {
+ margin-bottom: 5px;
+ }
+ }
+
+ ul {
+ display: inline-flex;
+ flex-direction: column;
+ list-style-type: none;
+ padding: 0;
+ margin: 0;
+ width: 100%;
+ }
+
+ li {
+ display: inline-flex;
+ flex-direction: row;
+ width: 100%;
+ margin: 1px 0;
+ padding: 3px 4px;
+ border-radius: 3px;
+ align-items: center;
+
+ &:nth-child(odd) {
+ background-color: var(--color-text-light-highlight, #f0f0e0);
+ }
+
+ img {
+ margin-right: 5px;
+ flex: 0;
+ }
+
+ label {
+ flex: 1;
+ flex-wrap: wrap;
+ }
+
+ small {
+ min-width: 1rem;
+ text-align: right;
+ padding-right: 2px;
+ }
+ }
+}
+
+/* ---------------------- TRADING UI ---------------------- */
+
+
+.item-piles-trading-sheet {
+
+ .item-piles-confirm-quantity {
+ justify-self: flex-end;
+ }
+
+ .item-piles-quantity-container {
+ flex: 0 1 75px;
+ display: flex;
+ padding-right: 3px;
+ }
+
+ .item-piles-quantity {
+ margin: 0 !important;
+ }
+
+ .item-piles-quantity-text {
+ line-height: 1.25rem;
+ font-size: 0.85rem;
+ background-color: rgba(255, 255, 255, 0.15);
+ border: 1px solid rgba(0, 0, 0, 0.15);
+ padding-right: 0.2rem;
+ border-radius: 4px;
+ margin: 0 2px;
+ width: 100%;
+ height: 20px;
+ letter-spacing: 0.2px;
+ }
+
+ .item-piles-quantity-text:hover {
+ background-color: rgba(255, 255, 255, 0.5);
+ border: 1px solid rgba(0, 0, 0, 0.5);
+ }
+
+ .item-piles-add-currency {
+ flex: 1;
+ vertical-align: middle;
+ margin-bottom: 5px;
+ }
+
+ .item-piles-items-list {
+ min-height: 300px;
+ max-height: 300px;
+ }
+
+ .item-piles-currency-list {
+ min-height: unset;
+ max-height: unset;
+ }
+
+ h1, h2 {
+ border: 0;
+ vertical-align: center;
+ }
+
+ .character-header {
+
+ display: inline-flex;
+ flex-direction: row;
+ flex: 0 1 auto;
+ padding: 5px;
+ align-items: center;
+
+ .character-name {
+ padding-top: 0.5rem;
+ text-align: center;
+ flex: 1;
+ }
+
+ img {
+ max-width: 40px;
+ max-height: 40px;
+ width: auto;
+ height: auto;
+ border: 0;
+ margin-right: auto;
+ flex: 0 1 auto;
+ border-radius: 5px;
+ }
+
+ .accepted-icon {
+ font-size: 2rem;
+ color: #979797;
+
+
+ &.accepted {
+ color: rgb(5, 150, 105);
+ }
+ }
+ }
+}
+
+.item-piles-text-editor {
+
+ .editor {
+ height: calc(100% - 32px) !important;
+ }
+
+ .tox.tox-tinymce {
+ height: calc(100%) !important;
+ }
+}
+
+.price-list {
+ z-index: 900;
+ font-size: 0.75rem;
+ border-radius: 5px;
+ overflow: hidden;
+ background-color: #ccccbe;
+
+ .price-group {
+
+ cursor: pointer;
+ user-select: none;
+
+ &.selected {
+ background-color: #e6e6d5;
+ }
+
+ &:hover {
+ background-color: #ffffed;
+ }
+
+ .price-group-container {
+ display: flex;
+ align-items: center;
+
+ padding: 0 4px 0 2px;
+
+ &:first-child {
+ padding-top: 2px;
+ }
+
+ &:last-child {
+ padding-bottom: 2px;
+ }
+
+ .item-piles-img-container {
+ min-height: 18px;
+ min-width: 18px;
+ max-width: 18px;
+ max-height: 18px;
+ margin: 1px;
+ }
+ }
+
+ &:not(:last-child) {
+ border-bottom: 1px solid rgba(0, 0, 0, 0.5);
+ }
+ }
+}
\ No newline at end of file
diff --git a/src/systems.js b/src/systems.js
new file mode 100644
index 00000000..4f3c7f84
--- /dev/null
+++ b/src/systems.js
@@ -0,0 +1,57 @@
+import dnd5e from "./systems/dnd5e.js";
+
+// ā IMPORT SYSTEMS HERE ā
+import pf1 from "./systems/pf1.js";
+import pf2e from "./systems/pf2e.js";
+import ds4 from "./systems/ds4.js";
+import d35e from "./systems/d35e.js";
+import sfrpg from "./systems/sfrpg.js";
+import swade from "./systems/swade.js";
+import tormenta20 from "./systems/tormenta20.js";
+import wfrp4e from "./systems/wfrp4e.js"
+import splittermond from "./systems/splittermond.js"
+import twodsix from "./systems/twodsix.js";
+// ā IMPORT SYSTEMS HERE ā
+
+/**
+ * NOTE: YOUR PULL REQUEST WILL NOT BE ACCEPTED IF YOU DO NOT
+ * FOLLOW THE CONVENTION IN THE D&D 5E SYSTEM FILE
+ */
+export const SYSTEMS = {
+
+ SUPPORTED_SYSTEMS: {
+ dnd5e,
+ // ā ADD SYSTEMS HERE ā
+ pf1,
+ pf2e,
+ ds4,
+ d35e,
+ sfrpg,
+ swade,
+ tormenta20,
+ wfrp4e,
+ splittermond,
+ twodsix
+ // ā ADD SYSTEMS HERE ā
+ },
+
+ DEFAULT_SETTINGS: {
+ ACTOR_CLASS_TYPE: "",
+ ITEM_QUANTITY_ATTRIBUTE: "",
+ ITEM_PRICE_ATTRIBUTE: "",
+ ITEM_FILTERS: [],
+ ITEM_SIMILARITIES: [],
+ CURRENCIES: {
+ "itemBased": false,
+ "list": []
+ }
+ },
+
+ get HAS_SYSTEM_SUPPORT() {
+ return !!this.SUPPORTED_SYSTEMS?.[game.system.id];
+ },
+
+ get DATA() {
+ return this.SUPPORTED_SYSTEMS?.[game.system.id] ?? this.DEFAULT_SETTINGS;
+ }
+};
\ No newline at end of file
diff --git a/src/systems/d35e.js b/src/systems/d35e.js
new file mode 100644
index 00000000..f7f82349
--- /dev/null
+++ b/src/systems/d35e.js
@@ -0,0 +1,71 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "npc",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
+
+ // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "spell,feat,class,race,attack,full-attack,buff,aura,alignment,enhancement,damage-type,material"
+ }
+ ],
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type"],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data
+ "CURRENCIES": [
+ {
+ type: "attribute",
+ name: "DND5E.CurrencyPP",
+ img: "icons/commodities/currency/coin-inset-snail-silver.webp",
+ abbreviation: "{#}PP",
+ data: {
+ path: "data.currency.pp"
+ },
+ primary: false,
+ exchangeRate: 10
+ },
+ {
+ type: "attribute",
+ name: "DND5E.CurrencyGP",
+ img: "icons/commodities/currency/coin-embossed-crown-gold.webp",
+ abbreviation: "{#}GP",
+ data: {
+ path: "data.currency.gp",
+ },
+ primary: true,
+ exchangeRate: 1
+ },
+ {
+ type: "attribute",
+ name: "DND5E.CurrencySP",
+ img: "icons/commodities/currency/coin-engraved-moon-silver.webp",
+ abbreviation: "{#}SP",
+ data: {
+ path: "data.currency.sp",
+ },
+ primary: false,
+ exchangeRate: 0.1
+ },
+ {
+ type: "attribute",
+ name: "DND5E.CurrencyCP",
+ img: "icons/commodities/currency/coin-engraved-waves-copper.webp",
+ abbreviation: "{#}CP",
+ data: {
+ path: "data.currency.cp",
+ },
+ primary: false,
+ exchangeRate: 0.01
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/systems/dnd5e.js b/src/systems/dnd5e.js
new file mode 100644
index 00000000..87da76d5
--- /dev/null
+++ b/src/systems/dnd5e.js
@@ -0,0 +1,99 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "character",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
+
+ // The item price attribute is the path to the attribute on each item that determine how much it costs
+ "ITEM_PRICE_ATTRIBUTE": "data.price",
+
+ // Item filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "spell,feat,class"
+ },
+ {
+ "path": "data.weaponType",
+ "filters": "natural"
+ }
+ ],
+
+ "ITEM_TRANSFORMER": async (itemData) => {
+ ["equipped", "proficient", "prepared"].forEach(key => delete itemData.data[key]);
+ itemData.data.attunement = Math.min(CONFIG.DND5E.attunementTypes.REQUIRED, itemData.data.attunement);
+ if (itemData.type === "spell") {
+ const scroll = await Item.implementation.createScrollFromSpell(itemData);
+ itemData = scroll.data;
+ }
+ return itemData;
+ },
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type"],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data
+ "CURRENCIES": [
+ {
+ type: "attribute",
+ name: "DND5E.CurrencyPP",
+ img: "icons/commodities/currency/coin-inset-snail-silver.webp",
+ abbreviation: "{#}PP",
+ data: {
+ path: "data.currency.pp"
+ },
+ primary: false,
+ exchangeRate: 10
+ },
+ {
+ type: "attribute",
+ name: "DND5E.CurrencyGP",
+ img: "icons/commodities/currency/coin-embossed-crown-gold.webp",
+ abbreviation: "{#}GP",
+ data: {
+ path: "data.currency.gp",
+ },
+ primary: true,
+ exchangeRate: 1
+ },
+ {
+ type: "attribute",
+ name: "DND5E.CurrencyEP",
+ img: "icons/commodities/currency/coin-inset-copper-axe.webp",
+ abbreviation: "{#}EP",
+ data: {
+ path: "data.currency.ep",
+ },
+ primary: false,
+ exchangeRate: 0.5
+ },
+ {
+ type: "attribute",
+ name: "DND5E.CurrencySP",
+ img: "icons/commodities/currency/coin-engraved-moon-silver.webp",
+ abbreviation: "{#}SP",
+ data: {
+ path: "data.currency.sp",
+ },
+ primary: false,
+ exchangeRate: 0.1
+ },
+ {
+ type: "attribute",
+ name: "DND5E.CurrencyCP",
+ img: "icons/commodities/currency/coin-engraved-waves-copper.webp",
+ abbreviation: "{#}CP",
+ data: {
+ path: "data.currency.cp",
+ },
+ primary: false,
+ exchangeRate: 0.01
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/systems/ds4.js b/src/systems/ds4.js
new file mode 100644
index 00000000..cd48863e
--- /dev/null
+++ b/src/systems/ds4.js
@@ -0,0 +1,62 @@
+// Item Piles Definitions for Foundry VTT Game System Dungeonslayers 4
+
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "character",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
+
+ // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "spell,talent,racialAbility,language,alphabet,specialCreatureAbility"
+ }
+ ],
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type"],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data
+ "CURRENCIES": [
+ {
+ type: "attribute",
+ name: "DS4.CharacterCurrencyGold",
+ img: "icons/commodities/currency/coin-embossed-crown-gold.webp",
+ abbreviation: "{#}G",
+ data: {
+ path: "data.currency.gold",
+ },
+ primary: true,
+ exchangeRate: 1
+ },
+ {
+ type: "attribute",
+ name: "DS4.CharacterCurrencySilver",
+ img: "icons/commodities/currency/coin-inset-snail-silver.webp",
+ abbreviation: "{#}S",
+ data: {
+ path: "data.currency.silver",
+ },
+ primary: false,
+ exchangeRate: 0.1
+ },
+ {
+ type: "attribute",
+ name: "DS4.CharacterCurrencyCopper",
+ img: "icons/commodities/currency/coin-engraved-waves-copper.webp",
+ abbreviation: "{#}C",
+ data: {
+ path: "data.currency.copper",
+ },
+ primary: false,
+ exchangeRate: 0.01
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/systems/pf1.js b/src/systems/pf1.js
new file mode 100644
index 00000000..8684b731
--- /dev/null
+++ b/src/systems/pf1.js
@@ -0,0 +1,71 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "npc",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
+
+ // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "attack,buff,class,feat,race,spell"
+ }
+ ],
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type"],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data
+ "CURRENCIES": [
+ {
+ type: "attribute",
+ name: "PF1.CurrencyPlatinumP",
+ img: "systems/pf1/icons/items/inventory/coins-silver.jpg",
+ abbreviation: "{#}PP",
+ data: {
+ path: "data.currency.gold",
+ },
+ primary: true,
+ exchangeRate: 10
+ },
+ {
+ type: "attribute",
+ name: "DS4.CharacterCurrencyGold",
+ img: "systems/pf1/icons/items/inventory/coin-gold.jpg",
+ abbreviation: "{#}G",
+ data: {
+ path: "data.currency.gold",
+ },
+ primary: true,
+ exchangeRate: 1
+ },
+ {
+ type: "attribute",
+ name: "PF1.CurrencySilverP",
+ img: "systems/pf1/icons/items/inventory/coin-silver.jpg",
+ abbreviation: "{#}SP",
+ data: {
+ path: "data.currency.sp",
+ },
+ primary: false,
+ exchangeRate: 0.1
+ },
+ {
+ type: "attribute",
+ name: "PF1.CurrencyCopperP",
+ img: "systems/pf1/icons/items/inventory/coin-copper.jpg",
+ abbreviation: "{#}C",
+ data: {
+ path: "data.currency.cp",
+ },
+ primary: false,
+ exchangeRate: 0.01
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/systems/pf2e.js b/src/systems/pf2e.js
new file mode 100644
index 00000000..2d1ac7bb
--- /dev/null
+++ b/src/systems/pf2e.js
@@ -0,0 +1,74 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "loot",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
+
+ // The item price attribute is the path to the attribute on each item that determine how much it costs
+ "ITEM_PRICE_ATTRIBUTE": "data.price",
+
+ // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "action,spell,melee,lore,heritage,feat,effect,class,background,ancestry"
+ }
+ ],
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type", "data.temporary.value"],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()`, put it into `data.item`, and strip out any module data
+ "CURRENCIES": [
+ {
+ type: "item",
+ name: "Platinum Pieces",
+ img: "systems/pf2e/icons/equipment/treasure/currency/platinum-pieces.webp",
+ abbreviation: "{#}PP",
+ data: {
+ uuid: "Compendium.pf2e.equipment-srd.JuNPeK5Qm1w6wpb4"
+ },
+ primary: false,
+ exchangeRate: 10
+ },
+ {
+ type: "item",
+ name: "Gold Pieces",
+ img: "systems/pf2e/icons/equipment/treasure/currency/gold-pieces.webp",
+ abbreviation: "{#}GP",
+ data: {
+ uuid: "Compendium.pf2e.equipment-srd.B6B7tBWJSqOBz5zz"
+ },
+ primary: true,
+ exchangeRate: 1
+ },
+ {
+ type: "item",
+ name: "Silver Pieces",
+ img: "systems/pf2e/icons/equipment/treasure/currency/silver-pieces.webp",
+ abbreviation: "{#}SP",
+ data: {
+ uuid: "Compendium.pf2e.equipment-srd.5Ew82vBF9YfaiY9f"
+ },
+ primary: false,
+ exchangeRate: 0.1
+ },
+ {
+ type: "item",
+ name: "Copper Pieces",
+ img: "systems/pf2e/icons/equipment/treasure/currency/copper-pieces.webp",
+ abbreviation: "{#}CP",
+ data: {
+ uuid: "Compendium.pf2e.equipment-srd.lzJ8AVhRcbFul5fh"
+ },
+ primary: false,
+ exchangeRate: 0.01
+ }
+ ]
+}
diff --git a/src/systems/sfrpg.js b/src/systems/sfrpg.js
new file mode 100644
index 00000000..b409b24d
--- /dev/null
+++ b/src/systems/sfrpg.js
@@ -0,0 +1,50 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "npc2",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
+
+ // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "attack,buff,class,feat,race,spell"
+ }
+ ],
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type"],
+
+ "CURRENCIES": {
+ "Credits": [
+ {
+ type: "attribute",
+ name: "SFRPG.Currencies.Credits",
+ img: "systems/sfrpg/icons/equipment/goods/credstick.jpg",
+ abbreviation: "{#}C",
+ data: {
+ path: "data.currency.credit",
+ },
+ primary: true,
+ exchangeRate: 1
+ }
+ ],
+ "Universal Polymer Base": [
+ {
+ type: "attribute",
+ name: "SFRPG.Currencies.UPBs",
+ img: "systems/sfrpg/icons/equipment/goods/upb.jpg",
+ abbreviation: "{#} UBP",
+ data: {
+ path: "data.currency.upb",
+ },
+ primary: false,
+ exchangeRate: 1
+ }
+ ]
+ }
+}
\ No newline at end of file
diff --git a/src/systems/splittermond.js b/src/systems/splittermond.js
new file mode 100644
index 00000000..2d5f280c
--- /dev/null
+++ b/src/systems/splittermond.js
@@ -0,0 +1,60 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "npc",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
+
+ // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "spell,strength,weakness,mastery,species,culture,ancestry,education,resource,npcfeature,moonsign,language,culturelore,statuseffect,spelleffect"
+ }
+ ],
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type", "data.sufferedDamage", "data.quality"],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data
+ "CURRENCIES": [
+ {
+ type: "attribute",
+ name: "Solare",
+ img: "icons/commodities/currency/coins-assorted-mix-copper.webp",
+ abbreviation: "{#}S",
+ data: {
+ path: "data.currency.S",
+ },
+ primary: false,
+ exchangeRate: 10000
+ },
+ {
+ type: "attribute",
+ name: "Lunare",
+ img: "icons/commodities/currency/coin-embossed-unicorn-silver.webp",
+ abbreviation: "{#}L",
+ data: {
+ path: "data.currency.L",
+ },
+ primary: false,
+ exchangeRate: 100
+ },
+ {
+ type: "attribute",
+ name: "Telare",
+ img: "icons/commodities/currency/coins-assorted-mix-platinum.webp",
+ abbreviation: "{#}T",
+ data: {
+ path: "data.currency.T",
+ },
+ primary: true,
+ exchangeRate: 1
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/systems/swade.js b/src/systems/swade.js
new file mode 100644
index 00000000..ee46027f
--- /dev/null
+++ b/src/systems/swade.js
@@ -0,0 +1,35 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "character",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
+
+ // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "edge,hindrance,skill,power,ability"
+ }
+ ],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data
+ "CURRENCIES": [
+ {
+ type: "attribute",
+ name: "SWADE.Currency",
+ img: "icons/svg/coins.svg",
+ abbreviation: "{#}T",
+ data: {
+ path: "data.details.currency",
+ },
+ primary: true,
+ exchangeRate: 1
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/systems/tormenta20.js b/src/systems/tormenta20.js
new file mode 100644
index 00000000..4e7fc45c
--- /dev/null
+++ b/src/systems/tormenta20.js
@@ -0,0 +1,64 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "character",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.qtd",
+
+ // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "magia, poder, classe"
+ },
+ {
+ "path": "data.tipoUso",
+ "filters": "nat"
+ }
+ ],
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type"],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data
+ "CURRENCIES": [
+ {
+ type: "attribute",
+ name: "Ouro",
+ img: "icons/commodities/currency/coin-embossed-insect-gold.webp",
+ abbreviation: "{#}O",
+ data: {
+ path: "data.dinheiro.to",
+ },
+ primary: true,
+ exchangeRate: 1
+ },
+ {
+ type: "attribute",
+ name: "Prata",
+ img: "icons/commodities/currency/coin-embossed-unicorn-silver.webp",
+ abbreviation: "{#}P",
+ data: {
+ path: "data.dinheiro.tp",
+ },
+ primary: false,
+ exchangeRate: 0.1
+ },
+ {
+ type: "attribute",
+ name: "Cobre",
+ img: "icons/commodities/currency/coin-engraved-waves-copper.webp",
+ abbreviation: "{#}C",
+ data: {
+ path: "data.dinheiro.tc",
+ },
+ primary: false,
+ exchangeRate: 0.01
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/systems/twodsix.js b/src/systems/twodsix.js
new file mode 100644
index 00000000..c253b74f
--- /dev/null
+++ b/src/systems/twodsix.js
@@ -0,0 +1,41 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "traveller",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity",
+
+ // The item price attribute is the path to the attribute on each item that determine how much it costs
+ "ITEM_PRICE_ATTRIBUTE": "data.price",
+
+ // Item filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "skills"
+ }
+ ],
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type", "techLevel"],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data
+ "CURRENCIES": [
+ {
+ type: "attribute",
+ name: "Credits",
+ img: "systems/twodsix/assets/icons/id-card.svg",
+ abbreviation: "Cr {#}",
+ data: {
+ path: "data.finances.cash"
+ },
+ primary: true,
+ exchangeRate: 1
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/systems/wfrp4e.js b/src/systems/wfrp4e.js
new file mode 100644
index 00000000..06049c2c
--- /dev/null
+++ b/src/systems/wfrp4e.js
@@ -0,0 +1,26 @@
+export default {
+
+ "VERSION": "1.0.0",
+
+ // The actor class type is the type of actor that will be used for the default item pile actor that is created on first item drop.
+ "ACTOR_CLASS_TYPE": "character",
+
+ // The item quantity attribute is the path to the attribute on items that denote how many of that item that exists
+ "ITEM_QUANTITY_ATTRIBUTE": "data.quantity.value",
+
+ // Item types and the filters actively remove items from the item pile inventory UI that users cannot loot, such as spells, feats, and classes
+ "ITEM_FILTERS": [
+ {
+ "path": "type",
+ "filters": "career,container,critical,disease,injury,mutation,prayer,psychology,talent,skill,spell,trait,extendedTest,vehicleMod,cargo"
+ }
+ ],
+
+ // Item similarities determines how item piles detect similarities and differences in the system
+ "ITEM_SIMILARITIES": ["name", "type"],
+
+ // Currencies in item piles is a versatile system that can accept actor attributes (a number field on the actor's sheet) or items (actual items in their inventory)
+ // In the case of attributes, the path is relative to the "actor.data"
+ // In the case of items, it is recommended you export the item with `.toObject()` and strip out any module data
+ "CURRENCIES": []
+}
\ No newline at end of file
diff --git a/styles/module.css b/styles/module.css
deleted file mode 100644
index 52762c16..00000000
--- a/styles/module.css
+++ /dev/null
@@ -1,403 +0,0 @@
-/* ----------------------- Generic ----------------------- */
-.item-piles-player-list-trade-button {
- line-height: inherit;
- font-size: 0.85rem;
- width: calc(100% - 0.5rem);
- margin: 0.25rem;
-}
-.item-piles-player-list-trade-button.item-piles-minimal-ui {
- padding: 2px 0 0 0;
- text-align: center;
-}
-.item-piles-player-list-trade-button.item-piles-minimal-ui i {
- width: 100%;
-}
-.item-piles-specate-trade:disabled {
- background-color: rgba(0, 0, 0, 0.25);
-}
-.item-piles-progress {
- width: calc(100% - 4px);
- background: #e1e4e8;
- border-radius: 3px;
- overflow: hidden;
- margin: 0.25rem 2px 0 2px;
- height: 6px;
-}
-.item-piles-progress .progress-bar {
- display: block;
- height: 100%;
- background-color: rgba(0, 0, 0, 0.65);
- transition: width 30s linear;
-}
-.item-piles-dialog {
- text-align: center;
- font-size: 0.9rem;
- margin-bottom: 1rem;
-}
-.item-piles-disabled {
- opacity: 0.75;
-}
-.item-piles-clickable {
- cursor: pointer;
-}
-.item-piles-clickable-red {
- color: red;
-}
-.item-piles-clickable-green {
- color: green;
-}
-.item-piles-clickable-green:hover {
- text-shadow: 0 0 8px #007d00;
-}
-.item-piles-moveable {
- cursor: move;
-}
-.item-piles-highlight {
- color: var(--color-text-hyperlink, #ff6400);
- text-decoration: underline;
-}
-.item-piles-grow {
- flex-grow: 1;
-}
-.item-piles-text-right {
- text-align: right;
-}
-.item-piles-text-center {
- text-align: center;
-}
-.item-piles-small-text {
- font-size: 0.75rem;
-}
-.item-piles-middle {
- vertical-align: middle;
-}
-.item-piles-img-container {
- min-height: 37px;
- max-width: 37px;
- max-height: 37px;
- overflow: hidden;
- border-radius: 4px;
- border: 1px solid black;
-}
-.item-piles-img-container .item-piles-img {
- border: 0;
- width: auto;
- height: 100%;
- transition: transform 150ms;
-}
-.item-piles-img-container .item-piles-img:hover {
- transform: scale(1.125, 1.125);
-}
-.item-piles-odd-color:nth-child(even) {
- background-color: var(--color-text-light-highlight, #f0f0e0);
-}
-.item-piles-bottom-divider {
- border-bottom: 1px solid rgba(0, 0, 0, 0.35);
- margin-bottom: 0.5rem;
- padding-bottom: 0.5rem;
-}
-.item-piles-top-divider {
- border-top: 1px solid rgba(0, 0, 0, 0.35);
- margin-top: 0.5rem;
- padding-top: 0.5rem;
-}
-.item-piles-disabled {
- background-color: var(--color-bg-btn-minor-inactive, #c9c7b8);
-}
-
-.item-piles-slider-group {
- padding: 0 5px 0 0;
- margin-bottom: 0.25rem;
- margin-right: 5px;
- border-radius: 4px;
-}
-
-#item-piles-preview-container {
- position: absolute;
- display: none;
-}
-#item-piles-preview-container #item-piles-preview-image {
- border: 0;
- width: 300px;
- border-radius: 1rem;
- box-shadow: rgba(0, 0, 0, 0.25) 0px 54px 55px, rgba(0, 0, 0, 0.12) 0px -12px 30px, rgba(0, 0, 0, 0.12) 0px 4px 6px, rgba(0, 0, 0, 0.17) 0px 12px 13px, rgba(0, 0, 0, 0.09) 0px -3px 5px;
-}
-
-/* ----------------------- INVENTORY ----------------------- */
-.item-piles-items-list {
- max-height: 500px;
- overflow-y: scroll;
-}
-.item-piles-items-list .item-piles-change-actor-select {
- display: none;
-}
-.item-piles-items-list #item-piles-preview-container {
- position: absolute;
- display: none;
-}
-.item-piles-items-list .item-piles-add-currency {
- margin-right: 5px;
- flex: 0 1 auto;
- vertical-align: middle;
-}
-.item-piles-items-list .item-piles-item-row {
- padding: 0 5px 0 0;
- margin-bottom: 0.25rem;
- margin-right: 5px;
- border-radius: 4px;
-}
-.item-piles-items-list .item-piles-item-row:nth-child(even):not(.item-piles-disabled) {
- background-color: var(--color-text-light-highlight, #f0f0e0);
-}
-.item-piles-items-list .item-piles-item-row .item-piles-disabled {
- background-color: var(--color-bg-btn-minor-inactive, #c9c7b8);
-}
-.item-piles-items-list .item-piles-item-row div {
- display: inline-flex;
- flex-direction: column;
- justify-content: center;
-}
-.item-piles-items-list .item-piles-item-row .item-piles-text {
- line-height: 1.6rem;
- font-size: 1rem;
- text-wrap: normal;
- flex: 0 1 auto;
-}
-.item-piles-items-list .item-piles-item-row .item-piles-name {
- padding: 0 0.5rem;
- flex: 4;
- display: inline-flex;
- flex-direction: column;
-}
-.item-piles-items-list .item-piles-item-row .item-piles-name .item-piles-name-container {
- flex: 1;
- display: inline-flex;
- flex-direction: column;
- justify-content: center;
-}
-.item-piles-items-list .item-piles-item-row .item-piles-name .item-piles-name-container a {
- max-width: fit-content;
-}
-.item-piles-items-list .item-piles-item-row .item-piles-name span {
- line-height: 1;
- flex: 0;
-}
-.item-piles-items-list .item-piles-item-row .item-piles-quantity {
- flex: 1;
- margin-left: 0.5rem;
- text-align: right;
-}
-.item-piles-items-list .item-piles-item-row .item-piles-input-divider {
- flex: 1;
- margin: 0.1rem 0.5rem 0 0.25rem;
- font-size: 0.8rem;
- line-height: 1.5rem;
-}
-.item-piles-items-list .item-piles-item-row .item-piles-item-take-button, .item-piles-items-list .item-piles-item-row .item-piles-currency-take-button {
- flex: 0;
- min-width: 4rem;
- height: 26px;
- padding: 1px 3px;
- line-height: inherit;
-}
-
-.item-piles-collapsible:not(:last-child) {
- margin-bottom: 0.75rem;
- padding-bottom: 0.75rem;
- border-bottom: 1px solid var(--color-border-light-primary, #b5b3a4);
-}
-.item-piles-collapsible > summary {
- display: block;
- font-weight: 900;
-}
-.item-piles-collapsible > summary::before {
- font-family: "Font Awesome 5 Free";
- font-weight: 900;
- content: "\f054";
- margin-right: 0.5rem;
-}
-.item-piles-collapsible[open] > summary {
- margin-bottom: 0.5rem;
-}
-.item-piles-collapsible[open] > summary::before {
- font-family: "Font Awesome 5 Free";
- font-weight: 900;
- content: "\f078";
- margin-right: 0.275rem;
-}
-
-/* ----------------------- CONFIG ----------------------- */
-.item-piles-config {
- width: 430px;
-}
-.item-piles-config .item-piles-config-container {
- display: flex;
- flex-direction: column;
- justify-content: flex-start;
- overflow: hidden;
-}
-.item-piles-config .item-piles-config-container .sheet-navigation {
- margin-bottom: 0.5rem;
- padding-bottom: 0.5rem;
- border-bottom: 1px solid var(--color-border-light-primary, #b5b3a4);
-}
-.item-piles-config .item-piles-config-container .item-piles-sections {
- padding: 0.25rem;
- max-height: calc(100% - 51px - 34px);
- overflow-y: scroll;
-}
-.item-piles-config .item-piles-config-container p {
- flex: 0;
- line-height: 14px;
- font-size: var(--font-size-12);
- color: var(--color-text-dark-secondary);
- padding-right: 1rem;
- margin-top: 0;
- overflow-y: hidden;
-}
-.item-piles-config .item-piles-config-container footer {
- margin-top: 0.5rem;
- padding-top: 0.5rem;
- border-top: 1px solid var(--color-border-light-primary, #b5b3a4);
-}
-
-/* ---------------------- CHAT CARDS ---------------------- */
-.item-piles-chat-card {
- padding: 0.5rem;
-}
-.item-piles-chat-card img {
- border: 0;
- vertical-align: middle;
-}
-.item-piles-chat-card .item-piles-chat-card-title i {
- line-height: 1rem;
- font-size: 1.25rem;
- margin: 0 0.5rem;
-}
-.item-piles-chat-card .item-piles-chat-card-title img {
- margin-bottom: 5px;
-}
-.item-piles-chat-card ul {
- display: inline-flex;
- flex-direction: column;
- list-style-type: none;
- padding: 0;
- margin: 0;
- width: 100%;
-}
-.item-piles-chat-card li {
- display: inline-flex;
- flex-direction: row;
- width: 100%;
- margin: 1px 0;
- padding: 3px 4px;
- border-radius: 3px;
- align-items: center;
-}
-.item-piles-chat-card li:nth-child(odd) {
- background-color: var(--color-text-light-highlight, #f0f0e0);
-}
-.item-piles-chat-card li img {
- margin-right: 5px;
- flex: 0;
-}
-.item-piles-chat-card li label {
- flex: 1;
- flex-wrap: wrap;
-}
-.item-piles-chat-card li small {
- min-width: 1rem;
- text-align: right;
- padding-right: 2px;
-}
-
-/* ---------------------- TRADING UI ---------------------- */
-.item-piles-trading-sheet .item-piles-item-row {
- padding: 2px;
-}
-.item-piles-trading-sheet .item-piles-remove-item {
- opacity: 0.5;
-}
-.item-piles-trading-sheet .item-piles-remove-item:hover {
- opacity: 1;
-}
-.item-piles-trading-sheet .item-piles-confirm-quantity {
- display: none;
-}
-.item-piles-trading-sheet .item-piles-quantity-text {
- line-height: 1.6rem;
- font-size: 0.85rem;
- background-color: rgba(255, 255, 255, 0.15);
- border: 1px solid rgba(0, 0, 0, 0.15);
- padding-right: 5px;
- border-radius: 4px;
- margin-left: 10px;
-}
-.item-piles-trading-sheet .item-piles-quantity-text:hover {
- background-color: rgba(255, 255, 255, 0.5);
- border: 1px solid rgba(0, 0, 0, 0.5);
-}
-.item-piles-trading-sheet .item-piles-add-currency {
- flex: 1;
- vertical-align: middle;
- margin-bottom: 5px;
-}
-.item-piles-trading-sheet .item-piles-items-list {
- min-height: 300px;
- max-height: 300px;
-}
-.item-piles-trading-sheet .item-piles-currency-list {
- min-height: unset;
- max-height: unset;
-}
-.item-piles-trading-sheet .item-piles-img-container {
- min-height: 29px;
- max-width: 29px;
- max-height: 29px;
- overflow: hidden;
- border-radius: 4px;
- border: 1px solid black;
-}
-.item-piles-trading-sheet .item-piles-img-container .item-piles-img {
- border: 0;
- width: auto;
- height: 100%;
- transition: transform 250ms;
-}
-.item-piles-trading-sheet .item-piles-img-container .item-piles-img:hover {
- transform: scale(1.25, 1.25);
-}
-.item-piles-trading-sheet .accepted {
- box-shadow: 0 0 40px rgba(0, 255, 0, 0.35) inset, 0 0 10px rgba(0, 255, 0, 0.35);
- transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
-}
-.item-piles-trading-sheet h1, .item-piles-trading-sheet h2 {
- border: 0;
- vertical-align: center;
-}
-.item-piles-trading-sheet .character-header {
- display: inline-flex;
- flex-direction: row;
- flex: 0 1 auto;
- padding: 5px;
-}
-.item-piles-trading-sheet .character-header .character-name {
- padding-top: 0.5rem;
- text-align: center;
- flex: 1;
-}
-.item-piles-trading-sheet .character-header img {
- max-width: 40px;
- max-height: 40px;
- width: auto;
- height: auto;
- border: 0;
- margin-right: auto;
- flex: 0 1 auto;
- border-radius: 5px;
-}
-.item-piles-trading-sheet .character-header.trader img {
- margin-left: auto;
-}
-
-/*# sourceMappingURL=module.css.map */
diff --git a/styles/module.css.map b/styles/module.css.map
deleted file mode 100644
index 3be509a9..00000000
--- a/styles/module.css.map
+++ /dev/null
@@ -1 +0,0 @@
-{"version":3,"sourceRoot":"","sources":["module.scss"],"names":[],"mappings":"AAAA;AAIE;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAEA;EACE;;AAKN;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAKJ;EACE;EACA;EACA;;AAGF;EACE;;AAGF;EACE;;AAEA;EACE;;AAGF;EACE;;AAGF;EACE;;AAIJ;EACE;;AAGF;EACE;EACA;;AAGF;EACE;;AAIA;EACE;;AAGF;EACE;;AAIJ;EACE;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EAEA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;;AAKN;EACE;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;;;AAKJ;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;;AAEA;EACE;EACA;EACA;EACA;;;AAIJ;AAGA;EACE;EACA;;AAEA;EACE;;AAGF;EACE;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAEA;EACE;;AAGF;EACE;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;;AAIJ;EACE;EACA;;AAIJ;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;;;AASJ;EACE;EACA;EACA;;AAGF;EACE;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAIJ;EACE;;AAEA;EACE;EACA;EACA;EACA;;;AAKN;AAEA;EACE;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;;;AAON;AAEA;EACE;;AAEA;EACE;EACA;;AAIA;EACE;EACA;EACA;;AAGF;EACE;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAGF;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;EACA;;;AAKN;AAKE;EACE;;AAGF;EACE;;AAGF;EACE;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;;AAKA;EACE;EACA;EACA;EAEA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;;AASR;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EAEE;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAIA;EACE","file":"module.css"}
\ No newline at end of file
diff --git a/styles/module.scss b/styles/module.scss
deleted file mode 100644
index 172070fb..00000000
--- a/styles/module.scss
+++ /dev/null
@@ -1,522 +0,0 @@
-/* ----------------------- Generic ----------------------- */
-
-.item-piles {
-
- &-player-list-trade-button {
- line-height: inherit;
- font-size: 0.85rem;
- width: calc(100% - 0.5rem);
- margin: 0.25rem;
-
- &.item-piles-minimal-ui {
- padding: 2px 0 0 0;
- text-align: center;
-
- i {
- width: 100%;
- }
- }
- }
-
- &-specate-trade:disabled {
- background-color: rgba(0, 0, 0, 0.25);
- }
-
- &-progress {
- width: calc(100% - 4px);
- background: #e1e4e8;
- border-radius: 3px;
- overflow: hidden;
- margin: 0.25rem 2px 0 2px;
- height: 6px;
-
- .progress-bar {
- display: block;
- height: 100%;
- background-color: rgba(0, 0, 0, 0.65);
- transition: width 30s linear;
- }
- }
-
-
- &-dialog {
- text-align: center;
- font-size: 0.9rem;
- margin-bottom: 1rem;
- }
-
- &-disabled {
- opacity: 0.75;
- }
-
- &-clickable {
- cursor: pointer;
-
- &-red {
- color: red;
- }
-
- &-green {
- color: green;
- }
-
- &-green:hover {
- text-shadow: 0 0 8px rgba(0, 125, 0, 1);
- }
- }
-
- &-moveable {
- cursor: move;
- }
-
- &-highlight {
- color: var(--color-text-hyperlink, #ff6400);
- text-decoration: underline;
- }
-
- &-grow {
- flex-grow: 1;
- }
-
- &-text {
- &-right {
- text-align: right;
- }
-
- &-center {
- text-align: center;
- }
- }
-
- &-small-text {
- font-size: 0.75rem;
- }
-
- &-middle {
- vertical-align: middle;
- }
-
- &-img-container {
- min-height: 37px;
- max-width: 37px;
- max-height: 37px;
-
- overflow: hidden;
- border-radius: 4px;
- border: 1px solid black;
-
- .item-piles-img {
- border: 0;
- width: auto;
- height: 100%;
- transition: transform 150ms;
-
- &:hover {
- transform: scale(1.125, 1.125);
- }
- }
- }
-
- &-odd-color:nth-child(even) {
- background-color: var(--color-text-light-highlight, #f0f0e0);
- }
-
- &-bottom-divider {
- border-bottom: 1px solid rgba(0, 0, 0, 0.35);
- margin-bottom: 0.5rem;
- padding-bottom: 0.5rem;
- }
-
- &-top-divider {
- border-top: 1px solid rgba(0, 0, 0, 0.35);
- margin-top: 0.5rem;
- padding-top: 0.5rem;
- }
-
- &-disabled {
- background-color: var(--color-bg-btn-minor-inactive, #c9c7b8)
- }
-
-}
-
-.item-piles-slider-group {
- padding: 0 5px 0 0;
- margin-bottom: 0.25rem;
- margin-right: 5px;
- border-radius: 4px;
-}
-
-#item-piles-preview-container {
- position: absolute;
- display: none;
-
- #item-piles-preview-image {
- border: 0;
- width: 300px;
- border-radius: 1rem;
- box-shadow: rgba(0, 0, 0, 0.25) 0px 54px 55px, rgba(0, 0, 0, 0.12) 0px -12px 30px, rgba(0, 0, 0, 0.12) 0px 4px 6px, rgba(0, 0, 0, 0.17) 0px 12px 13px, rgba(0, 0, 0, 0.09) 0px -3px 5px;
- }
-}
-
-/* ----------------------- INVENTORY ----------------------- */
-
-
-.item-piles-items-list {
- max-height: 500px;
- overflow-y: scroll;
-
- .item-piles-change-actor-select {
- display: none;
- }
-
- #item-piles-preview-container {
- position: absolute;
- display: none;
- }
-
- .item-piles-add-currency {
- margin-right: 5px;
- flex: 0 1 auto;
- vertical-align: middle;
- }
-
- .item-piles-item-row {
- padding: 0 5px 0 0;
- margin-bottom: 0.25rem;
- margin-right: 5px;
- border-radius: 4px;
-
- &:nth-child(even):not(.item-piles-disabled) {
- background-color: var(--color-text-light-highlight, #f0f0e0);
- }
-
- .item-piles-disabled {
- background-color: var(--color-bg-btn-minor-inactive, #c9c7b8)
- }
-
- div {
- display: inline-flex;
- flex-direction: column;
- justify-content: center;
- }
-
- .item-piles-text {
- line-height: 1.6rem;
- font-size: 1rem;
- text-wrap: normal;
- flex: 0 1 auto;
- }
-
- .item-piles-name {
- padding: 0 0.5rem;
- flex: 4;
- display: inline-flex;
- flex-direction: column;
-
- .item-piles-name-container {
- flex: 1;
- display: inline-flex;
- flex-direction: column;
- justify-content: center;
-
- a {
- max-width: fit-content;
- }
- }
-
- span {
- line-height: 1;
- flex: 0;
- }
- }
-
- .item-piles-quantity {
- flex: 1;
- margin-left: 0.5rem;
- text-align: right;
- }
-
- .item-piles-input-divider {
- flex: 1;
- margin: 0.1rem 0.5rem 0 0.25rem;
- font-size: 0.8rem;
- line-height: 1.5rem;
- }
-
- .item-piles-item-take-button, .item-piles-currency-take-button {
- flex: 0;
- min-width: 4rem;
- height: 26px;
- padding: 1px 3px;
- line-height: inherit;
- }
-
- }
-
-}
-
-.item-piles-collapsible {
-
- &:not(:last-child) {
- margin-bottom: 0.75rem;
- padding-bottom: 0.75rem;
- border-bottom: 1px solid var(--color-border-light-primary, #b5b3a4);
- }
-
- & > summary {
- display: block;
- font-weight: 900;
-
- &::before {
- font-family: "Font Awesome 5 Free";
- font-weight: 900;
- content: "\f054";
- margin-right: 0.5rem;
- }
- }
-
- &[open] > summary {
- margin-bottom: 0.5rem;
-
- &::before {
- font-family: "Font Awesome 5 Free";
- font-weight: 900;
- content: "\f078";
- margin-right: 0.275rem;
- }
- }
-}
-
-/* ----------------------- CONFIG ----------------------- */
-
-.item-piles-config {
- width: 430px;
-
- .item-piles-config-container {
- display: flex;
- flex-direction: column;
- justify-content: flex-start;
- overflow: hidden;
-
- .sheet-navigation {
- margin-bottom: 0.5rem;
- padding-bottom: 0.5rem;
- border-bottom: 1px solid var(--color-border-light-primary, #b5b3a4);
- }
-
- .item-piles-sections {
- padding: 0.25rem;
- max-height: calc(100% - 51px - 34px);
- overflow-y: scroll;
- }
-
- p {
- flex: 0;
- line-height: 14px;
- font-size: var(--font-size-12);
- color: var(--color-text-dark-secondary);
- padding-right: 1rem;
- margin-top: 0;
- overflow-y: hidden;
- }
-
- footer {
- margin-top: 0.5rem;
- padding-top: 0.5rem;
- border-top: 1px solid var(--color-border-light-primary, #b5b3a4);
- }
-
- }
-
-}
-
-/* ---------------------- CHAT CARDS ---------------------- */
-
-.item-piles-chat-card {
- padding: 0.5rem;
-
- img {
- border: 0;
- vertical-align: middle;
- }
-
- .item-piles-chat-card-title {
- i {
- line-height: 1rem;
- font-size: 1.25rem;
- margin: 0 0.5rem;
- }
-
- img {
- margin-bottom: 5px;
- }
- }
-
- ul {
- display: inline-flex;
- flex-direction: column;
- list-style-type: none;
- padding: 0;
- margin: 0;
- width: 100%;
- }
-
- li {
- display: inline-flex;
- flex-direction: row;
- width: 100%;
- margin: 1px 0;
- padding: 3px 4px;
- border-radius: 3px;
- align-items: center;
-
- &:nth-child(odd) {
- background-color: var(--color-text-light-highlight, #f0f0e0);
- }
-
- img {
- margin-right: 5px;
- flex: 0;
- }
-
- label {
- flex: 1;
- flex-wrap: wrap;
- }
-
- small {
- min-width: 1rem;
- text-align: right;
- padding-right: 2px;
- }
- }
-}
-
-/* ---------------------- TRADING UI ---------------------- */
-
-
-.item-piles-trading-sheet {
-
- .item-piles-item-row {
- padding: 2px;
- }
-
- .item-piles-remove-item {
- opacity: 0.5;
- }
-
- .item-piles-remove-item:hover {
- opacity: 1;
- }
-
- .item-piles-confirm-quantity {
- display: none;
- }
-
- .item-piles-quantity-text {
- line-height: 1.6rem;
- font-size: 0.85rem;
- background-color: rgba(255, 255, 255, 0.15);
- border: 1px solid rgba(0, 0, 0, 0.15);
- padding-right: 5px;
- border-radius: 4px;
- margin-left: 10px;
- }
-
- .item-piles-quantity-text:hover {
- background-color: rgba(255, 255, 255, 0.5);
- border: 1px solid rgba(0, 0, 0, 0.5);
- }
-
- .item-piles-add-currency {
- flex: 1;
- vertical-align: middle;
- margin-bottom: 5px;
- }
-
- .item-piles-items-list {
- min-height: 300px;
- max-height: 300px;
- }
-
- .item-piles-currency-list {
- min-height: unset;
- max-height: unset;
- }
-
- .item-piles {
-
- &-img-container {
- min-height: 29px;
- max-width: 29px;
- max-height: 29px;
-
- overflow: hidden;
- border-radius: 4px;
- border: 1px solid black;
-
- .item-piles-img {
- border: 0;
- width: auto;
- height: 100%;
- transition: transform 250ms;
-
- &:hover {
- transform: scale(1.25, 1.25);
- }
- }
-
-
- }
-
- }
-
- .accepted {
- box-shadow: 0 0 40px rgba(0, 255, 0, 0.35) inset, 0 0 10px rgba(0, 255, 0, 0.35);
- transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
- }
-
- h1, h2 {
- border: 0;
- vertical-align: center;
- }
-
- .character-header {
-
- display: inline-flex;
- flex-direction: row;
- flex: 0 1 auto;
- padding: 5px;
-
- .character-name {
- padding-top: 0.5rem;
- text-align: center;
- flex: 1;
- }
-
- img {
- max-width: 40px;
- max-height: 40px;
- width: auto;
- height: auto;
- border: 0;
- margin-right: auto;
- flex: 0 1 auto;
- border-radius: 5px;
- }
-
- &.trader {
- img {
- margin-left: auto;
- }
- }
-
- }
-
-}
-
-
-
-
-
-
diff --git a/templates/loot-chat-message.html b/templates/chat/looted.html
similarity index 100%
rename from templates/loot-chat-message.html
rename to templates/chat/looted.html
diff --git a/templates/chat/merchant-traded.html b/templates/chat/merchant-traded.html
new file mode 100644
index 00000000..30ac37af
--- /dev/null
+++ b/templates/chat/merchant-traded.html
@@ -0,0 +1,21 @@
+
+
+
+
+
+
+
+
{{message}}
+
+
+
+ {{#each items as |item id|}}
+
+
+ {{item.name}}
+ {{item.quantity}}
+
+ {{/each}}
+
+
+
diff --git a/templates/trade-complete-chat-message.html b/templates/chat/trade-complete.html
similarity index 100%
rename from templates/trade-complete-chat-message.html
rename to templates/chat/trade-complete.html
diff --git a/templates/trade-started-chat-message.html b/templates/chat/trade-started.html
similarity index 100%
rename from templates/trade-started-chat-message.html
rename to templates/chat/trade-started.html
diff --git a/templates/currencies-editor.html b/templates/currencies-editor.html
deleted file mode 100644
index 0ea50cc5..00000000
--- a/templates/currencies-editor.html
+++ /dev/null
@@ -1,51 +0,0 @@
-
-
-
-
- {{localize "ITEM-PILES.CurrenciesEditor.Explanation"}}
-
-
-
-
{{localize "ITEM-PILES.CurrenciesEditor.Name"}}
-
{{localize "ITEM-PILES.CurrenciesEditor.Path"}}
-
{{localize "ITEM-PILES.CurrenciesEditor.Icon"}}
-
Add
-
-
-
- {{#each currencies as |currency id|}}
-
-
-
-
- {{filePicker target=(concat id ".img") type="imagevideo"}}
-
-
-
-
-
-
- {{/each}}
-
-
-
-
-
-
\ No newline at end of file
diff --git a/templates/drop-currency-dialog.html b/templates/drop-currency-dialog.html
deleted file mode 100644
index 1a3e4d41..00000000
--- a/templates/drop-currency-dialog.html
+++ /dev/null
@@ -1,41 +0,0 @@
-
-
-
- {{ content }}
-
-
- {{#each currencies as |currency id|}}
-
- {{/each}}
-
- {{#unless currencies.length}}
-
- {{localize "ITEM-PILES.DropCurrencies.NoCurrency" actor_name=source.name}}
-
- {{/unless}}
-
-
-
-
diff --git a/templates/drop-item-dialog.html b/templates/drop-item-dialog.html
deleted file mode 100644
index b2f8fdc2..00000000
--- a/templates/drop-item-dialog.html
+++ /dev/null
@@ -1,34 +0,0 @@
-
-
- {{localize "ITEM-PILES.DropItem.Dropping"}}: {{droppedItem.name}}
-
- {{#if itemPileAtLocation}}
-
- {{localize "ITEM-PILES.DropItem.ExistingPiles" item_pile_name=itemPile.name}}
-
- {{/if}}
-
- {{#if itemQuantityMoreThanOne}}
-
-
- {{localize "ITEM-PILES.DropItem.QuantityToDrop" quantity=itemQuantity itemName=droppedItem.name}}
-
-
-
-
-
-
- {{else}}
-
- {{/if}}
-
-
-
-
diff --git a/templates/filter-editor.html b/templates/filter-editor.html
deleted file mode 100644
index 45e09fcc..00000000
--- a/templates/filter-editor.html
+++ /dev/null
@@ -1,40 +0,0 @@
-
-
-
-
- {{localize "ITEM-PILES.FilterEditor.Explanation"}}
-
-
-
-
-
{{localize "ITEM-PILES.FilterEditor.Path"}}
-
{{localize "ITEM-PILES.FilterEditor.Filters"}}
-
- {{#each filters as |filter id|}}
-
- {{/each}}
-
{{localize "ITEM-PILES.FilterEditor.AddNew"}}
-
-
-
-
\ No newline at end of file
diff --git a/templates/item-pile-config.html b/templates/item-pile-config.html
deleted file mode 100644
index 45687e8e..00000000
--- a/templates/item-pile-config.html
+++ /dev/null
@@ -1,274 +0,0 @@
-
-
-
- {{localize "ITEM-PILES.Defaults.Main.Title"}}
- {{localize "ITEM-PILES.Defaults.Other.Title"}}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {{localize "ITEM-PILES.Defaults.Main.ConfigureOverrideCurrencies"}}
-
-
-
-
-
- {{localize "ITEM-PILES.Defaults.Main.ConfigureOverrideItemFilters"}}
-
-
-
-
-
-
-
-
- {{ localize "ITEM-PILES.Defaults.SingleItem.Title"}}
-
- {{localize "ITEM-PILES.Defaults.SingleItem.DisplayOneContainerWarning"}}
-
-
-
-
-
-
-
-
-
- {{ localize "ITEM-PILES.Defaults.Container.Title"}}
-
-
- {{localize "ITEM-PILES.Defaults.Container.IsContainer"}}
-
-
-
-
-
-
- {{localize "ITEM-PILES.Defaults.Container.Closed"}}
-
-
-
-
- {{localize "ITEM-PILES.Defaults.Container.Locked"}}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {{ localize "ITEM-PILES.Defaults.Sharing.Title"}}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {{localize "ITEM-PILES.Defaults.Sharing.ResetSharingData"}}
-
-
-
-
-
-
-
-
-
-
-
diff --git a/templates/item-pile-inventory.html b/templates/item-pile-inventory.html
deleted file mode 100644
index 74bcad20..00000000
--- a/templates/item-pile-inventory.html
+++ /dev/null
@@ -1,161 +0,0 @@
-
-
-
-
- {{#if isDeleted}}
-
-
{{localize "ITEM-PILES.Inspect.Destroyed"}}
-
- {{else}}
-
- {{#if editQuantities}}
-
{{localize "ITEM-PILES.Inspect.Owner"}}
- {{else}}
-
- {{{ localize "ITEM-PILES.Inspect.AsActor" actorName=recipient.name }}}
-
- {{#select recipient.uuid}}
- {{#each playerActors as |actor id|}}
- {{actor.name}}
- {{/each}}
- {{/select}}
-
-
- {{/if}}
-
-
-
- {{#if isEmpty}}
-
{{localize "ITEM-PILES.Inspect.Empty"}}
- {{/if}}
-
-
-
-
-
-
-
- {{#if hasItems}}
-
{{localize "ITEM-PILES.Items"}}:
- {{/if}}
- {{#each items as |item id|}}
-
-
-
-
-
-
- {{#unless @root.editQuantities}}
x{{item.quantity}} {{/unless}}
-
-
-
- {{#if @root.editQuantities}}
-
-
-
- {{else}}
- {{#if item.shareLeft}}
-
-
-
-
- / {{item.shareLeft}}
-
-
- {{else}}
- {{#if @root.shareItemsEnabled}}
-
{{localize "ITEM-PILES.Inspect.NoShareLeft"}}
- {{else}}
-
{{localize "ITEM-PILES.Inspect.NoneLeft"}}
- {{/if}}
- {{/if}}
- {{/if}}
-
-
- {{#unless @root.editQuantities}}
-
- {{localize "ITEM-PILES.Inspect.Take"}}
-
- {{/unless}}
-
-
- {{/each}}
-
- {{#if systemHasCurrencies}}
-
-
-
- {{#each currencies as |currency id|}}
-
-
-
-
-
-
{{currency.name}}
- {{#unless @root.editQuantities}}
x{{currency.quantity}} {{/unless}}
-
-
-
- {{#if @root.editQuantities}}
-
-
-
- {{else}}
- {{#if currency.shareLeft}}
-
-
-
- / {{currency.shareLeft}}
-
- {{else}}
- {{#if @root.shareCurrenciesEnabled}}
-
{{localize "ITEM-PILES.Inspect.NoShareLeft"}}
- {{else}}
-
{{localize "ITEM-PILES.Inspect.NoneLeft"}}
- {{/if}}
- {{/if}}
- {{/if}}
-
-
- {{#unless @root.editQuantities}}
-
- {{localize "ITEM-PILES.Inspect.Take"}}
-
- {{/unless}}
-
-
- {{/each}}
- {{/if}}
-
-
-
- {{/if}}
-
-
-
-
-
-
diff --git a/templates/similarities-editor.html b/templates/similarities-editor.html
deleted file mode 100644
index af3135dc..00000000
--- a/templates/similarities-editor.html
+++ /dev/null
@@ -1,36 +0,0 @@
-
-
-
-
- {{localize "ITEM-PILES.SimilaritiesEditor.Explanation_P1"}}
- {{localize "ITEM-PILES.SimilaritiesEditor.Explanation_P2"}}
-
-
-
- {{#each similarities as |path id|}}
-
- {{/each}}
-
{{localize "ITEM-PILES.SimilaritiesEditor.AddNew"}}
-
-
-
-
\ No newline at end of file
diff --git a/templates/text-editor.html b/templates/text-editor.html
new file mode 100644
index 00000000..a8a038b4
--- /dev/null
+++ b/templates/text-editor.html
@@ -0,0 +1,13 @@
+
+
+ {{editor content=text target="text" button=true owner=true
+ editable=true}}
+
+
+
+
\ No newline at end of file
diff --git a/templates/trade-dialog.html b/templates/trade-dialog.html
deleted file mode 100644
index a813c775..00000000
--- a/templates/trade-dialog.html
+++ /dev/null
@@ -1,151 +0,0 @@
-
-
-
-
-
-
-
- {{#if isPrompt}}
- {{localize "ITEM-PILES.Trade.Prompt.Title"}}
- {{else}}
- {{localize "ITEM-PILES.Trade.Request.Title"}}
- {{/if}}
-
-
- {{#if isPrompt}}
-
- {{#if isPrivate}}
-
{{{localize "ITEM-PILES.Trade.Prompt.PrivateContent" trading_user_name=tradingUser.name trading_actor_name=tradingActor.name}}}
- {{else}}
-
{{{localize "ITEM-PILES.Trade.Prompt.Content" trading_user_name=tradingUser.name trading_actor_name=tradingActor.name}}}
- {{/if}}
-
{{localize "ITEM-PILES.Trade.Prompt.AcceptQuery"}}
-
-
- {{else}}
-
- {{localize "ITEM-PILES.Trade.Request.User"}}
-
-
-
- User:
- {{#select user.id}}
-
- {{#each users as |user id|}}
- {{user.name}}
- {{/each}}
-
- {{/select}}
-
-
-
-
-
-
- {{localize "ITEM-PILES.Trade.Private"}}
-
- {{ localize "ITEM-PILES.Trade.PrivateExplanation"}}
-
-
-
- {{/if}}
-
- {{#if actor}}
- {{localize "ITEM-PILES.Trade.Request.PickedActor"}}
- {{else}}
- {{localize "ITEM-PILES.Trade.Request.PickActor"}}
- {{/if}}
-
-
-
- {{#if hasUnlinkedTokenOwnership}}
-
- {{ localize "ITEM-PILES.Trade.Request.PickToken" }}
-
- {{/if}}
-
-
-
-
- {{#if isPrompt}}
-
-
-
- {{/if}}
-
-
\ No newline at end of file
diff --git a/templates/trading-app-spectate.html b/templates/trading-app-spectate.html
deleted file mode 100644
index 6b1b1e4f..00000000
--- a/templates/trading-app-spectate.html
+++ /dev/null
@@ -1,157 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {{#each leftActor.items as |item id|}}
-
-
-
-
-
-
-
-
- {{item.quantity}}
-
-
-
- {{/each}}
-
-
-
-
-
-
-
-
- {{#each leftActor.currencies as |currency id|}}
-
-
-
-
-
-
-
-
- {{currency.quantity}}
-
-
-
- {{/each}}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {{#each rightActor.items as |item id|}}
-
-
-
-
-
-
-
-
- {{item.quantity}}
-
-
-
- {{/each}}
-
-
-
-
-
-
-
-
- {{#each rightActor.currencies as |currency id|}}
-
-
-
-
-
-
-
-
- {{currency.quantity}}
-
-
-
- {{/each}}
-
-
-
-
-
-
-
-
-
diff --git a/templates/trading-app.html b/templates/trading-app.html
deleted file mode 100644
index 3ffa2001..00000000
--- a/templates/trading-app.html
+++ /dev/null
@@ -1,208 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {{#unless leftActor.hasItems}}
-
-
{{ localize "ITEM-PILES.Trade.DragDrop" }}
-
- {{/unless}}
-
- {{#each leftActor.items as |item id|}}
-
-
-
-
-
-
-
-
-
-
-
-
-
{{item.quantity}}
-
-
-
-
-
-
- {{/each}}
-
-
-
- {{#if systemHasCurrencies}}
-
-
-
-
-
- {{#each leftActor.currencies as |currency id|}}
-
-
-
-
-
-
-
-
-
-
-
-
-
{{currency.quantity}}
-
-
-
-
-
-
- {{/each}}
-
-
-
- {{/if}}
-
-
-
- {{#if leftActor.accepted}}
-
{{localize "Cancel"}}
- {{else}}
-
{{localize "ITEM-PILES.Trade.Accept"}}
- {{/if}}
-
-
-
-
-
-
-
-
-
-
-
-
- {{#each rightActor.items as |item id|}}
-
-
-
-
-
-
-
-
- {{item.quantity}}
-
-
-
- {{/each}}
-
-
-
- {{#if systemHasCurrencies}}
-
-
-
- {{#if rightActor.currencies.length}}
-
- {{/if}}
-
- {{#each rightActor.currencies as |currency id|}}
-
-
-
-
-
-
-
-
- {{currency.quantity}}
-
-
-
- {{/each}}
-
-
-
- {{/if}}
-
-
-
-
-
-
-
diff --git a/vite.config.mjs b/vite.config.mjs
new file mode 100644
index 00000000..4d9657b8
--- /dev/null
+++ b/vite.config.mjs
@@ -0,0 +1,102 @@
+import { svelte } from '@sveltejs/vite-plugin-svelte';
+import resolve from '@rollup/plugin-node-resolve'; // This resolves NPM modules from node_modules.
+import preprocess from 'svelte-preprocess';
+import {
+ postcssConfig,
+ terserConfig,
+ typhonjsRuntime
+} from '@typhonjs-fvtt/runtime/rollup';
+
+const s_COMPRESS = false; // Set to true to compress the module bundle.
+const s_SOURCEMAPS = true; // Generate sourcemaps for the bundle (recommended).
+
+// EXPERIMENTAL: Set to true to enable linking against the TyphonJS Runtime Library module.
+// You must add a Foundry module dependency on the `typhonjs` Foundry package or manually install it in Foundry from:
+// https://github.com/typhonjs-fvtt-lib/typhonjs/releases/latest/download/module.json
+const s_TYPHONJS_MODULE_LIB = false;
+
+// Used in bundling.
+const s_RESOLVE_CONFIG = {
+ browser: true,
+ dedupe: ['svelte']
+};
+
+// ATTENTION!
+// You must change `base` and the `proxy` strings replacing `/modules/item-piles/` with your
+// module or system ID.
+
+export default () => {
+ /** @type {import('vite').UserConfig} */
+ return {
+ root: 'src/', // Source location / esbuild root.
+ base: '/modules/item-piles/', // Base module path that 30001 / served dev directory.
+ publicDir: false, // No public resources to copy.
+ cacheDir: '../.vite-cache', // Relative from root directory.
+
+ resolve: { conditions: ['import', 'browser'] },
+
+ esbuild: {
+ target: ['es2022', 'chrome100'],
+ keepNames: true // Note: doesn't seem to work.
+ },
+
+ css: {
+ // Creates a standard configuration for PostCSS with autoprefixer & postcss-preset-env.
+ postcss: postcssConfig({ compress: s_COMPRESS, sourceMap: s_SOURCEMAPS })
+ },
+
+ // About server options:
+ // - Set to `open` to boolean `false` to not open a browser window automatically. This is useful if you set up a
+ // debugger instance in your IDE and launch it with the URL: 'http://localhost:30001/game'.
+ //
+ // - The top proxy entry for `lang` will pull the language resources from the main Foundry / 30000 server. This
+ // is necessary to reference the dev resources as the root is `/src` and there is no public / static resources
+ // served.
+ server: {
+ port: 29999,
+ open: false,
+ proxy: {
+ '^(/modules/item-piles/languages)': 'http://127.0.0.1:30000',
+ '^(?!/modules/item-piles/)': 'http://127.0.0.1:30000',
+ '/socket.io': { target: 'ws://127.0.0.1:30000', ws: true }
+ }
+ },
+
+ build: {
+ outDir: __dirname,
+ emptyOutDir: false,
+ sourcemap: s_SOURCEMAPS,
+ brotliSize: true,
+ minify: s_COMPRESS ? 'terser' : false,
+ target: ['es2022', 'chrome100'],
+ terserOptions: s_COMPRESS ? { ...terserConfig(), ecma: 2022 } : void 0,
+ lib: {
+ entry: './module.js',
+ formats: ['es'],
+ fileName: 'module'
+ }
+ },
+
+ plugins: [
+ svelte({
+ preprocess: preprocess(),
+ onwarn: (warning, handler) => {
+ // Suppress `a11y-missing-attribute` for missing href in links.
+ // Foundry doesn't follow accessibility rules.
+ if (warning.message.includes(` element should have an href attribute`)) {
+ return;
+ }
+
+ // Let Rollup handle all other warnings normally.
+ handler(warning);
+ },
+ }),
+
+ resolve(s_RESOLVE_CONFIG), // Necessary when bundling npm-linked packages.
+
+ // When s_TYPHONJS_MODULE_LIB is true transpile against the Foundry module version of TRL.
+ s_TYPHONJS_MODULE_LIB && typhonjsRuntime()
+ ]
+ };
+};
+