\n This program is free software: you can redistribute it and/or modify\n it under the terms of the GNU General Public License as published by\n the Free Software Foundation, either version 3 of the License, or\n (at your option) any later version.\n
\n
\n This program is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the \n GNU General Public License\n for more details.\n
\n )}\n \n \n );\n }\n}\n\nexport default App;\n","// In production, we register a service worker to serve assets from local cache.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on the \"N+1\" visit to a page, since previously\n// cached resources are updated in the background.\n\n// To learn more about the benefits of this model, read https://goo.gl/KwvDNy.\n// This link also includes instructions on opting out of this behavior.\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.1/8 is considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\nexport default function register() {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n // const publicUrl = new URL(process.env.PUBLIC_URL, window.location);\n // if (publicUrl.origin !== window.location.origin) {\n // // Our service worker won't work if PUBLIC_URL is on a different origin\n // // from what our page is served on. This might happen if a CDN is used to\n // // serve assets; see https://github.com/facebookincubator/create-react-app/issues/2374\n // return;\n // }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Lets check if a service worker still exists or not.\n checkValidServiceWorker(swUrl);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://goo.gl/SC7cgQ'\n );\n });\n } else {\n // Is not local host. Just register service worker\n registerValidSW(swUrl);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl) {\n navigator.serviceWorker\n .register(swUrl)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the old content will have been purged and\n // the fresh content will have been added to the cache.\n // It's the perfect time to display a \"New content is\n // available; please refresh.\" message in your web app.\n console.log('New content is available; please refresh.');\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.');\n }\n }\n };\n };\n })\n .catch(error => {\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl)\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n if (\n response.status === 404 ||\n response.headers.get('content-type').indexOf('javascript') === -1\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl);\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister();\n });\n }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport App from './App';\n//import {elevate} from './infrastructure/elevator';\nimport registerServiceWorker from './registerServiceWorker';\n\n//elevate();\n\nReactDOM.render(, document.getElementById('root'));\nregisterServiceWorker();\n","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\""],"sourceRoot":""}
\ No newline at end of file
diff --git a/static/js/main.c1156830.chunk.js b/static/js/main.e43f80a3.chunk.js
similarity index 60%
rename from static/js/main.c1156830.chunk.js
rename to static/js/main.e43f80a3.chunk.js
index ae6e9c5f..921adeba 100644
--- a/static/js/main.c1156830.chunk.js
+++ b/static/js/main.e43f80a3.chunk.js
@@ -1,2 +1,2 @@
-(window.webpackJsonpwebhole=window.webpackJsonpwebhole||[]).push([[0],{130:function(e,t){},149:function(e,t,n){},425:function(e,t,n){},427:function(e,t,n){},428:function(e,t,n){},437:function(e,t,n){},438:function(e,t,n){},439:function(e,t,n){},440:function(e,t,n){},441:function(e,t,n){"use strict";n.r(t);var a=n(0),o=n.n(a),r=n(10),i=n.n(r),s=(n(85),n(1)),l=n(2),c=n(4),u=n(3),h=n(6),d=n(5),p=n(22),m=n(9),f=n(23),g=n.n(f),b=function(){function e(){Object(s.a)(this,e),this.names={},this.current_h=Math.random()}return Object(l.a)(e,[{key:"get",value:function(e){return"\u6d1e\u4e3b"===(e=e.toLowerCase())?["hsl(0,0%,97%)","hsl(0,0%,16%)"]:(this.names[e]||(this.current_h+=.618033988749895,this.current_h%=1,this.names[e]=["hsl(".concat(360*this.current_h,", 50%, 90%)"),"hsl(".concat(360*this.current_h,", 60%, 20%)")]),this.names[e])}}]),e}(),v=/(^|[^\d\u20e3\ufe0e\ufe0f])(#\d{1,7})(?![\d\u20e3\ufe0e\ufe0f])/g,E=/((?:https?:\/\/)?thuhole\.com\/?#(?:#|%23)(\d{1,7}))(?!\d|\u20e3|\ufe0e|\ufe0f)/g,_=/(^|[^A-Za-z])((?:(?:Angry|Baby|Crazy|Diligent|Excited|Fat|Greedy|Hungry|Interesting|Jolly|Kind|Little|Magic|Na\xefve|Old|PKU|Quiet|Rich|Superman|Tough|Undefined|Valuable|Wifeless|Xiangbuchulai|Young|Zombie)\s)?(?:Alice|Bob|Carol|Dave|Eve|Francis|Grace|Hans|Isabella|Jason|Kate|Louis|Margaret|Nathan|Olivia|Paul|Queen|Richard|Susan|Thomas|Uma|Vivian|Winnie|Xander|Yasmine|Zach)|You Win(?: \d+)?|\u6d1e\u4e3b)(?![A-Za-z])/gi,w=/(^|[^.@a-zA-Z0-9_])((?:https?:\/\/)?(?:(?:[\w-]+\.)+[a-zA-Z]{2,3}|\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})(?::\d{1,5})?(?:\/[\w~!@#$%^&*()\-_=+[\]{};:,./?|]*)?)(?![a-zA-Z0-9])/gi;function A(e,t){return e=[[null,e]],t.forEach(function(t){var n=Object(m.a)(t,2),a=n[0],o=n[1];e=[].concat.apply([],e.map(function(e){var t=Object(m.a)(e,2),n=t[0],r=t[1];return n?[e]:r.split(o).map(function(e){return o.test(e)?[a,e]:[null,e]}).filter(function(e){var t=Object(m.a)(e,2),n=t[0],a=t[1];return null!==n||a})}))}),e}var k=n(65),y=n.n(k),O=n(66),j=n.n(O),C=n(67),N=n.n(C),x=(n(89),n(90),n(68)),S=n.n(x),I=n(69),D=n.n(I),U=n(70),R=n.n(U),H=n(71),T=n.n(H),Q=n(72),M=n.n(Q),L=n(73),G=n.n(L),P=(n(91),n(92),n(74)),X=n.n(P);function F(e){if(!e.ok)throw Error("\u7f51\u7edc\u9519\u8bef ".concat(e.status," ").concat(e.statusText));return e.text().then(function(e){try{return JSON.parse(e)}catch(t){throw console.error("json parse error"),console.trace(t),console.log(e),new SyntaxError("JSON Parse Error "+e.substr(0,50))}})}function V(){return"&PKUHelperAPI=3.0&jsapiver="+encodeURIComponent("Travis200625212041-"+2*Math.floor(+new Date/72e5))}var W="pkuhelper_login_popup_anchor";function B(e){return e<10?"0"+e:""+e}function Y(e){return"".concat(e.getMonth()+1,"-").concat(B(e.getDate())," ").concat(e.getHours(),":").concat(B(e.getMinutes()),":").concat(B(e.getSeconds()))}var K=N()(j.a);function z(e){var t=new Date(1e3*e.stamp);return o.a.createElement("span",null,o.a.createElement(y.a,{date:t,formatter:K,title:t.toLocaleString("zh-CN",{timeZone:"Asia/Shanghai",hour12:!1})}),"\xa0",Y(t))}function q(e){return o.a.createElement("p",{className:"centered-line title-line aux-margin"},o.a.createElement("span",{className:"black-outline"},e.text))}S.a,D.a,R.a,T.a,M.a,G.a,X.a;var Z=function(e){function t(e){var n;return Object(s.a)(this,t),(n=Object(c.a)(this,Object(u.a)(t).call(this,e))).state={loading_status:"idle"},n.username_ref=o.a.createRef(),n.password_ref=o.a.createRef(),n.input_token_ref=o.a.createRef(),n.popup_anchor=document.getElementById(W),n.popup_anchor||(n.popup_anchor=document.createElement("div"),n.popup_anchor.id=W,document.body.appendChild(n.popup_anchor)),n}return Object(d.a)(t,e),Object(l.a)(t,[{key:"do_sendcode",value:function(e){var t=this;"loading"!==this.state.loading_status&&this.setState({loading_status:"loading"},function(){fetch("//thuhole.com/api_xmcp/login/send_code?user="+encodeURIComponent(t.username_ref.current.value)+"&code_type="+encodeURIComponent(e)+V(),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({excluded_scopes:[]})}).then(F).then(function(e){if(console.log(e),!e.success)throw new Error(JSON.stringify(e));alert(e.msg),t.setState({loading_status:"done"})}).catch(function(e){console.error(e),alert("\u53d1\u9001\u5931\u8d25\n"+e),t.setState({loading_status:"done"})})})}},{key:"do_login",value:function(e){var t=this;"loading"!==this.state.loading_status&&this.setState({loading_status:"loading"},function(){fetch("//thuhole.com/api_xmcp/login/login?user="+encodeURIComponent(t.username_ref.current.value)+"&valid_code="+encodeURIComponent(t.password_ref.current.value)+V(),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({excluded_scopes:[]})}).then(F).then(function(n){if(0!==n.code){if(n.msg)throw new Error(n.msg);throw new Error(JSON.stringify(n))}e(n.user_token),alert("\u767b\u5f55\u6210\u529f"),t.setState({loading_status:"done"}),t.props.on_close()}).catch(function(e){console.error(e),alert("\u767b\u5f55\u5931\u8d25\n"+e),t.setState({loading_status:"done"})})})}},{key:"do_input_token",value:function(e){var t=this;if("loading"!==this.state.loading_status){var n=this.input_token_ref.current.value;this.setState({loading_status:"loading"},function(){fetch("//thuhole.com/api_xmcp/hole/system_msg?user_token="+encodeURIComponent(n)+V()).then(function(e){return e.json()}).then(function(a){if(a.error)throw new Error(a.error);if(0===a.result.length)throw new Error("result check failed");t.setState({loading_status:"done"}),e(n),t.props.on_close()}).catch(function(e){alert("Token\u68c0\u9a8c\u5931\u8d25\n"+e),t.setState({loading_status:"done"}),console.error(e)})})}}},{key:"render",value:function(){var e=this;return i.a.createPortal(o.a.createElement("div",null,o.a.createElement("div",{className:"thuhole-login-popup-shadow"}),o.a.createElement("div",{className:"thuhole-login-popup"},o.a.createElement("p",null,o.a.createElement("b",null,"\u63a5\u6536\u9a8c\u8bc1\u7801\u6765\u767b\u5f55 T\u5927\u6811\u6d1e")),o.a.createElement("p",null,o.a.createElement("label",null,"\u3000\u90ae\u7bb1\xa0",o.a.createElement("input",{ref:this.username_ref,type:"email",autoFocus:!0,defaultValue:"@mails.tsinghua.edu.cn"})),o.a.createElement("span",{className:"thuhole-login-type"},o.a.createElement("a",{onClick:function(t){return e.do_sendcode("mail")}},"\xa0\u53d1\u9001\u90ae\u4ef6\xa0"))),o.a.createElement("p",null,o.a.createElement("label",null,"\u9a8c\u8bc1\u7801\xa0",o.a.createElement("input",{ref:this.password_ref,type:"tel"})),o.a.createElement("button",{type:"button",disabled:"loading"===this.state.loading_status,onClick:function(t){return e.do_login(e.props.token_callback)}},"\u767b\u5f55")),o.a.createElement("hr",null),o.a.createElement("p",null,o.a.createElement("b",null,"\u4ece\u5176\u4ed6\u8bbe\u5907\u5bfc\u5165\u767b\u5f55\u72b6\u6001")),o.a.createElement("p",null,o.a.createElement("input",{ref:this.input_token_ref,placeholder:"User Token"}),o.a.createElement("button",{type:"button",disabled:"loading"===this.state.loading_status,onClick:function(t){return e.do_input_token(e.props.token_callback)}},"\u5bfc\u5165")),o.a.createElement("hr",null),o.a.createElement("p",null,o.a.createElement("button",{onClick:this.props.on_close},"\u53d6\u6d88")))),this.popup_anchor)}}]),t}(a.Component),J=function(e){function t(e){var n;return Object(s.a)(this,t),(n=Object(c.a)(this,Object(u.a)(t).call(this,e))).state={popup_show:!1},n.on_popup_bound=n.on_popup.bind(Object(h.a)(n)),n.on_close_bound=n.on_close.bind(Object(h.a)(n)),n}return Object(d.a)(t,e),Object(l.a)(t,[{key:"on_popup",value:function(){this.setState({popup_show:!0})}},{key:"on_close",value:function(){this.setState({popup_show:!1})}},{key:"render",value:function(){return o.a.createElement(o.a.Fragment,null,this.props.children(this.on_popup_bound),this.state.popup_show&&o.a.createElement(Z,{token_callback:this.props.token_callback,on_close:this.on_close_bound}))}}]),t}(a.Component),$="hole_cache_db",ee=1,te=function(){function e(){var t=this;Object(s.a)(this,e),this.db=null,this.added_items_since_maintenance=0,this.encrypt=this.encrypt.bind(this),this.decrypt=this.decrypt.bind(this);var n=indexedDB.open($,ee);n.onerror=console.error.bind(console),n.onupgradeneeded=function(e){console.log("comment cache db upgrade"),e.target.result.createObjectStore("comment",{keyPath:"pid"}).createIndex("last_access","last_access",{unique:!1})},n.onsuccess=function(e){console.log("comment cache db loaded"),t.db=e.target.result,setTimeout(t.maintenance.bind(t),1)}}return Object(l.a)(e,[{key:"encrypt",value:function(e,t){for(var n=JSON.stringify(t),a="",o=0,r=(42^e)%128;o1e3?(console.log("comment cache db maintenance",a),t.index("last_access").openKeyCursor().onsuccess=function(e){var n=e.target.result;n&&(t.delete(n.primaryKey),--a>1e3&&n.continue())}):console.log("comment cache db no need to maintenance",a),e.added_items_since_maintenance=0},n.onerror=console.error.bind(console)}}},{key:"clear",value:function(){this.db&&(indexedDB.deleteDatabase($),console.log("delete comment cache db"))}}]),e}();function ne(){return window.hole_cache||(window.hole_cache=new te),window.hole_cache}function ae(e){return V()+(e?"&user_token="+e:"")}var oe={load_replies:function(e,t,n,a){return e=parseInt(e),fetch(fe+"/api.php?action=getcomment&pid="+e+ae(t)).then(F).then(function(t){if(0!==t.code)throw t.msg?new Error(t.msg):new Error(JSON.stringify(t));return ne().delete(e).then(function(){ne().put(e,a,t)}),t.data=t.data.sort(function(e,t){return parseInt(e.cid,10)-parseInt(t.cid,10)}).map(function(e){return e._display_color=n.get(e.name),e.variant={},e}),t})},load_replies_with_cache:function(e,t,n,a){return e=parseInt(e),ne().get(e,a).then(function(o){return o?(o.data=o.data.sort(function(e,t){return parseInt(e.cid,10)-parseInt(t.cid,10)}).map(function(e){return e._display_color=n.get(e.name),e.variant={},e}),o):oe.load_replies(e,t,n,a)})},set_attention:function(e,t,n){var a=new URLSearchParams;return a.append("user_token",n),a.append("pid",e),a.append("switch",t?"1":"0"),fetch(fe+"/api.php?action=attention"+ae(n),{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:a}).then(F).then(function(t){if(ne().delete(e),0!==t.code&&(!t.msg||"\u5df2\u7ecf\u5173\u6ce8\u8fc7\u4e86"!==t.msg))throw t.msg&&alert(t.msg),new Error(JSON.stringify(t));return t})},report:function(e,t,n){var a=new URLSearchParams;return a.append("user_token",n),a.append("pid",e),a.append("reason",t),fetch(fe+"/api.php?action=report"+ae(n),{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:a}).then(F).then(function(e){if(0!==e.code)throw e.msg&&alert(e.msg),new Error(JSON.stringify(e));return e})},get_list:function(e,t){return fetch(fe+"/api.php?action=getlist&p="+e+ae(t)).then(F).then(function(e){if(0!==e.code)throw new Error(JSON.stringify(e));return e})},get_search:function(e,t,n){return fetch(fe+"/api.php?action=search&pagesize=50&page="+e+"&keywords="+encodeURIComponent(t)+ae(n)).then(F).then(function(e){if(0!==e.code){if(e.msg)throw new Error(e.msg);throw new Error(JSON.stringify(e))}return e})},get_single:function(e,t){return fetch(fe+"/api.php?action=getone&pid="+e+ae(t)).then(F).then(function(e){if(0!==e.code)throw e.msg?new Error(e.msg):new Error(JSON.stringify(e));return e})},get_attention:function(e){return fetch(fe+"/api.php?action=getattention"+ae(e)).then(F).then(function(e){if(0!==e.code){if(e.msg)throw new Error(e.msg);throw new Error(JSON.stringify(e))}return e})}},re=n(35),ie=n.n(re),se=(n(149),n(75)),le=n.n(se),ce=n(76),ue=n.n(ce),he=n(36),de=n.n(he),pe=(n(424),n(425),n(426),new le.a({html:!1,linkify:!1,breaks:!0,inline:!0,highlight:function(e,t){if(t&&de.a.getLanguage(t))try{return'
\n This program is free software: you can redistribute it and/or modify\n it under the terms of the GNU General Public License as published by\n the Free Software Foundation, either version 3 of the License, or\n (at your option) any later version.\n
\n
\n This program is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the \n GNU General Public License\n for more details.\n
\n )}\n \n \n );\n }\n}\n\nexport default App;\n","// In production, we register a service worker to serve assets from local cache.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on the \"N+1\" visit to a page, since previously\n// cached resources are updated in the background.\n\n// To learn more about the benefits of this model, read https://goo.gl/KwvDNy.\n// This link also includes instructions on opting out of this behavior.\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.1/8 is considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\nexport default function register() {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n // const publicUrl = new URL(process.env.PUBLIC_URL, window.location);\n // if (publicUrl.origin !== window.location.origin) {\n // // Our service worker won't work if PUBLIC_URL is on a different origin\n // // from what our page is served on. This might happen if a CDN is used to\n // // serve assets; see https://github.com/facebookincubator/create-react-app/issues/2374\n // return;\n // }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Lets check if a service worker still exists or not.\n checkValidServiceWorker(swUrl);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://goo.gl/SC7cgQ'\n );\n });\n } else {\n // Is not local host. Just register service worker\n registerValidSW(swUrl);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl) {\n navigator.serviceWorker\n .register(swUrl)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the old content will have been purged and\n // the fresh content will have been added to the cache.\n // It's the perfect time to display a \"New content is\n // available; please refresh.\" message in your web app.\n console.log('New content is available; please refresh.');\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.');\n }\n }\n };\n };\n })\n .catch(error => {\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl)\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n if (\n response.status === 404 ||\n response.headers.get('content-type').indexOf('javascript') === -1\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl);\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister();\n });\n }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport App from './App';\n//import {elevate} from './infrastructure/elevator';\nimport registerServiceWorker from './registerServiceWorker';\n\n//elevate();\n\nReactDOM.render(, document.getElementById('root'));\nregisterServiceWorker();\n","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\""],"sourceRoot":""}
\ No newline at end of file