@rpg-engine/long-bow 0.8.9 → 0.8.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,6 +3,9 @@ import { IItem } from '@rpg-engine/shared';
3
3
  interface IProps {
4
4
  item: IItem;
5
5
  }
6
+ export declare const gemColors: {
7
+ [key: string]: string;
8
+ };
6
9
  export declare const onRenderGems: (item: IItem) => JSX.Element | undefined;
7
10
  export declare const ItemSlotQty: ({ item }: IProps) => JSX.Element;
8
11
  export default ItemSlotQty;
@@ -0,0 +1,11 @@
1
+ import { IGemSchema, IItem } from '@rpg-engine/shared';
2
+ import React from 'react';
3
+ export interface IGemSelectorProps {
4
+ atlasJSON: any;
5
+ atlasIMG: any;
6
+ item: IItem;
7
+ scale?: number;
8
+ onClose: () => void;
9
+ onSelect: (selectedGems: IGemSchema[]) => void;
10
+ }
11
+ export declare const GemSelector: React.FC<IGemSelectorProps>;
package/dist/index.d.ts CHANGED
@@ -25,6 +25,7 @@ export * from './components/Item/Inventory/ItemContainer';
25
25
  export * from './components/Item/Inventory/ItemPropertySimpleHandler';
26
26
  export * from './components/Item/Inventory/ItemQuantitySelectorModal';
27
27
  export * from './components/Item/Inventory/ItemSlot';
28
+ export * from './components/itemSelector/GemSelector';
28
29
  export * from './components/itemSelector/ItemSelector';
29
30
  export * from './components/Leaderboard/Leaderboard';
30
31
  export * from './components/ListMenu';
@@ -27819,6 +27819,12 @@ var generateContextMenu = function generateContextMenu(item, itemContainerType,
27819
27819
  }
27820
27820
  }
27821
27821
  }
27822
+ if (item.attachedGems && item.attachedGems.length > 0) {
27823
+ contextActionMenu.push({
27824
+ id: shared.ItemSocketEvents.DetachGem,
27825
+ text: "Detach Gems"
27826
+ });
27827
+ }
27822
27828
  return contextActionMenu;
27823
27829
  };
27824
27830
 
@@ -31181,7 +31187,7 @@ var ItemContainer$1 = /*#__PURE__*/React__default.memo(function (_ref) {
31181
31187
  onItemDragEnd = _ref.onItemDragEnd,
31182
31188
  onItemDragStart = _ref.onItemDragStart,
31183
31189
  onItemPlaceDrop = _ref.onItemPlaceDrop,
31184
- _onOutsideDrop = _ref.onOutsideDrop,
31190
+ onOutsideDrop = _ref.onOutsideDrop,
31185
31191
  checkIfItemCanBeMoved = _ref.checkIfItemCanBeMoved,
31186
31192
  initialPosition = _ref.initialPosition,
31187
31193
  checkIfItemShouldDragEnd = _ref.checkIfItemShouldDragEnd,
@@ -31246,12 +31252,49 @@ var ItemContainer$1 = /*#__PURE__*/React__default.memo(function (_ref) {
31246
31252
  }
31247
31253
  onDragEndScrollingEvents();
31248
31254
  }, [onItemDragEnd, onDragEndScrollingEvents]);
31249
- // Memoize handleSetShortcut to prevent unnecessary re-renders
31250
- var memoizedHandleSetShortcut = React.useCallback(function (item, index) {
31251
- handleSetShortcut(item, index);
31252
- }, [handleSetShortcut]);
31253
- // Memoize onRenderSlots to prevent re-creating the slots array on every render
31254
- var onRenderSlots = React.useMemo(function () {
31255
+ var handleItemClick = React.useCallback(function (itemType, containerType, item) {
31256
+ if (settingShortcutIndex !== -1) {
31257
+ setSettingShortcutIndex(-1);
31258
+ handleSetShortcut(item, settingShortcutIndex);
31259
+ } else if (onItemClick) {
31260
+ onItemClick(item, itemType, containerType);
31261
+ }
31262
+ }, [settingShortcutIndex, handleSetShortcut, onItemClick]);
31263
+ var handlePlaceDrop = React.useCallback(function (item, slotIndex, itemContainerType) {
31264
+ if (onItemPlaceDrop) {
31265
+ onItemPlaceDrop(item, slotIndex, itemContainerType);
31266
+ }
31267
+ onDragEndScrollingEvents();
31268
+ }, [onItemPlaceDrop, onDragEndScrollingEvents]);
31269
+ var handleOutsideDrop = React.useCallback(function (item, position) {
31270
+ if (onOutsideDrop) {
31271
+ onOutsideDrop(item, position);
31272
+ }
31273
+ onDragEndScrollingEvents();
31274
+ }, [onOutsideDrop, onDragEndScrollingEvents]);
31275
+ var handleQuantitySelect = React.useCallback(function (maxQuantity, callback) {
31276
+ setQuantitySelect({
31277
+ isOpen: true,
31278
+ maxQuantity: maxQuantity,
31279
+ callback: callback
31280
+ });
31281
+ }, []);
31282
+ // Memoize slot rendering configuration
31283
+ var slotConfig = React.useMemo(function () {
31284
+ return {
31285
+ type: type,
31286
+ atlasIMG: atlasIMG,
31287
+ atlasJSON: atlasJSON,
31288
+ scale: scale,
31289
+ equipmentSet: equipmentSet,
31290
+ isDepotSystem: isDepotSystem,
31291
+ isSelectingShortcut: settingShortcutIndex !== -1,
31292
+ checkIfItemCanBeMoved: checkIfItemCanBeMoved,
31293
+ checkIfItemShouldDragEnd: checkIfItemShouldDragEnd
31294
+ };
31295
+ }, [type, atlasIMG, atlasJSON, scale, equipmentSet, isDepotSystem, settingShortcutIndex, checkIfItemCanBeMoved, checkIfItemShouldDragEnd]);
31296
+ // Memoize slots rendering
31297
+ var renderSlots = React.useMemo(function () {
31255
31298
  var slots = [];
31256
31299
  for (var i = 0; i < itemContainer.slotQty; i++) {
31257
31300
  var _itemContainer$slots;
@@ -31260,55 +31303,27 @@ var ItemContainer$1 = /*#__PURE__*/React__default.memo(function (_ref) {
31260
31303
  key: i,
31261
31304
  slotIndex: i,
31262
31305
  item: currentItem,
31263
- itemContainerType: type,
31264
- onMouseOver: onMouseOver ? function (event, slotIndex, item) {
31265
- return onMouseOver(event, slotIndex, item);
31266
- } : undefined,
31267
- onMouseOut: undefined,
31268
- onPointerDown: function onPointerDown(itemType, containerType, item) {
31269
- if (settingShortcutIndex !== -1) {
31270
- setSettingShortcutIndex(-1);
31271
- memoizedHandleSetShortcut(item, settingShortcutIndex);
31272
- } else if (onItemClick) {
31273
- onItemClick(item, itemType, containerType);
31274
- }
31275
- },
31306
+ itemContainerType: slotConfig.type,
31307
+ onMouseOver: onMouseOver,
31308
+ onPointerDown: handleItemClick,
31276
31309
  onDragStart: onDragStartHandler,
31277
31310
  onDragEnd: onDragEndHandler,
31278
- dragScale: scale,
31279
- checkIfItemCanBeMoved: checkIfItemCanBeMoved,
31280
- checkIfItemShouldDragEnd: checkIfItemShouldDragEnd,
31281
- openQuantitySelector: function openQuantitySelector(maxQuantity, callback) {
31282
- setQuantitySelect({
31283
- isOpen: true,
31284
- maxQuantity: maxQuantity,
31285
- callback: callback
31286
- });
31287
- },
31288
- onPlaceDrop: function onPlaceDrop(item, slotIndex, itemContainerType) {
31289
- if (onItemPlaceDrop) {
31290
- onItemPlaceDrop(item, slotIndex, itemContainerType);
31291
- }
31292
- console.log('PLACE DROP');
31293
- onDragEndScrollingEvents();
31294
- },
31295
- onOutsideDrop: function onOutsideDrop(item, position) {
31296
- if (_onOutsideDrop) {
31297
- _onOutsideDrop(item, position);
31298
- }
31299
- console.log('OUTSIDE DROP');
31300
- onDragEndScrollingEvents();
31301
- },
31302
- atlasIMG: atlasIMG,
31303
- atlasJSON: atlasJSON,
31304
- isSelectingShortcut: settingShortcutIndex !== -1,
31305
- equipmentSet: equipmentSet,
31306
- setItemShortcut: type === shared.ItemContainerType.Inventory ? memoizedHandleSetShortcut : undefined,
31307
- isDepotSystem: isDepotSystem
31311
+ dragScale: slotConfig.scale,
31312
+ checkIfItemCanBeMoved: slotConfig.checkIfItemCanBeMoved,
31313
+ checkIfItemShouldDragEnd: slotConfig.checkIfItemShouldDragEnd,
31314
+ openQuantitySelector: handleQuantitySelect,
31315
+ onPlaceDrop: handlePlaceDrop,
31316
+ onOutsideDrop: handleOutsideDrop,
31317
+ atlasIMG: slotConfig.atlasIMG,
31318
+ atlasJSON: slotConfig.atlasJSON,
31319
+ isSelectingShortcut: slotConfig.isSelectingShortcut,
31320
+ equipmentSet: slotConfig.equipmentSet,
31321
+ setItemShortcut: type === shared.ItemContainerType.Inventory ? handleSetShortcut : undefined,
31322
+ isDepotSystem: slotConfig.isDepotSystem
31308
31323
  }));
31309
31324
  }
31310
31325
  return slots;
31311
- }, [itemContainer.slotQty, itemContainer.slots, type, onMouseOver, settingShortcutIndex, memoizedHandleSetShortcut, onItemClick, onDragStartHandler, onDragEndHandler, scale, checkIfItemCanBeMoved, checkIfItemShouldDragEnd, onItemPlaceDrop, _onOutsideDrop, atlasIMG, atlasJSON, equipmentSet, isDepotSystem, onDragEndScrollingEvents]);
31326
+ }, [itemContainer.slotQty, itemContainer.slots, slotConfig, onMouseOver, handleItemClick, onDragStartHandler, onDragEndHandler, handleQuantitySelect, handlePlaceDrop, handleOutsideDrop, handleSetShortcut, type]);
31312
31327
  return React__default.createElement(ItemSlotDraggingProvider, null, React__default.createElement(ItemSlotDetailsProvider, null, React__default.createElement(DraggedItem, {
31313
31328
  atlasIMG: atlasIMG,
31314
31329
  atlasJSON: atlasJSON,
@@ -31334,7 +31349,7 @@ var ItemContainer$1 = /*#__PURE__*/React__default.memo(function (_ref) {
31334
31349
  ref: containerRef,
31335
31350
  isScrollable: itemContainer.slotQty > MIN_SLOTS_FOR_SCROLL,
31336
31351
  isFullScreen: isFullScreen
31337
- }, onRenderSlots)), quantitySelect.isOpen && React__default.createElement(ItemQuantitySelectorModal, {
31352
+ }, renderSlots)), quantitySelect.isOpen && React__default.createElement(ItemQuantitySelectorModal, {
31338
31353
  quantitySelect: quantitySelect,
31339
31354
  setQuantitySelect: setQuantitySelect
31340
31355
  }), React__default.createElement(ItemSlotToolTips, {
@@ -31427,6 +31442,111 @@ var ItemPropertySimpleHandler = function ItemPropertySimpleHandler(_ref) {
31427
31442
  });
31428
31443
  };
31429
31444
 
31445
+ var GemSelector = function GemSelector(_ref) {
31446
+ var _item$attachedGems;
31447
+ var atlasJSON = _ref.atlasJSON,
31448
+ atlasIMG = _ref.atlasIMG,
31449
+ item = _ref.item,
31450
+ scale = _ref.scale,
31451
+ onClose = _ref.onClose,
31452
+ onSelect = _ref.onSelect;
31453
+ var _useState = React.useState([]),
31454
+ selectedGems = _useState[0],
31455
+ setSelectedGems = _useState[1];
31456
+ var size = useResponsiveSize(scale);
31457
+ var handleGemToggle = function handleGemToggle(gem) {
31458
+ setSelectedGems(function (prev) {
31459
+ return prev.some(function (selected) {
31460
+ return selected.key === gem.key;
31461
+ }) ? prev.filter(function (selected) {
31462
+ return selected.key !== gem.key;
31463
+ }) : [].concat(prev, [gem]);
31464
+ });
31465
+ };
31466
+ var handleConfirm = function handleConfirm() {
31467
+ onSelect(selectedGems);
31468
+ onClose();
31469
+ };
31470
+ if (!size) return null;
31471
+ return React__default.createElement(DraggableContainer, {
31472
+ type: exports.RPGUIContainerTypes.Framed,
31473
+ width: "450px",
31474
+ height: size.height,
31475
+ scale: scale,
31476
+ cancelDrag: ".gem-selector-container",
31477
+ onCloseButton: onClose
31478
+ }, React__default.createElement(ContentWrapper$1, null, React__default.createElement(Header$2, null, React__default.createElement(Title$3, null, "GEM SELECTION"), React__default.createElement(Subtitle, null, "Select gems to detach")), React__default.createElement(GemGrid, null, (_item$attachedGems = item.attachedGems) == null ? void 0 : _item$attachedGems.map(function (gem, index) {
31479
+ return React__default.createElement(GemItem, {
31480
+ key: gem.key + "-" + index
31481
+ }, React__default.createElement(CheckItemWrapper, null, React__default.createElement(CheckItem, {
31482
+ defaultValue: selectedGems.some(function (selected) {
31483
+ return selected.key === gem.key;
31484
+ }),
31485
+ onChange: function onChange() {
31486
+ handleGemToggle(gem);
31487
+ }
31488
+ })), React__default.createElement(SpriteWrapper, null, React__default.createElement(SpriteFromAtlas, {
31489
+ atlasIMG: atlasIMG,
31490
+ atlasJSON: atlasJSON,
31491
+ spriteKey: "gems/" + gem.key + ".png",
31492
+ imgScale: 2,
31493
+ imgClassname: "gem-sprite",
31494
+ centered: true
31495
+ })), React__default.createElement(GemName, null, gem.name.replace(/ of /gi, '\n').toUpperCase()));
31496
+ })), React__default.createElement(ButtonWrapper, null, React__default.createElement(Button, {
31497
+ buttonType: exports.ButtonTypes.RPGUIButton,
31498
+ onPointerDown: function onPointerDown() {
31499
+ onClose();
31500
+ }
31501
+ }, "Cancel"), React__default.createElement(Button, {
31502
+ buttonType: exports.ButtonTypes.RPGUIButton,
31503
+ onPointerDown: function onPointerDown() {
31504
+ handleConfirm();
31505
+ },
31506
+ disabled: selectedGems.length === 0
31507
+ }, "Confirm"))));
31508
+ };
31509
+ var Title$3 = /*#__PURE__*/styled__default.h1.withConfig({
31510
+ displayName: "GemSelector__Title",
31511
+ componentId: "sc-gbt8g4-0"
31512
+ })(["font-size:0.8rem;color:", " !important;"], uiColors.yellow);
31513
+ var Subtitle = /*#__PURE__*/styled__default.h2.withConfig({
31514
+ displayName: "GemSelector__Subtitle",
31515
+ componentId: "sc-gbt8g4-1"
31516
+ })(["font-size:0.6rem;color:", ";margin:0;"], uiColors.white);
31517
+ var Header$2 = /*#__PURE__*/styled__default.div.withConfig({
31518
+ displayName: "GemSelector__Header",
31519
+ componentId: "sc-gbt8g4-2"
31520
+ })(["text-align:center;padding:5px;border-bottom:2px solid #444;"]);
31521
+ var GemGrid = /*#__PURE__*/styled__default.div.withConfig({
31522
+ displayName: "GemSelector__GemGrid",
31523
+ componentId: "sc-gbt8g4-3"
31524
+ })(["display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:20px;margin-top:10px;min-height:150px;overflow-y:auto;"]);
31525
+ var ContentWrapper$1 = /*#__PURE__*/styled__default.div.withConfig({
31526
+ displayName: "GemSelector__ContentWrapper",
31527
+ componentId: "sc-gbt8g4-4"
31528
+ })(["display:flex;flex-direction:column;align-items:center;margin-left:20px;justify-content:space-between;height:100%;"]);
31529
+ var GemItem = /*#__PURE__*/styled__default.div.withConfig({
31530
+ displayName: "GemSelector__GemItem",
31531
+ componentId: "sc-gbt8g4-5"
31532
+ })(["display:flex;flex-direction:column;align-items:center;justify-content:space-between;background-color:", " !important;height:100px;width:90px;padding:5px;"], uiColors.darkGray);
31533
+ var GemName = /*#__PURE__*/styled__default.div.withConfig({
31534
+ displayName: "GemSelector__GemName",
31535
+ componentId: "sc-gbt8g4-6"
31536
+ })(["font-size:0.5rem;color:", " !important;text-align:center;text-transform:uppercase;line-height:1.2;width:100%;min-height:30px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word;"], uiColors.yellow);
31537
+ var ButtonWrapper = /*#__PURE__*/styled__default.div.withConfig({
31538
+ displayName: "GemSelector__ButtonWrapper",
31539
+ componentId: "sc-gbt8g4-7"
31540
+ })(["display:flex;justify-content:center;align-self:center;"]);
31541
+ var CheckItemWrapper = /*#__PURE__*/styled__default.div.withConfig({
31542
+ displayName: "GemSelector__CheckItemWrapper",
31543
+ componentId: "sc-gbt8g4-8"
31544
+ })(["display:flex;justify-content:center;width:100%;height:20px;input.rpgui-checkbox + label{margin:0 !important;padding-left:23px !important;}"]);
31545
+ var SpriteWrapper = /*#__PURE__*/styled__default.div.withConfig({
31546
+ displayName: "GemSelector__SpriteWrapper",
31547
+ componentId: "sc-gbt8g4-9"
31548
+ })(["display:flex;align-items:center;justify-content:center;width:100%;height:50px;"]);
31549
+
31430
31550
  var ItemSelector = function ItemSelector(_ref) {
31431
31551
  var atlasIMG = _ref.atlasIMG,
31432
31552
  atlasJSON = _ref.atlasJSON,
@@ -31459,7 +31579,7 @@ var ItemSelector = function ItemSelector(_ref) {
31459
31579
  style: {
31460
31580
  width: '100%'
31461
31581
  }
31462
- }, React__default.createElement(Title$3, null, 'Harvesting instruments'), React__default.createElement(Subtitle, null, 'Use the tool, you need it'), React__default.createElement("hr", {
31582
+ }, React__default.createElement(Title$4, null, 'Harvesting instruments'), React__default.createElement(Subtitle$1, null, 'Use the tool, you need it'), React__default.createElement("hr", {
31463
31583
  className: "golden"
31464
31584
  })), React__default.createElement(RadioInputScroller$1, null, options == null ? void 0 : options.map(function (option, index) {
31465
31585
  return React__default.createElement(RadioOptionsWrapper$1, {
@@ -31481,18 +31601,18 @@ var ItemSelector = function ItemSelector(_ref) {
31481
31601
  alignItems: 'center'
31482
31602
  }
31483
31603
  }, option.name, " ", React__default.createElement("br", null), option.description)));
31484
- })), React__default.createElement(ButtonWrapper, null, React__default.createElement(Button, {
31604
+ })), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
31485
31605
  buttonType: exports.ButtonTypes.RPGUIButton,
31486
31606
  onPointerDown: onClose
31487
31607
  }, "Cancel"), React__default.createElement(Button, {
31488
31608
  buttonType: exports.ButtonTypes.RPGUIButton
31489
31609
  }, "Select")));
31490
31610
  };
31491
- var Title$3 = /*#__PURE__*/styled__default.h1.withConfig({
31611
+ var Title$4 = /*#__PURE__*/styled__default.h1.withConfig({
31492
31612
  displayName: "ItemSelector__Title",
31493
31613
  componentId: "sc-gptoxp-0"
31494
31614
  })(["font-size:0.6rem;color:yellow !important;"]);
31495
- var Subtitle = /*#__PURE__*/styled__default.h1.withConfig({
31615
+ var Subtitle$1 = /*#__PURE__*/styled__default.h1.withConfig({
31496
31616
  displayName: "ItemSelector__Subtitle",
31497
31617
  componentId: "sc-gptoxp-1"
31498
31618
  })(["font-size:0.4rem;color:yellow !important;"]);
@@ -31508,7 +31628,7 @@ var RadioOptionsWrapper$1 = /*#__PURE__*/styled__default.div.withConfig({
31508
31628
  displayName: "ItemSelector__RadioOptionsWrapper",
31509
31629
  componentId: "sc-gptoxp-4"
31510
31630
  })(["display:flex;align-items:stretch;margin-bottom:40px;"]);
31511
- var ButtonWrapper = /*#__PURE__*/styled__default.div.withConfig({
31631
+ var ButtonWrapper$1 = /*#__PURE__*/styled__default.div.withConfig({
31512
31632
  displayName: "ItemSelector__ButtonWrapper",
31513
31633
  componentId: "sc-gptoxp-5"
31514
31634
  })(["display:flex;justify-content:space-around;padding-top:20px;width:100%;"]);
@@ -32398,12 +32518,12 @@ var PartyCreate = function PartyCreate(_ref) {
32398
32518
  style: {
32399
32519
  width: '100%'
32400
32520
  }
32401
- }, React__default.createElement(Title$4, null, "Create Party"), React__default.createElement("hr", {
32521
+ }, React__default.createElement(Title$5, null, "Create Party"), React__default.createElement("hr", {
32402
32522
  className: "golden"
32403
32523
  }))), React__default.createElement("h1", null, "Type your party name"), React__default.createElement(Input, {
32404
32524
  placeholder: "Type party name",
32405
32525
  type: "text"
32406
- }), React__default.createElement(ButtonWrapper$1, null, React__default.createElement(Button, {
32526
+ }), React__default.createElement(ButtonWrapper$2, null, React__default.createElement(Button, {
32407
32527
  buttonType: exports.ButtonTypes.RPGUIButton,
32408
32528
  onPointerDown: function onPointerDown() {
32409
32529
  onCreate();
@@ -32421,11 +32541,11 @@ var Wrapper$2 = /*#__PURE__*/styled__default.div.withConfig({
32421
32541
  displayName: "PartyCreate__Wrapper",
32422
32542
  componentId: "sc-13brop0-0"
32423
32543
  })(["display:flex;flex-direction:column;width:100%;"]);
32424
- var Title$4 = /*#__PURE__*/styled__default.h1.withConfig({
32544
+ var Title$5 = /*#__PURE__*/styled__default.h1.withConfig({
32425
32545
  displayName: "PartyCreate__Title",
32426
32546
  componentId: "sc-13brop0-1"
32427
32547
  })(["font-size:0.6rem;color:", " !important;"], uiColors.yellow);
32428
- var ButtonWrapper$1 = /*#__PURE__*/styled__default.div.withConfig({
32548
+ var ButtonWrapper$2 = /*#__PURE__*/styled__default.div.withConfig({
32429
32549
  displayName: "PartyCreate__ButtonWrapper",
32430
32550
  componentId: "sc-13brop0-2"
32431
32551
  })(["margin-top:10px;width:100%;display:flex;justify-content:space-around;align-items:center;.cancel-button{filter:grayscale(0.7);}"]);
@@ -32470,7 +32590,7 @@ var PartyDashboard = function PartyDashboard(_ref) {
32470
32590
  style: {
32471
32591
  width: '100%'
32472
32592
  }
32473
- }, React__default.createElement(Title$5, null, "Party Dashboard"), React__default.createElement(Button, {
32593
+ }, React__default.createElement(Title$6, null, "Party Dashboard"), React__default.createElement(Button, {
32474
32594
  buttonType: exports.ButtonTypes.RPGUIButton
32475
32595
  }, "Create"), React__default.createElement("hr", {
32476
32596
  className: "golden"
@@ -32497,7 +32617,7 @@ var RowsWrapper = /*#__PURE__*/styled__default.div.withConfig({
32497
32617
  displayName: "PartyDashboard__RowsWrapper",
32498
32618
  componentId: "sc-16cm41r-1"
32499
32619
  })(["overflow-y:scroll;-webkit-overflow-scrolling:touch;width:100%;height:200px;"]);
32500
- var Title$5 = /*#__PURE__*/styled__default.h1.withConfig({
32620
+ var Title$6 = /*#__PURE__*/styled__default.h1.withConfig({
32501
32621
  displayName: "PartyDashboard__Title",
32502
32622
  componentId: "sc-16cm41r-2"
32503
32623
  })(["font-size:0.6rem;color:", " !important;"], uiColors.yellow);
@@ -32534,7 +32654,7 @@ var PartyInvite = function PartyInvite(_ref) {
32534
32654
  style: {
32535
32655
  width: '100%'
32536
32656
  }
32537
- }, React__default.createElement(Title$6, null, "Invite for Party"), React__default.createElement("hr", {
32657
+ }, React__default.createElement(Title$7, null, "Invite for Party"), React__default.createElement("hr", {
32538
32658
  className: "golden"
32539
32659
  }))), React__default.createElement(RowsWrapper$1, {
32540
32660
  className: "playersRows"
@@ -32553,7 +32673,7 @@ var Wrapper$4 = /*#__PURE__*/styled__default.div.withConfig({
32553
32673
  displayName: "PartyInvite__Wrapper",
32554
32674
  componentId: "sc-eu8ggt-0"
32555
32675
  })(["display:flex;flex-direction:column;width:100%;"]);
32556
- var Title$6 = /*#__PURE__*/styled__default.h1.withConfig({
32676
+ var Title$7 = /*#__PURE__*/styled__default.h1.withConfig({
32557
32677
  displayName: "PartyInvite__Title",
32558
32678
  componentId: "sc-eu8ggt-1"
32559
32679
  })(["font-size:0.6rem;color:", " !important;"], uiColors.yellow);
@@ -32991,7 +33111,7 @@ var QuestInfo = function QuestInfo(_ref) {
32991
33111
  onPointerDown: onRightClick
32992
33112
  }), React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
32993
33113
  className: "drag-handler"
32994
- }, React__default.createElement(Title$7, null, React__default.createElement(Thumbnail, {
33114
+ }, React__default.createElement(Title$8, null, React__default.createElement(Thumbnail, {
32995
33115
  src: quests[currentIndex].thumbnail || img$8
32996
33116
  }), quests[currentIndex].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
32997
33117
  className: "golden"
@@ -33010,7 +33130,7 @@ var QuestInfo = function QuestInfo(_ref) {
33010
33130
  }, button.title);
33011
33131
  })))) : React__default.createElement(QuestsContainer, null, React__default.createElement(QuestContainer, null, React__default.createElement(TitleContainer$1, {
33012
33132
  className: "drag-handler"
33013
- }, React__default.createElement(Title$7, null, React__default.createElement(Thumbnail, {
33133
+ }, React__default.createElement(Title$8, null, React__default.createElement(Thumbnail, {
33014
33134
  src: quests[0].thumbnail || img$8
33015
33135
  }), quests[0].title), React__default.createElement(QuestSplitDiv, null, React__default.createElement("hr", {
33016
33136
  className: "golden"
@@ -33057,7 +33177,7 @@ var TitleContainer$1 = /*#__PURE__*/styled__default.div.withConfig({
33057
33177
  displayName: "QuestInfo__TitleContainer",
33058
33178
  componentId: "sc-1wccpiy-6"
33059
33179
  })(["width:100%;display:flex;flex-wrap:wrap;justify-content:flex-start;align-items:center;margin-top:1rem;"]);
33060
- var Title$7 = /*#__PURE__*/styled__default.h1.withConfig({
33180
+ var Title$8 = /*#__PURE__*/styled__default.h1.withConfig({
33061
33181
  displayName: "QuestInfo__Title",
33062
33182
  componentId: "sc-1wccpiy-7"
33063
33183
  })(["color:white;z-index:22;font-size:", " !important;color:", " !important;"], uiFonts.size.medium, uiColors.yellow);
@@ -33740,7 +33860,7 @@ var SpellInfo = function SpellInfo(_ref) {
33740
33860
  castingType = spell.castingType,
33741
33861
  cooldown = spell.cooldown,
33742
33862
  maxDistanceGrid = spell.maxDistanceGrid;
33743
- return React__default.createElement(Container$v, null, React__default.createElement(Header$2, null, React__default.createElement("div", null, React__default.createElement(Title$8, null, name), React__default.createElement(Type$1, null, magicWords))), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
33863
+ return React__default.createElement(Container$v, null, React__default.createElement(Header$3, null, React__default.createElement("div", null, React__default.createElement(Title$9, null, name), React__default.createElement(Type$1, null, magicWords))), React__default.createElement(Statistic$1, null, React__default.createElement("div", {
33744
33864
  className: "label"
33745
33865
  }, "Casting Type:"), React__default.createElement("div", {
33746
33866
  className: "value"
@@ -33770,7 +33890,7 @@ var Container$v = /*#__PURE__*/styled__default.div.withConfig({
33770
33890
  displayName: "SpellInfo__Container",
33771
33891
  componentId: "sc-4hbw3q-0"
33772
33892
  })(["color:white;background-color:#222;border-radius:5px;padding:0.5rem;font-size:", ";border:3px solid ", ";height:max-content;width:30rem;@media (max-width:580px){width:80vw;}"], uiFonts.size.small, uiColors.lightGray);
33773
- var Title$8 = /*#__PURE__*/styled__default.div.withConfig({
33893
+ var Title$9 = /*#__PURE__*/styled__default.div.withConfig({
33774
33894
  displayName: "SpellInfo__Title",
33775
33895
  componentId: "sc-4hbw3q-1"
33776
33896
  })(["font-size:", ";font-weight:bold;margin-bottom:0.5rem;display:flex;align-items:center;margin:0;"], uiFonts.size.medium);
@@ -33782,7 +33902,7 @@ var Description$2 = /*#__PURE__*/styled__default.div.withConfig({
33782
33902
  displayName: "SpellInfo__Description",
33783
33903
  componentId: "sc-4hbw3q-3"
33784
33904
  })(["margin-top:1.5rem;font-size:", ";color:", ";font-style:italic;"], uiFonts.size.small, uiColors.lightGray);
33785
- var Header$2 = /*#__PURE__*/styled__default.div.withConfig({
33905
+ var Header$3 = /*#__PURE__*/styled__default.div.withConfig({
33786
33906
  displayName: "SpellInfo__Header",
33787
33907
  componentId: "sc-4hbw3q-4"
33788
33908
  })(["display:flex;align-items:center;justify-content:space-between;margin-bottom:0.5rem;"]);
@@ -33978,7 +34098,7 @@ var Spell = function Spell(_ref) {
33978
34098
  imgScale: IMAGE_SCALE,
33979
34099
  containerStyle: CONTAINER_STYLE,
33980
34100
  centered: true
33981
- })), React__default.createElement(Info, null, React__default.createElement(Title$9, null, React__default.createElement("span", null, name), React__default.createElement("span", {
34101
+ })), React__default.createElement(Info, null, React__default.createElement(Title$a, null, React__default.createElement("span", null, name), React__default.createElement("span", {
33982
34102
  className: "spell"
33983
34103
  }, "(", magicWords, ")")), React__default.createElement(Description$3, null, description)), React__default.createElement(Divider$1, null), React__default.createElement(Cost, null, React__default.createElement("span", null, "Mana cost:"), React__default.createElement("span", {
33984
34104
  className: "mana"
@@ -33999,7 +34119,7 @@ var Info = /*#__PURE__*/styled__default.span.withConfig({
33999
34119
  displayName: "Spell__Info",
34000
34120
  componentId: "sc-j96fa2-2"
34001
34121
  })(["width:0;flex:1;@media (orientation:portrait){display:none;}"]);
34002
- var Title$9 = /*#__PURE__*/styled__default.p.withConfig({
34122
+ var Title$a = /*#__PURE__*/styled__default.p.withConfig({
34003
34123
  displayName: "Spell__Title",
34004
34124
  componentId: "sc-j96fa2-3"
34005
34125
  })(["display:flex;flex-wrap:wrap;align-items:center;margin-bottom:5px;margin:0;span{font-size:", " !important;font-weight:bold !important;color:", " !important;margin-right:0.5rem;}.spell{font-size:", " !important;font-weight:normal !important;color:", " !important;}"], uiFonts.size.medium, uiColors.yellow, uiFonts.size.small, uiColors.lightGray);
@@ -34063,7 +34183,7 @@ var Spellbook = function Spellbook(_ref) {
34063
34183
  height: "inherit",
34064
34184
  cancelDrag: "#spellbook-search, #shortcuts_list, .spell",
34065
34185
  scale: scale
34066
- }, React__default.createElement(Container$z, null, React__default.createElement(Title$a, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
34186
+ }, React__default.createElement(Container$z, null, React__default.createElement(Title$b, null, "Learned Spells"), React__default.createElement(ShortcutsSetter, {
34067
34187
  setSettingShortcutIndex: setSettingShortcutIndex,
34068
34188
  settingShortcutIndex: settingShortcutIndex,
34069
34189
  shortcuts: shortcuts,
@@ -34095,7 +34215,7 @@ var Spellbook = function Spellbook(_ref) {
34095
34215
  }, spell)));
34096
34216
  }))));
34097
34217
  };
34098
- var Title$a = /*#__PURE__*/styled__default.h1.withConfig({
34218
+ var Title$b = /*#__PURE__*/styled__default.h1.withConfig({
34099
34219
  displayName: "Spellbook__Title",
34100
34220
  componentId: "sc-r02nfq-0"
34101
34221
  })(["font-size:", " !important;margin-bottom:0 !important;"], uiFonts.size.large);
@@ -34581,7 +34701,7 @@ var TradingMenu = function TradingMenu(_ref) {
34581
34701
  width: "500px",
34582
34702
  cancelDrag: "#TraderContainer",
34583
34703
  scale: scale
34584
- }, React__default.createElement(Container$A, null, React__default.createElement(Title$b, null, type.charAt(0).toUpperCase() + type.slice(1), " Menu"), React__default.createElement("hr", {
34704
+ }, React__default.createElement(Container$A, null, React__default.createElement(Title$c, null, type.charAt(0).toUpperCase() + type.slice(1), " Menu"), React__default.createElement("hr", {
34585
34705
  className: "golden"
34586
34706
  }), React__default.createElement(ScrollWrapper, {
34587
34707
  id: "TraderContainer"
@@ -34598,7 +34718,7 @@ var TradingMenu = function TradingMenu(_ref) {
34598
34718
  scale: scale,
34599
34719
  isBuy: isBuy()
34600
34720
  });
34601
- })), React__default.createElement(InfoSection, null, React__default.createElement(GoldInfo, null, React__default.createElement("p", null, "Available Gold:"), React__default.createElement("p", null, "$", characterAvailableGold.toFixed(2))), React__default.createElement(GoldInfo, null, React__default.createElement("p", null, "Total:"), React__default.createElement("p", null, "$", sum)), !hasGoldForSale() ? React__default.createElement(AlertText, null, "Sorry, not enough money.") : React__default.createElement(GoldInfo, null, React__default.createElement("p", null, "Final Gold:"), React__default.createElement("p", null, "$", getFinalGold().toFixed(2)))), React__default.createElement(ButtonWrapper$2, null, React__default.createElement(Button, {
34721
+ })), React__default.createElement(InfoSection, null, React__default.createElement(GoldInfo, null, React__default.createElement("p", null, "Available Gold:"), React__default.createElement("p", null, "$", characterAvailableGold.toFixed(2))), React__default.createElement(GoldInfo, null, React__default.createElement("p", null, "Total:"), React__default.createElement("p", null, "$", sum)), !hasGoldForSale() ? React__default.createElement(AlertText, null, "Sorry, not enough money.") : React__default.createElement(GoldInfo, null, React__default.createElement("p", null, "Final Gold:"), React__default.createElement("p", null, "$", getFinalGold().toFixed(2)))), React__default.createElement(ButtonWrapper$3, null, React__default.createElement(Button, {
34602
34722
  buttonType: exports.ButtonTypes.RPGUIButton,
34603
34723
  disabled: !hasGoldForSale(),
34604
34724
  onPointerDown: function onPointerDown() {
@@ -34613,7 +34733,7 @@ var Container$A = /*#__PURE__*/styled__default.div.withConfig({
34613
34733
  displayName: "TradingMenu__Container",
34614
34734
  componentId: "sc-1wjsz1l-0"
34615
34735
  })(["width:100%;"]);
34616
- var Title$b = /*#__PURE__*/styled__default.h1.withConfig({
34736
+ var Title$c = /*#__PURE__*/styled__default.h1.withConfig({
34617
34737
  displayName: "TradingMenu__Title",
34618
34738
  componentId: "sc-1wjsz1l-1"
34619
34739
  })(["font-size:0.7rem !important;color:yellow !important;text-align:center;"]);
@@ -34633,7 +34753,7 @@ var AlertText = /*#__PURE__*/styled__default.p.withConfig({
34633
34753
  displayName: "TradingMenu__AlertText",
34634
34754
  componentId: "sc-1wjsz1l-5"
34635
34755
  })(["color:red !important;text-align:center;margin:0.3rem 0;font-size:0.5rem;"]);
34636
- var ButtonWrapper$2 = /*#__PURE__*/styled__default.div.withConfig({
34756
+ var ButtonWrapper$3 = /*#__PURE__*/styled__default.div.withConfig({
34637
34757
  displayName: "TradingMenu__ButtonWrapper",
34638
34758
  componentId: "sc-1wjsz1l-6"
34639
34759
  })(["display:flex;justify-content:space-around;width:100%;margin-top:1rem;"]);
@@ -34812,6 +34932,7 @@ exports.EquipmentSet = EquipmentSet;
34812
34932
  exports.EquipmentSlotSpriteByType = EquipmentSlotSpriteByType;
34813
34933
  exports.ErrorBoundary = ErrorBoundary;
34814
34934
  exports.FriendList = FriendList;
34935
+ exports.GemSelector = GemSelector;
34815
34936
  exports.HistoryDialog = HistoryDialog;
34816
34937
  exports.ImageCarousel = ImageCarousel;
34817
34938
  exports.Input = Input;