@rpg-engine/long-bow 0.2.22 → 0.2.24

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.
Files changed (30) hide show
  1. package/dist/components/Equipment/EquipmentSet.d.ts +2 -0
  2. package/dist/components/HistoryDialog.d.ts +1 -1
  3. package/dist/components/Item/Inventory/ErrorBoundary.d.ts +14 -0
  4. package/dist/components/Item/Inventory/ItemContainer.d.ts +2 -0
  5. package/dist/components/Item/Inventory/ItemSlot.d.ts +2 -0
  6. package/dist/long-bow.cjs.development.js +855 -702
  7. package/dist/long-bow.cjs.development.js.map +1 -1
  8. package/dist/long-bow.cjs.production.min.js +1 -1
  9. package/dist/long-bow.cjs.production.min.js.map +1 -1
  10. package/dist/long-bow.esm.js +858 -705
  11. package/dist/long-bow.esm.js.map +1 -1
  12. package/package.json +1 -1
  13. package/src/components/Character/CharacterSelection.tsx +19 -11
  14. package/src/components/Equipment/EquipmentSet.tsx +6 -0
  15. package/src/components/HistoryDialog.tsx +20 -3
  16. package/src/components/Item/Inventory/ErrorBoundary.tsx +43 -0
  17. package/src/components/Item/Inventory/ItemContainer.tsx +6 -0
  18. package/src/components/Item/Inventory/ItemSlot.tsx +33 -24
  19. package/src/components/NPCDialog/img/{background.png → background01.png} +0 -0
  20. package/src/components/NPCDialog/img/background02.png +0 -0
  21. package/src/components/NPCDialog/img/background03.png +0 -0
  22. package/src/components/QuestList.tsx +13 -1
  23. package/src/components/SkillProgressBar.tsx +11 -8
  24. package/src/mocks/atlas/items/items.json +169 -121
  25. package/src/mocks/atlas/items/items.png +0 -0
  26. package/src/stories/CharacterSelection.stories.tsx +4 -0
  27. package/src/stories/EquipmentSet.stories.tsx +4 -0
  28. package/src/stories/HistoryDialog.stories.tsx +4 -2
  29. package/src/stories/ItemContainer.stories.tsx +4 -0
  30. package/src/components/NPCDialog/.DS_Store +0 -0
@@ -34,6 +34,21 @@ function _extends() {
34
34
  return _extends.apply(this, arguments);
35
35
  }
36
36
 
37
+ function _inheritsLoose(subClass, superClass) {
38
+ subClass.prototype = Object.create(superClass.prototype);
39
+ subClass.prototype.constructor = subClass;
40
+
41
+ _setPrototypeOf(subClass, superClass);
42
+ }
43
+
44
+ function _setPrototypeOf(o, p) {
45
+ _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {
46
+ o.__proto__ = p;
47
+ return o;
48
+ };
49
+ return _setPrototypeOf(o, p);
50
+ }
51
+
37
52
  function _objectWithoutPropertiesLoose(source, excluded) {
38
53
  if (source == null) return {};
39
54
  var target = {};
@@ -20360,543 +20375,8 @@ var entitiesJSON = {
20360
20375
 
20361
20376
  var img = '';
20362
20377
 
20363
- var Ellipsis = function Ellipsis(_ref) {
20364
- var children = _ref.children,
20365
- maxLines = _ref.maxLines;
20366
- console.log('Ellipsis Component 2');
20367
- return React__default.createElement(Container$1, null, React__default.createElement("div", {
20368
- className: "ellipsis-" + maxLines + "-lines"
20369
- }, children));
20370
- };
20371
- var Container$1 = /*#__PURE__*/styled.div.withConfig({
20372
- displayName: "Ellipsis__Container",
20373
- componentId: "sc-ysrlju-0"
20374
- })([".ellipsis-1-lines{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;}.ellipsis-2-lines{display:-webkit-box;max-width:100%;height:25px;margin:0 auto;line-height:1;-webkit-line-clamp:2;-webkit-box-orient:vertical;text-overflow:ellipsis;overflow:hidden;}.ellipsis-3-lines{display:-webkit-box;max-width:100%;height:43px;margin:0 auto;line-height:1;-webkit-line-clamp:3;-webkit-box-orient:vertical;text-overflow:ellipsis;overflow:hidden;}"]);
20375
-
20376
- var img$1 = '';
20377
-
20378
- var img$2 = '';
20379
-
20380
- var img$3 = '';
20381
-
20382
- var img$4 = '';
20383
-
20384
- var PropertySelect = function PropertySelect(_ref) {
20385
- var availableProperties = _ref.availableProperties,
20386
- onChange = _ref.onChange;
20387
-
20388
- var _useState = React.useState(0),
20389
- currentIndex = _useState[0],
20390
- setCurrentIndex = _useState[1];
20391
-
20392
- var propertiesLength = availableProperties.length - 1;
20393
-
20394
- var onLeftClick = function onLeftClick() {
20395
- if (currentIndex === 0) setCurrentIndex(propertiesLength);else setCurrentIndex(function (index) {
20396
- return index - 1;
20397
- });
20398
- };
20399
-
20400
- var onRightClick = function onRightClick() {
20401
- if (currentIndex === propertiesLength) setCurrentIndex(0);else setCurrentIndex(function (index) {
20402
- return index + 1;
20403
- });
20404
- };
20405
-
20406
- React.useEffect(function () {
20407
- onChange(availableProperties[currentIndex]);
20408
- }, [currentIndex]);
20409
- React.useEffect(function () {
20410
- setCurrentIndex(0);
20411
- }, [JSON.stringify(availableProperties)]);
20412
-
20413
- var getCurrentSelectionName = function getCurrentSelectionName() {
20414
- var item = availableProperties[currentIndex];
20415
-
20416
- if (item) {
20417
- return item.name;
20418
- }
20419
-
20420
- return '';
20421
- };
20422
-
20423
- return React__default.createElement(Container$2, null, React__default.createElement(TextOverlay, null, React__default.createElement(Item, null, React__default.createElement(Ellipsis, {
20424
- maxLines: 1
20425
- }, getCurrentSelectionName()))), React__default.createElement("div", {
20426
- className: "rpgui-progress-track"
20427
- }), React__default.createElement(LeftArrow, {
20428
- onClick: onLeftClick,
20429
- onTouchStart: onLeftClick
20430
- }), React__default.createElement(RightArrow, {
20431
- onClick: onRightClick,
20432
- onTouchStart: onRightClick
20433
- }));
20434
- };
20435
- var Item = /*#__PURE__*/styled.span.withConfig({
20436
- displayName: "PropertySelect__Item",
20437
- componentId: "sc-12uqx6s-0"
20438
- })(["font-size:1rem;color:white;text-align:center;z-index:1;position:absolute;top:12px;width:100%;"]);
20439
- var TextOverlay = /*#__PURE__*/styled.div.withConfig({
20440
- displayName: "PropertySelect__TextOverlay",
20441
- componentId: "sc-12uqx6s-1"
20442
- })(["width:100%;position:relative;"]);
20443
- var Container$2 = /*#__PURE__*/styled.div.withConfig({
20444
- displayName: "PropertySelect__Container",
20445
- componentId: "sc-12uqx6s-2"
20446
- })(["position:relative;display:flex;flex-direction:column;justify-content:start;align-items:flex-start;min-width:100px;width:40%;"]);
20447
- var LeftArrow = /*#__PURE__*/styled.div.withConfig({
20448
- displayName: "PropertySelect__LeftArrow",
20449
- componentId: "sc-12uqx6s-3"
20450
- })(["background-image:url(", ");background-size:100% 100%;left:0;position:absolute;width:40px;height:42px;:active{background-image:url(", ");}z-index:2;"], img$2, img$1);
20451
- var RightArrow = /*#__PURE__*/styled.div.withConfig({
20452
- displayName: "PropertySelect__RightArrow",
20453
- componentId: "sc-12uqx6s-4"
20454
- })(["background-image:url(", ");right:0;position:absolute;width:40px;background-size:100% 100%;height:42px;:active{background-image:url(", ");}z-index:2;"], img$4, img$3);
20455
-
20456
- var CharacterSelection = function CharacterSelection(_ref) {
20457
- var availableCharacters = _ref.availableCharacters,
20458
- onChange = _ref.onChange;
20459
- var propertySelectValues = availableCharacters.map(function (item) {
20460
- return {
20461
- id: item.textureKey,
20462
- name: item.name
20463
- };
20464
- });
20465
-
20466
- var _useState = React.useState(),
20467
- selectedValue = _useState[0],
20468
- setSelectedValue = _useState[1];
20469
-
20470
- var _useState2 = React.useState(''),
20471
- selectedSpriteKey = _useState2[0],
20472
- setSelectedSpriteKey = _useState2[1];
20473
-
20474
- var onSelectedValueChange = function onSelectedValueChange() {
20475
- var textureKey = selectedValue ? selectedValue.id : '';
20476
- var spriteKey = textureKey ? textureKey + '/down/standing/0.png' : '';
20477
-
20478
- if (spriteKey == selectedSpriteKey) {
20479
- return;
20480
- }
20481
-
20482
- setSelectedSpriteKey(spriteKey);
20483
- onChange(textureKey);
20484
- };
20485
-
20486
- React.useEffect(function () {
20487
- onSelectedValueChange();
20488
- }, [selectedValue]);
20489
- React.useEffect(function () {
20490
- setSelectedValue(propertySelectValues[0]);
20491
- }, [availableCharacters]);
20492
- return React__default.createElement(Container$3, null, selectedSpriteKey && React__default.createElement(SpriteFromAtlas, {
20493
- spriteKey: selectedSpriteKey,
20494
- atlasIMG: img,
20495
- atlasJSON: entitiesJSON,
20496
- imgScale: 4,
20497
- height: 50,
20498
- width: 50,
20499
- containerStyle: {
20500
- padding: '25px 10px 5px 27px'
20501
- }
20502
- }), React__default.createElement(PropertySelect, {
20503
- availableProperties: propertySelectValues,
20504
- onChange: function onChange(value) {
20505
- setSelectedValue(value);
20506
- }
20507
- }));
20508
- };
20509
- var Container$3 = /*#__PURE__*/styled.div.withConfig({
20510
- displayName: "CharacterSelection__Container",
20511
- componentId: "sc-b34498-0"
20512
- })(["display:flex;flex-direction:column;align-items:center;image-rendering:pixelated;"]);
20513
-
20514
- var colors = {
20515
- darkGrey: '#3e3e3e',
20516
- darkYellow: '#FFC857',
20517
- orange: '#E9724C',
20518
- cardinal: '#C5283D',
20519
- raisinBlack: '#191923',
20520
- navyBlue: '#0E79B2',
20521
- purple: '#8C3D8C',
20522
- blue: '#3772FF'
20523
- };
20524
-
20525
- var Input = function Input(_ref) {
20526
- var props = _extends({}, _ref);
20527
-
20528
- return React__default.createElement("input", Object.assign({}, props));
20529
- };
20530
-
20531
- (function (RPGUIContainerTypes) {
20532
- RPGUIContainerTypes["Framed"] = "framed";
20533
- RPGUIContainerTypes["FramedGold"] = "framed-golden";
20534
- RPGUIContainerTypes["FramedGold2"] = "framed-golden-2";
20535
- RPGUIContainerTypes["FramedGrey"] = "framed-grey";
20536
- })(exports.RPGUIContainerTypes || (exports.RPGUIContainerTypes = {}));
20537
-
20538
- var RPGUIContainer = function RPGUIContainer(_ref) {
20539
- var children = _ref.children,
20540
- type = _ref.type,
20541
- _ref$width = _ref.width,
20542
- width = _ref$width === void 0 ? '50%' : _ref$width,
20543
- height = _ref.height,
20544
- className = _ref.className;
20545
- return React__default.createElement(Container$4, {
20546
- width: width,
20547
- height: height || 'auto',
20548
- className: "rpgui-container " + type + " " + className
20549
- }, children);
20550
- };
20551
- var Container$4 = /*#__PURE__*/styled.div.withConfig({
20552
- displayName: "RPGUIContainer__Container",
20553
- componentId: "sc-a8l4p8-0"
20554
- })(["height:", ";width:", ";display:flex;flex-wrap:wrap;image-rendering:pixelated;"], function (props) {
20555
- return props.height;
20556
- }, function (_ref2) {
20557
- var width = _ref2.width;
20558
- return width;
20559
- });
20560
-
20561
- var Column = /*#__PURE__*/styled.div.withConfig({
20562
- displayName: "Column",
20563
- componentId: "sc-1pesqff-0"
20564
- })(["flex:", ";display:flex;flex-wrap:", ";align-items:", ";justify-content:", ";"], function (props) {
20565
- return props.flex || 'auto';
20566
- }, function (props) {
20567
- return props.flexWrap || 'nowrap';
20568
- }, function (props) {
20569
- return props.alignItems || 'flex-start';
20570
- }, function (props) {
20571
- return props.justifyContent || 'flex-start';
20572
- });
20573
-
20574
- var Chat = function Chat(_ref) {
20575
- var chatMessages = _ref.chatMessages,
20576
- onSendChatMessage = _ref.onSendChatMessage,
20577
- _ref$opacity = _ref.opacity,
20578
- opacity = _ref$opacity === void 0 ? 1 : _ref$opacity,
20579
- _ref$width = _ref.width,
20580
- width = _ref$width === void 0 ? '100%' : _ref$width,
20581
- _ref$height = _ref.height,
20582
- height = _ref$height === void 0 ? '250px' : _ref$height,
20583
- onCloseButton = _ref.onCloseButton;
20584
-
20585
- var _useState = React.useState(''),
20586
- message = _useState[0],
20587
- setMessage = _useState[1];
20588
-
20589
- React.useEffect(function () {
20590
- scrollChatToBottom();
20591
- }, []);
20592
- React.useEffect(function () {
20593
- scrollChatToBottom();
20594
- }, [chatMessages]);
20595
-
20596
- var scrollChatToBottom = function scrollChatToBottom() {
20597
- var scrollingElement = document.querySelector('.chat-body');
20598
-
20599
- if (scrollingElement) {
20600
- scrollingElement.scrollTop = scrollingElement.scrollHeight;
20601
- }
20602
- };
20603
-
20604
- var handleSubmit = function handleSubmit(event) {
20605
- event.preventDefault();
20606
- onSendChatMessage(message);
20607
- setMessage('');
20608
- };
20609
-
20610
- var getInputValue = function getInputValue(value) {
20611
- setMessage(value);
20612
- };
20613
-
20614
- var onRenderMessageLines = function onRenderMessageLines(emitter, createdAt, message) {
20615
- return dayjs(createdAt || new Date()).format('HH:mm') + " " + (emitter != null && emitter.name ? emitter.name + ": " : 'Unknown: ') + " " + message;
20616
- };
20617
-
20618
- var onRenderChatMessages = function onRenderChatMessages(chatMessages) {
20619
- return chatMessages != null && chatMessages.length ? chatMessages == null ? void 0 : chatMessages.map(function (_ref2, index) {
20620
- var _id = _ref2._id,
20621
- createdAt = _ref2.createdAt,
20622
- emitter = _ref2.emitter,
20623
- message = _ref2.message;
20624
- return React__default.createElement(MessageText, {
20625
- key: _id + "_" + index
20626
- }, onRenderMessageLines(emitter, createdAt, message));
20627
- }) : React__default.createElement(MessageText, null, "No messages available.");
20628
- };
20629
-
20630
- return React__default.createElement(Container$5, null, React__default.createElement(CustomContainer, {
20631
- type: exports.RPGUIContainerTypes.FramedGrey,
20632
- width: width,
20633
- height: height,
20634
- className: "chat-container",
20635
- opacity: opacity
20636
- }, React__default.createElement(reactErrorBoundary.ErrorBoundary, {
20637
- fallback: React__default.createElement("p", null, "Oops! Your chat has crashed.")
20638
- }, onCloseButton && React__default.createElement(CloseButton, {
20639
- onClick: onCloseButton,
20640
- onTouchStart: onCloseButton
20641
- }, "X"), React__default.createElement(RPGUIContainer, {
20642
- type: exports.RPGUIContainerTypes.FramedGrey,
20643
- width: '100%',
20644
- height: '80%',
20645
- className: "chat-body dark-background"
20646
- }, onRenderChatMessages(chatMessages)), React__default.createElement(Form, {
20647
- onSubmit: handleSubmit
20648
- }, React__default.createElement(Column, {
20649
- flex: 70
20650
- }, React__default.createElement(CustomInput, {
20651
- value: message,
20652
- id: "inputMessage",
20653
- onChange: function onChange(e) {
20654
- return getInputValue(e.target.value);
20655
- },
20656
- height: 20,
20657
- className: "chat-input dark-background",
20658
- type: "text",
20659
- autoComplete: "off"
20660
- })), React__default.createElement(Column, {
20661
- justifyContent: "flex-end"
20662
- }, React__default.createElement(Button, {
20663
- buttonType: exports.ButtonTypes.RPGUIButton,
20664
- id: "chat-send-button"
20665
- }, "Send"))))));
20666
- };
20667
- var Container$5 = /*#__PURE__*/styled.div.withConfig({
20668
- displayName: "Chat__Container",
20669
- componentId: "sc-1bk05n6-0"
20670
- })(["position:relative;"]);
20671
- var CloseButton = /*#__PURE__*/styled.div.withConfig({
20672
- displayName: "Chat__CloseButton",
20673
- componentId: "sc-1bk05n6-1"
20674
- })(["position:absolute;top:2px;right:0px;color:white;z-index:22;font-size:0.7rem;"]);
20675
- var CustomInput = /*#__PURE__*/styled(Input).withConfig({
20676
- displayName: "Chat__CustomInput",
20677
- componentId: "sc-1bk05n6-2"
20678
- })(["height:30px;width:100%;.rpgui-content .input{min-height:39px;}"]);
20679
- var CustomContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
20680
- displayName: "Chat__CustomContainer",
20681
- componentId: "sc-1bk05n6-3"
20682
- })(["display:block;opacity:", ";&:hover{opacity:1;}.dark-background{background-color:", " !important;}.chat-body{&.rpgui-container.framed-grey{background:unset;}max-height:170px;overflow-y:auto;}"], function (props) {
20683
- return props.opacity;
20684
- }, colors.darkGrey);
20685
- var Form = /*#__PURE__*/styled.form.withConfig({
20686
- displayName: "Chat__Form",
20687
- componentId: "sc-1bk05n6-4"
20688
- })(["display:flex;width:100%;justify-content:center;align-items:center;"]);
20689
- var MessageText = /*#__PURE__*/styled.p.withConfig({
20690
- displayName: "Chat__MessageText",
20691
- componentId: "sc-1bk05n6-5"
20692
- })(["display:block !important;width:100%;font-size:0.7rem !important;overflow-y:auto;margin:0;"]);
20693
-
20694
- var CheckButton = function CheckButton(_ref) {
20695
- var items = _ref.items,
20696
- onChange = _ref.onChange;
20697
-
20698
- var generateSelectedValuesList = function generateSelectedValuesList() {
20699
- var selectedValues = {};
20700
- items.forEach(function (item) {
20701
- selectedValues[item.label] = false;
20702
- });
20703
- return selectedValues;
20704
- };
20705
-
20706
- var _useState = React.useState(generateSelectedValuesList()),
20707
- selectedValues = _useState[0],
20708
- setSelectedValues = _useState[1];
20709
-
20710
- var handleClick = function handleClick(label) {
20711
- var _extends2;
20712
-
20713
- setSelectedValues(_extends({}, selectedValues, (_extends2 = {}, _extends2[label] = !selectedValues[label], _extends2)));
20714
- };
20715
-
20716
- React.useEffect(function () {
20717
- if (selectedValues) {
20718
- onChange(selectedValues);
20719
- }
20720
- }, [selectedValues]);
20721
- return React__default.createElement("div", {
20722
- id: "elemento-checkbox"
20723
- }, items == null ? void 0 : items.map(function (element, index) {
20724
- return React__default.createElement("div", {
20725
- key: element.label + "_" + index
20726
- }, React__default.createElement("input", {
20727
- className: "rpgui-checkbox",
20728
- type: "checkbox",
20729
- checked: selectedValues[element.label],
20730
- onChange: function onChange() {}
20731
- }), React__default.createElement("label", {
20732
- onClick: function onClick() {
20733
- return handleClick(element.label);
20734
- }
20735
- }, element.label), React__default.createElement("br", null));
20736
- }));
20737
- };
20738
-
20739
- function useOutsideClick(ref, id) {
20740
- React.useEffect(function () {
20741
- /**
20742
- * Alert if clicked on outside of element
20743
- */
20744
- function handleClickOutside(event) {
20745
- if (ref.current && !ref.current.contains(event.target)) {
20746
- var _event = new CustomEvent('clickOutside', {
20747
- detail: {
20748
- id: id
20749
- }
20750
- });
20751
-
20752
- document.dispatchEvent(_event);
20753
- }
20754
- } // Bind the event listener
20755
-
20756
-
20757
- document.addEventListener('mousedown', handleClickOutside);
20758
- return function () {
20759
- // Unbind the event listener on clean up
20760
- document.removeEventListener('mousedown', handleClickOutside);
20761
- };
20762
- }, [ref]);
20763
- }
20764
-
20765
- var DraggableContainer = function DraggableContainer(_ref) {
20766
- var children = _ref.children,
20767
- _ref$width = _ref.width,
20768
- width = _ref$width === void 0 ? '50%' : _ref$width,
20769
- height = _ref.height,
20770
- className = _ref.className,
20771
- _ref$type = _ref.type,
20772
- type = _ref$type === void 0 ? exports.RPGUIContainerTypes.FramedGold : _ref$type,
20773
- onCloseButton = _ref.onCloseButton,
20774
- title = _ref.title,
20775
- imgSrc = _ref.imgSrc,
20776
- _ref$imgWidth = _ref.imgWidth,
20777
- imgWidth = _ref$imgWidth === void 0 ? '20px' : _ref$imgWidth,
20778
- cancelDrag = _ref.cancelDrag,
20779
- onPositionChange = _ref.onPositionChange,
20780
- onOutsideClick = _ref.onOutsideClick;
20781
- var draggableRef = React.useRef(null);
20782
- useOutsideClick(draggableRef, 'item-container');
20783
- React.useEffect(function () {
20784
- document.addEventListener('clickOutside', function (event) {
20785
- var e = event;
20786
-
20787
- if (e.detail.id === 'item-container') {
20788
- if (onOutsideClick) {
20789
- onOutsideClick();
20790
- }
20791
- }
20792
- });
20793
- return function () {
20794
- document.removeEventListener('clickOutside', function (_e) {});
20795
- };
20796
- }, []);
20797
- return React__default.createElement(Draggable, {
20798
- cancel: ".container-close," + cancelDrag,
20799
- onDrag: function onDrag(_e, data) {
20800
- if (onPositionChange) {
20801
- onPositionChange({
20802
- x: data.x,
20803
- y: data.y
20804
- });
20805
- }
20806
- }
20807
- }, React__default.createElement(Container$6, {
20808
- ref: draggableRef,
20809
- width: width,
20810
- height: height || 'auto',
20811
- className: "rpgui-container " + type + " " + className
20812
- }, title && React__default.createElement(TitleContainer, {
20813
- className: "drag-handler"
20814
- }, React__default.createElement(Title, null, imgSrc && React__default.createElement(Icon, {
20815
- src: imgSrc,
20816
- width: imgWidth
20817
- }), title)), onCloseButton && React__default.createElement(CloseButton$1, {
20818
- className: "container-close",
20819
- onClick: onCloseButton,
20820
- onTouchStart: onCloseButton
20821
- }, "X"), children));
20822
- };
20823
- var Container$6 = /*#__PURE__*/styled.div.withConfig({
20824
- displayName: "DraggableContainer__Container",
20825
- componentId: "sc-184mpyl-0"
20826
- })(["height:", ";width:", ";display:flex;flex-wrap:wrap;image-rendering:pixelated;&.rpgui-container{padding-top:1.5rem;}"], function (props) {
20827
- return props.height;
20828
- }, function (_ref2) {
20829
- var width = _ref2.width;
20830
- return width;
20831
- });
20832
- var CloseButton$1 = /*#__PURE__*/styled.div.withConfig({
20833
- displayName: "DraggableContainer__CloseButton",
20834
- componentId: "sc-184mpyl-1"
20835
- })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
20836
- var TitleContainer = /*#__PURE__*/styled.div.withConfig({
20837
- displayName: "DraggableContainer__TitleContainer",
20838
- componentId: "sc-184mpyl-2"
20839
- })(["width:100%;height:100%;display:flex;flex-wrap:wrap;justify-content:flex-start;align-items:center;"]);
20840
- var Title = /*#__PURE__*/styled.h1.withConfig({
20841
- displayName: "DraggableContainer__Title",
20842
- componentId: "sc-184mpyl-3"
20843
- })(["color:white;z-index:22;font-size:0.6rem;"]);
20844
- var Icon = /*#__PURE__*/styled.img.withConfig({
20845
- displayName: "DraggableContainer__Icon",
20846
- componentId: "sc-184mpyl-4"
20847
- })(["color:white;z-index:22;font-size:10px;width:", ";margin-right:0.5rem;"], function (props) {
20848
- return props.width;
20849
- });
20850
-
20851
- var _RPGUI = RPGUI;
20852
- var RPGUIRoot = function RPGUIRoot(_ref) {
20853
- var children = _ref.children;
20854
- return React__default.createElement("div", {
20855
- className: "rpgui-content"
20856
- }, children);
20857
- };
20858
-
20859
- var Dropdown = function Dropdown(_ref) {
20860
- var options = _ref.options,
20861
- width = _ref.width,
20862
- onChange = _ref.onChange;
20863
- var dropdownId = uuid.v4();
20864
-
20865
- var _useState = React.useState(''),
20866
- selectedValue = _useState[0],
20867
- setSelectedValue = _useState[1];
20868
-
20869
- React.useEffect(function () {
20870
- var element = document.getElementById("rpgui-dropdown-" + dropdownId);
20871
-
20872
- var dropdownValue = _RPGUI.get_value(element);
20873
-
20874
- setSelectedValue(dropdownValue);
20875
- element == null ? void 0 : element.addEventListener('change', function (event) {
20876
- setSelectedValue(event == null ? void 0 : event.target.value);
20877
- });
20878
- }, []);
20879
- React.useEffect(function () {
20880
- if (selectedValue) {
20881
- onChange(selectedValue);
20882
- }
20883
- }, [selectedValue]);
20884
- return React__default.createElement("select", {
20885
- id: "rpgui-dropdown-" + dropdownId,
20886
- style: {
20887
- width: width
20888
- },
20889
- className: "rpgui-dropdown"
20890
- }, options.map(function (option) {
20891
- return React__default.createElement("option", {
20892
- key: option.id,
20893
- value: option.value
20894
- }, option.option);
20895
- }));
20896
- };
20897
-
20898
20378
  var frames$1 = {
20899
- "legs/studded-legs.png": {
20379
+ "maces/club.png": {
20900
20380
  frame: {
20901
20381
  x: 0,
20902
20382
  y: 0,
@@ -24064,7 +23544,7 @@ var frames$1 = {
24064
23544
  y: 0.5
24065
23545
  }
24066
23546
  },
24067
- "accessories/amazons-necklace.png": {
23547
+ "legs/studded-legs.png": {
24068
23548
  frame: {
24069
23549
  x: 0,
24070
23550
  y: 176,
@@ -24088,7 +23568,7 @@ var frames$1 = {
24088
23568
  y: 0.5
24089
23569
  }
24090
23570
  },
24091
- "maces/club.png": {
23571
+ "accessories/amazons-necklace.png": {
24092
23572
  frame: {
24093
23573
  x: 16,
24094
23574
  y: 176,
@@ -24424,7 +23904,7 @@ var frames$1 = {
24424
23904
  y: 0.5
24425
23905
  }
24426
23906
  },
24427
- "others/golden-key.png": {
23907
+ "others/gold-coin.png": {
24428
23908
  frame: {
24429
23909
  x: 192,
24430
23910
  y: 48,
@@ -24448,7 +23928,7 @@ var frames$1 = {
24448
23928
  y: 0.5
24449
23929
  }
24450
23930
  },
24451
- "others/royal-chalice.png": {
23931
+ "others/golden-key.png": {
24452
23932
  frame: {
24453
23933
  x: 192,
24454
23934
  y: 64,
@@ -24472,7 +23952,7 @@ var frames$1 = {
24472
23952
  y: 0.5
24473
23953
  }
24474
23954
  },
24475
- "others/silver-key.png": {
23955
+ "others/no-image.png": {
24476
23956
  frame: {
24477
23957
  x: 192,
24478
23958
  y: 80,
@@ -24496,7 +23976,7 @@ var frames$1 = {
24496
23976
  y: 0.5
24497
23977
  }
24498
23978
  },
24499
- "potions/dextery-potion.png": {
23979
+ "others/royal-chalice.png": {
24500
23980
  frame: {
24501
23981
  x: 192,
24502
23982
  y: 96,
@@ -24520,7 +24000,7 @@ var frames$1 = {
24520
24000
  y: 0.5
24521
24001
  }
24522
24002
  },
24523
- "potions/endurance-potion.png": {
24003
+ "others/silver-key.png": {
24524
24004
  frame: {
24525
24005
  x: 192,
24526
24006
  y: 112,
@@ -24544,7 +24024,7 @@ var frames$1 = {
24544
24024
  y: 0.5
24545
24025
  }
24546
24026
  },
24547
- "potions/greater-endurance-potion.png": {
24027
+ "potions/dextery-potion.png": {
24548
24028
  frame: {
24549
24029
  x: 192,
24550
24030
  y: 128,
@@ -24568,7 +24048,7 @@ var frames$1 = {
24568
24048
  y: 0.5
24569
24049
  }
24570
24050
  },
24571
- "potions/greater-life-potion.png": {
24051
+ "potions/endurance-potion.png": {
24572
24052
  frame: {
24573
24053
  x: 192,
24574
24054
  y: 144,
@@ -24592,7 +24072,7 @@ var frames$1 = {
24592
24072
  y: 0.5
24593
24073
  }
24594
24074
  },
24595
- "potions/greater-mana-potion.png": {
24075
+ "potions/greater-endurance-potion.png": {
24596
24076
  frame: {
24597
24077
  x: 192,
24598
24078
  y: 160,
@@ -24616,7 +24096,7 @@ var frames$1 = {
24616
24096
  y: 0.5
24617
24097
  }
24618
24098
  },
24619
- "potions/life-potion.png": {
24099
+ "potions/greater-life-potion.png": {
24620
24100
  frame: {
24621
24101
  x: 192,
24622
24102
  y: 176,
@@ -24640,7 +24120,7 @@ var frames$1 = {
24640
24120
  y: 0.5
24641
24121
  }
24642
24122
  },
24643
- "potions/light-antidote.png": {
24123
+ "potions/greater-mana-potion.png": {
24644
24124
  frame: {
24645
24125
  x: 0,
24646
24126
  y: 192,
@@ -24664,7 +24144,7 @@ var frames$1 = {
24664
24144
  y: 0.5
24665
24145
  }
24666
24146
  },
24667
- "potions/light-endurance-potion.png": {
24147
+ "potions/life-potion.png": {
24668
24148
  frame: {
24669
24149
  x: 16,
24670
24150
  y: 192,
@@ -24688,7 +24168,7 @@ var frames$1 = {
24688
24168
  y: 0.5
24689
24169
  }
24690
24170
  },
24691
- "potions/light-life-potion.png": {
24171
+ "potions/light-antidote.png": {
24692
24172
  frame: {
24693
24173
  x: 32,
24694
24174
  y: 192,
@@ -24712,7 +24192,7 @@ var frames$1 = {
24712
24192
  y: 0.5
24713
24193
  }
24714
24194
  },
24715
- "potions/light-mana-potion.png": {
24195
+ "potions/light-endurance-potion.png": {
24716
24196
  frame: {
24717
24197
  x: 48,
24718
24198
  y: 192,
@@ -24736,7 +24216,7 @@ var frames$1 = {
24736
24216
  y: 0.5
24737
24217
  }
24738
24218
  },
24739
- "potions/mana-potion.png": {
24219
+ "potions/light-life-potion.png": {
24740
24220
  frame: {
24741
24221
  x: 64,
24742
24222
  y: 192,
@@ -24760,7 +24240,7 @@ var frames$1 = {
24760
24240
  y: 0.5
24761
24241
  }
24762
24242
  },
24763
- "potions/stamina-potion.png": {
24243
+ "potions/light-mana-potion.png": {
24764
24244
  frame: {
24765
24245
  x: 80,
24766
24246
  y: 192,
@@ -24784,7 +24264,7 @@ var frames$1 = {
24784
24264
  y: 0.5
24785
24265
  }
24786
24266
  },
24787
- "ranged-weapons/arrow.png": {
24267
+ "potions/mana-potion.png": {
24788
24268
  frame: {
24789
24269
  x: 96,
24790
24270
  y: 192,
@@ -24808,7 +24288,7 @@ var frames$1 = {
24808
24288
  y: 0.5
24809
24289
  }
24810
24290
  },
24811
- "ranged-weapons/bolt.png": {
24291
+ "potions/stamina-potion.png": {
24812
24292
  frame: {
24813
24293
  x: 112,
24814
24294
  y: 192,
@@ -24832,7 +24312,7 @@ var frames$1 = {
24832
24312
  y: 0.5
24833
24313
  }
24834
24314
  },
24835
- "ranged-weapons/bow.png": {
24315
+ "ranged-weapons/arrow.png": {
24836
24316
  frame: {
24837
24317
  x: 128,
24838
24318
  y: 192,
@@ -24856,7 +24336,7 @@ var frames$1 = {
24856
24336
  y: 0.5
24857
24337
  }
24858
24338
  },
24859
- "ranged-weapons/compound-bow.png": {
24339
+ "ranged-weapons/bolt.png": {
24860
24340
  frame: {
24861
24341
  x: 144,
24862
24342
  y: 192,
@@ -24880,7 +24360,7 @@ var frames$1 = {
24880
24360
  y: 0.5
24881
24361
  }
24882
24362
  },
24883
- "ranged-weapons/corruption-bolt.png": {
24363
+ "ranged-weapons/bow.png": {
24884
24364
  frame: {
24885
24365
  x: 160,
24886
24366
  y: 192,
@@ -24904,7 +24384,7 @@ var frames$1 = {
24904
24384
  y: 0.5
24905
24385
  }
24906
24386
  },
24907
- "ranged-weapons/corruption-bow.png": {
24387
+ "ranged-weapons/compound-bow.png": {
24908
24388
  frame: {
24909
24389
  x: 176,
24910
24390
  y: 192,
@@ -24928,7 +24408,7 @@ var frames$1 = {
24928
24408
  y: 0.5
24929
24409
  }
24930
24410
  },
24931
- "ranged-weapons/crossbow.png": {
24411
+ "ranged-weapons/corruption-bolt.png": {
24932
24412
  frame: {
24933
24413
  x: 192,
24934
24414
  y: 192,
@@ -24952,7 +24432,7 @@ var frames$1 = {
24952
24432
  y: 0.5
24953
24433
  }
24954
24434
  },
24955
- "ranged-weapons/elden's-bow.png": {
24435
+ "ranged-weapons/corruption-bow.png": {
24956
24436
  frame: {
24957
24437
  x: 208,
24958
24438
  y: 0,
@@ -24976,7 +24456,7 @@ var frames$1 = {
24976
24456
  y: 0.5
24977
24457
  }
24978
24458
  },
24979
- "ranged-weapons/elven-bolt.png": {
24459
+ "ranged-weapons/crossbow.png": {
24980
24460
  frame: {
24981
24461
  x: 208,
24982
24462
  y: 16,
@@ -25000,7 +24480,7 @@ var frames$1 = {
25000
24480
  y: 0.5
25001
24481
  }
25002
24482
  },
25003
- "ranged-weapons/elven-bow.png": {
24483
+ "ranged-weapons/elden's-bow.png": {
25004
24484
  frame: {
25005
24485
  x: 208,
25006
24486
  y: 32,
@@ -25024,7 +24504,7 @@ var frames$1 = {
25024
24504
  y: 0.5
25025
24505
  }
25026
24506
  },
25027
- "ranged-weapons/fire-bolt.png": {
24507
+ "ranged-weapons/elven-bolt.png": {
25028
24508
  frame: {
25029
24509
  x: 208,
25030
24510
  y: 48,
@@ -25048,7 +24528,7 @@ var frames$1 = {
25048
24528
  y: 0.5
25049
24529
  }
25050
24530
  },
25051
- "ranged-weapons/frost-bow.png": {
24531
+ "ranged-weapons/elven-bow.png": {
25052
24532
  frame: {
25053
24533
  x: 208,
25054
24534
  y: 64,
@@ -25072,7 +24552,7 @@ var frames$1 = {
25072
24552
  y: 0.5
25073
24553
  }
25074
24554
  },
25075
- "ranged-weapons/frost-crossbow.png": {
24555
+ "ranged-weapons/fire-bolt.png": {
25076
24556
  frame: {
25077
24557
  x: 208,
25078
24558
  y: 80,
@@ -25096,7 +24576,7 @@ var frames$1 = {
25096
24576
  y: 0.5
25097
24577
  }
25098
24578
  },
25099
- "ranged-weapons/hellish-bow.png": {
24579
+ "ranged-weapons/frost-bow.png": {
25100
24580
  frame: {
25101
24581
  x: 208,
25102
24582
  y: 96,
@@ -25120,7 +24600,7 @@ var frames$1 = {
25120
24600
  y: 0.5
25121
24601
  }
25122
24602
  },
25123
- "ranged-weapons/horse-bow.png": {
24603
+ "ranged-weapons/frost-crossbow.png": {
25124
24604
  frame: {
25125
24605
  x: 208,
25126
24606
  y: 112,
@@ -25144,7 +24624,7 @@ var frames$1 = {
25144
24624
  y: 0.5
25145
24625
  }
25146
24626
  },
25147
- "ranged-weapons/hunters-bow.png": {
24627
+ "ranged-weapons/hellish-bow.png": {
25148
24628
  frame: {
25149
24629
  x: 208,
25150
24630
  y: 128,
@@ -25168,7 +24648,7 @@ var frames$1 = {
25168
24648
  y: 0.5
25169
24649
  }
25170
24650
  },
25171
- "ranged-weapons/long-bow.png": {
24651
+ "ranged-weapons/horse-bow.png": {
25172
24652
  frame: {
25173
24653
  x: 208,
25174
24654
  y: 144,
@@ -25192,7 +24672,7 @@ var frames$1 = {
25192
24672
  y: 0.5
25193
24673
  }
25194
24674
  },
25195
- "ranged-weapons/orcish-bow.png": {
24675
+ "ranged-weapons/hunters-bow.png": {
25196
24676
  frame: {
25197
24677
  x: 208,
25198
24678
  y: 160,
@@ -25216,7 +24696,7 @@ var frames$1 = {
25216
24696
  y: 0.5
25217
24697
  }
25218
24698
  },
25219
- "ranged-weapons/royal-bow.png": {
24699
+ "ranged-weapons/long-bow.png": {
25220
24700
  frame: {
25221
24701
  x: 208,
25222
24702
  y: 176,
@@ -25240,7 +24720,7 @@ var frames$1 = {
25240
24720
  y: 0.5
25241
24721
  }
25242
24722
  },
25243
- "ranged-weapons/royal-crossbow.png": {
24723
+ "ranged-weapons/orcish-bow.png": {
25244
24724
  frame: {
25245
24725
  x: 208,
25246
24726
  y: 192,
@@ -25264,7 +24744,7 @@ var frames$1 = {
25264
24744
  y: 0.5
25265
24745
  }
25266
24746
  },
25267
- "ranged-weapons/short-bow.png": {
24747
+ "ranged-weapons/royal-bow.png": {
25268
24748
  frame: {
25269
24749
  x: 0,
25270
24750
  y: 208,
@@ -25288,7 +24768,7 @@ var frames$1 = {
25288
24768
  y: 0.5
25289
24769
  }
25290
24770
  },
25291
- "ranged-weapons/slingshot.png": {
24771
+ "ranged-weapons/royal-crossbow.png": {
25292
24772
  frame: {
25293
24773
  x: 16,
25294
24774
  y: 208,
@@ -25312,7 +24792,7 @@ var frames$1 = {
25312
24792
  y: 0.5
25313
24793
  }
25314
24794
  },
25315
- "ranged-weapons/stone.png": {
24795
+ "ranged-weapons/short-bow.png": {
25316
24796
  frame: {
25317
24797
  x: 32,
25318
24798
  y: 208,
@@ -25336,7 +24816,7 @@ var frames$1 = {
25336
24816
  y: 0.5
25337
24817
  }
25338
24818
  },
25339
- "rings/elven-ring.png": {
24819
+ "ranged-weapons/slingshot.png": {
25340
24820
  frame: {
25341
24821
  x: 48,
25342
24822
  y: 208,
@@ -25360,7 +24840,7 @@ var frames$1 = {
25360
24840
  y: 0.5
25361
24841
  }
25362
24842
  },
25363
- "rings/golden-ring.png": {
24843
+ "ranged-weapons/stone.png": {
25364
24844
  frame: {
25365
24845
  x: 64,
25366
24846
  y: 208,
@@ -25384,7 +24864,7 @@ var frames$1 = {
25384
24864
  y: 0.5
25385
24865
  }
25386
24866
  },
25387
- "rings/haste-ring.png": {
24867
+ "rings/elven-ring.png": {
25388
24868
  frame: {
25389
24869
  x: 80,
25390
24870
  y: 208,
@@ -25408,7 +24888,7 @@ var frames$1 = {
25408
24888
  y: 0.5
25409
24889
  }
25410
24890
  },
25411
- "rings/iron-ring.png": {
24891
+ "rings/golden-ring.png": {
25412
24892
  frame: {
25413
24893
  x: 96,
25414
24894
  y: 208,
@@ -25432,7 +24912,7 @@ var frames$1 = {
25432
24912
  y: 0.5
25433
24913
  }
25434
24914
  },
25435
- "rings/jade-ring.png": {
24915
+ "rings/haste-ring.png": {
25436
24916
  frame: {
25437
24917
  x: 112,
25438
24918
  y: 208,
@@ -25456,7 +24936,7 @@ var frames$1 = {
25456
24936
  y: 0.5
25457
24937
  }
25458
24938
  },
25459
- "rings/orc-ring.png": {
24939
+ "rings/iron-ring.png": {
25460
24940
  frame: {
25461
24941
  x: 128,
25462
24942
  y: 208,
@@ -25480,7 +24960,7 @@ var frames$1 = {
25480
24960
  y: 0.5
25481
24961
  }
25482
24962
  },
25483
- "rings/ruby-ring.png": {
24963
+ "rings/jade-ring.png": {
25484
24964
  frame: {
25485
24965
  x: 144,
25486
24966
  y: 208,
@@ -25504,7 +24984,7 @@ var frames$1 = {
25504
24984
  y: 0.5
25505
24985
  }
25506
24986
  },
25507
- "rings/sapphire-ring.png": {
24987
+ "rings/orc-ring.png": {
25508
24988
  frame: {
25509
24989
  x: 160,
25510
24990
  y: 208,
@@ -25528,7 +25008,7 @@ var frames$1 = {
25528
25008
  y: 0.5
25529
25009
  }
25530
25010
  },
25531
- "rings/soldiers-ring.png": {
25011
+ "rings/ruby-ring.png": {
25532
25012
  frame: {
25533
25013
  x: 176,
25534
25014
  y: 208,
@@ -25552,10 +25032,58 @@ var frames$1 = {
25552
25032
  y: 0.5
25553
25033
  }
25554
25034
  },
25035
+ "rings/sapphire-ring.png": {
25036
+ frame: {
25037
+ x: 192,
25038
+ y: 208,
25039
+ w: 16,
25040
+ h: 16
25041
+ },
25042
+ rotated: false,
25043
+ trimmed: false,
25044
+ spriteSourceSize: {
25045
+ x: 0,
25046
+ y: 0,
25047
+ w: 16,
25048
+ h: 16
25049
+ },
25050
+ sourceSize: {
25051
+ w: 16,
25052
+ h: 16
25053
+ },
25054
+ pivot: {
25055
+ x: 0.5,
25056
+ y: 0.5
25057
+ }
25058
+ },
25059
+ "rings/soldiers-ring.png": {
25060
+ frame: {
25061
+ x: 208,
25062
+ y: 208,
25063
+ w: 16,
25064
+ h: 16
25065
+ },
25066
+ rotated: false,
25067
+ trimmed: false,
25068
+ spriteSourceSize: {
25069
+ x: 0,
25070
+ y: 0,
25071
+ w: 16,
25072
+ h: 16
25073
+ },
25074
+ sourceSize: {
25075
+ w: 16,
25076
+ h: 16
25077
+ },
25078
+ pivot: {
25079
+ x: 0.5,
25080
+ y: 0.5
25081
+ }
25082
+ },
25555
25083
  "shields/knights-shield.png": {
25556
25084
  frame: {
25557
- x: 192,
25558
- y: 208,
25085
+ x: 224,
25086
+ y: 0,
25559
25087
  w: 16,
25560
25088
  h: 16
25561
25089
  },
@@ -25578,8 +25106,8 @@ var frames$1 = {
25578
25106
  },
25579
25107
  "shields/plate-shield.png": {
25580
25108
  frame: {
25581
- x: 208,
25582
- y: 208,
25109
+ x: 224,
25110
+ y: 16,
25583
25111
  w: 16,
25584
25112
  h: 16
25585
25113
  },
@@ -25603,7 +25131,7 @@ var frames$1 = {
25603
25131
  "shields/scutum-shield.png": {
25604
25132
  frame: {
25605
25133
  x: 224,
25606
- y: 0,
25134
+ y: 32,
25607
25135
  w: 16,
25608
25136
  h: 16
25609
25137
  },
@@ -25627,7 +25155,7 @@ var frames$1 = {
25627
25155
  "shields/silver-shield.png": {
25628
25156
  frame: {
25629
25157
  x: 224,
25630
- y: 16,
25158
+ y: 48,
25631
25159
  w: 16,
25632
25160
  h: 16
25633
25161
  },
@@ -25651,7 +25179,7 @@ var frames$1 = {
25651
25179
  "shields/studded-shield.png": {
25652
25180
  frame: {
25653
25181
  x: 224,
25654
- y: 32,
25182
+ y: 64,
25655
25183
  w: 16,
25656
25184
  h: 16
25657
25185
  },
@@ -25675,7 +25203,7 @@ var frames$1 = {
25675
25203
  "shields/wooden-shield.png": {
25676
25204
  frame: {
25677
25205
  x: 224,
25678
- y: 48,
25206
+ y: 80,
25679
25207
  w: 16,
25680
25208
  h: 16
25681
25209
  },
@@ -25699,7 +25227,7 @@ var frames$1 = {
25699
25227
  "spears/bohemian-earspoon.png": {
25700
25228
  frame: {
25701
25229
  x: 224,
25702
- y: 64,
25230
+ y: 96,
25703
25231
  w: 16,
25704
25232
  h: 16
25705
25233
  },
@@ -25723,7 +25251,7 @@ var frames$1 = {
25723
25251
  "spears/corseque.png": {
25724
25252
  frame: {
25725
25253
  x: 224,
25726
- y: 80,
25254
+ y: 112,
25727
25255
  w: 16,
25728
25256
  h: 16
25729
25257
  },
@@ -25747,7 +25275,7 @@ var frames$1 = {
25747
25275
  "spears/guan-dao.png": {
25748
25276
  frame: {
25749
25277
  x: 224,
25750
- y: 96,
25278
+ y: 128,
25751
25279
  w: 16,
25752
25280
  h: 16
25753
25281
  },
@@ -25771,7 +25299,7 @@ var frames$1 = {
25771
25299
  "spears/javelin.png": {
25772
25300
  frame: {
25773
25301
  x: 224,
25774
- y: 112,
25302
+ y: 144,
25775
25303
  w: 16,
25776
25304
  h: 16
25777
25305
  },
@@ -25795,7 +25323,7 @@ var frames$1 = {
25795
25323
  "spears/royal-spear.png": {
25796
25324
  frame: {
25797
25325
  x: 224,
25798
- y: 128,
25326
+ y: 160,
25799
25327
  w: 16,
25800
25328
  h: 16
25801
25329
  },
@@ -25819,7 +25347,7 @@ var frames$1 = {
25819
25347
  "spears/spear.png": {
25820
25348
  frame: {
25821
25349
  x: 224,
25822
- y: 144,
25350
+ y: 176,
25823
25351
  w: 16,
25824
25352
  h: 16
25825
25353
  },
@@ -25843,7 +25371,7 @@ var frames$1 = {
25843
25371
  "spears/trident.png": {
25844
25372
  frame: {
25845
25373
  x: 224,
25846
- y: 160,
25374
+ y: 192,
25847
25375
  w: 16,
25848
25376
  h: 16
25849
25377
  },
@@ -25867,7 +25395,7 @@ var frames$1 = {
25867
25395
  "spell-icons/attract.png": {
25868
25396
  frame: {
25869
25397
  x: 224,
25870
- y: 176,
25398
+ y: 208,
25871
25399
  w: 16,
25872
25400
  h: 16
25873
25401
  },
@@ -25890,8 +25418,8 @@ var frames$1 = {
25890
25418
  },
25891
25419
  "spell-icons/blood-thirsty.png": {
25892
25420
  frame: {
25893
- x: 224,
25894
- y: 192,
25421
+ x: 0,
25422
+ y: 224,
25895
25423
  w: 16,
25896
25424
  h: 16
25897
25425
  },
@@ -25914,8 +25442,8 @@ var frames$1 = {
25914
25442
  },
25915
25443
  "spell-icons/degenerate.png": {
25916
25444
  frame: {
25917
- x: 224,
25918
- y: 208,
25445
+ x: 16,
25446
+ y: 224,
25919
25447
  w: 16,
25920
25448
  h: 16
25921
25449
  },
@@ -25938,7 +25466,7 @@ var frames$1 = {
25938
25466
  },
25939
25467
  "spell-icons/earth-barrier.png": {
25940
25468
  frame: {
25941
- x: 0,
25469
+ x: 32,
25942
25470
  y: 224,
25943
25471
  w: 16,
25944
25472
  h: 16
@@ -25962,7 +25490,7 @@ var frames$1 = {
25962
25490
  },
25963
25491
  "spell-icons/earth-spiker.png": {
25964
25492
  frame: {
25965
- x: 16,
25493
+ x: 48,
25966
25494
  y: 224,
25967
25495
  w: 16,
25968
25496
  h: 16
@@ -25986,7 +25514,7 @@ var frames$1 = {
25986
25514
  },
25987
25515
  "spell-icons/enchanted-arrow.png": {
25988
25516
  frame: {
25989
- x: 32,
25517
+ x: 64,
25990
25518
  y: 224,
25991
25519
  w: 16,
25992
25520
  h: 16
@@ -26010,7 +25538,7 @@ var frames$1 = {
26010
25538
  },
26011
25539
  "spell-icons/enchanted-blow.png": {
26012
25540
  frame: {
26013
- x: 48,
25541
+ x: 80,
26014
25542
  y: 224,
26015
25543
  w: 16,
26016
25544
  h: 16
@@ -26034,7 +25562,7 @@ var frames$1 = {
26034
25562
  },
26035
25563
  "spell-icons/fire-tornado.png": {
26036
25564
  frame: {
26037
- x: 64,
25565
+ x: 96,
26038
25566
  y: 224,
26039
25567
  w: 16,
26040
25568
  h: 16
@@ -26058,7 +25586,7 @@ var frames$1 = {
26058
25586
  },
26059
25587
  "spell-icons/fireball.png": {
26060
25588
  frame: {
26061
- x: 80,
25589
+ x: 112,
26062
25590
  y: 224,
26063
25591
  w: 16,
26064
25592
  h: 16
@@ -26082,7 +25610,7 @@ var frames$1 = {
26082
25610
  },
26083
25611
  "spell-icons/freeze.png": {
26084
25612
  frame: {
26085
- x: 96,
25613
+ x: 128,
26086
25614
  y: 224,
26087
25615
  w: 16,
26088
25616
  h: 16
@@ -26106,7 +25634,7 @@ var frames$1 = {
26106
25634
  },
26107
25635
  "spell-icons/haste.png": {
26108
25636
  frame: {
26109
- x: 112,
25637
+ x: 144,
26110
25638
  y: 224,
26111
25639
  w: 16,
26112
25640
  h: 16
@@ -26130,7 +25658,7 @@ var frames$1 = {
26130
25658
  },
26131
25659
  "spell-icons/icon_133.png": {
26132
25660
  frame: {
26133
- x: 128,
25661
+ x: 160,
26134
25662
  y: 224,
26135
25663
  w: 16,
26136
25664
  h: 16
@@ -26154,7 +25682,7 @@ var frames$1 = {
26154
25682
  },
26155
25683
  "spell-icons/lighting-bolt.png": {
26156
25684
  frame: {
26157
- x: 144,
25685
+ x: 176,
26158
25686
  y: 224,
26159
25687
  w: 16,
26160
25688
  h: 16
@@ -26178,7 +25706,7 @@ var frames$1 = {
26178
25706
  },
26179
25707
  "spell-icons/lighting-field.png": {
26180
25708
  frame: {
26181
- x: 160,
25709
+ x: 192,
26182
25710
  y: 224,
26183
25711
  w: 16,
26184
25712
  h: 16
@@ -26202,7 +25730,7 @@ var frames$1 = {
26202
25730
  },
26203
25731
  "spell-icons/magic-shield.png": {
26204
25732
  frame: {
26205
- x: 176,
25733
+ x: 208,
26206
25734
  y: 224,
26207
25735
  w: 16,
26208
25736
  h: 16
@@ -26226,7 +25754,7 @@ var frames$1 = {
26226
25754
  },
26227
25755
  "spell-icons/poison-arrow.png": {
26228
25756
  frame: {
26229
- x: 192,
25757
+ x: 224,
26230
25758
  y: 224,
26231
25759
  w: 16,
26232
25760
  h: 16
@@ -26250,8 +25778,8 @@ var frames$1 = {
26250
25778
  },
26251
25779
  "spell-icons/poison-blow.png": {
26252
25780
  frame: {
26253
- x: 208,
26254
- y: 224,
25781
+ x: 240,
25782
+ y: 0,
26255
25783
  w: 16,
26256
25784
  h: 16
26257
25785
  },
@@ -26274,8 +25802,8 @@ var frames$1 = {
26274
25802
  },
26275
25803
  "spell-icons/poison-field.png": {
26276
25804
  frame: {
26277
- x: 224,
26278
- y: 224,
25805
+ x: 240,
25806
+ y: 16,
26279
25807
  w: 16,
26280
25808
  h: 16
26281
25809
  },
@@ -26299,7 +25827,7 @@ var frames$1 = {
26299
25827
  "spell-icons/poison-tornado.png": {
26300
25828
  frame: {
26301
25829
  x: 240,
26302
- y: 0,
25830
+ y: 32,
26303
25831
  w: 16,
26304
25832
  h: 16
26305
25833
  },
@@ -26323,7 +25851,7 @@ var frames$1 = {
26323
25851
  "spell-icons/regenerate.png": {
26324
25852
  frame: {
26325
25853
  x: 240,
26326
- y: 16,
25854
+ y: 48,
26327
25855
  w: 16,
26328
25856
  h: 16
26329
25857
  },
@@ -26347,7 +25875,7 @@ var frames$1 = {
26347
25875
  "spell-icons/sleep.png": {
26348
25876
  frame: {
26349
25877
  x: 240,
26350
- y: 32,
25878
+ y: 64,
26351
25879
  w: 16,
26352
25880
  h: 16
26353
25881
  },
@@ -26371,7 +25899,7 @@ var frames$1 = {
26371
25899
  "spell-icons/soul-death.png": {
26372
25900
  frame: {
26373
25901
  x: 240,
26374
- y: 48,
25902
+ y: 80,
26375
25903
  w: 16,
26376
25904
  h: 16
26377
25905
  },
@@ -26395,7 +25923,7 @@ var frames$1 = {
26395
25923
  "spell-icons/tsunami.png": {
26396
25924
  frame: {
26397
25925
  x: 240,
26398
- y: 64,
25926
+ y: 96,
26399
25927
  w: 16,
26400
25928
  h: 16
26401
25929
  },
@@ -26419,7 +25947,7 @@ var frames$1 = {
26419
25947
  "staffs/air-wand.png": {
26420
25948
  frame: {
26421
25949
  x: 240,
26422
- y: 80,
25950
+ y: 112,
26423
25951
  w: 16,
26424
25952
  h: 16
26425
25953
  },
@@ -26443,7 +25971,7 @@ var frames$1 = {
26443
25971
  "staffs/appendice's-staff.png": {
26444
25972
  frame: {
26445
25973
  x: 240,
26446
- y: 96,
25974
+ y: 128,
26447
25975
  w: 16,
26448
25976
  h: 16
26449
25977
  },
@@ -26467,7 +25995,7 @@ var frames$1 = {
26467
25995
  "staffs/corruption-staff.png": {
26468
25996
  frame: {
26469
25997
  x: 240,
26470
- y: 112,
25998
+ y: 144,
26471
25999
  w: 16,
26472
26000
  h: 16
26473
26001
  },
@@ -26491,7 +26019,7 @@ var frames$1 = {
26491
26019
  "staffs/enchanted-staff.png": {
26492
26020
  frame: {
26493
26021
  x: 240,
26494
- y: 128,
26022
+ y: 160,
26495
26023
  w: 16,
26496
26024
  h: 16
26497
26025
  },
@@ -26515,7 +26043,7 @@ var frames$1 = {
26515
26043
  "staffs/fire-staff.png": {
26516
26044
  frame: {
26517
26045
  x: 240,
26518
- y: 144,
26046
+ y: 176,
26519
26047
  w: 16,
26520
26048
  h: 16
26521
26049
  },
@@ -26539,7 +26067,7 @@ var frames$1 = {
26539
26067
  "staffs/fire-wand.png": {
26540
26068
  frame: {
26541
26069
  x: 240,
26542
- y: 160,
26070
+ y: 192,
26543
26071
  w: 16,
26544
26072
  h: 16
26545
26073
  },
@@ -26563,7 +26091,7 @@ var frames$1 = {
26563
26091
  "staffs/moon's-staff.png": {
26564
26092
  frame: {
26565
26093
  x: 240,
26566
- y: 176,
26094
+ y: 208,
26567
26095
  w: 16,
26568
26096
  h: 16
26569
26097
  },
@@ -26587,7 +26115,7 @@ var frames$1 = {
26587
26115
  "staffs/poison-staff.png": {
26588
26116
  frame: {
26589
26117
  x: 240,
26590
- y: 192,
26118
+ y: 224,
26591
26119
  w: 16,
26592
26120
  h: 16
26593
26121
  },
@@ -26610,8 +26138,8 @@ var frames$1 = {
26610
26138
  },
26611
26139
  "staffs/poison-wand.png": {
26612
26140
  frame: {
26613
- x: 240,
26614
- y: 208,
26141
+ x: 0,
26142
+ y: 240,
26615
26143
  w: 16,
26616
26144
  h: 16
26617
26145
  },
@@ -26634,8 +26162,8 @@ var frames$1 = {
26634
26162
  },
26635
26163
  "staffs/royal-staff.png": {
26636
26164
  frame: {
26637
- x: 240,
26638
- y: 224,
26165
+ x: 16,
26166
+ y: 240,
26639
26167
  w: 16,
26640
26168
  h: 16
26641
26169
  },
@@ -26658,7 +26186,7 @@ var frames$1 = {
26658
26186
  },
26659
26187
  "staffs/ruby-staff.png": {
26660
26188
  frame: {
26661
- x: 0,
26189
+ x: 32,
26662
26190
  y: 240,
26663
26191
  w: 16,
26664
26192
  h: 16
@@ -26682,7 +26210,7 @@ var frames$1 = {
26682
26210
  },
26683
26211
  "staffs/soul-staff.png": {
26684
26212
  frame: {
26685
- x: 16,
26213
+ x: 48,
26686
26214
  y: 240,
26687
26215
  w: 16,
26688
26216
  h: 16
@@ -26706,7 +26234,7 @@ var frames$1 = {
26706
26234
  },
26707
26235
  "staffs/wand.png": {
26708
26236
  frame: {
26709
- x: 32,
26237
+ x: 64,
26710
26238
  y: 240,
26711
26239
  w: 16,
26712
26240
  h: 16
@@ -26730,7 +26258,7 @@ var frames$1 = {
26730
26258
  },
26731
26259
  "swords/basilisk-sword.png": {
26732
26260
  frame: {
26733
- x: 48,
26261
+ x: 80,
26734
26262
  y: 240,
26735
26263
  w: 16,
26736
26264
  h: 16
@@ -26754,7 +26282,7 @@ var frames$1 = {
26754
26282
  },
26755
26283
  "swords/broad-sword.png": {
26756
26284
  frame: {
26757
- x: 64,
26285
+ x: 96,
26758
26286
  y: 240,
26759
26287
  w: 16,
26760
26288
  h: 16
@@ -26778,7 +26306,7 @@ var frames$1 = {
26778
26306
  },
26779
26307
  "swords/corruption-sword.png": {
26780
26308
  frame: {
26781
- x: 80,
26309
+ x: 112,
26782
26310
  y: 240,
26783
26311
  w: 16,
26784
26312
  h: 16
@@ -26802,7 +26330,7 @@ var frames$1 = {
26802
26330
  },
26803
26331
  "swords/damascus-sword.png": {
26804
26332
  frame: {
26805
- x: 96,
26333
+ x: 128,
26806
26334
  y: 240,
26807
26335
  w: 16,
26808
26336
  h: 16
@@ -26826,7 +26354,7 @@ var frames$1 = {
26826
26354
  },
26827
26355
  "swords/double-edged-sword.png": {
26828
26356
  frame: {
26829
- x: 112,
26357
+ x: 144,
26830
26358
  y: 240,
26831
26359
  w: 16,
26832
26360
  h: 16
@@ -26850,7 +26378,7 @@ var frames$1 = {
26850
26378
  },
26851
26379
  "swords/dragon's-sword.png": {
26852
26380
  frame: {
26853
- x: 128,
26381
+ x: 160,
26854
26382
  y: 240,
26855
26383
  w: 16,
26856
26384
  h: 16
@@ -26874,7 +26402,7 @@ var frames$1 = {
26874
26402
  },
26875
26403
  "swords/dragon-sword.png": {
26876
26404
  frame: {
26877
- x: 144,
26405
+ x: 176,
26878
26406
  y: 240,
26879
26407
  w: 16,
26880
26408
  h: 16
@@ -26898,7 +26426,7 @@ var frames$1 = {
26898
26426
  },
26899
26427
  "swords/elden's-sword.png": {
26900
26428
  frame: {
26901
- x: 160,
26429
+ x: 192,
26902
26430
  y: 240,
26903
26431
  w: 16,
26904
26432
  h: 16
@@ -26922,7 +26450,7 @@ var frames$1 = {
26922
26450
  },
26923
26451
  "swords/elven-sword.png": {
26924
26452
  frame: {
26925
- x: 176,
26453
+ x: 208,
26926
26454
  y: 240,
26927
26455
  w: 16,
26928
26456
  h: 16
@@ -26946,7 +26474,7 @@ var frames$1 = {
26946
26474
  },
26947
26475
  "swords/enchanted-sword.png": {
26948
26476
  frame: {
26949
- x: 192,
26477
+ x: 224,
26950
26478
  y: 240,
26951
26479
  w: 16,
26952
26480
  h: 16
@@ -26970,7 +26498,7 @@ var frames$1 = {
26970
26498
  },
26971
26499
  "swords/fire-sword.png": {
26972
26500
  frame: {
26973
- x: 208,
26501
+ x: 240,
26974
26502
  y: 240,
26975
26503
  w: 16,
26976
26504
  h: 16
@@ -26994,8 +26522,8 @@ var frames$1 = {
26994
26522
  },
26995
26523
  "swords/golden-sword.png": {
26996
26524
  frame: {
26997
- x: 224,
26998
- y: 240,
26525
+ x: 256,
26526
+ y: 0,
26999
26527
  w: 16,
27000
26528
  h: 16
27001
26529
  },
@@ -27018,8 +26546,8 @@ var frames$1 = {
27018
26546
  },
27019
26547
  "swords/katana.png": {
27020
26548
  frame: {
27021
- x: 240,
27022
- y: 240,
26549
+ x: 256,
26550
+ y: 16,
27023
26551
  w: 16,
27024
26552
  h: 16
27025
26553
  },
@@ -27043,7 +26571,7 @@ var frames$1 = {
27043
26571
  "swords/knights-sword.png": {
27044
26572
  frame: {
27045
26573
  x: 256,
27046
- y: 0,
26574
+ y: 32,
27047
26575
  w: 16,
27048
26576
  h: 16
27049
26577
  },
@@ -27067,7 +26595,7 @@ var frames$1 = {
27067
26595
  "swords/leviathan-sword.png": {
27068
26596
  frame: {
27069
26597
  x: 256,
27070
- y: 16,
26598
+ y: 48,
27071
26599
  w: 16,
27072
26600
  h: 16
27073
26601
  },
@@ -27091,7 +26619,7 @@ var frames$1 = {
27091
26619
  "swords/lighting-sword.png": {
27092
26620
  frame: {
27093
26621
  x: 256,
27094
- y: 32,
26622
+ y: 64,
27095
26623
  w: 16,
27096
26624
  h: 16
27097
26625
  },
@@ -27115,7 +26643,7 @@ var frames$1 = {
27115
26643
  "swords/long-sword.png": {
27116
26644
  frame: {
27117
26645
  x: 256,
27118
- y: 48,
26646
+ y: 80,
27119
26647
  w: 16,
27120
26648
  h: 16
27121
26649
  },
@@ -27139,7 +26667,7 @@ var frames$1 = {
27139
26667
  "swords/mithril-sword.png": {
27140
26668
  frame: {
27141
26669
  x: 256,
27142
- y: 64,
26670
+ y: 96,
27143
26671
  w: 16,
27144
26672
  h: 16
27145
26673
  },
@@ -27163,7 +26691,7 @@ var frames$1 = {
27163
26691
  "swords/rapier.png": {
27164
26692
  frame: {
27165
26693
  x: 256,
27166
- y: 80,
26694
+ y: 112,
27167
26695
  w: 16,
27168
26696
  h: 16
27169
26697
  },
@@ -27187,7 +26715,7 @@ var frames$1 = {
27187
26715
  "swords/saber.png": {
27188
26716
  frame: {
27189
26717
  x: 256,
27190
- y: 96,
26718
+ y: 128,
27191
26719
  w: 16,
27192
26720
  h: 16
27193
26721
  },
@@ -27211,7 +26739,7 @@ var frames$1 = {
27211
26739
  "swords/short-sword.png": {
27212
26740
  frame: {
27213
26741
  x: 256,
27214
- y: 112,
26742
+ y: 144,
27215
26743
  w: 16,
27216
26744
  h: 16
27217
26745
  },
@@ -27235,7 +26763,7 @@ var frames$1 = {
27235
26763
  "swords/sword.png": {
27236
26764
  frame: {
27237
26765
  x: 256,
27238
- y: 128,
26766
+ y: 160,
27239
26767
  w: 16,
27240
26768
  h: 16
27241
26769
  },
@@ -27257,23 +26785,610 @@ var frames$1 = {
27257
26785
  }
27258
26786
  }
27259
26787
  };
27260
- var meta$1 = {
27261
- app: "http://free-tex-packer.com",
27262
- version: "0.6.7",
27263
- image: "items.png",
27264
- format: "RGBA8888",
27265
- size: {
27266
- w: 320,
27267
- h: 320
27268
- },
27269
- scale: 1
26788
+ var meta$1 = {
26789
+ app: "http://free-tex-packer.com",
26790
+ version: "0.6.7",
26791
+ image: "items.png",
26792
+ format: "RGBA8888",
26793
+ size: {
26794
+ w: 320,
26795
+ h: 320
26796
+ },
26797
+ scale: 1
26798
+ };
26799
+ var atlasJSON = {
26800
+ frames: frames$1,
26801
+ meta: meta$1
26802
+ };
26803
+
26804
+ var img$1 = '';
26805
+
26806
+ var ErrorBoundary = /*#__PURE__*/function (_Component) {
26807
+ _inheritsLoose(ErrorBoundary, _Component);
26808
+
26809
+ function ErrorBoundary() {
26810
+ var _this;
26811
+
26812
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
26813
+ args[_key] = arguments[_key];
26814
+ }
26815
+
26816
+ _this = _Component.call.apply(_Component, [this].concat(args)) || this;
26817
+ _this.state = {
26818
+ hasError: false
26819
+ };
26820
+ return _this;
26821
+ }
26822
+
26823
+ ErrorBoundary.getDerivedStateFromError = function getDerivedStateFromError(_) {
26824
+ // Update state so the next render will show the fallback UI.
26825
+ return {
26826
+ hasError: true
26827
+ };
26828
+ };
26829
+
26830
+ var _proto = ErrorBoundary.prototype;
26831
+
26832
+ _proto.componentDidCatch = function componentDidCatch(error, errorInfo) {
26833
+ console.error('Uncaught error:', error, errorInfo);
26834
+ console.log('quelquer cois');
26835
+ };
26836
+
26837
+ _proto.render = function render() {
26838
+ if (this.state.hasError) {
26839
+ return React__default.createElement(SpriteFromAtlas, {
26840
+ atlasIMG: img$1,
26841
+ atlasJSON: atlasJSON,
26842
+ spriteKey: 'others/no-image.png',
26843
+ imgScale: 3
26844
+ });
26845
+ }
26846
+
26847
+ return this.props.children;
26848
+ };
26849
+
26850
+ return ErrorBoundary;
26851
+ }(React.Component);
26852
+
26853
+ var Ellipsis = function Ellipsis(_ref) {
26854
+ var children = _ref.children,
26855
+ maxLines = _ref.maxLines;
26856
+ console.log('Ellipsis Component 2');
26857
+ return React__default.createElement(Container$1, null, React__default.createElement("div", {
26858
+ className: "ellipsis-" + maxLines + "-lines"
26859
+ }, children));
26860
+ };
26861
+ var Container$1 = /*#__PURE__*/styled.div.withConfig({
26862
+ displayName: "Ellipsis__Container",
26863
+ componentId: "sc-ysrlju-0"
26864
+ })([".ellipsis-1-lines{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;}.ellipsis-2-lines{display:-webkit-box;max-width:100%;height:25px;margin:0 auto;line-height:1;-webkit-line-clamp:2;-webkit-box-orient:vertical;text-overflow:ellipsis;overflow:hidden;}.ellipsis-3-lines{display:-webkit-box;max-width:100%;height:43px;margin:0 auto;line-height:1;-webkit-line-clamp:3;-webkit-box-orient:vertical;text-overflow:ellipsis;overflow:hidden;}"]);
26865
+
26866
+ var img$2 = '';
26867
+
26868
+ var img$3 = '';
26869
+
26870
+ var img$4 = '';
26871
+
26872
+ var img$5 = '';
26873
+
26874
+ var PropertySelect = function PropertySelect(_ref) {
26875
+ var availableProperties = _ref.availableProperties,
26876
+ onChange = _ref.onChange;
26877
+
26878
+ var _useState = React.useState(0),
26879
+ currentIndex = _useState[0],
26880
+ setCurrentIndex = _useState[1];
26881
+
26882
+ var propertiesLength = availableProperties.length - 1;
26883
+
26884
+ var onLeftClick = function onLeftClick() {
26885
+ if (currentIndex === 0) setCurrentIndex(propertiesLength);else setCurrentIndex(function (index) {
26886
+ return index - 1;
26887
+ });
26888
+ };
26889
+
26890
+ var onRightClick = function onRightClick() {
26891
+ if (currentIndex === propertiesLength) setCurrentIndex(0);else setCurrentIndex(function (index) {
26892
+ return index + 1;
26893
+ });
26894
+ };
26895
+
26896
+ React.useEffect(function () {
26897
+ onChange(availableProperties[currentIndex]);
26898
+ }, [currentIndex]);
26899
+ React.useEffect(function () {
26900
+ setCurrentIndex(0);
26901
+ }, [JSON.stringify(availableProperties)]);
26902
+
26903
+ var getCurrentSelectionName = function getCurrentSelectionName() {
26904
+ var item = availableProperties[currentIndex];
26905
+
26906
+ if (item) {
26907
+ return item.name;
26908
+ }
26909
+
26910
+ return '';
26911
+ };
26912
+
26913
+ return React__default.createElement(Container$2, null, React__default.createElement(TextOverlay, null, React__default.createElement(Item, null, React__default.createElement(Ellipsis, {
26914
+ maxLines: 1
26915
+ }, getCurrentSelectionName()))), React__default.createElement("div", {
26916
+ className: "rpgui-progress-track"
26917
+ }), React__default.createElement(LeftArrow, {
26918
+ onClick: onLeftClick,
26919
+ onTouchStart: onLeftClick
26920
+ }), React__default.createElement(RightArrow, {
26921
+ onClick: onRightClick,
26922
+ onTouchStart: onRightClick
26923
+ }));
26924
+ };
26925
+ var Item = /*#__PURE__*/styled.span.withConfig({
26926
+ displayName: "PropertySelect__Item",
26927
+ componentId: "sc-12uqx6s-0"
26928
+ })(["font-size:1rem;color:white;text-align:center;z-index:1;position:absolute;top:12px;width:100%;"]);
26929
+ var TextOverlay = /*#__PURE__*/styled.div.withConfig({
26930
+ displayName: "PropertySelect__TextOverlay",
26931
+ componentId: "sc-12uqx6s-1"
26932
+ })(["width:100%;position:relative;"]);
26933
+ var Container$2 = /*#__PURE__*/styled.div.withConfig({
26934
+ displayName: "PropertySelect__Container",
26935
+ componentId: "sc-12uqx6s-2"
26936
+ })(["position:relative;display:flex;flex-direction:column;justify-content:start;align-items:flex-start;min-width:100px;width:40%;"]);
26937
+ var LeftArrow = /*#__PURE__*/styled.div.withConfig({
26938
+ displayName: "PropertySelect__LeftArrow",
26939
+ componentId: "sc-12uqx6s-3"
26940
+ })(["background-image:url(", ");background-size:100% 100%;left:0;position:absolute;width:40px;height:42px;:active{background-image:url(", ");}z-index:2;"], img$3, img$2);
26941
+ var RightArrow = /*#__PURE__*/styled.div.withConfig({
26942
+ displayName: "PropertySelect__RightArrow",
26943
+ componentId: "sc-12uqx6s-4"
26944
+ })(["background-image:url(", ");right:0;position:absolute;width:40px;background-size:100% 100%;height:42px;:active{background-image:url(", ");}z-index:2;"], img$5, img$4);
26945
+
26946
+ var CharacterSelection = function CharacterSelection(_ref) {
26947
+ var availableCharacters = _ref.availableCharacters,
26948
+ onChange = _ref.onChange;
26949
+ var propertySelectValues = availableCharacters.map(function (item) {
26950
+ return {
26951
+ id: item.textureKey,
26952
+ name: item.name
26953
+ };
26954
+ });
26955
+
26956
+ var _useState = React.useState(),
26957
+ selectedValue = _useState[0],
26958
+ setSelectedValue = _useState[1];
26959
+
26960
+ var _useState2 = React.useState(''),
26961
+ selectedSpriteKey = _useState2[0],
26962
+ setSelectedSpriteKey = _useState2[1];
26963
+
26964
+ var onSelectedValueChange = function onSelectedValueChange() {
26965
+ var textureKey = selectedValue ? selectedValue.id : '';
26966
+ var spriteKey = textureKey ? textureKey + '/down/standing/0.png' : '';
26967
+
26968
+ if (spriteKey == selectedSpriteKey) {
26969
+ return;
26970
+ }
26971
+
26972
+ setSelectedSpriteKey(spriteKey);
26973
+ onChange(textureKey);
26974
+ };
26975
+
26976
+ React.useEffect(function () {
26977
+ onSelectedValueChange();
26978
+ }, [selectedValue]);
26979
+ React.useEffect(function () {
26980
+ setSelectedValue(propertySelectValues[0]);
26981
+ }, [availableCharacters]);
26982
+ return React__default.createElement(Container$3, null, selectedSpriteKey && React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
26983
+ spriteKey: selectedSpriteKey,
26984
+ atlasIMG: img,
26985
+ atlasJSON: entitiesJSON,
26986
+ imgScale: 4,
26987
+ height: 80,
26988
+ width: 64,
26989
+ containerStyle: {
26990
+ display: 'flex',
26991
+ alignItems: 'center',
26992
+ paddingBottom: '15px'
26993
+ },
26994
+ imgStyle: {
26995
+ left: '22px'
26996
+ }
26997
+ })), React__default.createElement(PropertySelect, {
26998
+ availableProperties: propertySelectValues,
26999
+ onChange: function onChange(value) {
27000
+ setSelectedValue(value);
27001
+ }
27002
+ }));
27003
+ };
27004
+ var Container$3 = /*#__PURE__*/styled.div.withConfig({
27005
+ displayName: "CharacterSelection__Container",
27006
+ componentId: "sc-b34498-0"
27007
+ })(["display:flex;flex-direction:column;align-items:center;image-rendering:pixelated;"]);
27008
+
27009
+ var colors = {
27010
+ darkGrey: '#3e3e3e',
27011
+ darkYellow: '#FFC857',
27012
+ orange: '#E9724C',
27013
+ cardinal: '#C5283D',
27014
+ raisinBlack: '#191923',
27015
+ navyBlue: '#0E79B2',
27016
+ purple: '#8C3D8C',
27017
+ blue: '#3772FF'
27018
+ };
27019
+
27020
+ var Input = function Input(_ref) {
27021
+ var props = _extends({}, _ref);
27022
+
27023
+ return React__default.createElement("input", Object.assign({}, props));
27024
+ };
27025
+
27026
+ (function (RPGUIContainerTypes) {
27027
+ RPGUIContainerTypes["Framed"] = "framed";
27028
+ RPGUIContainerTypes["FramedGold"] = "framed-golden";
27029
+ RPGUIContainerTypes["FramedGold2"] = "framed-golden-2";
27030
+ RPGUIContainerTypes["FramedGrey"] = "framed-grey";
27031
+ })(exports.RPGUIContainerTypes || (exports.RPGUIContainerTypes = {}));
27032
+
27033
+ var RPGUIContainer = function RPGUIContainer(_ref) {
27034
+ var children = _ref.children,
27035
+ type = _ref.type,
27036
+ _ref$width = _ref.width,
27037
+ width = _ref$width === void 0 ? '50%' : _ref$width,
27038
+ height = _ref.height,
27039
+ className = _ref.className;
27040
+ return React__default.createElement(Container$4, {
27041
+ width: width,
27042
+ height: height || 'auto',
27043
+ className: "rpgui-container " + type + " " + className
27044
+ }, children);
27045
+ };
27046
+ var Container$4 = /*#__PURE__*/styled.div.withConfig({
27047
+ displayName: "RPGUIContainer__Container",
27048
+ componentId: "sc-a8l4p8-0"
27049
+ })(["height:", ";width:", ";display:flex;flex-wrap:wrap;image-rendering:pixelated;"], function (props) {
27050
+ return props.height;
27051
+ }, function (_ref2) {
27052
+ var width = _ref2.width;
27053
+ return width;
27054
+ });
27055
+
27056
+ var Column = /*#__PURE__*/styled.div.withConfig({
27057
+ displayName: "Column",
27058
+ componentId: "sc-1pesqff-0"
27059
+ })(["flex:", ";display:flex;flex-wrap:", ";align-items:", ";justify-content:", ";"], function (props) {
27060
+ return props.flex || 'auto';
27061
+ }, function (props) {
27062
+ return props.flexWrap || 'nowrap';
27063
+ }, function (props) {
27064
+ return props.alignItems || 'flex-start';
27065
+ }, function (props) {
27066
+ return props.justifyContent || 'flex-start';
27067
+ });
27068
+
27069
+ var Chat = function Chat(_ref) {
27070
+ var chatMessages = _ref.chatMessages,
27071
+ onSendChatMessage = _ref.onSendChatMessage,
27072
+ _ref$opacity = _ref.opacity,
27073
+ opacity = _ref$opacity === void 0 ? 1 : _ref$opacity,
27074
+ _ref$width = _ref.width,
27075
+ width = _ref$width === void 0 ? '100%' : _ref$width,
27076
+ _ref$height = _ref.height,
27077
+ height = _ref$height === void 0 ? '250px' : _ref$height,
27078
+ onCloseButton = _ref.onCloseButton;
27079
+
27080
+ var _useState = React.useState(''),
27081
+ message = _useState[0],
27082
+ setMessage = _useState[1];
27083
+
27084
+ React.useEffect(function () {
27085
+ scrollChatToBottom();
27086
+ }, []);
27087
+ React.useEffect(function () {
27088
+ scrollChatToBottom();
27089
+ }, [chatMessages]);
27090
+
27091
+ var scrollChatToBottom = function scrollChatToBottom() {
27092
+ var scrollingElement = document.querySelector('.chat-body');
27093
+
27094
+ if (scrollingElement) {
27095
+ scrollingElement.scrollTop = scrollingElement.scrollHeight;
27096
+ }
27097
+ };
27098
+
27099
+ var handleSubmit = function handleSubmit(event) {
27100
+ event.preventDefault();
27101
+ onSendChatMessage(message);
27102
+ setMessage('');
27103
+ };
27104
+
27105
+ var getInputValue = function getInputValue(value) {
27106
+ setMessage(value);
27107
+ };
27108
+
27109
+ var onRenderMessageLines = function onRenderMessageLines(emitter, createdAt, message) {
27110
+ return dayjs(createdAt || new Date()).format('HH:mm') + " " + (emitter != null && emitter.name ? emitter.name + ": " : 'Unknown: ') + " " + message;
27111
+ };
27112
+
27113
+ var onRenderChatMessages = function onRenderChatMessages(chatMessages) {
27114
+ return chatMessages != null && chatMessages.length ? chatMessages == null ? void 0 : chatMessages.map(function (_ref2, index) {
27115
+ var _id = _ref2._id,
27116
+ createdAt = _ref2.createdAt,
27117
+ emitter = _ref2.emitter,
27118
+ message = _ref2.message;
27119
+ return React__default.createElement(MessageText, {
27120
+ key: _id + "_" + index
27121
+ }, onRenderMessageLines(emitter, createdAt, message));
27122
+ }) : React__default.createElement(MessageText, null, "No messages available.");
27123
+ };
27124
+
27125
+ return React__default.createElement(Container$5, null, React__default.createElement(CustomContainer, {
27126
+ type: exports.RPGUIContainerTypes.FramedGrey,
27127
+ width: width,
27128
+ height: height,
27129
+ className: "chat-container",
27130
+ opacity: opacity
27131
+ }, React__default.createElement(reactErrorBoundary.ErrorBoundary, {
27132
+ fallback: React__default.createElement("p", null, "Oops! Your chat has crashed.")
27133
+ }, onCloseButton && React__default.createElement(CloseButton, {
27134
+ onClick: onCloseButton,
27135
+ onTouchStart: onCloseButton
27136
+ }, "X"), React__default.createElement(RPGUIContainer, {
27137
+ type: exports.RPGUIContainerTypes.FramedGrey,
27138
+ width: '100%',
27139
+ height: '80%',
27140
+ className: "chat-body dark-background"
27141
+ }, onRenderChatMessages(chatMessages)), React__default.createElement(Form, {
27142
+ onSubmit: handleSubmit
27143
+ }, React__default.createElement(Column, {
27144
+ flex: 70
27145
+ }, React__default.createElement(CustomInput, {
27146
+ value: message,
27147
+ id: "inputMessage",
27148
+ onChange: function onChange(e) {
27149
+ return getInputValue(e.target.value);
27150
+ },
27151
+ height: 20,
27152
+ className: "chat-input dark-background",
27153
+ type: "text",
27154
+ autoComplete: "off"
27155
+ })), React__default.createElement(Column, {
27156
+ justifyContent: "flex-end"
27157
+ }, React__default.createElement(Button, {
27158
+ buttonType: exports.ButtonTypes.RPGUIButton,
27159
+ id: "chat-send-button"
27160
+ }, "Send"))))));
27161
+ };
27162
+ var Container$5 = /*#__PURE__*/styled.div.withConfig({
27163
+ displayName: "Chat__Container",
27164
+ componentId: "sc-1bk05n6-0"
27165
+ })(["position:relative;"]);
27166
+ var CloseButton = /*#__PURE__*/styled.div.withConfig({
27167
+ displayName: "Chat__CloseButton",
27168
+ componentId: "sc-1bk05n6-1"
27169
+ })(["position:absolute;top:2px;right:0px;color:white;z-index:22;font-size:0.7rem;"]);
27170
+ var CustomInput = /*#__PURE__*/styled(Input).withConfig({
27171
+ displayName: "Chat__CustomInput",
27172
+ componentId: "sc-1bk05n6-2"
27173
+ })(["height:30px;width:100%;.rpgui-content .input{min-height:39px;}"]);
27174
+ var CustomContainer = /*#__PURE__*/styled(RPGUIContainer).withConfig({
27175
+ displayName: "Chat__CustomContainer",
27176
+ componentId: "sc-1bk05n6-3"
27177
+ })(["display:block;opacity:", ";&:hover{opacity:1;}.dark-background{background-color:", " !important;}.chat-body{&.rpgui-container.framed-grey{background:unset;}max-height:170px;overflow-y:auto;}"], function (props) {
27178
+ return props.opacity;
27179
+ }, colors.darkGrey);
27180
+ var Form = /*#__PURE__*/styled.form.withConfig({
27181
+ displayName: "Chat__Form",
27182
+ componentId: "sc-1bk05n6-4"
27183
+ })(["display:flex;width:100%;justify-content:center;align-items:center;"]);
27184
+ var MessageText = /*#__PURE__*/styled.p.withConfig({
27185
+ displayName: "Chat__MessageText",
27186
+ componentId: "sc-1bk05n6-5"
27187
+ })(["display:block !important;width:100%;font-size:0.7rem !important;overflow-y:auto;margin:0;"]);
27188
+
27189
+ var CheckButton = function CheckButton(_ref) {
27190
+ var items = _ref.items,
27191
+ onChange = _ref.onChange;
27192
+
27193
+ var generateSelectedValuesList = function generateSelectedValuesList() {
27194
+ var selectedValues = {};
27195
+ items.forEach(function (item) {
27196
+ selectedValues[item.label] = false;
27197
+ });
27198
+ return selectedValues;
27199
+ };
27200
+
27201
+ var _useState = React.useState(generateSelectedValuesList()),
27202
+ selectedValues = _useState[0],
27203
+ setSelectedValues = _useState[1];
27204
+
27205
+ var handleClick = function handleClick(label) {
27206
+ var _extends2;
27207
+
27208
+ setSelectedValues(_extends({}, selectedValues, (_extends2 = {}, _extends2[label] = !selectedValues[label], _extends2)));
27209
+ };
27210
+
27211
+ React.useEffect(function () {
27212
+ if (selectedValues) {
27213
+ onChange(selectedValues);
27214
+ }
27215
+ }, [selectedValues]);
27216
+ return React__default.createElement("div", {
27217
+ id: "elemento-checkbox"
27218
+ }, items == null ? void 0 : items.map(function (element, index) {
27219
+ return React__default.createElement("div", {
27220
+ key: element.label + "_" + index
27221
+ }, React__default.createElement("input", {
27222
+ className: "rpgui-checkbox",
27223
+ type: "checkbox",
27224
+ checked: selectedValues[element.label],
27225
+ onChange: function onChange() {}
27226
+ }), React__default.createElement("label", {
27227
+ onClick: function onClick() {
27228
+ return handleClick(element.label);
27229
+ }
27230
+ }, element.label), React__default.createElement("br", null));
27231
+ }));
27232
+ };
27233
+
27234
+ function useOutsideClick(ref, id) {
27235
+ React.useEffect(function () {
27236
+ /**
27237
+ * Alert if clicked on outside of element
27238
+ */
27239
+ function handleClickOutside(event) {
27240
+ if (ref.current && !ref.current.contains(event.target)) {
27241
+ var _event = new CustomEvent('clickOutside', {
27242
+ detail: {
27243
+ id: id
27244
+ }
27245
+ });
27246
+
27247
+ document.dispatchEvent(_event);
27248
+ }
27249
+ } // Bind the event listener
27250
+
27251
+
27252
+ document.addEventListener('mousedown', handleClickOutside);
27253
+ return function () {
27254
+ // Unbind the event listener on clean up
27255
+ document.removeEventListener('mousedown', handleClickOutside);
27256
+ };
27257
+ }, [ref]);
27258
+ }
27259
+
27260
+ var DraggableContainer = function DraggableContainer(_ref) {
27261
+ var children = _ref.children,
27262
+ _ref$width = _ref.width,
27263
+ width = _ref$width === void 0 ? '50%' : _ref$width,
27264
+ height = _ref.height,
27265
+ className = _ref.className,
27266
+ _ref$type = _ref.type,
27267
+ type = _ref$type === void 0 ? exports.RPGUIContainerTypes.FramedGold : _ref$type,
27268
+ onCloseButton = _ref.onCloseButton,
27269
+ title = _ref.title,
27270
+ imgSrc = _ref.imgSrc,
27271
+ _ref$imgWidth = _ref.imgWidth,
27272
+ imgWidth = _ref$imgWidth === void 0 ? '20px' : _ref$imgWidth,
27273
+ cancelDrag = _ref.cancelDrag,
27274
+ onPositionChange = _ref.onPositionChange,
27275
+ onOutsideClick = _ref.onOutsideClick;
27276
+ var draggableRef = React.useRef(null);
27277
+ useOutsideClick(draggableRef, 'item-container');
27278
+ React.useEffect(function () {
27279
+ document.addEventListener('clickOutside', function (event) {
27280
+ var e = event;
27281
+
27282
+ if (e.detail.id === 'item-container') {
27283
+ if (onOutsideClick) {
27284
+ onOutsideClick();
27285
+ }
27286
+ }
27287
+ });
27288
+ return function () {
27289
+ document.removeEventListener('clickOutside', function (_e) {});
27290
+ };
27291
+ }, []);
27292
+ return React__default.createElement(Draggable, {
27293
+ cancel: ".container-close," + cancelDrag,
27294
+ onDrag: function onDrag(_e, data) {
27295
+ if (onPositionChange) {
27296
+ onPositionChange({
27297
+ x: data.x,
27298
+ y: data.y
27299
+ });
27300
+ }
27301
+ }
27302
+ }, React__default.createElement(Container$6, {
27303
+ ref: draggableRef,
27304
+ width: width,
27305
+ height: height || 'auto',
27306
+ className: "rpgui-container " + type + " " + className
27307
+ }, title && React__default.createElement(TitleContainer, {
27308
+ className: "drag-handler"
27309
+ }, React__default.createElement(Title, null, imgSrc && React__default.createElement(Icon, {
27310
+ src: imgSrc,
27311
+ width: imgWidth
27312
+ }), title)), onCloseButton && React__default.createElement(CloseButton$1, {
27313
+ className: "container-close",
27314
+ onClick: onCloseButton,
27315
+ onTouchStart: onCloseButton
27316
+ }, "X"), children));
27270
27317
  };
27271
- var atlasJSON = {
27272
- frames: frames$1,
27273
- meta: meta$1
27318
+ var Container$6 = /*#__PURE__*/styled.div.withConfig({
27319
+ displayName: "DraggableContainer__Container",
27320
+ componentId: "sc-184mpyl-0"
27321
+ })(["height:", ";width:", ";display:flex;flex-wrap:wrap;image-rendering:pixelated;&.rpgui-container{padding-top:1.5rem;}"], function (props) {
27322
+ return props.height;
27323
+ }, function (_ref2) {
27324
+ var width = _ref2.width;
27325
+ return width;
27326
+ });
27327
+ var CloseButton$1 = /*#__PURE__*/styled.div.withConfig({
27328
+ displayName: "DraggableContainer__CloseButton",
27329
+ componentId: "sc-184mpyl-1"
27330
+ })(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:0.8rem;"]);
27331
+ var TitleContainer = /*#__PURE__*/styled.div.withConfig({
27332
+ displayName: "DraggableContainer__TitleContainer",
27333
+ componentId: "sc-184mpyl-2"
27334
+ })(["width:100%;height:100%;display:flex;flex-wrap:wrap;justify-content:flex-start;align-items:center;"]);
27335
+ var Title = /*#__PURE__*/styled.h1.withConfig({
27336
+ displayName: "DraggableContainer__Title",
27337
+ componentId: "sc-184mpyl-3"
27338
+ })(["color:white;z-index:22;font-size:0.6rem;"]);
27339
+ var Icon = /*#__PURE__*/styled.img.withConfig({
27340
+ displayName: "DraggableContainer__Icon",
27341
+ componentId: "sc-184mpyl-4"
27342
+ })(["color:white;z-index:22;font-size:10px;width:", ";margin-right:0.5rem;"], function (props) {
27343
+ return props.width;
27344
+ });
27345
+
27346
+ var _RPGUI = RPGUI;
27347
+ var RPGUIRoot = function RPGUIRoot(_ref) {
27348
+ var children = _ref.children;
27349
+ return React__default.createElement("div", {
27350
+ className: "rpgui-content"
27351
+ }, children);
27274
27352
  };
27275
27353
 
27276
- var img$5 = '';
27354
+ var Dropdown = function Dropdown(_ref) {
27355
+ var options = _ref.options,
27356
+ width = _ref.width,
27357
+ onChange = _ref.onChange;
27358
+ var dropdownId = uuid.v4();
27359
+
27360
+ var _useState = React.useState(''),
27361
+ selectedValue = _useState[0],
27362
+ setSelectedValue = _useState[1];
27363
+
27364
+ React.useEffect(function () {
27365
+ var element = document.getElementById("rpgui-dropdown-" + dropdownId);
27366
+
27367
+ var dropdownValue = _RPGUI.get_value(element);
27368
+
27369
+ setSelectedValue(dropdownValue);
27370
+ element == null ? void 0 : element.addEventListener('change', function (event) {
27371
+ setSelectedValue(event == null ? void 0 : event.target.value);
27372
+ });
27373
+ }, []);
27374
+ React.useEffect(function () {
27375
+ if (selectedValue) {
27376
+ onChange(selectedValue);
27377
+ }
27378
+ }, [selectedValue]);
27379
+ return React__default.createElement("select", {
27380
+ id: "rpgui-dropdown-" + dropdownId,
27381
+ style: {
27382
+ width: width
27383
+ },
27384
+ className: "rpgui-dropdown"
27385
+ }, options.map(function (option) {
27386
+ return React__default.createElement("option", {
27387
+ key: option.id,
27388
+ value: option.value
27389
+ }, option.option);
27390
+ }));
27391
+ };
27277
27392
 
27278
27393
  var RelativeListMenu = function RelativeListMenu(_ref) {
27279
27394
  var options = _ref.options,
@@ -27466,7 +27581,9 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
27466
27581
  _onMouseOver = _ref.onMouseOver,
27467
27582
  _onMouseOut = _ref.onMouseOut,
27468
27583
  _onClick = _ref.onClick,
27469
- _onSelected = _ref.onSelected;
27584
+ _onSelected = _ref.onSelected,
27585
+ atlasJSON = _ref.atlasJSON,
27586
+ atlasIMG = _ref.atlasIMG;
27470
27587
 
27471
27588
  var _useState = React.useState(false),
27472
27589
  isTooltipVisible = _useState[0],
@@ -27510,13 +27627,13 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
27510
27627
 
27511
27628
  if (itemToRender != null && itemToRender.texturePath) {
27512
27629
  console.table(itemToRender);
27513
- element.push(React__default.createElement(SpriteFromAtlas, {
27630
+ element.push(React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
27514
27631
  key: itemToRender._id,
27515
- atlasIMG: img$5,
27632
+ atlasIMG: atlasIMG,
27516
27633
  atlasJSON: atlasJSON,
27517
27634
  spriteKey: itemToRender.texturePath,
27518
27635
  imgScale: 3
27519
- }));
27636
+ })));
27520
27637
  }
27521
27638
 
27522
27639
  var stackInfo = getStackInfo((_itemToRender$_id = itemToRender == null ? void 0 : itemToRender._id) != null ? _itemToRender$_id : '', (_itemToRender$stackQt = itemToRender == null ? void 0 : itemToRender.stackQty) != null ? _itemToRender$stackQt : 0);
@@ -27535,13 +27652,13 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
27535
27652
  var _itemToRender$_id2, _itemToRender$stackQt2;
27536
27653
 
27537
27654
  var element = [];
27538
- element.push(React__default.createElement(SpriteFromAtlas, {
27655
+ element.push(React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
27539
27656
  key: itemToRender._id,
27540
- atlasIMG: img$5,
27657
+ atlasIMG: atlasIMG,
27541
27658
  atlasJSON: atlasJSON,
27542
27659
  spriteKey: itemToRender.texturePath,
27543
27660
  imgScale: 3
27544
- }));
27661
+ })));
27545
27662
  var stackInfo = getStackInfo((_itemToRender$_id2 = itemToRender == null ? void 0 : itemToRender._id) != null ? _itemToRender$_id2 : '', (_itemToRender$stackQt2 = itemToRender == null ? void 0 : itemToRender.stackQty) != null ? _itemToRender$stackQt2 : 0);
27546
27663
 
27547
27664
  if (stackInfo) {
@@ -27550,14 +27667,14 @@ var ItemSlot = /*#__PURE__*/mobxReactLite.observer(function (_ref) {
27550
27667
 
27551
27668
  return element;
27552
27669
  } else {
27553
- return React__default.createElement(SpriteFromAtlas, {
27554
- atlasIMG: img$5,
27670
+ return React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
27671
+ atlasIMG: atlasIMG,
27555
27672
  atlasJSON: atlasJSON,
27556
27673
  spriteKey: EquipmentSlotSpriteByType[slotSpriteMask],
27557
27674
  imgScale: 3,
27558
27675
  grayScale: true,
27559
27676
  opacity: 0.4
27560
- });
27677
+ }));
27561
27678
  }
27562
27679
  };
27563
27680
 
@@ -27629,7 +27746,9 @@ var EquipmentSet = function EquipmentSet(_ref) {
27629
27746
  onClose = _ref.onClose,
27630
27747
  _onMouseOver = _ref.onMouseOver,
27631
27748
  _onSelected = _ref.onSelected,
27632
- onItemClick = _ref.onItemClick;
27749
+ onItemClick = _ref.onItemClick,
27750
+ atlasIMG = _ref.atlasIMG,
27751
+ atlasJSON = _ref.atlasJSON;
27633
27752
  var neck = equipmentSet.neck,
27634
27753
  leftHand = equipmentSet.leftHand,
27635
27754
  ring = equipmentSet.ring,
@@ -27666,7 +27785,9 @@ var EquipmentSet = function EquipmentSet(_ref) {
27666
27785
  },
27667
27786
  onSelected: function onSelected(optionId) {
27668
27787
  if (_onSelected) _onSelected(optionId);
27669
- }
27788
+ },
27789
+ atlasIMG: atlasIMG,
27790
+ atlasJSON: atlasJSON
27670
27791
  });
27671
27792
  });
27672
27793
  };
@@ -27729,7 +27850,9 @@ var ItemContainer = function ItemContainer(_ref) {
27729
27850
  _onMouseOver = _ref.onMouseOver,
27730
27851
  _onSelected = _ref.onSelected,
27731
27852
  onItemClick = _ref.onItemClick,
27732
- type = _ref.type;
27853
+ type = _ref.type,
27854
+ atlasJSON = _ref.atlasJSON,
27855
+ atlasIMG = _ref.atlasIMG;
27733
27856
 
27734
27857
  var onRenderSlots = function onRenderSlots() {
27735
27858
  var slots = [];
@@ -27750,7 +27873,9 @@ var ItemContainer = function ItemContainer(_ref) {
27750
27873
  },
27751
27874
  onSelected: function onSelected(optionId, item) {
27752
27875
  if (_onSelected) _onSelected(optionId, item);
27753
- }
27876
+ },
27877
+ atlasIMG: atlasIMG,
27878
+ atlasJSON: atlasJSON
27754
27879
  }));
27755
27880
  }
27756
27881
 
@@ -28375,11 +28500,11 @@ var Thumbnail = /*#__PURE__*/styled.img.withConfig({
28375
28500
  var LeftArrow$1 = /*#__PURE__*/styled.div.withConfig({
28376
28501
  displayName: "QuestInfo__LeftArrow",
28377
28502
  componentId: "sc-15s2boc-9"
28378
- })(["background-image:url(", ");background-size:100% 100%;left:0;position:absolute;width:40px;height:42px;:active{background-image:url(", ");}"], img$2, img$1);
28503
+ })(["background-image:url(", ");background-size:100% 100%;left:0;position:absolute;width:40px;height:42px;:active{background-image:url(", ");}"], img$3, img$2);
28379
28504
  var RightArrow$1 = /*#__PURE__*/styled.div.withConfig({
28380
28505
  displayName: "QuestInfo__RightArrow",
28381
28506
  componentId: "sc-15s2boc-10"
28382
- })(["background-image:url(", ");right:0;position:absolute;width:40px;background-size:100% 100%;height:42px;:active{background-image:url(", ");}"], img$4, img$3);
28507
+ })(["background-image:url(", ");right:0;position:absolute;width:40px;background-size:100% 100%;height:42px;:active{background-image:url(", ");}"], img$5, img$4);
28383
28508
 
28384
28509
  var QuestList = function QuestList(_ref) {
28385
28510
  var quests = _ref.quests,
@@ -28409,7 +28534,7 @@ var QuestList = function QuestList(_ref) {
28409
28534
  }, quest.title), React__default.createElement("p", {
28410
28535
  className: "quest-detail__description"
28411
28536
  }, quest.description)));
28412
- }) : React__default.createElement("div", null))));
28537
+ }) : React__default.createElement(NoQuestContainer, null, React__default.createElement("p", null, "There are no ongoing quests")))));
28413
28538
  };
28414
28539
  var QuestDraggableContainer$1 = /*#__PURE__*/styled(DraggableContainer).withConfig({
28415
28540
  displayName: "QuestList__QuestDraggableContainer",
@@ -28422,7 +28547,11 @@ var Title$2 = /*#__PURE__*/styled.h1.withConfig({
28422
28547
  var QuestListContainer = /*#__PURE__*/styled.div.withConfig({
28423
28548
  displayName: "QuestList__QuestListContainer",
28424
28549
  componentId: "sc-1a2vx6q-2"
28425
- })(["margin-top:20px;margin-bottom:40px;overflow-y:auto;max-height:400px;.quest-item{display:flex;align-items:flex-start;margin-bottom:12px;}.quest-number{border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin-right:16px;background-color:brown;flex-shrink:0;}.quest-number.completed{background-color:yellow;}p{margin:0;}.quest-detail__title{color:yellow;}.quest-detail__description{margin-top:5px;}"]);
28550
+ })(["margin-top:20px;margin-bottom:40px;overflow-y:auto;max-height:400px;.quest-item{display:flex;align-items:flex-start;margin-bottom:12px;}.quest-number{border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin-right:16px;background-color:brown;flex-shrink:0;}.quest-number.completed{background-color:yellow;}p{margin:0;}.quest-detail__title{color:yellow;}.quest-detail__description{margin-top:5px;}.Noquest-detail__description{margin-top:5px;margin:auto;}"]);
28551
+ var NoQuestContainer = /*#__PURE__*/styled.div.withConfig({
28552
+ displayName: "QuestList__NoQuestContainer",
28553
+ componentId: "sc-1a2vx6q-3"
28554
+ })(["text-align:center;p{margin-top:5px;}"]);
28426
28555
 
28427
28556
  var InputRadio = function InputRadio(_ref) {
28428
28557
  var name = _ref.name,
@@ -28546,14 +28675,14 @@ var SkillProgressBar = function SkillProgressBar(_ref) {
28546
28675
  showSkillPoints = _ref$showSkillPoints === void 0 ? true : _ref$showSkillPoints;
28547
28676
  var spForNextLevel = shared.getSPForLevel(level + 1);
28548
28677
  var ratio = skillPoints / spForNextLevel * 100;
28549
- return React__default.createElement(React__default.Fragment, null, React__default.createElement(ProgressTitle, null, React__default.createElement(TitleName, null, skillName), React__default.createElement(ValueDisplay, null, "lv ", level)), React__default.createElement(ProgressBody, null, React__default.createElement(ProgressIconContainer, null, atlasJSON ? React__default.createElement(SpriteContainer, null, React__default.createElement(SpriteFromAtlas, {
28550
- atlasIMG: img$5,
28678
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement(ProgressTitle, null, React__default.createElement(TitleName, null, skillName), React__default.createElement(ValueDisplay, null, "lv ", level)), React__default.createElement(ProgressBody, null, React__default.createElement(ProgressIconContainer, null, atlasJSON ? React__default.createElement(SpriteContainer, null, React__default.createElement(ErrorBoundary, null, React__default.createElement(SpriteFromAtlas, {
28679
+ atlasIMG: img$1,
28551
28680
  atlasJSON: atlasJSON,
28552
28681
  spriteKey: texturePath,
28553
28682
  imgScale: 1,
28554
28683
  grayScale: true,
28555
28684
  opacity: 0.5
28556
- })) : React__default.createElement(React__default.Fragment, null)), React__default.createElement(ProgressBarContainer$1, null, React__default.createElement(SimpleProgressBar, {
28685
+ }))) : React__default.createElement(React__default.Fragment, null)), React__default.createElement(ProgressBarContainer$1, null, React__default.createElement(SimpleProgressBar, {
28557
28686
  value: ratio,
28558
28687
  bgColor: bgColor
28559
28688
  }))), showSkillPoints && React__default.createElement(SkillDisplayContainer, null, React__default.createElement(SkillPointsDisplay, null, skillPoints, "/", spForNextLevel)));
@@ -28836,8 +28965,32 @@ var HistoryDialog = function HistoryDialog(_ref) {
28836
28965
  imagePath = _ref.imagePath,
28837
28966
  textAndTypeArray = _ref.textAndTypeArray,
28838
28967
  onClose = _ref.onClose;
28968
+
28969
+ var _useState = React.useState(0),
28970
+ img = _useState[0],
28971
+ setImage = _useState[1];
28972
+
28973
+ var onHandleSpacePress = function onHandleSpacePress(event) {
28974
+ if (event.code === 'Space') {
28975
+ if (img < (backgroundImgPath == null ? void 0 : backgroundImgPath.length) - 1) {
28976
+ setImage(function (prev) {
28977
+ return prev + 1;
28978
+ });
28979
+ } else {
28980
+ // if there's no more text chunks, close the dialog
28981
+ onClose();
28982
+ }
28983
+ }
28984
+ };
28985
+
28986
+ React.useEffect(function () {
28987
+ document.addEventListener('keydown', onHandleSpacePress);
28988
+ return function () {
28989
+ return document.removeEventListener('keydown', onHandleSpacePress);
28990
+ };
28991
+ }, [backgroundImgPath]);
28839
28992
  return React__default.createElement(BackgroundContainer, {
28840
- imgPath: backgroundImgPath,
28993
+ imgPath: backgroundImgPath[img],
28841
28994
  fullImg: fullCoverBackground
28842
28995
  }, React__default.createElement(DialogContainer, null, textAndTypeArray ? React__default.createElement(NPCMultiDialog, {
28843
28996
  textAndTypeArray: textAndTypeArray,