@rpg-engine/long-bow 0.1.63 → 0.1.64

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.
@@ -1,2 +1,2 @@
1
- "use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=require("react"),n=e(t),i=e(require("styled-components")),r=e(require("dayjs")),o=require("react-error-boundary"),a=e(require("react-draggable")),l=require("uuid");function s(){return(s=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var i in n)Object.prototype.hasOwnProperty.call(n,i)&&(e[i]=n[i])}return e}).apply(this,arguments)}require("rpgui/rpgui.min.css"),require("rpgui/rpgui.min.js");var c,u=["children","buttonType"];(c=exports.ButtonTypes||(exports.ButtonTypes={})).RPGUIButton="rpgui-button",c.RPGUIGoldButton="rpgui-button golden";var d,p=function(e){var t=e.children,i=e.buttonType,r=function(e,t){if(null==e)return{};var n,i,r={},o=Object.keys(e);for(i=0;i<o.length;i++)t.indexOf(n=o[i])>=0||(r[n]=e[n]);return r}(e,u);return n.createElement(m,Object.assign({className:""+i},r),n.createElement("p",null,t))},m=i.button.withConfig({displayName:"Button__ButtonContainer",componentId:"sc-obzd3o-0"})(["height:45px;font-size:11.5px;"]),f=function(e){var t=s({},e);return n.createElement("input",Object.assign({},t))};(d=exports.RPGUIContainerTypes||(exports.RPGUIContainerTypes={})).Framed="framed",d.FramedGold="framed-golden",d.FramedGold2="framed-golden-2",d.FramedGrey="framed-grey";var g=function(e){var t=e.width;return n.createElement(h,{width:void 0===t?"50%":t,height:e.height||"auto",className:"rpgui-container "+e.type+" "+e.className},e.children)},h=i.div.withConfig({displayName:"RPGUIContainer__Container",componentId:"sc-a8l4p8-0"})(["height:",";width:",";display:flex;flex-wrap:wrap;image-rendering:pixelated;"],(function(e){return e.height}),(function(e){return e.width})),x=i.div.withConfig({displayName:"Column",componentId:"sc-1pesqff-0"})(["flex:",";display:flex;flex-wrap:",";align-items:",";justify-content:",";"],(function(e){return e.flex||"auto"}),(function(e){return e.flexWrap||"nowrap"}),(function(e){return e.alignItems||"flex-start"}),(function(e){return e.justifyContent||"flex-start"})),y=i.div.withConfig({displayName:"Chat__Container",componentId:"sc-1bk05n6-0"})(["position:relative;"]),v=i.div.withConfig({displayName:"Chat__CloseButton",componentId:"sc-1bk05n6-1"})(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:10px;"]),w=i(f).withConfig({displayName:"Chat__CustomInput",componentId:"sc-1bk05n6-2"})(["height:30px;width:100%;.rpgui-content .input{min-height:39px;}"]),C=i(g).withConfig({displayName:"Chat__CustomContainer",componentId:"sc-1bk05n6-3"})(["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(e){return e.opacity}),"#3e3e3e"),b=i.form.withConfig({displayName:"Chat__Form",componentId:"sc-1bk05n6-4"})(["display:flex;width:100%;justify-content:center;align-items:center;"]),E=i.p.withConfig({displayName:"Chat__MessageText",componentId:"sc-1bk05n6-5"})(["display:block !important;width:100%;font-size:0.7rem !important;overflow-y:auto;margin:0;"]),_=i.div.withConfig({displayName:"DraggableContainer__Container",componentId:"sc-184mpyl-0"})(["height:",";width:",";display:flex;flex-wrap:wrap;image-rendering:pixelated;"],(function(e){return e.height}),(function(e){return e.width})),I=i.div.withConfig({displayName:"DraggableContainer__CloseButton",componentId:"sc-184mpyl-1"})(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:10px;"]),N=i.div.withConfig({displayName:"DraggableContainer__TitleContainer",componentId:"sc-184mpyl-2"})(["width:100%;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;"]),k=i.h1.withConfig({displayName:"DraggableContainer__Title",componentId:"sc-184mpyl-3"})(["color:white;z-index:22;font-size:10px;"]),T=i.img.withConfig({displayName:"DraggableContainer__Icon",componentId:"sc-184mpyl-4"})(["color:white;z-index:22;font-size:10px;width:",";margin-right:0.5rem;"],(function(e){return e.width})),S=RPGUI,P=i.div.withConfig({displayName:"ListMenu__Container",componentId:"sc-i9097t-0"})(["display:flex;flex-direction:column;width:100%;justify-content:start;align-items:flex-start;position:absolute;top:","px;left:","px;li{font-size:","em;}"],(function(e){return e.y||0}),(function(e){return e.x||0}),(function(e){return e.fontSize})),B=i.li.withConfig({displayName:"ListMenu__ListElement",componentId:"sc-i9097t-1"})(["margin-right:0.5rem;"]);const D=require("./alice.png"),z=require("./space.gif");var R,j=function(e){var i=e.text,r=e.onFinish,o=e.onStart,a=t.useState(""),l=a[0],s=a[1];return t.useEffect((function(){var e=0,t=setInterval((function(){0===e&&o&&o(),e<i.length?(s(i.substring(0,e+1)),e++):(clearInterval(t),r&&r())}),50);return function(){clearInterval(t)}}),[i]),n.createElement(G,null,l)},G=i.p.withConfig({displayName:"DynamicText__TextContainer",componentId:"sc-1ggl9nd-0"})(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]),q=function(e){var i=e.onClose,r=e.onEndStep,o=e.onStartStep,a=e.text.match(new RegExp(".{1,85}","g")),l=t.useState(0),s=l[0],c=l[1],u=function(e){"Space"===e.code&&((null==a?void 0:a[s+1])?c((function(e){return e+1})):i())};return t.useEffect((function(){return document.addEventListener("keydown",u),function(){return document.removeEventListener("keydown",u)}}),[s]),n.createElement(U,null,n.createElement(j,{text:(null==a?void 0:a[s])||"",onFinish:r,onStart:o}))},U=i.div.withConfig({displayName:"NPCDialogText__Container",componentId:"sc-1cxkdh9-0"})([""]),F=function(e,t,i){void 0===i&&(i=window);var r=n.useRef();n.useEffect((function(){r.current=t}),[t]),n.useEffect((function(){var t=function(e){return r.current(e)};return i.addEventListener(e,t),function(){i.removeEventListener(e,t)}}),[e,i])},A=function(e){var i=e.questions,r=e.answers,o=e.onClose,a=t.useState(i[0]),l=a[0],s=a[1],c=t.useState(!1),u=c[0],d=c[1],p=function(){if(!l.answerIds||0===l.answerIds.length)return null;var e=l.answerIds[0];return r.find((function(t){return t.id===e}))},m=t.useState(p()),f=m[0],g=m[1];t.useEffect((function(){g(p())}),[l]);var h=function(e){return e.map((function(e){return r.find((function(t){return t.id===e}))}))};return F("keydown",(function(e){switch(e.key){case"ArrowDown":var t=h(l.answerIds).findIndex((function(e){return(null==e?void 0:e.id)===f.id+1})),n=l.answerIds[t],r=h(l.answerIds).find((function(e){return(null==e?void 0:e.id)===n}));g(r||p());break;case"ArrowUp":var a=h(l.answerIds).findIndex((function(e){return(null==e?void 0:e.id)===f.id-1})),c=l.answerIds&&l.answerIds[a],u=h(l.answerIds).find((function(e){return(null==e?void 0:e.id)===c}));g(u||h(l.answerIds).pop());break;case"Enter":if(d(!1),null==f||!f.nextQuestionId)return void o();s(i.find((function(e){return e.id===f.nextQuestionId})))}})),n.createElement(O,null,n.createElement(L,null,n.createElement(j,{text:l.text,onStart:function(){return d(!1)},onFinish:function(){return d(!0)}})),u&&n.createElement(Q,null,function(){var e=l.answerIds;if(!e)return null;var t=h(e);return t?t.map((function(e){var t=(null==f?void 0:f.id)===(null==e?void 0:e.id),r=t?"yellow":"white";return e?n.createElement(X,{key:"answer_"+e.id},n.createElement(W,{color:r},t?"X":null),n.createElement(M,{key:e.id,onClick:function(){return function(e){d(!1),e.nextQuestionId?s(i.find((function(t){return t.id===e.nextQuestionId}))):o()}(e)},color:r},e.text)):null})):null}()))},O=i.div.withConfig({displayName:"QuestionDialog__Container",componentId:"sc-bxc5u0-0"})(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]),L=i.div.withConfig({displayName:"QuestionDialog__QuestionContainer",componentId:"sc-bxc5u0-1"})(["flex:100%;width:100%;"]),Q=i.div.withConfig({displayName:"QuestionDialog__AnswersContainer",componentId:"sc-bxc5u0-2"})(["flex:100%;"]),M=i.p.withConfig({displayName:"QuestionDialog__Answer",componentId:"sc-bxc5u0-3"})(["flex:auto;color:"," !important;font-size:0.65rem !important;background:inherit;border:none;"],(function(e){return e.color})),W=i.span.withConfig({displayName:"QuestionDialog__AnswerSelectedIcon",componentId:"sc-bxc5u0-4"})(["flex:5% 0 0;color:"," !important;"],(function(e){return e.color})),X=i.div.withConfig({displayName:"QuestionDialog__AnswerRow",componentId:"sc-bxc5u0-5"})(["display:flex;flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:0.5rem;height:22px;p{line-height:unset;margin-top:0;margin-bottom:0rem;}"]);(R=exports.NPCDialogType||(exports.NPCDialogType={})).TextOnly="TextOnly",R.TextAndThumbnail="TextAndThumbnail";var H,V=i.div.withConfig({displayName:"NPCDialog__Container",componentId:"sc-1b4aw74-0"})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]),Y=i.div.withConfig({displayName:"NPCDialog__TextContainer",componentId:"sc-1b4aw74-1"})(["flex:"," 0 0;width:355px;"],(function(e){return e.flex})),J=i.div.withConfig({displayName:"NPCDialog__ThumbnailContainer",componentId:"sc-1b4aw74-2"})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]),K=i.img.withConfig({displayName:"NPCDialog__NPCThumbnail",componentId:"sc-1b4aw74-3"})(["image-rendering:pixelated;height:128px;width:128px;"]),Z=i.img.withConfig({displayName:"NPCDialog__PressSpaceIndicator",componentId:"sc-1b4aw74-4"})(["position:absolute;right:",";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"],(function(e){return e.right})),$=i.span.withConfig({displayName:"ProgressBar__ProgressBarText",componentId:"sc-qa6fzh-0"})(["font-size:1rem;color:white;text-align:center;z-index:1;position:absolute;left:50%;transform:translateX(-50%);top:12px;"]),ee=i.div.withConfig({displayName:"ProgressBar__TextOverlay",componentId:"sc-qa6fzh-1"})(["width:100%;position:relative;"]),te=i.div.withConfig({displayName:"ProgressBar__Container",componentId:"sc-qa6fzh-2"})(["display:flex;flex-direction:column;min-width:","px;width:","%;justify-content:start;align-items:flex-start;",""],(function(e){return e.minWidth}),(function(e){return e.percentageWidth}),(function(e){return e.style}));(H=exports.RangeSliderType||(exports.RangeSliderType={})).Slider="rpgui-slider",H.GoldSlider="rpgui-slider golden";var ne=i.input.withConfig({displayName:"RangeSlider__Input",componentId:"sc-v8mte9-0"})(["opacity:0;"]);const ie=require("./imgExp.png");var re=function(e){var t=e.bgColor;return n.createElement(oe,null,n.createElement(se,null,n.createElement(ae,null,n.createElement(le,{value:e.value,bgColor:void 0===t?"red":t}))))},oe=i.div.withConfig({displayName:"SimpleProgressBar__Container",componentId:"sc-mbeil3-0"})(["display:flex;justify-content:center;align-items:center;width:100%;"]),ae=i.span.withConfig({displayName:"SimpleProgressBar__BackgroundBar",componentId:"sc-mbeil3-1"})(["background-color:rgba(0,0,0,0.075);"]),le=i.span.withConfig({displayName:"SimpleProgressBar__Progress",componentId:"sc-mbeil3-2"})(["background-color:",";width:","%;"],(function(e){return e.bgColor}),(function(e){return e.value})),se=i.div.withConfig({displayName:"SimpleProgressBar__ProgressBarContainer",componentId:"sc-mbeil3-3"})(["border-radius:60px;border:1px solid #282424;overflow:hidden;width:100%;span{display:block;height:100%;}height:8px;"]),ce=i.span.withConfig({displayName:"SkillProgressBar__TitleName",componentId:"sc-5vuroc-0"})(["margin-left:5px;"]),ue=i.span.withConfig({displayName:"SkillProgressBar__ValueDisplay",componentId:"sc-5vuroc-1"})([""]),de=i.div.withConfig({displayName:"SkillProgressBar__ProgressIconContainer",componentId:"sc-5vuroc-2"})(["display:flex;justify-content:center;align-items:center;"]),pe=i.div.withConfig({displayName:"SkillProgressBar__ProgressBody",componentId:"sc-5vuroc-3"})(["display:flex;flex-direction:row;"]),me=i.div.withConfig({displayName:"SkillProgressBar__ProgressTitle",componentId:"sc-5vuroc-4"})(["width:100%;display:flex;flex-direction:row;justify-content:space-between;span{font-size:0.6rem;}"]),fe=i.img.withConfig({displayName:"SkillProgressBar__Icon",componentId:"sc-5vuroc-5"})(["margin-right:10px;height:30px;"]),ge=i.div.withConfig({displayName:"Truncate__Container",componentId:"sc-6x00qb-0"})(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:",";-webkit-box-orient:vertical;overflow:hidden;"],(function(e){return e.maxLines}));exports.Button=p,exports.Chat=function(e){var i=e.chatMessages,a=e.onSendChatMessage,l=e.opacity,s=void 0===l?1:l,c=e.width,u=void 0===c?"100%":c,d=e.height,m=void 0===d?"250px":d,f=e.onCloseButton,h=t.useState(""),_=h[0],I=h[1];t.useEffect((function(){N()}),[]),t.useEffect((function(){N()}),[i]);var N=function(){var e=document.querySelector(".chat-body");e&&(e.scrollTop=e.scrollHeight)};return n.createElement(y,null,n.createElement(C,{type:exports.RPGUIContainerTypes.FramedGrey,width:u,height:m,className:"chat-container",opacity:s},n.createElement(o.ErrorBoundary,{fallback:n.createElement("p",null,"Oops! Your chat has crashed.")},f&&n.createElement(v,{onClick:f,onTouchStart:f},"X"),n.createElement(g,{type:exports.RPGUIContainerTypes.FramedGrey,width:"100%",height:"80%",className:"chat-body dark-background"},function(e){return null!=e&&e.length?null==e?void 0:e.map((function(e,t){return n.createElement(E,{key:e._id+"_"+t},function(e,t,n){return r(t||new Date).format("HH:mm")+" "+(null!=e&&e.name?e.name+": ":"Unknown: ")+" "+n}(e.emitter,e.createdAt,e.message))})):n.createElement(E,null,"No messages available.")}(i)),n.createElement(b,{onSubmit:function(e){e.preventDefault(),a(_),I("")}},n.createElement(x,{flex:70},n.createElement(w,{value:_,id:"inputMessage",onChange:function(e){I(e.target.value)},height:20,className:"chat-input dark-background",type:"text",autoComplete:"off"})),n.createElement(x,{justifyContent:"flex-end"},n.createElement(p,{buttonType:exports.ButtonTypes.RPGUIButton,id:"chat-send-button"},"Send"))))))},exports.CheckButton=function(e){var i=e.items,r=e.onChange,o=t.useState(function(){var e={};return i.forEach((function(t){e[t.label]=!1})),e}()),a=o[0],l=o[1];return t.useEffect((function(){a&&r(a)}),[a]),n.createElement("div",{id:"elemento-checkbox"},null==i?void 0:i.map((function(e,t){return n.createElement("div",{key:e.label+"_"+t},n.createElement("input",{className:"rpgui-checkbox",type:"checkbox",checked:a[e.label],onChange:function(){}}),n.createElement("label",{onClick:function(){var t,n;l(s({},a,((n={})[t=e.label]=!a[t],n)))}},e.label),n.createElement("br",null))})))},exports.DraggableContainer=function(e){var t=e.children,i=e.width,r=e.type,o=void 0===r?exports.RPGUIContainerTypes.FramedGold:r,l=e.onCloseButton,s=e.title,c=e.imgSrc,u=e.imgWidth;return n.createElement(a,null,n.createElement(_,{width:void 0===i?"50%":i,height:e.height||"auto",className:"rpgui-container "+o+" "+e.className+" rpgui-draggable"},n.createElement(N,null,n.createElement(k,null,c&&n.createElement(T,{src:c,width:void 0===u?"20px":u}),s)),l&&n.createElement(I,{onClick:l,onTouchStart:l},"X"),t))},exports.Dropdown=function(e){var i=e.options,r=e.width,o=e.onChange,a=l.v4(),s=t.useState(""),c=s[0],u=s[1];return t.useEffect((function(){var e=document.getElementById("rpgui-dropdown-"+a),t=S.get_value(e);u(t),null==e||e.addEventListener("change",(function(e){u(null==e?void 0:e.target.value)}))}),[]),t.useEffect((function(){c&&o(c)}),[c]),n.createElement("select",{id:"rpgui-dropdown-"+a,style:{width:r},className:"rpgui-dropdown"},i.map((function(e){return n.createElement("option",{key:e.id,value:e.value},e.option)})))},exports.DynamicText=j,exports.Input=f,exports.InputRadio=function(e){var i=e.name,r=e.items,o=e.onChange,a=t.useState(),l=a[0],s=a[1],c=function(){var e=document.querySelector("input[name="+i+"]:checked");s(e.value)};return t.useEffect((function(){l&&o(l)}),[l]),n.createElement("div",{id:"elemento-radio"},r.map((function(e){return n.createElement(n.Fragment,null,n.createElement("input",{key:e.value,className:"rpgui-radio",value:e.value,name:i,type:"radio"}),n.createElement("label",{onClick:c},e.label),n.createElement("br",null))})))},exports.ListMenu=function(e){var t=e.onSelected,i=e.fontSize;return n.createElement(P,{x:e.x,y:e.y,fontSize:void 0===i?.8:i},n.createElement("ul",{className:"rpgui-list-imp",style:{overflow:"hidden"}},e.options.map((function(e){return n.createElement(B,{key:e.text,onClick:function(){t(e.id)}},e.text)}))))},exports.NPCDialog=function(e){var i=e.text,r=e.type,o=e.onClose,a=e.imagePath,l=e.isQuestionDialog,s=void 0!==l&&l,c=e.questions,u=e.answers,d=t.useState(!1),p=d[0],m=d[1];return n.createElement(g,{type:exports.RPGUIContainerTypes.FramedGold,width:s?"600px":"50%",height:"180px"},s&&c&&u?n.createElement(n.Fragment,null,n.createElement(Y,{flex:r===exports.NPCDialogType.TextAndThumbnail?"70%":"100%"},n.createElement(A,{questions:c,answers:u,onClose:function(){o&&o()}})),r===exports.NPCDialogType.TextAndThumbnail&&n.createElement(J,null,n.createElement(K,{src:a||D}))):n.createElement(n.Fragment,null,n.createElement(V,null,n.createElement(Y,{flex:r===exports.NPCDialogType.TextAndThumbnail?"70%":"100%"},n.createElement(q,{onStartStep:function(){return m(!1)},onEndStep:function(){return m(!0)},text:i||"No text provided.",onClose:function(){o&&o()}})),r===exports.NPCDialogType.TextAndThumbnail&&n.createElement(J,null,n.createElement(K,{src:a||D}))),p&&n.createElement(Z,{right:r===exports.NPCDialogType.TextOnly?"1rem":"10.5rem",src:z})))},exports.ProgressBar=function(e){var t=e.max,i=e.value,r=e.color,o=e.displayText,a=void 0===o||o,l=e.percentageWidth,s=void 0===l?40:l,c=e.minWidth,u=void 0===c?100:c,d=e.style,p=function(e,t){return t>e&&(t=e),100*t/e};return n.createElement(te,{className:"rpgui-progress","data-value":p(t,i)/100,"data-rpguitype":"progress",percentageWidth:s,minWidth:u,style:d},a&&n.createElement(ee,null,n.createElement($,null,i,"/",t)),n.createElement("div",{className:" rpgui-progress-track"},n.createElement("div",{className:"rpgui-progress-fill "+r+" ",style:{left:"0px",width:p(t,i)+"%"}})),n.createElement("div",{className:" rpgui-progress-left-edge"}),n.createElement("div",{className:" rpgui-progress-right-edge"}))},exports.QuestionDialog=A,exports.RPGUIContainer=g,exports.RPGUIRoot=function(e){return n.createElement("div",{className:"rpgui-content"},e.children)},exports.RangeSlider=function(e){var i=e.type,r=e.valueMin,o=e.valueMax,a=e.width,s=e.onChange,c=l.v4(),u=t.useState(!1),d=u[0],p=u[1];F("mouseup",(function(){d&&m(),p(!1)}));var m=function(){var e=document.getElementById("rpgui-slider-"+c),t=S.get_value(e);s(Number(t))};return n.createElement("div",{onMouseUp:m,onMouseDown:function(){return p(!0)}},n.createElement(ne,{className:i===exports.RangeSliderType.Slider?exports.RangeSliderType.Slider:exports.RangeSliderType.GoldSlider,type:"range",style:{width:a},min:r,max:o,id:"rpgui-slider-"+c}))},exports.SkillProgressBar=function(e){var t=e.value,i=e.bgColor,r=e.logoSrc,o=void 0===r?ie:r;return n.createElement(n.Fragment,null,n.createElement(me,null,n.createElement(ce,null,e.titleName),n.createElement(ue,null,t)),n.createElement(pe,null,n.createElement(de,null,n.createElement(fe,{src:o})),n.createElement(re,{value:t,bgColor:i})))},exports.TextArea=function(e){var t=s({},e);return n.createElement("textarea",Object.assign({},t))},exports.Truncate=function(e){var t=e.maxLines;return n.createElement(ge,{maxLines:void 0===t?1:t},e.children)},exports._RPGUI=S,exports.useEventListener=F;
1
+ "use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=require("react"),n=e(t),A=e(require("styled-components")),i=e(require("dayjs")),r=require("react-error-boundary"),o=e(require("react-draggable")),a=require("uuid");function g(){return(g=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var A in n)Object.prototype.hasOwnProperty.call(n,A)&&(e[A]=n[A])}return e}).apply(this,arguments)}require("rpgui/rpgui.min.css"),require("rpgui/rpgui.min.js");var l,c=["children","buttonType"];(l=exports.ButtonTypes||(exports.ButtonTypes={})).RPGUIButton="rpgui-button",l.RPGUIGoldButton="rpgui-button golden";var s,f=function(e){var t=e.children,A=e.buttonType,i=function(e,t){if(null==e)return{};var n,A,i={},r=Object.keys(e);for(A=0;A<r.length;A++)t.indexOf(n=r[A])>=0||(i[n]=e[n]);return i}(e,c);return n.createElement(C,Object.assign({className:""+A},i),n.createElement("p",null,t))},C=A.button.withConfig({displayName:"Button__ButtonContainer",componentId:"sc-obzd3o-0"})(["height:45px;font-size:11.5px;"]),u=function(e){var t=g({},e);return n.createElement("input",Object.assign({},t))};(s=exports.RPGUIContainerTypes||(exports.RPGUIContainerTypes={})).Framed="framed",s.FramedGold="framed-golden",s.FramedGold2="framed-golden-2",s.FramedGrey="framed-grey";var d,I=function(e){var t=e.width;return n.createElement(w,{width:void 0===t?"50%":t,height:e.height||"auto",className:"rpgui-container "+e.type+" "+e.className},e.children)},w=A.div.withConfig({displayName:"RPGUIContainer__Container",componentId:"sc-a8l4p8-0"})(["height:",";width:",";display:flex;flex-wrap:wrap;image-rendering:pixelated;"],(function(e){return e.height}),(function(e){return e.width})),B=A.div.withConfig({displayName:"Column",componentId:"sc-1pesqff-0"})(["flex:",";display:flex;flex-wrap:",";align-items:",";justify-content:",";"],(function(e){return e.flex||"auto"}),(function(e){return e.flexWrap||"nowrap"}),(function(e){return e.alignItems||"flex-start"}),(function(e){return e.justifyContent||"flex-start"})),p=A.div.withConfig({displayName:"Chat__Container",componentId:"sc-1bk05n6-0"})(["position:relative;"]),m=A.div.withConfig({displayName:"Chat__CloseButton",componentId:"sc-1bk05n6-1"})(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:10px;"]),E=A(u).withConfig({displayName:"Chat__CustomInput",componentId:"sc-1bk05n6-2"})(["height:30px;width:100%;.rpgui-content .input{min-height:39px;}"]),v=A(I).withConfig({displayName:"Chat__CustomContainer",componentId:"sc-1bk05n6-3"})(["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(e){return e.opacity}),"#3e3e3e"),h=A.form.withConfig({displayName:"Chat__Form",componentId:"sc-1bk05n6-4"})(["display:flex;width:100%;justify-content:center;align-items:center;"]),P=A.p.withConfig({displayName:"Chat__MessageText",componentId:"sc-1bk05n6-5"})(["display:block !important;width:100%;font-size:0.7rem !important;overflow-y:auto;margin:0;"]),x=A.div.withConfig({displayName:"DraggableContainer__Container",componentId:"sc-184mpyl-0"})(["height:",";width:",";display:flex;flex-wrap:wrap;image-rendering:pixelated;"],(function(e){return e.height}),(function(e){return e.width})),Q=A.div.withConfig({displayName:"DraggableContainer__CloseButton",componentId:"sc-184mpyl-1"})(["position:absolute;top:3px;right:0px;color:white;z-index:22;font-size:10px;"]),D=A.div.withConfig({displayName:"DraggableContainer__TitleContainer",componentId:"sc-184mpyl-2"})(["width:100%;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;"]),y=A.h1.withConfig({displayName:"DraggableContainer__Title",componentId:"sc-184mpyl-3"})(["color:white;z-index:22;font-size:10px;"]),H=A.img.withConfig({displayName:"DraggableContainer__Icon",componentId:"sc-184mpyl-4"})(["color:white;z-index:22;font-size:10px;width:",";margin-right:0.5rem;"],(function(e){return e.width})),z=RPGUI,b=A.div.withConfig({displayName:"ListMenu__Container",componentId:"sc-i9097t-0"})(["display:flex;flex-direction:column;width:100%;justify-content:start;align-items:flex-start;position:absolute;top:","px;left:","px;li{font-size:","em;}"],(function(e){return e.y||0}),(function(e){return e.x||0}),(function(e){return e.fontSize})),N=A.li.withConfig({displayName:"ListMenu__ListElement",componentId:"sc-i9097t-1"})(["margin-right:0.5rem;"]),F="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAMAAABEpIrGAAAABGdBTUEAALGPC/xhBQAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAAP1BMVEUAAAA7FyVxQTsUEBPj5v////+5v/tCJDOOUlIiHBr1oJfptaO6dWr61rhzFy1bMTjoanMUNGQoXMQkn97+88DQ3IhAAAAAAXRSTlMAQObYZgAAAAFiS0dEBfhv6ccAAAAHdElNRQfmAw4VOBC7c5LYAAABM0lEQVQ4y3XRi5KDIAwFUAUkbrBgpP//rZsHVHQ009qZ3tPboNN0zmwzvcw8O5sX4y0NOg/Et3jRCXF+ziULorjkOQ9gE24dvuUAzq08DiCO4pe3WN7zCP56vmpubBReQYC11YPS86ySxxCsAABTSgjb5m4g8nfbxvFHBkH2OEEvAItVuCuIsgGgl+Gcr7kDXxhEAx55A2SQEEeQeZwUaIP8Tbo05B0RFPhItAjgj1w6cDnhLluDj+Egkh3pCCP4pKQAw1IPO0W9Nti5gW9RP2dKA3BZd2Dw+baYX+Nt4GM00O4S3kEpF6Alb2Bv4LeC3kkGfAW0/p0RPoJVKr63ghHsKuRh5DIUKOAlGOwrtt9fQekAEfmhZslHUDoglB0zjfkJigN7UnTQQ4GBWomoVhEN/AOPSBh38gy+fwAAACV0RVh0ZGF0ZTpjcmVhdGUAMjAyMi0wMy0xNFQyMTo1NTo1MSswMDowMJcc0eEAAAAldEVYdGRhdGU6bW9kaWZ5ADIwMjItMDMtMTRUMjE6NTU6NTErMDA6MDDmQWldAAAAAElFTkSuQmCC",T=function(e){var A=e.text,i=e.onFinish,r=e.onStart,o=t.useState(""),a=o[0],g=o[1];return t.useEffect((function(){var e=0,t=setInterval((function(){0===e&&r&&r(),e<A.length?(g(A.substring(0,e+1)),e++):(clearInterval(t),i&&i())}),50);return function(){clearInterval(t)}}),[A]),n.createElement(O,null,a)},O=A.p.withConfig({displayName:"DynamicText__TextContainer",componentId:"sc-1ggl9nd-0"})(["font-size:0.7rem !important;color:white;text-shadow:1px 1px 0px #000000;letter-spacing:1.2px;word-break:normal;"]),M=function(e){var A=e.onClose,i=e.onEndStep,r=e.onStartStep,o=e.text.match(new RegExp(".{1,85}","g")),a=t.useState(0),g=a[0],l=a[1],c=function(e){"Space"===e.code&&((null==o?void 0:o[g+1])?l((function(e){return e+1})):A())};return t.useEffect((function(){return document.addEventListener("keydown",c),function(){return document.removeEventListener("keydown",c)}}),[g]),n.createElement(G,null,n.createElement(T,{text:(null==o?void 0:o[g])||"",onFinish:i,onStart:r}))},G=A.div.withConfig({displayName:"NPCDialogText__Container",componentId:"sc-1cxkdh9-0"})([""]),X=function(e,t,A){void 0===A&&(A=window);var i=n.useRef();n.useEffect((function(){i.current=t}),[t]),n.useEffect((function(){var t=function(e){return i.current(e)};return A.addEventListener(e,t),function(){A.removeEventListener(e,t)}}),[e,A])},R=function(e){var A=e.questions,i=e.answers,r=e.onClose,o=t.useState(A[0]),a=o[0],g=o[1],l=t.useState(!1),c=l[0],s=l[1],f=function(){if(!a.answerIds||0===a.answerIds.length)return null;var e=a.answerIds[0];return i.find((function(t){return t.id===e}))},C=t.useState(f()),u=C[0],d=C[1];t.useEffect((function(){d(f())}),[a]);var I=function(e){return e.map((function(e){return i.find((function(t){return t.id===e}))}))};return X("keydown",(function(e){switch(e.key){case"ArrowDown":var t=I(a.answerIds).findIndex((function(e){return(null==e?void 0:e.id)===u.id+1})),n=a.answerIds[t],i=I(a.answerIds).find((function(e){return(null==e?void 0:e.id)===n}));d(i||f());break;case"ArrowUp":var o=I(a.answerIds).findIndex((function(e){return(null==e?void 0:e.id)===u.id-1})),l=a.answerIds&&a.answerIds[o],c=I(a.answerIds).find((function(e){return(null==e?void 0:e.id)===l}));d(c||I(a.answerIds).pop());break;case"Enter":if(s(!1),null==u||!u.nextQuestionId)return void r();g(A.find((function(e){return e.id===u.nextQuestionId})))}})),n.createElement(K,null,n.createElement(S,null,n.createElement(T,{text:a.text,onStart:function(){return s(!1)},onFinish:function(){return s(!0)}})),c&&n.createElement(j,null,function(){var e=a.answerIds;if(!e)return null;var t=I(e);return t?t.map((function(e){var t=(null==u?void 0:u.id)===(null==e?void 0:e.id),i=t?"yellow":"white";return e?n.createElement(L,{key:"answer_"+e.id},n.createElement(k,{color:i},t?"X":null),n.createElement(Y,{key:e.id,onClick:function(){return function(e){s(!1),e.nextQuestionId?g(A.find((function(t){return t.id===e.nextQuestionId}))):r()}(e)},color:i},e.text)):null})):null}()))},K=A.div.withConfig({displayName:"QuestionDialog__Container",componentId:"sc-bxc5u0-0"})(["display:flex;word-break:break-all;box-sizing:border-box;justify-content:flex-start;align-items:flex-start;flex-wrap:wrap;"]),S=A.div.withConfig({displayName:"QuestionDialog__QuestionContainer",componentId:"sc-bxc5u0-1"})(["flex:100%;width:100%;"]),j=A.div.withConfig({displayName:"QuestionDialog__AnswersContainer",componentId:"sc-bxc5u0-2"})(["flex:100%;"]),Y=A.p.withConfig({displayName:"QuestionDialog__Answer",componentId:"sc-bxc5u0-3"})(["flex:auto;color:"," !important;font-size:0.65rem !important;background:inherit;border:none;"],(function(e){return e.color})),k=A.span.withConfig({displayName:"QuestionDialog__AnswerSelectedIcon",componentId:"sc-bxc5u0-4"})(["flex:5% 0 0;color:"," !important;"],(function(e){return e.color})),L=A.div.withConfig({displayName:"QuestionDialog__AnswerRow",componentId:"sc-bxc5u0-5"})(["display:flex;flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:0.5rem;height:22px;p{line-height:unset;margin-top:0;margin-bottom:0rem;}"]);(d=exports.NPCDialogType||(exports.NPCDialogType={})).TextOnly="TextOnly",d.TextAndThumbnail="TextAndThumbnail";var V,q=A.div.withConfig({displayName:"NPCDialog__Container",componentId:"sc-1b4aw74-0"})(["display:flex;width:100%;height:100%;box-sizing:border-box;justify-content:center;align-items:flex-start;position:relative;"]),U=A.div.withConfig({displayName:"NPCDialog__TextContainer",componentId:"sc-1b4aw74-1"})(["flex:"," 0 0;width:355px;"],(function(e){return e.flex})),W=A.div.withConfig({displayName:"NPCDialog__ThumbnailContainer",componentId:"sc-1b4aw74-2"})(["flex:30% 0 0;display:flex;justify-content:flex-end;"]),Z=A.img.withConfig({displayName:"NPCDialog__NPCThumbnail",componentId:"sc-1b4aw74-3"})(["image-rendering:pixelated;height:128px;width:128px;"]),J=A.img.withConfig({displayName:"NPCDialog__PressSpaceIndicator",componentId:"sc-1b4aw74-4"})(["position:absolute;right:",";bottom:1rem;height:20.7px;image-rendering:-webkit-optimize-contrast;"],(function(e){return e.right})),_=A.span.withConfig({displayName:"ProgressBar__ProgressBarText",componentId:"sc-qa6fzh-0"})(["font-size:1rem;color:white;text-align:center;z-index:1;position:absolute;left:50%;transform:translateX(-50%);top:12px;"]),$=A.div.withConfig({displayName:"ProgressBar__TextOverlay",componentId:"sc-qa6fzh-1"})(["width:100%;position:relative;"]),ee=A.div.withConfig({displayName:"ProgressBar__Container",componentId:"sc-qa6fzh-2"})(["display:flex;flex-direction:column;min-width:","px;width:","%;justify-content:start;align-items:flex-start;",""],(function(e){return e.minWidth}),(function(e){return e.percentageWidth}),(function(e){return e.style}));(V=exports.RangeSliderType||(exports.RangeSliderType={})).Slider="rpgui-slider",V.GoldSlider="rpgui-slider golden";var te=A.input.withConfig({displayName:"RangeSlider__Input",componentId:"sc-v8mte9-0"})(["opacity:0;"]),ne=function(e){var t=e.bgColor;return n.createElement(Ae,null,n.createElement(oe,null,n.createElement(ie,null,n.createElement(re,{value:e.value,bgColor:void 0===t?"red":t}))))},Ae=A.div.withConfig({displayName:"SimpleProgressBar__Container",componentId:"sc-mbeil3-0"})(["display:flex;justify-content:center;align-items:center;width:100%;"]),ie=A.span.withConfig({displayName:"SimpleProgressBar__BackgroundBar",componentId:"sc-mbeil3-1"})(["background-color:rgba(0,0,0,0.075);"]),re=A.span.withConfig({displayName:"SimpleProgressBar__Progress",componentId:"sc-mbeil3-2"})(["background-color:",";width:","%;"],(function(e){return e.bgColor}),(function(e){return e.value})),oe=A.div.withConfig({displayName:"SimpleProgressBar__ProgressBarContainer",componentId:"sc-mbeil3-3"})(["border-radius:60px;border:1px solid #282424;overflow:hidden;width:100%;span{display:block;height:100%;}height:8px;"]),ae=A.span.withConfig({displayName:"SkillProgressBar__TitleName",componentId:"sc-5vuroc-0"})(["margin-left:5px;"]),ge=A.span.withConfig({displayName:"SkillProgressBar__ValueDisplay",componentId:"sc-5vuroc-1"})([""]),le=A.div.withConfig({displayName:"SkillProgressBar__ProgressIconContainer",componentId:"sc-5vuroc-2"})(["display:flex;justify-content:center;align-items:center;"]),ce=A.div.withConfig({displayName:"SkillProgressBar__ProgressBody",componentId:"sc-5vuroc-3"})(["display:flex;flex-direction:row;"]),se=A.div.withConfig({displayName:"SkillProgressBar__ProgressTitle",componentId:"sc-5vuroc-4"})(["width:100%;display:flex;flex-direction:row;justify-content:space-between;span{font-size:0.6rem;}"]),fe=A.img.withConfig({displayName:"SkillProgressBar__Icon",componentId:"sc-5vuroc-5"})(["margin-right:10px;height:30px;"]),Ce=A.div.withConfig({displayName:"Truncate__Container",componentId:"sc-6x00qb-0"})(["display:-webkit-box;max-width:100%;max-height:100%;-webkit-line-clamp:",";-webkit-box-orient:vertical;overflow:hidden;"],(function(e){return e.maxLines}));exports.Button=f,exports.Chat=function(e){var A=e.chatMessages,o=e.onSendChatMessage,a=e.opacity,g=void 0===a?1:a,l=e.width,c=void 0===l?"100%":l,s=e.height,C=void 0===s?"250px":s,u=e.onCloseButton,d=t.useState(""),w=d[0],x=d[1];t.useEffect((function(){Q()}),[]),t.useEffect((function(){Q()}),[A]);var Q=function(){var e=document.querySelector(".chat-body");e&&(e.scrollTop=e.scrollHeight)};return n.createElement(p,null,n.createElement(v,{type:exports.RPGUIContainerTypes.FramedGrey,width:c,height:C,className:"chat-container",opacity:g},n.createElement(r.ErrorBoundary,{fallback:n.createElement("p",null,"Oops! Your chat has crashed.")},u&&n.createElement(m,{onClick:u,onTouchStart:u},"X"),n.createElement(I,{type:exports.RPGUIContainerTypes.FramedGrey,width:"100%",height:"80%",className:"chat-body dark-background"},function(e){return null!=e&&e.length?null==e?void 0:e.map((function(e,t){return n.createElement(P,{key:e._id+"_"+t},function(e,t,n){return i(t||new Date).format("HH:mm")+" "+(null!=e&&e.name?e.name+": ":"Unknown: ")+" "+n}(e.emitter,e.createdAt,e.message))})):n.createElement(P,null,"No messages available.")}(A)),n.createElement(h,{onSubmit:function(e){e.preventDefault(),o(w),x("")}},n.createElement(B,{flex:70},n.createElement(E,{value:w,id:"inputMessage",onChange:function(e){x(e.target.value)},height:20,className:"chat-input dark-background",type:"text",autoComplete:"off"})),n.createElement(B,{justifyContent:"flex-end"},n.createElement(f,{buttonType:exports.ButtonTypes.RPGUIButton,id:"chat-send-button"},"Send"))))))},exports.CheckButton=function(e){var A=e.items,i=e.onChange,r=t.useState(function(){var e={};return A.forEach((function(t){e[t.label]=!1})),e}()),o=r[0],a=r[1];return t.useEffect((function(){o&&i(o)}),[o]),n.createElement("div",{id:"elemento-checkbox"},null==A?void 0:A.map((function(e,t){return n.createElement("div",{key:e.label+"_"+t},n.createElement("input",{className:"rpgui-checkbox",type:"checkbox",checked:o[e.label],onChange:function(){}}),n.createElement("label",{onClick:function(){var t,n;a(g({},o,((n={})[t=e.label]=!o[t],n)))}},e.label),n.createElement("br",null))})))},exports.DraggableContainer=function(e){var t=e.children,A=e.width,i=e.type,r=void 0===i?exports.RPGUIContainerTypes.FramedGold:i,a=e.onCloseButton,g=e.title,l=e.imgSrc,c=e.imgWidth;return n.createElement(o,null,n.createElement(x,{width:void 0===A?"50%":A,height:e.height||"auto",className:"rpgui-container "+r+" "+e.className+" rpgui-draggable"},n.createElement(D,null,n.createElement(y,null,l&&n.createElement(H,{src:l,width:void 0===c?"20px":c}),g)),a&&n.createElement(Q,{onClick:a,onTouchStart:a},"X"),t))},exports.Dropdown=function(e){var A=e.options,i=e.width,r=e.onChange,o=a.v4(),g=t.useState(""),l=g[0],c=g[1];return t.useEffect((function(){var e=document.getElementById("rpgui-dropdown-"+o),t=z.get_value(e);c(t),null==e||e.addEventListener("change",(function(e){c(null==e?void 0:e.target.value)}))}),[]),t.useEffect((function(){l&&r(l)}),[l]),n.createElement("select",{id:"rpgui-dropdown-"+o,style:{width:i},className:"rpgui-dropdown"},A.map((function(e){return n.createElement("option",{key:e.id,value:e.value},e.option)})))},exports.DynamicText=T,exports.Input=u,exports.InputRadio=function(e){var A=e.name,i=e.items,r=e.onChange,o=t.useState(),a=o[0],g=o[1],l=function(){var e=document.querySelector("input[name="+A+"]:checked");g(e.value)};return t.useEffect((function(){a&&r(a)}),[a]),n.createElement("div",{id:"elemento-radio"},i.map((function(e){return n.createElement(n.Fragment,null,n.createElement("input",{key:e.value,className:"rpgui-radio",value:e.value,name:A,type:"radio"}),n.createElement("label",{onClick:l},e.label),n.createElement("br",null))})))},exports.ListMenu=function(e){var t=e.onSelected,A=e.fontSize;return n.createElement(b,{x:e.x,y:e.y,fontSize:void 0===A?.8:A},n.createElement("ul",{className:"rpgui-list-imp",style:{overflow:"hidden"}},e.options.map((function(e){return n.createElement(N,{key:e.text,onClick:function(){t(e.id)}},e.text)}))))},exports.NPCDialog=function(e){var A=e.text,i=e.type,r=e.onClose,o=e.imagePath,a=e.isQuestionDialog,g=void 0!==a&&a,l=e.questions,c=e.answers,s=t.useState(!1),f=s[0],C=s[1];return n.createElement(I,{type:exports.RPGUIContainerTypes.FramedGold,width:g?"600px":"50%",height:"180px"},g&&l&&c?n.createElement(n.Fragment,null,n.createElement(U,{flex:i===exports.NPCDialogType.TextAndThumbnail?"70%":"100%"},n.createElement(R,{questions:l,answers:c,onClose:function(){r&&r()}})),i===exports.NPCDialogType.TextAndThumbnail&&n.createElement(W,null,n.createElement(Z,{src:o||F}))):n.createElement(n.Fragment,null,n.createElement(q,null,n.createElement(U,{flex:i===exports.NPCDialogType.TextAndThumbnail?"70%":"100%"},n.createElement(M,{onStartStep:function(){return C(!1)},onEndStep:function(){return C(!0)},text:A||"No text provided.",onClose:function(){r&&r()}})),i===exports.NPCDialogType.TextAndThumbnail&&n.createElement(W,null,n.createElement(Z,{src:o||F}))),f&&n.createElement(J,{right:i===exports.NPCDialogType.TextOnly?"1rem":"10.5rem",src:"data:image/gif;base64,R0lGODlhQAAgAPIAAAAAAA0NDRERESIiIigoKFlZWf///wAAACH/C05FVFNDQVBFMi4wAwEAAAAh/wtJbWFnZU1hZ2ljaw5nYW1tYT0wLjQ1NDU0NQAh+QQBFAAAACwAAAAAQAAgAAAD/wi63P4wykmrvTjrzbv/YAgIZGmeaKquakQWcCzPdG3fNukIeO//PQGDBywafcIF8chswpKKZcxApTqvNOiIZi0YsODncFaFlcNOrdTbJVff0/c3Lp/Xs2N37cy2ndt6ZnhKXHdsc4d7VnwyfIxqPWWOXXWLgHSGYoSNbZKVZp2WiJyjg1GFcaClqaqJhasyUAFrh3Cur3KqubWXBQIBAAEDtDeMaEEDAcLEx2gCycvN0jHPysPT09XR2M3a19zH3gTM4EYCBNDD4yzs7e4r48nB6gT19vf4+fr7/P3P8sKGvRtIkMUAeQoCHlzIsKHDhxAjSoTWQJnFixgzatzIsQWjRQYJAAAh/wtJbWFnZU1hZ2ljaw5nYW1tYT0wLjQ1NDU0NQAh+QQBFAAAACwAAAAAQAAgAAAD8Ai63P4wykmrvTjrzbv/YCiOlGCeaKqubMtGZiHPdG3feI6bjqD/wOBPwPAJj0ggcWFMOp+ypaI5M1it0KxNCqDKsAWDdhwt1q5fMPnJ9aJt17g4HafJ3/et+Tzn99V+aThqfTNtcHlhhIBVWG+BdDSHOmiPeHdij3aYhZONf46YkZGanzpSAV6KjaOIpqWtNwIBAAEDqqKKhZuJnHSwAgMBtqo5sGs5wcO3yM01ysTO0gXQzNPN1cXXUNnbyNna3kcmwrW3Lujp6ugD5bbn6/HyLe20Cu/t+fr7/P3+/wCF2VswrKDBgwgTKlzIsCCDBAA7"})))},exports.ProgressBar=function(e){var t=e.max,A=e.value,i=e.color,r=e.displayText,o=void 0===r||r,a=e.percentageWidth,g=void 0===a?40:a,l=e.minWidth,c=void 0===l?100:l,s=e.style,f=function(e,t){return t>e&&(t=e),100*t/e};return n.createElement(ee,{className:"rpgui-progress","data-value":f(t,A)/100,"data-rpguitype":"progress",percentageWidth:g,minWidth:c,style:s},o&&n.createElement($,null,n.createElement(_,null,A,"/",t)),n.createElement("div",{className:" rpgui-progress-track"},n.createElement("div",{className:"rpgui-progress-fill "+i+" ",style:{left:"0px",width:f(t,A)+"%"}})),n.createElement("div",{className:" rpgui-progress-left-edge"}),n.createElement("div",{className:" rpgui-progress-right-edge"}))},exports.QuestionDialog=R,exports.RPGUIContainer=I,exports.RPGUIRoot=function(e){return n.createElement("div",{className:"rpgui-content"},e.children)},exports.RangeSlider=function(e){var A=e.type,i=e.valueMin,r=e.valueMax,o=e.width,g=e.onChange,l=a.v4(),c=t.useState(!1),s=c[0],f=c[1];X("mouseup",(function(){s&&C(),f(!1)}));var C=function(){var e=document.getElementById("rpgui-slider-"+l),t=z.get_value(e);g(Number(t))};return n.createElement("div",{onMouseUp:C,onMouseDown:function(){return f(!0)}},n.createElement(te,{className:A===exports.RangeSliderType.Slider?exports.RangeSliderType.Slider:exports.RangeSliderType.GoldSlider,type:"range",style:{width:o},min:i,max:r,id:"rpgui-slider-"+l}))},exports.SkillProgressBar=function(e){var t=e.value,A=e.bgColor,i=e.logoSrc,r=void 0===i?"data:image/png;base64,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":i;return n.createElement(n.Fragment,null,n.createElement(se,null,n.createElement(ae,null,e.titleName),n.createElement(ge,null,t)),n.createElement(ce,null,n.createElement(le,null,n.createElement(fe,{src:r})),n.createElement(ne,{value:t,bgColor:A})))},exports.TextArea=function(e){var t=g({},e);return n.createElement("textarea",Object.assign({},t))},exports.Truncate=function(e){var t=e.maxLines;return n.createElement(Ce,{maxLines:void 0===t?1:t},e.children)},exports._RPGUI=z,exports.useEventListener=X;
2
2
  //# sourceMappingURL=long-bow.cjs.production.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"long-bow.cjs.production.min.js","sources":["../src/components/Button.tsx","../src/components/RPGUIContainer.tsx","../src/components/Input.tsx","../src/components/shared/Column.tsx","../src/components/Chat/Chat.tsx","../src/constants/uiColors.ts","../src/components/DraggableContainer.tsx","../src/components/RPGUIRoot.tsx","../src/components/ListMenu.tsx","../src/components/NPCDialog/img/npcDialog/npcThumbnails/alice.png","../src/components/NPCDialog/img/space.gif","../src/libs/StringHelpers.ts","../src/components/NPCDialog/NPCDialog.tsx","../src/components/typography/DynamicText.tsx","../src/components/NPCDialog/NPCDialogText.tsx","../src/hooks/useEventListener.ts","../src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx","../src/components/RangeSlider.tsx","../src/components/ProgressBar.tsx","../src/components/imgExp.png","../src/components/SimpleProgressBar.tsx","../src/components/SkillProgressBar.tsx","../src/components/Truncate.tsx","../src/components/CheckButton.tsx","../src/components/Dropdown.tsx","../src/components/RadioButton.tsx","../src/components/TextArea.tsx"],"sourcesContent":["import React from 'react';\nimport styled from 'styled-components';\n\nexport enum ButtonTypes {\n RPGUIButton = 'rpgui-button',\n RPGUIGoldButton = 'rpgui-button golden',\n}\n\nexport interface IButtonProps {\n children: React.ReactNode;\n buttonType: ButtonTypes;\n}\n\nexport const Button: React.FC<IButtonProps &\n React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n >> = ({ children, buttonType, ...props }) => {\n return (\n <ButtonContainer className={`${buttonType}`} {...props}>\n <p>{children}</p>\n </ButtonContainer>\n );\n};\n\nconst ButtonContainer = styled.button<any>`\n height: 45px;\n font-size: 11.5px;\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport enum RPGUIContainerTypes {\n Framed = 'framed',\n FramedGold = 'framed-golden',\n FramedGold2 = 'framed-golden-2',\n FramedGrey = 'framed-grey',\n}\nexport interface IRPGUIContainerProps {\n type: RPGUIContainerTypes;\n children: React.ReactNode;\n width?: string;\n height?: string;\n className?: string;\n}\n\nexport const RPGUIContainer: React.FC<IRPGUIContainerProps> = ({\n children,\n type,\n width = '50%',\n height,\n className,\n}) => {\n return (\n <Container\n width={width}\n height={height || 'auto'}\n className={`rpgui-container ${type} ${className}`}\n >\n {children}\n </Container>\n );\n};\n\ninterface IContainerProps {\n width: string;\n height: string;\n}\n\nconst Container = styled.div<IContainerProps>`\n height: ${props => props.height};\n width: ${({ width }) => width};\n display: flex;\n flex-wrap: wrap;\n image-rendering: pixelated;\n`;\n","import React from 'react';\n\nexport interface IInputProps\n extends React.DetailedHTMLProps<\n React.InputHTMLAttributes<HTMLInputElement>,\n HTMLInputElement\n > {}\n\nexport const Input: React.FC<IInputProps> = ({ ...props }) => {\n return <input {...props} />;\n};\n","import styled from 'styled-components';\n\ninterface IColumn {\n flex?: number;\n alignItems?: string;\n justifyContent?: string;\n flexWrap?: string;\n}\n\nexport const Column = styled.div<IColumn>`\n flex: ${props => props.flex || 'auto'};\n display: flex;\n flex-wrap: ${props => props.flexWrap || 'nowrap'};\n align-items: ${props => props.alignItems || 'flex-start'};\n justify-content: ${props => props.justifyContent || 'flex-start'};\n`;\n","import { IChatMessage } from '@rpg-engine/shared';\nimport dayjs from 'dayjs';\nimport React, { useEffect, useState } from 'react';\nimport { ErrorBoundary } from 'react-error-boundary';\nimport styled from 'styled-components';\nimport { colors } from '../../constants/uiColors';\nimport { Button, ButtonTypes } from '../Button';\nimport { Input } from '../Input';\nimport { RPGUIContainer, RPGUIContainerTypes } from '../RPGUIContainer';\nimport { Column } from '../shared/Column';\n\ninterface IEmitter {\n _id: string;\n name: string;\n}\nexport interface IChatProps {\n chatMessages: IChatMessage[];\n onSendChatMessage: (message: string) => void;\n onCloseButton: () => void;\n opacity?: number;\n width?: string;\n height?: string;\n}\n\nexport const Chat: React.FC<IChatProps> = ({\n chatMessages,\n onSendChatMessage,\n opacity = 1,\n width = '100%',\n height = '250px',\n onCloseButton,\n}) => {\n const [message, setMessage] = useState('');\n\n useEffect(() => {\n scrollChatToBottom();\n }, []);\n\n useEffect(() => {\n scrollChatToBottom();\n }, [chatMessages]);\n\n const scrollChatToBottom = () => {\n const scrollingElement = document.querySelector('.chat-body');\n if (scrollingElement) {\n scrollingElement.scrollTop = scrollingElement.scrollHeight;\n }\n };\n\n const handleSubmit = (event: React.SyntheticEvent<HTMLFormElement>) => {\n event.preventDefault();\n onSendChatMessage(message);\n setMessage('');\n };\n const getInputValue = (value: string) => {\n setMessage(value);\n };\n\n const onRenderMessageLines = (\n emitter: IEmitter,\n createdAt: string | undefined,\n message: string\n ) => {\n return `${dayjs(createdAt || new Date()).format('HH:mm')} ${\n emitter?.name ? `${emitter.name}: ` : 'Unknown: '\n } ${message}`;\n };\n\n const onRenderChatMessages = (chatMessages: IChatMessage[]) => {\n return chatMessages?.length ? (\n chatMessages?.map(({ _id, createdAt, emitter, message }, index) => (\n <MessageText key={`${_id}_${index}`}>\n {onRenderMessageLines(emitter, createdAt, message)}\n </MessageText>\n ))\n ) : (\n <MessageText>No messages available.</MessageText>\n );\n };\n\n return (\n <Container>\n <CustomContainer\n type={RPGUIContainerTypes.FramedGrey}\n width={width}\n height={height}\n className=\"chat-container\"\n opacity={opacity}\n >\n <ErrorBoundary fallback={<p>Oops! Your chat has crashed.</p>}>\n {onCloseButton && (\n <CloseButton onClick={onCloseButton} onTouchStart={onCloseButton}>\n X\n </CloseButton>\n )}\n <RPGUIContainer\n type={RPGUIContainerTypes.FramedGrey}\n width={'100%'}\n height={'80%'}\n className=\"chat-body dark-background\"\n >\n {onRenderChatMessages(chatMessages)}\n </RPGUIContainer>\n\n <Form onSubmit={handleSubmit}>\n <Column flex={70}>\n <CustomInput\n value={message}\n id=\"inputMessage\"\n onChange={e => getInputValue(e.target.value)}\n height={20}\n className=\"chat-input dark-background\"\n type=\"text\"\n autoComplete=\"off\"\n />\n </Column>\n <Column justifyContent=\"flex-end\">\n <Button\n buttonType={ButtonTypes.RPGUIButton}\n id=\"chat-send-button\"\n >\n Send\n </Button>\n </Column>\n </Form>\n </ErrorBoundary>\n </CustomContainer>\n </Container>\n );\n};\n\nconst Container = styled.div`\n position: relative;\n`;\n\nconst CloseButton = styled.div`\n position: absolute;\n top: 3px;\n right: 0px;\n color: white;\n z-index: 22;\n font-size: 10px;\n`;\n\nconst CustomInput = styled(Input)`\n height: 30px;\n width: 100%;\n\n .rpgui-content .input {\n min-height: 39px;\n }\n`;\n\ninterface ICustomContainerProps {\n opacity: number;\n}\n\nconst CustomContainer = styled(RPGUIContainer)`\n display: block;\n\n opacity: ${(props: ICustomContainerProps) => props.opacity};\n\n &:hover {\n opacity: 1;\n }\n\n .dark-background {\n background-color: ${colors.darkGrey} !important;\n }\n\n .chat-body {\n &.rpgui-container.framed-grey {\n background: unset;\n }\n max-height: 170px;\n overflow-y: auto;\n }\n`;\n\nconst Form = styled.form`\n display: flex;\n width: 100%;\n justify-content: center;\n align-items: center;\n`;\n\nconst MessageText = styled.p`\n display: block !important;\n width: 100%;\n font-size: 0.7rem !important;\n overflow-y: auto;\n margin: 0;\n`;\n","export const colors = {\n darkGrey: '#3e3e3e',\n};\n","import React from 'react';\nimport Draggable from 'react-draggable';\nimport styled from 'styled-components';\nimport { RPGUIContainerTypes } from './RPGUIContainer';\n\nexport interface IDraggableContainerProps {\n children: React.ReactNode;\n width?: string;\n height?: string;\n className?: string;\n type?: RPGUIContainerTypes;\n title: string;\n imgSrc?: string;\n imgWidth?: string;\n onCloseButton: () => void;\n}\n\nexport const DraggableContainer: React.FC<IDraggableContainerProps> = ({\n children,\n width = '50%',\n height,\n className,\n type = RPGUIContainerTypes.FramedGold,\n onCloseButton,\n title,\n imgSrc,\n imgWidth = '20px',\n}) => {\n return (\n <Draggable>\n <Container\n width={width}\n height={height || 'auto'}\n className={`rpgui-container ${type} ${className} rpgui-draggable`}\n >\n <TitleContainer>\n <Title>\n {imgSrc && <Icon src={imgSrc} width={imgWidth} />}\n {title}\n </Title>\n </TitleContainer>\n {onCloseButton && (\n <CloseButton onClick={onCloseButton} onTouchStart={onCloseButton}>\n X\n </CloseButton>\n )}\n\n {children}\n </Container>\n </Draggable>\n );\n};\n\ninterface IContainerProps {\n width: string;\n height: string;\n}\n\nconst Container = styled.div<IContainerProps>`\n height: ${props => props.height};\n width: ${({ width }) => width};\n display: flex;\n flex-wrap: wrap;\n image-rendering: pixelated;\n`;\n\nconst CloseButton = styled.div`\n position: absolute;\n top: 3px;\n right: 0px;\n color: white;\n z-index: 22;\n font-size: 10px;\n`;\n\nconst TitleContainer = styled.div`\n width: 100%;\n\n display: flex;\n flex-wrap: wrap;\n justify-content: center;\n align-items: center;\n`;\n\nconst Title = styled.h1`\n color: white;\n z-index: 22;\n font-size: 10px;\n`;\n\ninterface ICustomIconProps {\n width: string;\n}\n\nconst Icon = styled.img`\n color: white;\n z-index: 22;\n font-size: 10px;\n width: ${(props: ICustomIconProps) => props.width};\n margin-right: 0.5rem;\n`;\n","import React from 'react';\nimport 'rpgui/rpgui.min.css';\nimport 'rpgui/rpgui.min.js';\n\ninterface IProps {\n children: React.ReactNode;\n}\n\n//@ts-ignore\nexport const _RPGUI = RPGUI;\n\nexport const RPGUIRoot: React.FC<IProps> = ({ children }) => {\n return <div className=\"rpgui-content\">{children}</div>;\n};\n","import React from 'react';\nimport styled from 'styled-components';\n\ninterface IListMenuOption {\n id: string;\n text: string;\n}\n\nexport interface IListMenuProps {\n x: number;\n y: number;\n options: IListMenuOption[];\n onSelected: (selectedOptionId: string) => void;\n fontSize?: number;\n}\n\nexport const ListMenu: React.FC<IListMenuProps> = ({\n options,\n onSelected,\n x,\n y,\n fontSize = 0.8,\n}) => {\n return (\n <Container x={x} y={y} fontSize={fontSize}>\n <ul className=\"rpgui-list-imp\" style={{ overflow: 'hidden' }}>\n {options.map(params => (\n <ListElement\n key={params.text}\n onClick={() => {\n onSelected(params.id);\n }}\n >\n {params.text}\n </ListElement>\n ))}\n </ul>\n </Container>\n );\n};\n\ninterface IContainerProps {\n x?: number;\n y?: number;\n fontSize?: number;\n}\n\nconst Container = styled.div<IContainerProps>`\n display: flex;\n flex-direction: column;\n width: 100%;\n justify-content: start;\n align-items: flex-start;\n position: absolute;\n top: ${props => props.y || 0}px;\n left: ${props => props.x || 0}px;\n\n li {\n font-size: ${props => props.fontSize}em;\n }\n`;\n\nconst ListElement = styled.li`\n margin-right: 0.5rem;\n`;\n","const img = require('./alice.png'); export default img;","const img = require('./space.gif'); export default img;","export const chunkString = (str: string, length: number) => {\n return str.match(new RegExp('.{1,' + length + '}', 'g'));\n};\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { RPGUIContainer, RPGUIContainerTypes } from '../RPGUIContainer';\nimport aliceDefaultThumbnail from './img/npcDialog/npcThumbnails/alice.png';\nimport pressSpaceGif from './img/space.gif';\nimport { NPCDialogText } from './NPCDialogText';\nimport {\n IQuestionDialog,\n IQuestionDialogAnswer,\n QuestionDialog,\n} from './QuestionDialog/QuestionDialog';\n\nexport enum NPCDialogType {\n TextOnly = 'TextOnly',\n TextAndThumbnail = 'TextAndThumbnail',\n}\n\nexport interface INPCDialogProps {\n text?: string;\n type: NPCDialogType;\n imagePath?: string;\n onClose?: () => void;\n isQuestionDialog?: boolean;\n answers?: IQuestionDialogAnswer[];\n questions?: IQuestionDialog[];\n}\n\nexport const NPCDialog: React.FC<INPCDialogProps> = ({\n text,\n type,\n onClose,\n imagePath,\n isQuestionDialog = false,\n questions,\n answers,\n}) => {\n const [showGoNextIndicator, setShowGoNextIndicator] = useState<boolean>(\n false\n );\n\n return (\n <RPGUIContainer\n type={RPGUIContainerTypes.FramedGold}\n width={isQuestionDialog ? '600px' : '50%'}\n height={'180px'}\n >\n {isQuestionDialog && questions && answers ? (\n <>\n <TextContainer\n flex={type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'}\n >\n <QuestionDialog\n questions={questions}\n answers={answers}\n onClose={() => {\n if (onClose) {\n onClose();\n }\n }}\n />\n </TextContainer>\n {type === NPCDialogType.TextAndThumbnail && (\n <ThumbnailContainer>\n <NPCThumbnail src={imagePath || aliceDefaultThumbnail} />\n </ThumbnailContainer>\n )}\n </>\n ) : (\n <>\n <Container>\n <TextContainer\n flex={type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'}\n >\n <NPCDialogText\n onStartStep={() => setShowGoNextIndicator(false)}\n onEndStep={() => setShowGoNextIndicator(true)}\n text={text || 'No text provided.'}\n onClose={() => {\n if (onClose) {\n onClose();\n }\n }}\n />\n </TextContainer>\n {type === NPCDialogType.TextAndThumbnail && (\n <ThumbnailContainer>\n <NPCThumbnail src={imagePath || aliceDefaultThumbnail} />\n </ThumbnailContainer>\n )}\n </Container>\n {showGoNextIndicator && (\n <PressSpaceIndicator\n right={type === NPCDialogType.TextOnly ? '1rem' : '10.5rem'}\n src={pressSpaceGif}\n />\n )}\n </>\n )}\n </RPGUIContainer>\n );\n};\n\nconst Container = styled.div`\n display: flex;\n width: 100%;\n height: 100%;\n\n box-sizing: border-box;\n justify-content: center;\n align-items: flex-start;\n position: relative;\n`;\n\ninterface ITextContainerProps {\n flex: string;\n}\n\nconst TextContainer = styled.div<ITextContainerProps>`\n flex: ${({ flex }) => flex} 0 0;\n width: 355px;\n`;\n\nconst ThumbnailContainer = styled.div`\n flex: 30% 0 0;\n display: flex;\n justify-content: flex-end;\n`;\n\nconst NPCThumbnail = styled.img`\n image-rendering: pixelated;\n height: 128px;\n width: 128px;\n`;\n\ninterface IPressSpaceIndicatorProps {\n right: string;\n}\n\nconst PressSpaceIndicator = styled.img<IPressSpaceIndicatorProps>`\n position: absolute;\n right: ${({ right }) => right};\n bottom: 1rem;\n height: 20.7px;\n image-rendering: -webkit-optimize-contrast;\n`;\n","import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\n\ninterface IProps {\n text: string;\n onFinish?: () => void;\n onStart?: () => void;\n}\n\nexport const DynamicText: React.FC<IProps> = ({ text, onFinish, onStart }) => {\n const [textState, setTextState] = useState<string>('');\n\n useEffect(() => {\n let i = 0;\n const interval = setInterval(() => {\n // on every interval, show one more character\n\n if (i === 0) {\n if (onStart) {\n onStart();\n }\n }\n\n if (i < text.length) {\n setTextState(text.substring(0, i + 1));\n i++;\n } else {\n clearInterval(interval);\n if (onFinish) {\n onFinish();\n }\n }\n }, 50);\n\n return () => {\n clearInterval(interval);\n };\n }, [text]);\n\n return <TextContainer>{textState}</TextContainer>;\n};\n\nconst TextContainer = styled.p`\n font-size: 0.7rem !important;\n color: white;\n text-shadow: 1px 1px 0px #000000;\n letter-spacing: 1.2px;\n word-break: normal;\n`;\n","import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport { chunkString } from '../../libs/StringHelpers';\nimport { DynamicText } from '../typography/DynamicText';\n\ninterface IProps {\n text: string;\n onClose: () => void;\n onEndStep: () => void;\n onStartStep: () => void;\n}\n\nexport const NPCDialogText: React.FC<IProps> = ({\n text,\n onClose,\n onEndStep,\n onStartStep,\n}) => {\n const textChunks = chunkString(text, 85);\n\n const [chunkIndex, setChunkIndex] = useState<number>(0);\n\n const onHandleSpacePress = (event: KeyboardEvent) => {\n if (event.code === 'Space') {\n const hasNextChunk = textChunks?.[chunkIndex + 1] || false;\n\n if (hasNextChunk) {\n setChunkIndex(prev => prev + 1);\n } else {\n // if there's no more text chunks, close the dialog\n onClose();\n }\n }\n };\n\n useEffect(() => {\n document.addEventListener('keydown', onHandleSpacePress);\n\n return () => document.removeEventListener('keydown', onHandleSpacePress);\n }, [chunkIndex]);\n\n return (\n <Container>\n <DynamicText\n text={textChunks?.[chunkIndex] || ''}\n onFinish={onEndStep}\n onStart={onStartStep}\n />\n </Container>\n );\n};\n\nconst Container = styled.div``;\n","import React from 'react';\n\n//@ts-ignore\nexport const useEventListener = (type, handler, el = window) => {\n const savedHandler = React.useRef();\n\n React.useEffect(() => {\n savedHandler.current = handler;\n }, [handler]);\n\n React.useEffect(() => {\n //@ts-ignore\n const listener = e => savedHandler.current(e);\n\n el.addEventListener(type, listener);\n\n return () => {\n el.removeEventListener(type, listener);\n };\n }, [type, el]);\n};\n","import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport { useEventListener } from '../../../hooks/useEventListener';\nimport { DynamicText } from '../../typography/DynamicText';\n\nexport interface IQuestionDialogAnswer {\n id: number;\n text: string;\n nextQuestionId?: number;\n}\n\nexport interface IQuestionDialog {\n id: number;\n text: string;\n answerIds?: number[];\n}\n\nexport interface IProps {\n questions: IQuestionDialog[];\n answers: IQuestionDialogAnswer[];\n onClose: () => void;\n}\n\nexport const QuestionDialog: React.FC<IProps> = ({\n questions,\n answers,\n onClose,\n}) => {\n const [currentQuestion, setCurrentQuestion] = useState(questions[0]);\n\n const [canShowAnswers, setCanShowAnswers] = useState<boolean>(false);\n\n const onGetFirstAnswer = () => {\n if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {\n return null;\n }\n\n const firstAnswerId = currentQuestion.answerIds![0];\n\n return answers.find(answer => answer.id === firstAnswerId);\n };\n\n const [\n currentAnswer,\n setCurrentAnswer,\n ] = useState<IQuestionDialogAnswer | null>(onGetFirstAnswer()!);\n\n useEffect(() => {\n setCurrentAnswer(onGetFirstAnswer()!);\n }, [currentQuestion]);\n\n const onGetAnswers = (answerIds: number[]) => {\n return answerIds.map((answerId: number) =>\n answers.find(answer => answer.id === answerId)\n );\n };\n\n const onKeyPress = (e: KeyboardEvent) => {\n switch (e.key) {\n case 'ArrowDown':\n // select next answer, if any.\n // if no next answer, select first answer\n // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(\n // (answer) => answer?.id === currentAnswer!.id + 1\n // );\n\n const nextAnswerIndex = onGetAnswers(\n currentQuestion.answerIds!\n ).findIndex(answer => answer?.id === currentAnswer!.id + 1);\n\n const nextAnswerID = currentQuestion.answerIds![nextAnswerIndex];\n\n // console.log(nextAnswerIndex);\n\n const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(\n answer => answer?.id === nextAnswerID\n );\n\n setCurrentAnswer(nextAnswer || onGetFirstAnswer()!);\n\n break;\n case 'ArrowUp':\n // select previous answer, if any.\n // if no previous answer, select last answer\n\n const previousAnswerIndex = onGetAnswers(\n currentQuestion.answerIds!\n ).findIndex(answer => answer?.id === currentAnswer!.id - 1);\n\n const previousAnswerID =\n currentQuestion.answerIds &&\n currentQuestion.answerIds[previousAnswerIndex];\n\n const previousAnswer = onGetAnswers(currentQuestion.answerIds!).find(\n answer => answer?.id === previousAnswerID\n );\n\n if (previousAnswer) {\n setCurrentAnswer(previousAnswer);\n } else {\n setCurrentAnswer(onGetAnswers(currentQuestion.answerIds!).pop()!);\n }\n\n break;\n case 'Enter':\n setCanShowAnswers(false);\n\n if (!currentAnswer?.nextQuestionId) {\n onClose();\n return;\n } else {\n setCurrentQuestion(\n questions.find(\n question => question.id === currentAnswer!.nextQuestionId\n )!\n );\n }\n\n break;\n }\n };\n useEventListener('keydown', onKeyPress);\n\n const onAnswerClick = (answer: IQuestionDialogAnswer) => {\n setCanShowAnswers(false);\n if (answer.nextQuestionId) {\n // if there is a next question, go to it\n setCurrentQuestion(\n questions.find(question => question.id === answer.nextQuestionId)!\n );\n } else {\n // else, finish dialog!\n onClose();\n }\n };\n\n const onRenderCurrentAnswers = () => {\n const answerIds = currentQuestion.answerIds;\n if (!answerIds) {\n return null;\n }\n\n const answers = onGetAnswers(answerIds);\n\n if (!answers) {\n return null;\n }\n\n return answers.map(answer => {\n const isSelected = currentAnswer?.id === answer?.id;\n const selectedColor = isSelected ? 'yellow' : 'white';\n\n if (answer) {\n return (\n <AnswerRow key={`answer_${answer.id}`}>\n <AnswerSelectedIcon color={selectedColor}>\n {isSelected ? 'X' : null}\n </AnswerSelectedIcon>\n\n <Answer\n key={answer.id}\n onClick={() => onAnswerClick(answer)}\n color={selectedColor}\n >\n {answer.text}\n </Answer>\n </AnswerRow>\n );\n }\n\n return null;\n });\n };\n\n return (\n <Container>\n <QuestionContainer>\n <DynamicText\n text={currentQuestion.text}\n onStart={() => setCanShowAnswers(false)}\n onFinish={() => setCanShowAnswers(true)}\n />\n </QuestionContainer>\n\n {canShowAnswers && (\n <AnswersContainer>{onRenderCurrentAnswers()}</AnswersContainer>\n )}\n </Container>\n );\n};\n\nconst Container = styled.div`\n display: flex;\n\n word-break: break-all;\n\n box-sizing: border-box;\n justify-content: flex-start;\n align-items: flex-start;\n flex-wrap: wrap;\n`;\n\nconst QuestionContainer = styled.div`\n flex: 100%;\n width: 100%;\n`;\n\nconst AnswersContainer = styled.div`\n flex: 100%;\n`;\n\ninterface IAnswerProps {\n color: string;\n}\n\nconst Answer = styled.p<IAnswerProps>`\n flex: auto;\n color: ${props => props.color} !important;\n font-size: 0.65rem !important;\n background: inherit;\n border: none;\n`;\n\nconst AnswerSelectedIcon = styled.span<IAnswerProps>`\n flex: 5% 0 0;\n color: ${props => props.color} !important;\n`;\n\nconst AnswerRow = styled.div`\n display: flex;\n flex-wrap: wrap;\n justify-content: center;\n align-items: center;\n margin-bottom: 0.5rem;\n height: 22px;\n\n p {\n line-height: unset;\n margin-top: 0;\n margin-bottom: 0rem;\n }\n`;\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { v4 as uuidv4 } from 'uuid';\nimport { useEventListener } from '../hooks/useEventListener';\nimport { _RPGUI } from './RPGUIRoot';\n\nexport enum RangeSliderType {\n Slider = 'rpgui-slider',\n GoldSlider = 'rpgui-slider golden',\n}\n\nexport interface IRangeSliderProps {\n type: RangeSliderType;\n valueMin: number;\n valueMax: number;\n width: string;\n onChange: (value: number) => void;\n}\n\nexport const RangeSlider: React.FC<IRangeSliderProps> = ({\n type,\n valueMin,\n valueMax,\n width,\n onChange,\n}) => {\n const sliderId = uuidv4();\n\n const [wasMouseDownFirst, setWasMouseDownFirst] = useState<boolean>(false);\n\n useEventListener('mouseup', () => {\n if (wasMouseDownFirst) {\n onHandleMouseUp();\n }\n setWasMouseDownFirst(false);\n });\n\n const onHandleMouseUp = () => {\n const rpguiSlider = document.getElementById(`rpgui-slider-${sliderId}`);\n const value = _RPGUI.get_value(rpguiSlider);\n\n onChange(Number(value));\n };\n\n return (\n <div\n onMouseUp={onHandleMouseUp}\n onMouseDown={() => setWasMouseDownFirst(true)}\n >\n <Input\n className={\n type === RangeSliderType.Slider\n ? RangeSliderType.Slider\n : RangeSliderType.GoldSlider\n }\n type=\"range\"\n style={{ width: width }}\n min={valueMin}\n max={valueMax}\n id={`rpgui-slider-${sliderId}`}\n />\n </div>\n );\n};\n\nconst Input = styled.input`\n opacity: 0;\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport interface IBarProps {\n max: number;\n value: number;\n color: 'red' | 'blue' | 'green';\n style?: Record<string, any>;\n displayText?: boolean;\n percentageWidth?: number;\n minWidth?: number;\n}\n\nexport const ProgressBar: React.FC<IBarProps> = ({\n max,\n value,\n color,\n displayText = true,\n percentageWidth = 40,\n minWidth = 100,\n style,\n}) => {\n const calculatePercentageValue = function(max: number, value: number) {\n if (value > max) {\n value = max;\n }\n return (value * 100) / max;\n };\n\n return (\n <Container\n className=\"rpgui-progress\"\n data-value={calculatePercentageValue(max, value) / 100}\n data-rpguitype=\"progress\"\n percentageWidth={percentageWidth}\n minWidth={minWidth}\n style={style}\n >\n {displayText && (\n <TextOverlay>\n <ProgressBarText>\n {value}/{max}\n </ProgressBarText>\n </TextOverlay>\n )}\n <div className=\" rpgui-progress-track\">\n <div\n className={`rpgui-progress-fill ${color} `}\n style={{\n left: '0px',\n width: calculatePercentageValue(max, value) + '%',\n }}\n ></div>\n </div>\n <div className=\" rpgui-progress-left-edge\"></div>\n <div className=\" rpgui-progress-right-edge\"></div>\n </Container>\n );\n};\n\nconst ProgressBarText = styled.span`\n font-size: 1rem;\n color: white;\n text-align: center;\n z-index: 1;\n position: absolute;\n left: 50%;\n transform: translateX(-50%);\n top: 12px;\n`;\n\nconst TextOverlay = styled.div`\n width: 100%;\n position: relative;\n`;\n\ninterface IContainerProps {\n percentageWidth?: number;\n minWidth?: number;\n style?: Record<string, any>;\n}\n\nconst Container = styled.div<IContainerProps>`\n display: flex;\n flex-direction: column;\n min-width: ${props => props.minWidth}px;\n width: ${props => props.percentageWidth}%;\n justify-content: start;\n align-items: flex-start;\n ${props => props.style}\n`;\n","const img = require('./imgExp.png'); export default img;","import React from 'react';\nimport styled from 'styled-components';\n\ninterface IProps {\n value: number;\n height?: string;\n bgColor?: string;\n}\n\nexport const SimpleProgressBar: React.FC<IProps> = ({\n value,\n\n bgColor = 'red',\n}) => {\n return (\n <Container>\n <ProgressBarContainer>\n <BackgroundBar>\n <Progress value={value} bgColor={bgColor} />\n </BackgroundBar>\n </ProgressBarContainer>\n </Container>\n );\n};\n\nconst Container = styled.div`\n display: flex;\n justify-content: center;\n align-items: center;\n width: 100%;\n`;\n\nconst BackgroundBar = styled.span`\n background-color: rgba(0, 0, 0, 0.075);\n`;\n\ninterface IProgressProps {\n value: number;\n bgColor: string;\n}\n\nconst Progress = styled.span`\n background-color: ${(props: IProgressProps) => props.bgColor};\n width: ${(props: IProgressProps) => props.value}%;\n`;\n\nconst ProgressBarContainer = styled.div`\n border-radius: 60px;\n border: 1px solid #282424;\n overflow: hidden;\n width: 100%;\n span {\n display: block;\n height: 100%;\n }\n\n height: 8px;\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport imgSrcTemplate from './imgExp.png';\nimport { SimpleProgressBar } from './SimpleProgressBar';\n\nexport interface ISkillProgressBarProps {\n value: number;\n\n height: string;\n bgColor: string;\n titleName: string;\n\n logoSrc?: string;\n}\n\nexport const SkillProgressBar: React.FC<ISkillProgressBarProps> = ({\n value,\n bgColor,\n titleName,\n\n logoSrc = imgSrcTemplate,\n}) => {\n return (\n <>\n <ProgressTitle>\n <TitleName>{titleName}</TitleName>\n <ValueDisplay>{value}</ValueDisplay>\n </ProgressTitle>\n <ProgressBody>\n <ProgressIconContainer>\n <Icon src={logoSrc} />\n </ProgressIconContainer>\n\n <SimpleProgressBar value={value} bgColor={bgColor} />\n </ProgressBody>\n </>\n );\n};\n\nconst TitleName = styled.span`\n margin-left: 5px;\n`;\n\nconst ValueDisplay = styled.span``;\n\nconst ProgressIconContainer = styled.div`\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nconst ProgressBody = styled.div`\n display: flex;\n flex-direction: row;\n`;\n\nconst ProgressTitle = styled.div`\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n span {\n font-size: 0.6rem;\n }\n`;\n\nconst Icon = styled.img`\n margin-right: 10px;\n height: 30px;\n`;\n","/* eslint-disable react/require-default-props */\nimport React from 'react';\nimport styled from 'styled-components';\n\ninterface IProps {\n maxLines?: number;\n children: React.ReactNode;\n}\n\nexport const Truncate: React.FC<IProps> = ({ maxLines = 1, children }) => {\n return <Container maxLines={maxLines}>{children}</Container>;\n};\n\ninterface IContainerProps {\n maxLines: number;\n}\n\nconst Container = styled.div<IContainerProps>`\n display: -webkit-box;\n max-width: 100%;\n max-height: 100%;\n -webkit-line-clamp: ${props => props.maxLines};\n -webkit-box-orient: vertical;\n overflow: hidden;\n`;\n","import React, { useEffect, useState } from 'react';\n\nexport interface ICheckItems {\n label: string;\n value: string;\n}\n\nexport interface ICheckProps {\n items: ICheckItems[];\n onChange: (selectedValues: IChecklistSelectedValues) => void;\n}\n\ninterface IChecklistSelectedValues {\n [label: string]: boolean;\n}\n\nexport const CheckButton: React.FC<ICheckProps> = ({ items, onChange }) => {\n const generateSelectedValuesList = () => {\n const selectedValues: IChecklistSelectedValues = {};\n\n items.forEach(item => {\n selectedValues[item.label] = false;\n });\n\n return selectedValues;\n };\n\n const [selectedValues, setSelectedValues] = useState<\n IChecklistSelectedValues\n >(generateSelectedValuesList());\n\n const handleClick = (label: string) => {\n setSelectedValues({\n ...selectedValues,\n [label]: !selectedValues[label],\n });\n };\n\n useEffect(() => {\n if (selectedValues) {\n onChange(selectedValues);\n }\n }, [selectedValues]);\n\n return (\n <div id=\"elemento-checkbox\">\n {items?.map((element, index) => {\n return (\n <div key={`${element.label}_${index}`}>\n <input\n className=\"rpgui-checkbox\"\n type=\"checkbox\"\n checked={selectedValues[element.label]}\n onChange={() => {}}\n />\n <label onClick={() => handleClick(element.label)}>\n {element.label}\n </label>\n <br />\n </div>\n );\n })}\n </div>\n );\n};\n","import React, { useEffect, useState } from 'react';\nimport { v4 as uuidv4 } from 'uuid';\nimport { _RPGUI } from './RPGUIRoot';\n\nexport interface IOptionsProps {\n id: number;\n value: string;\n option: string;\n}\n\nexport interface IDropdownProps {\n options: IOptionsProps[];\n width?: string;\n onChange: (value: string) => void;\n}\n\nexport const Dropdown: React.FC<IDropdownProps> = ({\n options,\n width,\n onChange,\n}) => {\n const dropdownId = uuidv4();\n\n const [selectedValue, setSelectedValue] = useState<string>('');\n\n useEffect(() => {\n const element = document.getElementById(`rpgui-dropdown-${dropdownId}`);\n const dropdownValue = _RPGUI.get_value(element);\n setSelectedValue(dropdownValue);\n\n element?.addEventListener('change', (event: any) => {\n setSelectedValue(event?.target.value);\n });\n }, []);\n\n useEffect(() => {\n if (selectedValue) {\n onChange(selectedValue);\n }\n }, [selectedValue]);\n\n return (\n <select\n id={`rpgui-dropdown-${dropdownId}`}\n style={{ width: width }}\n className=\"rpgui-dropdown\"\n >\n {options.map(option => {\n return (\n <option key={option.id} value={option.value}>\n {option.option}\n </option>\n );\n })}\n </select>\n );\n};\n","import React, { useEffect, useState } from 'react';\n\nexport interface IRadioItems {\n label: string;\n value: string;\n}\n\nexport interface IRadioProps {\n name: string;\n items: IRadioItems[];\n onChange: (value: string) => void;\n}\n\nexport const InputRadio: React.FC<IRadioProps> = ({\n name,\n items,\n onChange,\n}) => {\n const [selectedValue, setSelectedValue] = useState<string>();\n const handleClick = () => {\n let element = document.querySelector(\n `input[name=${name}]:checked`\n ) as HTMLInputElement;\n const elementValue = element.value;\n setSelectedValue(elementValue);\n };\n\n useEffect(() => {\n if (selectedValue) {\n onChange(selectedValue);\n }\n }, [selectedValue]);\n\n return (\n <div id=\"elemento-radio\">\n {items.map(element => {\n return (\n <>\n <input\n key={element.value}\n className=\"rpgui-radio\"\n value={element.value}\n name={name}\n type=\"radio\"\n />\n <label onClick={handleClick}>{element.label}</label>\n <br />\n </>\n );\n })}\n </div>\n );\n};\n","import React from 'react';\n\nexport interface ITextArea\n extends React.DetailedHTMLProps<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HTMLTextAreaElement\n > {}\n\nexport const TextArea: React.FC<ITextArea> = ({ ...props }) => {\n return <textarea {...props} />;\n};\n"],"names":["ButtonTypes","RPGUIContainerTypes","Button","children","buttonType","props","React","ButtonContainer","className","styled","button","displayName","componentId","Input","RPGUIContainer","width","Container","height","type","div","Column","flex","flexWrap","alignItems","justifyContent","CloseButton","CustomInput","CustomContainer","opacity","Form","form","MessageText","p","TitleContainer","Title","h1","Icon","img","_RPGUI","RPGUI","y","x","fontSize","ListElement","li","require","NPCDialogType","DynamicText","text","onFinish","onStart","useState","textState","setTextState","useEffect","i","interval","setInterval","length","substring","clearInterval","TextContainer","NPCDialogText","onClose","onEndStep","onStartStep","textChunks","match","RegExp","chunkIndex","setChunkIndex","onHandleSpacePress","event","code","prev","document","addEventListener","removeEventListener","useEventListener","handler","el","window","savedHandler","useRef","current","listener","e","QuestionDialog","questions","answers","currentQuestion","setCurrentQuestion","canShowAnswers","setCanShowAnswers","onGetFirstAnswer","answerIds","firstAnswerId","find","answer","id","currentAnswer","setCurrentAnswer","onGetAnswers","map","answerId","key","nextAnswerIndex","findIndex","nextAnswerID","nextAnswer","previousAnswerIndex","previousAnswerID","previousAnswer","pop","nextQuestionId","question","QuestionContainer","AnswersContainer","isSelected","selectedColor","AnswerRow","AnswerSelectedIcon","color","Answer","onClick","onAnswerClick","onRenderCurrentAnswers","span","RangeSliderType","ThumbnailContainer","NPCThumbnail","PressSpaceIndicator","right","ProgressBarText","TextOverlay","minWidth","percentageWidth","style","input","SimpleProgressBar","bgColor","ProgressBarContainer","BackgroundBar","Progress","value","TitleName","ValueDisplay","ProgressIconContainer","ProgressBody","ProgressTitle","maxLines","chatMessages","onSendChatMessage","onCloseButton","message","setMessage","scrollChatToBottom","scrollingElement","querySelector","scrollTop","scrollHeight","FramedGrey","ErrorBoundary","fallback","onTouchStart","index","_id","emitter","createdAt","dayjs","Date","format","name","onRenderMessageLines","onRenderChatMessages","onSubmit","preventDefault","onChange","target","autoComplete","RPGUIButton","items","selectedValues","forEach","item","label","generateSelectedValuesList","setSelectedValues","element","checked","FramedGold","title","imgSrc","imgWidth","Draggable","src","options","dropdownId","uuidv4","selectedValue","setSelectedValue","getElementById","dropdownValue","get_value","option","handleClick","onSelected","overflow","params","imagePath","isQuestionDialog","showGoNextIndicator","setShowGoNextIndicator","TextAndThumbnail","aliceDefaultThumbnail","TextOnly","pressSpaceGif","max","displayText","calculatePercentageValue","left","valueMin","valueMax","sliderId","wasMouseDownFirst","setWasMouseDownFirst","onHandleMouseUp","rpguiSlider","Number","onMouseUp","onMouseDown","Slider","GoldSlider","min","logoSrc","imgSrcTemplate","titleName"],"mappings":"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"}
1
+ {"version":3,"file":"long-bow.cjs.production.min.js","sources":["../src/components/Button.tsx","../src/components/RPGUIContainer.tsx","../src/components/Input.tsx","../src/components/NPCDialog/NPCDialog.tsx","../src/components/shared/Column.tsx","../src/components/Chat/Chat.tsx","../src/constants/uiColors.ts","../src/components/DraggableContainer.tsx","../src/components/RPGUIRoot.tsx","../src/components/ListMenu.tsx","../src/components/typography/DynamicText.tsx","../src/components/NPCDialog/NPCDialogText.tsx","../src/libs/StringHelpers.ts","../src/hooks/useEventListener.ts","../src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx","../src/components/RangeSlider.tsx","../src/components/ProgressBar.tsx","../src/components/SimpleProgressBar.tsx","../src/components/SkillProgressBar.tsx","../src/components/Truncate.tsx","../src/components/CheckButton.tsx","../src/components/Dropdown.tsx","../src/components/RadioButton.tsx","../src/components/TextArea.tsx"],"sourcesContent":["import React from 'react';\nimport styled from 'styled-components';\n\nexport enum ButtonTypes {\n RPGUIButton = 'rpgui-button',\n RPGUIGoldButton = 'rpgui-button golden',\n}\n\nexport interface IButtonProps {\n children: React.ReactNode;\n buttonType: ButtonTypes;\n}\n\nexport const Button: React.FC<IButtonProps &\n React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n >> = ({ children, buttonType, ...props }) => {\n return (\n <ButtonContainer className={`${buttonType}`} {...props}>\n <p>{children}</p>\n </ButtonContainer>\n );\n};\n\nconst ButtonContainer = styled.button<any>`\n height: 45px;\n font-size: 11.5px;\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport enum RPGUIContainerTypes {\n Framed = 'framed',\n FramedGold = 'framed-golden',\n FramedGold2 = 'framed-golden-2',\n FramedGrey = 'framed-grey',\n}\nexport interface IRPGUIContainerProps {\n type: RPGUIContainerTypes;\n children: React.ReactNode;\n width?: string;\n height?: string;\n className?: string;\n}\n\nexport const RPGUIContainer: React.FC<IRPGUIContainerProps> = ({\n children,\n type,\n width = '50%',\n height,\n className,\n}) => {\n return (\n <Container\n width={width}\n height={height || 'auto'}\n className={`rpgui-container ${type} ${className}`}\n >\n {children}\n </Container>\n );\n};\n\ninterface IContainerProps {\n width: string;\n height: string;\n}\n\nconst Container = styled.div<IContainerProps>`\n height: ${props => props.height};\n width: ${({ width }) => width};\n display: flex;\n flex-wrap: wrap;\n image-rendering: pixelated;\n`;\n","import React from 'react';\n\nexport interface IInputProps\n extends React.DetailedHTMLProps<\n React.InputHTMLAttributes<HTMLInputElement>,\n HTMLInputElement\n > {}\n\nexport const Input: React.FC<IInputProps> = ({ ...props }) => {\n return <input {...props} />;\n};\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { RPGUIContainer, RPGUIContainerTypes } from '../RPGUIContainer';\nimport aliceDefaultThumbnail from './img/npcDialog/npcThumbnails/alice.png';\nimport pressSpaceGif from './img/space.gif';\nimport { NPCDialogText } from './NPCDialogText';\nimport {\n IQuestionDialog,\n IQuestionDialogAnswer,\n QuestionDialog,\n} from './QuestionDialog/QuestionDialog';\n\nexport enum NPCDialogType {\n TextOnly = 'TextOnly',\n TextAndThumbnail = 'TextAndThumbnail',\n}\n\nexport interface INPCDialogProps {\n text?: string;\n type: NPCDialogType;\n imagePath?: string;\n onClose?: () => void;\n isQuestionDialog?: boolean;\n answers?: IQuestionDialogAnswer[];\n questions?: IQuestionDialog[];\n}\n\nexport const NPCDialog: React.FC<INPCDialogProps> = ({\n text,\n type,\n onClose,\n imagePath,\n isQuestionDialog = false,\n questions,\n answers,\n}) => {\n const [showGoNextIndicator, setShowGoNextIndicator] = useState<boolean>(\n false\n );\n\n return (\n <RPGUIContainer\n type={RPGUIContainerTypes.FramedGold}\n width={isQuestionDialog ? '600px' : '50%'}\n height={'180px'}\n >\n {isQuestionDialog && questions && answers ? (\n <>\n <TextContainer\n flex={type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'}\n >\n <QuestionDialog\n questions={questions}\n answers={answers}\n onClose={() => {\n if (onClose) {\n onClose();\n }\n }}\n />\n </TextContainer>\n {type === NPCDialogType.TextAndThumbnail && (\n <ThumbnailContainer>\n <NPCThumbnail src={imagePath || aliceDefaultThumbnail} />\n </ThumbnailContainer>\n )}\n </>\n ) : (\n <>\n <Container>\n <TextContainer\n flex={type === NPCDialogType.TextAndThumbnail ? '70%' : '100%'}\n >\n <NPCDialogText\n onStartStep={() => setShowGoNextIndicator(false)}\n onEndStep={() => setShowGoNextIndicator(true)}\n text={text || 'No text provided.'}\n onClose={() => {\n if (onClose) {\n onClose();\n }\n }}\n />\n </TextContainer>\n {type === NPCDialogType.TextAndThumbnail && (\n <ThumbnailContainer>\n <NPCThumbnail src={imagePath || aliceDefaultThumbnail} />\n </ThumbnailContainer>\n )}\n </Container>\n {showGoNextIndicator && (\n <PressSpaceIndicator\n right={type === NPCDialogType.TextOnly ? '1rem' : '10.5rem'}\n src={pressSpaceGif}\n />\n )}\n </>\n )}\n </RPGUIContainer>\n );\n};\n\nconst Container = styled.div`\n display: flex;\n width: 100%;\n height: 100%;\n\n box-sizing: border-box;\n justify-content: center;\n align-items: flex-start;\n position: relative;\n`;\n\ninterface ITextContainerProps {\n flex: string;\n}\n\nconst TextContainer = styled.div<ITextContainerProps>`\n flex: ${({ flex }) => flex} 0 0;\n width: 355px;\n`;\n\nconst ThumbnailContainer = styled.div`\n flex: 30% 0 0;\n display: flex;\n justify-content: flex-end;\n`;\n\nconst NPCThumbnail = styled.img`\n image-rendering: pixelated;\n height: 128px;\n width: 128px;\n`;\n\ninterface IPressSpaceIndicatorProps {\n right: string;\n}\n\nconst PressSpaceIndicator = styled.img<IPressSpaceIndicatorProps>`\n position: absolute;\n right: ${({ right }) => right};\n bottom: 1rem;\n height: 20.7px;\n image-rendering: -webkit-optimize-contrast;\n`;\n","import styled from 'styled-components';\n\ninterface IColumn {\n flex?: number;\n alignItems?: string;\n justifyContent?: string;\n flexWrap?: string;\n}\n\nexport const Column = styled.div<IColumn>`\n flex: ${props => props.flex || 'auto'};\n display: flex;\n flex-wrap: ${props => props.flexWrap || 'nowrap'};\n align-items: ${props => props.alignItems || 'flex-start'};\n justify-content: ${props => props.justifyContent || 'flex-start'};\n`;\n","import { IChatMessage } from '@rpg-engine/shared';\nimport dayjs from 'dayjs';\nimport React, { useEffect, useState } from 'react';\nimport { ErrorBoundary } from 'react-error-boundary';\nimport styled from 'styled-components';\nimport { colors } from '../../constants/uiColors';\nimport { Button, ButtonTypes } from '../Button';\nimport { Input } from '../Input';\nimport { RPGUIContainer, RPGUIContainerTypes } from '../RPGUIContainer';\nimport { Column } from '../shared/Column';\n\ninterface IEmitter {\n _id: string;\n name: string;\n}\nexport interface IChatProps {\n chatMessages: IChatMessage[];\n onSendChatMessage: (message: string) => void;\n onCloseButton: () => void;\n opacity?: number;\n width?: string;\n height?: string;\n}\n\nexport const Chat: React.FC<IChatProps> = ({\n chatMessages,\n onSendChatMessage,\n opacity = 1,\n width = '100%',\n height = '250px',\n onCloseButton,\n}) => {\n const [message, setMessage] = useState('');\n\n useEffect(() => {\n scrollChatToBottom();\n }, []);\n\n useEffect(() => {\n scrollChatToBottom();\n }, [chatMessages]);\n\n const scrollChatToBottom = () => {\n const scrollingElement = document.querySelector('.chat-body');\n if (scrollingElement) {\n scrollingElement.scrollTop = scrollingElement.scrollHeight;\n }\n };\n\n const handleSubmit = (event: React.SyntheticEvent<HTMLFormElement>) => {\n event.preventDefault();\n onSendChatMessage(message);\n setMessage('');\n };\n const getInputValue = (value: string) => {\n setMessage(value);\n };\n\n const onRenderMessageLines = (\n emitter: IEmitter,\n createdAt: string | undefined,\n message: string\n ) => {\n return `${dayjs(createdAt || new Date()).format('HH:mm')} ${\n emitter?.name ? `${emitter.name}: ` : 'Unknown: '\n } ${message}`;\n };\n\n const onRenderChatMessages = (chatMessages: IChatMessage[]) => {\n return chatMessages?.length ? (\n chatMessages?.map(({ _id, createdAt, emitter, message }, index) => (\n <MessageText key={`${_id}_${index}`}>\n {onRenderMessageLines(emitter, createdAt, message)}\n </MessageText>\n ))\n ) : (\n <MessageText>No messages available.</MessageText>\n );\n };\n\n return (\n <Container>\n <CustomContainer\n type={RPGUIContainerTypes.FramedGrey}\n width={width}\n height={height}\n className=\"chat-container\"\n opacity={opacity}\n >\n <ErrorBoundary fallback={<p>Oops! Your chat has crashed.</p>}>\n {onCloseButton && (\n <CloseButton onClick={onCloseButton} onTouchStart={onCloseButton}>\n X\n </CloseButton>\n )}\n <RPGUIContainer\n type={RPGUIContainerTypes.FramedGrey}\n width={'100%'}\n height={'80%'}\n className=\"chat-body dark-background\"\n >\n {onRenderChatMessages(chatMessages)}\n </RPGUIContainer>\n\n <Form onSubmit={handleSubmit}>\n <Column flex={70}>\n <CustomInput\n value={message}\n id=\"inputMessage\"\n onChange={e => getInputValue(e.target.value)}\n height={20}\n className=\"chat-input dark-background\"\n type=\"text\"\n autoComplete=\"off\"\n />\n </Column>\n <Column justifyContent=\"flex-end\">\n <Button\n buttonType={ButtonTypes.RPGUIButton}\n id=\"chat-send-button\"\n >\n Send\n </Button>\n </Column>\n </Form>\n </ErrorBoundary>\n </CustomContainer>\n </Container>\n );\n};\n\nconst Container = styled.div`\n position: relative;\n`;\n\nconst CloseButton = styled.div`\n position: absolute;\n top: 3px;\n right: 0px;\n color: white;\n z-index: 22;\n font-size: 10px;\n`;\n\nconst CustomInput = styled(Input)`\n height: 30px;\n width: 100%;\n\n .rpgui-content .input {\n min-height: 39px;\n }\n`;\n\ninterface ICustomContainerProps {\n opacity: number;\n}\n\nconst CustomContainer = styled(RPGUIContainer)`\n display: block;\n\n opacity: ${(props: ICustomContainerProps) => props.opacity};\n\n &:hover {\n opacity: 1;\n }\n\n .dark-background {\n background-color: ${colors.darkGrey} !important;\n }\n\n .chat-body {\n &.rpgui-container.framed-grey {\n background: unset;\n }\n max-height: 170px;\n overflow-y: auto;\n }\n`;\n\nconst Form = styled.form`\n display: flex;\n width: 100%;\n justify-content: center;\n align-items: center;\n`;\n\nconst MessageText = styled.p`\n display: block !important;\n width: 100%;\n font-size: 0.7rem !important;\n overflow-y: auto;\n margin: 0;\n`;\n","export const colors = {\n darkGrey: '#3e3e3e',\n};\n","import React from 'react';\nimport Draggable from 'react-draggable';\nimport styled from 'styled-components';\nimport { RPGUIContainerTypes } from './RPGUIContainer';\n\nexport interface IDraggableContainerProps {\n children: React.ReactNode;\n width?: string;\n height?: string;\n className?: string;\n type?: RPGUIContainerTypes;\n title: string;\n imgSrc?: string;\n imgWidth?: string;\n onCloseButton: () => void;\n}\n\nexport const DraggableContainer: React.FC<IDraggableContainerProps> = ({\n children,\n width = '50%',\n height,\n className,\n type = RPGUIContainerTypes.FramedGold,\n onCloseButton,\n title,\n imgSrc,\n imgWidth = '20px',\n}) => {\n return (\n <Draggable>\n <Container\n width={width}\n height={height || 'auto'}\n className={`rpgui-container ${type} ${className} rpgui-draggable`}\n >\n <TitleContainer>\n <Title>\n {imgSrc && <Icon src={imgSrc} width={imgWidth} />}\n {title}\n </Title>\n </TitleContainer>\n {onCloseButton && (\n <CloseButton onClick={onCloseButton} onTouchStart={onCloseButton}>\n X\n </CloseButton>\n )}\n\n {children}\n </Container>\n </Draggable>\n );\n};\n\ninterface IContainerProps {\n width: string;\n height: string;\n}\n\nconst Container = styled.div<IContainerProps>`\n height: ${props => props.height};\n width: ${({ width }) => width};\n display: flex;\n flex-wrap: wrap;\n image-rendering: pixelated;\n`;\n\nconst CloseButton = styled.div`\n position: absolute;\n top: 3px;\n right: 0px;\n color: white;\n z-index: 22;\n font-size: 10px;\n`;\n\nconst TitleContainer = styled.div`\n width: 100%;\n\n display: flex;\n flex-wrap: wrap;\n justify-content: center;\n align-items: center;\n`;\n\nconst Title = styled.h1`\n color: white;\n z-index: 22;\n font-size: 10px;\n`;\n\ninterface ICustomIconProps {\n width: string;\n}\n\nconst Icon = styled.img`\n color: white;\n z-index: 22;\n font-size: 10px;\n width: ${(props: ICustomIconProps) => props.width};\n margin-right: 0.5rem;\n`;\n","import React from 'react';\nimport 'rpgui/rpgui.min.css';\nimport 'rpgui/rpgui.min.js';\n\ninterface IProps {\n children: React.ReactNode;\n}\n\n//@ts-ignore\nexport const _RPGUI = RPGUI;\n\nexport const RPGUIRoot: React.FC<IProps> = ({ children }) => {\n return <div className=\"rpgui-content\">{children}</div>;\n};\n","import React from 'react';\nimport styled from 'styled-components';\n\ninterface IListMenuOption {\n id: string;\n text: string;\n}\n\nexport interface IListMenuProps {\n x: number;\n y: number;\n options: IListMenuOption[];\n onSelected: (selectedOptionId: string) => void;\n fontSize?: number;\n}\n\nexport const ListMenu: React.FC<IListMenuProps> = ({\n options,\n onSelected,\n x,\n y,\n fontSize = 0.8,\n}) => {\n return (\n <Container x={x} y={y} fontSize={fontSize}>\n <ul className=\"rpgui-list-imp\" style={{ overflow: 'hidden' }}>\n {options.map(params => (\n <ListElement\n key={params.text}\n onClick={() => {\n onSelected(params.id);\n }}\n >\n {params.text}\n </ListElement>\n ))}\n </ul>\n </Container>\n );\n};\n\ninterface IContainerProps {\n x?: number;\n y?: number;\n fontSize?: number;\n}\n\nconst Container = styled.div<IContainerProps>`\n display: flex;\n flex-direction: column;\n width: 100%;\n justify-content: start;\n align-items: flex-start;\n position: absolute;\n top: ${props => props.y || 0}px;\n left: ${props => props.x || 0}px;\n\n li {\n font-size: ${props => props.fontSize}em;\n }\n`;\n\nconst ListElement = styled.li`\n margin-right: 0.5rem;\n`;\n","import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\n\ninterface IProps {\n text: string;\n onFinish?: () => void;\n onStart?: () => void;\n}\n\nexport const DynamicText: React.FC<IProps> = ({ text, onFinish, onStart }) => {\n const [textState, setTextState] = useState<string>('');\n\n useEffect(() => {\n let i = 0;\n const interval = setInterval(() => {\n // on every interval, show one more character\n\n if (i === 0) {\n if (onStart) {\n onStart();\n }\n }\n\n if (i < text.length) {\n setTextState(text.substring(0, i + 1));\n i++;\n } else {\n clearInterval(interval);\n if (onFinish) {\n onFinish();\n }\n }\n }, 50);\n\n return () => {\n clearInterval(interval);\n };\n }, [text]);\n\n return <TextContainer>{textState}</TextContainer>;\n};\n\nconst TextContainer = styled.p`\n font-size: 0.7rem !important;\n color: white;\n text-shadow: 1px 1px 0px #000000;\n letter-spacing: 1.2px;\n word-break: normal;\n`;\n","import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport { chunkString } from '../../libs/StringHelpers';\nimport { DynamicText } from '../typography/DynamicText';\n\ninterface IProps {\n text: string;\n onClose: () => void;\n onEndStep: () => void;\n onStartStep: () => void;\n}\n\nexport const NPCDialogText: React.FC<IProps> = ({\n text,\n onClose,\n onEndStep,\n onStartStep,\n}) => {\n const textChunks = chunkString(text, 85);\n\n const [chunkIndex, setChunkIndex] = useState<number>(0);\n\n const onHandleSpacePress = (event: KeyboardEvent) => {\n if (event.code === 'Space') {\n const hasNextChunk = textChunks?.[chunkIndex + 1] || false;\n\n if (hasNextChunk) {\n setChunkIndex(prev => prev + 1);\n } else {\n // if there's no more text chunks, close the dialog\n onClose();\n }\n }\n };\n\n useEffect(() => {\n document.addEventListener('keydown', onHandleSpacePress);\n\n return () => document.removeEventListener('keydown', onHandleSpacePress);\n }, [chunkIndex]);\n\n return (\n <Container>\n <DynamicText\n text={textChunks?.[chunkIndex] || ''}\n onFinish={onEndStep}\n onStart={onStartStep}\n />\n </Container>\n );\n};\n\nconst Container = styled.div``;\n","export const chunkString = (str: string, length: number) => {\n return str.match(new RegExp('.{1,' + length + '}', 'g'));\n};\n","import React from 'react';\n\n//@ts-ignore\nexport const useEventListener = (type, handler, el = window) => {\n const savedHandler = React.useRef();\n\n React.useEffect(() => {\n savedHandler.current = handler;\n }, [handler]);\n\n React.useEffect(() => {\n //@ts-ignore\n const listener = e => savedHandler.current(e);\n\n el.addEventListener(type, listener);\n\n return () => {\n el.removeEventListener(type, listener);\n };\n }, [type, el]);\n};\n","import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport { useEventListener } from '../../../hooks/useEventListener';\nimport { DynamicText } from '../../typography/DynamicText';\n\nexport interface IQuestionDialogAnswer {\n id: number;\n text: string;\n nextQuestionId?: number;\n}\n\nexport interface IQuestionDialog {\n id: number;\n text: string;\n answerIds?: number[];\n}\n\nexport interface IProps {\n questions: IQuestionDialog[];\n answers: IQuestionDialogAnswer[];\n onClose: () => void;\n}\n\nexport const QuestionDialog: React.FC<IProps> = ({\n questions,\n answers,\n onClose,\n}) => {\n const [currentQuestion, setCurrentQuestion] = useState(questions[0]);\n\n const [canShowAnswers, setCanShowAnswers] = useState<boolean>(false);\n\n const onGetFirstAnswer = () => {\n if (!currentQuestion.answerIds || currentQuestion.answerIds.length === 0) {\n return null;\n }\n\n const firstAnswerId = currentQuestion.answerIds![0];\n\n return answers.find(answer => answer.id === firstAnswerId);\n };\n\n const [\n currentAnswer,\n setCurrentAnswer,\n ] = useState<IQuestionDialogAnswer | null>(onGetFirstAnswer()!);\n\n useEffect(() => {\n setCurrentAnswer(onGetFirstAnswer()!);\n }, [currentQuestion]);\n\n const onGetAnswers = (answerIds: number[]) => {\n return answerIds.map((answerId: number) =>\n answers.find(answer => answer.id === answerId)\n );\n };\n\n const onKeyPress = (e: KeyboardEvent) => {\n switch (e.key) {\n case 'ArrowDown':\n // select next answer, if any.\n // if no next answer, select first answer\n // const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(\n // (answer) => answer?.id === currentAnswer!.id + 1\n // );\n\n const nextAnswerIndex = onGetAnswers(\n currentQuestion.answerIds!\n ).findIndex(answer => answer?.id === currentAnswer!.id + 1);\n\n const nextAnswerID = currentQuestion.answerIds![nextAnswerIndex];\n\n // console.log(nextAnswerIndex);\n\n const nextAnswer = onGetAnswers(currentQuestion.answerIds!).find(\n answer => answer?.id === nextAnswerID\n );\n\n setCurrentAnswer(nextAnswer || onGetFirstAnswer()!);\n\n break;\n case 'ArrowUp':\n // select previous answer, if any.\n // if no previous answer, select last answer\n\n const previousAnswerIndex = onGetAnswers(\n currentQuestion.answerIds!\n ).findIndex(answer => answer?.id === currentAnswer!.id - 1);\n\n const previousAnswerID =\n currentQuestion.answerIds &&\n currentQuestion.answerIds[previousAnswerIndex];\n\n const previousAnswer = onGetAnswers(currentQuestion.answerIds!).find(\n answer => answer?.id === previousAnswerID\n );\n\n if (previousAnswer) {\n setCurrentAnswer(previousAnswer);\n } else {\n setCurrentAnswer(onGetAnswers(currentQuestion.answerIds!).pop()!);\n }\n\n break;\n case 'Enter':\n setCanShowAnswers(false);\n\n if (!currentAnswer?.nextQuestionId) {\n onClose();\n return;\n } else {\n setCurrentQuestion(\n questions.find(\n question => question.id === currentAnswer!.nextQuestionId\n )!\n );\n }\n\n break;\n }\n };\n useEventListener('keydown', onKeyPress);\n\n const onAnswerClick = (answer: IQuestionDialogAnswer) => {\n setCanShowAnswers(false);\n if (answer.nextQuestionId) {\n // if there is a next question, go to it\n setCurrentQuestion(\n questions.find(question => question.id === answer.nextQuestionId)!\n );\n } else {\n // else, finish dialog!\n onClose();\n }\n };\n\n const onRenderCurrentAnswers = () => {\n const answerIds = currentQuestion.answerIds;\n if (!answerIds) {\n return null;\n }\n\n const answers = onGetAnswers(answerIds);\n\n if (!answers) {\n return null;\n }\n\n return answers.map(answer => {\n const isSelected = currentAnswer?.id === answer?.id;\n const selectedColor = isSelected ? 'yellow' : 'white';\n\n if (answer) {\n return (\n <AnswerRow key={`answer_${answer.id}`}>\n <AnswerSelectedIcon color={selectedColor}>\n {isSelected ? 'X' : null}\n </AnswerSelectedIcon>\n\n <Answer\n key={answer.id}\n onClick={() => onAnswerClick(answer)}\n color={selectedColor}\n >\n {answer.text}\n </Answer>\n </AnswerRow>\n );\n }\n\n return null;\n });\n };\n\n return (\n <Container>\n <QuestionContainer>\n <DynamicText\n text={currentQuestion.text}\n onStart={() => setCanShowAnswers(false)}\n onFinish={() => setCanShowAnswers(true)}\n />\n </QuestionContainer>\n\n {canShowAnswers && (\n <AnswersContainer>{onRenderCurrentAnswers()}</AnswersContainer>\n )}\n </Container>\n );\n};\n\nconst Container = styled.div`\n display: flex;\n\n word-break: break-all;\n\n box-sizing: border-box;\n justify-content: flex-start;\n align-items: flex-start;\n flex-wrap: wrap;\n`;\n\nconst QuestionContainer = styled.div`\n flex: 100%;\n width: 100%;\n`;\n\nconst AnswersContainer = styled.div`\n flex: 100%;\n`;\n\ninterface IAnswerProps {\n color: string;\n}\n\nconst Answer = styled.p<IAnswerProps>`\n flex: auto;\n color: ${props => props.color} !important;\n font-size: 0.65rem !important;\n background: inherit;\n border: none;\n`;\n\nconst AnswerSelectedIcon = styled.span<IAnswerProps>`\n flex: 5% 0 0;\n color: ${props => props.color} !important;\n`;\n\nconst AnswerRow = styled.div`\n display: flex;\n flex-wrap: wrap;\n justify-content: center;\n align-items: center;\n margin-bottom: 0.5rem;\n height: 22px;\n\n p {\n line-height: unset;\n margin-top: 0;\n margin-bottom: 0rem;\n }\n`;\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { v4 as uuidv4 } from 'uuid';\nimport { useEventListener } from '../hooks/useEventListener';\nimport { _RPGUI } from './RPGUIRoot';\n\nexport enum RangeSliderType {\n Slider = 'rpgui-slider',\n GoldSlider = 'rpgui-slider golden',\n}\n\nexport interface IRangeSliderProps {\n type: RangeSliderType;\n valueMin: number;\n valueMax: number;\n width: string;\n onChange: (value: number) => void;\n}\n\nexport const RangeSlider: React.FC<IRangeSliderProps> = ({\n type,\n valueMin,\n valueMax,\n width,\n onChange,\n}) => {\n const sliderId = uuidv4();\n\n const [wasMouseDownFirst, setWasMouseDownFirst] = useState<boolean>(false);\n\n useEventListener('mouseup', () => {\n if (wasMouseDownFirst) {\n onHandleMouseUp();\n }\n setWasMouseDownFirst(false);\n });\n\n const onHandleMouseUp = () => {\n const rpguiSlider = document.getElementById(`rpgui-slider-${sliderId}`);\n const value = _RPGUI.get_value(rpguiSlider);\n\n onChange(Number(value));\n };\n\n return (\n <div\n onMouseUp={onHandleMouseUp}\n onMouseDown={() => setWasMouseDownFirst(true)}\n >\n <Input\n className={\n type === RangeSliderType.Slider\n ? RangeSliderType.Slider\n : RangeSliderType.GoldSlider\n }\n type=\"range\"\n style={{ width: width }}\n min={valueMin}\n max={valueMax}\n id={`rpgui-slider-${sliderId}`}\n />\n </div>\n );\n};\n\nconst Input = styled.input`\n opacity: 0;\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport interface IBarProps {\n max: number;\n value: number;\n color: 'red' | 'blue' | 'green';\n style?: Record<string, any>;\n displayText?: boolean;\n percentageWidth?: number;\n minWidth?: number;\n}\n\nexport const ProgressBar: React.FC<IBarProps> = ({\n max,\n value,\n color,\n displayText = true,\n percentageWidth = 40,\n minWidth = 100,\n style,\n}) => {\n const calculatePercentageValue = function(max: number, value: number) {\n if (value > max) {\n value = max;\n }\n return (value * 100) / max;\n };\n\n return (\n <Container\n className=\"rpgui-progress\"\n data-value={calculatePercentageValue(max, value) / 100}\n data-rpguitype=\"progress\"\n percentageWidth={percentageWidth}\n minWidth={minWidth}\n style={style}\n >\n {displayText && (\n <TextOverlay>\n <ProgressBarText>\n {value}/{max}\n </ProgressBarText>\n </TextOverlay>\n )}\n <div className=\" rpgui-progress-track\">\n <div\n className={`rpgui-progress-fill ${color} `}\n style={{\n left: '0px',\n width: calculatePercentageValue(max, value) + '%',\n }}\n ></div>\n </div>\n <div className=\" rpgui-progress-left-edge\"></div>\n <div className=\" rpgui-progress-right-edge\"></div>\n </Container>\n );\n};\n\nconst ProgressBarText = styled.span`\n font-size: 1rem;\n color: white;\n text-align: center;\n z-index: 1;\n position: absolute;\n left: 50%;\n transform: translateX(-50%);\n top: 12px;\n`;\n\nconst TextOverlay = styled.div`\n width: 100%;\n position: relative;\n`;\n\ninterface IContainerProps {\n percentageWidth?: number;\n minWidth?: number;\n style?: Record<string, any>;\n}\n\nconst Container = styled.div<IContainerProps>`\n display: flex;\n flex-direction: column;\n min-width: ${props => props.minWidth}px;\n width: ${props => props.percentageWidth}%;\n justify-content: start;\n align-items: flex-start;\n ${props => props.style}\n`;\n","import React from 'react';\nimport styled from 'styled-components';\n\ninterface IProps {\n value: number;\n height?: string;\n bgColor?: string;\n}\n\nexport const SimpleProgressBar: React.FC<IProps> = ({\n value,\n\n bgColor = 'red',\n}) => {\n return (\n <Container>\n <ProgressBarContainer>\n <BackgroundBar>\n <Progress value={value} bgColor={bgColor} />\n </BackgroundBar>\n </ProgressBarContainer>\n </Container>\n );\n};\n\nconst Container = styled.div`\n display: flex;\n justify-content: center;\n align-items: center;\n width: 100%;\n`;\n\nconst BackgroundBar = styled.span`\n background-color: rgba(0, 0, 0, 0.075);\n`;\n\ninterface IProgressProps {\n value: number;\n bgColor: string;\n}\n\nconst Progress = styled.span`\n background-color: ${(props: IProgressProps) => props.bgColor};\n width: ${(props: IProgressProps) => props.value}%;\n`;\n\nconst ProgressBarContainer = styled.div`\n border-radius: 60px;\n border: 1px solid #282424;\n overflow: hidden;\n width: 100%;\n span {\n display: block;\n height: 100%;\n }\n\n height: 8px;\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport imgSrcTemplate from './imgExp.png';\nimport { SimpleProgressBar } from './SimpleProgressBar';\n\nexport interface ISkillProgressBarProps {\n value: number;\n\n height: string;\n bgColor: string;\n titleName: string;\n\n logoSrc?: string;\n}\n\nexport const SkillProgressBar: React.FC<ISkillProgressBarProps> = ({\n value,\n bgColor,\n titleName,\n\n logoSrc = imgSrcTemplate,\n}) => {\n return (\n <>\n <ProgressTitle>\n <TitleName>{titleName}</TitleName>\n <ValueDisplay>{value}</ValueDisplay>\n </ProgressTitle>\n <ProgressBody>\n <ProgressIconContainer>\n <Icon src={logoSrc} />\n </ProgressIconContainer>\n\n <SimpleProgressBar value={value} bgColor={bgColor} />\n </ProgressBody>\n </>\n );\n};\n\nconst TitleName = styled.span`\n margin-left: 5px;\n`;\n\nconst ValueDisplay = styled.span``;\n\nconst ProgressIconContainer = styled.div`\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nconst ProgressBody = styled.div`\n display: flex;\n flex-direction: row;\n`;\n\nconst ProgressTitle = styled.div`\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n span {\n font-size: 0.6rem;\n }\n`;\n\nconst Icon = styled.img`\n margin-right: 10px;\n height: 30px;\n`;\n","/* eslint-disable react/require-default-props */\nimport React from 'react';\nimport styled from 'styled-components';\n\ninterface IProps {\n maxLines?: number;\n children: React.ReactNode;\n}\n\nexport const Truncate: React.FC<IProps> = ({ maxLines = 1, children }) => {\n return <Container maxLines={maxLines}>{children}</Container>;\n};\n\ninterface IContainerProps {\n maxLines: number;\n}\n\nconst Container = styled.div<IContainerProps>`\n display: -webkit-box;\n max-width: 100%;\n max-height: 100%;\n -webkit-line-clamp: ${props => props.maxLines};\n -webkit-box-orient: vertical;\n overflow: hidden;\n`;\n","import React, { useEffect, useState } from 'react';\n\nexport interface ICheckItems {\n label: string;\n value: string;\n}\n\nexport interface ICheckProps {\n items: ICheckItems[];\n onChange: (selectedValues: IChecklistSelectedValues) => void;\n}\n\ninterface IChecklistSelectedValues {\n [label: string]: boolean;\n}\n\nexport const CheckButton: React.FC<ICheckProps> = ({ items, onChange }) => {\n const generateSelectedValuesList = () => {\n const selectedValues: IChecklistSelectedValues = {};\n\n items.forEach(item => {\n selectedValues[item.label] = false;\n });\n\n return selectedValues;\n };\n\n const [selectedValues, setSelectedValues] = useState<\n IChecklistSelectedValues\n >(generateSelectedValuesList());\n\n const handleClick = (label: string) => {\n setSelectedValues({\n ...selectedValues,\n [label]: !selectedValues[label],\n });\n };\n\n useEffect(() => {\n if (selectedValues) {\n onChange(selectedValues);\n }\n }, [selectedValues]);\n\n return (\n <div id=\"elemento-checkbox\">\n {items?.map((element, index) => {\n return (\n <div key={`${element.label}_${index}`}>\n <input\n className=\"rpgui-checkbox\"\n type=\"checkbox\"\n checked={selectedValues[element.label]}\n onChange={() => {}}\n />\n <label onClick={() => handleClick(element.label)}>\n {element.label}\n </label>\n <br />\n </div>\n );\n })}\n </div>\n );\n};\n","import React, { useEffect, useState } from 'react';\nimport { v4 as uuidv4 } from 'uuid';\nimport { _RPGUI } from './RPGUIRoot';\n\nexport interface IOptionsProps {\n id: number;\n value: string;\n option: string;\n}\n\nexport interface IDropdownProps {\n options: IOptionsProps[];\n width?: string;\n onChange: (value: string) => void;\n}\n\nexport const Dropdown: React.FC<IDropdownProps> = ({\n options,\n width,\n onChange,\n}) => {\n const dropdownId = uuidv4();\n\n const [selectedValue, setSelectedValue] = useState<string>('');\n\n useEffect(() => {\n const element = document.getElementById(`rpgui-dropdown-${dropdownId}`);\n const dropdownValue = _RPGUI.get_value(element);\n setSelectedValue(dropdownValue);\n\n element?.addEventListener('change', (event: any) => {\n setSelectedValue(event?.target.value);\n });\n }, []);\n\n useEffect(() => {\n if (selectedValue) {\n onChange(selectedValue);\n }\n }, [selectedValue]);\n\n return (\n <select\n id={`rpgui-dropdown-${dropdownId}`}\n style={{ width: width }}\n className=\"rpgui-dropdown\"\n >\n {options.map(option => {\n return (\n <option key={option.id} value={option.value}>\n {option.option}\n </option>\n );\n })}\n </select>\n );\n};\n","import React, { useEffect, useState } from 'react';\n\nexport interface IRadioItems {\n label: string;\n value: string;\n}\n\nexport interface IRadioProps {\n name: string;\n items: IRadioItems[];\n onChange: (value: string) => void;\n}\n\nexport const InputRadio: React.FC<IRadioProps> = ({\n name,\n items,\n onChange,\n}) => {\n const [selectedValue, setSelectedValue] = useState<string>();\n const handleClick = () => {\n let element = document.querySelector(\n `input[name=${name}]:checked`\n ) as HTMLInputElement;\n const elementValue = element.value;\n setSelectedValue(elementValue);\n };\n\n useEffect(() => {\n if (selectedValue) {\n onChange(selectedValue);\n }\n }, [selectedValue]);\n\n return (\n <div id=\"elemento-radio\">\n {items.map(element => {\n return (\n <>\n <input\n key={element.value}\n className=\"rpgui-radio\"\n value={element.value}\n name={name}\n type=\"radio\"\n />\n <label onClick={handleClick}>{element.label}</label>\n <br />\n </>\n );\n })}\n </div>\n );\n};\n","import React from 'react';\n\nexport interface ITextArea\n extends React.DetailedHTMLProps<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HTMLTextAreaElement\n > {}\n\nexport const TextArea: React.FC<ITextArea> = ({ ...props }) => {\n return <textarea {...props} />;\n};\n"],"names":["ButtonTypes","RPGUIContainerTypes","Button","children","buttonType","props","React","ButtonContainer","className","styled","button","displayName","componentId","Input","NPCDialogType","RPGUIContainer","width","Container","height","type","div","Column","flex","flexWrap","alignItems","justifyContent","CloseButton","CustomInput","CustomContainer","opacity","Form","form","MessageText","p","TitleContainer","Title","h1","Icon","img","_RPGUI","RPGUI","y","x","fontSize","ListElement","li","DynamicText","text","onFinish","onStart","useState","textState","setTextState","useEffect","i","interval","setInterval","length","substring","clearInterval","TextContainer","NPCDialogText","onClose","onEndStep","onStartStep","textChunks","match","RegExp","chunkIndex","setChunkIndex","onHandleSpacePress","event","code","prev","document","addEventListener","removeEventListener","useEventListener","handler","el","window","savedHandler","useRef","current","listener","e","QuestionDialog","questions","answers","currentQuestion","setCurrentQuestion","canShowAnswers","setCanShowAnswers","onGetFirstAnswer","answerIds","firstAnswerId","find","answer","id","currentAnswer","setCurrentAnswer","onGetAnswers","map","answerId","key","nextAnswerIndex","findIndex","nextAnswerID","nextAnswer","previousAnswerIndex","previousAnswerID","previousAnswer","pop","nextQuestionId","question","QuestionContainer","AnswersContainer","isSelected","selectedColor","AnswerRow","AnswerSelectedIcon","color","Answer","onClick","onAnswerClick","onRenderCurrentAnswers","span","RangeSliderType","ThumbnailContainer","NPCThumbnail","PressSpaceIndicator","right","ProgressBarText","TextOverlay","minWidth","percentageWidth","style","input","SimpleProgressBar","bgColor","ProgressBarContainer","BackgroundBar","Progress","value","TitleName","ValueDisplay","ProgressIconContainer","ProgressBody","ProgressTitle","maxLines","chatMessages","onSendChatMessage","onCloseButton","message","setMessage","scrollChatToBottom","scrollingElement","querySelector","scrollTop","scrollHeight","FramedGrey","ErrorBoundary","fallback","onTouchStart","index","_id","emitter","createdAt","dayjs","Date","format","name","onRenderMessageLines","onRenderChatMessages","onSubmit","preventDefault","onChange","target","autoComplete","RPGUIButton","items","selectedValues","forEach","item","label","generateSelectedValuesList","setSelectedValues","element","checked","FramedGold","title","imgSrc","imgWidth","Draggable","src","options","dropdownId","uuidv4","selectedValue","setSelectedValue","getElementById","dropdownValue","get_value","option","handleClick","onSelected","overflow","params","imagePath","isQuestionDialog","showGoNextIndicator","setShowGoNextIndicator","TextAndThumbnail","aliceDefaultThumbnail","TextOnly","max","displayText","calculatePercentageValue","left","valueMin","valueMax","sliderId","wasMouseDownFirst","setWasMouseDownFirst","onHandleMouseUp","rpguiSlider","Number","onMouseUp","onMouseDown","Slider","GoldSlider","min","logoSrc","titleName"],"mappings":"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"}