@rpg-engine/long-bow 0.1.61 → 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.
- package/dist/long-bow.cjs.development.js +3 -3
- package/dist/long-bow.cjs.development.js.map +1 -1
- package/dist/long-bow.cjs.production.min.js +1 -1
- package/dist/long-bow.cjs.production.min.js.map +1 -1
- package/dist/long-bow.esm.js +3 -3
- package/dist/long-bow.esm.js.map +1 -1
- package/package.json +2 -1
- package/dist/alice.png +0 -0
- package/dist/imgExp.png +0 -0
- package/dist/space.gif +0 -0
|
@@ -426,9 +426,9 @@ var ListElement = /*#__PURE__*/styled.li.withConfig({
|
|
|
426
426
|
componentId: "sc-i9097t-1"
|
|
427
427
|
})(["margin-right:0.5rem;"]);
|
|
428
428
|
|
|
429
|
-
|
|
429
|
+
var img = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAMAAABEpIrGAAAABGdBTUEAALGPC/xhBQAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAAP1BMVEUAAAA7FyVxQTsUEBPj5v////+5v/tCJDOOUlIiHBr1oJfptaO6dWr61rhzFy1bMTjoanMUNGQoXMQkn97+88DQ3IhAAAAAAXRSTlMAQObYZgAAAAFiS0dEBfhv6ccAAAAHdElNRQfmAw4VOBC7c5LYAAABM0lEQVQ4y3XRi5KDIAwFUAUkbrBgpP//rZsHVHQ009qZ3tPboNN0zmwzvcw8O5sX4y0NOg/Et3jRCXF+ziULorjkOQ9gE24dvuUAzq08DiCO4pe3WN7zCP56vmpubBReQYC11YPS86ySxxCsAABTSgjb5m4g8nfbxvFHBkH2OEEvAItVuCuIsgGgl+Gcr7kDXxhEAx55A2SQEEeQeZwUaIP8Tbo05B0RFPhItAjgj1w6cDnhLluDj+Egkh3pCCP4pKQAw1IPO0W9Nti5gW9RP2dKA3BZd2Dw+baYX+Nt4GM00O4S3kEpF6Alb2Bv4LeC3kkGfAW0/p0RPoJVKr63ghHsKuRh5DIUKOAlGOwrtt9fQekAEfmhZslHUDoglB0zjfkJigN7UnTQQ4GBWomoVhEN/AOPSBh38gy+fwAAACV0RVh0ZGF0ZTpjcmVhdGUAMjAyMi0wMy0xNFQyMTo1NTo1MSswMDowMJcc0eEAAAAldEVYdGRhdGU6bW9kaWZ5ADIwMjItMDMtMTRUMjE6NTU6NTErMDA6MDDmQWldAAAAAElFTkSuQmCC';
|
|
430
430
|
|
|
431
|
-
|
|
431
|
+
var img$1 = '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';
|
|
432
432
|
|
|
433
433
|
var chunkString = function chunkString(str, length) {
|
|
434
434
|
return str.match(new RegExp('.{1,' + length + '}', 'g'));
|
|
@@ -957,7 +957,7 @@ var Input$1 = /*#__PURE__*/styled.input.withConfig({
|
|
|
957
957
|
componentId: "sc-v8mte9-0"
|
|
958
958
|
})(["opacity:0;"]);
|
|
959
959
|
|
|
960
|
-
const img$2 = require('./imgExp.png');
|
|
960
|
+
var img$2 = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAIACAYAAAD0eNT6AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAOxAAADsQBlSsOGwAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAACAASURBVHic7J1nfBRl14ev2d30ngCRXkSxYMMCCBakSrFhxYJiF0Gwiw3bY+/Po6+VIoqCHYiUAFJsiL2LBQWBkEJ6SNnM+2GIhJCE7Mw9uzO75/r98oFk9+xNsjvnP6eCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAiCIAhCk2ihPoAgCEFDAw4DhgNHA/vs+P5vwCdAFvAFoIfkdIJbyQD6A/2AfYG9gXggFSgEyoDfgV+Aj4FVwLaQnFQQBCGCSAJOA14ENmE49+a+NgMvAaOB5BCcV3AH0cAFwCKghj2/r+p/VQMfAOfusCMIgiAoYl9gMrAEqCSwi3P9rypgKXAd0COo/wPBqUQBk4B/MP++qv/1N3A14Avmf0IQBCFciAEGA08A61BzYW7s6zfgKWAoEBuU/5ngJI4BfsSe99Z3GGkpQRAEYQ+0By4F3gFKsM/pN/VVCrwHXAZ0sPn/KoQWLzCVwEP9gX5VA7cBnqD8rwRBEFyCBzgcuAlYDdQSfKff3NfvwJPAIIwwsRAeRAOvE9z30ltIhEkQhAgnHTgbeAXIJfROvqVfecCrwBiMCnHBncQD2YTmPbQIiLP/vygIguAcugHXYBTwVRF6Z271yw+sxQghH460HruFUDr/uq8VQILd/1FBEIRQEYcRNn8S+IvQO2y7v3KAmcAZSJuhU3GC8xcRIAhCWNIFo3huDqEp4HPKVzVGPcNNwP5WfqGCMpzk/EUECILgerwY4e+pGOHwUF9Qnfr1O/AcMAqjtVEILk50/iICBEFwHa0wwtwzMcaehvoC6ravMmAeRqSkfYC/eyFwnOz8RQQIguB4DmRnm56f0F8ww+nrB+ABjJnz0ieuFjc4fxEBgiA4igSMcPVzwEZCf3GMlK9cjPqJCzAWzgjmcZPzr/sSEaAIackRhMDYHxiBsVGvPy4ceqNp0OvgVIYPbANA1tKtfPltIboe4oOZowYj4pIFLMAYVSu0jHiMNMsJqgz2PtDH2YOiOXJ/H+nJGvlFOmt+rGH2kirW/lyj6mXAaJM9GahQaTTSEAEgCM0TCxzPTqffLaSnMUlSoo/Bx7Vm+KBMhg9sQ9vMXQetbc7ZTtbSrWRl57BkRS4lpUov1sHkT3aKgQ8RB9EUSp1/erLGS1MSOOXYppf7vbm8ikvvL6OwVJnSFBFgEREAgrA7HTGc/QhgIMbF0nXsu3ciIwZlMnxQG47tm0F0VMtS51XVtaz8JJ+s7K0syM7h199LbT6pbZQDyzDEQBbG5jlBsfPvlOlh2X+T2bv9nt9fv/7tZ+DEEjZurVXx0iAiwBIiAATBaNM7FCOfPxLohQs/Gz6fRu9eaYwashejhmZywL5JSuz+8Vc52StzmbdoC0tW5FJZpeziHWz+AOZjOL8VGHMIIo144H0MYWuZjpkelrfQ+dexfnMtA64uZv1mZe+jlRiCvUyVwUjBdRc5QVCEB2OF7gXAMIy5+66jfdtYhg/MZPigTAYf15qEeK+tr1daVkP2yjyysnPIWprDP5u32/p6NrINY978AmAhxv6CcEf5nf/y/yXTrV3gTRm/bfQz4GqJBIQaEQBCJNIZY8HOMaE+SKB4vRpHHZbKiMGZjBiUySEHpqBZ+RSXb4O4VMwY0XX4+vsispbmsGBJDmu+KsTvd2UlYS2wBiM6kAV8jVFtHk44xvnXISIg9IgAECKNzsAqjDy/K0hPjWbogNaMGJzJ0AFtaJXedKFVwPy+GjQPxCZDQjokZIDP3BC+vIIqFi3fyvzFOSz+MJeCwip15wwumzCEQBaGU3FtEcQOHOf86xAREFpEAAiRxnKMqn5Hc/AByQwfZNzl9z0iDa/Xpo/q76t3/15UrCEG4tMNYaAFfqH3+3U+/rzg386Cb38sVnDYkFCJkWOu6yxYF9rjBEwsxrkd5/zrEBEQOkQACJHEAIyqcMcRH+dl4DGtGT6oDcMHZdKpfZBWoTcmAOrjiYL4FCNNkJABXnNjD/7+p8KoG8jeytJVuZRX+E3ZcQDrMBzqAgxh4PQwx3RgrApDdjj/OmwQAYsxinqd/vcJKSIAhEjiaeDqUB+ijq6d4v/N5R/frxWxMSGYcLsnAbALGsQkGJGBhHSISTT1ktsra/nwozzmL8khKzuHP/8uN2XHAZRi3G3WpQs2hfY4u3EMhkixjJ3Ovw4bRMBs4DyMGg+hEUQACG7AAxwC9AZSgC3AxwQejg1p+D8qykP/o9KN0P7gNuy/j5o2PUsEJAAa4I2C+FSIz4D4NPCY60D4aV0JC5YYqYLVawqornbl9VoHvmJnqmANoXc8s4BzrRoJhvOvwwYRcBtwnypj4YYIAMGppAJDMIbxDAPaNPKYpcBEWj7+dRXG+N6gkdk6hhMHtmH4wEyGHN+alGSHTQ62IgDqo2kQk2REBxLTIcrc7KSi4moWf5hL1tIcPli6lZzcSjXnCz55wAcYYmAxRtthsNkAdLBiIJjOvw7FIqAGOA7jhkFogAgAwWl0w1Dsp9KynfDbgdMwLrZ7YgZG379teDwavQ5OYcSgTEYMzuTwg1PweBz8MVMlABoSFbujbiAN4tJMFRLW1up88W0RC5bksCA7hy+/LaK21pXdeTUYDqguVfBdkF63EjDdMuL1wDevpHBgV3tnSzSGYhHwPXAYxt9BqIeDr0xCBDIcY8tboJu+KjAm+f3a8Af6plHxeD1Ho9eOenn2hnMvnvx1hoJz7kJyko8hx7dh+ECjgC+ztbk2upBglwCoj+bZIQZ2dBb4zPmknNzKHQOItrL4w60Ul7j2ev43O8cTL8MYWWwHW4HWVgwMPiqK9x5MJC4m+K5CsQiYAPxXhaFwQgSA4BQOBT7BaFsyw3yMql/0LaO6ommD0RiFzmB2RBK2V9bSo+9S/v7HenfQfvvUzdnP5Jje6US1cM6+4wiGAGhIVLyRJohLhdgUU0OIqqtrWfVZAVnZRnTg53WubdWvwFhaNB8jivWnQttZwIlWjYSJCNgAdEe6AnZBBIDgFD4B+lh4fu03ywb838EHJvUGDm/qQUtX5XHiOZ8GXGgWG+PhuKNbMXKw4fS7dXblfqDdCYUAqE9dm2H8juiA12fKzB9/lf+bKljxcR7bK0Ndf2eaH9kZHViNtbD1GOBVFYcKExFwHop+H+GCCADBCRwOrLVq5J3pR3HKiXvt8XHvL9rC2AlfUVjU/C6Yju3ijPW5g9ow8Bj75+yHhFALgPpoGkRbbzMsK/ezdFUuWdlGZ8GGTa6dB1OI0Wa4ACM6sDXA53swhPVRKg4TBiJgEUZBsbADEQCCE7gWeNSqkZefOJSLzunUosdu3FTBI8/8zpz3N7E5x1hoExPt4cjDUv9drnPIgclWj+R8nCQAGuKLNdoM41IttRl+80Pxv6mCT7/Y5uZ9BWvZGR34gpbtK+iAUYCoZPS1y0VADUY3USg6MhyJCADBCTwMXG/VyFsvH8lpI9oG/Lyc3Eoqtvvp0DYOny/CPhJOFgD1UbSvoKCwikXLc5m/OIdFy7eSv821KeEt7LqvoLlZy3tjzMBwvQhYt8FPn0uLKSg2LeJOxliHLCACQAiMfTEq9fsAGRgFNd9iDBz5wYLdO4C7rBxM02DDV0No39ZsDWGE4hYB0JD6+wrikjGi3YHh9+t8+sW2fzsLvv6+SP05g0M1xoyLLIxiwl8aeczewAqgvYoXDKUIWPBxNSOvLzH79IeAmxQex9WIABCaIwZjiMZwjIE83Zt57HTgGpq/E9kNfcMZceNuWHPdtNf/usfsIQFOHNiGrNes1BBGKG4VAPVR1Ga4cVPFv8uLslfmUlbu2n0Fv7MzVbACY1bGCGAuoGzJRChFwAlXl7D8y+ZreJrgPeAUxcdxLSIAhIa0x3D4w4HBBNaT/wnG9L5me7L0TcM74/UNBQYBwyqrapM691pieupbbIyHNYuO5aD9IyBnr5pwEAC7ULevIHXnNkMTVFbVsuLjfBZk57BgSQ6/ry9TfM6gUYbRTXACoHwMZahEwEvzKrnkflN/k28xxooLiAAQwItRJTwSw+kfgrX3xTPA+Prf0PUzvORVH0pt7agdr9Or4Ws8N3M9V9zwbcAvFhPtYc6LR3DS0D1X/wuNEHYCoAG77CtIBY+5NsNffitl/pIcPliaw6pPC6hy574CWwiFCPj+Dz8HnWcqZfM30FnxcVyLCIDIJB0YihEWHAq0UmjbD3TTN55aRrT/BHRtFOgjgbTmnqTrcPn13/DCrL9a/EL9e6fz9H8O4tCeKRaPHFlUVdfyw88l/PZnGeT8TPcOXg7s6iXaYWsKlFN/X0F8quk2w+KSGpasMPYVZGXnsGWra/cVKCPYImBzfi3tRhWaeWoeFqcjhhMiACKHg9mZy++LcedvCzdP7L7u/lsP6AoEdLul6/DkC39w50M/Nzrm1ePROPLQVEYMzuTU4W3puZ8Dtum5hC1b68bo5rBkRe5uv9+keI0hR0Ux/OgohveNYq8Ml042DAQF+wp0Hb74ppCspTksWLKVtd8UunVfgWWCKQIsRAA2AC3rFY4ARACEL16MHPupGONAg/amH3tWR6Y/dZjp5xcWVfNO1mY+/7qQwqJqunSK58AeSQw5vg2tM0zvNokoamt11n5TyIIlW3cs0ilEb6Ff0jTo1cPH8L5RjDg6iiP39+EJdz2gqM1wa14lHyw1fueLP8ylqNhUoZprCZYIsFAD8D1wkOLjuBYRAOFJP+AFYP9QvPiY0zrw6rO9QvHSEU1h0a6rdLfmqQlNt07VOLFvNCOOjmJI7yhSEyPgsqFgX0FNjc7qNflkZW9lwZIcfvzVdOuaqwiGCBg4oYRlX5gSV+9jzAIQEAEQjpwEvIkNFb8t5eaJ+3D/rSHRHhHHD7+UGKH97K2sXpNPTY294WefF/od7GN432hG9IsKyarYoFO3ryAu1YgOeM19tP78u/zfiYQffpRPxXbXthnuETtFgMU5AA8DNyo8jqsRARBedAO+AcxVNyli8Zy+DD5O6mzsoGK7nw8/ymf+ki1kZW9l/Qa7Nsm2jM57eRh+dBQjjo7mhMN9IekJDyqK9hWUV/hZtjqPBUuMQkIVGyqdhh0i4Pd/aul9SRH5RaaF7mnAO8oO5HLC/NMacUwHxobyAD33S+LbDweYiZgKTfDXxop/7xyXr86jvMKZd45xMRoDevkY0S+a4X2j6NI23AsHaNBmaH5fwXc/FRupguwcPllbYHskpznitCgqdDW1CypFwB+bahkwvpi/c0y3YPqBTCDf8mHCBLlMhw8xGG/sQAb3KCU2xsOq9/tzxKGpoTpCWFBTo/Px5wU7Kstz+P5nd+aOD+zq/beroP8hUfjCPVugaUa9QF2qINrc0L3SshqWf5TH/MU5zFuc8++yqmBwaWIfrkzqyym50/m7Rs3OnGMP9ZH1aBIJcebdzV9bahlwdTF/brI0f2EJxqAyYQciAMKHgzCmXIWE1JQo5rxwhIT+TZKbX8XCZUax2OIVW9lWGF7V46mJGkN6G2LgxL5RtEmLgOiAgn0FtbU6a74qZP5io4Xz6++LWtzNEQgaGnemDOGqpKMB+LtmG6fkTmej31Sv/W5YiQQouPOv4yKMKKmwAxEA4cNQYGGwXzQ1JYpzR3fg1kn70DZTFvG0FF2Hr74r+vcuf81XkdM/7vHAEfv5GHG0MXfg8B6+8E8ZKdpXsGnLdq6+5Tveydqs7Gg+PDyefjJnxR+6y/edIAIUOv9NGDVSMrWpHuH+sYskzsXYymc73TrHM+jY1owcksmQ49sQEx0Bd3MKKK/w8/HnBcxbnMPbCzazcVP4FX6ZoXWqxvG9ohjZL4qTjomOrDbD+HSITaKll+LnZq5n/M3f4ferEYuxWhTPp5/BsLgejf48lCJAofMHmAw8ocJQOBEBn7SI4RpseoP7fBq9e6UxashejBqayQH7ygS+lvLHX+Vkr8xl3qItLFmRS2WVzJBvDq8H+vT0Map/NIOO8HH4fuZm97uKujbD+B2CwNv4//nBp3/j5nt/VPayCVo0M1qdw7Ex3Zp93EZ/EafkTgtqTYCinH8d6zBSpHL33wARAOHD3cDtqoy1aRXD0AGtGTVkL4YOaENyUgRciBVQU2PsmJ+/ZAvzFkXO8Be76NrOw+Ajoxh0pFE7kGihkMwVNLKvQNdh8u3f8+QLfyh7mdbeRN5odT49o1q2RCuYkQDFd/5+YCDGWmShAWH+aYoongGuNPtkj0fjsINSGHRsK0YO3ot+R6WHf15WEVvzKlm4bCvzl0Tm+NdgERej0e9gHyP7RXHqcdF0ygz/1JPfE8tlD5bz8jtqHC9AR18qc1tdQDdfRkDPC0YkQPGdPxg3RneqMhZuyCU+fHgdOCvQJ53QvxXjxnRi6IA2tEqXOfstwe83KrMXLLG3Mtt2onf8vauqQnsOkxzS3cuJfY0hRH0P8uENMz1QWQ3n3FHKOyvU/X16RLXmjVYX0M6bbOr5dooAG5z/PIxdKM4cnOEARACED0uBEwJ90rxZvRk5ONOG44QXoezNVkqrdDihL9rQY2FAX2O275pv0BethKzl8E9OqE9oivRkjYFHGKmCUf2jaOvybYbbSnRG3VDCR9/uvhXTLEdFd2JWqzGkeszNJ6jDjnTA49fEM/zaElVhf4CVwDBAKm2bQQRA+PANxsrfgPgk6xj6HJ5mw3Hczx9/lTNv8RbmL85hxSf5VFe7sIDP44GDesCQYwynf/B+zS+2+fl3WLwKfeUa+PgLqFbngIKFxwOH7etj0BE+RvaLpt/B7moz3Jxfy7DJJXz7m7ob10Gx+/BSxlnEaWpWhKgWAV4P+NV9vFZjbEAtVWYxTHHRx0LYAxuB9oE+6ddPBrJPt5AND3QUFdv9fLTGaNN7N2uze+ezpyXDMUehHdcbhh0HbQLL9f7LtmJYtQZ9xWewcAVsdecE1TZpHob2NiIDQ3tHkZzg3Mven5tqGTKphN82qnP+o+MP5qm0U4jS1I5iVJ0OUMRHGM5fqm9bgHM/CUKgVAABT+Ip+OVE0lJDtjgw5KzfUM7iD3PJXpnLB0u3UlrmvjteADq333mXf/ThEKW4a8NfC9//YqQKFq+Cb3/GjYUPPi/0PtBoMxzVL4oDHLTN8Ot1fk68toQt+epuhS9N7MM9qcPw2HSp/6tmG8fk/I/tinYHWETu/ANEBEB4kICJN73Xq1G1cSQeT+S8Daqra/no84IdW9i2urdNLz4Ojj0KbVA/GNQf2ge5juOfHMhejb5kNaxcAxXurInYt5OXMYOjueLUGDLTQ1c3sPLrGk66sYSiUnWiakJSf25PGazMXmPcWbSIZ0s+tvU1Wojc+Zsgcq784U1nYH2gT2qdEc3WH4epP43D2JpXSVb2VrKWurxNr3N7GNwfbcgxxl1+jPWuDf1vP1qCx1ggbXZjW2UVfLTWEANLVsNf/1g+V7BJS9J4aUoCpx4X/E6Y+R9Vc+ZtpVRUqnH+Ghp3pw7l8sS+Suw1xePFK7m/eKmtr9FCxPmbRARAeHA4sDbQJ+2/TxI/rh5gw3FCi67DF98UsiDbmLP/xbdF7pyzH+WDPoehDeoPg/vDPl2Uv4T+a71cs1eDBNASNYjXzOyuMVi3HpasRl+yCj772jWFhF4PvPmfRE45NngiYNaiKsbdV6rsVxSteflv2mmcEt9TjcEmmFG2lhu2zbP1NVqIOH8LiAAID4YAiwJ9Uv/e6ax6v78Nxwk+xSU1LP5wK1lLt5KVnUNOrkunfrZOh0H90Qb3g+P7QpK9BZq7CID6aEDMDjGQqEG0yUtFSRl8+An6ko8gezXkFpg+azDISNH4aXYqrVPtvzQ+PXc7k54sp1ZRyj9ei+bljLM4Iba7GoNN8EHFz4zLfwM/Ie+KEedvEZnvGh60MvUklw/++XldKQuyc8jKzmHVZwXubdM7ZH8jtD+4v9Gm53FAD7sObAd9uw55OkQB8RpaggYJWstvHZISYNQgtFGDoLYWvv15Z6rgm59Q5v0UkV+k89y727ntQmu98s2h63DXyxXc9ZK6LpNUTxyvtjqXI6M7KrPZGKsr/+TSgrni/MMEEQDhQWtTT8qIUX0OW9leWcvqz/LJXpnL+wtz+GmdSz/78XHQ/wijYn9wf2jbJtQn2jPVQJGOXqQbzj9eM6IDCYCvhWrA44FDD0A79AC44TIoKITVa43OgkUrocgZf88FH1XbJgD8tXDVw2U8/566CFWmN4k5rc5n/yh7C0G/qvqHC/JmU6WHPKUjzl8RIgDCg3RTT0pzfvvfhn8qyFpqVOwvXZVLWblLp3ru29W4yx/UH3ofqr5NL5joQJmOXrajriLGiApo8UBcANGB9FQ4aRDaSYOMOoHPvkbP3hEd+PVPmw6/Z37dYM97rKoazrurlLnL1I327eJLZ06r8+niM3UJaDF/1ORzXv5rlOohT62J81eIi69CQj1MpgCcFwHw+41tenWh/W9+KA71kcwREw39jjAq9gf3g04Bz2hyD5U6VOroBYAXiNPQEjFSBd4WqoEonxEV6X8ETJ0Ef/8Di3e0GX601ug0cDGlFTqjbyll8Rp1HSiHRLfj9VbnkeGxt05ks7+Y03NnkusPeXu9OH/FiAAID0yNestwSAQgf1sVi5ZvZf7iHBYtz6Wg0KUX+w57GQV8g/rBsUdBXMBzmdyPHyjV0UsBTd8RHcCoHYgNoLCuU3u45Cy0S84yZgysXIOevaOQcOMWu04PQJdOaoVxQbHOiOtK+PQHdaHzfjFdmJkxhiSPvSJ+W205Z+TOVDby1wLi/G1ABEB4YK4GoFXoIgBhMWff64GeAczZjzR0YLtuFBPm60atQJ0YCKTNMC4Whh5r/I7BmDOwaCX64lW27Cv4+pSLObLTMQwq+4IRZZ/Rb/sPaJhrI/1rSy1DJ5Xwy9/q0goj4w7g/9JHE63Ze/ku06s4J28Wv9bkqjBXCRQAbU08Vyb82YRcrcKDr4BDA33SxwuOoe8RwVkEVFbuJ3tlLlnZOWQt3crGTS6ds5+eCgOPNir2j+9rzN13MU22AdqNxo5UwY6uArPBqG3FRpvh4lWw7BOjsNAK6alon7wN6Sn/fqu1v5BhZWsZWfYJQ8q/IKW2rEWmflrvZ+jkEjao23DHWfGH8nj6yfhMD2loGVW6nwvyX2PZ9t9UmPMD5wBrgA+BLgE8V+78bUQEQHiwAegQ6JN++fgE9t070Ybj7GTxh7k8/eIfLFmRS2WVC+/yNQ167rujN78/9OpJOC2eD5kAaEgURiFhohZYIWF9/LXw5fdG3UD2avj+18D2Ffi8aNMfgbpIQ2MP0f30rvyZkWWfMqjsCw6vXNfo4z7/qYbh15WQV6h2tO9tKYPQbL5s16Jzef6bvFfxvQpzOnA58MKOf3em5SJAnL/NiAAID0wtAsr/ZRjpqfbMAqisquWSyV8z682Ntti3lYR4OO4oo2J/UD93tOmZxDECoD67tBlq5hOVm7dC9kdGZ8GKNVBW3vRj01PQnprarPNvjG7VmxlU/iUjyj5jSPkXxOhVLF5TzWm3lFJWoW6079SUIVyZdLQSe3vihm3zmVH2uSpztwAPNPheB+At4KhmnvcacCnQzB9NsIoIAPfjyEVAZ166lrnvb7LFti107bhjGM8xcPRhEO3uIUktxZECoCGx2s4hRGbb86uq4OOvjPHEn34F6zcacwm6dTRqC8aOhgxr6bB4vZJuc6bz4+QX8SuqafHh4fH0kzkrPuAMnykeKF7GY8UrVJl7DLiuiZ95gDHA+RijzNOALcAq4P8wogSCzYgAcD+OWwT06lsbOe+qL22xrYzoKOjby6jYH9wf9u4c6hOFBFcIgPp42ZkqsLKvwA6mvYl+84PKphtGaz6eSz+dEXH7K7G3J6aVruGmwgWqzM0CxkLoRwYKTSNdAO7HVAugnTMAHv6fksIh9WS22tmmd3wfSIwP9YmEQPEDxTp6sb7rvoL4ANsMVfPUdPR7nlZmLsUTyysZY+gTExxh+lb5t9xSmKXK3HzgIsT5Ox4RAO7H1BCgjHR7ZgBs2VrpnOE9Hg8cdoAxjGdQfzioh7TphRP19xVgYV+BpTPo6Hc+Ac/OUmaytTeRN1qdT8+ovZTZbI4V23/nmm3vUmuy1bEBnwBnAyGfFyzsGREA7sdRi4DW/RHiVt3UZDi+j1GxP/Boy3ldwUU03Fegos2wOWr86NfeC7PfV2ayoy+Vua0uoJvPVGAvYL6s2sjY/Nep0pWkgr4DRgAt65MUQo4IAPfjqEVAW/NCMMWvc/udw3j69jLy+0JkowPlOnq5xX0FTVGxHf2iG2HpRxYN7aRHVGvmtLqAtt7gzJb4uXor5+TNolxX8pn9HWMt+TYVxoTgIALA/ZgbA2xTBCCvIAjLQmJjoPehRmj/xOOho5nhYkJE0di+ggQNEjXj34FQVII+5hpY842y4/WK7sDsVueS5glOXco//iLOyZvFWxCgmgAAIABJREFUtlolA7m2AsMxqvgFFyECwP2Y3ANgjwDI36Zu2ckudGwHA/qgHdfbCO0nSAGfYJJ/9xXohusKZF/B1nz0M6+GH35VdpzBsfvyYsaZxGnBiVzl15ZxRu5M/vEXqTBXBAwF1P1ChKAhAsD9OKoGIL9AUQpA5uyHhrIyWDAPPvsEtmwGzQMdOkL/Y2DoMIgKs/kIDfcVNNdm+Mff6KePhw3q5lucHn8IT6adTJQWaBjCHMW12zkz9xV+q8lTYa4cI+f/tQpjQvARAeB+zAmADLtSABYEQHqqsRJ2yDHGRLZUd8/Zdx0rPoQH7oXiBl0cf/4Bq1bAyy/C1Hvg4ENCcryg0LDNMG5H3cD6X9HPmwC5Bcpe6rLEPtyTOsz20b51VOo1XJA/m++qN6swVw2ciTGuV3ApIgDcT7qpJ6XaE27M32ZOAGj3XQ+XnGW07gnB56058Pijzc/Oz9kCE6+Cu+6D444P2tFCRl0h4Udfws3XQ6m6Dpebk0/g2uTjlNnbEzXUcmnBXD6uXK/CnA6MA5RNDRJCg1xt3Y+jugDy8k1GAA7cV5x/qHjvnT07/zqqq+GOKUa0IBL4aBVcd40y5+/Fw8NpI4Pq/HV0btg2j4UVP6syeT3GpD/B5cgV1/2YnATosBRAvfWrQhB57x14+IHAtubV1ESGCFiYBbfcCJVqOluiNS/Ppo9mbMKRSuy1lLuKlvBqmbLR3PdizPgXwgARAO4mERNbAL1ejZRke7I/5gVAqtqDCHtm5tuBO/86wl0EzHkd7r0L/Gp2JcRr0bySMYZT4nsqsddSnipZxTMlytL0zwG3qzImhB4RAO7G3BjgtGhbtgBWV9dSXGKyDTBNIgBBZebb6Nf/x5zzryMcRYCuw0svwJOPWfvd1CPVE8ebrS9gQGx3JfZaypzyr7mvaKkqc+8C41UZE5yBCAB347gZAKaumUkJMr0vmKhw/nWEkwiorYWH7oeXX1BmMtObxHutL+KI6I7KbLaEhRW/MKngPXQF8/1TkqPWYMz3d9nqSGFPiABwN45qATTbASDh/yCi0vnXEQ4ioLoK7rgV3n9Xmcl9fK34oM2l7B+VqcxmS/iocj2XFsyhRsEyviMPTeWTef3vAoIw4lMINiIA3I2jhgCZ7gAQARAc7HD+dbhZBFSUww3XwXJl4XIOiW7H+23G0cEb3NTWj9U5XJg/m0rd+jK+fbolMP/V3uy/f7KM3QxTRAC4G0elAKQA0MHY6fzrcKMIKCqCiVfD558pM9kvpgtvt7qQDE+CMpst4c+aAs7Im0lR7XbLtjq0i2PJ3KNp0yoGdN3UjYbgfEQAuBtzLYBOSwFkiACwlWA4/zrcJAK2bIbLL4Yfv1dmcljcfrze6nySPPbM2WiKLf4STs+bQa7f+ryCVunRLJ7Th84d4oxv6OYijYLzEQHgbkx3AdiB6QiAdADYRzCdfx1uEAHr/4QrL4UNfyszeVb8obyccRYxWnAHrBbXbuecvFlsqCm0bCs+zsv7r/Rm/32Sdn7TY+5GQ3A+MgrY3TiqBsDsIiBNhgDZw4tvoE95OLjOv446EXD3f9SODS4qgk8+go0boLIK2raFo3obC4tayvffwQ2Td995YIFJScdyS8oJQZvrX0e5XsXZebP4odr6Jt6YaA/vzTyKvkek7foDXRMBEKaIAHA35moA0u1puZMaAAcRSudfR50IuOd+ONbi6NvqanjxOZj7xu6T+TTNsH/tDdBqD5OxP/0Ebr0ZtldYO0/dS6NxV+pQrkjsq8ReIFTrfsblv8Haqg2WbXm9GrOe6cWgYxv7/UkNQLgiKQB3YzICYE9+UmoAHIITnH8dNTVw+y2wcoV5G5WVMHkCzJrZ+FheXTfSDePGwm/rmrazZBHcdJ0y5+/Dw9Ppp4TE+deiM2HbOyzb/psSe/974CBOH9Wu8R9qUgMQrogAcDeOSgGYbgNMEwGgDIXOX1MVzbYqAh6+H75qwSz7/DxjW+G6X3f/2Vtz4O47jbMoIFaLYnqrczgz/lAl9gLl1sIPeLv8OyW27r1lPy6/oEvTD9ClBiBcEQHgbsIjBSARADUodP4ej8aLjx3Kndf3UHAwzIuAn3+ChR+0/PFFRXDN+F1FwEsvwGOPGJP+FJDiiWVOq/MZEruvEnuB8nDxh7xUqqZtcdJl3bh10h7/HxIBCFNEALgX04uAUpPtEQAyCTCEzHxb6Z3//x44iHFjOjH1hh48cNsBCg7IThEQSHfABwsC/z8VFcHVV8JPP8JTTygd7dvam8g7rS+iT0xnZTYDYXrp5zxcvFyJrXNHd+DRuw5syUOT9R/OsCdsKIQUEQDuxdTdf3pqlG2LgIqKzS4CSlZ7mEjjxTeUtfrV3flfMbbLv9+7aUJ3tZGAO6a0PBLw80/mXqe0xOjxf+M1c89vhM6+NBa0vpieUXspsxkI75R/x82FC5TYGjm4DdOePLTl14I2fkkDhCEiANyLowoACwqtLAKSmwvTKA77v/DoIYwb02m3n029oUdo0gGlJeZfR9EqX4ADojKZ3/piuvjSldkMhOXbf2PCtneoVbDcp/8hPuY8ezBRUQFc/v1+SQOEISIA3IujFgGZHwIk4X/TzHo3KM6/jpCIgNS05n8eBHrHdOK91uPI9Cbt+cE28EXVRi7Kf4Mq3bqgObi7l3kPJxEXHaAtmQUQlogAcC8m9wDYVABotgNACgDN8dUP6DfeHzTnX0fQRcDBoamyr2NI7L7MbXUBKZ6Ay22U8Ev1VsbkvUq5bvLzVY9u7TwsfDyJ1EQNagJM13llFkA4IgLAvTgqBSBDgIKLfs/TUG29pS0Q519HUEXAyFHgC828sjPiD2FaxtnEavaI5j2x0V/IWXmvsK223LKtvTI8LH4ymbYZOy75tQG+d2QhUFgiAsC9hMciIBkDHDg5ebB6rWUzZpx/HUETAe07wLnnq3mdALg8sS//TT+VKM0b9NcGyK8t44zcmWzyWx9XnJqosfDxJPZuX+9yXxtgBEBSAGGJCAD3Eh6LgCQCEDjf/2I59G/F+dcRLBHQ69KBnDQgeCvpb0keyD2pw4I+17+OUr2Ss/Nm8XtNvmVbcTEa7z+cxCHdGwiZQFMAWq0IgDBEBIB7MSkAbJoBIIuAgkep9ZDw4QencP4ZHSzbsVsEHK79RrZnCm/dHcvpA+ztFvHi4eG0UUxOPtbW12mOKr2GsXmz+aZqk2VbPi+8cU8ixxzSSAol0BQAHkkBhCEiANyLo1IAEgEIIq2tt6J9/nUhZ1/+BdXV1qfjKRcBO+YEHK79xhJuJo1SfF6YfXeibSIgWvPxfMYZjE04whb7LcFPLZcXvMmqyj8t29I0eGlKAqP6NyH4/YHO7JAagHBEBIB7cVQRoCwCCiK9ekKc9ar0txdsVioClE0MrK5Gu/1mrlkxkTRK//22zwuv35PImCFqRUC8Fs0rGecwKk7R+U2go3PDtvksqDA5+KgBD18dzwUnNvNZDzgCoEsKIAwRAeBeHJUCkEVAQSQ2Bs49WYkplSLgpgndlYkAvcbPxbfn8c6KXd9XXg/MvEOtCIjSPKR5gldj0Bj3FmUzq+wLJbamjI3junP2IBADjgBoEgEIQ0QAuBdTceAMmzYBShdAcNFuuAw6NrG+NUBUiwBV6YDqGjj7jlLeXbm7CJhxu7p0QFHtds7Ke4Xvq7cosRcoz5R8zNMlq5XYuvSkGO69LG7PD2yhAPhg6VbOvHQtXY/I7gIUAOuAl4He5k8pOAURAO4kAWjBp3xXvF6NtBRZBBQWpKeivfqEst+f6nSAKhFQVQ1n3b67CFBdE7CttpzRuTOCLgLeKP+au4oWK7E1+vhonr0xoWVrnPeQAthWWM2Icz9j+JhPmfv+JtZvKPcAaUB34CLgU+BFTCwkE5yDCAB3Yiofl5ZizyKgmhqdwiKTi4AkAmCe/fdGm/citFGTnnVqTUBVNZx5W+lu6QDVNQHbass5NXcaXyuowG8Ji7b/wuSC99AVzPcf0CuKWVMT8Lb0iq7r4G9cBJRX+Bl0xsdkZefsycrFwFwgNMMSBMuIAHAnjtoDUFBYZa4tPTFeFgFZZd+uaO8850gRoLImoLrGiATYXRNQVLudM/Jm2C4C1lZt4LL8udRg/fd8xH4+3nsokdjoAMV9E8OAptz3E19+W9RSKyOBqwN7YcEpiABwJ+ExBEgKANUgIsBVIuCn6hzG5L1KhW4yalaPfTp6mf9IIknxJiJ7jaQBcvOreG7m+kAt3QyEZl6yYAkRAO7E3AwAmwoAZRGQA4gwEdBYYaAbRMD6mgLOyJtJYW2FZVvtW3tY8mQSmekmL+ONTAPMXpnL9sqA/+Z7AX3NHUIIJSIA3InJGQBO6wAQAaCUCBIBZ97mPhGQV1vG2Xmz2Oov3fOD90BGisbiJ5LovJeFS3gjEYCf15k+W0/zBxFChQgAd2JuFbBdEQDTUwClAFA5IgIcKQKKa7dzZu5M/lAw3z8+VuP9h5I4oKvF2rtGagBqakz/nTMtnUUICSIA3ElrU0/KsGcKYK7pFECa2oMIBiICHCUCtuvVnJf/mpIWwygfvPWfRI4+SMGK5EZSACnJplP5MinQhYgAcCfmIgCyCChyEBHgCBFQrfu5OH8On1b+ZfkMHg+8ckciw/oo+hw3kgKwkCaUSYEuRASAO3FUG6DUADgUEQEhFQE6OtcXzmPJ9l+VvP7j18Rz1iCFn+FGpgFauEaIAHAhIgDciaMWAckmQAcjIiBkImBq0WJml32l5HXvuSyOiWcoHrrXSATAQquwpABciAgAd+KoFIDpNkARAMFBREDQRcBjxSt4tuRjJa931Wkx3HZhwJO/90xjEQBJAUQUIgDcibk5AE5LAcgcgOAhIiBoImBG2VoeKF6m5HXGDInm6WsTlNjaDUkBRDwiANyH6UVAqeYrfJvF/CRAKQIMKiICbBcBH1T8zM3bFiixH33c4Uy7NRGPXVfpWv9u30pLicLrNbUvJBbj2iS4CBEA7sOU0k5PtW8RUFGxLAJyDSICbBMBqyr/5NKCufgVzPfn8J7UzngcX5SNl2i9dreFQB6PpY2hEgVwGSIA3IejCgDzt8kiINexb1e0uf9z5CrhmyZ0V7ZKuG5s8HurdhcBM25Xt0q4qHY7Z+XN5IK816jSm1+z2yL27472+tP4ExIo8tp8U93IMCALA8OkENBliABwHyanADos/J8uQ4BCygH7GKuEM5wXCVC9SviMW3ePBKhfJVxBmW7ys1CfTu0NcZaaDECeJ9m6zeaQWQARjQgA9+GsPQBmBYAUAIaefbvCU886UgS4MR1gmYw0tDeehsydH/E8n81pskamAYoAiBxEALgPR6UApADQ5XTpIiLACSIgKQFtzn+he+ddvp0fggiApAAiBxEA7iM8UgASAXAOIgJCKwJiY9BefQIO3m+3H9mfAlAaARAB4DJEALgPk0OAHJYCkCFAzkJEQGhEgNeD9uy90LdXoz8ORQrAwrVCUgAuQwSA+3BWDYDJIUCyCMiBiAgIrgjQNLRHb4WRJzT5kAIpAhRsRASA+3DUIiDzNQASAXAkIgKCJgK0O6+Bc09p9jH53uCnAKQGIHIQAeA+HJUCkBqAMEREgP0i4JoLYfz5e3xYntfmSJlfIgCRjAgA9+GsFIDUAIQnIgLsEwFnjUS79eoWPTTP7giALASKaEQAuA9HLQIyPwhIagAcT5cu8NjTkKpmaFOkTwwEwONBu/Rs0Fo2ltv2FEAjAsBCCkAEgMsQAeAuwmcRkEQA3EH37vC/5xwZCXDjxEBqa9FHXwlf/9iih9ueAmhkIVB6qiwEihREALgLWQQkBB9JB6hNBxSVoJ9+VYtEQL4nmVo7L9N67W6dAB6PpRsGKQR0ESIA3IUpAWAhpNcssggoghAREBIR4Nc89i8EaqwOwHzKUNIALkIEgLswl/+3SQDIIqAIo0sXOj77IhltMpWYExFQgn7WBPj7n2YfJguBBLsQAeAuwqQDQML/buSo+HhWDB7CvPfm06qVmut8xBcGFhSiX/+fZh+S77NZAKidBigpABchAsBdmEsBOG0GgBQAuo6TU1KY160bGT4vB/Y8iPfnfeBIETD1hh7KREBVtREJaCgCfF6YfbdCEbD8U/jmpyZ/nOexuxCwkQiApAAiAhEA7iI8WgBlCJCruLJVK6Z37kysZ+flQkSAYhGwZHWTP5KFQIJdiABwF46aAihDgMIbr6bxePv2PNCuXaMXChEBhggYfbz1z5e+fmOTP3NZCkAiAC5CBIC7cFYNgCwCClsSPB5md+nMuD1U/R/Y8yCyFmaTmem8wsBgzAmoqtYpKDbTCtMAr7fJHxXYngLYfRaA7AOIDEQAuAtHtQHKIqDwpG2Uj4V7783QpJbdefbosR/vvBt5hYGlFTrDJpew/EuTszDqoXXt2OTPbB8HXLv751i6ACIDEQDuIt3Mk5yXApAIQEgoLIa//oHi0iYfcmBsLEv33oeD4wIbOBlp6YDXFlcx/NoSVn2zewFdwGgaDDu2yR/LQiDBLkQAuIuwSAFIDUAQqaqCF15HP/ZM9H1PQD/iJPS9j0Pvexo8NR0qK/996ICkRBZ235v20eamwEWSCDh3aqka5w8w4gTYb+8mfxyKhUDSBhgZiABwF+GRApAIQHBYvxF96IXoUx6Gn35nl7GNv/2Ffs/TMHYMbNjA+WlpzO3SlWRP07nolhApIkAZHduhPXJLsw8JxUIgaQOMDEQAuId4TCwC8ng00lNlEVDEsfY79GEXwve/NP+4DRtInHgVd8bGEtXCDXV7IlIKAy3TLhPtrWcgo/nJmKFYCJSWYnp/SBzGtUpwASIA3IPjFgEVFpldBCQCwFbmL0U/9XLI39aih5duzeGmG69TeoQePfZj3oJFjhQBKscGm6ZdJtq7z0EzxX91FHiS0FH/Gf6XRhYCeb0aaSmmbxwkCuASRAC4B3MzAGwK/xcUmlwElBAPMbIIyDaenYV+8c2wvXLPj63Hu++8xcYNG5QeRURAE7Rpg/ZOy5w/QI3mpdCbaO+ZJA0QkYgAcA9SACg0jb8W/ZaH0O94HGoDd5B+v58VKz9UfiwRAQ1o0waefhY6dQjoaaFYCCSFgOGPCAD30NrMk+wSALl5MgbYMZRXoF94Pbz4hiUzG/7+S9GBdqVHj/14570FJCeryWU7dU7AHqlz/h06wu5p92YJxTRAaQUMf0QAuAdzMwCcFgFIkw4ApWzNRz/5Mli4wrIpbzPT6KzyxRdrKS0tUWbPdYWB9Z0/BCwAXLYQSCIALkEEgHsIkxSACABl/PIH+rCx8PWPSsztf8CBSuw0ZObM6Vwz4SpqTaQmmsM16YCGzh9MCIDgLwSSfQDhjwgA9+AoAWA+BdB8y5PQQlZ9jj5iHGzYrMRcUlIyA08YpMRWfaZPe4mJV1+p3PnX4fh0QEbG7s4fHJgCkBqASEQEgHswNwTIrjHAphcBSQ2AZd6Yj372BChSF1K/7vobiItX2749c+Z0Jk+agG6qXaTlODodUFQEv/+++/cDFAD2LwRSmgKQCIBLEAHgHqQGINLRdfSHn0efMNWYR6uIIUOHcfWEScrsgX1h/6ZwbDqgpgbumAIrPtzl27o/MFEkC4EEOxAB4B4clQLIy5cugKBSXYM+8S546DnMDWBonFGjTmbmK7OJilI3LTLYzr8OV4mAQGsA7J4G2EgKwMK1Q1IALkEEgHsw1QbY2nwYr1lkDHAQKS1HP28yvD5PqdkrrhzPzFmziQtw819zhMr51+EaERDg8fK9SWrO0RRSBBiRiABwD46aBGhaAEgEIDA2b0UfdQks+1iZSa/Xy0MPP8aDDz2Kx6PuEhBq51+HK0SA0yIAMgkwIhEB4A4SMLEIyOI872aRSYBB4Md1LVvoEwDx8QnMeu0NLr/iKmU2wTnOvw7Hi4ClywN6WigWAlnYIyILgVyCCAB3YOru38JGr2axtAhIigBbxvJP0UdeDJtylJnMzMwk64PFDB8+UplNUNvqp2ka8Qlq5t47tkWwpgamTIEFLRcBoVgI5PHIQqBwRwSAOzBXAGhT/t/0IqBEWQTUIma9iz5mIpSUKTO53377k71sJYf1OlyZTVDb6qdpGhNveYCnZywgJU1NHZljWwRratAvvhHeWdSyhwdlIZBMA4w0RAC4A2d1AJjN/6dJ+L9ZdB39oefQJ98DNQEmiZuhT5++ZC3MplOnzspsgtqwf53zP+2cS+jeoyePvfC2I0WA0nSAvxb9yttaLALyPVIIKKhFBIA7MFcAaNMQIGkBtIGqKvTLb4WHn1dq9tTTTue9eR+QkaH2hswu51+HHSLg1Is+p7LKvSIgz2d3K6AsBIo0RAC4g/CIAEgBYONsK0YffVWL7wRbyhVXjmfa9FeIjY1Vatdu51+HahGwYEkOo8e5VwTYvxBo96iTpADCGxEA7sDUh8muGgBZBKSQ9RvRh18In36lzKTP5+OJJ//Lgw89iqapLRwLlvOvQ0TATuyfBbD751pSAOGNCAB34Kg9AKZTABIB2JW13xltfr/9pcxkYmISr7/xFheNa9qpmiXYzr8OEQEGoZgGKAuBwhsRAO7AUTUAsghIAfOXop96OeRvU2ayXbt2LFyUzeAhQ5XZrCNUzr+O7j16Mn32+8pqGdwoAmQhkKAaEQDuwFFtgFIDYJHnZ6NffDNsr1Rm8sCeB7F02SoOOvgQZTbrCLXzB0hN8HFCv8N5X2FBo9tEgMsWAkkEwAWIAHAHjioCzDctACK8BsBfi37zg+i3PgIKJ+adMHAQixYvpV379sps1jFjxrSQO//EWA+dWsUA0POggyNWBOTbLQDUpgAkAuACRAC4A2fVAEgEIHDKytEvuBZemqPU7NixFzH3zXdJSlLvHKZPe0mp85805cGAnX9slIeubWKpP9CyfYcOpKeru8FcsCSHMVc4cGKgvxZ9/B0wfxkQjAiAtAFGGiIA3IGjugBkEVCA5OShn3wZLF6lzKSmadx8y2089d9n8fl8yuzWMWPGNOUT/k45++KAnhfl1eiWGYu3nvevqqpi7AXnsm7dr5bPVR+VcwKUTgysrkG/5CZ4Z5EsBBKUIwLA+ZhaBGRxjnezmG4DjMQ9AD/9jj5sLHzzkzKTMTExvPjSdG6Zcpsym/WZMWMakyaOD2nYX/NodM2MJdq30/nrus6Eq69gxYeBLdJpKU5PB/wz70s19pqikTkAFvaJyEIgFyACwPmYuvu3sMmrWSwtAoq0FMDKNegjx8HGLcpMpqWl8+77WZx+xlnKbNbHEc5fgy6toomP3vXydM/dU3l99muWz9UcThYBheP/w+xsk+K7JTSyEMjiRlEpBHQ4IgCcj6M6AGQRUAt5fR762ROguFSZya5du7Fk6YccfXQ/ZTbr4wTnD9A+PZqU+F3TGq+8MoNHH3nQ8rlagpNFwPlTS3ndThHQyEKgDKkDCFtEADif8CgAjJRFQHULfSZMherdL6ZmOfLIo8hetpJ99tlXmc36THv5xZAX/AFkpkTTKmnXO85lS7OZfM3Vls8VCE4tDPTXwgV3l/LhlyajcHtCCgEjChEAzsdcAaBdewBkEVDTVFUbVduKF/qcdPKpzFuwiFat7LmeTnv5RaUFf5OmPBhwwR8Yvf5t03Z1/j98/x0XnD+G6mqbHF4zqF4lrEoEVNfA2XeUUVJu/e+1G2oXAkkKwOGIAHA+zpoBYHoPQJgLgMJi9DPHw9wspWavuHI8M2a+SlxcwHWgLcIpzr9+r38dmzZt4vTTT6GkpNjy2cziVBGQU1DLc++qGyT1L40UAkoKIHwRAeB8zI0BdtwmwDDuAPj7H/QR4+CjL5SZ9Hq9PPLoEzz40KN4PPZ8TJ3i/Bvr9S8tLeHMM05l0z//WD6bVZwqAt5daUMtgNppgCIAHI4IAOfjrBoAWQS0K1/9YCz0+fVPZSYTEhJ57fW5XHrZFcpsNmTGjGlcO3liSPv8ofFef7/fzyXjLuS7b7+xfDZVOHFOwK9/7363bhlZCBRRiABwPo6qAZBFQPX44ENjwE9ugTKTe+21F1kfLGbYsOHKbDbEKQV/Hs1w/vV7/QGunTyRDz5YYPlstG0LTzwNKWreeyoLA1tnRGN1U7Nf3TTpnahdCCQCwOGIAHA+jmoDlBqAHcx8G33cjVCxXZnJAw44kKXLVnHoYb2U2WyIU8L+mgad28QQ16DX//HHHmb6tJcsn42kJHjkSTiyNzz1jDIRoCId8PJrf3Ppdd+Ya6etR9d2XmsGGqORLgDZBxC+iABwPmGSAgiTGoC6Nr/r7oMadSHY444fwKIly+jQsaMymw1xivMHaJ8eQ0rcrg7srTfncNfUOyyfjagouP8h6NLF+Hf37o4RAXXOv7bW+t/gxD42TPpU2wUgAsDhiABwPo5KAUT0IqDKKvTLpihv8zv33PN56+33SU62TyQ5yfnvlRpNq6RdB/188snHXHXlZdbPp2lwy21w2OG7ft8BIkCl80+M07j69Jg9PzBQZA5ARCECwPmERwrA7XMACorQT7sC3l2szGTdQp9n/u8FoqLs2dsAzin4A0hL8LFX6q7/1z///IPzxpzJ9u0K0imXXA5DT2z8Z927wzPPg6JVwoEUBqp0/gBPXxtPZroNl+9GagCkDTB8EQHgbOIxuQgoNdkeh2J+EqCLUwB/bkA/8UJYo64qPTo6mueef9m2hT51OGW8L0BirJeODXr98/PzGX3qSeTl5Vk+HyNGwYXjmn9Mly7w1LPKREBLxgardv73XR7HhSNsuPuHRkcBW9grIguBHI4IAGdjSkGnp0bh9coiICV8/o3R5vfH38pMpqam8c678znr7HOU2WwMJzl/o9c/Zpde/4qKCs45azS///6b5fNx2OFww80te2wQRYBq5++dciW3jLXRp+q1uw0D8not3VBIJ4CDEQHgbMwVANqU/ze9CChLDFlPAAAgAElEQVTBpYuA3s9GP/UKKChUZrJz5y4szl5O/2OOVWazMZzk/KO8Gns36PWvra3lskvH8dlnn1o+H126wgMPGcV/LX5OF9tFgGrnr906ntrJl1DkTVBir0n8jdQBmE8pShrAwYgAcDZSABgqnp+NfuktUKlu2lqvw48ge9lKevTYT5nNxnCS86/r9Y9q0Ot/+2238P5771g+Hxmt4LEnITEp8OfaKALscP5MMtIbeZ5kJTabRAoBIwYRAM7GWXsAzAoANxUA1vjRb7gf/dZHQIEDrWPkyJPIylpMmzZtlNlsDKcM+TGeD10b6fV/4fn/479PP2n5fMTFwyOPQ+Ze5m106QKPPQ2padbPgyEC+o9ardb5T530r/MHyPPZXE/T2EpgmQYYlogAcDaOSgGEfQFgWTn6+ZNh+ptKzV5x5XhmzppNXLy99VBOqvYH6JARQ1KDXv/FixZy803XWz0eeDww9W7YV8Fc/e7d4X/PKYsErP26UOGd/9Uw/vxdvpdvdwSgEQEgKYDwRASAswmPFIAbIgBbctFHXQLZHykzWdfm9+BDj+L12jC1rR5OCvsD7JUaRUbirr3+33z9FReOPY+aRubNB8yk66C/wjoKxekAFWi3Xg2TLtrt+3leu1MAshAoUhAB4GzMbQK0aQqg6RSA02sAfvoNfdhY+O4XZSZjY2OZNv0V29v8wHnOPy3Rx16pu74HN23axNlnn05ZWanVI8J5F8DoM6zbaYiDREBTzh8gz2tzRE0WAkUMIgCcjbNqAMJxEdCHnxmrfP/JUWYyPT2d9+Z9wKmnna7MZlM4zfknxnrplLFrj3pJSTGnjz5ZzWrfEwbC5VdZt9MUDhABzTl/gAKPzQKg0WFA0gYYjogAcDZSA2Anr72HPmYilJQpM9mt295kL1tJnz59ldlsCqc5/7hoo9e//pa76upqzjv3bH74/jvLZ+SAA+HWO438v52EUATsyfkD5HtNdDwEQqNdAKYHD0kKwMGIAHA2zqoBMLsIyGk1AHULfa65G6oV5KN30Lt3H7KXrWTvvbsrs9kUTnP+UV6Nbm127fXXdZ2JE67kw+XLLJ+Rdu3hoccgNta6rZYQAhHQEucPwUgBSBtgpCACwNmERQrAUTUAVVXoV96mfKHPKaeO5v35C8kIgsNwmvP3aMagn4a9/g/cfx+vvTrL6hEhJcXo9U9T06rXYoIoAlrq/CEYRYCSAogURAA4m/BIAThlFfC2YvQzroa3Fio1e8WV45k2/RVig3B36jTnX9frH9ug1//NuW/w4AP3WT0iREfDg49Cx07WbZkhGCLg6vEtdv4QhDZAtSmA1pbOItiKCADnEofJRUBpKQ5bBOSECMBf/6CPuAg+/kKZSZ/Px+NPPM2DDz2Kx+68NM5z/gAdG+n1X716lcLVvrfDQQdbs2MVO0XAFVfB+RcG9JQ8n82fJ/ULgQK+jgnBQQSAczGlnO1aBOT36xQVm8yXh1oAfPG9sdBn3XplJhMSEpn9+puMu/hSZTabw4nOv21aFOkNev1//vknzj3nTCorKy3ZBuCqCTBkqHU7KrBDBNQ5/wCHBuV7ktBR/xn/F/ULgaQOwKGIAHAujgr/52+rMjfdLNSLgBYsRz/1csgrUGaybdu2LFyUzZChw5TZbA4nOv+MRB+ZKbv+Xbds2cLpo0+msHCbJdsAnHQKjDnPuh2VqBQB9e/8a4EAPlo1mlcWAglKEAHgXJzVAeDG8P/zs9HH3QgV25WZPPDAnixdtoqDDzlUmc3mcKLzT47z0qFBr39FeTnnnnMGG/5WsDa5z9Fw/U3W7diBChHQWNjfH5i4tn8hUGPDgKQQMNwQAeBcnNUB4KYCQH8t+i0PKV/oM+CEgSxasoz2HToos9kcTnT+cdEeOrfetdff7/dz8bixrF37ucVTAj32g3v/AzaPTraEFRHQVM4/wD9xvt2dAI1FAGQWQNghAsC5OCoF4JoIQHkF+oXXw4tvKDV7/vljmfvmuyQl2Xzh3YETnX+0b/def4Cbb7qeBQvmWbINQOvW8MAjxpY/p2NGBDRX8BdgeY3tswBkIVBEIALAuYRHCiCYQ4C25qOffBksXKHMZN1Cn/8+8xxRUfZ0VzTESSt96/BohvNv2Ov/9FNP8Pxzz1qyDUBiIjz2FNi8LlkpXbrAE/+Ftm2bf5zXa6Q0mqv29zf9o8awfxbA7hEASQGEHyIAnEt4LAIK1hjgX/4wKv2//lGZyZiYGF54cVpQFvrUMe3lF5k8aYKylb6TpjxoaaWvYafxXv/33n2bO26fYsk2AD4f3PcgdNvbuq1g021veGkmjD5z9ymFmga9Dof/exFOHd28nQAFQL7d+wAaSQHIQqDww7fnhwghwlk1AE5eBLTqc/SLboCiEmUm09LSeXX2HPr166/M5p5wovOHxnv916z5jMsvu9h6lELT4KYpcMSR1uyEkpQUuPZ6GD8BfvwB8vMgPgH23RdatbCbN8BfY4HP7hoASQFEAiIAnIvUALSEN+ajX3svVO1+x2KWLl268ubb77HPPvsqs7knZsyYxrWTJypz/hNveUCJ82/XSK//+vV/Mubs06moqLBsn4sugeEjrdtxAjExcFgvU0/Va3S0AHr77e8CkCLASEBSAM7FWTUATlwE9Pxs9AlTlTr/I444kuxlK4Pu/J1W8AdGr3+bBr3+BQUFnH7ayeTm5lq2z6AhMM76OcOCAP/09hcBSg1AJCARAOcSFikAW2oAavzoNz0AM99WanbUSafwwovTiIsL3uRSpzr/5Pjde/2rqqq44PxzWLfuV8v2OfQwuO0OduknjGQC7AKwfSWwpAAiAokAOJfwSAGojgCUlqOfO0m587/iyvHMfOU1cf5AXIyXLg16/XVdZ/xVl7FqpYIOiy5djHa/qBBOiHQagUYA7C4ClBRARCARAGcii4AaY/NW9DGT4PtflJn0er088OAjXHb5lcpstgSnOn+j1z8GT4M786l33s6cN163bJ/UNHjoMUiy+Q7WbQQ6B8DuhUA1TS8EMjESPB7jeqagaERQiUQAnImpRUBpKWG8COjHdUabn0LnHx+fwKuz54jz34HXo9G1TSxRDd5DM2ZM44nHH7Fsn5gYeOhRaB+cSYquwmkLgZCFQJGACABnYq4A0HyOrllCvgho+afoIy+GTTnWbe0gMzOTDxYu4cQTRyiz2RKc6vw1Dbq2jiGuQa9/9pLFXDtpgmX7eDww9V44sKd1W+GIExcCNTYMKF0KAcMJEQDOJDwKAFXc/c96F33MRCgps25rB/vvfwBLl63iUJMtW2ZxqvMHo9c/sUGv/48//sBFF55PTSPh4IC55lo49jjrdsKZABcC5dvdCthYIaD5a4xEAByICABnYq4A0KYpgKZbAK0sAtJ19IeeQ598D9QEOCatGY497ngWLVlGx06dlNlsCU52/m3To3fr9d+8eTOnjz6Z4uIi6y9w9hg4/UzrdsKdgFsBZSGQYA0RAM7EUSmAoBcAVlWhX3EbPPy8uec3wZhzz+Ott98nJSW4C4qc7PwzEn1kNsjrlpaWcProk/ln40brL9CvP4yfaN1OJOCChUCSAggvRAA4k/BIAZhpAdxWjD76Knh7obnXbIS6hT7PPPsC0dHBbT1zsvNvrNe/urqa8887h++/+9b6C+x/ANx1n5H/F/aMCxYCSQogvJA2QGfiqEVAplMAgQ4BWr8R/ZyJ8Ntf5l6vEaKjo3nq6Wc5Z8y5ymy2FCc7/8Z6/QFuvOFali3Ntv4CbdsZ7X5BnKvgemQhkBBkRAA4E0cNAQrKIqC136GfNxnyt5l6rcZITExixsxXGTR4iDKbLcXJzr+pXv+HH7qfl196wfoLJCfDY09Cerp1W5GELAQSgowIAGfirD0AdtcAzF+KfuXtsL3S3Os0Qrt27Zj75rv0POhgZTZbipOdv9ej0S1z917/t9+ay3333m39BaKijNW+nTpbtxVhuGEhkEQAwgtJzjkTZ9UAFJhcttOSGoDnZ6NffLNS59/zoINZumyVOP/d7EHXNjHERu36sf/oo9Vccfkl1jcRahrcchv0OtyanUjFBQuBpAYgvJAIgDNxVhtggUnn3FwNgL8W/daH4aU55mw3wcBBg5n5ymskJgZ/1KyTnT9Ap4wYEmN37fX/9ddfGHP2GVRWKhBgl18FQ0+0bidSkYVAQpCRCIAzCY82wKYiAGXl6Bdcq9z5j71wHHPmvhMS5//ySy9wzYSrlDn/SVMeVOr826VFk9ag17+4uIgzRp9CYaGCuouTToHzx1q3E8m4YCGQpADCCxEAziMOY3lGQNi5CMh0CqCxGoCcPPSTL4PFq6wdqh51bX5PPf0MPl/wg1ovv/QC106eaD2Ezk7nf8rZFys4mUFGko82jbw3ptx8I+vX/2n9Bfr0hetvsm4n0nHBQqCMtGg8HlM7CBIwseBMsBdJATgPU6EyOxcBFRYrEgA//W6M9d24xfrBdhATE8Oz//cCo0M0ac7pzj85zkuHRqa3bd68mddff836C3TfB+65H7zePT9WaJ4A920UeBIxygatv/eaOJCxEMiz82/r9WqkJPvYVmjqmpABKJguJahCIgDOw1wBoE3h/4LCajWLgFauQR85TqnzT09P5715H4TM+c+YMY3rrr1GmfOfeMsDSp1/fIyXLm127/UHWL5sKdXVJoVdHa1aw8OPQXzAASuhMQJcCFSt+UKyEEgKAcMHEQDOIzwKAOvvAXh9HvrZE6C4VM2hgK5du7Fk6Qr69j1amc1AcHrOP9qn0bWRXv86LIf+ExLg0SehTaY1O8KuBDwMSBYCCeYRAeA8nDUDwPQioNSdC30mTIVqBRvldnDUUb3JXraS7t33UWYzEJwe9vd5YO9Gev0bvq75F/AZYf/u3c3bEBonwGhbKBYCSSFg+CA1AM7DUSkA0x0ASQno4++AuVlKz3PyKafx3PMvEReiEbNOd/4eTaNrZiwxUc1r+332sSCerr8Jevcx/3yhaWqAAD7KIZkFIK2AYYMIAOdhSiWnp9rTAVBgrtgHPvoCFDjJ+lx73Y3ccedd1u5eLeD0nD9A59bRJMTsObA3ZOgw4uLiqKioCOwFxl4Eo042eTphjwSYUcq3fSFQ450AJpEIgMOQFIDzMDkF0PSe7mbJzTNZA6DQ+Xu9Xh57/CnunHp3SJ2/k4f8ALRPjyYlvmWaPjk5hUsvuyKwFxg4GC4N8DlCYATaChiChUBSAxA+iABwHo4aAmR6FbAiEhISmf3Gm1x8yWUhO4PTC/7A6PVvnRxYFGjKlNs56qjeLXvwkUfB7XfSaEuBoA4XLASysHRMIgAOQwSA83DUHgDTNQAK2Guvvfhg4RKGhnC8rNNz/tB0r/+eiIuP58qZs9COH9D8A08cYaz2jbLnPSbsRK8JsAgwBAuBJAIQPkgNgPNwVBug6SmAFjnggAOZ++a7dOjYMSSvD+5w/s31+u+Jr2orGF9QhH7fg/DFWlgwD374HooKIT0Deh5k5PtDsFQpYnFaDYCkAMIaEQDOw2ERAHVb+lrK8QNO4JVZs0lOtjm/2QxuKPiL9ml0a6bXvzn+1qv5//buPM7Gsg3g+O85y8yZ3cwwm2UGUbQo7dvbJkURsm/Zksq+JKVQKJGilBJZKiprUWlFREkbshQz9i07g9me94+HwjlnZs4593OWcX0/n/m8XjPnvu/GzLnu516uq1nuVrL10xHn6muMDxFYnp4BMH0CIFsAJZlsAQSfoDoD4O8tgDZtHmLmrHkBD/7BfuDvzF1/mxfpn4+QT/OcrezV1eVmEIqEQEEgWQEoOWQFILiUnEJAHtI0jf5PPs2Apwb6pT93QiH4WyzFu+vvSi46bXK28ad+UumYhCLFzQS48nf0mZ+zcfWfXHP0CKXjNG6vaeehumGkJip8riukIJAXKcLPFATy8O6pMItMAIJLySkE5IHw8HBeHzeeps1amN5XYUIh+ANUKF28u/7n04FuuTtYXHBc+ZiEIvlFBNWDR9B7Pw/zvwUgB1h1+lMLf8xl6OQTvPhoBF0bOxQNSAoClWSyBRBcvDsAaNL+v9eFgDxQqlQ8s+fOl+BfTGUTwihVzLv+5xuWt5cZ+YcVj0goVVhBoMNH0R/s8m/wd+X4CZ1uo7N5doLCh2zZBiixZAUguFxQBwDT0zOYOXseVatebGo/RQmV4J8UZ3d51//UqVN88fkCfvrpR7Zv306ZMmWoceVVPPBAg3/PUkzLP8SovH3KxyQUi3CzkpeXj/7wk7B6Q7GaGTr5BP+70kataxVsDebnOUWKxPgw/sKrlSQ5CBhEZAIQXEpGIaBiuPrqa5nx0SySkpJM66M4QiX4x0XaSHNx1fPTT+fRr09Pdu3a5fS5J5/oy4CnBlLjsY70yd2pfExCMbuGlmYBF3MA/dnR8N2KYjel6zB44glFEwBZASipZAIQXIJqC2D/QXP2/+vXf4BJ704hMsB15N+dNFFp8H9qyEhatXtEwcjOFWazkFrK7nTX/41xr9OvXx+3VxWPHTvK00/1x776B/LGPCNZ/IKZBSP4W118bvonMGGGx00u+yOPXfsLfD8UKAWBSiyZAASXBG9elBiv/gbAkaN5jJvkY814F3r16sWoUaOwWAJ7/GTChAl066Yu+I8dO5auXbsqGFnxTJ8+vdDgf7bc6fPQrqgKnZr7YWTCY9rp4O8qmePyX9D7Dve66bWb832fAEhBoBJLDgEGlzLevEh1IaCdu09ye8NlfL1E3Z6x1Wpl7NixjB49OiiCf5cuXUI2+C9ZsoT27dt7lKRIf3E8nJCrf8FIS7JApIvVma070Nv1gxzvV+JyVKR6cLECIBOAkkEmAMEl4EmAVq87wg11vufX1epOi0dFRTF79my6deumrE1vhXrwz8zMpGHDhpw65eEBzcNH4aul5gxKeC/BAnEugv+xbPTWveDAIZ+az0hR8BbvIhugbAGUDDIBCC4BvQXw1eJ93FJvKdt2qrtClJKSwqJFi6hfv76yNr0V6sEfoF27dhw4cMCr1+qr1ysejfBJtIZW2kXwLyhAf3QgrNvkU/PpKRYuSXd1qMBDcg2wxJIJQHAJWCGgSR9s5b5WP3LkqLr0sNWrV2f58uVcc03gc8yXhOC/bNkylixZ4n0DxyUBW9BwaGiprt9+9SFj4IvFPnfRs5kDJbttsgVQYskEILj4/RqgrsPgkRvo2Os3cnN9D45n3HHHHSxbtoyMjAxlbXqrJAR/gAULFvj0ei1JHr6CQriGVtb1dT/Gvw9vvOdzFzdeZlOXDVC2AEosuQUQXLzbAvDyl/FUTgEdevzGB7PVZuZs2rQpU6ZMweFQlY7UeyUl+ANs3LjRtwZuqqlmIMJ79kKu+839En3Qqz53kVbawsfDorEpWP0HZAugBJMVgODh10JABw7lULvpcuXBv3v37syYMUOCf7C5/GK4rkagR3Fhs4JW1gqufl2XrUJ/fBD4+LMaEa4xd0Q0ZcuYWxAooVSYt2klzhQEEkFAJgDBw2+FgDZvyebm+5eyZPl+b7p0yWazMX78eMaMGYMWBAlnSmLwr1KlincvtNvQRge2yuIFzwJaOSu4enBe9zf6Q30gx7fMm5oGk56O4tpqihd2wxycX6DAZtMo5X0FUjkHECRkAhA8vPqliIr0bJ1vxaqD3FBnCev/OuZNdy7FxcXxxRdf8Mgj6rPgeaMkBn/A65sU2rB+cGV1xaMRxaZh7Pm7Stexcw968+7GNU0fDe4YQfNairOCWqyQcgmuDixEe1mUCpkABA2ZAAQPr1YAtu44wdvTthTra+d8tou7HvyBfQpz/JctW5ZFixZx1113KWvTFyU1+APceOONnn+fe3aA9o3NGZAomgZamtV1kZ8Dh9EbPwY79/jczYO3h/FMexNW1ktXBrvzzuTrEzN9uS4s5wCChEwAgkeUty/sOXANq9cdKfRrRo/fROOOP5N9It/bbpzUrFmTlStXcuWVVypr0xclOfif8c4775CWlla8L252P9pTj5k7IFEoLcXi+jf75Ckj0c9fWT73cVVVK1OeiVJf6iEuFWKci3X98sdh+g5e60vL0b68WKgjE4Dg4VVtTYATJ/Np9vAqjmc7B/f8fJ2uA1bTZ9BaCgqKnzq2KPfddx+LFy8mNTVVWZu+uBCCP0BGRgZvL/wMLq3q/ossFni8DdrYQVIAKIC0JAvEuPj+5xegd3kaVv7ucx8piRbmjYghyl0ZYW+FR0NiRae/PnI0j2adf+ZUjk+/Z77vdwglVF0UEb47CvTGy0nZPwdy2LnnJA3q/BeQj2fn06TTz7w3U+1J/0cffZSpU6cGxUl/uHCCP8DuvFxuse0lv2V9tIrl4MQJOJptfLJCGtS7C230QLRm9xcv+O9XNykU/9FKaxDv4ldZ19H7DINZX/jcR0S4xsJXYqheUfHbuNUGaZeB1fmQX9tuv/D9Cu8yUZ6WD/QDsn1pRKghjwfB5XPgXl8amPp6Tdo0Kcfuvae4v/WPrPrdt1ziZ7NYLIwYMYK+ffsqa9NXF1LwP5afz0WH1rJXV5etUd+obktInJagoZV2k+XvubHw2hSfu7BY4OOh0TS63YRS4CnVIcq5MOn4KVk8+sQfvrb+OVDX10aEGrICEFzWAR3xYWvmq8X7qFYlmiYdV7JO4Ul/h8PBBx98QKdOnZS16asLKfjn6Tq3Ht7A3wXqDnACsgKgWrwFzc0dfP3FN+HVd5V082rPSNrdp7YKKADx5Yy9//P8tuYwTTr9TF6+Tz8veUBLYJcvjQh1ZAIQXHZhpAm5zdsGcnIL+HDeTg4fUfeUWLp0aT7//HPuueceZW366kIK/rqu0/xIJt/kqZvQ/UsmAOqU0ox9f1fGvw/Dxinppl8rBwPbmXDiP6IUlKnitHV05GgetZutYM8+DytQOhsKTPe1EaGObAEEHxuwDLgu0AMBqFixEh/PmkuVKoUcOvOzKZMn0bNHV2XBv/uAF2nUwryVDbtVo0pqBGE2z3/dctFpmrOV7wpMCP7IFoAyhQX/dz5EH/CSkm6a3hXG9CHRaor8nM0eAWVrGPv/Z9F1aPrwz8z8dKevPawCbgSc8wqLgJFbAMEnD2gLmPOO74EbbriRbxctleDvSx8WjYrJDq+CP0D/3F2mBX+hSFwhwf/9uehPjVTSze017Ux91oTgb7FCSjWn4A8w9JWNKoL/caAFEvyDjkwAgtMGIKAXuBs2asy8Tz8nIcH5MFCghFzw1yCjTBiRYc6/ZmvXrqF3r+5ce3UN0sunUrliORo2uJ/33ptKzumUsCPy9jIp/6Bp4xMKlNLQkt28jc7+wjjxr/u+zXLFRVbmvBhNuNfZd93RIPliCHNO9rPgqz0MHrlBRSd9gL9UNCTUki2A4DYJaO/vTnv27MPg54YGRU7/M0It+AOUSwyndMz5S6o6zw0ZxJhXXyY/3/Xy+6WXXkbLSeN5plIEZu/QyxaADxIsxnU/V6Z/gt7zeZ+L+wBULmth6fhYUhJNeF5LSIf48k5//dfm41x37xIOHfb5oX0O0MjXRoQ5gucdXrgSBfwE+CWRu81mY9TLr9K+Q/Cc9IfQDP7JcWGkxjs/rvXs0ZV3J71T5Ou1pERYMAkyypkxvH/JBMBLfgr+SfEWlo6PoUp5E85rxyRBkvP23tFjedxY93vWbvA5X08WUBOQZawgJVsAwe040Aw/JM2Iiopm+oyZEvwVKBVlcxn8R418sVjBH0Dfux+9x3NKlo+FWlppzX3w/2CesuAfF62x8FWTgr8jFspc5PTXBQU6rR/7RUXwzwGaI8E/qMkEIPitAXqY2UFKSgqfff4lte/xKQeRcqEY/KMdFiqUdr6fPXvWxwx9fohnjf2wCn7yPV2sUEdLskBCIQf+eg1VEvwjHRrzR8ZwZRUTgr/NYRz605z/O54cuo5PFu5W0cuTwI8qGhLmUVw4WpjkHeAOjCQaSl162WXMmfMJ5cqZu9TsqXcnTVQa/J8aMpJW7cwtV2y3aqTGh2E57+Hw+++X0OWRTuhePM3rny9Cuz44ii1d0DSMw36xbp78p81B7ztcSfAPt8OcF6O5pYYJb88WO6Re6jLN7+QZ2xg57m8VvXwCvKqiIWEumQCEBguwT3Wjd999NzNnziQ2NlZ10z6ZMGEC3bo9XiKS/Kxfv57mzZpw6pSXSVQ2bVU7IOE5DbRUC0S7Cf4TPzLu+SvYrrHb4KOh0dS+Tvlxf+OJP+USCHNOIrT0xwN06adktelv4CEw/fyqUEC2AIKfA5iB4m2ADh06sGDBgqAM/iUlw9+ePXuoW7cuBw/KNmjIsoBWtpDgP3Yy+pMjlAR/qwWmPhtN/VtNyO8PULoSRMQ5/XXm1mwatf/J1wp/YJxVehBQV4BEmEomAMGtNPAN0ERVg5qm8fzzzzNx4kTsdhOeMnxQkoJ/dnY29evXJzMz07eGKldQMyDhOSto5a0Q6SL46zr6oFfQn39NSVeaBm/1j6J5LZOCf0IFiE1x+usjR/Oo3+ZH9u1XUmOiM+BztSDhP7IFELyqAJ8Bzkd1vRQeHs7EiRNp1aqVqiaVKUnBv6CggFatWvHTTz/53JZW6xYFIxIes2lo5TRwFY/zC9D7DoP35irpStPgjb5RdKxnQnEfMAJ/vPNEMje3gMYdV7Jmvc8n/gFeA95X0ZDwH5kABKebgbkYKwBKxMfHM2fOHG67zes6Q6YpScEfoHfv3sydqyA4XHsF3HKN7+0Iz4RrxrK/q3fH3Dz0x56BuV8q6UrTYGyvSLo0NCn4RyZC6cpOf63r0Kn373y1WMnRomUY2f5EiJEJQPBpAkzF2PtXomLFiixYsIBq1aqpalKZkhb8x44dy5gxY3xvKCYK7bXBvrcjPBOpoaVZXG+OZp9A79gfvl6mpCtNg9f7RPFYI5OCvyMGUi52qu4H8OyI9Uz9aJuKXnZivGdJnv8QJAZCXA0AACAASURBVGcAgksPjAN/yoL/tddey/LlyyX4+8GCBQvo3bu37w3ZrGgTR0DldN/bEsUXe/rJ39W74sEj6I0fVxr8x/aKNC/4h0VCanWXd/3feX8LQ1/ZqKKXkxhpfnepaEz4n0wAgoMVeB3j7qyyf5MGDRqwaNEikpOTVTWpTEkL/qtWraJZs2Zu8/t7Qhv+BNxxo4JRiWJL1NBSLK6To2/biV63HaxUk5TpzJN/18bK5vnnsoUZd/0tzod8P/t6D48+oeScng50RJL9hDTZAgi8KIyn/vtVNvrY410ZMWIkmsXKiZPBtTr37qSJSu/5PzVkJHc90I5128wtm2u1aKSWCsN2XnK2LVu2ULfufRw/ftz3Tnp2gPaNfW9HFE9RCX7W/Y3erBvs2qumO7OX/S12SLsMbM7t//zbIZp1XkVenpIr+kOBD1Q0JAJHigEFVhowH7hKVYNWq5Vhw0fw6GOBexouTCim9wWwaBpVUh1EnFfa99Chg9SudQcbNqz3vZNG96KNH+pyz9YsF3QxIKtmJPhxroRr+H4l+kN94KiCiR3/nfY37cCfxQqpl4Mj2ulTf2ce55Z6S9mzz8uEVOeaDTRGkv2EPFkBCJzLgAWAsoveDoeD8W+9Q8NGwfkEGarBX9OgYlK4U/DPzc2lbZuWaoL/DVehvTbIr8H/gmYHrayba34As75A7z4YctSsntms8O7AaFrfY9I9f80CKdVdBv8du05Su+lyVcH/N6AtEvxLBJkABMZdwCzAOS2XlxISEpj+4SxuuCE4945DNfgDlE8MJybi3HV/Xdfp1rULixd953sHGeXQJo+EMJOCgzhX5Oknf3d1dsZMRh/2urJKjOF2+HBoNA+YleEPi1Hcx0WWv38O5FC76XIytyopKLobqI9RpVSUADIB8L/2wFuAsjR8VatezMzZ80hPz1DVpFJTJk+iR/fHvSqGcz5/B/+UUnYSop1/TYYPe57pHyjIe1I6AW3mG5AY73tbomhxmlHRz9VCS04uep9hMONTZd1FRWjMfsGk3P5grBglVYVI55+fo8fyqNtiBX9uVJLo5wTQEFByd1AEB5kA+I8GDDr9ocz119/A9A9nkZiYqLJZZUI5+CdG20gp5fzU9t57U3lpxHDfO3CEo019GdLL+t6WKFxRh/0OHEbv0A+WrVLWZalojQUvx3DT5Wa9zWqQVAWinfOF5ZzO8rfyNyVp+QuA1sAKFY2J4CETAP8IAyZi/BIp06Dhg7z19kQcDpOuE/kolIN/tMNKuUTnw1pLv19Crx4KDlhaLGhvDjWy/QlzWTGS+0S4Cf6bt6K37AmbtijrMjnBwsJXY6hxkbt9BgXKVILoJKe/zs/XadllFV8uUlZAtBfGwT9RwkgeAPPFAwtRHPy7PPo4706eJsHfBBFhFiomhTudx1u/fh0tWzQlJ8f3winakJ5w/50+tyOKEKGhpRcS/Bf9iF67rdLgXyHZwpI3TA7+pStBbKrTX+s6dO77O7PmK8vN8xIwVlVjIrjICoC5KmKc9FeWhs9ut/PKmNdp0+YhVU0qF8rBP8ymUSnJgdVybsDYtWsXDzaqz+HDCpZUOzWDLsFXkKnEKWy/H+CdD9GfeRny1F2FvLSilc9Hx1A+2cRnq4R0iEtz+akeA1cz6YOtqnqaATypqjERfGQCYJ5rgU8BZWn4oqKimTzlPWrfc6+qJpUL5eBv0Yzgb7edGzFOZGfTqkVTtm9TcP6p1s1oz0vdFFMVtd+fk4M+YCRMVbuq/b8rbcwdEUN8jIlXOUtXchv8nxq+jtfe8bH89H+WAO2Q634lmkwAzPEARpYsdylGPJaamspHH8/hihpXqmpSuVAO/mfu+jvOu+ufn59Pxw4PsWrVSt87ueIStHdexCmVoFDHfjqfv7sbd7v2ond4An5erbTbhreF8f7gKCLCTQz+ie6D/9PD1/HCmL9U9fQn0ABQkjhABC85A6BeZ2AmCoP/pZdexjfffi/B30Su7voD9H+iDwsWKLgWlpaMNm00RCn7sRDni9bQKhQS/H/8Db1Wa+XBv3sTBzOHRZsb/EtXhlKug//AF9YzXF3w3wnUBQ6qalAEL5kAqGMBXsG4469sZeXu2vfw5dffUbZcOVVNKhfqwT813vVd/zFjRjPh7fG+dxAXg/bha5AWfEWZSgQNtDIW46S/u8WVqbPRGz4Ce/er61aDQR0jGNMrEouZ76SlK0Oc84E/MJ78h72qpLIfGEG/DqDuRKQIarIFoIYDmAI0Vdlo27btGP3qa9jtJiURUSDUg39itI3kOOdHxrlzZjH42YG+d2C3GaV9L6nse1vCmR20VKv7AtqnctD7Dlea3AcgzA7vPh1Ny9omZ28sJPg/O0Lpk382RpY/JaUCRWiQCYDvEoF5wM2qGtQ0jf5PPs2ApxQEIBOFevCPjXB913/VqpV06fKw72mLNQ1t9DNw2/W+tSNci9aMw37unvq37EB/qC+sVfaEDBgJfma9EM2dV5s8MS8k+A96aQPPj1b235UDPAgsVdWgCA0yAfDNRcBnQBVVDYaHhzPujbdo0rS5qiZNEerBPyLMQnoZ57v+WVmZNGvSiBPZCnKn9+sMzZVWeRYAFmPJn7hC9tw/W4TeYwgcOqK06yrlrXw6MpqLK5h4kFPToEwViHFO8gMweOQGnnt5g6re8oFWwBeqGhShQyYA3rsW45cmQVWDwV7Q54xQD/7u7vrv37+fRg3qsW+fggxqze9H6/uw7+2Iczk0tFQN7IVc8Rs8Bt75UFkxnzNurWFj1gsxlCll4mE/zQJJF0O069Tez728gSGjlAX/AuAhjEPL4gIkEwDvlEVx8K9UqTIzZ8+jcuWLVDVpilAP/u7u+p88eZKWzRuzadPfvndy67VoLw+U0r6qldKMJ39339ZNW9AfHgCrlQXIfz1cP5xxfaOwm/mOqVkgtTpElHL6lK7Dk0P/5KXXFfx8nm4S6AooqGglQpVMALwzAoXB/7rrrmf6h7MoXdq5qEcwCfXg7+6uf0FBAV0e6cSKFct97+SSymjvjjROiQk17KcT+0QWMqH6cD56/xFwXEnZ239ZLTCsSyT9W5uccttiN4K/I8bpUwUFOl0HrObNyVkqexwAvKmyQRF6ZALguUQUnvZ/oEEj3np7IhEREaqaNEWoB39wf9d/yKBnmDNbwSpoUiLaB2MgzvlNXHgpWkNL1sDqJvifPIX+3FiYMEN51zGRGh8Mieb+m02ezNnCIPVSCIty+lRenk77Hr/y3sztKnt8AeMhRlzgZALguRsAJe8I3Xv0Yshzw7CYeonYdyUh+KfFh7m86z9p4gReffVl3zuIjDCCf3nXp7aFh6ynn/qjC3nqX78JvfMAWLdJefeVy1r45KUYqlc0OWujzQFpl4Ld+QHgVE4BLR5ZxZzPlBX2ARgHPKWyQRG6ZALguUt8bcBqtTLipZd5uHMXFeMx1aSJE+jdq7uy4N/zqRE0aN5RwciKLzHaRlKc85ztqy8X0q9vL987sJ4u7VtDWc2nC1tR1/sKCuDN99FfeANO+V6Z8Xz33WRn2qBoc3P6A4RFQuplxgrAebJP5NOo/UoWfrdXZY8TgO4qGxShTSYAnqvoy4sjI6OYNHkqdercp2o8pvn2m6/p26dnSAf/2EjXd/3Xrl1Dh/ZtycvL87kPbWgfqHu7z+1c8KwaWpIGhQXebTvRuw2GZauUd69p8EQrB8O7mJzZD8ARCynVwer8FnzseB4PtP2Jb5f+o7LHt4EuSHEfcRaZAHiukrcvTElJ4cOPZnPlVTVVjscUubm59Ondg/x830ulnln293fwjwi3kuHirv/OnTtp/OADHDly2PdOHmsNnYI7Z0NIiD19wr+wFXeTDvoBJMRqvD84mntv8MPhzahESL7YOPV/noOHcqnTYgU//qI0Ff9bwKNI8BfnkQmA57xaAahWrTozZ82jXPnyqsdjim+++YrNm33fWw3Unr9x1z8cy3nR/8iRwzRuVJ+dO3b43sn9d6IN6uF7Oxey4pzw37sfvfdQWLjElCFcWcXKrBdiqJTmh7M4pdIgsSKu7jLu3H2Su5ss58+NR1X2OBboiQR/4YJMADxjATK8eeGkydNCJvgD/LDU96yggVr2t1o0KiY5sJ93cjw3N5e2bVqydu0a3zu55nJj3z/ID3AGLQ2It6Alau7v9QN88jV6v+FwQMFqjQut7wnjrf5RRDpM3u/XtNPlfF0fEl274Sh1W6xg644TKnt9FeiNBH/hhkwAPJOK+7IjbmmaRsUMn44O+N2+f3w7fBSo4K9pULFMOBFhzoH5iX69+e7bb3zvpEIa2tTR4HA+WyCKIeL0Xn9h5XMPHELv+wJ8+rUpQwi3w5heUTzSwA//hharseQf6Tp1yHfL/qFR+5UcOpyrstfRQB+VDYqSRx5fPOPV/n9KSgoRkaFVBz4mJtbr1wZqzx+gQqKDaBd3/V8aMZxJEyf43H5CqTBen1GXxNLBnbchKFk1tCQLWnmL++Cv68Ze/02NTQv+ldIsfD8+1j/B3xYGaVe4Df4zP91J3RYrVAf/l5HgL4pBJgCe8WoCkBFiT/8ANa68yqvXBWrPHyA1IYz4aOfgP2vmRwwf9rzP7YfZLXw88Roer7yXX/Xx3IP6++clVpwFLcMCheXRz9qO3qwretdBsF/pIbh/Nb4jjJ/fjePaan5Y/AyLgrI1INw5wQ/AmAmbadZ5FSdP+Vh18lyjgL4qGxQll0wAPONVJE/PyFA8DPPVrXsf0dGeZbQ7s+wfiOCfGGMjOdb5BPfSpd/zaJeHfb7KqGkw+bWruPMWI11zOY7wecF7fFjwMfEo3bctWSJAK285nc3Pzdfk5sHYyei3NIHvVpgzjHCNV3tG8vEwP9zvByOff9nLwea8ypCfr/NY/z/oOXANBQVKt+dfAPqpbFCUbDIB8IyXKwBe3xwMmPj4BPr1f7LYXx+oPX+A2Agr5RKc32g3btxAqxZNOXXqlM99DBtQjRYNyzr9fRP+ZE3BG9TT1dacD3l20FI0tPJWiCgk4P74G/qdLdGff82UpD4Al1Wy8tPEWHo0NTmf/xmxKUZqX4vzKsPx7HwatlupOq+/DgxBMvwJD8kEwDPerQCkZygehn/06NGb+x5oUuTXWa02ej8zKiDBPzLcSkaS813//fv306xJIw4d8n0puWPLCgzoUcXt51M5xjx9OpP1ucRgThALGRqQqKFlWCG2kLeXw0fRnxqJXv9hWG/OVoqmQfcmDn5+N47LKpmc0vdMhwkZUOYil5Ug9x/MoXbT5Xz65W6VveZjJPgZrLJRcWHww29FiTIU8LjSS9duPShfvoIJwzHXjgM5XHlzHRyOCNat+YXcHOfgViHjIp4dOYE7aj/g9/GF2TQqpziwWc59sz1x4gSNGtyv5LrfPXck8cH4q7FYil42rsEeWrKGtSSxWYv3uW+/2K9wCTpaQytrRYsu5GqfrsPMz9Fb94LvVxr/3wRJ8RY+GhpN9yYObP54lztTzS8myeWnN2Ud545GP/D72iMqez0FtAKmqWxUXDikYHnxRQDH8eJ7tm7DZtLS0tSPyETb95/in6P/pck9cvggPyxayMZ1v3P82BESEpO56rpbuPqG/2F1kc7UbFaLRtVUB+H2c58y8/Pzadu6BfPnf+JzHzUujWXJvFuIjfHsv09HY4JWk35abY7inOf9X6s3wKIV6Ft3giMc7bKqcPetkBDn48g9GOtG3zM9EgVaogWKuku/ag36wFHw82rf+yxE7evsTH4mitREPy1whkdDyiVGYR8Xvl36D007/cz+g0pXh44ADwCLVDYqLiwyASi+asCfnr7I4XCwa8+BoK/4d7bzg3+wsWgalVIcRIc7f0+f7N+XN9943ec+0lIcrPjsVsqX9f66Xxal6KHV4VOt6rmf2JiJ3nc4LP/F+UURDmjXGK13Ryjl/VXM4vJpAhChGYl8CsviB7BzD/rQ12Hm56Y98QNER2iM7BrJIw2ct4TM67QMJFVxmdYX4O1pW+g6YDW5uUpP+u8B6gIufoCEKD6ZABTffcB8T19UterFrFz1uwnDMUewB3+A9NLhxLso7fvGuNcY8KTvh6Bjom0smXczV16m5kn8U60q3anDFq0U/PQ7eovucORY4S+Kj0Xr2xnaNwG7eSssXk0Awk8/8RdWqhfgxEkYNw39tSmQbe5Nidtr2pn0VBQV/ZHOF4w9/vh0iC/n8tOncgp4vP8fTPxgq+qes4B7ADl1KnwmE4Di64aRV9sjte+5l49nzjVhOOqFQvBPiw9zWdp34cLPadGssc/Fi6xWjTmTr6Ve7RSf2jlfNnYGH6jBqNvHou/xoMpb5XS0Qd2hzu1Kx3OGRxOAMA0tgcIP94HxlD9nIfpzY2HHHp/GV5RIh8aLj0bQtbHDf0/9FjukXGxc9XNh3/4cmnRayeIf9qvu+U+M4L9ddcPiwiSpgIvPqxsAoZIEKBSCf2KMzWXw//WXVbRr21pJ5cKxwy5XHvwBIsmF16d6FvwBNm1Bb9sHbrkG7bnecPnFysdWJDtoCRaILSJvP8Cva9GffhlWmr/qdUsNG+8+HcVF5fx4ljk8ClKqud3v/3X1YRq2+4kt25WvePyEseyvfFYhLlwyASi+EnsFcPv+nKAP/u7u+m/duoWmTRqSnX3c5z4G9KjCY+0zfG7HFV2HyTN8WA5e+jN6rdbQsDZa/y5Q0Q+FpcJBi9cgxlJ04N+wGX3EWzD/G1P3+cFI6jO0cwQ9mzn8W4upiP3+GXN30LHnb2SfUHCw8lxfAw2BIvaNhPCMTACKz6tsPsGeBdAI/krzkCvn7q7/oUMHadzoAfbu9a1wEUDzBmUZNqCaz+24k7Utm337fTwFXlAAs75A/+RraFEfrU8nSEtWM8CzOTS0UhS91A+QuQ195Nsw6wtjfCa78TIb7w6M4uIKfnzq1zSjhG+c65s8+fk6Tw79k1FvmJLPYDLQGQjuX1IRkmQCUHxerQAEcxXAUAj+YTaNiknhWM6L/mdK+27YsN7nPm65PoF3x15l6h7y0WMKV1hy82DqbPQP50OHpmg92kGigrwDjtNL/UUd7gPYvhv95Qkw41PIU/7E66RUtMawLpF0aRDu36f+sAhIusRtPv8jR/No/dgvqpP7gJHd7zmMDH9SzleYQg4BFk8ZwKvHzB279nmcU98fth/I4Z8jwR38bRaokhrhdNdf13U6P9yejz6c4XMfVStH88OCW0iML+S+vgJ7/zlF8qULzWk8OhIeaYn2SCuI9+zqoL4xH6JOX+cr6h4/wJ5/0F+dBFPngIvEUGZoWTuMl7tFkuKve/1nxJSB0hcZ5Xxd+HPjURq2W8nGTcpX5k8BHYAPVDcsxNlkAlA81wMeVykpXbo0mzKD78BuKAR/i2Zk+Ytycdd/6PNDGPnSCz73kRgfxvLPbqVKJddPd6pdfNO3ZgSL/0RHQvsmaI+1htKuy886ydPBVoy3gQOH0MdOhkkfG9f7/KBqBStv9I3krmucD36aymKF0pXdZvUDeH/Wdrr0+4Njx5WfnTkANAIWq25YiPOFTnaawPJu/z89+Jb/QyH4A6SXCXMZ/KdNm6Ik+DvCLXwy7Tq/BX+AR9qmm9vBsWx4bQp6zXroT4+CXcVYtCoq+G/bhT7wZfSa9WDcNL8Ef0eYxpBOEfwxLc7/wT8s0ijh6yb4n8opoMfANbR+7Bczgv9m4GYk+As/kTMAxZPh1YsqBtcEIFSCf9mEMOIinX80v/v2G3r16Opz+xaLxntvXM1N1xbzKVmRrh0rMu3j7fy25rC5HZ04CW9PR588C1rWR+vaFtKdKxkWas0G9HHTYO6XftnjP6P2dXbG9Y3079W+M2LKQBn3p/w3b8mmSaeV/PKHKf9+i4HGgIf3RIXwnqwAFI+XKwAZiofhvVAJ/qVjbJSJdX7qW7t2DW1atyA31/f/hpeerc6D96f63I6nwuwWPvvgei692E9nQnJyYPJM9OsboHfoDyv/KPo1i39Eb/o4+h0tjdS9fgr+aaUtTH8umoWvxvg/+FusRmKfpIvdBv95X+zm6rsXmxX83wbuRoK/8DOZABSPVxOAYFkBCJXgHxdhpayLu/67d++maZOGHD3qeyW1h1un0+fRyj63463UZAc/LfwfPTtXwm73069ffgF8+jV63fbodTsYd/Xzz7qyl5cPs79Av7MleuPH4DuPj7t4LdKh8Uz7CDZ8GEfzWuYexHTJEQvla0JUGZefPrPk37DdTxw6rPx3KB94EngEueYnAkAOARZPJl5sA3w6/wv+d9vtygfjiVAJ/pHhVqokh6OdV3b3+PFj3HtPLf74/Tef+6hbK5l5U67DVpxDb36wcdMx+j//J3M/V36FrGjpZdG6tAQd9Dffh207/dq9xQJt7g1naOcIyiUF4DlE06BUWYiv4Papf8Pfx2jRZRW/rjblqf8I0BJYYEbjQhRHcLwTBjc7kI0X5yX+WLM+oNsAOw7ksC8Egn+4TaNKagQ267k/jnl5ebRo3pgvF37hcx9X1yjFojk3ER0VfMdeVqw6SO9n17D854OBHopf3HCpjdE9IrnxsgD9W9gjIbmqUcbXjSkfbqPrgNVmHPQD2ADURwr6iACTLYCilceL4G+32ylb1nWlMH8IleBvs0ClZIdT8Afo17eXkuAPUL1qNFYXfQSDG66OZ9n8W/lowjVklI8M9HBMU6W8lY+GRrN8Qmzggn9sCpS/0m3wP3rMSOzTrvuvZgX/TzCuFUvwFwEXnO+IweVu4EtPX1SxYiV+++NPE4ZTtFAJ/haLRuVk13f9X31lFIOeHai0v0uqRPPeuJpcXcN1FbdgkH0in5ff3MTIcX+rzR4YQIlxGoM6RNClocPMysaFszmMPP4R7ks8r1h1kLZdf+Gvzb7XlXBBB14CngLMz5ksRDEE4K5NyKkF1PP0RVfVrEnzFq1MGE7hdh4MjeAPkF4mnNgI5x/BuXNm0atnd3TFRWX+OZDDpOlbKSiAW29IxGIJvvmv3W7hthsTebiNkTPgtzWHyc0LzUywkQ6Nns0cfDQ0htuusmMN1HpjbIpRwS8swuWn8/J0nnt5I+26/8o/B0zJbngEaA6MQ9L6iiAiE4CiNQZu8fRFt99+J3Xq3GfCcNzbeTCHvepPKpuibEIYidHO1/1WrVpJyxZNyTUpzWxBASz+YT9fLtrH7TeVJsHkFMDeioywcvdtZejcJgOLBVb9foi8/NCIHeF26FgvnNkvRtPotjAiwgM00bI5jMAfl+b2oN+6v45yX6sfmT5nh1lFDH8H7sSLTKJCmE3OABTNuyuAfq4CGErBPynO7vKu/6ZNf9PkwQacyM42fQwrVh3k6rsXM3nGNtP78kWZxDBeHFidjcvvonOb9KC5weBKuB06PxDO5lmleKt/FKn+zt1/ttgUKH+V2yV/XYcxEzZzda0lrPr9kFmjeA+4CSPDnxBBJ3jfTYLHT8C1nr5o8pT3aNiosQnDcRZKwb9UlI2MMs53/ffv30+tO//H5s2mlFQt1IP3p/LWqBqmFwRS4e/M4wwZtYEZc3eQFyRbAxHhGp0fCKd/G0dggz4YJ/yTLjLu97uRtS2bjj1/49ulpuXdOQn0wEjwI0TQkglA0f4BEj190aLFy7iq5tUmDOdcoRT8I8OsVElxvut/8uRJHqhXhxUrlgdoZJBcJpyXnq1O26blAzYGT2Rty+aVtzYzYdoWTpz0X6res4XZoV3dcJ7tEEHZMgEO/JoFSpWD+HJul/t1HSa8t4W+g9eaecDyL6Ap4HviCiFMJhOAwsUCXmUBydq6k/h4c3PNh1LwN+76R2I779SJrus83Kk9H3/ke2lfFe6/O5k3X7qCcmmuD4wFm527T/Lym5t4e9oWs66tOXGE/ffEn1Y6CHYRI+KMsr1uDvmBMWHq1Os3vvne1Gy7czDK+Jq2pyCESjIBKNxVwC+evig2No5tO/aYMJz/7DyYy97D/qnH7iubBaqkRRBucw4Wzw58ijFjRgdgVO6VirMz4pnqPNw6HS1EfkOOHM3jzclZvPT63xw4ZM7PRWyURru64TzR2hH4J34Aix0S0439fjfOPPX3GbTWzAnSKaA/MMasDoQwQ4i8vQVMI2CWpy+6/IoaLF32ownDMYRS8C/srv/Ed96md6/uARhV8dS+vQxvjaoRUsl5jh7LY8J7W3jtnUyytqk5TJmeYqFXcwcd64UTHREEbxmaZgT9+HSwuk8ssP6vYzzS73eWLN9v5mj+wrji5/GDghCBFgS/zUGtDzDK0xfVq9+A9943Z0k7lIK/pkFGmXCXpX0XLvycls2bkJfn81NZPkZiFVMKx0dH2Rj+VDUe75ARlHkD3MnP15n7+W7GTNjM9yu8C4DXVbfRs5mDJneGOW3dBEx4NJSpDOHuKyqeyinghTF/8eLYvziVY2rOnUkYh/2OmdmJEGYJgnW8oObVFcCKJlUB3BVCwR8gLT7MZfD//bdfaf9QGxXBH6A3xlWrDSoaO9+x43l0f3o1t9Zfxu9rfa9G6C9Wq8aD96eyZN7N/PrNbXRuk06Eo+gobrdBkzvD+GpMDD++E0uLu4Mk+NvCIKkqlLuy0OC/6Id/qHHHIoaM2mBm8D8INAE6IsFfhLDQeaQJjM+Bez190ehXxtKxU2elA9l1MJc9IRT8k2PtpCY4X6vbuXMnd915Kzt37FDRzatAr9N/jgBeBLph0s+1xaLRqVUFXnq2OnEu8hgEu917T/Hm5CwmvLeFXXtOnvO51EQLneqH82ij8MBf5TuHBUqlGlX7LO5nIgcP5fLk0D+Z8N4WsxL6nLEcaIVRIVSIkCYTgMKtBy729EWzZn9CrbtrKxtEqAV/d3f9jxw5zD1338mff65V0c1c4EGc86rXA94BklR04kpKUjgjB11KqwfLhcwhwbMVFOj8uvowGzcfhz0bqFrewlVVtNAL7gAADmBJREFUbViCKe4DRCZA6Upgd7j9koICnXdnbOPJ5/80K43vGbnAIGAEkstflBAh+PblNxaMMsDOkawIq35dzUUXVVEyiFAL/tEOC5WSHVjOi4y5ubk0fvABFn33rYpufgLuwPj3cSUZY3+2rorO3PnfjYm8/sLlXF7NfdKZoLdpaaBH4MwRDQkVCy3cA7Dyt0N0fXI1P/1qehnl9UBbYKXZHQnhT8E25w8mZfEi+FssFsqXr6BkAKEW/B12CxWTnIM/wBP9eqsK/pkYtdQLO+K+B7gPeAgwpbQbwJLl+6lZazE9Bq7hyNGSUbkvoGzhUOYiKFuj0OB/4FAOPQau4ca635sd/HWMbH7XIMFflEAyAXDPq5N8qWlphId7PG9wEmrB32aFisnhWF2clH9pxHAmTZygopsDGE/1xU2yMBUjjbNpV7Ty8nTGTtjMJTd/y9SPtlFQEBzpeUOKxQ6JGVDhmtN3+l0vTObn64yblMlF13/D2AmbyTe3ONJm4HbgEUycRAoRSDIBcM+rCUDFDN9vAIRa8NcsGhWTXCf6+XDGdIYPe15FN6cw8jKs9/B164AbgSGAad/UXXtO8lC3X7n2niV8t8zUbHMlh2YxUvdWuNpI41vIgYqvFu+jZq3FdB2wmoOHTM1+qQPjgRrAEjM7EiLQZALgnpdVAH2bAIRc8Ncgo3SYy0Q/y5YtpVvXLui+H8vWgYeBxV6+PgcYDFyNcX7ANL/8cZg7G/3A3U2Ws3pd6Fwb9CvNYjzpV7gGEjKKTObT9OGfqd10OX/8afr3cxfG9tKjyPU+cQGQCYB7XkXydB/KAIda8Acom+D6rv+GDetp2bwJp06dUtHNM8A0Be2sAW7GSNt6QkF7bn29xHhiffzJP9i3P7T+TU2jaRCTZDzxl7nIuNvvxp59p+jS7w8uv/07Pv5kp9kj04G3gGrAfLM7EyJYyATAPa9WANLTvVsBCMXgnxQXRukY5/vwe/fupXGjBzh0SMkBrYnAMBUNnZYHvARcCXyvsF3njvJ03ng3iyo3fMOLY//i5KkL9PaYZoGYMlCuppHMx+b+jMyJk/kMH/MXVW74hremZvmj5PF64DagC14W/hIiVMkEwD3vtgC8yAK461DoBf9SUTbS4p2D/4nsbJo1bcTWrVtUdPMlxnKsGTZiHPLqisnLvYeP5DJg2DouvvEbJn2w1R9BLTicCfzla0LSxYVW68vNLWD8FGOy9PTwdWaW6z0jB3geP0wEhQhWkgfAtQiMk78ef382/r2F5OTkYn/9rkO57DGpeptZjLv+EZx/4L+goIC2rVvw6afzVHSzFrgF/5RWTQPexNj/NV1G+UgG9KhChxYVsNkC/CtoSh4AC8QkGtn77IWXVS4o0Jk1fxdPv7COvzb77bD9LxhnSqSAj7igyQTAteoYAcgjEZGR7Nq9H62Y6eFCadnfbtUIs2k47BbSEsJcXvfr/0Qfxr85TkV3OzBO7m9T0ZgHWgEjgVR/dFatSgyD+lWlSb20wBUaUjkBsNggLgVi0wrd3z9j3he7GfjCOtasP6puDIU7AgwExiHZ/ISQCYAb9+HFYaBq1aqz4qfiPVTsPpTL7iB68rdoYLNqhNsthNk0wm1n/lcjPMziMrnP2d4Y9xoDnuynYihHgf8Bv6lozAuxGFcGuwLuj6crdHm1WIY8cTEN6qT6P7WwigmA1Q6xqRCXVuiJ/jO+XLSPZ0es58dfTM/gd4YOfAD0wzjpL4TAT29wIcjUK4CBCv5Wi0aY3UK4TTs3yJ8O+t6aP/8Tnn6qv4oh5gHNCFzwB+MpsRdGKuFxwK1md7h63REatV9JzSviGPLEJdxXKzk0agyERUFcKsQkF3qHH0DXYcHXexg6eqM/Az8YK3mP4/0VUiFKLJkAuGbaAUAzg//ZAd5u1f5dtg8/HeTNWGb+9ZdVPNyxPQUFSlZUe2BUYAwGqzFWIpoAr2HUFzDVL38cpl7rH7m8Wix9H6tMy0blAn9GwIkGkaWMp/3I+CK/Wtdh/le7ef7ljaz8zR/HOf51HBgFDMfEBFBChDKZALjmXQ6A9IxCP+9r8Nc0Yy/e1TJ9mN3icl/eTFu2ZNG0SUOys5Uc3noReENFQ4p9jHEb4TngMfzwO7N63REe6vYrg17aQM9HKtG5TToRDvelcP3CYoXoMlAqDeyRRX55QYHOgq/3MHjkBn75w++36+ZjPPVv9XfHQoSSYHu8CBZ/AJd7+qIZH82iTp37XH6uuMG/sGV6u1ULiqXh7OzjbPr7bzq0b8vGjRtUNPkh0AJjrzaYXYmxGnCLPztNSQqnx8OVeLRdBnGxzlcvfVLUGYCwCGN/PzbFuNZXhOwT+UyesY1X3trE35l+T6H/K9AbWOTvjoUIRUEQToLSUSDa0xet+OkXqlWr7vT3Zwd/Xw/b+cuhQwfJyswkK8v4yDzz58xMtmzJUpHe94ylwN3ASVUN+kEt4FXgUn92GhNto32LCjzx+EWUTXWoadTVBEDTjKf9mOQiS/KesW9/DuMmZTJuUib/HPD7ivtOjIObE4F8f3cuRKgKjmgTXJIofrW5f2maxq7d+4mIPHd5NDdf59iJfMJOB3y7NTi+5SdOnGDPnt3/BvnMs4L9hg3rOZFdWLVdZTZhXPfb54/OFLMD7TGSyST5s+Mwu4UH6qTQ65HK3HhN0fvwhTp7AmCPNFL1xiUbFfqK4e/M47w2MZMJ07Zw4qTfY282xorMMIxJuxDCA8ERjYLL9cAKT1+UnJzMxr+VZL9TIicnh+3bt/0b4LdkZZGZ9d+fFaXp9cU+4Cbg70APxEelgKeAboCix/Liu/m6BLp1qkijuqnY7V4k9sxcfvppPwkcscV6ia4b1flen5jJgq/3BKIEcgHwPsb3fbu/OxeipJAJgLMWGHeGPXLdddfz1Tf+vWm0b9++0wH9v+X5rC1ZZGVlsnPHDvLzg3Y19ARwF7A80ANRKAPjxHlzAvB7VTbVQZeHMujcJp2k0u5z7TvRC4q1tw9w6HAukz/cxpuTs9i4KWDF8r4DngB+DtQAhCgpZALg7GlgqKcvatqsORPemax0ICdPnjQC/Jasc57kzyzZKzp9728FGHf9ZwZ6ICa5FuP62f8C0Xl4mIVmDcrSrWNFrrmylJI2f119mDfezeKD2dvJPhGwSeXPGE/8XwVqAEKUNHIN0JlXVwAzMjxPHaDrOrt27TrncF1W1uZ//7xrV4lMWvYEJTf4A6zEqC5XBxgMXOfPzk/lFDD1o21M/WgbNa+Io2PLdFo2KkupOM9uD2SfyGfmpzsZPyWL5T8HdLtoHUY56NkE/y0RIUKKrAA4+xa4w9MXjXvzbVq3buv09ydPnmT37l0uD9v9tXEjx48HbCk1ECYAnQM9CD+rBbwAXBOoAYSHWah/bwqd26Rz161lCr1Kuur3Q0z9eDvvfbydA4FNVb0NYyVuEkaGSCGEYjIBcJaJsZ/rkcFDnichsfR/T/KZmWRlbWb//v3qRxia5gMNuDCvaWnAAxhX1a4I5EAuqhhFhxYVeKhZedJSjDOLu/eeYtrH23h3+jbW/RXww/S7MSZMbwGnAjwWIcQFxI7xtKHLh9KPn/Eir0IJpAGNgTUE+N/EZtP0erVT9Pr3pOg2mxbonw8dI2tfN4xS3EII4XeVCfwbYUn7yMJP5XVDiAXjtsCfBP7fJ9AfmzC2hYquHyyEECaqTeDfEEvSx2ECvOQd5CxAPeAHAv9v5e+PM4FfDiILIYLCIwT+jbGkfOzHSKokiuc2YAHGNclA/9uZ+fE7xuqHF1mLhBDCPC8S+DfIUP/IAaYDZT383gvD5cA0jO9joP8tVX0UAAsxVtjk4LEQQUJ+Gc/1EUb9d1G0XGALxq2Jzac/NgDLgH8COK6SIh3oBXQCogI8Fm+dwsiq+QqwOsBjEUKcRyYA51pJAO9rB6G9GIH97CB/5s/buTCv9PlbIvAo0IXQWVU5AIwHXgdKZDYrIUoCmQCcKxMvcgCEsJM4B/az/xySuYZLKBvQEHgc47xAMFoHjAMmIz87QgQ9mQCcq6RNAAowaqW7C/DydBaaLsOYCLQm8PkVcoE5wJvAYow9fyFECJAJwLk+Be4P9CA8dJL/gvz5H+uRJ7GSLBbjRH134FI/970T47DiOIy0vUIIEdIeJvAnpl2dqv8bowraW8CTQFOMswqJ5nwbRIjRME7Yz8Hc2wP5wGcYuQusfvkvE0KYRlYAzhWO8dSc4ed+93Hu0vzZy/XbkWIooviSgVZAe4ytAhU2YzztT8H42RRClAAyAXB2DbAEtTnJT+Ic3M8O8hdUSUDhN9cC7YAWQLyHrz2KUbZ5MvA9srcvRIkjEwDXrsF480sv5tfrFH7YbqcJYxSiuBwY1QjbAXfjfvm+AKMc9hRgNpDtj8EJIQJDJgDuhWO8YdYDLsH4Xh3F9VN8JlK6VISGchi3B+pgFL8C44zJF8D7yIE+IYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQgghhBBCCCGEEEIIIYQQQsD/AdMqWmLhXW6wAAAAAElFTkSuQmCC';
|
|
961
961
|
|
|
962
962
|
var SimpleProgressBar = function SimpleProgressBar(_ref) {
|
|
963
963
|
var value = _ref.value,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"long-bow.cjs.development.js","sources":["../src/components/Button.tsx","../src/constants/uiColors.ts","../src/components/Input.tsx","../src/components/RPGUIContainer.tsx","../src/components/shared/Column.tsx","../src/components/Chat/Chat.tsx","../src/components/CheckButton.tsx","../src/components/DraggableContainer.tsx","../src/components/RPGUIRoot.tsx","../src/components/Dropdown.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/typography/DynamicText.tsx","../src/components/NPCDialog/NPCDialogText.tsx","../src/hooks/useEventListener.ts","../src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx","../src/components/NPCDialog/NPCDialog.tsx","../src/components/ProgressBar.tsx","../src/components/RadioButton.tsx","../src/components/RangeSlider.tsx","../src/components/imgExp.png","../src/components/SimpleProgressBar.tsx","../src/components/SkillProgressBar.tsx","../src/components/TextArea.tsx","../src/components/Truncate.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","export const colors = {\n darkGrey: '#3e3e3e',\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 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 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","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 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, { 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 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, { 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 { 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 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, { 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, { 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","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","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","/* 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"],"names":["ButtonTypes","Button","children","buttonType","props","React","ButtonContainer","className","styled","button","colors","darkGrey","Input","RPGUIContainerTypes","RPGUIContainer","type","width","height","Container","div","Column","flex","flexWrap","alignItems","justifyContent","Chat","chatMessages","onSendChatMessage","opacity","onCloseButton","useState","message","setMessage","useEffect","scrollChatToBottom","scrollingElement","document","querySelector","scrollTop","scrollHeight","handleSubmit","event","preventDefault","getInputValue","value","onRenderMessageLines","emitter","createdAt","dayjs","Date","format","name","onRenderChatMessages","length","map","index","_id","MessageText","key","CustomContainer","FramedGrey","ErrorBoundary","fallback","CloseButton","onClick","onTouchStart","Form","onSubmit","CustomInput","id","onChange","e","target","autoComplete","RPGUIButton","form","p","CheckButton","items","generateSelectedValuesList","selectedValues","forEach","item","label","setSelectedValues","handleClick","element","checked","DraggableContainer","FramedGold","title","imgSrc","imgWidth","Draggable","TitleContainer","Title","Icon","src","h1","img","_RPGUI","RPGUI","RPGUIRoot","Dropdown","options","dropdownId","uuidv4","selectedValue","setSelectedValue","getElementById","dropdownValue","get_value","addEventListener","style","option","ListMenu","onSelected","x","y","fontSize","overflow","params","ListElement","text","li","chunkString","str","match","RegExp","DynamicText","onFinish","onStart","textState","setTextState","i","interval","setInterval","substring","clearInterval","TextContainer","NPCDialogText","onClose","onEndStep","onStartStep","textChunks","chunkIndex","setChunkIndex","onHandleSpacePress","code","hasNextChunk","prev","removeEventListener","useEventListener","handler","el","window","savedHandler","useRef","current","listener","QuestionDialog","questions","answers","currentQuestion","setCurrentQuestion","canShowAnswers","setCanShowAnswers","onGetFirstAnswer","answerIds","firstAnswerId","find","answer","currentAnswer","setCurrentAnswer","onGetAnswers","answerId","onKeyPress","nextAnswerIndex","findIndex","nextAnswerID","nextAnswer","previousAnswerIndex","previousAnswerID","previousAnswer","pop","nextQuestionId","question","onAnswerClick","onRenderCurrentAnswers","isSelected","selectedColor","AnswerRow","AnswerSelectedIcon","color","Answer","QuestionContainer","AnswersContainer","span","NPCDialogType","NPCDialog","imagePath","isQuestionDialog","showGoNextIndicator","setShowGoNextIndicator","TextAndThumbnail","ThumbnailContainer","NPCThumbnail","aliceDefaultThumbnail","PressSpaceIndicator","right","TextOnly","pressSpaceGif","ProgressBar","max","displayText","percentageWidth","minWidth","calculatePercentageValue","TextOverlay","ProgressBarText","left","InputRadio","elementValue","RangeSliderType","RangeSlider","valueMin","valueMax","sliderId","wasMouseDownFirst","setWasMouseDownFirst","onHandleMouseUp","rpguiSlider","Number","onMouseUp","onMouseDown","Slider","GoldSlider","min","input","SimpleProgressBar","bgColor","ProgressBarContainer","BackgroundBar","Progress","SkillProgressBar","titleName","logoSrc","imgSrcTemplate","ProgressTitle","TitleName","ValueDisplay","ProgressBody","ProgressIconContainer","TextArea","Truncate","maxLines"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,WAAYA;EACVA,0BAAA,iBAAA;EACAA,8BAAA,wBAAA;AACD,CAHD,EAAYA,mBAAW,KAAXA,mBAAW,KAAA,CAAvB;;IAUaC,MAAM,GAIZ,SAJMA,MAIN;MAAGC,gBAAAA;MAAUC,kBAAAA;MAAeC;;EACjC,OACEC,4BAAA,CAACC,eAAD;IAAiBC,SAAS,OAAKJ;KAAkBC,MAAjD,EACEC,4BAAA,IAAA,MAAA,EAAIH,QAAJ,CADF,CADF;AAKD;AAED,IAAMI,eAAe,gBAAGE,MAAM,CAACC,MAAV;EAAA;EAAA;AAAA,qCAArB;;ACzBO,IAAMC,MAAM,GAAG;EACpBC,QAAQ,EAAE;AADU,CAAf;;ICQMC,KAAK,GAA0B,SAA/BA,KAA+B;MAAMR;;EAChD,OAAOC,4BAAA,QAAA,oBAAWD,MAAX,CAAP;AACD,CAFM;;ACLP,WAAYS;EACVA,6BAAA,WAAA;EACAA,iCAAA,kBAAA;EACAA,kCAAA,oBAAA;EACAA,iCAAA,gBAAA;AACD,CALD,EAAYA,2BAAmB,KAAnBA,2BAAmB,KAAA,CAA/B;;AAcA,IAAaC,cAAc,GAAmC,SAAjDA,cAAiD;MAC5DZ,gBAAAA;MACAa,YAAAA;wBACAC;MAAAA,gCAAQ;MACRC,cAAAA;MACAV,iBAAAA;EAEA,OACEF,4BAAA,CAACa,SAAD;IACEF,KAAK,EAAEA;IACPC,MAAM,EAAEA,MAAM,IAAI;IAClBV,SAAS,uBAAqBQ,IAArB,SAA6BR;GAHxC,EAKGL,QALH,CADF;AASD,CAhBM;AAuBP,IAAMgB,SAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,sFACH,UAAAf,KAAK;EAAA,OAAIA,KAAK,CAACa,MAAV;AAAA,CADF,EAEJ;EAAA,IAAGD,KAAH,SAAGA,KAAH;EAAA,OAAeA,KAAf;AAAA,CAFI,CAAf;;AC/BO,IAAMI,MAAM,gBAAGZ,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,qFACT,UAAAf,KAAK;EAAA,OAAIA,KAAK,CAACiB,IAAN,IAAc,MAAlB;AAAA,CADI,EAGJ,UAAAjB,KAAK;EAAA,OAAIA,KAAK,CAACkB,QAAN,IAAkB,QAAtB;AAAA,CAHD,EAIF,UAAAlB,KAAK;EAAA,OAAIA,KAAK,CAACmB,UAAN,IAAoB,YAAxB;AAAA,CAJH,EAKE,UAAAnB,KAAK;EAAA,OAAIA,KAAK,CAACoB,cAAN,IAAwB,YAA5B;AAAA,CALP,CAAZ;;ICeMC,IAAI,GAAyB,SAA7BA,IAA6B;MACxCC,oBAAAA;MACAC,yBAAAA;0BACAC;MAAAA,oCAAU;wBACVZ;MAAAA,gCAAQ;yBACRC;MAAAA,kCAAS;MACTY,qBAAAA;;EAEA,gBAA8BC,cAAQ,CAAC,EAAD,CAAtC;MAAOC,OAAP;MAAgBC,UAAhB;;EAEAC,eAAS,CAAC;IACRC,kBAAkB;GADX,EAEN,EAFM,CAAT;EAIAD,eAAS,CAAC;IACRC,kBAAkB;GADX,EAEN,CAACR,YAAD,CAFM,CAAT;;EAIA,IAAMQ,kBAAkB,GAAG,SAArBA,kBAAqB;IACzB,IAAMC,gBAAgB,GAAGC,QAAQ,CAACC,aAAT,CAAuB,YAAvB,CAAzB;;IACA,IAAIF,gBAAJ,EAAsB;MACpBA,gBAAgB,CAACG,SAAjB,GAA6BH,gBAAgB,CAACI,YAA9C;;GAHJ;;EAOA,IAAMC,YAAY,GAAG,SAAfA,YAAe,CAACC,KAAD;IACnBA,KAAK,CAACC,cAAN;IACAf,iBAAiB,CAACI,OAAD,CAAjB;IACAC,UAAU,CAAC,EAAD,CAAV;GAHF;;EAKA,IAAMW,aAAa,GAAG,SAAhBA,aAAgB,CAACC,KAAD;IACpBZ,UAAU,CAACY,KAAD,CAAV;GADF;;EAIA,IAAMC,oBAAoB,GAAG,SAAvBA,oBAAuB,CAC3BC,OAD2B,EAE3BC,SAF2B,EAG3BhB,OAH2B;IAK3B,OAAUiB,KAAK,CAACD,SAAS,IAAI,IAAIE,IAAJ,EAAd,CAAL,CAA+BC,MAA/B,CAAsC,OAAtC,CAAV,UACEJ,OAAO,QAAP,IAAAA,OAAO,CAAEK,IAAT,GAAmBL,OAAO,CAACK,IAA3B,UAAsC,WADxC,UAEIpB,OAFJ;GALF;;EAUA,IAAMqB,oBAAoB,GAAG,SAAvBA,oBAAuB,CAAC1B,YAAD;IAC3B,OAAOA,YAAY,QAAZ,IAAAA,YAAY,CAAE2B,MAAd,GACL3B,YADK,oBACLA,YAAY,CAAE4B,GAAd,CAAkB,iBAAuCC,KAAvC;MAAA,IAAGC,GAAH,SAAGA,GAAH;UAAQT,SAAR,SAAQA,SAAR;UAAmBD,OAAnB,SAAmBA,OAAnB;UAA4Bf,OAA5B,SAA4BA,OAA5B;MAAA,OAChB1B,4BAAA,CAACoD,WAAD;QAAaC,GAAG,EAAKF,GAAL,SAAYD;OAA5B,EACGV,oBAAoB,CAACC,OAAD,EAAUC,SAAV,EAAqBhB,OAArB,CADvB,CADgB;KAAlB,CADK,GAOL1B,4BAAA,CAACoD,WAAD,MAAA,0BAAA,CAPF;GADF;;EAYA,OACEpD,4BAAA,CAACa,WAAD,MAAA,EACEb,4BAAA,CAACsD,eAAD;IACE5C,IAAI,EAAEF,2BAAmB,CAAC+C;IAC1B5C,KAAK,EAAEA;IACPC,MAAM,EAAEA;IACRV,SAAS,EAAC;IACVqB,OAAO,EAAEA;GALX,EAOEvB,4BAAA,CAACwD,gCAAD;IAAeC,QAAQ,EAAEzD,4BAAA,IAAA,MAAA,gCAAA;GAAzB,EACGwB,aAAa,IACZxB,4BAAA,CAAC0D,WAAD;IAAaC,OAAO,EAAEnC;IAAeoC,YAAY,EAAEpC;GAAnD,KAAA,CAFJ,EAMExB,4BAAA,CAACS,cAAD;IACEC,IAAI,EAAEF,2BAAmB,CAAC+C;IAC1B5C,KAAK,EAAE;IACPC,MAAM,EAAE;IACRV,SAAS,EAAC;GAJZ,EAMG6C,oBAAoB,CAAC1B,YAAD,CANvB,CANF,EAeErB,4BAAA,CAAC6D,IAAD;IAAMC,QAAQ,EAAE3B;GAAhB,EACEnC,4BAAA,CAACe,MAAD;IAAQC,IAAI,EAAE;GAAd,EACEhB,4BAAA,CAAC+D,WAAD;IACExB,KAAK,EAAEb;IACPsC,EAAE,EAAC;IACHC,QAAQ,EAAE,kBAAAC,CAAC;MAAA,OAAI5B,aAAa,CAAC4B,CAAC,CAACC,MAAF,CAAS5B,KAAV,CAAjB;;IACX3B,MAAM,EAAE;IACRV,SAAS,EAAC;IACVQ,IAAI,EAAC;IACL0D,YAAY,EAAC;GAPf,CADF,CADF,EAYEpE,4BAAA,CAACe,MAAD;IAAQI,cAAc,EAAC;GAAvB,EACEnB,4BAAA,CAACJ,MAAD;IACEE,UAAU,EAAEH,mBAAW,CAAC0E;IACxBL,EAAE,EAAC;GAFL,QAAA,CADF,CAZF,CAfF,CAPF,CADF,CADF;AAiDD,CAzGM;AA2GP,IAAMnD,WAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,0BAAf;AAIA,IAAM4C,WAAW,gBAAGvD,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,kFAAjB;AASA,IAAMiD,WAAW,gBAAG5D,MAAM,CAACI,KAAD,CAAT;EAAA;EAAA;AAAA,sEAAjB;AAaA,IAAM+C,eAAe,gBAAGnD,MAAM,CAACM,cAAD,CAAT;EAAA;EAAA;AAAA,uMAGR,UAACV,KAAD;EAAA,OAAkCA,KAAK,CAACwB,OAAxC;AAAA,CAHQ,EAUGlB,MAAM,CAACC,QAVV,CAArB;AAsBA,IAAMuD,IAAI,gBAAG1D,MAAM,CAACmE,IAAV;EAAA;EAAA;AAAA,0EAAV;AAOA,IAAMlB,WAAW,gBAAGjD,MAAM,CAACoE,CAAV;EAAA;EAAA;AAAA,iGAAjB;;IC1KaC,WAAW,GAA0B,SAArCA,WAAqC;MAAGC,aAAAA;MAAOR,gBAAAA;;EAC1D,IAAMS,0BAA0B,GAAG,SAA7BA,0BAA6B;IACjC,IAAMC,cAAc,GAA6B,EAAjD;IAEAF,KAAK,CAACG,OAAN,CAAc,UAAAC,IAAI;MAChBF,cAAc,CAACE,IAAI,CAACC,KAAN,CAAd,GAA6B,KAA7B;KADF;IAIA,OAAOH,cAAP;GAPF;;EAUA,gBAA4ClD,cAAQ,CAElDiD,0BAA0B,EAFwB,CAApD;MAAOC,cAAP;MAAuBI,iBAAvB;;EAIA,IAAMC,WAAW,GAAG,SAAdA,WAAc,CAACF,KAAD;;;IAClBC,iBAAiB,cACZJ,cADY,6BAEdG,KAFc,IAEN,CAACH,cAAc,CAACG,KAAD,CAFT,cAAjB;GADF;;EAOAlD,eAAS,CAAC;IACR,IAAI+C,cAAJ,EAAoB;MAClBV,QAAQ,CAACU,cAAD,CAAR;;GAFK,EAIN,CAACA,cAAD,CAJM,CAAT;EAMA,OACE3E,4BAAA,MAAA;IAAKgE,EAAE,EAAC;GAAR,EACGS,KADH,oBACGA,KAAK,CAAExB,GAAP,CAAW,UAACgC,OAAD,EAAU/B,KAAV;IACV,OACElD,4BAAA,MAAA;MAAKqD,GAAG,EAAK4B,OAAO,CAACH,KAAb,SAAsB5B;KAA9B,EACElD,4BAAA,QAAA;MACEE,SAAS,EAAC;MACVQ,IAAI,EAAC;MACLwE,OAAO,EAAEP,cAAc,CAACM,OAAO,CAACH,KAAT;MACvBb,QAAQ,EAAE;KAJZ,CADF,EAOEjE,4BAAA,QAAA;MAAO2D,OAAO,EAAE;QAAA,OAAMqB,WAAW,CAACC,OAAO,CAACH,KAAT,CAAjB;;KAAhB,EACGG,OAAO,CAACH,KADX,CAPF,EAUE9E,4BAAA,KAAA,MAAA,CAVF,CADF;GADD,CADH,CADF;AAoBD,CAhDM;;ICCMmF,kBAAkB,GAAuC,SAAzDA,kBAAyD;MACpEtF,gBAAAA;wBACAc;MAAAA,gCAAQ;MACRC,cAAAA;MACAV,iBAAAA;uBACAQ;MAAAA,8BAAOF,2BAAmB,CAAC4E;MAC3B5D,qBAAAA;MACA6D,aAAAA;MACAC,cAAAA;2BACAC;MAAAA,sCAAW;EAEX,OACEvF,4BAAA,CAACwF,SAAD,MAAA,EACExF,4BAAA,CAACa,WAAD;IACEF,KAAK,EAAEA;IACPC,MAAM,EAAEA,MAAM,IAAI;IAClBV,SAAS,uBAAqBQ,IAArB,SAA6BR,SAA7B;GAHX,EAKEF,4BAAA,CAACyF,cAAD,MAAA,EACEzF,4BAAA,CAAC0F,KAAD,MAAA,EACGJ,MAAM,IAAItF,4BAAA,CAAC2F,IAAD;IAAMC,GAAG,EAAEN;IAAQ3E,KAAK,EAAE4E;GAA1B,CADb,EAEGF,KAFH,CADF,CALF,EAWG7D,aAAa,IACZxB,4BAAA,CAAC0D,aAAD;IAAaC,OAAO,EAAEnC;IAAeoC,YAAY,EAAEpC;GAAnD,KAAA,CAZJ,EAiBG3B,QAjBH,CADF,CADF;AAuBD,CAlCM;AAyCP,IAAMgB,WAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,sFACH,UAAAf,KAAK;EAAA,OAAIA,KAAK,CAACa,MAAV;AAAA,CADF,EAEJ;EAAA,IAAGD,KAAH,SAAGA,KAAH;EAAA,OAAeA,KAAf;AAAA,CAFI,CAAf;AAQA,IAAM+C,aAAW,gBAAGvD,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,kFAAjB;AASA,IAAM2E,cAAc,gBAAGtF,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,yFAApB;AASA,IAAM4E,KAAK,gBAAGvF,MAAM,CAAC0F,EAAV;EAAA;EAAA;AAAA,8CAAX;AAUA,IAAMF,IAAI,gBAAGxF,MAAM,CAAC2F,GAAV;EAAA;EAAA;AAAA,8EAIC,UAAC/F,KAAD;EAAA,OAA6BA,KAAK,CAACY,KAAnC;AAAA,CAJD,CAAV;;ICrFaoF,MAAM,GAAGC,KAAf;AAEP,IAAaC,SAAS,GAAqB,SAA9BA,SAA8B;MAAGpG,gBAAAA;EAC5C,OAAOG,4BAAA,MAAA;IAAKE,SAAS,EAAC;GAAf,EAAgCL,QAAhC,CAAP;AACD,CAFM;;ICKMqG,QAAQ,GAA6B,SAArCA,QAAqC;MAChDC,eAAAA;MACAxF,aAAAA;MACAsD,gBAAAA;EAEA,IAAMmC,UAAU,GAAGC,OAAM,EAAzB;;EAEA,gBAA0C5E,cAAQ,CAAS,EAAT,CAAlD;MAAO6E,aAAP;MAAsBC,gBAAtB;;EAEA3E,eAAS,CAAC;IACR,IAAMqD,OAAO,GAAGlD,QAAQ,CAACyE,cAAT,qBAA0CJ,UAA1C,CAAhB;;IACA,IAAMK,aAAa,GAAGV,MAAM,CAACW,SAAP,CAAiBzB,OAAjB,CAAtB;;IACAsB,gBAAgB,CAACE,aAAD,CAAhB;IAEAxB,OAAO,QAAP,YAAAA,OAAO,CAAE0B,gBAAT,CAA0B,QAA1B,EAAoC,UAACvE,KAAD;MAClCmE,gBAAgB,CAACnE,KAAD,oBAACA,KAAK,CAAE+B,MAAP,CAAc5B,KAAf,CAAhB;KADF;GALO,EAQN,EARM,CAAT;EAUAX,eAAS,CAAC;IACR,IAAI0E,aAAJ,EAAmB;MACjBrC,QAAQ,CAACqC,aAAD,CAAR;;GAFK,EAIN,CAACA,aAAD,CAJM,CAAT;EAMA,OACEtG,4BAAA,SAAA;IACEgE,EAAE,sBAAoBoC;IACtBQ,KAAK,EAAE;MAAEjG,KAAK,EAAEA;;IAChBT,SAAS,EAAC;GAHZ,EAKGiG,OAAO,CAAClD,GAAR,CAAY,UAAA4D,MAAM;IACjB,OACE7G,4BAAA,SAAA;MAAQqD,GAAG,EAAEwD,MAAM,CAAC7C;MAAIzB,KAAK,EAAEsE,MAAM,CAACtE;KAAtC,EACGsE,MAAM,CAACA,MADV,CADF;GADD,CALH,CADF;AAeD,CAxCM;;ICAMC,QAAQ,GAA6B,SAArCA,QAAqC;MAChDX,eAAAA;MACAY,kBAAAA;MACAC,SAAAA;MACAC,SAAAA;2BACAC;MAAAA,sCAAW;EAEX,OACElH,4BAAA,CAACa,WAAD;IAAWmG,CAAC,EAAEA;IAAGC,CAAC,EAAEA;IAAGC,QAAQ,EAAEA;GAAjC,EACElH,4BAAA,KAAA;IAAIE,SAAS,EAAC;IAAiB0G,KAAK,EAAE;MAAEO,QAAQ,EAAE;;GAAlD,EACGhB,OAAO,CAAClD,GAAR,CAAY,UAAAmE,MAAM;IAAA,OACjBpH,4BAAA,CAACqH,WAAD;MACEhE,GAAG,EAAE+D,MAAM,CAACE;MACZ3D,OAAO,EAAE;QACPoD,UAAU,CAACK,MAAM,CAACpD,EAAR,CAAV;;KAHJ,EAMGoD,MAAM,CAACE,IANV,CADiB;GAAlB,CADH,CADF,CADF;AAgBD,CAvBM;AA+BP,IAAMzG,WAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,kKAON,UAAAf,KAAK;EAAA,OAAIA,KAAK,CAACkH,CAAN,IAAW,CAAf;AAAA,CAPC,EAQL,UAAAlH,KAAK;EAAA,OAAIA,KAAK,CAACiH,CAAN,IAAW,CAAf;AAAA,CARA,EAWE,UAAAjH,KAAK;EAAA,OAAIA,KAAK,CAACmH,QAAV;AAAA,CAXP,CAAf;AAeA,IAAMG,WAAW,gBAAGlH,MAAM,CAACoH,EAAV;EAAA;EAAA;AAAA,4BAAjB;;AC9DA,MAAM,GAAG,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;;ACAnC,MAAMzB,KAAG,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;;ACA5B,IAAM0B,WAAW,GAAG,SAAdA,WAAc,CAACC,GAAD,EAAczE,MAAd;EACzB,OAAOyE,GAAG,CAACC,KAAJ,CAAU,IAAIC,MAAJ,CAAW,SAAS3E,MAAT,GAAkB,GAA7B,EAAkC,GAAlC,CAAV,CAAP;AACD,CAFM;;ICSM4E,WAAW,GAAqB,SAAhCA,WAAgC;MAAGN,YAAAA;MAAMO,gBAAAA;MAAUC,eAAAA;;EAC9D,gBAAkCrG,cAAQ,CAAS,EAAT,CAA1C;MAAOsG,SAAP;MAAkBC,YAAlB;;EAEApG,eAAS,CAAC;IACR,IAAIqG,CAAC,GAAG,CAAR;IACA,IAAMC,QAAQ,GAAGC,WAAW,CAAC;;MAG3B,IAAIF,CAAC,KAAK,CAAV,EAAa;QACX,IAAIH,OAAJ,EAAa;UACXA,OAAO;;;;MAIX,IAAIG,CAAC,GAAGX,IAAI,CAACtE,MAAb,EAAqB;QACnBgF,YAAY,CAACV,IAAI,CAACc,SAAL,CAAe,CAAf,EAAkBH,CAAC,GAAG,CAAtB,CAAD,CAAZ;QACAA,CAAC;OAFH,MAGO;QACLI,aAAa,CAACH,QAAD,CAAb;;QACA,IAAIL,QAAJ,EAAc;UACZA,QAAQ;;;KAfc,EAkBzB,EAlByB,CAA5B;IAoBA,OAAO;MACLQ,aAAa,CAACH,QAAD,CAAb;KADF;GAtBO,EAyBN,CAACZ,IAAD,CAzBM,CAAT;EA2BA,OAAOtH,4BAAA,CAACsI,aAAD,MAAA,EAAgBP,SAAhB,CAAP;AACD,CA/BM;AAiCP,IAAMO,aAAa,gBAAGnI,MAAM,CAACoE,CAAV;EAAA;EAAA;AAAA,uHAAnB;;AC9BO,IAAMgE,aAAa,GAAqB,SAAlCA,aAAkC;MAC7CjB,YAAAA;MACAkB,eAAAA;MACAC,iBAAAA;MACAC,mBAAAA;EAEA,IAAMC,UAAU,GAAGnB,WAAW,CAACF,IAAD,EAAO,EAAP,CAA9B;;EAEA,gBAAoC7F,cAAQ,CAAS,CAAT,CAA5C;MAAOmH,UAAP;MAAmBC,aAAnB;;EAEA,IAAMC,kBAAkB,GAAG,SAArBA,kBAAqB,CAAC1G,KAAD;IACzB,IAAIA,KAAK,CAAC2G,IAAN,KAAe,OAAnB,EAA4B;MAC1B,IAAMC,YAAY,GAAG,CAAAL,UAAU,QAAV,YAAAA,UAAU,CAAGC,UAAU,GAAG,CAAhB,CAAV,KAAgC,KAArD;;MAEA,IAAII,YAAJ,EAAkB;QAChBH,aAAa,CAAC,UAAAI,IAAI;UAAA,OAAIA,IAAI,GAAG,CAAX;SAAL,CAAb;OADF,MAEO;;QAELT,OAAO;;;GARb;;EAaA5G,eAAS,CAAC;IACRG,QAAQ,CAAC4E,gBAAT,CAA0B,SAA1B,EAAqCmC,kBAArC;IAEA,OAAO;MAAA,OAAM/G,QAAQ,CAACmH,mBAAT,CAA6B,SAA7B,EAAwCJ,kBAAxC,CAAN;KAAP;GAHO,EAIN,CAACF,UAAD,CAJM,CAAT;EAMA,OACE5I,4BAAA,CAACa,WAAD,MAAA,EACEb,4BAAA,CAAC4H,WAAD;IACEN,IAAI,EAAE,CAAAqB,UAAU,QAAV,YAAAA,UAAU,CAAGC,UAAH,CAAV,KAA4B;IAClCf,QAAQ,EAAEY;IACVX,OAAO,EAAEY;GAHX,CADF,CADF;AASD,CAtCM;AAwCP,IAAM7H,WAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,QAAf;;ICjDaqI,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACzI,IAAD,EAAO0I,OAAP,EAAgBC,EAAhB;MAAgBA;IAAAA,KAAKC;;;EACnD,IAAMC,YAAY,GAAGvJ,cAAK,CAACwJ,MAAN,EAArB;EAEAxJ,cAAK,CAAC4B,SAAN,CAAgB;IACd2H,YAAY,CAACE,OAAb,GAAuBL,OAAvB;GADF,EAEG,CAACA,OAAD,CAFH;EAIApJ,cAAK,CAAC4B,SAAN,CAAgB;;IAEd,IAAM8H,QAAQ,GAAG,SAAXA,QAAW,CAAAxF,CAAC;MAAA,OAAIqF,YAAY,CAACE,OAAb,CAAqBvF,CAArB,CAAJ;KAAlB;;IAEAmF,EAAE,CAAC1C,gBAAH,CAAoBjG,IAApB,EAA0BgJ,QAA1B;IAEA,OAAO;MACLL,EAAE,CAACH,mBAAH,CAAuBxI,IAAvB,EAA6BgJ,QAA7B;KADF;GANF,EASG,CAAChJ,IAAD,EAAO2I,EAAP,CATH;AAUD,CAjBM;;ICoBMM,cAAc,GAAqB,SAAnCA,cAAmC;MAC9CC,iBAAAA;MACAC,eAAAA;MACArB,eAAAA;;EAEA,gBAA8C/G,cAAQ,CAACmI,SAAS,CAAC,CAAD,CAAV,CAAtD;MAAOE,eAAP;MAAwBC,kBAAxB;;EAEA,iBAA4CtI,cAAQ,CAAU,KAAV,CAApD;MAAOuI,cAAP;MAAuBC,iBAAvB;;EAEA,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB;IACvB,IAAI,CAACJ,eAAe,CAACK,SAAjB,IAA8BL,eAAe,CAACK,SAAhB,CAA0BnH,MAA1B,KAAqC,CAAvE,EAA0E;MACxE,OAAO,IAAP;;;IAGF,IAAMoH,aAAa,GAAGN,eAAe,CAACK,SAAhB,CAA2B,CAA3B,CAAtB;IAEA,OAAON,OAAO,CAACQ,IAAR,CAAa,UAAAC,MAAM;MAAA,OAAIA,MAAM,CAACtG,EAAP,KAAcoG,aAAlB;KAAnB,CAAP;GAPF;;EAUA,iBAGI3I,cAAQ,CAA+ByI,gBAAgB,EAA/C,CAHZ;MACEK,aADF;MAEEC,gBAFF;;EAKA5I,eAAS,CAAC;IACR4I,gBAAgB,CAACN,gBAAgB,EAAjB,CAAhB;GADO,EAEN,CAACJ,eAAD,CAFM,CAAT;;EAIA,IAAMW,YAAY,GAAG,SAAfA,YAAe,CAACN,SAAD;IACnB,OAAOA,SAAS,CAAClH,GAAV,CAAc,UAACyH,QAAD;MAAA,OACnBb,OAAO,CAACQ,IAAR,CAAa,UAAAC,MAAM;QAAA,OAAIA,MAAM,CAACtG,EAAP,KAAc0G,QAAlB;OAAnB,CADmB;KAAd,CAAP;GADF;;EAMA,IAAMC,UAAU,GAAG,SAAbA,UAAa,CAACzG,CAAD;IACjB,QAAQA,CAAC,CAACb,GAAV;MACE,KAAK,WAAL;;;;;;QAOE,IAAMuH,eAAe,GAAGH,YAAY,CAClCX,eAAe,CAACK,SADkB,CAAZ,CAEtBU,SAFsB,CAEZ,UAAAP,MAAM;UAAA,OAAI,CAAAA,MAAM,QAAN,YAAAA,MAAM,CAAEtG,EAAR,MAAeuG,aAAc,CAACvG,EAAf,GAAoB,CAAvC;SAFM,CAAxB;QAIA,IAAM8G,YAAY,GAAGhB,eAAe,CAACK,SAAhB,CAA2BS,eAA3B,CAArB,CAXF;;QAeE,IAAMG,UAAU,GAAGN,YAAY,CAACX,eAAe,CAACK,SAAjB,CAAZ,CAAyCE,IAAzC,CACjB,UAAAC,MAAM;UAAA,OAAI,CAAAA,MAAM,QAAN,YAAAA,MAAM,CAAEtG,EAAR,MAAe8G,YAAnB;SADW,CAAnB;QAIAN,gBAAgB,CAACO,UAAU,IAAIb,gBAAgB,EAA/B,CAAhB;QAEA;;MACF,KAAK,SAAL;;;QAIE,IAAMc,mBAAmB,GAAGP,YAAY,CACtCX,eAAe,CAACK,SADsB,CAAZ,CAE1BU,SAF0B,CAEhB,UAAAP,MAAM;UAAA,OAAI,CAAAA,MAAM,QAAN,YAAAA,MAAM,CAAEtG,EAAR,MAAeuG,aAAc,CAACvG,EAAf,GAAoB,CAAvC;SAFU,CAA5B;QAIA,IAAMiH,gBAAgB,GACpBnB,eAAe,CAACK,SAAhB,IACAL,eAAe,CAACK,SAAhB,CAA0Ba,mBAA1B,CAFF;QAIA,IAAME,cAAc,GAAGT,YAAY,CAACX,eAAe,CAACK,SAAjB,CAAZ,CAAyCE,IAAzC,CACrB,UAAAC,MAAM;UAAA,OAAI,CAAAA,MAAM,QAAN,YAAAA,MAAM,CAAEtG,EAAR,MAAeiH,gBAAnB;SADe,CAAvB;;QAIA,IAAIC,cAAJ,EAAoB;UAClBV,gBAAgB,CAACU,cAAD,CAAhB;SADF,MAEO;UACLV,gBAAgB,CAACC,YAAY,CAACX,eAAe,CAACK,SAAjB,CAAZ,CAAyCgB,GAAzC,EAAD,CAAhB;;;QAGF;;MACF,KAAK,OAAL;QACElB,iBAAiB,CAAC,KAAD,CAAjB;;QAEA,IAAI,EAACM,aAAD,YAACA,aAAa,CAAEa,cAAhB,CAAJ,EAAoC;UAClC5C,OAAO;UACP;SAFF,MAGO;UACLuB,kBAAkB,CAChBH,SAAS,CAACS,IAAV,CACE,UAAAgB,QAAQ;YAAA,OAAIA,QAAQ,CAACrH,EAAT,KAAgBuG,aAAc,CAACa,cAAnC;WADV,CADgB,CAAlB;;;QAOF;;GA7DN;;EAgEAjC,gBAAgB,CAAC,SAAD,EAAYwB,UAAZ,CAAhB;;EAEA,IAAMW,aAAa,GAAG,SAAhBA,aAAgB,CAAChB,MAAD;IACpBL,iBAAiB,CAAC,KAAD,CAAjB;;IACA,IAAIK,MAAM,CAACc,cAAX,EAA2B;;MAEzBrB,kBAAkB,CAChBH,SAAS,CAACS,IAAV,CAAe,UAAAgB,QAAQ;QAAA,OAAIA,QAAQ,CAACrH,EAAT,KAAgBsG,MAAM,CAACc,cAA3B;OAAvB,CADgB,CAAlB;KAFF,MAKO;;MAEL5C,OAAO;;GATX;;EAaA,IAAM+C,sBAAsB,GAAG,SAAzBA,sBAAyB;IAC7B,IAAMpB,SAAS,GAAGL,eAAe,CAACK,SAAlC;;IACA,IAAI,CAACA,SAAL,EAAgB;MACd,OAAO,IAAP;;;IAGF,IAAMN,OAAO,GAAGY,YAAY,CAACN,SAAD,CAA5B;;IAEA,IAAI,CAACN,OAAL,EAAc;MACZ,OAAO,IAAP;;;IAGF,OAAOA,OAAO,CAAC5G,GAAR,CAAY,UAAAqH,MAAM;MACvB,IAAMkB,UAAU,GAAG,CAAAjB,aAAa,QAAb,YAAAA,aAAa,CAAEvG,EAAf,OAAsBsG,MAAtB,oBAAsBA,MAAM,CAAEtG,EAA9B,CAAnB;MACA,IAAMyH,aAAa,GAAGD,UAAU,GAAG,QAAH,GAAc,OAA9C;;MAEA,IAAIlB,MAAJ,EAAY;QACV,OACEtK,4BAAA,CAAC0L,SAAD;UAAWrI,GAAG,cAAYiH,MAAM,CAACtG;SAAjC,EACEhE,4BAAA,CAAC2L,kBAAD;UAAoBC,KAAK,EAAEH;SAA3B,EACGD,UAAU,GAAG,GAAH,GAAS,IADtB,CADF,EAKExL,4BAAA,CAAC6L,MAAD;UACExI,GAAG,EAAEiH,MAAM,CAACtG;UACZL,OAAO,EAAE;YAAA,OAAM2H,aAAa,CAAChB,MAAD,CAAnB;;UACTsB,KAAK,EAAEH;SAHT,EAKGnB,MAAM,CAAChD,IALV,CALF,CADF;;;MAiBF,OAAO,IAAP;KAtBK,CAAP;GAZF;;EAsCA,OACEtH,4BAAA,CAACa,WAAD,MAAA,EACEb,4BAAA,CAAC8L,iBAAD,MAAA,EACE9L,4BAAA,CAAC4H,WAAD;IACEN,IAAI,EAAEwC,eAAe,CAACxC;IACtBQ,OAAO,EAAE;MAAA,OAAMmC,iBAAiB,CAAC,KAAD,CAAvB;;IACTpC,QAAQ,EAAE;MAAA,OAAMoC,iBAAiB,CAAC,IAAD,CAAvB;;GAHZ,CADF,CADF,EASGD,cAAc,IACbhK,4BAAA,CAAC+L,gBAAD,MAAA,EAAmBR,sBAAsB,EAAzC,CAVJ,CADF;AAeD,CAtKM;AAwKP,IAAM1K,WAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,iIAAf;AAWA,IAAMgL,iBAAiB,gBAAG3L,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,6BAAvB;AAKA,IAAMiL,gBAAgB,gBAAG5L,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,kBAAtB;AAQA,IAAM+K,MAAM,gBAAG1L,MAAM,CAACoE,CAAV;EAAA;EAAA;AAAA,qGAED,UAAAxE,KAAK;EAAA,OAAIA,KAAK,CAAC6L,KAAV;AAAA,CAFJ,CAAZ;AAQA,IAAMD,kBAAkB,gBAAGxL,MAAM,CAAC6L,IAAV;EAAA;EAAA;AAAA,2CAEb,UAAAjM,KAAK;EAAA,OAAIA,KAAK,CAAC6L,KAAV;AAAA,CAFQ,CAAxB;AAKA,IAAMF,SAAS,gBAAGvL,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,oKAAf;;ACxNA,WAAYmL;EACVA,yBAAA,aAAA;EACAA,iCAAA,qBAAA;AACD,CAHD,EAAYA,qBAAa,KAAbA,qBAAa,KAAA,CAAzB;;AAeA,IAAaC,SAAS,GAA8B,SAAvCA,SAAuC;MAClD5E,YAAAA;MACA5G,YAAAA;MACA8H,gBAAAA;MACA2D,iBAAAA;mCACAC;MAAAA,sDAAmB;MACnBxC,iBAAAA;MACAC,eAAAA;;EAEA,gBAAsDpI,cAAQ,CAC5D,KAD4D,CAA9D;MAAO4K,mBAAP;MAA4BC,sBAA5B;;EAIA,OACEtM,4BAAA,CAACS,cAAD;IACEC,IAAI,EAAEF,2BAAmB,CAAC4E;IAC1BzE,KAAK,EAAEyL,gBAAgB,GAAG,OAAH,GAAa;IACpCxL,MAAM,EAAE;GAHV,EAKGwL,gBAAgB,IAAIxC,SAApB,IAAiCC,OAAjC,GACC7J,4BAAA,wBAAA,MAAA,EACEA,4BAAA,CAACsI,eAAD;IACEtH,IAAI,EAAEN,IAAI,KAAKuL,qBAAa,CAACM,gBAAvB,GAA0C,KAA1C,GAAkD;GAD1D,EAGEvM,4BAAA,CAAC2J,cAAD;IACEC,SAAS,EAAEA;IACXC,OAAO,EAAEA;IACTrB,OAAO,EAAE;MACP,IAAIA,QAAJ,EAAa;QACXA,QAAO;;;GALb,CAHF,CADF,EAcG9H,IAAI,KAAKuL,qBAAa,CAACM,gBAAvB,IACCvM,4BAAA,CAACwM,kBAAD,MAAA,EACExM,4BAAA,CAACyM,YAAD;IAAc7G,GAAG,EAAEuG,SAAS,IAAIO;GAAhC,CADF,CAfJ,CADD,GAsBC1M,4BAAA,wBAAA,MAAA,EACEA,4BAAA,CAACa,WAAD,MAAA,EACEb,4BAAA,CAACsI,eAAD;IACEtH,IAAI,EAAEN,IAAI,KAAKuL,qBAAa,CAACM,gBAAvB,GAA0C,KAA1C,GAAkD;GAD1D,EAGEvM,4BAAA,CAACuI,aAAD;IACEG,WAAW,EAAE;MAAA,OAAM4D,sBAAsB,CAAC,KAAD,CAA5B;;IACb7D,SAAS,EAAE;MAAA,OAAM6D,sBAAsB,CAAC,IAAD,CAA5B;;IACXhF,IAAI,EAAEA,IAAI,IAAI;IACdkB,OAAO,EAAE;MACP,IAAIA,QAAJ,EAAa;QACXA,QAAO;;;GANb,CAHF,CADF,EAeG9H,IAAI,KAAKuL,qBAAa,CAACM,gBAAvB,IACCvM,4BAAA,CAACwM,kBAAD,MAAA,EACExM,4BAAA,CAACyM,YAAD;IAAc7G,GAAG,EAAEuG,SAAS,IAAIO;GAAhC,CADF,CAhBJ,CADF,EAsBGL,mBAAmB,IAClBrM,4BAAA,CAAC2M,mBAAD;IACEC,KAAK,EAAElM,IAAI,KAAKuL,qBAAa,CAACY,QAAvB,GAAkC,MAAlC,GAA2C;IAClDjH,GAAG,EAAEkH;GAFP,CAvBJ,CA3BJ,CADF;AA4DD,CAzEM;AA2EP,IAAMjM,WAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,kIAAf;AAeA,IAAMwH,eAAa,gBAAGnI,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,mCACT;EAAA,IAAGE,IAAH,SAAGA,IAAH;EAAA,OAAcA,IAAd;AAAA,CADS,CAAnB;AAKA,IAAMwL,kBAAkB,gBAAGrM,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,2DAAxB;AAMA,IAAM2L,YAAY,gBAAGtM,MAAM,CAAC2F,GAAV;EAAA;EAAA;AAAA,2DAAlB;AAUA,IAAM6G,mBAAmB,gBAAGxM,MAAM,CAAC2F,GAAV;EAAA;EAAA;AAAA,0GAEd;EAAA,IAAG8G,KAAH,SAAGA,KAAH;EAAA,OAAeA,KAAf;AAAA,CAFc,CAAzB;;IC7HaG,WAAW,GAAwB,SAAnCA,WAAmC;MAC9CC,WAAAA;MACAzK,aAAAA;MACAqJ,aAAAA;8BACAqB;MAAAA,4CAAc;kCACdC;MAAAA,oDAAkB;2BAClBC;MAAAA,sCAAW;MACXvG,aAAAA;;EAEA,IAAMwG,wBAAwB,GAAG,SAA3BA,wBAA2B,CAASJ,GAAT,EAAsBzK,KAAtB;IAC/B,IAAIA,KAAK,GAAGyK,GAAZ,EAAiB;MACfzK,KAAK,GAAGyK,GAAR;;;IAEF,OAAQzK,KAAK,GAAG,GAAT,GAAgByK,GAAvB;GAJF;;EAOA,OACEhN,4BAAA,CAACa,WAAD;IACEX,SAAS,EAAC;kBACEkN,wBAAwB,CAACJ,GAAD,EAAMzK,KAAN,CAAxB,GAAuC;sBACpC;IACf2K,eAAe,EAAEA;IACjBC,QAAQ,EAAEA;IACVvG,KAAK,EAAEA;GANT,EAQGqG,WAAW,IACVjN,4BAAA,CAACqN,WAAD,MAAA,EACErN,4BAAA,CAACsN,eAAD,MAAA,EACG/K,KADH,KAAA,EACWyK,GADX,CADF,CATJ,EAeEhN,4BAAA,MAAA;IAAKE,SAAS,EAAC;GAAf,EACEF,4BAAA,MAAA;IACEE,SAAS,2BAAyB0L,KAAzB;IACThF,KAAK,EAAE;MACL2G,IAAI,EAAE,KADD;MAEL5M,KAAK,EAAEyM,wBAAwB,CAACJ,GAAD,EAAMzK,KAAN,CAAxB,GAAuC;;GAJlD,CADF,CAfF,EAwBEvC,4BAAA,MAAA;IAAKE,SAAS,EAAC;GAAf,CAxBF,EAyBEF,4BAAA,MAAA;IAAKE,SAAS,EAAC;GAAf,CAzBF,CADF;AA6BD,CA7CM;AA+CP,IAAMoN,eAAe,gBAAGnN,MAAM,CAAC6L,IAAV;EAAA;EAAA;AAAA,8HAArB;AAWA,IAAMqB,WAAW,gBAAGlN,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,qCAAjB;AAWA,IAAMD,WAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,0HAGA,UAAAf,KAAK;EAAA,OAAIA,KAAK,CAACoN,QAAV;AAAA,CAHL,EAIJ,UAAApN,KAAK;EAAA,OAAIA,KAAK,CAACmN,eAAV;AAAA,CAJD,EAOX,UAAAnN,KAAK;EAAA,OAAIA,KAAK,CAAC6G,KAAV;AAAA,CAPM,CAAf;;ICrEa4G,UAAU,GAA0B,SAApCA,UAAoC;MAC/C1K,YAAAA;MACA2B,aAAAA;MACAR,gBAAAA;;EAEA,gBAA0CxC,cAAQ,EAAlD;MAAO6E,aAAP;MAAsBC,gBAAtB;;EACA,IAAMvB,WAAW,GAAG,SAAdA,WAAc;IAClB,IAAIC,OAAO,GAAGlD,QAAQ,CAACC,aAAT,iBACEc,IADF,eAAd;IAGA,IAAM2K,YAAY,GAAGxI,OAAO,CAAC1C,KAA7B;IACAgE,gBAAgB,CAACkH,YAAD,CAAhB;GALF;;EAQA7L,eAAS,CAAC;IACR,IAAI0E,aAAJ,EAAmB;MACjBrC,QAAQ,CAACqC,aAAD,CAAR;;GAFK,EAIN,CAACA,aAAD,CAJM,CAAT;EAMA,OACEtG,4BAAA,MAAA;IAAKgE,EAAE,EAAC;GAAR,EACGS,KAAK,CAACxB,GAAN,CAAU,UAAAgC,OAAO;IAChB,OACEjF,4BAAA,wBAAA,MAAA,EACEA,4BAAA,QAAA;MACEqD,GAAG,EAAE4B,OAAO,CAAC1C;MACbrC,SAAS,EAAC;MACVqC,KAAK,EAAE0C,OAAO,CAAC1C;MACfO,IAAI,EAAEA;MACNpC,IAAI,EAAC;KALP,CADF,EAQEV,4BAAA,QAAA;MAAO2D,OAAO,EAAEqB;KAAhB,EAA8BC,OAAO,CAACH,KAAtC,CARF,EASE9E,4BAAA,KAAA,MAAA,CATF,CADF;GADD,CADH,CADF;AAmBD,CAvCM;;ACPP,WAAY0N;EACVA,yBAAA,iBAAA;EACAA,6BAAA,wBAAA;AACD,CAHD,EAAYA,uBAAe,KAAfA,uBAAe,KAAA,CAA3B;;AAaA,IAAaC,WAAW,GAAgC,SAA3CA,WAA2C;MACtDjN,YAAAA;MACAkN,gBAAAA;MACAC,gBAAAA;MACAlN,aAAAA;MACAsD,gBAAAA;EAEA,IAAM6J,QAAQ,GAAGzH,OAAM,EAAvB;;EAEA,gBAAkD5E,cAAQ,CAAU,KAAV,CAA1D;MAAOsM,iBAAP;MAA0BC,oBAA1B;;EAEA7E,gBAAgB,CAAC,SAAD,EAAY;IAC1B,IAAI4E,iBAAJ,EAAuB;MACrBE,eAAe;;;IAEjBD,oBAAoB,CAAC,KAAD,CAApB;GAJc,CAAhB;;EAOA,IAAMC,eAAe,GAAG,SAAlBA,eAAkB;IACtB,IAAMC,WAAW,GAAGnM,QAAQ,CAACyE,cAAT,mBAAwCsH,QAAxC,CAApB;;IACA,IAAMvL,KAAK,GAAGwD,MAAM,CAACW,SAAP,CAAiBwH,WAAjB,CAAd;;IAEAjK,QAAQ,CAACkK,MAAM,CAAC5L,KAAD,CAAP,CAAR;GAJF;;EAOA,OACEvC,4BAAA,MAAA;IACEoO,SAAS,EAAEH;IACXI,WAAW,EAAE;MAAA,OAAML,oBAAoB,CAAC,IAAD,CAA1B;;GAFf,EAIEhO,4BAAA,CAACO,OAAD;IACEL,SAAS,EACPQ,IAAI,KAAKgN,uBAAe,CAACY,MAAzB,GACIZ,uBAAe,CAACY,MADpB,GAEIZ,uBAAe,CAACa;IAEtB7N,IAAI,EAAC;IACLkG,KAAK,EAAE;MAAEjG,KAAK,EAAEA;;IAChB6N,GAAG,EAAEZ;IACLZ,GAAG,EAAEa;IACL7J,EAAE,oBAAkB8J;GAVtB,CAJF,CADF;AAmBD,CA5CM;AA8CP,IAAMvN,OAAK,gBAAGJ,MAAM,CAACsO,KAAV;EAAA;EAAA;AAAA,kBAAX;;ACjEA,MAAM3I,KAAG,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;;ACS7B,IAAM4I,iBAAiB,GAAqB,SAAtCA,iBAAsC;MACjDnM,aAAAA;0BAEAoM;MAAAA,oCAAU;EAEV,OACE3O,4BAAA,CAACa,WAAD,MAAA,EACEb,4BAAA,CAAC4O,oBAAD,MAAA,EACE5O,4BAAA,CAAC6O,aAAD,MAAA,EACE7O,4BAAA,CAAC8O,QAAD;IAAUvM,KAAK,EAAEA;IAAOoM,OAAO,EAAEA;GAAjC,CADF,CADF,CADF,CADF;AASD,CAdM;AAgBP,IAAM9N,WAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,0EAAf;AAOA,IAAM+N,aAAa,gBAAG1O,MAAM,CAAC6L,IAAV;EAAA;EAAA;AAAA,2CAAnB;AASA,IAAM8C,QAAQ,gBAAG3O,MAAM,CAAC6L,IAAV;EAAA;EAAA;AAAA,2CACQ,UAACjM,KAAD;EAAA,OAA2BA,KAAK,CAAC4O,OAAjC;AAAA,CADR,EAEH,UAAC5O,KAAD;EAAA,OAA2BA,KAAK,CAACwC,KAAjC;AAAA,CAFG,CAAd;AAKA,IAAMqM,oBAAoB,gBAAGzO,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,0HAA1B;;IC/BaiO,gBAAgB,GAAqC,SAArDA,gBAAqD;MAChExM,aAAAA;MACAoM,eAAAA;MACAK,iBAAAA;0BAEAC;MAAAA,oCAAUC;EAEV,OACElP,4BAAA,wBAAA,MAAA,EACEA,4BAAA,CAACmP,aAAD,MAAA,EACEnP,4BAAA,CAACoP,SAAD,MAAA,EAAYJ,SAAZ,CADF,EAEEhP,4BAAA,CAACqP,YAAD,MAAA,EAAe9M,KAAf,CAFF,CADF,EAKEvC,4BAAA,CAACsP,YAAD,MAAA,EACEtP,4BAAA,CAACuP,qBAAD,MAAA,EACEvP,4BAAA,CAAC2F,MAAD;IAAMC,GAAG,EAAEqJ;GAAX,CADF,CADF,EAKEjP,4BAAA,CAAC0O,iBAAD;IAAmBnM,KAAK,EAAEA;IAAOoM,OAAO,EAAEA;GAA1C,CALF,CALF,CADF;AAeD,CAtBM;AAwBP,IAAMS,SAAS,gBAAGjP,MAAM,CAAC6L,IAAV;EAAA;EAAA;AAAA,wBAAf;AAIA,IAAMqD,YAAY,gBAAGlP,MAAM,CAAC6L,IAAV;EAAA;EAAA;AAAA,QAAlB;AAEA,IAAMuD,qBAAqB,gBAAGpP,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,+DAA3B;AAMA,IAAMwO,YAAY,gBAAGnP,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,wCAAlB;AAKA,IAAMqO,aAAa,gBAAGhP,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,wGAAnB;AAUA,IAAM6E,MAAI,gBAAGxF,MAAM,CAAC2F,GAAV;EAAA;EAAA;AAAA,sCAAV;;IC1Da0J,QAAQ,GAAwB,SAAhCA,QAAgC;MAAMzP;;EACjD,OAAOC,4BAAA,WAAA,oBAAcD,MAAd,CAAP;AACD,CAFM;;ACRP;AACA,IAQa0P,QAAQ,GAAqB,SAA7BA,QAA6B;2BAAGC;MAAAA,sCAAW;MAAG7P,gBAAAA;EACzD,OAAOG,4BAAA,CAACa,WAAD;IAAW6O,QAAQ,EAAEA;GAArB,EAAgC7P,QAAhC,CAAP;AACD,CAFM;AAQP,IAAMgB,WAAS,gBAAGV,MAAM,CAACW,GAAV;EAAA;EAAA;AAAA,gIAIS,UAAAf,KAAK;EAAA,OAAIA,KAAK,CAAC2P,QAAV;AAAA,CAJd,CAAf;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
1
|
+
{"version":3,"file":"long-bow.cjs.development.js","sources":["../src/components/Button.tsx","../src/constants/uiColors.ts","../src/components/Input.tsx","../src/components/RPGUIContainer.tsx","../src/components/shared/Column.tsx","../src/components/Chat/Chat.tsx","../src/components/CheckButton.tsx","../src/components/DraggableContainer.tsx","../src/components/RPGUIRoot.tsx","../src/components/Dropdown.tsx","../src/components/ListMenu.tsx","../src/libs/StringHelpers.ts","../src/components/typography/DynamicText.tsx","../src/components/NPCDialog/NPCDialogText.tsx","../src/hooks/useEventListener.ts","../src/components/NPCDialog/QuestionDialog/QuestionDialog.tsx","../src/components/NPCDialog/NPCDialog.tsx","../src/components/ProgressBar.tsx","../src/components/RadioButton.tsx","../src/components/RangeSlider.tsx","../src/components/SimpleProgressBar.tsx","../src/components/SkillProgressBar.tsx","../src/components/TextArea.tsx","../src/components/Truncate.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","export const colors = {\n darkGrey: '#3e3e3e',\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 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 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","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 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, { 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 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","export const chunkString = (str: string, length: number) => {\n return str.match(new RegExp('.{1,' + length + '}', 'g'));\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 { 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 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, { 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, { 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\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","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","/* 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"],"names":["ButtonTypes","Button","children","buttonType","props","React","ButtonContainer","className","styled","button","colors","darkGrey","Input","RPGUIContainerTypes","RPGUIContainer","type","width","height","Container","div","Column","flex","flexWrap","alignItems","justifyContent","Chat","chatMessages","onSendChatMessage","opacity","onCloseButton","useState","message","setMessage","useEffect","scrollChatToBottom","scrollingElement","document","querySelector","scrollTop","scrollHeight","handleSubmit","event","preventDefault","getInputValue","value","onRenderMessageLines","emitter","createdAt","dayjs","Date","format","name","onRenderChatMessages","length","map","index","_id","MessageText","key","CustomContainer","FramedGrey","ErrorBoundary","fallback","CloseButton","onClick","onTouchStart","Form","onSubmit","CustomInput","id","onChange","e","target","autoComplete","RPGUIButton","form","p","CheckButton","items","generateSelectedValuesList","selectedValues","forEach","item","label","setSelectedValues","handleClick","element","checked","DraggableContainer","FramedGold","title","imgSrc","imgWidth","Draggable","TitleContainer","Title","Icon","src","h1","img","_RPGUI","RPGUI","RPGUIRoot","Dropdown","options","dropdownId","uuidv4","selectedValue","setSelectedValue","getElementById","dropdownValue","get_value","addEventListener","style","option","ListMenu","onSelected","x","y","fontSize","overflow","params","ListElement","text","li","chunkString","str","match","RegExp","DynamicText","onFinish","onStart","textState","setTextState","i","interval","setInterval","substring","clearInterval","TextContainer","NPCDialogText","onClose","onEndStep","onStartStep","textChunks","chunkIndex","setChunkIndex","onHandleSpacePress","code","hasNextChunk","prev","removeEventListener","useEventListener","handler","el","window","savedHandler","useRef","current","listener","QuestionDialog","questions","answers","currentQuestion","setCurrentQuestion","canShowAnswers","setCanShowAnswers","onGetFirstAnswer","answerIds","firstAnswerId","find","answer","currentAnswer","setCurrentAnswer","onGetAnswers","answerId","onKeyPress","nextAnswerIndex","findIndex","nextAnswerID","nextAnswer","previousAnswerIndex","previousAnswerID","previousAnswer","pop","nextQuestionId","question","onAnswerClick","onRenderCurrentAnswers","isSelected","selectedColor","AnswerRow","AnswerSelectedIcon","color","Answer","QuestionContainer","AnswersContainer","span","NPCDialogType","NPCDialog","imagePath","isQuestionDialog","showGoNextIndicator","setShowGoNextIndicator","TextAndThumbnail","ThumbnailContainer","NPCThumbnail","aliceDefaultThumbnail","PressSpaceIndicator","right","TextOnly","pressSpaceGif","ProgressBar","max","displayText","percentageWidth","minWidth","calculatePercentageValue","TextOverlay","ProgressBarText","left","InputRadio","elementValue","RangeSliderType","RangeSlider","valueMin","valueMax","sliderId","wasMouseDownFirst","setWasMouseDownFirst","onHandleMouseUp","rpguiSlider","Number","onMouseUp","onMouseDown","Slider","GoldSlider","min","input","SimpleProgressBar","bgColor","ProgressBarContainer","BackgroundBar","Progress","SkillProgressBar","titleName","logoSrc","imgSrcTemplate","ProgressTitle","TitleName","ValueDisplay","ProgressBody","ProgressIconContainer","TextArea","Truncate","maxLines"],"mappings":"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"}
|