From 2623299e889ff160460cae6ef0a132ffc97133fc Mon Sep 17 00:00:00 2001 From: NontasBak Date: Wed, 7 Aug 2024 11:51:52 +0300 Subject: [PATCH] Allow player to drag and drop ship placement --- main.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/main.js b/main.js index 081b2cc..574950e 100644 --- a/main.js +++ b/main.js @@ -1,2 +1,2 @@ -(()=>{"use strict";var n={430:(n,e,t)=>{t.d(e,{A:()=>A});var r=t(354),o=t.n(r),a=t(314),i=t.n(a)()(o());i.push([n.id,"html, body, div, span, applet, object, iframe,\nh1, h2, h3, h4, h5, h6, p, blockquote, pre,\na, abbr, acronym, address, big, cite, code,\ndel, dfn, em, img, ins, kbd, q, s, samp,\nsmall, strike, strong, sub, sup, tt, var,\nb, u, i, center,\ndl, dt, dd, ol, ul, li,\nfieldset, form, label, legend,\ntable, caption, tbody, tfoot, thead, tr, th, td,\narticle, aside, canvas, details, embed, \nfigure, figcaption, footer, header, hgroup, \nmenu, nav, output, ruby, section, summary,\ntime, mark, audio, video, button {\n\tmargin: 0;\n\tpadding: 0;\n\tborder: 0;\n\tfont-size: 100%;\n\tfont: inherit;\n\tvertical-align: baseline;\n}\n/* HTML5 display-role reset for older browsers */\narticle, aside, details, figcaption, figure, \nfooter, header, hgroup, menu, nav, section {\n\tdisplay: block;\n}\nbody {\n\tline-height: 1;\n}\nol, ul {\n\tlist-style: none;\n}\nblockquote, q {\n\tquotes: none;\n}\nblockquote:before, blockquote:after,\nq:before, q:after {\n\tcontent: '';\n\tcontent: none;\n}\ntable {\n\tborder-collapse: collapse;\n\tborder-spacing: 0;\n}","",{version:3,sources:["webpack://./src/reset.css"],names:[],mappings:"AAAA;;;;;;;;;;;;;CAaC,SAAS;CACT,UAAU;CACV,SAAS;CACT,eAAe;CACf,aAAa;CACb,wBAAwB;AACzB;AACA,gDAAgD;AAChD;;CAEC,cAAc;AACf;AACA;CACC,cAAc;AACf;AACA;CACC,gBAAgB;AACjB;AACA;CACC,YAAY;AACb;AACA;;CAEC,WAAW;CACX,aAAa;AACd;AACA;CACC,yBAAyB;CACzB,iBAAiB;AAClB",sourcesContent:["html, body, div, span, applet, object, iframe,\nh1, h2, h3, h4, h5, h6, p, blockquote, pre,\na, abbr, acronym, address, big, cite, code,\ndel, dfn, em, img, ins, kbd, q, s, samp,\nsmall, strike, strong, sub, sup, tt, var,\nb, u, i, center,\ndl, dt, dd, ol, ul, li,\nfieldset, form, label, legend,\ntable, caption, tbody, tfoot, thead, tr, th, td,\narticle, aside, canvas, details, embed, \nfigure, figcaption, footer, header, hgroup, \nmenu, nav, output, ruby, section, summary,\ntime, mark, audio, video, button {\n\tmargin: 0;\n\tpadding: 0;\n\tborder: 0;\n\tfont-size: 100%;\n\tfont: inherit;\n\tvertical-align: baseline;\n}\n/* HTML5 display-role reset for older browsers */\narticle, aside, details, figcaption, figure, \nfooter, header, hgroup, menu, nav, section {\n\tdisplay: block;\n}\nbody {\n\tline-height: 1;\n}\nol, ul {\n\tlist-style: none;\n}\nblockquote, q {\n\tquotes: none;\n}\nblockquote:before, blockquote:after,\nq:before, q:after {\n\tcontent: '';\n\tcontent: none;\n}\ntable {\n\tborder-collapse: collapse;\n\tborder-spacing: 0;\n}"],sourceRoot:""}]);const A=i},208:(n,e,t)=>{t.d(e,{A:()=>m});var r=t(354),o=t.n(r),a=t(314),i=t.n(a),A=t(417),s=t.n(A),c=new URL(t(126),t.b),l=new URL(t(356),t.b),d=new URL(t(837),t.b),p=i()(o()),u=s()(c),h=s()(l),g=s()(d);p.push([n.id,`* {\n box-sizing: border-box;\n}\n\nbody {\n font-family: "Roboto Mono", monospace;\n font-optical-sizing: auto;\n font-weight: 500;\n font-style: normal;\n\n display: flex;\n flex-direction: column;\n /* align-items: center; */\n justify-content: center;\n /* margin: -3vw; */\n /* height: 100vh; */\n\n position: relative;\n}\n\n.header {\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 2rem;\n font-size: calc(2.5rem + 1vw);\n}\n\n.game-container {\n display: flex;\n justify-content: space-around;\n align-items: center;\n flex-wrap: wrap;\n /* margin-top: 20vh; */\n /* width: 70vw; */\n}\n\n.player-container,\n.computer-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n\n position: relative;\n /* margin: 2rem; */\n}\n\n.player-container > h4,\n.computer-container > h4 {\n padding: 1rem;\n font-size: 1.5rem;\n}\n\n.board {\n display: grid;\n grid-template-columns: repeat(10, 1fr);\n grid-template-rows: repeat(10, 1fr);\n width: clamp(400px, 30vw, 800px);\n height: clamp(400px, 30vw, 800px);\n border: 2px solid black;\n}\n\n.cell {\n border: 1px solid black;\n}\n\n.computer .cell:hover {\n background-image: url(${u});\n background-size: cover;\n background-size: 80%;\n background-repeat: no-repeat;\n background-position: center;\n cursor: pointer;\n}\n\n.computer .cell.hit:hover {\n cursor: not-allowed;\n}\n\n.player .cell.ship {\n background-color: rgb(127, 186, 39);\n /* border: 2px solid rgb(0, 79, 0); */\n}\n\n.cell.water.hit {\n background-image: url(${h});\n background-size: 120%;\n background-position: 0 10px;\n background-repeat: no-repeat;\n}\n\n.cell.ship.hit {\n border: 2px solid rgb(0, 67, 0);\n background: url(${g}), greenyellow;\n background-size: 80%;\n background-position: center;\n background-repeat: no-repeat;\n}\n\n.cell.ship.hit.sunk {\n border: 2px solid rgb(156, 8, 8);\n background: url(${g}), rgb(255, 204, 204);\n background-size: 80%;\n background-position: center;\n background-repeat: no-repeat;\n}\n\n@keyframes fadeIn {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n}\n\n.restart-game-container {\n position: absolute;\n transform: translate(-50%, -50%);\n top: 50%;\n left: 50%;\n backdrop-filter: blur(2px);\n width: 100vw;\n height: 100vh;\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: 2rem;\n\n animation: fadeIn 0.5s;\n}\n\n.restart-game-container h2 {\n font-size: 3rem;\n font-weight: 700;\n}\n\n.restart-game-container button {\n padding: 1rem 2rem;\n font-size: 1.5rem;\n background-color: rgb(0, 0, 0, 0.8);\n color: white;\n border-radius: 5px;\n cursor: pointer;\n\n transition: background-color 0.3s;\n}\n\n.restart-game-container button:hover {\n background-color: rgb(0, 0, 0, 0.9);\n}\n\n.start-game-container {\n position: absolute;\n transform: translate(-50%, -50%);\n top: 50%;\n left: 50%;\n backdrop-filter: blur(2px);\n width: 101%;\n height: 101%;\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: 20%;\n}\n\n.start-game-container button {\n padding: 1rem 2rem;\n font-size: 1.5rem;\n border-radius: 0.5rem;\n background-color: rgb(40, 40, 40);\n color: white;\n\n transition: background-color 0.3s;\n}\n\n.start-game-container button:hover {\n background-color: rgb(0, 0, 0);\n}\n`,"",{version:3,sources:["webpack://./src/style.css"],names:[],mappings:"AAAA;IACI,sBAAsB;AAC1B;;AAEA;IACI,qCAAqC;IACrC,yBAAyB;IACzB,gBAAgB;IAChB,kBAAkB;;IAElB,aAAa;IACb,sBAAsB;IACtB,yBAAyB;IACzB,uBAAuB;IACvB,kBAAkB;IAClB,mBAAmB;;IAEnB,kBAAkB;AACtB;;AAEA;IACI,aAAa;IACb,uBAAuB;IACvB,mBAAmB;IACnB,aAAa;IACb,6BAA6B;AACjC;;AAEA;IACI,aAAa;IACb,6BAA6B;IAC7B,mBAAmB;IACnB,eAAe;IACf,sBAAsB;IACtB,iBAAiB;AACrB;;AAEA;;IAEI,aAAa;IACb,sBAAsB;IACtB,mBAAmB;;IAEnB,kBAAkB;IAClB,kBAAkB;AACtB;;AAEA;;IAEI,aAAa;IACb,iBAAiB;AACrB;;AAEA;IACI,aAAa;IACb,sCAAsC;IACtC,mCAAmC;IACnC,gCAAgC;IAChC,iCAAiC;IACjC,uBAAuB;AAC3B;;AAEA;IACI,uBAAuB;AAC3B;;AAEA;IACI,yDAA2C;IAC3C,sBAAsB;IACtB,oBAAoB;IACpB,4BAA4B;IAC5B,2BAA2B;IAC3B,eAAe;AACnB;;AAEA;IACI,mBAAmB;AACvB;;AAEA;IACI,mCAAmC;IACnC,qCAAqC;AACzC;;AAEA;IACI,yDAAwC;IACxC,qBAAqB;IACrB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI,+BAA+B;IAC/B,gEAAgD;IAChD,oBAAoB;IACpB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI,gCAAgC;IAChC,uEAAuD;IACvD,oBAAoB;IACpB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI;QACI,UAAU;IACd;IACA;QACI,UAAU;IACd;AACJ;;AAEA;IACI,kBAAkB;IAClB,gCAAgC;IAChC,QAAQ;IACR,SAAS;IACT,0BAA0B;IAC1B,YAAY;IACZ,aAAa;;IAEb,aAAa;IACb,sBAAsB;IACtB,uBAAuB;IACvB,mBAAmB;IACnB,SAAS;;IAET,sBAAsB;AAC1B;;AAEA;IACI,eAAe;IACf,gBAAgB;AACpB;;AAEA;IACI,kBAAkB;IAClB,iBAAiB;IACjB,mCAAmC;IACnC,YAAY;IACZ,kBAAkB;IAClB,eAAe;;IAEf,iCAAiC;AACrC;;AAEA;IACI,mCAAmC;AACvC;;AAEA;IACI,kBAAkB;IAClB,gCAAgC;IAChC,QAAQ;IACR,SAAS;IACT,0BAA0B;IAC1B,WAAW;IACX,YAAY;;IAEZ,aAAa;IACb,sBAAsB;IACtB,uBAAuB;IACvB,mBAAmB;IACnB,QAAQ;AACZ;;AAEA;IACI,kBAAkB;IAClB,iBAAiB;IACjB,qBAAqB;IACrB,iCAAiC;IACjC,YAAY;;IAEZ,iCAAiC;AACrC;;AAEA;IACI,8BAA8B;AAClC",sourcesContent:['* {\n box-sizing: border-box;\n}\n\nbody {\n font-family: "Roboto Mono", monospace;\n font-optical-sizing: auto;\n font-weight: 500;\n font-style: normal;\n\n display: flex;\n flex-direction: column;\n /* align-items: center; */\n justify-content: center;\n /* margin: -3vw; */\n /* height: 100vh; */\n\n position: relative;\n}\n\n.header {\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 2rem;\n font-size: calc(2.5rem + 1vw);\n}\n\n.game-container {\n display: flex;\n justify-content: space-around;\n align-items: center;\n flex-wrap: wrap;\n /* margin-top: 20vh; */\n /* width: 70vw; */\n}\n\n.player-container,\n.computer-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n\n position: relative;\n /* margin: 2rem; */\n}\n\n.player-container > h4,\n.computer-container > h4 {\n padding: 1rem;\n font-size: 1.5rem;\n}\n\n.board {\n display: grid;\n grid-template-columns: repeat(10, 1fr);\n grid-template-rows: repeat(10, 1fr);\n width: clamp(400px, 30vw, 800px);\n height: clamp(400px, 30vw, 800px);\n border: 2px solid black;\n}\n\n.cell {\n border: 1px solid black;\n}\n\n.computer .cell:hover {\n background-image: url("./icons/target.png");\n background-size: cover;\n background-size: 80%;\n background-repeat: no-repeat;\n background-position: center;\n cursor: pointer;\n}\n\n.computer .cell.hit:hover {\n cursor: not-allowed;\n}\n\n.player .cell.ship {\n background-color: rgb(127, 186, 39);\n /* border: 2px solid rgb(0, 79, 0); */\n}\n\n.cell.water.hit {\n background-image: url("./icons/sea.png");\n background-size: 120%;\n background-position: 0 10px;\n background-repeat: no-repeat;\n}\n\n.cell.ship.hit {\n border: 2px solid rgb(0, 67, 0);\n background: url("./icons/fire.png"), greenyellow;\n background-size: 80%;\n background-position: center;\n background-repeat: no-repeat;\n}\n\n.cell.ship.hit.sunk {\n border: 2px solid rgb(156, 8, 8);\n background: url("./icons/fire.png"), rgb(255, 204, 204);\n background-size: 80%;\n background-position: center;\n background-repeat: no-repeat;\n}\n\n@keyframes fadeIn {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n}\n\n.restart-game-container {\n position: absolute;\n transform: translate(-50%, -50%);\n top: 50%;\n left: 50%;\n backdrop-filter: blur(2px);\n width: 100vw;\n height: 100vh;\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: 2rem;\n\n animation: fadeIn 0.5s;\n}\n\n.restart-game-container h2 {\n font-size: 3rem;\n font-weight: 700;\n}\n\n.restart-game-container button {\n padding: 1rem 2rem;\n font-size: 1.5rem;\n background-color: rgb(0, 0, 0, 0.8);\n color: white;\n border-radius: 5px;\n cursor: pointer;\n\n transition: background-color 0.3s;\n}\n\n.restart-game-container button:hover {\n background-color: rgb(0, 0, 0, 0.9);\n}\n\n.start-game-container {\n position: absolute;\n transform: translate(-50%, -50%);\n top: 50%;\n left: 50%;\n backdrop-filter: blur(2px);\n width: 101%;\n height: 101%;\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: 20%;\n}\n\n.start-game-container button {\n padding: 1rem 2rem;\n font-size: 1.5rem;\n border-radius: 0.5rem;\n background-color: rgb(40, 40, 40);\n color: white;\n\n transition: background-color 0.3s;\n}\n\n.start-game-container button:hover {\n background-color: rgb(0, 0, 0);\n}\n'],sourceRoot:""}]);const m=p},314:n=>{n.exports=function(n){var e=[];return e.toString=function(){return this.map((function(e){var t="",r=void 0!==e[5];return e[4]&&(t+="@supports (".concat(e[4],") {")),e[2]&&(t+="@media ".concat(e[2]," {")),r&&(t+="@layer".concat(e[5].length>0?" ".concat(e[5]):""," {")),t+=n(e),r&&(t+="}"),e[2]&&(t+="}"),e[4]&&(t+="}"),t})).join("")},e.i=function(n,t,r,o,a){"string"==typeof n&&(n=[[null,n,void 0]]);var i={};if(r)for(var A=0;A0?" ".concat(l[5]):""," {").concat(l[1],"}")),l[5]=a),t&&(l[2]?(l[1]="@media ".concat(l[2]," {").concat(l[1],"}"),l[2]=t):l[2]=t),o&&(l[4]?(l[1]="@supports (".concat(l[4],") {").concat(l[1],"}"),l[4]=o):l[4]="".concat(o)),e.push(l))}},e}},417:n=>{n.exports=function(n,e){return e||(e={}),n?(n=String(n.__esModule?n.default:n),/^['"].*['"]$/.test(n)&&(n=n.slice(1,-1)),e.hash&&(n+=e.hash),/["'() \t\n]|(%20)/.test(n)||e.needQuotes?'"'.concat(n.replace(/"/g,'\\"').replace(/\n/g,"\\n"),'"'):n):n}},354:n=>{n.exports=function(n){var e=n[1],t=n[3];if(!t)return e;if("function"==typeof btoa){var r=btoa(unescape(encodeURIComponent(JSON.stringify(t)))),o="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(r),a="/*# ".concat(o," */");return[e].concat([a]).join("\n")}return[e].join("\n")}},72:n=>{var e=[];function t(n){for(var t=-1,r=0;r{var e={};n.exports=function(n,t){var r=function(n){if(void 0===e[n]){var t=document.querySelector(n);if(window.HTMLIFrameElement&&t instanceof window.HTMLIFrameElement)try{t=t.contentDocument.head}catch(n){t=null}e[n]=t}return e[n]}(n);if(!r)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");r.appendChild(t)}},540:n=>{n.exports=function(n){var e=document.createElement("style");return n.setAttributes(e,n.attributes),n.insert(e,n.options),e}},56:(n,e,t)=>{n.exports=function(n){var e=t.nc;e&&n.setAttribute("nonce",e)}},825:n=>{n.exports=function(n){if("undefined"==typeof document)return{update:function(){},remove:function(){}};var e=n.insertStyleElement(n);return{update:function(t){!function(n,e,t){var r="";t.supports&&(r+="@supports (".concat(t.supports,") {")),t.media&&(r+="@media ".concat(t.media," {"));var o=void 0!==t.layer;o&&(r+="@layer".concat(t.layer.length>0?" ".concat(t.layer):""," {")),r+=t.css,o&&(r+="}"),t.media&&(r+="}"),t.supports&&(r+="}");var a=t.sourceMap;a&&"undefined"!=typeof btoa&&(r+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a))))," */")),e.styleTagTransform(r,n,e.options)}(e,n,t)},remove:function(){!function(n){if(null===n.parentNode)return!1;n.parentNode.removeChild(n)}(e)}}}},113:n=>{n.exports=function(n,e){if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}},837:n=>{n.exports="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAABuwAAAbsBOuzj4gAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAAepSURBVHic1ZtbcFVXHcZ/a1/OSU5CIIRrQUsZLm1IO6A0CWlFqR3rODVAghmlfVAmTYo+VHmoOvpQZjqdcXQqPKhF7XTGOqMDU9JKddqxdpQRGYRWQQhtMxRLWyi0oSQkJzmXvf8+BGgue++zr8fyvZzZa33/y/n22mutvdbaSkT4v6J1+Sx0tlGw29Eo8oe+FeUMb5Qz2AR0r/kUYn+f7Ogmrt6E6oq/lTuN8gvQeXsDur4dkY2AYnwL1PWD5U6nfAJsa6lkuLgDTetERHPORv9j2fK5AlWWPuDB5nps2Q1Mfb5PnRv71ZTw57echUkQyQfsbtqMLYdx+vPjYRiDiefiFDZR791NmxGexo/Qhv7fRHNxC5uY567mduA3+G1lhvZKYrl4IJlHoLv5TpDfAbp/I3UmkVxKIH4BuldPR+S3gBnITkll7Ln4QPwCiP4z4MbgdlTEnosPxCtA15pW4L5Qtup6F2C70sB+LLS9Jde5AO823Uepsd4L13ULUEqh5JFIPkTqYsklIOIRoLPxToTFkXwUrE/HkktAxNUCvhrZR75QS3v9/BiyCYToAnR06CCbIvsRQOyHQtluvnVu2LDRBZh+5i5gTmQ/AAV7Q2CbjTc/zED232FDRhdAs78W2cdVjOaWsWnFKt/8+5fWkM09ymhhHm31j4YJGU2AjoYUojZG8jEetihGRl9mu/L3knZZ7aNojU25h7PfpXX5rKAhowkwM9MMzIjkYzJGCzN4delLJXlt9d9hOLf22nXRNkD2BQ0XTQBLuzWSvRuGRj/L+mUvON7R+5fW0LrsnwwMPc7k1axsrpmO5QuChIq2HqCkIZK9F4ZG70HXzrN++T50/SC2vQiRheSsuykUnWeNIlBgO9DpN0zUBZHkBACwbI2hkfXAet82OWsDAQSIOgokK0AY5PJ1dDTU+6WHF2BrywLi7gDjQqGw1S81vABW8ZbQtknDEt+5RXkEZkawTRYin/RLjSLA9Ai2ycKyZ/ulRhBA+/gKIP5HN3cBHmi+jS2Nn/Cw/fgKoFTOL9VdAMVqDPU831pX7Vgv1ATPrExQjPilugsgshi4jXx2D99YN3XmpUSFSq4c0NV7fqlefcBNACi+iDnyEt/8TO2ket8qu6Iqj9zTj3z+YmRXE2AaPX6pXo/AuDU+uYNi/u880HTTR0Vkw2UHMmsIa20fxdajqEVZOBPjppBSYFf83C+9dAv4CPUojtLVvOWKZfAWkC5iN5/G+kIvsvBDUILkdFRfjAKkzH56/nVpQll7/Vo6GhznLc4CdK/OAE7rbNNAnqSr8TlETQuSl9QNUbz3GPbi9ydWxHn3AUztwITrTcu/xFD2ZeyC47Kd83iZn2ZjerVw1QrS6jcnmTeItbYPDGtq5btpv25KQykwzUeuXbfd8jhDuYewbA0r49gxuh+R6Wq6CEzu+AJD5g5irXsdNOc4xs75MBjTMYXK1DukzJ3YUk++0EauMDZX8Th+4xX5LFEFMC2s5jdd/zyAzC6g4hJgJL+QkfyPp5Tret7NxKMTlLNR87FXvg1VrrHHMKdEfRzQtCHXKncrdS5KTJlzGXvphdLEJaFHU//Q1CXXKlcjJceixLSXnvfFU1VFqC1GCVUahup1q3IXwDKeCx/QRha4ij4RAtJ+HlL2xPIZRWTLWagrhE7jGpS507XK86BkV9NxQuz5y6J+rJZTvrjGladEbA2OTkP1ZZBlWdTKQUCQooZ6MtBK90SYRo4X3nQ9e+C9HiA8GyamfWN/YBul2ahVA9BxDrVygLHdUlCGjXz5gzBpjCFlHvGq9hZADyeAzHLtdENB3TCC3DwcztjUd3lVewvwxKEjwOFAATWBdAKdWlOIk7QpY5hnep/2opReEhPt4SAxpTKZcV1VFiFtlyaOR0XFD0tRSgvwq4N/Bf7kO2hlDL22EwRkWYA5Q0XqfXp6d5Si+VsUVfr3AH/yZxKc2c0I8GilzQf90PwJsOsf/0Hw7EyuQlIJTmoyDm+Tjrz0Cfae3OuH6n9ZfGD426AOlKKpwQSP/J738eqcNgepTDf7delfgN3H8+h6G/CWF01dzFwdwmOH6st4EwytSHXlGnYf9z0OB9sY+cWBC2isB9wH5aKOupxEK1Aw7PXupqCmajO7j7vO+50QfGfoiUNHgXbgsiunvyqw21KQEY9PDzQlTM/8gD0n9gT1G25r7JeHXsS2W4DTjk7fmAtxbxsccdmHMbQi1RVtPHMy1EHt8HuDvz58HGU1IuyfXKX6q9BOzgvtejLkwzSq16FVpcwBaitX0PN6qCk7RD0hsuvIB2jW3cBPgQkzIO3YQtRAHH2BQj07a3IRVKVfxay9gd+ffCOS99i+G+xsWYJmPQZ85WqR1A1j3fUamO7jt+G1aKRA9s+cePcrUu+QSn+dnhN/iSHrBD6c7Ly9EU39CNTnAMjksZpOI/MHHOluAoiloZ6fDe+lxgoqzEukzW3sfe2pONNN7svRzpYlaPYGYAPIGnvJBc1e9faU1jBFAAVyOoN6sW5sUmMa+9GMHXHd8ckoz6ezW++Yg2XdS/XoKpk72CAzsoukZnS21GYzxuWCkoIuDJoWFyqH1KmaMwxUvELK+EnQMT0M/gdWGE+/XO39uQAAAABJRU5ErkJggg=="},356:n=>{n.exports="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAACXBIWXMAAAHYAAAB2AH6XKZyAAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAABRtJREFUeJztmztsHEUYgL/Z27uzz/b5TRQTHGggiQugQYooaBAUiCSA4gYU6lAgBDQUSKFCoiESQqHmEeJDeYh0hBSIFJFCgVDsXHAeJMJ54LN9Z99jn/NTJAd2OPvetyjZr92d+f75d3Z2/t07CAkJCQl5cFFBiVPTEiNGPwAOuckJ5XTSLyJKKSUqlZYTAi8B51GcUB6fTU6oxXZIj87IZs9gP7ALmADMu4c84LwI3xuaQ5MT6lY7/IcvykhEeFvBboEdCCfVVFo0a2dCDsVHk49zUCklrRCLiEr9zlsInwCJKqcXFby/9wm+aKk/zXsoPgSSqw+pqbRUlCjFMcti374nVaEZ+clfJFHq5bDA7roaCsdVL69PPqJKzfhT09JLhK/X8xvr+oVX43FOffObDDYqP3ZBhou9/Fj34AEUr0iBU6lpGWrGLxFOb+RfNwF32WlGOfPtBXm0XvnRGdnqKM4AO+ttu4pnJcKZ1LSM19swlZbHXMXPwDMbnVctAaDYYRicnbogL9cqn7ooezyDcwq21dpmA7ZLhHOptOyqtcGRtOwWOAtsr3buumtARYTjSjg0s53TB5TSaw6JqCNpdhqKd4HXau6zDhR8h/Dp3m2cvXeBPCBibEvzvFLsB/bU3GddCfg3ktsIvwLzd+JiBHgaeKjuvhphrR9gFMVTCJvq7qqhBNxHVF8D7nPCBAQdQNCECQg6gKAxfbmTBdXhwlgEyhuJIP3m+dsOCuiOKpJxg+GEgWm0JxpPCwtFTc7SWJ5Qfv6W/X1xg5EO+00AAYquUHR9/ir4jPWZDCWMlr0tEWCxqLmx4qEr7DpW++cLPmNJk+Hu1t2dG/nNe0/WAn8ue6zYBuMDJs1eDC1wPeeRs3T1k8v+nEfeNhjvN5u+Nar5101zztZcWXLxm9gn+gJXltyaB7+arKW53AH/hvOs4AizCy5OpXlbBVcLlxZcCk7jIyg4d/pop7/qjWZ7wmzGZbmOq7hia2YzHpbXfJlhecJsxiNnt8f/nzWgEp6Gq1mPgS6D0Z4IiWjlG7PoCPNFn2wDU35jv3BtyaO/22A00Vp/TQkok7U0WUsTNRTdUYVplAOEkiu4DUzVWhEgW9JkS/f4BTxp3F9XAsq4WnDt4KroVvof+K1wmICgAwiaMAFBBxA0hpbWPrPrQYsmaL85c+sahlLEozGS8QSDiT5MI9IWoad9loorLNtFLMehXBAbShE3YyS7Ou83AbQIJcem5NjM53NsTg4xmOhrqXypuMLN5cWKV1yLUHJtSm7n/RXKYc1cLkPeKfFw/yhGk/WoFmEuO0/Oqu0j82r/loFRVJNvJar5190J5koFPN9nfHATEaOxtdLXmutLtyk4Vt1ty/6tQ5swVPv8VcphiysLN3B9v2655/tcXbjZ0ODX+DM32+qvoRx2uZyZY8Wu/XcKK3aJS5k5LK/5n/1YnsPlhTnybfLXWA77XFu8xUB3L8M9Sbqj8crBujbzhWVypXzNwdbk933+uOsf6emnKxprmb++criUJ1vKE41E6IrG/3lceb6P5dkNTdXG/CZd0VhL/I2Vw76P6xcbadoSXN/D9b2W9BVuhYMOIGjCBAQdQNCECQg6gKAJE9DxD/P/J5TCSERjwb2SCZgeM6aNLX3Jg8H9bSJAFIz1932uAN45lflyLpt7w/bcByIVMTMqW5L9Xx18ceTNNQP+4If557xIZCyowDqB6fs3Pn5h9Keg4wgJCQkJ+T/wNxL4/hbh21SVAAAAAElFTkSuQmCC"},126:n=>{n.exports="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAB2AAAAdgB+lymcgAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAAtySURBVHic7Vt5cFXVGf995y5viexIAAtYhbAXFC3uIKAFRTuMEzsCgYBA2TOibW117BvHaTutU6VSq4BJGBA7pRghWKhKrYMoiOKC7EstWiBhS5TkvXffvffrHy/Le3n3nnvzEkhn6m8mMzfnfOfbzvZ955xHaCNEIhFx4ODJDwDmAf17joxEInZb6KG2hVAAOHSoogPAIxq/cb4t9BBtIfR/Cd86oK0VaGvQpRLEUx/qC5GYAEW5AUK92ibudIaRJwjoDDoimM+A+SuwvQcxsZ5eeWbvpdDrojmA8/MVBHvMZU2ZAV0bQpoaaFb7hGWQZR5BwizFlZ2eoUjEvBh6troDeFpRbyZ6gXICd0BRWmeXsWwT8fi7MLGQVrXuyGg1B3D+/O7cTltPodCNEOKijCy2GRSNvwcY+VS87ERr8GyxogwQpi1+GjnBIqiq0hpKecq0LJtisReoeOmClvJqkQP4gaJczlF3UijQp6WKZCX/bNX7VF11N72+NusgKuttkKfMv5PbB463lfEAQJpyIyv6hzypYGC2PLJyABcuKkTH9ptJV/VsBbcGOBoHCFexrWzne6ffnA2PZk8BnrF4OsLhkqwWOl2HPWww7Ct7gYMhmJVnk0rEDYjzVVAqT0P58ksgZoBNE7AZsO1GTYUCEgQQgWNxIBZP5V5DNsZReemO5qjULCN42uIf4rJQGRTFdzvOCcOaMA40fAhEuxxQSsvqeNLGNIWiMah790N7bye0D3eDjERzVDxLoNtoQ8k+vw38GzJjSS8E1aNQVc0XfTgMq+B+KAP7JnutCeIWUOthm6j+GvqmLQj8/a3mOOIo6foIWre82g+x/0BFo+1+jTfHjYa4eyxUJXOJMSwgZgIWOzRsArtDe8Sm3A9j3GiEVq6CtsdXx17NRnwlgHw/xL5GABcWrUS7nAc9CYWAuWg21Kt7Z1RZnOxxM9tjD2YEyzYhuK4MYG/vEfNU2rjqZU86T7mTF/RBp3bHIIR8x9B1mD8vgtqlY0ZVzEz+NVXbrlvgvFinidm+A+HnVwKW5UVaQYQB9FpplYzIW3I4sM5TQyFgPpppPAOoSQBRF+OffOyXePLxSIMj/MC4+QbULpiNtNXUGbk24xdeRFLDuHDhUAQD13sxMRfOgtq1ifEMXDCSc94JsVgMlRWVqDxVgVgs5iUiDcZNIxHLn+RJR8B8vmdOVxmNvGcVfZmXp80xt0Htmx4MMoALLZnvPhCbNBHmkEFeZDm2YiyUEbg6gCMRlXVNGl1xOAwx8Y6M8guGD+NTh30zpkADiFA7ezpYl29MxJjBkYirne7b4L+qfkLtw9LszpqaD1VN5y1b6ckwoG99B9qOXdCOHAUCSfEdflyEQL++SIy8DsbYUWDdX4Rt53ZD/M6xCG7aIiPrjd3HRgF426nS3QG6mCLjyqEQlEH90soMKxngOEH7+DOEVpRCnEsmbvHUqWUz1AOHoB44hED5ZkTnzEBi+FCZ+EaZE8cj8MZWaaBkk5gEFwe4rwGq0lcm2LprXFqEZ7N7ZBd4823k/G5pg/EAQCl7eeq3OHceOb99FoG3/ikT3yi3Ywckrr1GSkPg293qHB3AU+f1h6rJz/CGD0n712mrAwDtk88QKlmTMc/DAO4ybdydsBBu2si2ESpeDe3Tz6Uq1CNxy0gPChrMkwq6OdU4jwA1eJ+UX0CH0v6yhn9N23m7I8NAaMUq10VuqmFiSsJlztg2Qi8Wg+KGVBUAMAcNBOShCsGiwU4Vzq2ELZ2A9tDBabtjzOW8Vt/6DsTZczJWUohz56G/vc2TjsMhWL2u8OLW37HUkSFRLxkr+6rGfd9iIOGy6ms7dklVilPyTwZtp5xHgx49e0jrbdB3ncrVSCQi6i4nG5mR6CJNEzs3Rn3xlN63bbsxqrNtaEePIk4EYs6Y55tVBWv15C47OWFiQhMv1gJgIuDwEdReuNAwxIPBoGNkbnfpLNMYMXDXyZPndUoty8vLrVbrrqhHpFacB+NyGbdgsOGzXu/62L6yorKRTm904wTTQkHdQhEnYK2uoH72r9VUjDENBOpW0dWais1aipGLH2747NY9F088Fcl0QigIGT5SxUybrZmpZQcOnNglnHJLZo9xWdfEtJuc6EjCZuEj/2/k405M3klQc+SwOqB/z5FNp0BnQTsB9HNpBvtEBayreiOWsoALIfDEU5G0KdBhbhFgccYUCHBy2K/VkiNkimE19D4AFBgW7jOs5BRQBKpfXNrgXLcpgKg8oRph2sUiqDySWpaXl1ut1r3MSDtXXzNrifyc/fAxfH19ZpIohEA43GhqoG9fqAcOObKYkLAxxkxucQGHDg8DADPMvH4I5+RI1QEAcUa+2wQJp9eu/VOGXY67AFn2FzJmSuUZT4UAIHGDPJMOsLPxaTxGXudLlnLypLReML5wLHekZt4tFXbqFCj9SNoRxphRsLt28aRzg925E4zbb/Wko9oolC//IycSOOBc7ASLNso1s6EePuKpGOsaorOmu0ZpqzUVa3SXDVcIROfO9JUZqnv3eaXUDI0cb5Wdp8DqZ/fDtKQxqP7Rx56KAUBi+FBEZxZkOKEWwGZN4G+qQG2GVgLRBwuQ+N6QpjWO0N71ugvhvbSu5LRTjXsAnUg4r171Qj/dA1H9tbd2AOLjRqPmZw+lBSucsp2lfttdu6Dm0YcQHzvaF29RVQV99ydSGob4h2t711aWuUrGlAwDuvwgIg2JYUPwzTO/RrRwKsyB/YHUyyWFYA7sj2jhVHzz+1/77nkA0Mu3AAn54xEh8KpbnXvEq8WWwgr9BorifCokFAS3vInEmNtg9ejuS1nWdcTHj0V8/FjU1tQAi5YAAKpf/IOvrS5DhVOVCLzp2rn1OI5hfbahzIWHWytavjzBUcM9FVMEkDARLF7t66IiUwA5f/sFM8IrSj2vzJhRTJJXqPIkOmHPdTWubmBoe/YhWLbJS91WR2D9Rqh793uR1QjW/ygjkDtgzdKDiMY/cKxURGOGtq4M+jvbvZRJQzAYRLfuucjt0R3BoDyRaQp9+w6E1m/wpGNgGZUvl0Zt3ldjUxZ9Bx1z/u0UgPPps0C0LiBSFNTOnwXj5hs8FatHVldj295H+IWX/FyNnSJdH+B1S+wpmV5+7itE48sd6/SUY0PLQnjZcgRfLfe9Jggh/BvPjMBfNyD8/Ao/xoOIlvi5Ivf/PmDOI8cR0NNPiuIGuCJzhJlDBqF21nTY3R3PIZsNcbIC4ZWr/Mz5pK5Mf1E2lvzID63/9wEW3wrTPJz2RsDlVZz6+T60++njiN85FsbE8bA7dnCk84KoqoJevgXBN7Z67vUNIBwWhjHbr4zmPZEpKPoB2oc2N7wPulALPie9fQbrGhLXXoPELSNhDhoIDofkCtVGoe7dB237zmS47dfwpLQzZNOtVF7qmPg4ymsG96SIBxbcz7qyBqapoabW+TLADULA6nUFrJ49klli/TFWNAZx5iyUEyeTWV02d4XgCwQxjjaU7GxOq6zOl/iewuuZ8DpIfnR4CXGOQPfQhpL3mtswq3eCVF66ixRrFICj2bRvVRAOE4ubsjEeaMFLUSpbvZ9YXMPAn7Pl0XJQGQHfp43FB7Pm0Bpq8L3TpzDR0wD8ZUUtx0kiepheK3mlpYxa8bn8nA62YTxG4HkAXebdIit8w8Dzwkj8ija/7O8wwgOt/4OJSdO62CwWEWMGgMz3ctnhODOKRUB5jta9lP1lowMu3k9mIhGB3cdG2SQmETAGgOPtrFtzAPsYtFUIvIphfbbJUtqW4NL9aCp/xuWIYSiI82zBvWNMPT5SRSEAjDDt0iDxSWHTccA+iIDyudsZXmvjkjmgKSZPntfJZuscAAhSOjtdWlwK/N//bvBbB7S1Am2NNnNAXl5uNYAPAf6g7rtN8F/KOj6D6EhHFQAAAABJRU5ErkJggg=="}},e={};function t(r){var o=e[r];if(void 0!==o)return o.exports;var a=e[r]={id:r,exports:{}};return n[r](a,a.exports,t),a.exports}t.m=n,t.n=n=>{var e=n&&n.__esModule?()=>n.default:()=>n;return t.d(e,{a:e}),e},t.d=(n,e)=>{for(var r in e)t.o(e,r)&&!t.o(n,r)&&Object.defineProperty(n,r,{enumerable:!0,get:e[r]})},t.o=(n,e)=>Object.prototype.hasOwnProperty.call(n,e),t.b=document.baseURI||self.location.href,t.nc=void 0,(()=>{var n=t(72),e=t.n(n),r=t(825),o=t.n(r),a=t(659),i=t.n(a),A=t(56),s=t.n(A),c=t(540),l=t.n(c),d=t(113),p=t.n(d),u=t(430),h={};h.styleTagTransform=p(),h.setAttributes=s(),h.insert=i().bind(null,"head"),h.domAPI=o(),h.insertStyleElement=l(),e()(u.A,h),u.A&&u.A.locals&&u.A.locals;var g=t(208),m={};m.styleTagTransform=p(),m.setAttributes=s(),m.insert=i().bind(null,"head"),m.domAPI=o(),m.insertStyleElement=l(),e()(g.A,m),g.A&&g.A.locals&&g.A.locals;const C=class{constructor(n){this.length=n,this.timesHit=0,this.hits=[],this.isSunk=!1}hit(n=null,e=null){if(this.isSunk)throw new Error("Ship is already sunk");this.timesHit++,this.hits.push({x:n,y:e}),this.determineIfSunk()&&(this.isSunk=!0)}isHit(n,e){return this.hits.some((t=>t.x===n&&t.y===e))}determineIfSunk(){return this.timesHit===this.length}},B=class{constructor(){this.board=this.createBoard(10),this.ships=[],this.missedAttacks=[]}createBoard(n){const e=[];for(let t=0;tn.isSunk))}canPlaceShip(n,e,t,r){if("horizontal"===t){if(this.board.length{let e;do{e=[Math.floor(10*Math.random()),Math.floor(10*Math.random()),Math.random()<.5?"horizontal":"vertical"]}while(!this.canPlaceShip(...e,n));this.placeShip(...e,n)}))}},b=class{constructor(n){this.type=n,this.gameBoard=new B}};new class{constructor(n,e){this.player=n,this.computer=e,this.cellClickHandler=this.cellClickHandler.bind(this)}displayBoardPlayer(){const n=this.player.gameBoard.board,e=document.querySelector(".board.player");e.innerHTML="";for(let t=0;t{n.removeEventListener("click",this.cellClickHandler)}));const e=document.createElement("div");e.classList.add("restart-game-container");const t=document.createElement("h2");t.textContent=`${n} won!`;const r=document.createElement("button");r.textContent="Play Again",r.addEventListener("click",(()=>{this.player.gameBoard=new B,this.computer.gameBoard=new B,this.player.gameBoard.placeShipRandomly(),this.computer.gameBoard.placeShipRandomly(),this.displayBoardPlayer(),this.startingScreen(),e.remove()})),e.append(t,r),document.body.appendChild(e)}startingScreen(){this.player.gameBoard.placeShipRandomly(),this.computer.gameBoard.placeShipRandomly(),this.displayBoardPlayer(),this.displayBoardComputerEmpty();const n=document.createElement("div");n.classList.add("start-game-container");const e=document.createElement("button");e.classList.add("randomize-ships"),e.textContent="Randomize Ships",e.addEventListener("click",(()=>{this.player.gameBoard.placeShipRandomly(),this.displayBoardPlayer()}));const t=document.createElement("button");t.classList.add("start"),t.textContent="Start",t.addEventListener("click",(()=>{this.displayBoardComputer(),n.remove()}));const r=document.querySelector(".computer-container");n.append(e,t),r.appendChild(n)}}(new b("player"),new b("computer")).startingScreen()})()})(); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.js","mappings":"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","sources":["webpack://my-webpack-project/./src/reset.css","webpack://my-webpack-project/./src/style.css","webpack://my-webpack-project/./node_modules/css-loader/dist/runtime/api.js","webpack://my-webpack-project/./node_modules/css-loader/dist/runtime/getUrl.js","webpack://my-webpack-project/./node_modules/css-loader/dist/runtime/sourceMaps.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/insertBySelector.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/insertStyleElement.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/styleDomAPI.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/styleTagTransform.js","webpack://my-webpack-project/webpack/bootstrap","webpack://my-webpack-project/webpack/runtime/compat get default export","webpack://my-webpack-project/webpack/runtime/define property getters","webpack://my-webpack-project/webpack/runtime/hasOwnProperty shorthand","webpack://my-webpack-project/webpack/runtime/jsonp chunk loading","webpack://my-webpack-project/webpack/runtime/nonce","webpack://my-webpack-project/./src/reset.css?ede0","webpack://my-webpack-project/./src/style.css?7163","webpack://my-webpack-project/./src/ship.js","webpack://my-webpack-project/./src/gameBoard.js","webpack://my-webpack-project/./src/player.js","webpack://my-webpack-project/./src/index.js","webpack://my-webpack-project/./src/display.js"],"sourcesContent":["// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `html, body, div, span, applet, object, iframe,\nh1, h2, h3, h4, h5, h6, p, blockquote, pre,\na, abbr, acronym, address, big, cite, code,\ndel, dfn, em, img, ins, kbd, q, s, samp,\nsmall, strike, strong, sub, sup, tt, var,\nb, u, i, center,\ndl, dt, dd, ol, ul, li,\nfieldset, form, label, legend,\ntable, caption, tbody, tfoot, thead, tr, th, td,\narticle, aside, canvas, details, embed, \nfigure, figcaption, footer, header, hgroup, \nmenu, nav, output, ruby, section, summary,\ntime, mark, audio, video, button {\n\tmargin: 0;\n\tpadding: 0;\n\tborder: 0;\n\tfont-size: 100%;\n\tfont: inherit;\n\tvertical-align: baseline;\n}\n/* HTML5 display-role reset for older browsers */\narticle, aside, details, figcaption, figure, \nfooter, header, hgroup, menu, nav, section {\n\tdisplay: block;\n}\nbody {\n\tline-height: 1;\n}\nol, ul {\n\tlist-style: none;\n}\nblockquote, q {\n\tquotes: none;\n}\nblockquote:before, blockquote:after,\nq:before, q:after {\n\tcontent: '';\n\tcontent: none;\n}\ntable {\n\tborder-collapse: collapse;\n\tborder-spacing: 0;\n}`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/reset.css\"],\"names\":[],\"mappings\":\"AAAA;;;;;;;;;;;;;CAaC,SAAS;CACT,UAAU;CACV,SAAS;CACT,eAAe;CACf,aAAa;CACb,wBAAwB;AACzB;AACA,gDAAgD;AAChD;;CAEC,cAAc;AACf;AACA;CACC,cAAc;AACf;AACA;CACC,gBAAgB;AACjB;AACA;CACC,YAAY;AACb;AACA;;CAEC,WAAW;CACX,aAAa;AACd;AACA;CACC,yBAAyB;CACzB,iBAAiB;AAClB\",\"sourcesContent\":[\"html, body, div, span, applet, object, iframe,\\nh1, h2, h3, h4, h5, h6, p, blockquote, pre,\\na, abbr, acronym, address, big, cite, code,\\ndel, dfn, em, img, ins, kbd, q, s, samp,\\nsmall, strike, strong, sub, sup, tt, var,\\nb, u, i, center,\\ndl, dt, dd, ol, ul, li,\\nfieldset, form, label, legend,\\ntable, caption, tbody, tfoot, thead, tr, th, td,\\narticle, aside, canvas, details, embed, \\nfigure, figcaption, footer, header, hgroup, \\nmenu, nav, output, ruby, section, summary,\\ntime, mark, audio, video, button {\\n\\tmargin: 0;\\n\\tpadding: 0;\\n\\tborder: 0;\\n\\tfont-size: 100%;\\n\\tfont: inherit;\\n\\tvertical-align: baseline;\\n}\\n/* HTML5 display-role reset for older browsers */\\narticle, aside, details, figcaption, figure, \\nfooter, header, hgroup, menu, nav, section {\\n\\tdisplay: block;\\n}\\nbody {\\n\\tline-height: 1;\\n}\\nol, ul {\\n\\tlist-style: none;\\n}\\nblockquote, q {\\n\\tquotes: none;\\n}\\nblockquote:before, blockquote:after,\\nq:before, q:after {\\n\\tcontent: '';\\n\\tcontent: none;\\n}\\ntable {\\n\\tborder-collapse: collapse;\\n\\tborder-spacing: 0;\\n}\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"./icons/target.png\", import.meta.url);\nvar ___CSS_LOADER_URL_IMPORT_1___ = new URL(\"./icons/sea.png\", import.meta.url);\nvar ___CSS_LOADER_URL_IMPORT_2___ = new URL(\"./icons/fire.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\nvar ___CSS_LOADER_URL_REPLACEMENT_1___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_1___);\nvar ___CSS_LOADER_URL_REPLACEMENT_2___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_2___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `* {\n    box-sizing: border-box;\n}\n\nbody {\n    font-family: \"Roboto Mono\", monospace;\n    font-optical-sizing: auto;\n    font-weight: 500;\n    font-style: normal;\n\n    display: flex;\n    flex-direction: column;\n    /* align-items: center; */\n    justify-content: center;\n    /* margin: -3vw; */\n    /* height: 100vh; */\n\n    position: relative;\n}\n\n.header {\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    padding: 2rem;\n    font-size: calc(2.5rem + 1vw);\n}\n\n.game-container {\n    display: flex;\n    justify-content: space-around;\n    align-items: center;\n    flex-wrap: wrap;\n    /* margin-top: 20vh; */\n    /* width: 70vw; */\n}\n\n.player-container,\n.computer-container {\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n\n    position: relative;\n    /* margin: 2rem; */\n}\n\n.player-container > h4,\n.computer-container > h4 {\n    padding: 1rem;\n    font-size: 1.5rem;\n}\n\n.board {\n    display: grid;\n    grid-template-columns: repeat(10, 1fr);\n    grid-template-rows: repeat(10, 1fr);\n    width: clamp(400px, 30vw, 800px);\n    height: clamp(400px, 30vw, 800px);\n    border: 2px solid black;\n}\n\n.cell {\n    border: 1px solid black;\n}\n\n.computer .cell:hover {\n    background-image: url(${___CSS_LOADER_URL_REPLACEMENT_0___});\n    background-size: cover;\n    background-size: 80%;\n    background-repeat: no-repeat;\n    background-position: center;\n    cursor: pointer;\n}\n\n.computer .cell.hit:hover {\n    cursor: not-allowed;\n}\n\n.player .cell.ship {\n    background-color: rgb(127, 186, 39);\n    /* border: 2px solid rgb(0, 79, 0); */\n}\n\n.cell.water.hit {\n    background-image: url(${___CSS_LOADER_URL_REPLACEMENT_1___});\n    background-size: 120%;\n    background-position: 0 10px;\n    background-repeat: no-repeat;\n}\n\n.cell.ship.hit {\n    border: 2px solid rgb(0, 67, 0);\n    background: url(${___CSS_LOADER_URL_REPLACEMENT_2___}), greenyellow;\n    background-size: 80%;\n    background-position: center;\n    background-repeat: no-repeat;\n}\n\n.cell.ship.hit.sunk {\n    border: 2px solid rgb(156, 8, 8);\n    background: url(${___CSS_LOADER_URL_REPLACEMENT_2___}), rgb(255, 204, 204);\n    background-size: 80%;\n    background-position: center;\n    background-repeat: no-repeat;\n}\n\n@keyframes fadeIn {\n    from {\n        opacity: 0;\n    }\n    to {\n        opacity: 1;\n    }\n}\n\n.restart-game-container {\n    position: absolute;\n    transform: translate(-50%, -50%);\n    top: 50%;\n    left: 50%;\n    backdrop-filter: blur(2px);\n    width: 100vw;\n    height: 100vh;\n\n    display: flex;\n    flex-direction: column;\n    justify-content: center;\n    align-items: center;\n    gap: 2rem;\n\n    animation: fadeIn 0.5s;\n}\n\n.restart-game-container h2 {\n    font-size: 3rem;\n    font-weight: 700;\n}\n\n.restart-game-container button {\n    padding: 1rem 2rem;\n    font-size: 1.5rem;\n    background-color: rgb(0, 0, 0, 0.8);\n    color: white;\n    border-radius: 5px;\n    cursor: pointer;\n\n    transition: background-color 0.3s;\n}\n\n.restart-game-container button:hover {\n    background-color: rgb(0, 0, 0, 0.9);\n}\n\n.start-game-container {\n    position: absolute;\n    transform: translate(-50%, -50%);\n    top: 50%;\n    left: 50%;\n    backdrop-filter: blur(2px);\n    width: 101%;\n    height: 101%;\n\n    display: flex;\n    flex-direction: column;\n    justify-content: center;\n    align-items: center;\n    gap: 20%;\n}\n\n.start-game-container button {\n    padding: 1rem 2rem;\n    font-size: 1.5rem;\n    border-radius: 0.5rem;\n    background-color: rgb(40, 40, 40);\n    color: white;\n\n    transition: background-color 0.3s;\n}\n\n.start-game-container button:hover {\n    background-color: rgb(0, 0, 0);\n}\n`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/style.css\"],\"names\":[],\"mappings\":\"AAAA;IACI,sBAAsB;AAC1B;;AAEA;IACI,qCAAqC;IACrC,yBAAyB;IACzB,gBAAgB;IAChB,kBAAkB;;IAElB,aAAa;IACb,sBAAsB;IACtB,yBAAyB;IACzB,uBAAuB;IACvB,kBAAkB;IAClB,mBAAmB;;IAEnB,kBAAkB;AACtB;;AAEA;IACI,aAAa;IACb,uBAAuB;IACvB,mBAAmB;IACnB,aAAa;IACb,6BAA6B;AACjC;;AAEA;IACI,aAAa;IACb,6BAA6B;IAC7B,mBAAmB;IACnB,eAAe;IACf,sBAAsB;IACtB,iBAAiB;AACrB;;AAEA;;IAEI,aAAa;IACb,sBAAsB;IACtB,mBAAmB;;IAEnB,kBAAkB;IAClB,kBAAkB;AACtB;;AAEA;;IAEI,aAAa;IACb,iBAAiB;AACrB;;AAEA;IACI,aAAa;IACb,sCAAsC;IACtC,mCAAmC;IACnC,gCAAgC;IAChC,iCAAiC;IACjC,uBAAuB;AAC3B;;AAEA;IACI,uBAAuB;AAC3B;;AAEA;IACI,yDAA2C;IAC3C,sBAAsB;IACtB,oBAAoB;IACpB,4BAA4B;IAC5B,2BAA2B;IAC3B,eAAe;AACnB;;AAEA;IACI,mBAAmB;AACvB;;AAEA;IACI,mCAAmC;IACnC,qCAAqC;AACzC;;AAEA;IACI,yDAAwC;IACxC,qBAAqB;IACrB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI,+BAA+B;IAC/B,gEAAgD;IAChD,oBAAoB;IACpB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI,gCAAgC;IAChC,uEAAuD;IACvD,oBAAoB;IACpB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI;QACI,UAAU;IACd;IACA;QACI,UAAU;IACd;AACJ;;AAEA;IACI,kBAAkB;IAClB,gCAAgC;IAChC,QAAQ;IACR,SAAS;IACT,0BAA0B;IAC1B,YAAY;IACZ,aAAa;;IAEb,aAAa;IACb,sBAAsB;IACtB,uBAAuB;IACvB,mBAAmB;IACnB,SAAS;;IAET,sBAAsB;AAC1B;;AAEA;IACI,eAAe;IACf,gBAAgB;AACpB;;AAEA;IACI,kBAAkB;IAClB,iBAAiB;IACjB,mCAAmC;IACnC,YAAY;IACZ,kBAAkB;IAClB,eAAe;;IAEf,iCAAiC;AACrC;;AAEA;IACI,mCAAmC;AACvC;;AAEA;IACI,kBAAkB;IAClB,gCAAgC;IAChC,QAAQ;IACR,SAAS;IACT,0BAA0B;IAC1B,WAAW;IACX,YAAY;;IAEZ,aAAa;IACb,sBAAsB;IACtB,uBAAuB;IACvB,mBAAmB;IACnB,QAAQ;AACZ;;AAEA;IACI,kBAAkB;IAClB,iBAAiB;IACjB,qBAAqB;IACrB,iCAAiC;IACjC,YAAY;;IAEZ,iCAAiC;AACrC;;AAEA;IACI,8BAA8B;AAClC\",\"sourcesContent\":[\"* {\\n    box-sizing: border-box;\\n}\\n\\nbody {\\n    font-family: \\\"Roboto Mono\\\", monospace;\\n    font-optical-sizing: auto;\\n    font-weight: 500;\\n    font-style: normal;\\n\\n    display: flex;\\n    flex-direction: column;\\n    /* align-items: center; */\\n    justify-content: center;\\n    /* margin: -3vw; */\\n    /* height: 100vh; */\\n\\n    position: relative;\\n}\\n\\n.header {\\n    display: flex;\\n    justify-content: center;\\n    align-items: center;\\n    padding: 2rem;\\n    font-size: calc(2.5rem + 1vw);\\n}\\n\\n.game-container {\\n    display: flex;\\n    justify-content: space-around;\\n    align-items: center;\\n    flex-wrap: wrap;\\n    /* margin-top: 20vh; */\\n    /* width: 70vw; */\\n}\\n\\n.player-container,\\n.computer-container {\\n    display: flex;\\n    flex-direction: column;\\n    align-items: center;\\n\\n    position: relative;\\n    /* margin: 2rem; */\\n}\\n\\n.player-container > h4,\\n.computer-container > h4 {\\n    padding: 1rem;\\n    font-size: 1.5rem;\\n}\\n\\n.board {\\n    display: grid;\\n    grid-template-columns: repeat(10, 1fr);\\n    grid-template-rows: repeat(10, 1fr);\\n    width: clamp(400px, 30vw, 800px);\\n    height: clamp(400px, 30vw, 800px);\\n    border: 2px solid black;\\n}\\n\\n.cell {\\n    border: 1px solid black;\\n}\\n\\n.computer .cell:hover {\\n    background-image: url(\\\"./icons/target.png\\\");\\n    background-size: cover;\\n    background-size: 80%;\\n    background-repeat: no-repeat;\\n    background-position: center;\\n    cursor: pointer;\\n}\\n\\n.computer .cell.hit:hover {\\n    cursor: not-allowed;\\n}\\n\\n.player .cell.ship {\\n    background-color: rgb(127, 186, 39);\\n    /* border: 2px solid rgb(0, 79, 0); */\\n}\\n\\n.cell.water.hit {\\n    background-image: url(\\\"./icons/sea.png\\\");\\n    background-size: 120%;\\n    background-position: 0 10px;\\n    background-repeat: no-repeat;\\n}\\n\\n.cell.ship.hit {\\n    border: 2px solid rgb(0, 67, 0);\\n    background: url(\\\"./icons/fire.png\\\"), greenyellow;\\n    background-size: 80%;\\n    background-position: center;\\n    background-repeat: no-repeat;\\n}\\n\\n.cell.ship.hit.sunk {\\n    border: 2px solid rgb(156, 8, 8);\\n    background: url(\\\"./icons/fire.png\\\"), rgb(255, 204, 204);\\n    background-size: 80%;\\n    background-position: center;\\n    background-repeat: no-repeat;\\n}\\n\\n@keyframes fadeIn {\\n    from {\\n        opacity: 0;\\n    }\\n    to {\\n        opacity: 1;\\n    }\\n}\\n\\n.restart-game-container {\\n    position: absolute;\\n    transform: translate(-50%, -50%);\\n    top: 50%;\\n    left: 50%;\\n    backdrop-filter: blur(2px);\\n    width: 100vw;\\n    height: 100vh;\\n\\n    display: flex;\\n    flex-direction: column;\\n    justify-content: center;\\n    align-items: center;\\n    gap: 2rem;\\n\\n    animation: fadeIn 0.5s;\\n}\\n\\n.restart-game-container h2 {\\n    font-size: 3rem;\\n    font-weight: 700;\\n}\\n\\n.restart-game-container button {\\n    padding: 1rem 2rem;\\n    font-size: 1.5rem;\\n    background-color: rgb(0, 0, 0, 0.8);\\n    color: white;\\n    border-radius: 5px;\\n    cursor: pointer;\\n\\n    transition: background-color 0.3s;\\n}\\n\\n.restart-game-container button:hover {\\n    background-color: rgb(0, 0, 0, 0.9);\\n}\\n\\n.start-game-container {\\n    position: absolute;\\n    transform: translate(-50%, -50%);\\n    top: 50%;\\n    left: 50%;\\n    backdrop-filter: blur(2px);\\n    width: 101%;\\n    height: 101%;\\n\\n    display: flex;\\n    flex-direction: column;\\n    justify-content: center;\\n    align-items: center;\\n    gap: 20%;\\n}\\n\\n.start-game-container button {\\n    padding: 1rem 2rem;\\n    font-size: 1.5rem;\\n    border-radius: 0.5rem;\\n    background-color: rgb(40, 40, 40);\\n    color: white;\\n\\n    transition: background-color 0.3s;\\n}\\n\\n.start-game-container button:hover {\\n    background-color: rgb(0, 0, 0);\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","\"use strict\";\n\n/*\n  MIT License http://www.opensource.org/licenses/mit-license.php\n  Author Tobias Koppers @sokra\n*/\nmodule.exports = function (cssWithMappingToString) {\n  var list = [];\n\n  // return the list of modules as css string\n  list.toString = function toString() {\n    return this.map(function (item) {\n      var content = \"\";\n      var needLayer = typeof item[5] !== \"undefined\";\n      if (item[4]) {\n        content += \"@supports (\".concat(item[4], \") {\");\n      }\n      if (item[2]) {\n        content += \"@media \".concat(item[2], \" {\");\n      }\n      if (needLayer) {\n        content += \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\");\n      }\n      content += cssWithMappingToString(item);\n      if (needLayer) {\n        content += \"}\";\n      }\n      if (item[2]) {\n        content += \"}\";\n      }\n      if (item[4]) {\n        content += \"}\";\n      }\n      return content;\n    }).join(\"\");\n  };\n\n  // import a list of modules into the list\n  list.i = function i(modules, media, dedupe, supports, layer) {\n    if (typeof modules === \"string\") {\n      modules = [[null, modules, undefined]];\n    }\n    var alreadyImportedModules = {};\n    if (dedupe) {\n      for (var k = 0; k < this.length; k++) {\n        var id = this[k][0];\n        if (id != null) {\n          alreadyImportedModules[id] = true;\n        }\n      }\n    }\n    for (var _k = 0; _k < modules.length; _k++) {\n      var item = [].concat(modules[_k]);\n      if (dedupe && alreadyImportedModules[item[0]]) {\n        continue;\n      }\n      if (typeof layer !== \"undefined\") {\n        if (typeof item[5] === \"undefined\") {\n          item[5] = layer;\n        } else {\n          item[1] = \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\").concat(item[1], \"}\");\n          item[5] = layer;\n        }\n      }\n      if (media) {\n        if (!item[2]) {\n          item[2] = media;\n        } else {\n          item[1] = \"@media \".concat(item[2], \" {\").concat(item[1], \"}\");\n          item[2] = media;\n        }\n      }\n      if (supports) {\n        if (!item[4]) {\n          item[4] = \"\".concat(supports);\n        } else {\n          item[1] = \"@supports (\".concat(item[4], \") {\").concat(item[1], \"}\");\n          item[4] = supports;\n        }\n      }\n      list.push(item);\n    }\n  };\n  return list;\n};","\"use strict\";\n\nmodule.exports = function (url, options) {\n  if (!options) {\n    options = {};\n  }\n  if (!url) {\n    return url;\n  }\n  url = String(url.__esModule ? url.default : url);\n\n  // If url is already wrapped in quotes, remove them\n  if (/^['\"].*['\"]$/.test(url)) {\n    url = url.slice(1, -1);\n  }\n  if (options.hash) {\n    url += options.hash;\n  }\n\n  // Should url be wrapped?\n  // See https://drafts.csswg.org/css-values-3/#urls\n  if (/[\"'() \\t\\n]|(%20)/.test(url) || options.needQuotes) {\n    return \"\\\"\".concat(url.replace(/\"/g, '\\\\\"').replace(/\\n/g, \"\\\\n\"), \"\\\"\");\n  }\n  return url;\n};","\"use strict\";\n\nmodule.exports = function (item) {\n  var content = item[1];\n  var cssMapping = item[3];\n  if (!cssMapping) {\n    return content;\n  }\n  if (typeof btoa === \"function\") {\n    var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(cssMapping))));\n    var data = \"sourceMappingURL=data:application/json;charset=utf-8;base64,\".concat(base64);\n    var sourceMapping = \"/*# \".concat(data, \" */\");\n    return [content].concat([sourceMapping]).join(\"\\n\");\n  }\n  return [content].join(\"\\n\");\n};","\"use strict\";\n\nvar stylesInDOM = [];\nfunction getIndexByIdentifier(identifier) {\n  var result = -1;\n  for (var i = 0; i < stylesInDOM.length; i++) {\n    if (stylesInDOM[i].identifier === identifier) {\n      result = i;\n      break;\n    }\n  }\n  return result;\n}\nfunction modulesToDom(list, options) {\n  var idCountMap = {};\n  var identifiers = [];\n  for (var i = 0; i < list.length; i++) {\n    var item = list[i];\n    var id = options.base ? item[0] + options.base : item[0];\n    var count = idCountMap[id] || 0;\n    var identifier = \"\".concat(id, \" \").concat(count);\n    idCountMap[id] = count + 1;\n    var indexByIdentifier = getIndexByIdentifier(identifier);\n    var obj = {\n      css: item[1],\n      media: item[2],\n      sourceMap: item[3],\n      supports: item[4],\n      layer: item[5]\n    };\n    if (indexByIdentifier !== -1) {\n      stylesInDOM[indexByIdentifier].references++;\n      stylesInDOM[indexByIdentifier].updater(obj);\n    } else {\n      var updater = addElementStyle(obj, options);\n      options.byIndex = i;\n      stylesInDOM.splice(i, 0, {\n        identifier: identifier,\n        updater: updater,\n        references: 1\n      });\n    }\n    identifiers.push(identifier);\n  }\n  return identifiers;\n}\nfunction addElementStyle(obj, options) {\n  var api = options.domAPI(options);\n  api.update(obj);\n  var updater = function updater(newObj) {\n    if (newObj) {\n      if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap && newObj.supports === obj.supports && newObj.layer === obj.layer) {\n        return;\n      }\n      api.update(obj = newObj);\n    } else {\n      api.remove();\n    }\n  };\n  return updater;\n}\nmodule.exports = function (list, options) {\n  options = options || {};\n  list = list || [];\n  var lastIdentifiers = modulesToDom(list, options);\n  return function update(newList) {\n    newList = newList || [];\n    for (var i = 0; i < lastIdentifiers.length; i++) {\n      var identifier = lastIdentifiers[i];\n      var index = getIndexByIdentifier(identifier);\n      stylesInDOM[index].references--;\n    }\n    var newLastIdentifiers = modulesToDom(newList, options);\n    for (var _i = 0; _i < lastIdentifiers.length; _i++) {\n      var _identifier = lastIdentifiers[_i];\n      var _index = getIndexByIdentifier(_identifier);\n      if (stylesInDOM[_index].references === 0) {\n        stylesInDOM[_index].updater();\n        stylesInDOM.splice(_index, 1);\n      }\n    }\n    lastIdentifiers = newLastIdentifiers;\n  };\n};","\"use strict\";\n\nvar memo = {};\n\n/* istanbul ignore next  */\nfunction getTarget(target) {\n  if (typeof memo[target] === \"undefined\") {\n    var styleTarget = document.querySelector(target);\n\n    // Special case to return head of iframe instead of iframe itself\n    if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n      try {\n        // This will throw an exception if access to iframe is blocked\n        // due to cross-origin restrictions\n        styleTarget = styleTarget.contentDocument.head;\n      } catch (e) {\n        // istanbul ignore next\n        styleTarget = null;\n      }\n    }\n    memo[target] = styleTarget;\n  }\n  return memo[target];\n}\n\n/* istanbul ignore next  */\nfunction insertBySelector(insert, style) {\n  var target = getTarget(insert);\n  if (!target) {\n    throw new Error(\"Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.\");\n  }\n  target.appendChild(style);\n}\nmodule.exports = insertBySelector;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction insertStyleElement(options) {\n  var element = document.createElement(\"style\");\n  options.setAttributes(element, options.attributes);\n  options.insert(element, options.options);\n  return element;\n}\nmodule.exports = insertStyleElement;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction setAttributesWithoutAttributes(styleElement) {\n  var nonce = typeof __webpack_nonce__ !== \"undefined\" ? __webpack_nonce__ : null;\n  if (nonce) {\n    styleElement.setAttribute(\"nonce\", nonce);\n  }\n}\nmodule.exports = setAttributesWithoutAttributes;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction apply(styleElement, options, obj) {\n  var css = \"\";\n  if (obj.supports) {\n    css += \"@supports (\".concat(obj.supports, \") {\");\n  }\n  if (obj.media) {\n    css += \"@media \".concat(obj.media, \" {\");\n  }\n  var needLayer = typeof obj.layer !== \"undefined\";\n  if (needLayer) {\n    css += \"@layer\".concat(obj.layer.length > 0 ? \" \".concat(obj.layer) : \"\", \" {\");\n  }\n  css += obj.css;\n  if (needLayer) {\n    css += \"}\";\n  }\n  if (obj.media) {\n    css += \"}\";\n  }\n  if (obj.supports) {\n    css += \"}\";\n  }\n  var sourceMap = obj.sourceMap;\n  if (sourceMap && typeof btoa !== \"undefined\") {\n    css += \"\\n/*# sourceMappingURL=data:application/json;base64,\".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), \" */\");\n  }\n\n  // For old IE\n  /* istanbul ignore if  */\n  options.styleTagTransform(css, styleElement, options.options);\n}\nfunction removeStyleElement(styleElement) {\n  // istanbul ignore if\n  if (styleElement.parentNode === null) {\n    return false;\n  }\n  styleElement.parentNode.removeChild(styleElement);\n}\n\n/* istanbul ignore next  */\nfunction domAPI(options) {\n  if (typeof document === \"undefined\") {\n    return {\n      update: function update() {},\n      remove: function remove() {}\n    };\n  }\n  var styleElement = options.insertStyleElement(options);\n  return {\n    update: function update(obj) {\n      apply(styleElement, options, obj);\n    },\n    remove: function remove() {\n      removeStyleElement(styleElement);\n    }\n  };\n}\nmodule.exports = domAPI;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction styleTagTransform(css, styleElement) {\n  if (styleElement.styleSheet) {\n    styleElement.styleSheet.cssText = css;\n  } else {\n    while (styleElement.firstChild) {\n      styleElement.removeChild(styleElement.firstChild);\n    }\n    styleElement.appendChild(document.createTextNode(css));\n  }\n}\nmodule.exports = styleTagTransform;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","__webpack_require__.b = document.baseURI || self.location.href;\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t792: 0\n};\n\n// no chunk on demand loading\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// no jsonp function","__webpack_require__.nc = undefined;","\n      import API from \"!../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n      import domAPI from \"!../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n      import insertFn from \"!../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n      import setAttributes from \"!../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n      import insertStyleElement from \"!../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n      import styleTagTransformFn from \"!../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n      import content, * as namedExport from \"!!../node_modules/css-loader/dist/cjs.js!./reset.css\";\n      \n      \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n      options.insert = insertFn.bind(null, \"head\");\n    \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../node_modules/css-loader/dist/cjs.js!./reset.css\";\n       export default content && content.locals ? content.locals : undefined;\n","\n      import API from \"!../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n      import domAPI from \"!../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n      import insertFn from \"!../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n      import setAttributes from \"!../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n      import insertStyleElement from \"!../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n      import styleTagTransformFn from \"!../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n      import content, * as namedExport from \"!!../node_modules/css-loader/dist/cjs.js!./style.css\";\n      \n      \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n      options.insert = insertFn.bind(null, \"head\");\n    \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../node_modules/css-loader/dist/cjs.js!./style.css\";\n       export default content && content.locals ? content.locals : undefined;\n","class Ship {\n    constructor(length) {\n        this.length = length;\n        this.timesHit = 0;\n        this.hits = [];\n        this.isSunk = false;\n    }\n\n    hit(x = null, y = null) {\n        if (this.isSunk) {\n            throw new Error(\"Ship is already sunk\");\n        }\n        this.timesHit++;\n        this.hits.push({ x, y });\n        if (this.determineIfSunk()) this.isSunk = true;\n    }\n\n    isHit(x, y) {\n        return this.hits.some((hit) => hit.x === x && hit.y === y);\n    }\n\n    determineIfSunk() {\n        if (this.timesHit === this.length) {\n            return true;\n        }\n        return false;\n    }\n}\n\nexport default Ship;\n","import Ship from \"./ship\";\n\nclass GameBoard {\n    constructor() {\n        this.board = this.createBoard(10);\n        this.ships = [];\n        this.missedAttacks = [];\n    }\n\n    createBoard(length) {\n        const board = [];\n        for (let i = 0; i < length; i++) {\n            board[i] = [];\n            for (let j = 0; j < length; j++)\n                board[i][j] = { hit: false, ship: null };\n        }\n        return board;\n    }\n\n    placeShip(x, y, direction, ship) {\n        if (!this.canPlaceShip(x, y, direction, ship)) {\n            throw new Error(\"Ship cannot be placed.\");\n        }\n\n        this.ships.push(ship);\n        switch (direction) {\n            case \"horizontal\":\n                for (let i = 0; i < ship.length; i++) {\n                    this.board[x][y + i].ship = ship;\n                }\n                break;\n            case \"vertical\":\n                for (let i = 0; i < ship.length; i++) {\n                    this.board[x + i][y].ship = ship;\n                }\n                break;\n        }\n    }\n\n    canReceiveAttack(x, y) {\n        return !this.board[x][y].hit;\n    }\n\n    receiveAttack(x, y) {\n        if (!this.canReceiveAttack(x, y))\n            throw new Error(\"Spot is already hit\");\n        this.board[x][y].hit = true;\n        if (this.board[x][y].ship) {\n            this.board[x][y].ship.hit(x, y);\n        } else {\n            this.missedAttacks.push({ x, y });\n        }\n    }\n\n    allShipsSunk() {\n        return this.ships.every((ship) => ship.isSunk);\n    }\n\n    canPlaceShip(x, y, direction, ship) {\n        //Check if ship is out of bounds or on top of another ship\n        if (direction === \"horizontal\") {\n            if (this.board.length < y + ship.length) return false;\n            for (let i = 0; i < ship.length; i++)\n                if (this.board[x][y + i].ship) return false;\n        } else if (direction === \"vertical\") {\n            if (this.board.length < x + ship.length) return false;\n            for (let i = 0; i < ship.length; i++)\n                if (this.board[x + i][y].ship) return false;\n        }\n\n        //Check if ship is right next to another ship\n        if (direction === \"horizontal\") {\n            if (\n                (this.board[x][y - 1] && this.board[x][y - 1].ship) ||\n                (this.board[x][y + ship.length] &&\n                    this.board[x][y + ship.length].ship)\n            )\n                return false;\n            for (let i = -1; i < ship.length + 1; i++) {\n                if (\n                    this.board[x - 1] &&\n                    this.board[x - 1][y + i] &&\n                    this.board[x - 1][y + i].ship\n                )\n                    return false;\n                if (\n                    this.board[x + 1] &&\n                    this.board[x + 1][y + i] &&\n                    this.board[x + 1][y + i].ship\n                )\n                    return false;\n            }\n        } else if (direction === \"vertical\") {\n            if (\n                (this.board[x - 1] &&\n                    this.board[x - 1][y] &&\n                    this.board[x - 1][y].ship) ||\n                (this.board[x + ship.length] &&\n                    this.board[x + ship.length][y] &&\n                    this.board[x + ship.length][y].ship)\n            )\n                return false;\n            for (let i = -1; i < ship.length + 1; i++) {\n                if (\n                    this.board[x + i] &&\n                    this.board[x + i][y - 1] &&\n                    this.board[x + i][y - 1].ship\n                )\n                    return false;\n                if (\n                    this.board[x + i] &&\n                    this.board[x + i][y + 1] &&\n                    this.board[x + i][y + 1].ship\n                )\n                    return false;\n            }\n        }\n        return true;\n    }\n\n    placeShipRandomly() {\n        const getRandomPosition = () => {\n            const randomX = Math.floor(Math.random() * 10);\n            const randomY = Math.floor(Math.random() * 10);\n            const randomDirection =\n                Math.random() < 0.5 ? \"horizontal\" : \"vertical\";\n            return [randomX, randomY, randomDirection];\n        };\n        this.board = this.createBoard(10);\n        this.ships = [];\n        const ship1 = new Ship(1);\n        const ship2 = new Ship(1);\n        const ship3 = new Ship(1);\n        const ship4 = new Ship(1);\n        const ship5 = new Ship(2);\n        const ship6 = new Ship(2);\n        const ship7 = new Ship(2);\n        const ship8 = new Ship(3);\n        const ship9 = new Ship(3);\n        const ship10 = new Ship(4);\n        this.ships.push(\n            ship1,\n            ship2,\n            ship3,\n            ship4,\n            ship5,\n            ship6,\n            ship7,\n            ship8,\n            ship9,\n            ship10\n        );\n\n        this.ships.forEach((ship) => {\n            let randomPosition;\n            do {\n                randomPosition = getRandomPosition();\n            } while (!this.canPlaceShip(...randomPosition, ship));\n            this.placeShip(...randomPosition, ship);\n        });\n    }\n}\n\nexport default GameBoard;\n","import GameBoard from \"./gameBoard\";\n\nclass Player {\n    constructor(type) {\n        this.type = type; //Player or Computer\n        this.gameBoard = new GameBoard();\n    }\n}\n\nexport default Player;","import \"./reset.css\";\nimport \"./style.css\";\nimport Player from \"./player\";\nimport Display from \"./display\";\n\nconst player = new Player(\"player\");\nconst computer = new Player(\"computer\");\nconst display = new Display(player, computer);\n\ndisplay.startingScreen();\n","import Ship from \"./ship\";\nimport GameBoard from \"./gameBoard\";\n\nclass Display {\n    constructor(player, computer) {\n        this.player = player;\n        this.computer = computer;\n\n        this.cellClickHandler = this.cellClickHandler.bind(this);\n    }\n    displayBoardPlayer() {\n        const board = this.player.gameBoard.board;\n        // const board = gameBoard.board\n        const boardDiv = document.querySelector(`.board.player`);\n        boardDiv.innerHTML = \"\";\n        for (let i = 0; i < board.length; i++) {\n            for (let j = 0; j < board[i].length; j++) {\n                const cell = document.createElement(\"div\");\n                cell.classList.add(\"cell\");\n                cell.dataset.x = i;\n                cell.dataset.y = j;\n                if (board[i][j].hit) {\n                    cell.classList.add(\"hit\");\n                }\n                if (board[i][j].ship) {\n                    cell.classList.add(\"ship\");\n                    if (board[i][j].ship.isSunk) {\n                        cell.classList.add(\"sunk\");\n                    }\n                } else {\n                    cell.classList.add(\"water\");\n                }\n                boardDiv.appendChild(cell);\n            }\n        }\n    }\n\n    displayBoardComputer() {\n        const board = this.computer.gameBoard.board;\n        // const board = gameBoard.board;\n        const boardDiv = document.querySelector(`.board.computer`);\n        boardDiv.innerHTML = \"\";\n        for (let i = 0; i < board.length; i++) {\n            for (let j = 0; j < board[i].length; j++) {\n                const cell = document.createElement(\"div\");\n                cell.classList.add(\"cell\");\n                cell.dataset.x = i;\n                cell.dataset.y = j;\n                cell.addEventListener(\"click\", this.cellClickHandler);\n                if (board[i][j].hit) {\n                    cell.classList.add(\"hit\");\n                    if (board[i][j].ship) {\n                        cell.classList.add(\"ship\");\n                        if (board[i][j].ship.isSunk) {\n                            cell.classList.add(\"sunk\");\n                        }\n                    } else {\n                        cell.classList.add(\"water\");\n                    }\n                }\n                boardDiv.appendChild(cell);\n            }\n        }\n    }\n\n    displayBoardComputerEmpty() {\n        const board = this.computer.gameBoard.board;\n        const boardDiv = document.querySelector(`.board.computer`);\n        boardDiv.innerHTML = \"\";\n        for (let i = 0; i < board.length; i++) {\n            for (let j = 0; j < board[i].length; j++) {\n                const cell = document.createElement(\"div\");\n                cell.classList.add(\"cell\");\n                cell.classList.add(\"unclickable\");\n                boardDiv.appendChild(cell);\n            }\n        }\n    }\n\n    cellClickHandler(e) {\n        const x = e.target.dataset.x;\n        const y = e.target.dataset.y;\n\n        const computerBoard = this.computer.gameBoard.board;\n        if (computerBoard[x][y].hit) return;\n\n        this.computer.gameBoard.receiveAttack(x, y);\n        this.displayBoardComputer();\n        if (this.computer.gameBoard.allShipsSunk()) {\n            this.finalizeGame(\"Player\");\n            return;\n        }\n\n        //If you hit a ship you get to play again\n        if (computerBoard[x][y].ship) {\n            return;\n        }\n        const getRandomAttack = () => {\n            let randomAttackX = Math.floor(Math.random() * 10);\n            let randomAttackY = Math.floor(Math.random() * 10);\n\n            return [randomAttackX, randomAttackY];\n        };\n        const playerBoard = this.player.gameBoard.board;\n        let randomAttacks;\n        let isAlreadyhit;\n        do {\n            randomAttacks = getRandomAttack();\n\n            isAlreadyhit = false;\n            if (playerBoard[randomAttacks[0]][randomAttacks[1]].hit) {\n                isAlreadyhit = true;\n                continue;\n            }\n            // if (!this.player.gameBoard.canReceiveAttack(...randomAttacks)) {\n            //     continue;\n            // }\n            // console.log(randomAttacks);\n            // console.log(playerBoard[randomAttacks[0]][randomAttacks[1]].ship);\n            // console.log(playerBoard[randomAttacks[0]][randomAttacks[1]].hit);\n            this.player.gameBoard.receiveAttack(...randomAttacks);\n            this.displayBoardPlayer();\n            if (this.player.gameBoard.allShipsSunk()) {\n                this.finalizeGame(\"Computer\");\n                break;\n            }\n        } while (\n            playerBoard[randomAttacks[0]][randomAttacks[1]].ship ||\n            isAlreadyhit\n        );\n    }\n\n    finalizeGame(winner) {\n        const cells = document.querySelectorAll(\".cell\");\n        cells.forEach((cell) => {\n            cell.removeEventListener(\"click\", this.cellClickHandler);\n        });\n\n        const restartGameContainer = document.createElement(\"div\");\n        restartGameContainer.classList.add(\"restart-game-container\");\n        const winningMessage = document.createElement(\"h2\");\n        winningMessage.textContent = `${winner} won!`;\n        const playAgainButton = document.createElement(\"button\");\n        playAgainButton.textContent = \"Play Again\";\n        playAgainButton.addEventListener(\"click\", () => {\n            // window.location.reload();\n            this.player.gameBoard = new GameBoard();\n            this.computer.gameBoard = new GameBoard();\n            this.player.gameBoard.placeShipRandomly();\n            this.computer.gameBoard.placeShipRandomly();\n            this.displayBoardPlayer();\n            this.startingScreen();\n            restartGameContainer.remove();\n        });\n\n        restartGameContainer.append(winningMessage, playAgainButton);\n        document.body.appendChild(restartGameContainer);\n    }\n\n    startingScreen() {\n        this.player.gameBoard.placeShipRandomly();\n        this.computer.gameBoard.placeShipRandomly();\n        this.displayBoardPlayer();\n        this.displayBoardComputerEmpty();\n\n        const startGameContainer = document.createElement(\"div\");\n        startGameContainer.classList.add(\"start-game-container\");\n\n        const randomizeShipsButton = document.createElement(\"button\");\n        randomizeShipsButton.classList.add(\"randomize-ships\");\n        randomizeShipsButton.textContent = \"Randomize Ships\";\n        randomizeShipsButton.addEventListener(\"click\", () => {\n            this.player.gameBoard.placeShipRandomly();\n            this.displayBoardPlayer();\n        });\n\n        const startGameButton = document.createElement(\"button\");\n        startGameButton.classList.add(\"start\");\n        startGameButton.textContent = \"Start\";\n        startGameButton.addEventListener(\"click\", () => {\n            this.displayBoardComputer();\n            // startGameContainer.style.display = \"none\";\n            startGameContainer.remove();\n        });\n\n        const computerContainer = document.querySelector(\".computer-container\");\n        startGameContainer.append(randomizeShipsButton, startGameButton);\n        computerContainer.appendChild(startGameContainer);\n    }\n}\n\nexport default Display;\n"],"names":["___CSS_LOADER_EXPORT___","push","module","id","___CSS_LOADER_URL_IMPORT_0___","URL","___CSS_LOADER_URL_IMPORT_1___","___CSS_LOADER_URL_IMPORT_2___","___CSS_LOADER_URL_REPLACEMENT_0___","___CSS_LOADER_URL_REPLACEMENT_1___","___CSS_LOADER_URL_REPLACEMENT_2___","exports","cssWithMappingToString","list","toString","this","map","item","content","needLayer","concat","length","join","i","modules","media","dedupe","supports","layer","undefined","alreadyImportedModules","k","_k","url","options","String","__esModule","default","test","slice","hash","needQuotes","replace","cssMapping","btoa","base64","unescape","encodeURIComponent","JSON","stringify","data","sourceMapping","stylesInDOM","getIndexByIdentifier","identifier","result","modulesToDom","idCountMap","identifiers","base","count","indexByIdentifier","obj","css","sourceMap","references","updater","addElementStyle","byIndex","splice","api","domAPI","update","newObj","remove","lastIdentifiers","newList","index","newLastIdentifiers","_i","_index","memo","insert","style","target","styleTarget","document","querySelector","window","HTMLIFrameElement","contentDocument","head","e","getTarget","Error","appendChild","element","createElement","setAttributes","attributes","styleElement","nonce","setAttribute","insertStyleElement","styleTagTransform","apply","parentNode","removeChild","removeStyleElement","styleSheet","cssText","firstChild","createTextNode","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","m","n","getter","d","a","definition","key","o","Object","defineProperty","enumerable","get","prop","prototype","hasOwnProperty","call","b","baseURI","self","location","href","nc","locals","constructor","timesHit","hits","isSunk","hit","x","y","determineIfSunk","isHit","some","board","createBoard","ships","missedAttacks","j","ship","placeShip","direction","canPlaceShip","canReceiveAttack","receiveAttack","allShipsSunk","every","placeShipRandomly","ship1","ship2","ship3","ship4","ship5","ship6","ship7","ship8","ship9","ship10","forEach","randomPosition","Math","floor","random","type","gameBoard","player","computer","cellClickHandler","bind","displayBoardPlayer","boardDiv","innerHTML","cell","classList","add","dataset","displayBoardComputer","addEventListener","displayBoardComputerEmpty","computerBoard","finalizeGame","playerBoard","randomAttacks","isAlreadyhit","winner","querySelectorAll","removeEventListener","restartGameContainer","winningMessage","textContent","playAgainButton","startingScreen","append","body","startGameContainer","randomizeShipsButton","startGameButton","computerContainer"],"sourceRoot":""} \ No newline at end of file +(()=>{"use strict";var n={430:(n,e,t)=>{t.d(e,{A:()=>s});var r=t(354),a=t.n(r),o=t(314),i=t.n(o)()(a());i.push([n.id,"html, body, div, span, applet, object, iframe,\nh1, h2, h3, h4, h5, h6, p, blockquote, pre,\na, abbr, acronym, address, big, cite, code,\ndel, dfn, em, img, ins, kbd, q, s, samp,\nsmall, strike, strong, sub, sup, tt, var,\nb, u, i, center,\ndl, dt, dd, ol, ul, li,\nfieldset, form, label, legend,\ntable, caption, tbody, tfoot, thead, tr, th, td,\narticle, aside, canvas, details, embed, \nfigure, figcaption, footer, header, hgroup, \nmenu, nav, output, ruby, section, summary,\ntime, mark, audio, video, button {\n\tmargin: 0;\n\tpadding: 0;\n\tborder: 0;\n\tfont-size: 100%;\n\tfont: inherit;\n\tvertical-align: baseline;\n}\n/* HTML5 display-role reset for older browsers */\narticle, aside, details, figcaption, figure, \nfooter, header, hgroup, menu, nav, section {\n\tdisplay: block;\n}\nbody {\n\tline-height: 1;\n}\nol, ul {\n\tlist-style: none;\n}\nblockquote, q {\n\tquotes: none;\n}\nblockquote:before, blockquote:after,\nq:before, q:after {\n\tcontent: '';\n\tcontent: none;\n}\ntable {\n\tborder-collapse: collapse;\n\tborder-spacing: 0;\n}","",{version:3,sources:["webpack://./src/reset.css"],names:[],mappings:"AAAA;;;;;;;;;;;;;CAaC,SAAS;CACT,UAAU;CACV,SAAS;CACT,eAAe;CACf,aAAa;CACb,wBAAwB;AACzB;AACA,gDAAgD;AAChD;;CAEC,cAAc;AACf;AACA;CACC,cAAc;AACf;AACA;CACC,gBAAgB;AACjB;AACA;CACC,YAAY;AACb;AACA;;CAEC,WAAW;CACX,aAAa;AACd;AACA;CACC,yBAAyB;CACzB,iBAAiB;AAClB",sourcesContent:["html, body, div, span, applet, object, iframe,\nh1, h2, h3, h4, h5, h6, p, blockquote, pre,\na, abbr, acronym, address, big, cite, code,\ndel, dfn, em, img, ins, kbd, q, s, samp,\nsmall, strike, strong, sub, sup, tt, var,\nb, u, i, center,\ndl, dt, dd, ol, ul, li,\nfieldset, form, label, legend,\ntable, caption, tbody, tfoot, thead, tr, th, td,\narticle, aside, canvas, details, embed, \nfigure, figcaption, footer, header, hgroup, \nmenu, nav, output, ruby, section, summary,\ntime, mark, audio, video, button {\n\tmargin: 0;\n\tpadding: 0;\n\tborder: 0;\n\tfont-size: 100%;\n\tfont: inherit;\n\tvertical-align: baseline;\n}\n/* HTML5 display-role reset for older browsers */\narticle, aside, details, figcaption, figure, \nfooter, header, hgroup, menu, nav, section {\n\tdisplay: block;\n}\nbody {\n\tline-height: 1;\n}\nol, ul {\n\tlist-style: none;\n}\nblockquote, q {\n\tquotes: none;\n}\nblockquote:before, blockquote:after,\nq:before, q:after {\n\tcontent: '';\n\tcontent: none;\n}\ntable {\n\tborder-collapse: collapse;\n\tborder-spacing: 0;\n}"],sourceRoot:""}]);const s=i},208:(n,e,t)=>{t.d(e,{A:()=>m});var r=t(354),a=t.n(r),o=t(314),i=t.n(o),s=t(417),A=t.n(s),l=new URL(t(126),t.b),d=new URL(t(356),t.b),c=new URL(t(837),t.b),h=i()(a()),p=A()(l),u=A()(d),g=A()(c);h.push([n.id,`* {\n box-sizing: border-box;\n}\n\nbody {\n font-family: "Roboto Mono", monospace;\n font-optical-sizing: auto;\n font-weight: 500;\n font-style: normal;\n\n display: flex;\n flex-direction: column;\n /* align-items: center; */\n justify-content: center;\n /* margin: -3vw; */\n /* height: 100vh; */\n\n position: relative;\n}\n\n.header {\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 2rem;\n font-size: calc(2.5rem + 1vw);\n}\n\n.game-container {\n display: flex;\n justify-content: space-around;\n align-items: center;\n flex-wrap: wrap;\n /* margin-top: 20vh; */\n /* width: 70vw; */\n}\n\n.player-container,\n.computer-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n\n position: relative;\n /* margin: 2rem; */\n}\n\n.player-container > h4,\n.computer-container > h4 {\n padding: 1rem;\n font-size: 1.5rem;\n}\n\n.board {\n display: grid;\n grid-template-columns: repeat(10, 1fr);\n grid-template-rows: repeat(10, 1fr);\n width: clamp(400px, 30vw, 800px);\n height: clamp(400px, 30vw, 800px);\n border: 2px solid black;\n}\n\n.cell {\n border: 1px solid black;\n}\n\n.computer .cell:hover {\n background-image: url(${p});\n background-size: cover;\n background-size: 80%;\n background-repeat: no-repeat;\n background-position: center;\n cursor: pointer;\n}\n\n.computer .cell.hit:hover {\n cursor: not-allowed;\n}\n\n.player .cell.ship {\n background-color: rgb(127, 186, 39);\n /* border: 2px solid rgb(0, 79, 0); */\n}\n\n.cell.water.hit {\n background-image: url(${u});\n background-size: 120%;\n background-position: 0 10px;\n background-repeat: no-repeat;\n}\n\n.cell.ship.hit {\n border: 2px solid rgb(0, 67, 0);\n background: url(${g}), greenyellow;\n background-size: 80%;\n background-position: center;\n background-repeat: no-repeat;\n}\n\n.cell.ship.hit.sunk {\n border: 2px solid rgb(156, 8, 8);\n background: url(${g}), rgb(255, 204, 204);\n background-size: 80%;\n background-position: center;\n background-repeat: no-repeat;\n}\n\n@keyframes fadeIn {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n}\n\n.restart-game-container {\n position: absolute;\n transform: translate(-50%, -50%);\n top: 50%;\n left: 50%;\n backdrop-filter: blur(2px);\n width: 100vw;\n height: 100vh;\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: 2rem;\n\n animation: fadeIn 0.5s;\n}\n\n.restart-game-container h2 {\n font-size: 3rem;\n font-weight: 700;\n}\n\n.restart-game-container button {\n padding: 1rem 2rem;\n font-size: 1.5rem;\n background-color: rgb(0, 0, 0, 0.8);\n color: white;\n border-radius: 5px;\n cursor: pointer;\n\n transition: background-color 0.3s;\n}\n\n.restart-game-container button:hover {\n background-color: rgb(0, 0, 0, 0.9);\n}\n\n.start-game-container {\n position: absolute;\n transform: translate(-50%, -50%);\n top: 50%;\n left: 50%;\n backdrop-filter: blur(2px);\n width: 101%;\n height: 101%;\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: 20%;\n}\n\n.start-game-container button {\n padding: 1rem 2rem;\n font-size: 1.5rem;\n border-radius: 0.5rem;\n background-color: rgb(40, 40, 40);\n color: white;\n\n transition: background-color 0.3s;\n}\n\n.start-game-container button:hover {\n background-color: rgb(0, 0, 0);\n}\n\n.valid-move {\n background-color: green;\n}\n\n.invalid-move {\n background-color: red;\n}`,"",{version:3,sources:["webpack://./src/style.css"],names:[],mappings:"AAAA;IACI,sBAAsB;AAC1B;;AAEA;IACI,qCAAqC;IACrC,yBAAyB;IACzB,gBAAgB;IAChB,kBAAkB;;IAElB,aAAa;IACb,sBAAsB;IACtB,yBAAyB;IACzB,uBAAuB;IACvB,kBAAkB;IAClB,mBAAmB;;IAEnB,kBAAkB;AACtB;;AAEA;IACI,aAAa;IACb,uBAAuB;IACvB,mBAAmB;IACnB,aAAa;IACb,6BAA6B;AACjC;;AAEA;IACI,aAAa;IACb,6BAA6B;IAC7B,mBAAmB;IACnB,eAAe;IACf,sBAAsB;IACtB,iBAAiB;AACrB;;AAEA;;IAEI,aAAa;IACb,sBAAsB;IACtB,mBAAmB;;IAEnB,kBAAkB;IAClB,kBAAkB;AACtB;;AAEA;;IAEI,aAAa;IACb,iBAAiB;AACrB;;AAEA;IACI,aAAa;IACb,sCAAsC;IACtC,mCAAmC;IACnC,gCAAgC;IAChC,iCAAiC;IACjC,uBAAuB;AAC3B;;AAEA;IACI,uBAAuB;AAC3B;;AAEA;IACI,yDAA2C;IAC3C,sBAAsB;IACtB,oBAAoB;IACpB,4BAA4B;IAC5B,2BAA2B;IAC3B,eAAe;AACnB;;AAEA;IACI,mBAAmB;AACvB;;AAEA;IACI,mCAAmC;IACnC,qCAAqC;AACzC;;AAEA;IACI,yDAAwC;IACxC,qBAAqB;IACrB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI,+BAA+B;IAC/B,gEAAgD;IAChD,oBAAoB;IACpB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI,gCAAgC;IAChC,uEAAuD;IACvD,oBAAoB;IACpB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI;QACI,UAAU;IACd;IACA;QACI,UAAU;IACd;AACJ;;AAEA;IACI,kBAAkB;IAClB,gCAAgC;IAChC,QAAQ;IACR,SAAS;IACT,0BAA0B;IAC1B,YAAY;IACZ,aAAa;;IAEb,aAAa;IACb,sBAAsB;IACtB,uBAAuB;IACvB,mBAAmB;IACnB,SAAS;;IAET,sBAAsB;AAC1B;;AAEA;IACI,eAAe;IACf,gBAAgB;AACpB;;AAEA;IACI,kBAAkB;IAClB,iBAAiB;IACjB,mCAAmC;IACnC,YAAY;IACZ,kBAAkB;IAClB,eAAe;;IAEf,iCAAiC;AACrC;;AAEA;IACI,mCAAmC;AACvC;;AAEA;IACI,kBAAkB;IAClB,gCAAgC;IAChC,QAAQ;IACR,SAAS;IACT,0BAA0B;IAC1B,WAAW;IACX,YAAY;;IAEZ,aAAa;IACb,sBAAsB;IACtB,uBAAuB;IACvB,mBAAmB;IACnB,QAAQ;AACZ;;AAEA;IACI,kBAAkB;IAClB,iBAAiB;IACjB,qBAAqB;IACrB,iCAAiC;IACjC,YAAY;;IAEZ,iCAAiC;AACrC;;AAEA;IACI,8BAA8B;AAClC;;AAEA;IACI,uBAAuB;AAC3B;;AAEA;IACI,qBAAqB;AACzB",sourcesContent:['* {\n box-sizing: border-box;\n}\n\nbody {\n font-family: "Roboto Mono", monospace;\n font-optical-sizing: auto;\n font-weight: 500;\n font-style: normal;\n\n display: flex;\n flex-direction: column;\n /* align-items: center; */\n justify-content: center;\n /* margin: -3vw; */\n /* height: 100vh; */\n\n position: relative;\n}\n\n.header {\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 2rem;\n font-size: calc(2.5rem + 1vw);\n}\n\n.game-container {\n display: flex;\n justify-content: space-around;\n align-items: center;\n flex-wrap: wrap;\n /* margin-top: 20vh; */\n /* width: 70vw; */\n}\n\n.player-container,\n.computer-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n\n position: relative;\n /* margin: 2rem; */\n}\n\n.player-container > h4,\n.computer-container > h4 {\n padding: 1rem;\n font-size: 1.5rem;\n}\n\n.board {\n display: grid;\n grid-template-columns: repeat(10, 1fr);\n grid-template-rows: repeat(10, 1fr);\n width: clamp(400px, 30vw, 800px);\n height: clamp(400px, 30vw, 800px);\n border: 2px solid black;\n}\n\n.cell {\n border: 1px solid black;\n}\n\n.computer .cell:hover {\n background-image: url("./icons/target.png");\n background-size: cover;\n background-size: 80%;\n background-repeat: no-repeat;\n background-position: center;\n cursor: pointer;\n}\n\n.computer .cell.hit:hover {\n cursor: not-allowed;\n}\n\n.player .cell.ship {\n background-color: rgb(127, 186, 39);\n /* border: 2px solid rgb(0, 79, 0); */\n}\n\n.cell.water.hit {\n background-image: url("./icons/sea.png");\n background-size: 120%;\n background-position: 0 10px;\n background-repeat: no-repeat;\n}\n\n.cell.ship.hit {\n border: 2px solid rgb(0, 67, 0);\n background: url("./icons/fire.png"), greenyellow;\n background-size: 80%;\n background-position: center;\n background-repeat: no-repeat;\n}\n\n.cell.ship.hit.sunk {\n border: 2px solid rgb(156, 8, 8);\n background: url("./icons/fire.png"), rgb(255, 204, 204);\n background-size: 80%;\n background-position: center;\n background-repeat: no-repeat;\n}\n\n@keyframes fadeIn {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n}\n\n.restart-game-container {\n position: absolute;\n transform: translate(-50%, -50%);\n top: 50%;\n left: 50%;\n backdrop-filter: blur(2px);\n width: 100vw;\n height: 100vh;\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: 2rem;\n\n animation: fadeIn 0.5s;\n}\n\n.restart-game-container h2 {\n font-size: 3rem;\n font-weight: 700;\n}\n\n.restart-game-container button {\n padding: 1rem 2rem;\n font-size: 1.5rem;\n background-color: rgb(0, 0, 0, 0.8);\n color: white;\n border-radius: 5px;\n cursor: pointer;\n\n transition: background-color 0.3s;\n}\n\n.restart-game-container button:hover {\n background-color: rgb(0, 0, 0, 0.9);\n}\n\n.start-game-container {\n position: absolute;\n transform: translate(-50%, -50%);\n top: 50%;\n left: 50%;\n backdrop-filter: blur(2px);\n width: 101%;\n height: 101%;\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: 20%;\n}\n\n.start-game-container button {\n padding: 1rem 2rem;\n font-size: 1.5rem;\n border-radius: 0.5rem;\n background-color: rgb(40, 40, 40);\n color: white;\n\n transition: background-color 0.3s;\n}\n\n.start-game-container button:hover {\n background-color: rgb(0, 0, 0);\n}\n\n.valid-move {\n background-color: green;\n}\n\n.invalid-move {\n background-color: red;\n}'],sourceRoot:""}]);const m=h},314:n=>{n.exports=function(n){var e=[];return e.toString=function(){return this.map((function(e){var t="",r=void 0!==e[5];return e[4]&&(t+="@supports (".concat(e[4],") {")),e[2]&&(t+="@media ".concat(e[2]," {")),r&&(t+="@layer".concat(e[5].length>0?" ".concat(e[5]):""," {")),t+=n(e),r&&(t+="}"),e[2]&&(t+="}"),e[4]&&(t+="}"),t})).join("")},e.i=function(n,t,r,a,o){"string"==typeof n&&(n=[[null,n,void 0]]);var i={};if(r)for(var s=0;s0?" ".concat(d[5]):""," {").concat(d[1],"}")),d[5]=o),t&&(d[2]?(d[1]="@media ".concat(d[2]," {").concat(d[1],"}"),d[2]=t):d[2]=t),a&&(d[4]?(d[1]="@supports (".concat(d[4],") {").concat(d[1],"}"),d[4]=a):d[4]="".concat(a)),e.push(d))}},e}},417:n=>{n.exports=function(n,e){return e||(e={}),n?(n=String(n.__esModule?n.default:n),/^['"].*['"]$/.test(n)&&(n=n.slice(1,-1)),e.hash&&(n+=e.hash),/["'() \t\n]|(%20)/.test(n)||e.needQuotes?'"'.concat(n.replace(/"/g,'\\"').replace(/\n/g,"\\n"),'"'):n):n}},354:n=>{n.exports=function(n){var e=n[1],t=n[3];if(!t)return e;if("function"==typeof btoa){var r=btoa(unescape(encodeURIComponent(JSON.stringify(t)))),a="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(r),o="/*# ".concat(a," */");return[e].concat([o]).join("\n")}return[e].join("\n")}},72:n=>{var e=[];function t(n){for(var t=-1,r=0;r{var e={};n.exports=function(n,t){var r=function(n){if(void 0===e[n]){var t=document.querySelector(n);if(window.HTMLIFrameElement&&t instanceof window.HTMLIFrameElement)try{t=t.contentDocument.head}catch(n){t=null}e[n]=t}return e[n]}(n);if(!r)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");r.appendChild(t)}},540:n=>{n.exports=function(n){var e=document.createElement("style");return n.setAttributes(e,n.attributes),n.insert(e,n.options),e}},56:(n,e,t)=>{n.exports=function(n){var e=t.nc;e&&n.setAttribute("nonce",e)}},825:n=>{n.exports=function(n){if("undefined"==typeof document)return{update:function(){},remove:function(){}};var e=n.insertStyleElement(n);return{update:function(t){!function(n,e,t){var r="";t.supports&&(r+="@supports (".concat(t.supports,") {")),t.media&&(r+="@media ".concat(t.media," {"));var a=void 0!==t.layer;a&&(r+="@layer".concat(t.layer.length>0?" ".concat(t.layer):""," {")),r+=t.css,a&&(r+="}"),t.media&&(r+="}"),t.supports&&(r+="}");var o=t.sourceMap;o&&"undefined"!=typeof btoa&&(r+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(o))))," */")),e.styleTagTransform(r,n,e.options)}(e,n,t)},remove:function(){!function(n){if(null===n.parentNode)return!1;n.parentNode.removeChild(n)}(e)}}}},113:n=>{n.exports=function(n,e){if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}},837:n=>{n.exports="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAABuwAAAbsBOuzj4gAAABl0RVh0U29mdHdhcmUAd3d3Lmlua3NjYXBlLm9yZ5vuPBoAAAepSURBVHic1ZtbcFVXHcZ/a1/OSU5CIIRrQUsZLm1IO6A0CWlFqR3rODVAghmlfVAmTYo+VHmoOvpQZjqdcXQqPKhF7XTGOqMDU9JKddqxdpQRGYRWQQhtMxRLWyi0oSQkJzmXvf8+BGgue++zr8fyvZzZa33/y/n22mutvdbaSkT4v6J1+Sx0tlGw29Eo8oe+FeUMb5Qz2AR0r/kUYn+f7Ogmrt6E6oq/lTuN8gvQeXsDur4dkY2AYnwL1PWD5U6nfAJsa6lkuLgDTetERHPORv9j2fK5AlWWPuDB5nps2Q1Mfb5PnRv71ZTw57echUkQyQfsbtqMLYdx+vPjYRiDiefiFDZR791NmxGexo/Qhv7fRHNxC5uY567mduA3+G1lhvZKYrl4IJlHoLv5TpDfAbp/I3UmkVxKIH4BuldPR+S3gBnITkll7Ln4QPwCiP4z4MbgdlTEnosPxCtA15pW4L5Qtup6F2C70sB+LLS9Jde5AO823Uepsd4L13ULUEqh5JFIPkTqYsklIOIRoLPxToTFkXwUrE/HkktAxNUCvhrZR75QS3v9/BiyCYToAnR06CCbIvsRQOyHQtluvnVu2LDRBZh+5i5gTmQ/AAV7Q2CbjTc/zED232FDRhdAs78W2cdVjOaWsWnFKt/8+5fWkM09ymhhHm31j4YJGU2AjoYUojZG8jEetihGRl9mu/L3knZZ7aNojU25h7PfpXX5rKAhowkwM9MMzIjkYzJGCzN4delLJXlt9d9hOLf22nXRNkD2BQ0XTQBLuzWSvRuGRj/L+mUvON7R+5fW0LrsnwwMPc7k1axsrpmO5QuChIq2HqCkIZK9F4ZG70HXzrN++T50/SC2vQiRheSsuykUnWeNIlBgO9DpN0zUBZHkBACwbI2hkfXAet82OWsDAQSIOgokK0AY5PJ1dDTU+6WHF2BrywLi7gDjQqGw1S81vABW8ZbQtknDEt+5RXkEZkawTRYin/RLjSLA9Ai2ycKyZ/ulRhBA+/gKIP5HN3cBHmi+jS2Nn/Cw/fgKoFTOL9VdAMVqDPU831pX7Vgv1ATPrExQjPilugsgshi4jXx2D99YN3XmpUSFSq4c0NV7fqlefcBNACi+iDnyEt/8TO2ket8qu6Iqj9zTj3z+YmRXE2AaPX6pXo/AuDU+uYNi/u880HTTR0Vkw2UHMmsIa20fxdajqEVZOBPjppBSYFf83C+9dAv4CPUojtLVvOWKZfAWkC5iN5/G+kIvsvBDUILkdFRfjAKkzH56/nVpQll7/Vo6GhznLc4CdK/OAE7rbNNAnqSr8TlETQuSl9QNUbz3GPbi9ydWxHn3AUztwITrTcu/xFD2ZeyC47Kd83iZn2ZjerVw1QrS6jcnmTeItbYPDGtq5btpv25KQykwzUeuXbfd8jhDuYewbA0r49gxuh+R6Wq6CEzu+AJD5g5irXsdNOc4xs75MBjTMYXK1DukzJ3YUk++0EauMDZX8Th+4xX5LFEFMC2s5jdd/zyAzC6g4hJgJL+QkfyPp5Tret7NxKMTlLNR87FXvg1VrrHHMKdEfRzQtCHXKncrdS5KTJlzGXvphdLEJaFHU//Q1CXXKlcjJceixLSXnvfFU1VFqC1GCVUahup1q3IXwDKeCx/QRha4ij4RAtJ+HlL2xPIZRWTLWagrhE7jGpS507XK86BkV9NxQuz5y6J+rJZTvrjGladEbA2OTkP1ZZBlWdTKQUCQooZ6MtBK90SYRo4X3nQ9e+C9HiA8GyamfWN/YBul2ahVA9BxDrVygLHdUlCGjXz5gzBpjCFlHvGq9hZADyeAzHLtdENB3TCC3DwcztjUd3lVewvwxKEjwOFAATWBdAKdWlOIk7QpY5hnep/2opReEhPt4SAxpTKZcV1VFiFtlyaOR0XFD0tRSgvwq4N/Bf7kO2hlDL22EwRkWYA5Q0XqfXp6d5Si+VsUVfr3AH/yZxKc2c0I8GilzQf90PwJsOsf/0Hw7EyuQlIJTmoyDm+Tjrz0Cfae3OuH6n9ZfGD426AOlKKpwQSP/J738eqcNgepTDf7delfgN3H8+h6G/CWF01dzFwdwmOH6st4EwytSHXlGnYf9z0OB9sY+cWBC2isB9wH5aKOupxEK1Aw7PXupqCmajO7j7vO+50QfGfoiUNHgXbgsiunvyqw21KQEY9PDzQlTM/8gD0n9gT1G25r7JeHXsS2W4DTjk7fmAtxbxsccdmHMbQi1RVtPHMy1EHt8HuDvz58HGU1IuyfXKX6q9BOzgvtejLkwzSq16FVpcwBaitX0PN6qCk7RD0hsuvIB2jW3cBPgQkzIO3YQtRAHH2BQj07a3IRVKVfxay9gd+ffCOS99i+G+xsWYJmPQZ85WqR1A1j3fUamO7jt+G1aKRA9s+cePcrUu+QSn+dnhN/iSHrBD6c7Ly9EU39CNTnAMjksZpOI/MHHOluAoiloZ6fDe+lxgoqzEukzW3sfe2pONNN7svRzpYlaPYGYAPIGnvJBc1e9faU1jBFAAVyOoN6sW5sUmMa+9GMHXHd8ckoz6ezW++Yg2XdS/XoKpk72CAzsoukZnS21GYzxuWCkoIuDJoWFyqH1KmaMwxUvELK+EnQMT0M/gdWGE+/XO39uQAAAABJRU5ErkJggg=="},356:n=>{n.exports="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAACXBIWXMAAAHYAAAB2AH6XKZyAAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAABRtJREFUeJztmztsHEUYgL/Z27uzz/b5TRQTHGggiQugQYooaBAUiCSA4gYU6lAgBDQUSKFCoiESQqHmEeJDeYh0hBSIFJFCgVDsXHAeJMJ54LN9Z99jn/NTJAd2OPvetyjZr92d+f75d3Z2/t07CAkJCQl5cFFBiVPTEiNGPwAOuckJ5XTSLyJKKSUqlZYTAi8B51GcUB6fTU6oxXZIj87IZs9gP7ALmADMu4c84LwI3xuaQ5MT6lY7/IcvykhEeFvBboEdCCfVVFo0a2dCDsVHk49zUCklrRCLiEr9zlsInwCJKqcXFby/9wm+aKk/zXsoPgSSqw+pqbRUlCjFMcti374nVaEZ+clfJFHq5bDA7roaCsdVL69PPqJKzfhT09JLhK/X8xvr+oVX43FOffObDDYqP3ZBhou9/Fj34AEUr0iBU6lpGWrGLxFOb+RfNwF32WlGOfPtBXm0XvnRGdnqKM4AO+ttu4pnJcKZ1LSM19swlZbHXMXPwDMbnVctAaDYYRicnbogL9cqn7ooezyDcwq21dpmA7ZLhHOptOyqtcGRtOwWOAtsr3buumtARYTjSjg0s53TB5TSaw6JqCNpdhqKd4HXau6zDhR8h/Dp3m2cvXeBPCBibEvzvFLsB/bU3GddCfg3ktsIvwLzd+JiBHgaeKjuvhphrR9gFMVTCJvq7qqhBNxHVF8D7nPCBAQdQNCECQg6gKAxfbmTBdXhwlgEyhuJIP3m+dsOCuiOKpJxg+GEgWm0JxpPCwtFTc7SWJ5Qfv6W/X1xg5EO+00AAYquUHR9/ir4jPWZDCWMlr0tEWCxqLmx4qEr7DpW++cLPmNJk+Hu1t2dG/nNe0/WAn8ue6zYBuMDJs1eDC1wPeeRs3T1k8v+nEfeNhjvN5u+Nar5101zztZcWXLxm9gn+gJXltyaB7+arKW53AH/hvOs4AizCy5OpXlbBVcLlxZcCk7jIyg4d/pop7/qjWZ7wmzGZbmOq7hia2YzHpbXfJlhecJsxiNnt8f/nzWgEp6Gq1mPgS6D0Z4IiWjlG7PoCPNFn2wDU35jv3BtyaO/22A00Vp/TQkok7U0WUsTNRTdUYVplAOEkiu4DUzVWhEgW9JkS/f4BTxp3F9XAsq4WnDt4KroVvof+K1wmICgAwiaMAFBBxA0hpbWPrPrQYsmaL85c+sahlLEozGS8QSDiT5MI9IWoad9loorLNtFLMehXBAbShE3YyS7Ou83AbQIJcem5NjM53NsTg4xmOhrqXypuMLN5cWKV1yLUHJtSm7n/RXKYc1cLkPeKfFw/yhGk/WoFmEuO0/Oqu0j82r/loFRVJNvJar5190J5koFPN9nfHATEaOxtdLXmutLtyk4Vt1ty/6tQ5swVPv8VcphiysLN3B9v2655/tcXbjZ0ODX+DM32+qvoRx2uZyZY8Wu/XcKK3aJS5k5LK/5n/1YnsPlhTnybfLXWA77XFu8xUB3L8M9Sbqj8crBujbzhWVypXzNwdbk933+uOsf6emnKxprmb++criUJ1vKE41E6IrG/3lceb6P5dkNTdXG/CZd0VhL/I2Vw76P6xcbadoSXN/D9b2W9BVuhYMOIGjCBAQdQNCECQg6gKAJE9DxD/P/J5TCSERjwb2SCZgeM6aNLX3Jg8H9bSJAFIz1932uAN45lflyLpt7w/bcByIVMTMqW5L9Xx18ceTNNQP+4If557xIZCyowDqB6fs3Pn5h9Keg4wgJCQkJ+T/wNxL4/hbh21SVAAAAAElFTkSuQmCC"},126:n=>{n.exports="data:image/png;base64,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"}},e={};function t(r){var a=e[r];if(void 0!==a)return a.exports;var o=e[r]={id:r,exports:{}};return n[r](o,o.exports,t),o.exports}t.m=n,t.n=n=>{var e=n&&n.__esModule?()=>n.default:()=>n;return t.d(e,{a:e}),e},t.d=(n,e)=>{for(var r in e)t.o(e,r)&&!t.o(n,r)&&Object.defineProperty(n,r,{enumerable:!0,get:e[r]})},t.o=(n,e)=>Object.prototype.hasOwnProperty.call(n,e),t.b=document.baseURI||self.location.href,t.nc=void 0,(()=>{var n=t(72),e=t.n(n),r=t(825),a=t.n(r),o=t(659),i=t.n(o),s=t(56),A=t.n(s),l=t(540),d=t.n(l),c=t(113),h=t.n(c),p=t(430),u={};u.styleTagTransform=h(),u.setAttributes=A(),u.insert=i().bind(null,"head"),u.domAPI=a(),u.insertStyleElement=d(),e()(p.A,u),p.A&&p.A.locals&&p.A.locals;var g=t(208),m={};m.styleTagTransform=h(),m.setAttributes=A(),m.insert=i().bind(null,"head"),m.domAPI=a(),m.insertStyleElement=d(),e()(g.A,m),g.A&&g.A.locals&&g.A.locals;const B=class{constructor(n){this.length=n,this.timesHit=0,this.hits=[],this.isSunk=!1,this.coordinates=null,this.direction=null}hit(n=null,e=null){if(this.isSunk)throw new Error("Ship is already sunk");this.timesHit++,this.hits.push({x:n,y:e}),this.determineIfSunk()&&(this.isSunk=!0)}isHit(n,e){return this.hits.some((t=>t.x===n&&t.y===e))}determineIfSunk(){return this.timesHit===this.length}getShipDataJSON(){return JSON.stringify({coordinates:this.coordinates,direction:this.direction,length:this.length,allCellCoordinates:this.getAllCellCoordinates()})}getAllCellCoordinates(){const n=[];switch(this.direction){case"horizontal":for(let e=0;en.isSunk))}canPlaceShip(n,e,t,r){if("horizontal"===t){if(this.board.length{let e;do{e=[Math.floor(10*Math.random()),Math.floor(10*Math.random()),Math.random()<.5?"horizontal":"vertical"]}while(!this.canPlaceShip(...e,n));this.placeShip(...e,n)}))}},C=class{constructor(n){this.type=n,this.gameBoard=new b}};new class{constructor(n,e){this.player=n,this.computer=e,this.cellClickHandler=this.cellClickHandler.bind(this),this.dropHandler=this.dropHandler.bind(this),this.dragOverHandler=this.dragOverHandler.bind(this),this.dragStartHandler=this.dragStartHandler.bind(this),this.dragEndHandler=this.dragEndHandler.bind(this),this.dragData=null,this.validDragging=!1}displayBoardPlayer(){const n=this.player.gameBoard.board,e=document.querySelector(".board.player");e.innerHTML="";for(let t=0;tn.classList.remove("valid-move","invalid-move"))),console.log("dragover");const t=this.dragData,r=JSON.parse(t);if(!r)return;const a=new B(r.length),o=Number(n.target.dataset.x),i=Number(n.target.dataset.y);if(isNaN(o)||isNaN(i))return;const s=[];for(let n=0;n{n.classList.add("valid-move")})):s.forEach((n=>{n.classList.add("invalid-move")}))}dropHandler(n){n.preventDefault(),this.validDragging=!0;const e=document.querySelectorAll(".valid-move, .invalid-move");e&&e.forEach((n=>n.classList.remove("valid-move","invalid-move")));const t=n.dataTransfer.getData("text/plain");let r;try{r=JSON.parse(t)}catch(n){return void(this.dragData=null)}const a=new B(r.length);a.direction=r.direction;const o=Number(n.target.dataset.x),i=Number(n.target.dataset.y);if(!isNaN(o)&&!isNaN(i)){if(this.player.gameBoard.canPlaceShip(o,i,a.direction,a))this.player.gameBoard.placeShip(o,i,a.direction,a),this.player.gameBoard.ships=this.player.gameBoard.ships.filter((n=>this.player.gameBoard.board[r.coordinates.x][r.coordinates.y].ship!==n));else{const n=new B(r.length);this.player.gameBoard.placeShip(r.coordinates.x,r.coordinates.y,r.direction,n)}this.displayBoardPlayer()}}dragEndHandler(n){if(this.validDragging)return;console.log("dragend");const e=this.dragData,t=JSON.parse(e),r=new B(t.length);this.player.gameBoard.placeShip(t.coordinates.x,t.coordinates.y,t.direction,r),this.dragData=null,this.validDragging=!1,this.displayBoardPlayer()}displayBoardComputer(){const n=this.computer.gameBoard.board,e=document.querySelector(".board.computer");e.innerHTML="";for(let t=0;t{n.removeEventListener("click",this.cellClickHandler)}));const e=document.createElement("div");e.classList.add("restart-game-container");const t=document.createElement("h2");t.textContent=`${n} won!`;const r=document.createElement("button");r.textContent="Play Again",r.addEventListener("click",(()=>{this.player.gameBoard=new b,this.computer.gameBoard=new b,this.player.gameBoard.placeShipRandomly(),this.computer.gameBoard.placeShipRandomly(),this.displayBoardPlayer(),this.startingScreen(),e.remove()})),e.append(t,r),document.body.appendChild(e)}startingScreen(){document.body.classList.add("starting-screen"),this.player.gameBoard.placeShipRandomly(),this.computer.gameBoard.placeShipRandomly(),this.displayBoardPlayer(),this.displayBoardComputerEmpty();const n=document.createElement("div");n.classList.add("start-game-container");const e=document.createElement("button");e.classList.add("randomize-ships"),e.textContent="Randomize Ships",e.addEventListener("click",(()=>{this.player.gameBoard.placeShipRandomly(),this.displayBoardPlayer()}));const t=document.createElement("button");t.classList.add("start"),t.textContent="Start",t.addEventListener("click",(()=>{document.body.classList.remove("starting-screen"),this.displayBoardPlayer(),this.displayBoardComputer(),n.remove()}));const r=document.querySelector(".computer-container");n.append(e,t),r.appendChild(n)}}(new C("player"),new C("computer")).startingScreen()})()})(); +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.js","mappings":"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","sources":["webpack://my-webpack-project/./src/reset.css","webpack://my-webpack-project/./src/style.css","webpack://my-webpack-project/./node_modules/css-loader/dist/runtime/api.js","webpack://my-webpack-project/./node_modules/css-loader/dist/runtime/getUrl.js","webpack://my-webpack-project/./node_modules/css-loader/dist/runtime/sourceMaps.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/insertBySelector.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/insertStyleElement.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/styleDomAPI.js","webpack://my-webpack-project/./node_modules/style-loader/dist/runtime/styleTagTransform.js","webpack://my-webpack-project/webpack/bootstrap","webpack://my-webpack-project/webpack/runtime/compat get default export","webpack://my-webpack-project/webpack/runtime/define property getters","webpack://my-webpack-project/webpack/runtime/hasOwnProperty shorthand","webpack://my-webpack-project/webpack/runtime/jsonp chunk loading","webpack://my-webpack-project/webpack/runtime/nonce","webpack://my-webpack-project/./src/reset.css?ede0","webpack://my-webpack-project/./src/style.css?7163","webpack://my-webpack-project/./src/ship.js","webpack://my-webpack-project/./src/gameBoard.js","webpack://my-webpack-project/./src/player.js","webpack://my-webpack-project/./src/index.js","webpack://my-webpack-project/./src/display.js"],"sourcesContent":["// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `html, body, div, span, applet, object, iframe,\nh1, h2, h3, h4, h5, h6, p, blockquote, pre,\na, abbr, acronym, address, big, cite, code,\ndel, dfn, em, img, ins, kbd, q, s, samp,\nsmall, strike, strong, sub, sup, tt, var,\nb, u, i, center,\ndl, dt, dd, ol, ul, li,\nfieldset, form, label, legend,\ntable, caption, tbody, tfoot, thead, tr, th, td,\narticle, aside, canvas, details, embed, \nfigure, figcaption, footer, header, hgroup, \nmenu, nav, output, ruby, section, summary,\ntime, mark, audio, video, button {\n\tmargin: 0;\n\tpadding: 0;\n\tborder: 0;\n\tfont-size: 100%;\n\tfont: inherit;\n\tvertical-align: baseline;\n}\n/* HTML5 display-role reset for older browsers */\narticle, aside, details, figcaption, figure, \nfooter, header, hgroup, menu, nav, section {\n\tdisplay: block;\n}\nbody {\n\tline-height: 1;\n}\nol, ul {\n\tlist-style: none;\n}\nblockquote, q {\n\tquotes: none;\n}\nblockquote:before, blockquote:after,\nq:before, q:after {\n\tcontent: '';\n\tcontent: none;\n}\ntable {\n\tborder-collapse: collapse;\n\tborder-spacing: 0;\n}`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/reset.css\"],\"names\":[],\"mappings\":\"AAAA;;;;;;;;;;;;;CAaC,SAAS;CACT,UAAU;CACV,SAAS;CACT,eAAe;CACf,aAAa;CACb,wBAAwB;AACzB;AACA,gDAAgD;AAChD;;CAEC,cAAc;AACf;AACA;CACC,cAAc;AACf;AACA;CACC,gBAAgB;AACjB;AACA;CACC,YAAY;AACb;AACA;;CAEC,WAAW;CACX,aAAa;AACd;AACA;CACC,yBAAyB;CACzB,iBAAiB;AAClB\",\"sourcesContent\":[\"html, body, div, span, applet, object, iframe,\\nh1, h2, h3, h4, h5, h6, p, blockquote, pre,\\na, abbr, acronym, address, big, cite, code,\\ndel, dfn, em, img, ins, kbd, q, s, samp,\\nsmall, strike, strong, sub, sup, tt, var,\\nb, u, i, center,\\ndl, dt, dd, ol, ul, li,\\nfieldset, form, label, legend,\\ntable, caption, tbody, tfoot, thead, tr, th, td,\\narticle, aside, canvas, details, embed, \\nfigure, figcaption, footer, header, hgroup, \\nmenu, nav, output, ruby, section, summary,\\ntime, mark, audio, video, button {\\n\\tmargin: 0;\\n\\tpadding: 0;\\n\\tborder: 0;\\n\\tfont-size: 100%;\\n\\tfont: inherit;\\n\\tvertical-align: baseline;\\n}\\n/* HTML5 display-role reset for older browsers */\\narticle, aside, details, figcaption, figure, \\nfooter, header, hgroup, menu, nav, section {\\n\\tdisplay: block;\\n}\\nbody {\\n\\tline-height: 1;\\n}\\nol, ul {\\n\\tlist-style: none;\\n}\\nblockquote, q {\\n\\tquotes: none;\\n}\\nblockquote:before, blockquote:after,\\nq:before, q:after {\\n\\tcontent: '';\\n\\tcontent: none;\\n}\\ntable {\\n\\tborder-collapse: collapse;\\n\\tborder-spacing: 0;\\n}\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"./icons/target.png\", import.meta.url);\nvar ___CSS_LOADER_URL_IMPORT_1___ = new URL(\"./icons/sea.png\", import.meta.url);\nvar ___CSS_LOADER_URL_IMPORT_2___ = new URL(\"./icons/fire.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\nvar ___CSS_LOADER_URL_REPLACEMENT_1___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_1___);\nvar ___CSS_LOADER_URL_REPLACEMENT_2___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_2___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `* {\n    box-sizing: border-box;\n}\n\nbody {\n    font-family: \"Roboto Mono\", monospace;\n    font-optical-sizing: auto;\n    font-weight: 500;\n    font-style: normal;\n\n    display: flex;\n    flex-direction: column;\n    /* align-items: center; */\n    justify-content: center;\n    /* margin: -3vw; */\n    /* height: 100vh; */\n\n    position: relative;\n}\n\n.header {\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    padding: 2rem;\n    font-size: calc(2.5rem + 1vw);\n}\n\n.game-container {\n    display: flex;\n    justify-content: space-around;\n    align-items: center;\n    flex-wrap: wrap;\n    /* margin-top: 20vh; */\n    /* width: 70vw; */\n}\n\n.player-container,\n.computer-container {\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n\n    position: relative;\n    /* margin: 2rem; */\n}\n\n.player-container > h4,\n.computer-container > h4 {\n    padding: 1rem;\n    font-size: 1.5rem;\n}\n\n.board {\n    display: grid;\n    grid-template-columns: repeat(10, 1fr);\n    grid-template-rows: repeat(10, 1fr);\n    width: clamp(400px, 30vw, 800px);\n    height: clamp(400px, 30vw, 800px);\n    border: 2px solid black;\n}\n\n.cell {\n    border: 1px solid black;\n}\n\n.computer .cell:hover {\n    background-image: url(${___CSS_LOADER_URL_REPLACEMENT_0___});\n    background-size: cover;\n    background-size: 80%;\n    background-repeat: no-repeat;\n    background-position: center;\n    cursor: pointer;\n}\n\n.computer .cell.hit:hover {\n    cursor: not-allowed;\n}\n\n.player .cell.ship {\n    background-color: rgb(127, 186, 39);\n    /* border: 2px solid rgb(0, 79, 0); */\n}\n\n.cell.water.hit {\n    background-image: url(${___CSS_LOADER_URL_REPLACEMENT_1___});\n    background-size: 120%;\n    background-position: 0 10px;\n    background-repeat: no-repeat;\n}\n\n.cell.ship.hit {\n    border: 2px solid rgb(0, 67, 0);\n    background: url(${___CSS_LOADER_URL_REPLACEMENT_2___}), greenyellow;\n    background-size: 80%;\n    background-position: center;\n    background-repeat: no-repeat;\n}\n\n.cell.ship.hit.sunk {\n    border: 2px solid rgb(156, 8, 8);\n    background: url(${___CSS_LOADER_URL_REPLACEMENT_2___}), rgb(255, 204, 204);\n    background-size: 80%;\n    background-position: center;\n    background-repeat: no-repeat;\n}\n\n@keyframes fadeIn {\n    from {\n        opacity: 0;\n    }\n    to {\n        opacity: 1;\n    }\n}\n\n.restart-game-container {\n    position: absolute;\n    transform: translate(-50%, -50%);\n    top: 50%;\n    left: 50%;\n    backdrop-filter: blur(2px);\n    width: 100vw;\n    height: 100vh;\n\n    display: flex;\n    flex-direction: column;\n    justify-content: center;\n    align-items: center;\n    gap: 2rem;\n\n    animation: fadeIn 0.5s;\n}\n\n.restart-game-container h2 {\n    font-size: 3rem;\n    font-weight: 700;\n}\n\n.restart-game-container button {\n    padding: 1rem 2rem;\n    font-size: 1.5rem;\n    background-color: rgb(0, 0, 0, 0.8);\n    color: white;\n    border-radius: 5px;\n    cursor: pointer;\n\n    transition: background-color 0.3s;\n}\n\n.restart-game-container button:hover {\n    background-color: rgb(0, 0, 0, 0.9);\n}\n\n.start-game-container {\n    position: absolute;\n    transform: translate(-50%, -50%);\n    top: 50%;\n    left: 50%;\n    backdrop-filter: blur(2px);\n    width: 101%;\n    height: 101%;\n\n    display: flex;\n    flex-direction: column;\n    justify-content: center;\n    align-items: center;\n    gap: 20%;\n}\n\n.start-game-container button {\n    padding: 1rem 2rem;\n    font-size: 1.5rem;\n    border-radius: 0.5rem;\n    background-color: rgb(40, 40, 40);\n    color: white;\n\n    transition: background-color 0.3s;\n}\n\n.start-game-container button:hover {\n    background-color: rgb(0, 0, 0);\n}\n\n.valid-move {\n    background-color: green;\n}\n\n.invalid-move {\n    background-color: red;\n}`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/style.css\"],\"names\":[],\"mappings\":\"AAAA;IACI,sBAAsB;AAC1B;;AAEA;IACI,qCAAqC;IACrC,yBAAyB;IACzB,gBAAgB;IAChB,kBAAkB;;IAElB,aAAa;IACb,sBAAsB;IACtB,yBAAyB;IACzB,uBAAuB;IACvB,kBAAkB;IAClB,mBAAmB;;IAEnB,kBAAkB;AACtB;;AAEA;IACI,aAAa;IACb,uBAAuB;IACvB,mBAAmB;IACnB,aAAa;IACb,6BAA6B;AACjC;;AAEA;IACI,aAAa;IACb,6BAA6B;IAC7B,mBAAmB;IACnB,eAAe;IACf,sBAAsB;IACtB,iBAAiB;AACrB;;AAEA;;IAEI,aAAa;IACb,sBAAsB;IACtB,mBAAmB;;IAEnB,kBAAkB;IAClB,kBAAkB;AACtB;;AAEA;;IAEI,aAAa;IACb,iBAAiB;AACrB;;AAEA;IACI,aAAa;IACb,sCAAsC;IACtC,mCAAmC;IACnC,gCAAgC;IAChC,iCAAiC;IACjC,uBAAuB;AAC3B;;AAEA;IACI,uBAAuB;AAC3B;;AAEA;IACI,yDAA2C;IAC3C,sBAAsB;IACtB,oBAAoB;IACpB,4BAA4B;IAC5B,2BAA2B;IAC3B,eAAe;AACnB;;AAEA;IACI,mBAAmB;AACvB;;AAEA;IACI,mCAAmC;IACnC,qCAAqC;AACzC;;AAEA;IACI,yDAAwC;IACxC,qBAAqB;IACrB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI,+BAA+B;IAC/B,gEAAgD;IAChD,oBAAoB;IACpB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI,gCAAgC;IAChC,uEAAuD;IACvD,oBAAoB;IACpB,2BAA2B;IAC3B,4BAA4B;AAChC;;AAEA;IACI;QACI,UAAU;IACd;IACA;QACI,UAAU;IACd;AACJ;;AAEA;IACI,kBAAkB;IAClB,gCAAgC;IAChC,QAAQ;IACR,SAAS;IACT,0BAA0B;IAC1B,YAAY;IACZ,aAAa;;IAEb,aAAa;IACb,sBAAsB;IACtB,uBAAuB;IACvB,mBAAmB;IACnB,SAAS;;IAET,sBAAsB;AAC1B;;AAEA;IACI,eAAe;IACf,gBAAgB;AACpB;;AAEA;IACI,kBAAkB;IAClB,iBAAiB;IACjB,mCAAmC;IACnC,YAAY;IACZ,kBAAkB;IAClB,eAAe;;IAEf,iCAAiC;AACrC;;AAEA;IACI,mCAAmC;AACvC;;AAEA;IACI,kBAAkB;IAClB,gCAAgC;IAChC,QAAQ;IACR,SAAS;IACT,0BAA0B;IAC1B,WAAW;IACX,YAAY;;IAEZ,aAAa;IACb,sBAAsB;IACtB,uBAAuB;IACvB,mBAAmB;IACnB,QAAQ;AACZ;;AAEA;IACI,kBAAkB;IAClB,iBAAiB;IACjB,qBAAqB;IACrB,iCAAiC;IACjC,YAAY;;IAEZ,iCAAiC;AACrC;;AAEA;IACI,8BAA8B;AAClC;;AAEA;IACI,uBAAuB;AAC3B;;AAEA;IACI,qBAAqB;AACzB\",\"sourcesContent\":[\"* {\\n    box-sizing: border-box;\\n}\\n\\nbody {\\n    font-family: \\\"Roboto Mono\\\", monospace;\\n    font-optical-sizing: auto;\\n    font-weight: 500;\\n    font-style: normal;\\n\\n    display: flex;\\n    flex-direction: column;\\n    /* align-items: center; */\\n    justify-content: center;\\n    /* margin: -3vw; */\\n    /* height: 100vh; */\\n\\n    position: relative;\\n}\\n\\n.header {\\n    display: flex;\\n    justify-content: center;\\n    align-items: center;\\n    padding: 2rem;\\n    font-size: calc(2.5rem + 1vw);\\n}\\n\\n.game-container {\\n    display: flex;\\n    justify-content: space-around;\\n    align-items: center;\\n    flex-wrap: wrap;\\n    /* margin-top: 20vh; */\\n    /* width: 70vw; */\\n}\\n\\n.player-container,\\n.computer-container {\\n    display: flex;\\n    flex-direction: column;\\n    align-items: center;\\n\\n    position: relative;\\n    /* margin: 2rem; */\\n}\\n\\n.player-container > h4,\\n.computer-container > h4 {\\n    padding: 1rem;\\n    font-size: 1.5rem;\\n}\\n\\n.board {\\n    display: grid;\\n    grid-template-columns: repeat(10, 1fr);\\n    grid-template-rows: repeat(10, 1fr);\\n    width: clamp(400px, 30vw, 800px);\\n    height: clamp(400px, 30vw, 800px);\\n    border: 2px solid black;\\n}\\n\\n.cell {\\n    border: 1px solid black;\\n}\\n\\n.computer .cell:hover {\\n    background-image: url(\\\"./icons/target.png\\\");\\n    background-size: cover;\\n    background-size: 80%;\\n    background-repeat: no-repeat;\\n    background-position: center;\\n    cursor: pointer;\\n}\\n\\n.computer .cell.hit:hover {\\n    cursor: not-allowed;\\n}\\n\\n.player .cell.ship {\\n    background-color: rgb(127, 186, 39);\\n    /* border: 2px solid rgb(0, 79, 0); */\\n}\\n\\n.cell.water.hit {\\n    background-image: url(\\\"./icons/sea.png\\\");\\n    background-size: 120%;\\n    background-position: 0 10px;\\n    background-repeat: no-repeat;\\n}\\n\\n.cell.ship.hit {\\n    border: 2px solid rgb(0, 67, 0);\\n    background: url(\\\"./icons/fire.png\\\"), greenyellow;\\n    background-size: 80%;\\n    background-position: center;\\n    background-repeat: no-repeat;\\n}\\n\\n.cell.ship.hit.sunk {\\n    border: 2px solid rgb(156, 8, 8);\\n    background: url(\\\"./icons/fire.png\\\"), rgb(255, 204, 204);\\n    background-size: 80%;\\n    background-position: center;\\n    background-repeat: no-repeat;\\n}\\n\\n@keyframes fadeIn {\\n    from {\\n        opacity: 0;\\n    }\\n    to {\\n        opacity: 1;\\n    }\\n}\\n\\n.restart-game-container {\\n    position: absolute;\\n    transform: translate(-50%, -50%);\\n    top: 50%;\\n    left: 50%;\\n    backdrop-filter: blur(2px);\\n    width: 100vw;\\n    height: 100vh;\\n\\n    display: flex;\\n    flex-direction: column;\\n    justify-content: center;\\n    align-items: center;\\n    gap: 2rem;\\n\\n    animation: fadeIn 0.5s;\\n}\\n\\n.restart-game-container h2 {\\n    font-size: 3rem;\\n    font-weight: 700;\\n}\\n\\n.restart-game-container button {\\n    padding: 1rem 2rem;\\n    font-size: 1.5rem;\\n    background-color: rgb(0, 0, 0, 0.8);\\n    color: white;\\n    border-radius: 5px;\\n    cursor: pointer;\\n\\n    transition: background-color 0.3s;\\n}\\n\\n.restart-game-container button:hover {\\n    background-color: rgb(0, 0, 0, 0.9);\\n}\\n\\n.start-game-container {\\n    position: absolute;\\n    transform: translate(-50%, -50%);\\n    top: 50%;\\n    left: 50%;\\n    backdrop-filter: blur(2px);\\n    width: 101%;\\n    height: 101%;\\n\\n    display: flex;\\n    flex-direction: column;\\n    justify-content: center;\\n    align-items: center;\\n    gap: 20%;\\n}\\n\\n.start-game-container button {\\n    padding: 1rem 2rem;\\n    font-size: 1.5rem;\\n    border-radius: 0.5rem;\\n    background-color: rgb(40, 40, 40);\\n    color: white;\\n\\n    transition: background-color 0.3s;\\n}\\n\\n.start-game-container button:hover {\\n    background-color: rgb(0, 0, 0);\\n}\\n\\n.valid-move {\\n    background-color: green;\\n}\\n\\n.invalid-move {\\n    background-color: red;\\n}\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","\"use strict\";\n\n/*\n  MIT License http://www.opensource.org/licenses/mit-license.php\n  Author Tobias Koppers @sokra\n*/\nmodule.exports = function (cssWithMappingToString) {\n  var list = [];\n\n  // return the list of modules as css string\n  list.toString = function toString() {\n    return this.map(function (item) {\n      var content = \"\";\n      var needLayer = typeof item[5] !== \"undefined\";\n      if (item[4]) {\n        content += \"@supports (\".concat(item[4], \") {\");\n      }\n      if (item[2]) {\n        content += \"@media \".concat(item[2], \" {\");\n      }\n      if (needLayer) {\n        content += \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\");\n      }\n      content += cssWithMappingToString(item);\n      if (needLayer) {\n        content += \"}\";\n      }\n      if (item[2]) {\n        content += \"}\";\n      }\n      if (item[4]) {\n        content += \"}\";\n      }\n      return content;\n    }).join(\"\");\n  };\n\n  // import a list of modules into the list\n  list.i = function i(modules, media, dedupe, supports, layer) {\n    if (typeof modules === \"string\") {\n      modules = [[null, modules, undefined]];\n    }\n    var alreadyImportedModules = {};\n    if (dedupe) {\n      for (var k = 0; k < this.length; k++) {\n        var id = this[k][0];\n        if (id != null) {\n          alreadyImportedModules[id] = true;\n        }\n      }\n    }\n    for (var _k = 0; _k < modules.length; _k++) {\n      var item = [].concat(modules[_k]);\n      if (dedupe && alreadyImportedModules[item[0]]) {\n        continue;\n      }\n      if (typeof layer !== \"undefined\") {\n        if (typeof item[5] === \"undefined\") {\n          item[5] = layer;\n        } else {\n          item[1] = \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\").concat(item[1], \"}\");\n          item[5] = layer;\n        }\n      }\n      if (media) {\n        if (!item[2]) {\n          item[2] = media;\n        } else {\n          item[1] = \"@media \".concat(item[2], \" {\").concat(item[1], \"}\");\n          item[2] = media;\n        }\n      }\n      if (supports) {\n        if (!item[4]) {\n          item[4] = \"\".concat(supports);\n        } else {\n          item[1] = \"@supports (\".concat(item[4], \") {\").concat(item[1], \"}\");\n          item[4] = supports;\n        }\n      }\n      list.push(item);\n    }\n  };\n  return list;\n};","\"use strict\";\n\nmodule.exports = function (url, options) {\n  if (!options) {\n    options = {};\n  }\n  if (!url) {\n    return url;\n  }\n  url = String(url.__esModule ? url.default : url);\n\n  // If url is already wrapped in quotes, remove them\n  if (/^['\"].*['\"]$/.test(url)) {\n    url = url.slice(1, -1);\n  }\n  if (options.hash) {\n    url += options.hash;\n  }\n\n  // Should url be wrapped?\n  // See https://drafts.csswg.org/css-values-3/#urls\n  if (/[\"'() \\t\\n]|(%20)/.test(url) || options.needQuotes) {\n    return \"\\\"\".concat(url.replace(/\"/g, '\\\\\"').replace(/\\n/g, \"\\\\n\"), \"\\\"\");\n  }\n  return url;\n};","\"use strict\";\n\nmodule.exports = function (item) {\n  var content = item[1];\n  var cssMapping = item[3];\n  if (!cssMapping) {\n    return content;\n  }\n  if (typeof btoa === \"function\") {\n    var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(cssMapping))));\n    var data = \"sourceMappingURL=data:application/json;charset=utf-8;base64,\".concat(base64);\n    var sourceMapping = \"/*# \".concat(data, \" */\");\n    return [content].concat([sourceMapping]).join(\"\\n\");\n  }\n  return [content].join(\"\\n\");\n};","\"use strict\";\n\nvar stylesInDOM = [];\nfunction getIndexByIdentifier(identifier) {\n  var result = -1;\n  for (var i = 0; i < stylesInDOM.length; i++) {\n    if (stylesInDOM[i].identifier === identifier) {\n      result = i;\n      break;\n    }\n  }\n  return result;\n}\nfunction modulesToDom(list, options) {\n  var idCountMap = {};\n  var identifiers = [];\n  for (var i = 0; i < list.length; i++) {\n    var item = list[i];\n    var id = options.base ? item[0] + options.base : item[0];\n    var count = idCountMap[id] || 0;\n    var identifier = \"\".concat(id, \" \").concat(count);\n    idCountMap[id] = count + 1;\n    var indexByIdentifier = getIndexByIdentifier(identifier);\n    var obj = {\n      css: item[1],\n      media: item[2],\n      sourceMap: item[3],\n      supports: item[4],\n      layer: item[5]\n    };\n    if (indexByIdentifier !== -1) {\n      stylesInDOM[indexByIdentifier].references++;\n      stylesInDOM[indexByIdentifier].updater(obj);\n    } else {\n      var updater = addElementStyle(obj, options);\n      options.byIndex = i;\n      stylesInDOM.splice(i, 0, {\n        identifier: identifier,\n        updater: updater,\n        references: 1\n      });\n    }\n    identifiers.push(identifier);\n  }\n  return identifiers;\n}\nfunction addElementStyle(obj, options) {\n  var api = options.domAPI(options);\n  api.update(obj);\n  var updater = function updater(newObj) {\n    if (newObj) {\n      if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap && newObj.supports === obj.supports && newObj.layer === obj.layer) {\n        return;\n      }\n      api.update(obj = newObj);\n    } else {\n      api.remove();\n    }\n  };\n  return updater;\n}\nmodule.exports = function (list, options) {\n  options = options || {};\n  list = list || [];\n  var lastIdentifiers = modulesToDom(list, options);\n  return function update(newList) {\n    newList = newList || [];\n    for (var i = 0; i < lastIdentifiers.length; i++) {\n      var identifier = lastIdentifiers[i];\n      var index = getIndexByIdentifier(identifier);\n      stylesInDOM[index].references--;\n    }\n    var newLastIdentifiers = modulesToDom(newList, options);\n    for (var _i = 0; _i < lastIdentifiers.length; _i++) {\n      var _identifier = lastIdentifiers[_i];\n      var _index = getIndexByIdentifier(_identifier);\n      if (stylesInDOM[_index].references === 0) {\n        stylesInDOM[_index].updater();\n        stylesInDOM.splice(_index, 1);\n      }\n    }\n    lastIdentifiers = newLastIdentifiers;\n  };\n};","\"use strict\";\n\nvar memo = {};\n\n/* istanbul ignore next  */\nfunction getTarget(target) {\n  if (typeof memo[target] === \"undefined\") {\n    var styleTarget = document.querySelector(target);\n\n    // Special case to return head of iframe instead of iframe itself\n    if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n      try {\n        // This will throw an exception if access to iframe is blocked\n        // due to cross-origin restrictions\n        styleTarget = styleTarget.contentDocument.head;\n      } catch (e) {\n        // istanbul ignore next\n        styleTarget = null;\n      }\n    }\n    memo[target] = styleTarget;\n  }\n  return memo[target];\n}\n\n/* istanbul ignore next  */\nfunction insertBySelector(insert, style) {\n  var target = getTarget(insert);\n  if (!target) {\n    throw new Error(\"Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.\");\n  }\n  target.appendChild(style);\n}\nmodule.exports = insertBySelector;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction insertStyleElement(options) {\n  var element = document.createElement(\"style\");\n  options.setAttributes(element, options.attributes);\n  options.insert(element, options.options);\n  return element;\n}\nmodule.exports = insertStyleElement;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction setAttributesWithoutAttributes(styleElement) {\n  var nonce = typeof __webpack_nonce__ !== \"undefined\" ? __webpack_nonce__ : null;\n  if (nonce) {\n    styleElement.setAttribute(\"nonce\", nonce);\n  }\n}\nmodule.exports = setAttributesWithoutAttributes;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction apply(styleElement, options, obj) {\n  var css = \"\";\n  if (obj.supports) {\n    css += \"@supports (\".concat(obj.supports, \") {\");\n  }\n  if (obj.media) {\n    css += \"@media \".concat(obj.media, \" {\");\n  }\n  var needLayer = typeof obj.layer !== \"undefined\";\n  if (needLayer) {\n    css += \"@layer\".concat(obj.layer.length > 0 ? \" \".concat(obj.layer) : \"\", \" {\");\n  }\n  css += obj.css;\n  if (needLayer) {\n    css += \"}\";\n  }\n  if (obj.media) {\n    css += \"}\";\n  }\n  if (obj.supports) {\n    css += \"}\";\n  }\n  var sourceMap = obj.sourceMap;\n  if (sourceMap && typeof btoa !== \"undefined\") {\n    css += \"\\n/*# sourceMappingURL=data:application/json;base64,\".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), \" */\");\n  }\n\n  // For old IE\n  /* istanbul ignore if  */\n  options.styleTagTransform(css, styleElement, options.options);\n}\nfunction removeStyleElement(styleElement) {\n  // istanbul ignore if\n  if (styleElement.parentNode === null) {\n    return false;\n  }\n  styleElement.parentNode.removeChild(styleElement);\n}\n\n/* istanbul ignore next  */\nfunction domAPI(options) {\n  if (typeof document === \"undefined\") {\n    return {\n      update: function update() {},\n      remove: function remove() {}\n    };\n  }\n  var styleElement = options.insertStyleElement(options);\n  return {\n    update: function update(obj) {\n      apply(styleElement, options, obj);\n    },\n    remove: function remove() {\n      removeStyleElement(styleElement);\n    }\n  };\n}\nmodule.exports = domAPI;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction styleTagTransform(css, styleElement) {\n  if (styleElement.styleSheet) {\n    styleElement.styleSheet.cssText = css;\n  } else {\n    while (styleElement.firstChild) {\n      styleElement.removeChild(styleElement.firstChild);\n    }\n    styleElement.appendChild(document.createTextNode(css));\n  }\n}\nmodule.exports = styleTagTransform;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","__webpack_require__.b = document.baseURI || self.location.href;\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t792: 0\n};\n\n// no chunk on demand loading\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// no jsonp function","__webpack_require__.nc = undefined;","\n      import API from \"!../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n      import domAPI from \"!../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n      import insertFn from \"!../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n      import setAttributes from \"!../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n      import insertStyleElement from \"!../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n      import styleTagTransformFn from \"!../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n      import content, * as namedExport from \"!!../node_modules/css-loader/dist/cjs.js!./reset.css\";\n      \n      \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n      options.insert = insertFn.bind(null, \"head\");\n    \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../node_modules/css-loader/dist/cjs.js!./reset.css\";\n       export default content && content.locals ? content.locals : undefined;\n","\n      import API from \"!../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n      import domAPI from \"!../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n      import insertFn from \"!../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n      import setAttributes from \"!../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n      import insertStyleElement from \"!../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n      import styleTagTransformFn from \"!../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n      import content, * as namedExport from \"!!../node_modules/css-loader/dist/cjs.js!./style.css\";\n      \n      \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n      options.insert = insertFn.bind(null, \"head\");\n    \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../node_modules/css-loader/dist/cjs.js!./style.css\";\n       export default content && content.locals ? content.locals : undefined;\n","class Ship {\n    constructor(length) {\n        this.length = length;\n        this.timesHit = 0;\n        this.hits = [];\n        this.isSunk = false;\n        this.coordinates = null;\n        this.direction = null;\n    }\n\n    hit(x = null, y = null) {\n        if (this.isSunk) {\n            throw new Error(\"Ship is already sunk\");\n        }\n        this.timesHit++;\n        this.hits.push({ x, y });\n        if (this.determineIfSunk()) this.isSunk = true;\n    }\n\n    isHit(x, y) {\n        return this.hits.some((hit) => hit.x === x && hit.y === y);\n    }\n\n    determineIfSunk() {\n        if (this.timesHit === this.length) {\n            return true;\n        }\n        return false;\n    }\n\n    getShipDataJSON() {\n        return JSON.stringify({\n            coordinates: this.coordinates,\n            direction: this.direction,\n            length: this.length,\n            allCellCoordinates: this.getAllCellCoordinates(),\n        });\n    }\n\n    getAllCellCoordinates() {\n        const coordinates = [];\n        switch (this.direction) {\n            case \"horizontal\":\n                for (let i = 0; i < this.length; i++) {\n                    coordinates.push([this.coordinates.x, this.coordinates.y + i]);\n                }\n                break;\n            case \"vertical\":\n                for (let i = 0; i < this.length; i++) {\n                    coordinates.push([this.coordinates.x + i, this.coordinates.y]);\n                }\n                break;\n        }\n        return coordinates;\n    }\n}\n\nexport default Ship;\n","import Ship from \"./ship\";\n\nclass GameBoard {\n    constructor() {\n        this.board = this.createBoard(10);\n        this.ships = [];\n        this.missedAttacks = [];\n    }\n\n    createBoard(length) {\n        const board = [];\n        for (let i = 0; i < length; i++) {\n            board[i] = [];\n            for (let j = 0; j < length; j++)\n                board[i][j] = { hit: false, ship: null };\n        }\n        return board;\n    }\n\n    placeShip(x, y, direction, ship) {\n        if (!this.canPlaceShip(x, y, direction, ship)) {\n            throw new Error(\"Ship cannot be placed.\");\n        }\n\n        this.ships.push(ship);\n        ship.direction = direction;\n        ship.coordinates = { x, y };\n        // console.log(x, y, direction, ship);\n        switch (direction) {\n            case \"horizontal\":\n                for (let i = 0; i < ship.length; i++) {\n                    this.board[x][y + i].ship = ship;\n                    // ship.coordinates.push({ x: x, y: y + i });\n                }\n                break;\n            case \"vertical\":\n                for (let i = 0; i < ship.length; i++) {\n                    this.board[x + i][y].ship = ship;\n                    // ship.coordinates.push({ x: x + i, y: y });\n                }\n                break;\n        }\n    }\n\n    canReceiveAttack(x, y) {\n        return !this.board[x][y].hit;\n    }\n\n    receiveAttack(x, y) {\n        if (!this.canReceiveAttack(x, y))\n            throw new Error(\"Spot is already hit\");\n        this.board[x][y].hit = true;\n        if (this.board[x][y].ship) {\n            this.board[x][y].ship.hit(x, y);\n        } else {\n            this.missedAttacks.push({ x, y });\n        }\n    }\n\n    allShipsSunk() {\n        return this.ships.every((ship) => ship.isSunk);\n    }\n\n    canPlaceShip(x, y, direction, ship) {\n        //Check if ship is out of bounds or on top of another ship\n        if (direction === \"horizontal\") {\n            if (this.board.length < y + ship.length) return false;\n            for (let i = 0; i < ship.length; i++)\n                if (this.board[x][y + i].ship) return false;\n        } else if (direction === \"vertical\") {\n            // console.log(this.board.length, x, ship.length);\n            if (this.board.length < x + ship.length) return false;\n            for (let i = 0; i < ship.length; i++)\n                if (this.board[x + i][y].ship) return false;\n        }\n\n        //Check if ship is right next to another ship\n        if (direction === \"horizontal\") {\n            if (\n                (this.board[x][y - 1] && this.board[x][y - 1].ship) ||\n                (this.board[x][y + ship.length] &&\n                    this.board[x][y + ship.length].ship)\n            )\n                return false;\n            for (let i = -1; i < ship.length + 1; i++) {\n                if (\n                    this.board[x - 1] &&\n                    this.board[x - 1][y + i] &&\n                    this.board[x - 1][y + i].ship\n                )\n                    return false;\n                if (\n                    this.board[x + 1] &&\n                    this.board[x + 1][y + i] &&\n                    this.board[x + 1][y + i].ship\n                )\n                    return false;\n            }\n        } else if (direction === \"vertical\") {\n            if (\n                (this.board[x - 1] &&\n                    this.board[x - 1][y] &&\n                    this.board[x - 1][y].ship) ||\n                (this.board[x + ship.length] &&\n                    this.board[x + ship.length][y] &&\n                    this.board[x + ship.length][y].ship)\n            )\n                return false;\n            for (let i = -1; i < ship.length + 1; i++) {\n                if (\n                    this.board[x + i] &&\n                    this.board[x + i][y - 1] &&\n                    this.board[x + i][y - 1].ship\n                )\n                    return false;\n                if (\n                    this.board[x + i] &&\n                    this.board[x + i][y + 1] &&\n                    this.board[x + i][y + 1].ship\n                )\n                    return false;\n            }\n        }\n        return true;\n    }\n\n    placeShipRandomly() {\n        const getRandomPosition = () => {\n            const randomX = Math.floor(Math.random() * 10);\n            const randomY = Math.floor(Math.random() * 10);\n            const randomDirection =\n                Math.random() < 0.5 ? \"horizontal\" : \"vertical\";\n            return [randomX, randomY, randomDirection];\n        };\n        this.board = this.createBoard(10);\n        this.ships = [];\n        const ship1 = new Ship(1);\n        const ship2 = new Ship(1);\n        const ship3 = new Ship(1);\n        const ship4 = new Ship(1);\n        const ship5 = new Ship(2);\n        const ship6 = new Ship(2);\n        const ship7 = new Ship(2);\n        const ship8 = new Ship(3);\n        const ship9 = new Ship(3);\n        const ship10 = new Ship(4);\n        const shipsToPlace = [];\n        shipsToPlace.push(\n            ship1,\n            ship2,\n            ship3,\n            ship4,\n            ship5,\n            ship6,\n            ship7,\n            ship8,\n            ship9,\n            ship10\n        );\n\n        shipsToPlace.forEach((ship) => {\n            let randomPosition;\n            do {\n                randomPosition = getRandomPosition();\n            } while (!this.canPlaceShip(...randomPosition, ship));\n            this.placeShip(...randomPosition, ship);\n        });\n    }\n}\n\nexport default GameBoard;\n","import GameBoard from \"./gameBoard\";\n\nclass Player {\n    constructor(type) {\n        this.type = type; //Player or Computer\n        this.gameBoard = new GameBoard();\n    }\n}\n\nexport default Player;","import \"./reset.css\";\nimport \"./style.css\";\nimport Player from \"./player\";\nimport Display from \"./display\";\n\nconst player = new Player(\"player\");\nconst computer = new Player(\"computer\");\nconst display = new Display(player, computer);\n\ndisplay.startingScreen();\n","import Ship from \"./ship\";\nimport GameBoard from \"./gameBoard\";\n\nclass Display {\n    constructor(player, computer) {\n        this.player = player;\n        this.computer = computer;\n\n        this.cellClickHandler = this.cellClickHandler.bind(this);\n\n        this.dropHandler = this.dropHandler.bind(this);\n        this.dragOverHandler = this.dragOverHandler.bind(this);\n        this.dragStartHandler = this.dragStartHandler.bind(this);\n        this.dragEndHandler = this.dragEndHandler.bind(this);\n        this.dragData = null;\n        this.validDragging = false;\n    }\n    displayBoardPlayer() {\n        const board = this.player.gameBoard.board;\n        // const board = gameBoard.board\n        const boardDiv = document.querySelector(`.board.player`);\n        boardDiv.innerHTML = \"\";\n        for (let i = 0; i < board.length; i++) {\n            for (let j = 0; j < board[i].length; j++) {\n                const cell = document.createElement(\"div\");\n                cell.classList.add(\"cell\");\n                cell.dataset.x = i;\n                cell.dataset.y = j;\n                if (board[i][j].hit) {\n                    cell.classList.add(\"hit\");\n                }\n                if (board[i][j].ship) {\n                    cell.classList.add(\"ship\");\n                    if (board[i][j].ship.isSunk) {\n                        cell.classList.add(\"sunk\");\n                    }\n                    if (document.body.classList.contains(\"starting-screen\")) {\n                        cell.draggable = true;\n                        cell.addEventListener(\n                            \"dragstart\",\n                            this.dragStartHandler\n                        );\n                        cell.addEventListener(\"dragend\", this.dragEndHandler);\n                    }\n                } else {\n                    cell.classList.add(\"water\");\n                }\n\n                boardDiv.appendChild(cell);\n            }\n        }\n        if (document.body.classList.contains(\"starting-screen\")) {\n            boardDiv.addEventListener(\"dragover\", this.dragOverHandler);\n            boardDiv.addEventListener(\"drop\", this.dropHandler);\n        } else {\n            boardDiv.removeEventListener(\"dragover\", this.dragOverHandler);\n            boardDiv.removeEventListener(\"drop\", this.dropHandler);\n        }\n    }\n\n    dragStartHandler(e) {\n        console.log(\"dragstart\");\n        const board = this.player.gameBoard.board;\n        const i = Number(e.target.dataset.x);\n        const j = Number(e.target.dataset.y);\n\n        e.dataTransfer.setData(\n            \"text/plain\",\n            board[i][j].ship.getShipDataJSON()\n        );\n        this.dragData = board[i][j].ship.getShipDataJSON();\n\n        //Remove ship from old position\n        const oldShip = board[i][j].ship;\n        console.log(oldShip);\n        console.log(\n            document.querySelector(\n                `.cell[data-x=\"${oldShip.coordinates.x}\"][data-y=\"${oldShip.coordinates.y + i}\"]`\n            )\n        );\n        for (let i = 0; i < oldShip.length; i++) {\n            if (oldShip.direction === \"horizontal\") {\n                document\n                    .querySelector(\n                        `.cell[data-x=\"${oldShip.coordinates.x}\"][data-y=\"${oldShip.coordinates.y + i}\"]`\n                    )\n                    .classList.remove(\"ship\");\n                this.player.gameBoard.board[oldShip.coordinates.x][\n                    oldShip.coordinates.y + i\n                ].ship = null;\n            } else {\n                document\n                    .querySelector(\n                        `.cell[data-x=\"${oldShip.coordinates.x + i}\"][data-y=\"${oldShip.coordinates.y}\"]`\n                    )\n                    .classList.remove(\"ship\");\n                this.player.gameBoard.board[oldShip.coordinates.x + i][\n                    oldShip.coordinates.y\n                ].ship = null;\n            }\n        }\n    }\n\n    dragOverHandler(e) {\n        e.preventDefault();\n        e.dataTransfer.dropEffect = \"move\";\n        const cells = document.querySelectorAll(\".valid-move, .invalid-move\");\n        if (cells)\n            cells.forEach((cell) =>\n                cell.classList.remove(\"valid-move\", \"invalid-move\")\n            );\n        console.log(\"dragover\");\n        // console.log(e.dataTransfer.getData(\"text/plain\"));\n        const data = this.dragData;\n        // console.log(data);\n        const shipData = JSON.parse(data);\n        if (!shipData) return;\n        const newShip = new Ship(shipData.length);\n\n        const targetCellX = Number(e.target.dataset.x);\n        const targetCellY = Number(e.target.dataset.y);\n        // console.log(targetCellX, targetCellY);\n        if (isNaN(targetCellX) || isNaN(targetCellY)) return;\n\n        const cellsToMoveTo = [];\n        for (let i = 0; i < newShip.length; i++) {\n            if (shipData.direction === \"horizontal\") {\n                if (targetCellY + i < 10) {\n                    cellsToMoveTo.push(\n                        document.querySelector(\n                            `.player .cell[data-x=\"${targetCellX}\"][data-y=\"${targetCellY + i}\"]`\n                        )\n                    );\n                }\n            } else {\n                if (targetCellX + i < 10) {\n                    cellsToMoveTo.push(\n                        document.querySelector(\n                            `.player .cell[data-x=\"${targetCellX + i}\"][data-y=\"${targetCellY}\"]`\n                        )\n                    );\n                }\n            }\n        }\n\n        if (\n            this.player.gameBoard.canPlaceShip(\n                targetCellX,\n                targetCellY,\n                shipData.direction,\n                newShip\n            )\n        ) {\n            cellsToMoveTo.forEach((cell) => {\n                cell.classList.add(\"valid-move\");\n            });\n        } else {\n            cellsToMoveTo.forEach((cell) => {\n                cell.classList.add(\"invalid-move\");\n            });\n        }\n    }\n\n    dropHandler(e) {\n        e.preventDefault();\n        this.validDragging = true;\n        const cells = document.querySelectorAll(\".valid-move, .invalid-move\");\n        if (cells)\n            cells.forEach((cell) =>\n                cell.classList.remove(\"valid-move\", \"invalid-move\")\n            );\n\n        const data = e.dataTransfer.getData(\"text/plain\");\n        // console.log(data);\n        let shipData;\n        try {\n            shipData = JSON.parse(data);\n        } catch (err) {\n            this.dragData = null;\n            return;\n        }\n        const ship = new Ship(shipData.length);\n        // ship.coordinates = { x: i, y: j };\n        ship.direction = shipData.direction;\n        const targetCellX = Number(e.target.dataset.x);\n        const targetCellY = Number(e.target.dataset.y);\n        if (isNaN(targetCellX) || isNaN(targetCellY)) return;\n        // console.log(targetCellX, targetCellY);\n        if (\n            this.player.gameBoard.canPlaceShip(\n                targetCellX,\n                targetCellY,\n                ship.direction,\n                ship\n            )\n        ) {\n            this.player.gameBoard.placeShip(\n                targetCellX,\n                targetCellY,\n                ship.direction,\n                ship\n            );\n\n            //Remove ship from old position\n            this.player.gameBoard.ships = this.player.gameBoard.ships.filter(\n                (sp) => {\n                    return (\n                        this.player.gameBoard.board[shipData.coordinates.x][\n                            shipData.coordinates.y\n                        ].ship !== sp\n                    );\n                }\n            );\n        } else {\n            const oldShip = new Ship(shipData.length);\n            this.player.gameBoard.placeShip(\n                shipData.coordinates.x,\n                shipData.coordinates.y,\n                shipData.direction,\n                oldShip\n            );\n        }\n        this.displayBoardPlayer();\n    }\n\n    dragEndHandler(e) {\n        // console.log(this.validDragging);\n        if (this.validDragging) return;\n\n        console.log(\"dragend\");\n        const data = this.dragData;\n        const shipData = JSON.parse(data);\n        const oldShip = new Ship(shipData.length);\n        this.player.gameBoard.placeShip(\n            shipData.coordinates.x,\n            shipData.coordinates.y,\n            shipData.direction,\n            oldShip\n        );\n        this.dragData = null;\n        this.validDragging = false;\n        this.displayBoardPlayer();\n    }\n\n    displayBoardComputer() {\n        const board = this.computer.gameBoard.board;\n        // const board = gameBoard.board;\n        const boardDiv = document.querySelector(`.board.computer`);\n        boardDiv.innerHTML = \"\";\n        for (let i = 0; i < board.length; i++) {\n            for (let j = 0; j < board[i].length; j++) {\n                const cell = document.createElement(\"div\");\n                cell.classList.add(\"cell\");\n                cell.dataset.x = i;\n                cell.dataset.y = j;\n                cell.addEventListener(\"click\", this.cellClickHandler);\n                if (board[i][j].hit) {\n                    cell.classList.add(\"hit\");\n                    if (board[i][j].ship) {\n                        cell.classList.add(\"ship\");\n                        if (board[i][j].ship.isSunk) {\n                            cell.classList.add(\"sunk\");\n                        }\n                    } else {\n                        cell.classList.add(\"water\");\n                    }\n                }\n                boardDiv.appendChild(cell);\n            }\n        }\n    }\n\n    displayBoardComputerEmpty() {\n        const board = this.computer.gameBoard.board;\n        const boardDiv = document.querySelector(`.board.computer`);\n        boardDiv.innerHTML = \"\";\n        for (let i = 0; i < board.length; i++) {\n            for (let j = 0; j < board[i].length; j++) {\n                const cell = document.createElement(\"div\");\n                cell.classList.add(\"cell\");\n                cell.classList.add(\"unclickable\");\n                boardDiv.appendChild(cell);\n            }\n        }\n    }\n\n    cellClickHandler(e) {\n        const x = e.target.dataset.x;\n        const y = e.target.dataset.y;\n\n        const computerBoard = this.computer.gameBoard.board;\n        if (computerBoard[x][y].hit) return;\n\n        this.computer.gameBoard.receiveAttack(x, y);\n        this.displayBoardComputer();\n        if (this.computer.gameBoard.allShipsSunk()) {\n            this.finalizeGame(\"Player\");\n            return;\n        }\n\n        //If you hit a ship you get to play again\n        if (computerBoard[x][y].ship) {\n            return;\n        }\n        const getRandomAttack = () => {\n            let randomAttackX = Math.floor(Math.random() * 10);\n            let randomAttackY = Math.floor(Math.random() * 10);\n\n            return [randomAttackX, randomAttackY];\n        };\n        const playerBoard = this.player.gameBoard.board;\n        let randomAttacks;\n        let isAlreadyhit;\n        do {\n            randomAttacks = getRandomAttack();\n\n            isAlreadyhit = false;\n            if (playerBoard[randomAttacks[0]][randomAttacks[1]].hit) {\n                isAlreadyhit = true;\n                continue;\n            }\n            // if (!this.player.gameBoard.canReceiveAttack(...randomAttacks)) {\n            //     continue;\n            // }\n            // console.log(randomAttacks);\n            // console.log(playerBoard[randomAttacks[0]][randomAttacks[1]].ship);\n            // console.log(playerBoard[randomAttacks[0]][randomAttacks[1]].hit);\n            this.player.gameBoard.receiveAttack(...randomAttacks);\n            this.displayBoardPlayer();\n            if (this.player.gameBoard.allShipsSunk()) {\n                this.finalizeGame(\"Computer\");\n                break;\n            }\n        } while (\n            playerBoard[randomAttacks[0]][randomAttacks[1]].ship ||\n            isAlreadyhit\n        );\n    }\n\n    finalizeGame(winner) {\n        const cells = document.querySelectorAll(\".cell\");\n        cells.forEach((cell) => {\n            cell.removeEventListener(\"click\", this.cellClickHandler);\n        });\n\n        const restartGameContainer = document.createElement(\"div\");\n        restartGameContainer.classList.add(\"restart-game-container\");\n        const winningMessage = document.createElement(\"h2\");\n        winningMessage.textContent = `${winner} won!`;\n        const playAgainButton = document.createElement(\"button\");\n        playAgainButton.textContent = \"Play Again\";\n        playAgainButton.addEventListener(\"click\", () => {\n            // window.location.reload();\n            this.player.gameBoard = new GameBoard();\n            this.computer.gameBoard = new GameBoard();\n            this.player.gameBoard.placeShipRandomly();\n            this.computer.gameBoard.placeShipRandomly();\n            this.displayBoardPlayer();\n            this.startingScreen();\n            restartGameContainer.remove();\n        });\n\n        restartGameContainer.append(winningMessage, playAgainButton);\n        document.body.appendChild(restartGameContainer);\n    }\n\n    startingScreen() {\n        document.body.classList.add(\"starting-screen\");\n        this.player.gameBoard.placeShipRandomly();\n        this.computer.gameBoard.placeShipRandomly();\n        this.displayBoardPlayer();\n        this.displayBoardComputerEmpty();\n\n        const startGameContainer = document.createElement(\"div\");\n        startGameContainer.classList.add(\"start-game-container\");\n\n        const randomizeShipsButton = document.createElement(\"button\");\n        randomizeShipsButton.classList.add(\"randomize-ships\");\n        randomizeShipsButton.textContent = \"Randomize Ships\";\n        randomizeShipsButton.addEventListener(\"click\", () => {\n            this.player.gameBoard.placeShipRandomly();\n            this.displayBoardPlayer();\n        });\n\n        const startGameButton = document.createElement(\"button\");\n        startGameButton.classList.add(\"start\");\n        startGameButton.textContent = \"Start\";\n        startGameButton.addEventListener(\"click\", () => {\n            document.body.classList.remove(\"starting-screen\");\n            this.displayBoardPlayer();\n            this.displayBoardComputer();\n            // startGameContainer.style.display = \"none\";\n            startGameContainer.remove();\n        });\n\n        const computerContainer = document.querySelector(\".computer-container\");\n        startGameContainer.append(randomizeShipsButton, startGameButton);\n        computerContainer.appendChild(startGameContainer);\n    }\n}\n\nexport default Display;\n"],"names":["___CSS_LOADER_EXPORT___","push","module","id","___CSS_LOADER_URL_IMPORT_0___","URL","___CSS_LOADER_URL_IMPORT_1___","___CSS_LOADER_URL_IMPORT_2___","___CSS_LOADER_URL_REPLACEMENT_0___","___CSS_LOADER_URL_REPLACEMENT_1___","___CSS_LOADER_URL_REPLACEMENT_2___","exports","cssWithMappingToString","list","toString","this","map","item","content","needLayer","concat","length","join","i","modules","media","dedupe","supports","layer","undefined","alreadyImportedModules","k","_k","url","options","String","__esModule","default","test","slice","hash","needQuotes","replace","cssMapping","btoa","base64","unescape","encodeURIComponent","JSON","stringify","data","sourceMapping","stylesInDOM","getIndexByIdentifier","identifier","result","modulesToDom","idCountMap","identifiers","base","count","indexByIdentifier","obj","css","sourceMap","references","updater","addElementStyle","byIndex","splice","api","domAPI","update","newObj","remove","lastIdentifiers","newList","index","newLastIdentifiers","_i","_index","memo","insert","style","target","styleTarget","document","querySelector","window","HTMLIFrameElement","contentDocument","head","e","getTarget","Error","appendChild","element","createElement","setAttributes","attributes","styleElement","nonce","setAttribute","insertStyleElement","styleTagTransform","apply","parentNode","removeChild","removeStyleElement","styleSheet","cssText","firstChild","createTextNode","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","m","n","getter","d","a","definition","key","o","Object","defineProperty","enumerable","get","prop","prototype","hasOwnProperty","call","b","baseURI","self","location","href","nc","locals","constructor","timesHit","hits","isSunk","coordinates","direction","hit","x","y","determineIfSunk","isHit","some","getShipDataJSON","allCellCoordinates","getAllCellCoordinates","board","createBoard","ships","missedAttacks","j","ship","placeShip","canPlaceShip","canReceiveAttack","receiveAttack","allShipsSunk","every","placeShipRandomly","ship1","ship2","ship3","ship4","ship5","ship6","ship7","ship8","ship9","ship10","shipsToPlace","forEach","randomPosition","Math","floor","random","type","gameBoard","player","computer","cellClickHandler","bind","dropHandler","dragOverHandler","dragStartHandler","dragEndHandler","dragData","validDragging","displayBoardPlayer","boardDiv","innerHTML","cell","classList","add","dataset","body","contains","draggable","addEventListener","removeEventListener","console","log","Number","dataTransfer","setData","oldShip","preventDefault","dropEffect","cells","querySelectorAll","shipData","parse","newShip","targetCellX","targetCellY","isNaN","cellsToMoveTo","getData","err","filter","sp","displayBoardComputer","displayBoardComputerEmpty","computerBoard","finalizeGame","playerBoard","randomAttacks","isAlreadyhit","winner","restartGameContainer","winningMessage","textContent","playAgainButton","startingScreen","append","startGameContainer","randomizeShipsButton","startGameButton","computerContainer"],"sourceRoot":""} \ No newline at end of file