Merge branch 'feature/kakaomap_setting' into 'develop'
Feature/kakaomap setting - setting the basic layout of frontend - display the kakao map in main page - display the kakao map in main page - add search location box - create the marker to each map - implement InfoWindow - add display infowindow function for each marker See merge request !3
Showing
6 changed files
with
986 additions
and
19 deletions
... | @@ -1274,6 +1274,24 @@ | ... | @@ -1274,6 +1274,24 @@ |
1274 | "resolved": "https://registry.npmjs.org/@csstools/normalize.css/-/normalize.css-10.1.0.tgz", | 1274 | "resolved": "https://registry.npmjs.org/@csstools/normalize.css/-/normalize.css-10.1.0.tgz", |
1275 | "integrity": "sha512-ij4wRiunFfaJxjB0BdrYHIH8FxBJpOwNPhhAcunlmPdXudL1WQV1qoP9un6JsEBAgQH+7UXyyjh0g7jTxXK6tg==" | 1275 | "integrity": "sha512-ij4wRiunFfaJxjB0BdrYHIH8FxBJpOwNPhhAcunlmPdXudL1WQV1qoP9un6JsEBAgQH+7UXyyjh0g7jTxXK6tg==" |
1276 | }, | 1276 | }, |
1277 | + "@emotion/is-prop-valid": { | ||
1278 | + "version": "0.8.8", | ||
1279 | + "resolved": "https://registry.npmjs.org/@emotion/is-prop-valid/-/is-prop-valid-0.8.8.tgz", | ||
1280 | + "integrity": "sha512-u5WtneEAr5IDG2Wv65yhunPSMLIpuKsbuOktRojfrEiEvRyC85LgPMZI63cr7NUqT8ZIGdSVg8ZKGxIug4lXcA==", | ||
1281 | + "requires": { | ||
1282 | + "@emotion/memoize": "0.7.4" | ||
1283 | + } | ||
1284 | + }, | ||
1285 | + "@emotion/memoize": { | ||
1286 | + "version": "0.7.4", | ||
1287 | + "resolved": "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.7.4.tgz", | ||
1288 | + "integrity": "sha512-Ja/Vfqe3HpuzRsG1oBtWTHk2PGZ7GR+2Vz5iYGelAw8dx32K0y7PjVuxK6z1nMpZOqAFsRUPCkK1YjJ56qJlgw==" | ||
1289 | + }, | ||
1290 | + "@emotion/unitless": { | ||
1291 | + "version": "0.7.5", | ||
1292 | + "resolved": "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.7.5.tgz", | ||
1293 | + "integrity": "sha512-OWORNpfjMsSSUBVrRBVGECkhWcULOAJz9ZW8uK9qgxD+87M7jHRcvh/A96XXNhXTLmKcoYSQtBEX7lHMO7YRwg==" | ||
1294 | + }, | ||
1277 | "@hapi/address": { | 1295 | "@hapi/address": { |
1278 | "version": "2.1.4", | 1296 | "version": "2.1.4", |
1279 | "resolved": "https://registry.npmjs.org/@hapi/address/-/address-2.1.4.tgz", | 1297 | "resolved": "https://registry.npmjs.org/@hapi/address/-/address-2.1.4.tgz", |
... | @@ -1487,6 +1505,25 @@ | ... | @@ -1487,6 +1505,25 @@ |
1487 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-1.1.3.tgz", | 1505 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-1.1.3.tgz", |
1488 | "integrity": "sha512-shAmDyaQC4H92APFoIaVDHCx5bStIocgvbwQyxPRrbUY20V1EYTbSDchWbuwlMG3V17cprZhA6+78JfB+3DTPw==" | 1506 | "integrity": "sha512-shAmDyaQC4H92APFoIaVDHCx5bStIocgvbwQyxPRrbUY20V1EYTbSDchWbuwlMG3V17cprZhA6+78JfB+3DTPw==" |
1489 | }, | 1507 | }, |
1508 | + "@popperjs/core": { | ||
1509 | + "version": "2.4.0", | ||
1510 | + "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.4.0.tgz", | ||
1511 | + "integrity": "sha512-NMrDy6EWh9TPdSRiHmHH2ye1v5U0gBD7pRYwSwJvomx7Bm4GG04vu63dYiVzebLOx2obPpJugew06xVP0Nk7hA==" | ||
1512 | + }, | ||
1513 | + "@restart/context": { | ||
1514 | + "version": "2.1.4", | ||
1515 | + "resolved": "https://registry.npmjs.org/@restart/context/-/context-2.1.4.tgz", | ||
1516 | + "integrity": "sha512-INJYZQJP7g+IoDUh/475NlGiTeMfwTXUEr3tmRneckHIxNolGOW9CTq83S8cxq0CgJwwcMzMJFchxvlwe7Rk8Q==" | ||
1517 | + }, | ||
1518 | + "@restart/hooks": { | ||
1519 | + "version": "0.3.25", | ||
1520 | + "resolved": "https://registry.npmjs.org/@restart/hooks/-/hooks-0.3.25.tgz", | ||
1521 | + "integrity": "sha512-m2v3N5pxTsIiSH74/sb1yW8D9RxkJidGW+5Mfwn/lHb2QzhZNlaU1su7abSyT9EGf0xS/0waLjrf7/XxQHUk7w==", | ||
1522 | + "requires": { | ||
1523 | + "lodash": "^4.17.15", | ||
1524 | + "lodash-es": "^4.17.15" | ||
1525 | + } | ||
1526 | + }, | ||
1490 | "@sheerun/mutationobserver-shim": { | 1527 | "@sheerun/mutationobserver-shim": { |
1491 | "version": "0.3.3", | 1528 | "version": "0.3.3", |
1492 | "resolved": "https://registry.npmjs.org/@sheerun/mutationobserver-shim/-/mutationobserver-shim-0.3.3.tgz", | 1529 | "resolved": "https://registry.npmjs.org/@sheerun/mutationobserver-shim/-/mutationobserver-shim-0.3.3.tgz", |
... | @@ -1702,6 +1739,8 @@ | ... | @@ -1702,6 +1739,8 @@ |
1702 | }, | 1739 | }, |
1703 | "@testing-library/jest-dom": { | 1740 | "@testing-library/jest-dom": { |
1704 | "version": "4.2.4", | 1741 | "version": "4.2.4", |
1742 | + "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-4.2.4.tgz", | ||
1743 | + "integrity": "sha512-j31Bn0rQo12fhCWOUWy9fl7wtqkp7In/YP2p5ZFyRuiiB9Qs3g+hS4gAmDWONbAHcRmVooNJ5eOHQDCOmUFXHg==", | ||
1705 | "requires": { | 1744 | "requires": { |
1706 | "@babel/runtime": "^7.5.1", | 1745 | "@babel/runtime": "^7.5.1", |
1707 | "chalk": "^2.4.1", | 1746 | "chalk": "^2.4.1", |
... | @@ -1726,6 +1765,8 @@ | ... | @@ -1726,6 +1765,8 @@ |
1726 | }, | 1765 | }, |
1727 | "@testing-library/react": { | 1766 | "@testing-library/react": { |
1728 | "version": "9.5.0", | 1767 | "version": "9.5.0", |
1768 | + "resolved": "https://registry.npmjs.org/@testing-library/react/-/react-9.5.0.tgz", | ||
1769 | + "integrity": "sha512-di1b+D0p+rfeboHO5W7gTVeZDIK5+maEgstrZbWZSSvxDyfDRkkyBE1AJR5Psd6doNldluXlCWqXriUfqu/9Qg==", | ||
1729 | "requires": { | 1770 | "requires": { |
1730 | "@babel/runtime": "^7.8.4", | 1771 | "@babel/runtime": "^7.8.4", |
1731 | "@testing-library/dom": "^6.15.0", | 1772 | "@testing-library/dom": "^6.15.0", |
... | @@ -1733,7 +1774,9 @@ | ... | @@ -1733,7 +1774,9 @@ |
1733 | } | 1774 | } |
1734 | }, | 1775 | }, |
1735 | "@testing-library/user-event": { | 1776 | "@testing-library/user-event": { |
1736 | - "version": "7.2.1" | 1777 | + "version": "7.2.1", |
1778 | + "resolved": "https://registry.npmjs.org/@testing-library/user-event/-/user-event-7.2.1.tgz", | ||
1779 | + "integrity": "sha512-oZ0Ib5I4Z2pUEcoo95cT1cr6slco9WY7yiPpG+RGNkj8YcYgJnM7pXmYmorNOReh8MIGcKSqXyeGjxnr8YiZbA==" | ||
1737 | }, | 1780 | }, |
1738 | "@types/babel__core": { | 1781 | "@types/babel__core": { |
1739 | "version": "7.1.7", | 1782 | "version": "7.1.7", |
... | @@ -1965,6 +2008,11 @@ | ... | @@ -1965,6 +2008,11 @@ |
1965 | } | 2008 | } |
1966 | } | 2009 | } |
1967 | }, | 2010 | }, |
2011 | + "@types/warning": { | ||
2012 | + "version": "3.0.0", | ||
2013 | + "resolved": "https://registry.npmjs.org/@types/warning/-/warning-3.0.0.tgz", | ||
2014 | + "integrity": "sha1-DSUBJorY+ZYrdA04fEZU9fjiPlI=" | ||
2015 | + }, | ||
1968 | "@types/yargs": { | 2016 | "@types/yargs": { |
1969 | "version": "13.0.9", | 2017 | "version": "13.0.9", |
1970 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-13.0.9.tgz", | 2018 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-13.0.9.tgz", |
... | @@ -2818,6 +2866,22 @@ | ... | @@ -2818,6 +2866,22 @@ |
2818 | "resolved": "https://registry.npmjs.org/babel-plugin-named-asset-import/-/babel-plugin-named-asset-import-0.3.6.tgz", | 2866 | "resolved": "https://registry.npmjs.org/babel-plugin-named-asset-import/-/babel-plugin-named-asset-import-0.3.6.tgz", |
2819 | "integrity": "sha512-1aGDUfL1qOOIoqk9QKGIo2lANk+C7ko/fqH0uIyC71x3PEGz0uVP8ISgfEsFuG+FKmjHTvFK/nNM8dowpmUxLA==" | 2867 | "integrity": "sha512-1aGDUfL1qOOIoqk9QKGIo2lANk+C7ko/fqH0uIyC71x3PEGz0uVP8ISgfEsFuG+FKmjHTvFK/nNM8dowpmUxLA==" |
2820 | }, | 2868 | }, |
2869 | + "babel-plugin-styled-components": { | ||
2870 | + "version": "1.10.7", | ||
2871 | + "resolved": "https://registry.npmjs.org/babel-plugin-styled-components/-/babel-plugin-styled-components-1.10.7.tgz", | ||
2872 | + "integrity": "sha512-MBMHGcIA22996n9hZRf/UJLVVgkEOITuR2SvjHLb5dSTUyR4ZRGn+ngITapes36FI3WLxZHfRhkA1ffHxihOrg==", | ||
2873 | + "requires": { | ||
2874 | + "@babel/helper-annotate-as-pure": "^7.0.0", | ||
2875 | + "@babel/helper-module-imports": "^7.0.0", | ||
2876 | + "babel-plugin-syntax-jsx": "^6.18.0", | ||
2877 | + "lodash": "^4.17.11" | ||
2878 | + } | ||
2879 | + }, | ||
2880 | + "babel-plugin-syntax-jsx": { | ||
2881 | + "version": "6.18.0", | ||
2882 | + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-jsx/-/babel-plugin-syntax-jsx-6.18.0.tgz", | ||
2883 | + "integrity": "sha1-CvMqmm4Tyno/1QaeYtew9Y0NiUY=" | ||
2884 | + }, | ||
2821 | "babel-plugin-syntax-object-rest-spread": { | 2885 | "babel-plugin-syntax-object-rest-spread": { |
2822 | "version": "6.13.0", | 2886 | "version": "6.13.0", |
2823 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz", | 2887 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz", |
... | @@ -3130,6 +3194,11 @@ | ... | @@ -3130,6 +3194,11 @@ |
3130 | "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", | 3194 | "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", |
3131 | "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=" | 3195 | "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=" |
3132 | }, | 3196 | }, |
3197 | + "bootstrap": { | ||
3198 | + "version": "3.4.1", | ||
3199 | + "resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-3.4.1.tgz", | ||
3200 | + "integrity": "sha512-yN5oZVmRCwe5aKwzRj6736nSmKDX7pLYwsXiCj/EYmo16hODaBiT4En5btW/jhBF/seV+XMx3aYwukYC3A49DA==" | ||
3201 | + }, | ||
3133 | "brace-expansion": { | 3202 | "brace-expansion": { |
3134 | "version": "1.1.11", | 3203 | "version": "1.1.11", |
3135 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", | 3204 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", |
... | @@ -3417,6 +3486,11 @@ | ... | @@ -3417,6 +3486,11 @@ |
3417 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", | 3486 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", |
3418 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" | 3487 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" |
3419 | }, | 3488 | }, |
3489 | + "camelize": { | ||
3490 | + "version": "1.0.0", | ||
3491 | + "resolved": "https://registry.npmjs.org/camelize/-/camelize-1.0.0.tgz", | ||
3492 | + "integrity": "sha1-FkpUg+Yw+kMh5a8HAg5TGDGyYJs=" | ||
3493 | + }, | ||
3420 | "caniuse-api": { | 3494 | "caniuse-api": { |
3421 | "version": "3.0.0", | 3495 | "version": "3.0.0", |
3422 | "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz", | 3496 | "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz", |
... | @@ -3585,6 +3659,11 @@ | ... | @@ -3585,6 +3659,11 @@ |
3585 | } | 3659 | } |
3586 | } | 3660 | } |
3587 | }, | 3661 | }, |
3662 | + "classnames": { | ||
3663 | + "version": "2.2.6", | ||
3664 | + "resolved": "https://registry.npmjs.org/classnames/-/classnames-2.2.6.tgz", | ||
3665 | + "integrity": "sha512-JR/iSQOSt+LQIWwrwEzJ9uk0xfN3mTVYMwt1Ir5mUcSN6pU+V4zQFFaJsclJbPuAUQH+yfWef6tm7l1quW3C8Q==" | ||
3666 | + }, | ||
3588 | "clean-css": { | 3667 | "clean-css": { |
3589 | "version": "4.2.3", | 3668 | "version": "4.2.3", |
3590 | "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.2.3.tgz", | 3669 | "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.2.3.tgz", |
... | @@ -4052,6 +4131,11 @@ | ... | @@ -4052,6 +4131,11 @@ |
4052 | "postcss": "^7.0.5" | 4131 | "postcss": "^7.0.5" |
4053 | } | 4132 | } |
4054 | }, | 4133 | }, |
4134 | + "css-color-keywords": { | ||
4135 | + "version": "1.0.0", | ||
4136 | + "resolved": "https://registry.npmjs.org/css-color-keywords/-/css-color-keywords-1.0.0.tgz", | ||
4137 | + "integrity": "sha1-/qJhbcZ2spYmhrOvjb2+GAskTgU=" | ||
4138 | + }, | ||
4055 | "css-color-names": { | 4139 | "css-color-names": { |
4056 | "version": "0.0.4", | 4140 | "version": "0.0.4", |
4057 | "resolved": "https://registry.npmjs.org/css-color-names/-/css-color-names-0.0.4.tgz", | 4141 | "resolved": "https://registry.npmjs.org/css-color-names/-/css-color-names-0.0.4.tgz", |
... | @@ -4135,6 +4219,23 @@ | ... | @@ -4135,6 +4219,23 @@ |
4135 | "resolved": "https://registry.npmjs.org/css-select-base-adapter/-/css-select-base-adapter-0.1.1.tgz", | 4219 | "resolved": "https://registry.npmjs.org/css-select-base-adapter/-/css-select-base-adapter-0.1.1.tgz", |
4136 | "integrity": "sha512-jQVeeRG70QI08vSTwf1jHxp74JoZsr2XSgETae8/xC8ovSnL2WF87GTLO86Sbwdt2lK4Umg4HnnwMO4YF3Ce7w==" | 4220 | "integrity": "sha512-jQVeeRG70QI08vSTwf1jHxp74JoZsr2XSgETae8/xC8ovSnL2WF87GTLO86Sbwdt2lK4Umg4HnnwMO4YF3Ce7w==" |
4137 | }, | 4221 | }, |
4222 | + "css-to-react-native": { | ||
4223 | + "version": "2.3.2", | ||
4224 | + "resolved": "https://registry.npmjs.org/css-to-react-native/-/css-to-react-native-2.3.2.tgz", | ||
4225 | + "integrity": "sha512-VOFaeZA053BqvvvqIA8c9n0+9vFppVBAHCp6JgFTtTMU3Mzi+XnelJ9XC9ul3BqFzZyQ5N+H0SnwsWT2Ebchxw==", | ||
4226 | + "requires": { | ||
4227 | + "camelize": "^1.0.0", | ||
4228 | + "css-color-keywords": "^1.0.0", | ||
4229 | + "postcss-value-parser": "^3.3.0" | ||
4230 | + }, | ||
4231 | + "dependencies": { | ||
4232 | + "postcss-value-parser": { | ||
4233 | + "version": "3.3.1", | ||
4234 | + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", | ||
4235 | + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" | ||
4236 | + } | ||
4237 | + } | ||
4238 | + }, | ||
4138 | "css-tree": { | 4239 | "css-tree": { |
4139 | "version": "1.0.0-alpha.37", | 4240 | "version": "1.0.0-alpha.37", |
4140 | "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.0.0-alpha.37.tgz", | 4241 | "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.0.0-alpha.37.tgz", |
... | @@ -4326,6 +4427,11 @@ | ... | @@ -4326,6 +4427,11 @@ |
4326 | } | 4427 | } |
4327 | } | 4428 | } |
4328 | }, | 4429 | }, |
4430 | + "daum-map-api": { | ||
4431 | + "version": "1.0.2", | ||
4432 | + "resolved": "https://registry.npmjs.org/daum-map-api/-/daum-map-api-1.0.2.tgz", | ||
4433 | + "integrity": "sha1-3hbrEB11Ea5dZC/CZsl/lHmJiqQ=" | ||
4434 | + }, | ||
4329 | "debug": { | 4435 | "debug": { |
4330 | "version": "2.6.9", | 4436 | "version": "2.6.9", |
4331 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", | 4437 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", |
... | @@ -4585,6 +4691,15 @@ | ... | @@ -4585,6 +4691,15 @@ |
4585 | "utila": "~0.4" | 4691 | "utila": "~0.4" |
4586 | } | 4692 | } |
4587 | }, | 4693 | }, |
4694 | + "dom-helpers": { | ||
4695 | + "version": "5.1.4", | ||
4696 | + "resolved": "https://registry.npmjs.org/dom-helpers/-/dom-helpers-5.1.4.tgz", | ||
4697 | + "integrity": "sha512-TjMyeVUvNEnOnhzs6uAn9Ya47GmMo3qq7m+Lr/3ON0Rs5kHvb8I+SQYjLUSYn7qhEm0QjW0yrBkvz9yOrwwz1A==", | ||
4698 | + "requires": { | ||
4699 | + "@babel/runtime": "^7.8.7", | ||
4700 | + "csstype": "^2.6.7" | ||
4701 | + } | ||
4702 | + }, | ||
4588 | "dom-serializer": { | 4703 | "dom-serializer": { |
4589 | "version": "0.2.2", | 4704 | "version": "0.2.2", |
4590 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.2.2.tgz", | 4705 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.2.2.tgz", |
... | @@ -7347,6 +7462,11 @@ | ... | @@ -7347,6 +7462,11 @@ |
7347 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", | 7462 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", |
7348 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" | 7463 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" |
7349 | }, | 7464 | }, |
7465 | + "is-what": { | ||
7466 | + "version": "3.8.0", | ||
7467 | + "resolved": "https://registry.npmjs.org/is-what/-/is-what-3.8.0.tgz", | ||
7468 | + "integrity": "sha512-UKeBoQfV8bjlM4pmx1FLDHdxslW/1mTksEs8ReVsilPmUv5cORd4+2/wFcviI3cUjrLybxCjzc8DnodAzJ/Wrg==" | ||
7469 | + }, | ||
7350 | "is-windows": { | 7470 | "is-windows": { |
7351 | "version": "1.0.2", | 7471 | "version": "1.0.2", |
7352 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", | 7472 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", |
... | @@ -8258,6 +8378,11 @@ | ... | @@ -8258,6 +8378,11 @@ |
8258 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", | 8378 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", |
8259 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" | 8379 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" |
8260 | }, | 8380 | }, |
8381 | + "lodash-es": { | ||
8382 | + "version": "4.17.15", | ||
8383 | + "resolved": "https://registry.npmjs.org/lodash-es/-/lodash-es-4.17.15.tgz", | ||
8384 | + "integrity": "sha512-rlrc3yU3+JNOpZ9zj5pQtxnx2THmvRykwL4Xlxoa8I9lHBlVbbyPhgyPMioxVZ4NqyxaVVtaJnzsyOidQIhyyQ==" | ||
8385 | + }, | ||
8261 | "lodash._reinterpolate": { | 8386 | "lodash._reinterpolate": { |
8262 | "version": "3.0.0", | 8387 | "version": "3.0.0", |
8263 | "resolved": "https://registry.npmjs.org/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz", | 8388 | "resolved": "https://registry.npmjs.org/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz", |
... | @@ -8404,6 +8529,11 @@ | ... | @@ -8404,6 +8529,11 @@ |
8404 | "p-is-promise": "^2.0.0" | 8529 | "p-is-promise": "^2.0.0" |
8405 | } | 8530 | } |
8406 | }, | 8531 | }, |
8532 | + "memoize-one": { | ||
8533 | + "version": "5.1.1", | ||
8534 | + "resolved": "https://registry.npmjs.org/memoize-one/-/memoize-one-5.1.1.tgz", | ||
8535 | + "integrity": "sha512-HKeeBpWvqiVJD57ZUAsJNm71eHTykffzcLZVYWiVfQeI1rJtuEaS7hQiEpWfVVk18donPwJEcFKIkCmPJNOhHA==" | ||
8536 | + }, | ||
8407 | "memory-fs": { | 8537 | "memory-fs": { |
8408 | "version": "0.4.1", | 8538 | "version": "0.4.1", |
8409 | "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.4.1.tgz", | 8539 | "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.4.1.tgz", |
... | @@ -8442,6 +8572,14 @@ | ... | @@ -8442,6 +8572,14 @@ |
8442 | } | 8572 | } |
8443 | } | 8573 | } |
8444 | }, | 8574 | }, |
8575 | + "merge-anything": { | ||
8576 | + "version": "2.4.4", | ||
8577 | + "resolved": "https://registry.npmjs.org/merge-anything/-/merge-anything-2.4.4.tgz", | ||
8578 | + "integrity": "sha512-l5XlriUDJKQT12bH+rVhAHjwIuXWdAIecGwsYjv2LJo+dA1AeRTmeQS+3QBpO6lEthBMDi2IUMpLC1yyRvGlwQ==", | ||
8579 | + "requires": { | ||
8580 | + "is-what": "^3.3.1" | ||
8581 | + } | ||
8582 | + }, | ||
8445 | "merge-deep": { | 8583 | "merge-deep": { |
8446 | "version": "3.0.2", | 8584 | "version": "3.0.2", |
8447 | "resolved": "https://registry.npmjs.org/merge-deep/-/merge-deep-3.0.2.tgz", | 8585 | "resolved": "https://registry.npmjs.org/merge-deep/-/merge-deep-3.0.2.tgz", |
... | @@ -10624,6 +10762,15 @@ | ... | @@ -10624,6 +10762,15 @@ |
10624 | "react-is": "^16.8.1" | 10762 | "react-is": "^16.8.1" |
10625 | } | 10763 | } |
10626 | }, | 10764 | }, |
10765 | + "prop-types-extra": { | ||
10766 | + "version": "1.1.1", | ||
10767 | + "resolved": "https://registry.npmjs.org/prop-types-extra/-/prop-types-extra-1.1.1.tgz", | ||
10768 | + "integrity": "sha512-59+AHNnHYCdiC+vMwY52WmvP5dM3QLeoumYuEyceQDi9aEhtwN9zIQ2ZNo25sMyXnbh32h+P1ezDsUpUH3JAew==", | ||
10769 | + "requires": { | ||
10770 | + "react-is": "^16.3.2", | ||
10771 | + "warning": "^4.0.0" | ||
10772 | + } | ||
10773 | + }, | ||
10627 | "proxy-addr": { | 10774 | "proxy-addr": { |
10628 | "version": "2.0.6", | 10775 | "version": "2.0.6", |
10629 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", | 10776 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", |
... | @@ -10782,6 +10929,8 @@ | ... | @@ -10782,6 +10929,8 @@ |
10782 | }, | 10929 | }, |
10783 | "react": { | 10930 | "react": { |
10784 | "version": "16.13.1", | 10931 | "version": "16.13.1", |
10932 | + "resolved": "https://registry.npmjs.org/react/-/react-16.13.1.tgz", | ||
10933 | + "integrity": "sha512-YMZQQq32xHLX0bz5Mnibv1/LHb3Sqzngu7xstSM+vrkE5Kzr9xE0yMByK5kMoTK30YVJE61WfbxIFFvfeDKT1w==", | ||
10785 | "requires": { | 10934 | "requires": { |
10786 | "loose-envify": "^1.1.0", | 10935 | "loose-envify": "^1.1.0", |
10787 | "object-assign": "^4.1.1", | 10936 | "object-assign": "^4.1.1", |
... | @@ -10801,6 +10950,26 @@ | ... | @@ -10801,6 +10950,26 @@ |
10801 | "whatwg-fetch": "^3.0.0" | 10950 | "whatwg-fetch": "^3.0.0" |
10802 | } | 10951 | } |
10803 | }, | 10952 | }, |
10953 | + "react-bootstrap": { | ||
10954 | + "version": "1.0.1", | ||
10955 | + "resolved": "https://registry.npmjs.org/react-bootstrap/-/react-bootstrap-1.0.1.tgz", | ||
10956 | + "integrity": "sha512-xMHwsvDN7sIv26P9wWiosWjITZije2dRCjEJHVfV2KFoSJY+8uv2zttEw0XMB7xviQcW3zuIGLJXuj8vf6lYEg==", | ||
10957 | + "requires": { | ||
10958 | + "@babel/runtime": "^7.4.2", | ||
10959 | + "@restart/context": "^2.1.4", | ||
10960 | + "@restart/hooks": "^0.3.21", | ||
10961 | + "@types/react": "^16.9.23", | ||
10962 | + "classnames": "^2.2.6", | ||
10963 | + "dom-helpers": "^5.1.2", | ||
10964 | + "invariant": "^2.2.4", | ||
10965 | + "prop-types": "^15.7.2", | ||
10966 | + "prop-types-extra": "^1.1.0", | ||
10967 | + "react-overlays": "^3.1.2", | ||
10968 | + "react-transition-group": "^4.0.0", | ||
10969 | + "uncontrollable": "^7.0.0", | ||
10970 | + "warning": "^4.0.3" | ||
10971 | + } | ||
10972 | + }, | ||
10804 | "react-dev-utils": { | 10973 | "react-dev-utils": { |
10805 | "version": "10.2.1", | 10974 | "version": "10.2.1", |
10806 | "resolved": "https://registry.npmjs.org/react-dev-utils/-/react-dev-utils-10.2.1.tgz", | 10975 | "resolved": "https://registry.npmjs.org/react-dev-utils/-/react-dev-utils-10.2.1.tgz", |
... | @@ -11033,6 +11202,8 @@ | ... | @@ -11033,6 +11202,8 @@ |
11033 | }, | 11202 | }, |
11034 | "react-dom": { | 11203 | "react-dom": { |
11035 | "version": "16.13.1", | 11204 | "version": "16.13.1", |
11205 | + "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-16.13.1.tgz", | ||
11206 | + "integrity": "sha512-81PIMmVLnCNLO/fFOQxdQkvEq/+Hfpv24XNJfpyZhTRfO0QcmQIF/PgCa1zCOj2w1hrn12MFLyaJ/G0+Mxtfag==", | ||
11036 | "requires": { | 11207 | "requires": { |
11037 | "loose-envify": "^1.1.0", | 11208 | "loose-envify": "^1.1.0", |
11038 | "object-assign": "^4.1.1", | 11209 | "object-assign": "^4.1.1", |
... | @@ -11050,6 +11221,39 @@ | ... | @@ -11050,6 +11221,39 @@ |
11050 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", | 11221 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", |
11051 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==" | 11222 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==" |
11052 | }, | 11223 | }, |
11224 | + "react-kakao-maps": { | ||
11225 | + "version": "0.0.13", | ||
11226 | + "resolved": "https://registry.npmjs.org/react-kakao-maps/-/react-kakao-maps-0.0.13.tgz", | ||
11227 | + "integrity": "sha512-1ZHGbdvucFpq3rPSee1UB8cY/61QloQeH2Kh1SMSvIoL2kIUIo1lbF8FnwkHo3zrbpqcS4kIFPvvDB5xs27MdA==", | ||
11228 | + "requires": { | ||
11229 | + "@babel/runtime-corejs3": "^7.6.2", | ||
11230 | + "babel-runtime": "^6.26.0", | ||
11231 | + "react": "^16.9.0", | ||
11232 | + "react-dom": "^16.9.0", | ||
11233 | + "scriptjs": "^2.5.9", | ||
11234 | + "styled-components": "^4.3.2" | ||
11235 | + } | ||
11236 | + }, | ||
11237 | + "react-lifecycles-compat": { | ||
11238 | + "version": "3.0.4", | ||
11239 | + "resolved": "https://registry.npmjs.org/react-lifecycles-compat/-/react-lifecycles-compat-3.0.4.tgz", | ||
11240 | + "integrity": "sha512-fBASbA6LnOU9dOU2eW7aQ8xmYBSXUIWr+UmF9b1efZBazGNO+rcXT/icdKnYm2pTwcRylVUYwW7H1PHfLekVzA==" | ||
11241 | + }, | ||
11242 | + "react-overlays": { | ||
11243 | + "version": "3.2.0", | ||
11244 | + "resolved": "https://registry.npmjs.org/react-overlays/-/react-overlays-3.2.0.tgz", | ||
11245 | + "integrity": "sha512-YTgCmw6l4uBOYylSnc3V8WLX+A0EoGnzDrqkYz0K7MUKbMBZFpaxLXH4EF9eZbspd+syZHQ5XAABI7n/zak1EA==", | ||
11246 | + "requires": { | ||
11247 | + "@babel/runtime": "^7.4.5", | ||
11248 | + "@popperjs/core": "^2.0.0", | ||
11249 | + "@restart/hooks": "^0.3.12", | ||
11250 | + "@types/warning": "^3.0.0", | ||
11251 | + "dom-helpers": "^5.1.0", | ||
11252 | + "prop-types": "^15.7.2", | ||
11253 | + "uncontrollable": "^7.0.0", | ||
11254 | + "warning": "^4.0.3" | ||
11255 | + } | ||
11256 | + }, | ||
11053 | "react-router": { | 11257 | "react-router": { |
11054 | "version": "5.2.0", | 11258 | "version": "5.2.0", |
11055 | "resolved": "https://registry.npmjs.org/react-router/-/react-router-5.2.0.tgz", | 11259 | "resolved": "https://registry.npmjs.org/react-router/-/react-router-5.2.0.tgz", |
... | @@ -11098,6 +11302,8 @@ | ... | @@ -11098,6 +11302,8 @@ |
11098 | }, | 11302 | }, |
11099 | "react-scripts": { | 11303 | "react-scripts": { |
11100 | "version": "3.4.1", | 11304 | "version": "3.4.1", |
11305 | + "resolved": "https://registry.npmjs.org/react-scripts/-/react-scripts-3.4.1.tgz", | ||
11306 | + "integrity": "sha512-JpTdi/0Sfd31mZA6Ukx+lq5j1JoKItX7qqEK4OiACjVQletM1P38g49d9/D0yTxp9FrSF+xpJFStkGgKEIRjlQ==", | ||
11101 | "requires": { | 11307 | "requires": { |
11102 | "@babel/core": "7.9.0", | 11308 | "@babel/core": "7.9.0", |
11103 | "@svgr/webpack": "4.3.3", | 11309 | "@svgr/webpack": "4.3.3", |
... | @@ -11175,6 +11381,17 @@ | ... | @@ -11175,6 +11381,17 @@ |
11175 | } | 11381 | } |
11176 | } | 11382 | } |
11177 | }, | 11383 | }, |
11384 | + "react-transition-group": { | ||
11385 | + "version": "4.4.1", | ||
11386 | + "resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-4.4.1.tgz", | ||
11387 | + "integrity": "sha512-Djqr7OQ2aPUiYurhPalTrVy9ddmFCCzwhqQmtN+J3+3DzLO209Fdr70QrN8Z3DsglWql6iY1lDWAfpFiBtuKGw==", | ||
11388 | + "requires": { | ||
11389 | + "@babel/runtime": "^7.5.5", | ||
11390 | + "dom-helpers": "^5.0.1", | ||
11391 | + "loose-envify": "^1.4.0", | ||
11392 | + "prop-types": "^15.6.2" | ||
11393 | + } | ||
11394 | + }, | ||
11178 | "read-pkg": { | 11395 | "read-pkg": { |
11179 | "version": "2.0.0", | 11396 | "version": "2.0.0", |
11180 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", | 11397 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", |
... | @@ -11752,6 +11969,11 @@ | ... | @@ -11752,6 +11969,11 @@ |
11752 | "ajv-keywords": "^3.4.1" | 11969 | "ajv-keywords": "^3.4.1" |
11753 | } | 11970 | } |
11754 | }, | 11971 | }, |
11972 | + "scriptjs": { | ||
11973 | + "version": "2.5.9", | ||
11974 | + "resolved": "https://registry.npmjs.org/scriptjs/-/scriptjs-2.5.9.tgz", | ||
11975 | + "integrity": "sha512-qGVDoreyYiP1pkQnbnFAUIS5AjenNwwQBdl7zeos9etl+hYKWahjRTfzAZZYBv5xNHx7vNKCmaLDQZ6Fr2AEXg==" | ||
11976 | + }, | ||
11755 | "select-hose": { | 11977 | "select-hose": { |
11756 | "version": "2.0.0", | 11978 | "version": "2.0.0", |
11757 | "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz", | 11979 | "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz", |
... | @@ -12702,6 +12924,36 @@ | ... | @@ -12702,6 +12924,36 @@ |
12702 | } | 12924 | } |
12703 | } | 12925 | } |
12704 | }, | 12926 | }, |
12927 | + "styled-components": { | ||
12928 | + "version": "4.4.1", | ||
12929 | + "resolved": "https://registry.npmjs.org/styled-components/-/styled-components-4.4.1.tgz", | ||
12930 | + "integrity": "sha512-RNqj14kYzw++6Sr38n7197xG33ipEOktGElty4I70IKzQF1jzaD1U4xQ+Ny/i03UUhHlC5NWEO+d8olRCDji6g==", | ||
12931 | + "requires": { | ||
12932 | + "@babel/helper-module-imports": "^7.0.0", | ||
12933 | + "@babel/traverse": "^7.0.0", | ||
12934 | + "@emotion/is-prop-valid": "^0.8.1", | ||
12935 | + "@emotion/unitless": "^0.7.0", | ||
12936 | + "babel-plugin-styled-components": ">= 1", | ||
12937 | + "css-to-react-native": "^2.2.2", | ||
12938 | + "memoize-one": "^5.0.0", | ||
12939 | + "merge-anything": "^2.2.4", | ||
12940 | + "prop-types": "^15.5.4", | ||
12941 | + "react-is": "^16.6.0", | ||
12942 | + "stylis": "^3.5.0", | ||
12943 | + "stylis-rule-sheet": "^0.0.10", | ||
12944 | + "supports-color": "^5.5.0" | ||
12945 | + }, | ||
12946 | + "dependencies": { | ||
12947 | + "supports-color": { | ||
12948 | + "version": "5.5.0", | ||
12949 | + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", | ||
12950 | + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", | ||
12951 | + "requires": { | ||
12952 | + "has-flag": "^3.0.0" | ||
12953 | + } | ||
12954 | + } | ||
12955 | + } | ||
12956 | + }, | ||
12705 | "stylehacks": { | 12957 | "stylehacks": { |
12706 | "version": "4.0.3", | 12958 | "version": "4.0.3", |
12707 | "resolved": "https://registry.npmjs.org/stylehacks/-/stylehacks-4.0.3.tgz", | 12959 | "resolved": "https://registry.npmjs.org/stylehacks/-/stylehacks-4.0.3.tgz", |
... | @@ -12724,6 +12976,16 @@ | ... | @@ -12724,6 +12976,16 @@ |
12724 | } | 12976 | } |
12725 | } | 12977 | } |
12726 | }, | 12978 | }, |
12979 | + "stylis": { | ||
12980 | + "version": "3.5.4", | ||
12981 | + "resolved": "https://registry.npmjs.org/stylis/-/stylis-3.5.4.tgz", | ||
12982 | + "integrity": "sha512-8/3pSmthWM7lsPBKv7NXkzn2Uc9W7NotcwGNpJaa3k7WMM1XDCA4MgT5k/8BIexd5ydZdboXtU90XH9Ec4Bv/Q==" | ||
12983 | + }, | ||
12984 | + "stylis-rule-sheet": { | ||
12985 | + "version": "0.0.10", | ||
12986 | + "resolved": "https://registry.npmjs.org/stylis-rule-sheet/-/stylis-rule-sheet-0.0.10.tgz", | ||
12987 | + "integrity": "sha512-nTbZoaqoBnmK+ptANthb10ZRZOGC+EmTLLUxeYIuHNkEKcmKgXX1XWKkUBT2Ac4es3NybooPe0SmvKdhKJZAuw==" | ||
12988 | + }, | ||
12727 | "supports-color": { | 12989 | "supports-color": { |
12728 | "version": "6.1.0", | 12990 | "version": "6.1.0", |
12729 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", | 12991 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", |
... | @@ -13232,6 +13494,17 @@ | ... | @@ -13232,6 +13494,17 @@ |
13232 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", | 13494 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", |
13233 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" | 13495 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" |
13234 | }, | 13496 | }, |
13497 | + "uncontrollable": { | ||
13498 | + "version": "7.1.1", | ||
13499 | + "resolved": "https://registry.npmjs.org/uncontrollable/-/uncontrollable-7.1.1.tgz", | ||
13500 | + "integrity": "sha512-EcPYhot3uWTS3w00R32R2+vS8Vr53tttrvMj/yA1uYRhf8hbTG2GyugGqWDY0qIskxn0uTTojVd6wPYW9ZEf8Q==", | ||
13501 | + "requires": { | ||
13502 | + "@babel/runtime": "^7.6.3", | ||
13503 | + "@types/react": "^16.9.11", | ||
13504 | + "invariant": "^2.2.4", | ||
13505 | + "react-lifecycles-compat": "^3.0.4" | ||
13506 | + } | ||
13507 | + }, | ||
13235 | "unicode-canonical-property-names-ecmascript": { | 13508 | "unicode-canonical-property-names-ecmascript": { |
13236 | "version": "1.0.4", | 13509 | "version": "1.0.4", |
13237 | "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz", | 13510 | "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz", |
... | @@ -13523,6 +13796,14 @@ | ... | @@ -13523,6 +13796,14 @@ |
13523 | "makeerror": "1.0.x" | 13796 | "makeerror": "1.0.x" |
13524 | } | 13797 | } |
13525 | }, | 13798 | }, |
13799 | + "warning": { | ||
13800 | + "version": "4.0.3", | ||
13801 | + "resolved": "https://registry.npmjs.org/warning/-/warning-4.0.3.tgz", | ||
13802 | + "integrity": "sha512-rpJyN222KWIvHJ/F53XSZv0Zl/accqHR8et1kpaMTD/fLCRxtV8iX8czMzY7sVZupTI3zcUTg8eycS2kNF9l6w==", | ||
13803 | + "requires": { | ||
13804 | + "loose-envify": "^1.0.0" | ||
13805 | + } | ||
13806 | + }, | ||
13526 | "watchpack": { | 13807 | "watchpack": { |
13527 | "version": "1.7.2", | 13808 | "version": "1.7.2", |
13528 | "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-1.7.2.tgz", | 13809 | "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-1.7.2.tgz", | ... | ... |
... | @@ -6,8 +6,12 @@ | ... | @@ -6,8 +6,12 @@ |
6 | "@testing-library/jest-dom": "^4.2.4", | 6 | "@testing-library/jest-dom": "^4.2.4", |
7 | "@testing-library/react": "^9.3.2", | 7 | "@testing-library/react": "^9.3.2", |
8 | "@testing-library/user-event": "^7.1.2", | 8 | "@testing-library/user-event": "^7.1.2", |
9 | + "bootstrap": "^3.4.1", | ||
10 | + "daum-map-api": "^1.0.2", | ||
9 | "react": "^16.13.1", | 11 | "react": "^16.13.1", |
12 | + "react-bootstrap": "^1.0.1", | ||
10 | "react-dom": "^16.13.1", | 13 | "react-dom": "^16.13.1", |
14 | + "react-kakao-maps": "0.0.13", | ||
11 | "react-router-dom": "^5.2.0", | 15 | "react-router-dom": "^5.2.0", |
12 | "react-scripts": "3.4.1" | 16 | "react-scripts": "3.4.1" |
13 | }, | 17 | }, | ... | ... |
... | @@ -10,6 +10,16 @@ | ... | @@ -10,6 +10,16 @@ |
10 | content="Web site created using create-react-app" | 10 | content="Web site created using create-react-app" |
11 | /> | 11 | /> |
12 | <link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" /> | 12 | <link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" /> |
13 | + <script | ||
14 | + type="text/javascript" | ||
15 | + src="//dapi.kakao.com/v2/maps/sdk.js?appkey=61abec34d0855ba1d434ea222263d4a5&libraries=services,clusterer,drawing" | ||
16 | + ></script> | ||
17 | + <link | ||
18 | + rel="stylesheet" | ||
19 | + href="https://maxcdn.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" | ||
20 | + integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" | ||
21 | + crossorigin="anonymous" | ||
22 | + /> | ||
13 | <!-- | 23 | <!-- |
14 | manifest.json provides metadata used when your web app is installed on a | 24 | manifest.json provides metadata used when your web app is installed on a |
15 | user's mobile device or desktop. See https://developers.google.com/web/fundamentals/web-app-manifest/ | 25 | user's mobile device or desktop. See https://developers.google.com/web/fundamentals/web-app-manifest/ |
... | @@ -24,7 +34,7 @@ | ... | @@ -24,7 +34,7 @@ |
24 | work correctly both with client-side routing and a non-root public URL. | 34 | work correctly both with client-side routing and a non-root public URL. |
25 | Learn how to configure a non-root public URL by running `npm run build`. | 35 | Learn how to configure a non-root public URL by running `npm run build`. |
26 | --> | 36 | --> |
27 | - <title>React App</title> | 37 | + <title>HowsTheWeather</title> |
28 | </head> | 38 | </head> |
29 | <body> | 39 | <body> |
30 | <noscript>You need to enable JavaScript to run this app.</noscript> | 40 | <noscript>You need to enable JavaScript to run this app.</noscript> | ... | ... |
... | @@ -15,13 +15,14 @@ | ... | @@ -15,13 +15,14 @@ |
15 | 15 | ||
16 | .App-header { | 16 | .App-header { |
17 | background-color: #282c34; | 17 | background-color: #282c34; |
18 | - min-height: 100vh; | 18 | + min-height: 13vh; |
19 | display: flex; | 19 | display: flex; |
20 | flex-direction: column; | 20 | flex-direction: column; |
21 | align-items: center; | 21 | align-items: center; |
22 | justify-content: center; | 22 | justify-content: center; |
23 | font-size: calc(10px + 2vmin); | 23 | font-size: calc(10px + 2vmin); |
24 | color: white; | 24 | color: white; |
25 | + font-weight: bold; | ||
25 | } | 26 | } |
26 | 27 | ||
27 | .App-link { | 28 | .App-link { | ... | ... |
frontend/src/home.css
0 → 100644
1 | +.Home { | ||
2 | + text-align: center; | ||
3 | +} | ||
4 | + | ||
5 | +.Home-logo { | ||
6 | + height: 40vmin; | ||
7 | + pointer-events: none; | ||
8 | +} | ||
9 | + | ||
10 | +@media (prefers-reduced-motion: no-preference) { | ||
11 | + .Home-logo { | ||
12 | + animation: Home-logo-spin infinite 20s linear; | ||
13 | + } | ||
14 | +} | ||
15 | + | ||
16 | +.Home-header { | ||
17 | + background-color: #282c34; | ||
18 | + min-height: 13vh; | ||
19 | + display: flex; | ||
20 | + flex-direction: column; | ||
21 | + align-items: center; | ||
22 | + justify-content: center; | ||
23 | + font-size: calc(10px + 2vmin); | ||
24 | + color: white; | ||
25 | + font-weight: bold; | ||
26 | +} | ||
27 | + | ||
28 | +.Home-link { | ||
29 | + color: #61dafb; | ||
30 | +} | ||
31 | + | ||
32 | +@keyframes Home-logo-spin { | ||
33 | + from { | ||
34 | + transform: rotate(0deg); | ||
35 | + } | ||
36 | + to { | ||
37 | + transform: rotate(360deg); | ||
38 | + } | ||
39 | +} | ||
40 | + | ||
41 | +.strong { | ||
42 | + font-size: calc(10px + 1vmin); | ||
43 | + font-weight: bold; | ||
44 | +} | ||
45 | +.map_wrap, | ||
46 | +.map_wrap * { | ||
47 | + margin: 0; | ||
48 | + padding: 0; | ||
49 | + font-family: "Malgun Gothic", dotum, "돋움", sans-serif; | ||
50 | + font-size: 12px; | ||
51 | +} | ||
52 | +.map_wrap a, | ||
53 | +.map_wrap a:hover, | ||
54 | +.map_wrap a:active { | ||
55 | + color: #000; | ||
56 | + text-decoration: none; | ||
57 | +} | ||
58 | +.map_wrap { | ||
59 | + position: relative; | ||
60 | + width: 100%; | ||
61 | + height: 500px; | ||
62 | +} | ||
63 | + | ||
64 | +#menu_wrap { | ||
65 | + position: absolute; | ||
66 | + top: 0; | ||
67 | + left: 0; | ||
68 | + bottom: 0; | ||
69 | + width: 250px; | ||
70 | + margin: 10px 0 30px 10px; | ||
71 | + padding: 5px; | ||
72 | + overflow-y: auto; | ||
73 | + background: rgba(53, 53, 53, 0.8); | ||
74 | + z-index: 1; | ||
75 | + font-size: 12px; | ||
76 | + border-radius: 10px; | ||
77 | +} | ||
78 | +.bg_white { | ||
79 | + background: #fff; | ||
80 | +} | ||
81 | +x #menu_wrap hr { | ||
82 | + display: block; | ||
83 | + height: 1px; | ||
84 | + border: 0; | ||
85 | + border-top: 2px solid #5f5f5f; | ||
86 | + margin: 3px 0; | ||
87 | +} | ||
88 | +#menu_wrap .option { | ||
89 | + text-align: center; | ||
90 | + color: #ffffff; | ||
91 | + font-weight: bold; | ||
92 | +} | ||
93 | +#menu_wrap .option p { | ||
94 | + margin: 10px 0; | ||
95 | +} | ||
96 | +#menu_wrap .option button { | ||
97 | + margin-left: 5px; | ||
98 | +} | ||
99 | + | ||
100 | +#placesList li { | ||
101 | + list-style: none; | ||
102 | +} | ||
103 | +#placesList .item { | ||
104 | + position: relative; | ||
105 | + border-bottom: 1px solid #888; | ||
106 | + overflow: hidden; | ||
107 | + cursor: pointer; | ||
108 | + min-height: 65px; | ||
109 | +} | ||
110 | +#placesList .item span { | ||
111 | + display: block; | ||
112 | + margin-top: 4px; | ||
113 | +} | ||
114 | +#placesList .item h5, | ||
115 | +#placesList .item .info { | ||
116 | + text-overflow: ellipsis; | ||
117 | + overflow: hidden; | ||
118 | + white-space: nowrap; | ||
119 | +} | ||
120 | +#placesList .item .info { | ||
121 | + padding: 10px 0 10px 55px; | ||
122 | + color: #ffffff; | ||
123 | +} | ||
124 | +#placesList .info .gray { | ||
125 | + color: #eaeaea; | ||
126 | +} | ||
127 | +#placesList .info .jibun { | ||
128 | + padding-left: 26px; | ||
129 | + background: url(http://t1.daumcdn.net/localimg/localimages/07/mapapidoc/places_jibun.png) | ||
130 | + no-repeat; | ||
131 | +} | ||
132 | +#placesList .info .tel { | ||
133 | + color: #ffbb00; | ||
134 | + font-weight: bold; | ||
135 | +} | ||
136 | +#placesList .item .markerbg { | ||
137 | + float: left; | ||
138 | + position: absolute; | ||
139 | + width: 36px; | ||
140 | + height: 37px; | ||
141 | + margin: 10px 0 0 10px; | ||
142 | + background: url(http://t1.daumcdn.net/localimg/localimages/07/mapapidoc/marker_number_blue.png) | ||
143 | + no-repeat; | ||
144 | +} | ||
145 | +#placesList .item .marker_1 { | ||
146 | + background-position: 0 -10px; | ||
147 | +} | ||
148 | +#placesList .item .marker_2 { | ||
149 | + background-position: 0 -56px; | ||
150 | +} | ||
151 | +#placesList .item .marker_3 { | ||
152 | + background-position: 0 -102px; | ||
153 | +} | ||
154 | +#placesList .item .marker_4 { | ||
155 | + background-position: 0 -148px; | ||
156 | +} | ||
157 | +#placesList .item .marker_5 { | ||
158 | + background-position: 0 -194px; | ||
159 | +} | ||
160 | +#placesList .item .marker_6 { | ||
161 | + background-position: 0 -240px; | ||
162 | +} | ||
163 | +#placesList .item .marker_7 { | ||
164 | + background-position: 0 -286px; | ||
165 | +} | ||
166 | +#placesList .item .marker_8 { | ||
167 | + background-position: 0 -332px; | ||
168 | +} | ||
169 | +#placesList .item .marker_9 { | ||
170 | + background-position: 0 -378px; | ||
171 | +} | ||
172 | +#placesList .item .marker_10 { | ||
173 | + background-position: 0 -423px; | ||
174 | +} | ||
175 | +#placesList .item .marker_11 { | ||
176 | + background-position: 0 -470px; | ||
177 | +} | ||
178 | +#placesList .item .marker_12 { | ||
179 | + background-position: 0 -516px; | ||
180 | +} | ||
181 | +#placesList .item .marker_13 { | ||
182 | + background-position: 0 -562px; | ||
183 | +} | ||
184 | +#placesList .item .marker_14 { | ||
185 | + background-position: 0 -608px; | ||
186 | +} | ||
187 | +#placesList .item .marker_15 { | ||
188 | + background-position: 0 -654px; | ||
189 | +} | ||
190 | +#pagination { | ||
191 | + margin: 10px auto; | ||
192 | + text-align: center; | ||
193 | +} | ||
194 | +#pagination a { | ||
195 | + display: inline-block; | ||
196 | + margin-right: 10px; | ||
197 | +} | ||
198 | +#pagination .on { | ||
199 | + font-weight: bold; | ||
200 | + cursor: default; | ||
201 | + color: #777; | ||
202 | +} | ||
203 | + | ||
204 | +.wraps { | ||
205 | + position: absolute; | ||
206 | + left: 0; | ||
207 | + bottom: 40px; | ||
208 | + width: 288px; | ||
209 | + height: 132px; | ||
210 | + margin-left: -144px; | ||
211 | + text-align: left; | ||
212 | + overflow: hidden; | ||
213 | + font-size: 12px; | ||
214 | + font-family: "Malgun Gothic", dotum, "돋움", sans-serif; | ||
215 | + line-height: 1.5; | ||
216 | +} | ||
217 | +.wraps * { | ||
218 | + padding: 0; | ||
219 | + margin: 0; | ||
220 | +} | ||
221 | +.wraps .infos { | ||
222 | + width: 286px; | ||
223 | + height: 120px; | ||
224 | + border-radius: 5px; | ||
225 | + border-bottom: 2px solid #ccc; | ||
226 | + border-right: 1px solid #ccc; | ||
227 | + overflow: hidden; | ||
228 | + background: #fff; | ||
229 | +} | ||
230 | +.wraps .infos:nth-child(1) { | ||
231 | + border: 0; | ||
232 | + box-shadow: 0px 1px 2px #888; | ||
233 | +} | ||
234 | +.infos .title { | ||
235 | + padding: 5px 0 0 10px; | ||
236 | + height: 30px; | ||
237 | + background: #eee; | ||
238 | + border-bottom: 1px solid #ddd; | ||
239 | + font-size: 18px; | ||
240 | + font-weight: bold; | ||
241 | +} | ||
242 | +.infos .close { | ||
243 | + position: absolute; | ||
244 | + top: 10px; | ||
245 | + right: 10px; | ||
246 | + color: #888; | ||
247 | + width: 17px; | ||
248 | + height: 17px; | ||
249 | + background: url("http://t1.daumcdn.net/localimg/localimages/07/mapapidoc/overlay_close.png"); | ||
250 | +} | ||
251 | +.infos .close:hover { | ||
252 | + cursor: pointer; | ||
253 | +} | ||
254 | +.infos .body { | ||
255 | + position: relative; | ||
256 | + overflow: hidden; | ||
257 | +} | ||
258 | +.infos .desc { | ||
259 | + position: relative; | ||
260 | + margin: 13px 0 0 90px; | ||
261 | + height: 75px; | ||
262 | +} | ||
263 | +.desc .ellipsis { | ||
264 | + overflow: hidden; | ||
265 | + text-overflow: ellipsis; | ||
266 | + white-space: nowrap; | ||
267 | +} | ||
268 | +.desc .jibun { | ||
269 | + font-size: 11px; | ||
270 | + color: #888; | ||
271 | + margin-top: -2px; | ||
272 | +} | ||
273 | +.infos .img { | ||
274 | + position: absolute; | ||
275 | + top: 6px; | ||
276 | + left: 5px; | ||
277 | + width: 73px; | ||
278 | + height: 71px; | ||
279 | + border: 1px solid #ddd; | ||
280 | + color: #888; | ||
281 | + overflow: hidden; | ||
282 | +} | ||
283 | +.infos:after { | ||
284 | + content: ""; | ||
285 | + position: absolute; | ||
286 | + margin-left: -12px; | ||
287 | + left: 50%; | ||
288 | + bottom: 0; | ||
289 | + width: 22px; | ||
290 | + height: 12px; | ||
291 | + background: url("http://t1.daumcdn.net/localimg/localimages/07/mapapidoc/vertex_white.png"); | ||
292 | +} | ||
293 | +.infos .link { | ||
294 | + color: #5085bb; | ||
295 | +} | ||
296 | + | ||
297 | +#footer { | ||
298 | + position: absolute; | ||
299 | + bottom: 0; | ||
300 | + width: 100%; | ||
301 | + height: 100px; | ||
302 | + background: #ccc; | ||
303 | +} | ||
304 | + | ||
305 | +.left-box { | ||
306 | + float: left; | ||
307 | + width: 20%; | ||
308 | +} | ||
309 | +.left-box h5 { | ||
310 | + font-size: 1rem; | ||
311 | + font-style: italic; | ||
312 | + padding-left: 10px; | ||
313 | +} | ||
314 | +.right-box { | ||
315 | + float: right; | ||
316 | + width: 80%; | ||
317 | +} | ||
318 | +.right-box h5 { | ||
319 | + font-size: 1rem; | ||
320 | + font-style: italic; | ||
321 | + padding-left: 10px; | ||
322 | +} | ||
323 | +#middle { | ||
324 | + text-align: center; | ||
325 | +} | ||
326 | +.info-button { | ||
327 | + border-radius: 4px; | ||
328 | + background-color: #4641d9; | ||
329 | + width: 100px; | ||
330 | + color: white; | ||
331 | +} |
1 | import React, { Component } from "react"; | 1 | import React, { Component } from "react"; |
2 | import logo from "./logo.svg"; | 2 | import logo from "./logo.svg"; |
3 | import "./App.css"; | 3 | import "./App.css"; |
4 | +import Button from "react-bootstrap/Button"; | ||
5 | +import "./home.css"; | ||
6 | +import { Map, Marker, MarkerClusterer, Polyline } from "react-kakao-maps"; | ||
7 | +import "bootstrap/dist/css/bootstrap.min.css"; | ||
8 | + | ||
9 | +/* global kakao */ | ||
10 | + | ||
4 | export default class Home extends Component { | 11 | export default class Home extends Component { |
5 | constructor(props) { | 12 | constructor(props) { |
6 | super(props); | 13 | super(props); |
7 | - this.state = {}; | 14 | + this.state = { |
15 | + map: null, | ||
16 | + markers: [], | ||
17 | + markers: [], | ||
18 | + curMarker: new kakao.maps.Marker({ | ||
19 | + position: new kakao.maps.LatLng(37.503716, 127.044844), | ||
20 | + }), | ||
21 | + placeSearch: new kakao.maps.services.Places(), | ||
22 | + infoWindow: new kakao.maps.CustomOverlay({}), | ||
23 | + region: "은평구청", | ||
24 | + | ||
25 | + // curAirCondition: null, | ||
26 | + // routeInformation: null, | ||
27 | + }; | ||
28 | + this.removeAllChildNods = this.removeAllChildNods.bind(this); | ||
29 | + this.displayInfowindow = this.displayInfowindow.bind(this); | ||
30 | + } | ||
31 | + | ||
32 | + searchPlaces() { | ||
33 | + var keyword = document.getElementById("keyword").value; | ||
34 | + | ||
35 | + if (!keyword.replace(/^\s+|\s+$/g, "")) { | ||
36 | + alert("키워드를 입력해주세요!"); | ||
37 | + return false; | ||
38 | + } | ||
39 | + // 장소검색 객체를 통해 키워드로 장소검색을 요청합니다 | ||
40 | + this.state.placeSearch.keywordSearch( | ||
41 | + keyword, | ||
42 | + this.placesSearchCB.bind(this) | ||
43 | + ); | ||
44 | + } | ||
45 | + | ||
46 | + // 장소검색이 완료됐을 때 호출되는 콜백함수 입니다 | ||
47 | + placesSearchCB(data, status, pagination) { | ||
48 | + if (status === kakao.maps.services.Status.OK) { | ||
49 | + // 정상적으로 검색이 완료됐으면 | ||
50 | + // 검색 목록과 마커를 표출합니다 | ||
51 | + this.displayPlaces(data); | ||
52 | + | ||
53 | + // 페이지 번호를 표출합니다 | ||
54 | + this.displayPagination(pagination); | ||
55 | + } else if (status === kakao.maps.services.Status.ZERO_RESULT) { | ||
56 | + alert("검색 결과가 존재하지 않습니다."); | ||
57 | + return; | ||
58 | + } else if (status === kakao.maps.services.Status.ERROR) { | ||
59 | + alert("검색 결과 중 오류가 발생했습니다."); | ||
60 | + return; | ||
61 | + } | ||
62 | + } | ||
63 | + | ||
64 | + displayPlaces(places) { | ||
65 | + var listEl = document.getElementById("placesList"), | ||
66 | + menuEl = document.getElementById("menu_wrap"), | ||
67 | + fragment = document.createDocumentFragment(), | ||
68 | + bounds = new kakao.maps.LatLngBounds(), | ||
69 | + listStr = ""; | ||
70 | + | ||
71 | + // 검색 결과 목록에 추가된 항목들을 제거합니다 | ||
72 | + // 페이지별로 보여주기 때문에 추가한 것 같음. | ||
73 | + this.removeAllChildNods(listEl); | ||
74 | + | ||
75 | + // 지도에 표시되고 있는 마커를 제거합니다 | ||
76 | + this.removeMarker(); | ||
77 | + | ||
78 | + for (var i = 0; i < places.length; i++) { | ||
79 | + // 마커를 생성하고 지도에 표시합니다 | ||
80 | + var placePosition = new kakao.maps.LatLng(places[i].y, places[i].x), | ||
81 | + marker = this.addMarker(placePosition, i), | ||
82 | + itemEl = this.getListItem(i, places[i]); // 검색 결과 항목 Element를 생성합니다 | ||
83 | + | ||
84 | + // 검색된 장소 위치를 기준으로 지도 범위를 재설정하기위해 | ||
85 | + // LatLngBounds 객체에 좌표를 추가합니다 | ||
86 | + bounds.extend(placePosition); | ||
87 | + | ||
88 | + // 마커와 검색결과 항목에 mouseover 했을때 | ||
89 | + // 해당 장소에 인포윈도우에 장소명을 표시합니다 | ||
90 | + // mouseout 했을 때는 인포윈도우를 닫습니다 | ||
91 | + ((marker, title) => { | ||
92 | + kakao.maps.event.addListener(marker, "click", () => { | ||
93 | + this.displayInfowindow(marker, title); | ||
94 | + }); | ||
95 | + kakao.maps.event.addListener(marker, "mouseover", () => { | ||
96 | + this.displayInfowindow(marker, title); | ||
97 | + }); | ||
98 | + | ||
99 | + itemEl.onmouseover = () => { | ||
100 | + this.displayInfowindow(marker, title); | ||
101 | + }; | ||
102 | + })(marker, places[i].place_name); | ||
103 | + // 함수를 조건문처럼 사용하여 해당 함수가 true일때 marker,places[i].place_name함수가 불리워짐. | ||
104 | + | ||
105 | + fragment.appendChild(itemEl); | ||
106 | + } | ||
107 | + | ||
108 | + // 검색결과 항목들을 검색결과 목록 Elemnet에 추가합니다 | ||
109 | + listEl.appendChild(fragment); | ||
110 | + menuEl.scrollTop = 0; | ||
111 | + | ||
112 | + // 검색된 장소 위치를 기준으로 지도 범위를 재설정합니다 | ||
113 | + this.state.map.setBounds(bounds); | ||
114 | + } | ||
115 | + // 커스텀 오버레이를 닫기 위해 호출되는 함수입니다 | ||
116 | + closeOverlay() { | ||
117 | + this.state.infoWindow.setMap(null); | ||
118 | + } | ||
119 | + | ||
120 | + getListItem(index, places) { | ||
121 | + var el = document.createElement("li"), | ||
122 | + itemStr = | ||
123 | + '<span class="markerbg marker_' + | ||
124 | + (index + 1) + | ||
125 | + '"></span>' + | ||
126 | + '<div class="info">' + | ||
127 | + " <h5>" + | ||
128 | + places.place_name + | ||
129 | + "</h5>"; | ||
130 | + | ||
131 | + if (places.road_address_name) { | ||
132 | + itemStr += | ||
133 | + " <span>" + | ||
134 | + places.road_address_name + | ||
135 | + "</span>" + | ||
136 | + ' <span class="jibun gray">' + | ||
137 | + places.address_name + | ||
138 | + "</span>"; | ||
139 | + } else { | ||
140 | + itemStr += " <span>" + places.address_name + "</span>"; | ||
141 | + } | ||
142 | + | ||
143 | + itemStr += ' <span class="tel">' + places.phone + "</span>" + "</div>"; | ||
144 | + | ||
145 | + el.innerHTML = itemStr; | ||
146 | + el.className = "item"; | ||
147 | + | ||
148 | + return el; | ||
149 | + } | ||
150 | + | ||
151 | + addMarker(position, idx, title) { | ||
152 | + var imageSrc = | ||
153 | + "http://t1.daumcdn.net/localimg/localimages/07/mapapidoc/marker_number_blue.png", // 마커 이미지 url, 스프라이트 이미지를 씁니다 | ||
154 | + imageSize = new kakao.maps.Size(36, 37), // 마커 이미지의 크기 | ||
155 | + imgOptions = { | ||
156 | + spriteSize: new kakao.maps.Size(36, 691), // 스프라이트 이미지의 크기 | ||
157 | + spriteOrigin: new kakao.maps.Point(0, idx * 46 + 10), // 스프라이트 이미지 중 사용할 영역의 좌상단 좌표 | ||
158 | + offset: new kakao.maps.Point(13, 37), // 마커 좌표에 일치시킬 이미지 내에서의 좌표 | ||
159 | + }, | ||
160 | + markerImage = new kakao.maps.MarkerImage(imageSrc, imageSize, imgOptions), | ||
161 | + marker = new kakao.maps.Marker({ | ||
162 | + position: position, // 마커의 위치 | ||
163 | + image: markerImage, | ||
164 | + }); | ||
165 | + | ||
166 | + marker.setMap(this.state.map); // 지도 위에 마커를 표출합니다 | ||
167 | + this.setState({ curMarker: marker }); | ||
168 | + this.state.markers.push(marker); // 배열에 생성된 마커를 추가합니다 | ||
169 | + | ||
170 | + return marker; | ||
171 | + } | ||
172 | + | ||
173 | + // 지도 위에 표시되고 있는 마커를 모두 제거합니다 | ||
174 | + removeMarker() { | ||
175 | + for (var i = 0; i < this.state.markers.length; i++) { | ||
176 | + this.state.markers[i].setMap(null); | ||
177 | + } | ||
178 | + this.setState({ | ||
179 | + markers: [], | ||
180 | + }); | ||
181 | + } | ||
182 | + | ||
183 | + // 검색결과 목록 하단에 페이지번호를 표시는 함수입니다 | ||
184 | + displayPagination(pagination) { | ||
185 | + var paginationEl = document.getElementById("pagination"), | ||
186 | + fragment = document.createDocumentFragment(), | ||
187 | + i; | ||
188 | + | ||
189 | + // 기존에 추가된 페이지번호를 삭제합니다 | ||
190 | + while (paginationEl.hasChildNodes()) { | ||
191 | + paginationEl.removeChild(paginationEl.lastChild); | ||
192 | + } | ||
193 | + | ||
194 | + for (i = 1; i <= pagination.last; i++) { | ||
195 | + var el = document.createElement("a"); | ||
196 | + el.href = "#"; | ||
197 | + el.innerHTML = i; | ||
198 | + | ||
199 | + if (i === pagination.current) { | ||
200 | + el.className = "on"; | ||
201 | + } else { | ||
202 | + el.onclick = (function (i) { | ||
203 | + return function () { | ||
204 | + pagination.gotoPage(i); | ||
205 | + }; | ||
206 | + })(i); | ||
207 | + } | ||
208 | + | ||
209 | + fragment.appendChild(el); | ||
210 | + } | ||
211 | + paginationEl.appendChild(fragment); | ||
212 | + } | ||
213 | + | ||
214 | + removeAllChildNods(el) { | ||
215 | + while (el.hasChildNodes()) { | ||
216 | + el.removeChild(el.lastChild); | ||
217 | + } | ||
218 | + } | ||
219 | + | ||
220 | + // 검색결과 목록 또는 마커를 클릭했을 때 호출되는 함수입니다 | ||
221 | + // 인포윈도우에 장소명을 표시합니다 | ||
222 | + displayInfowindow(marker, title) { | ||
223 | + console.log(marker); | ||
224 | + | ||
225 | + let content = document.createElement("div"); | ||
226 | + content.className = "wraps"; | ||
227 | + | ||
228 | + let info = document.createElement("div"); | ||
229 | + info.className = "infos"; | ||
230 | + | ||
231 | + let titles = document.createElement("div"); | ||
232 | + titles.className = "title"; | ||
233 | + titles.innerHTML = title; | ||
234 | + | ||
235 | + let close = document.createElement("div"); | ||
236 | + close.className = "close"; | ||
237 | + close.onclick = () => { | ||
238 | + this.state.infoWindow.setMap(null); | ||
239 | + }; | ||
240 | + | ||
241 | + let body = document.createElement("div"); | ||
242 | + body.className = "body"; | ||
243 | + let desc = document.createElement("div"); | ||
244 | + let list = document.createElement("list"); | ||
245 | + let second = document.createElement("LI"); | ||
246 | + let br = document.createElement("div"); | ||
247 | + br.innerHTML += "<br>"; | ||
248 | + let second_ = document.createElement("LI"); | ||
249 | + | ||
250 | + let getMise = document.createElement("Button"); | ||
251 | + getMise.innerHTML = "미세먼지 정보"; | ||
252 | + getMise.className = "info-button"; | ||
253 | + getMise.onclick = () => { | ||
254 | + let position = marker.getPosition(); | ||
255 | + console.log(marker.getPosition()); | ||
256 | + console.log(position["Ga"]); | ||
257 | + }; | ||
258 | + let setDepart = document.createElement("Button"); | ||
259 | + setDepart.innerHTML = "출발지로 설정하기"; | ||
260 | + setDepart.onclick = () => { | ||
261 | + this.setState({ | ||
262 | + departure: marker.getPosition(), | ||
263 | + departureTitle: title, | ||
264 | + }); | ||
265 | + }; | ||
266 | + setDepart.className = "info-button"; | ||
267 | + let setArrive = document.createElement("Button"); | ||
268 | + setArrive.innerHTML = "도착지로 설정하기"; | ||
269 | + setArrive.onclick = () => { | ||
270 | + this.setState({ | ||
271 | + arrival: marker.getPosition(), | ||
272 | + arrivalTitle: title, | ||
273 | + }); | ||
274 | + }; | ||
275 | + setArrive.className = "info-button"; | ||
276 | + second.appendChild(getMise); | ||
277 | + second.appendChild(br); | ||
278 | + second_.appendChild(setDepart); | ||
279 | + second_.appendChild(setArrive); | ||
280 | + | ||
281 | + list.appendChild(second); | ||
282 | + list.appendChild(second_); | ||
283 | + desc.appendChild(list); | ||
284 | + body.appendChild(desc); | ||
285 | + titles.appendChild(close); | ||
286 | + info.appendChild(titles); | ||
287 | + info.appendChild(body); | ||
288 | + content.appendChild(info); | ||
289 | + | ||
290 | + this.state.infoWindow.setContent(content); | ||
291 | + this.state.infoWindow.setPosition(marker.getPosition()); | ||
292 | + this.state.infoWindow.setMap(this.state.map); | ||
293 | + } | ||
294 | + | ||
295 | + componentDidMount() { | ||
296 | + // 컴포넌트가 만들어지고, render 함수가 호출된 이후에 호출되는 메소 | ||
297 | + // AJAX나 타이머를 생성하는 코드를 작성하는 파트이다. | ||
298 | + let el = document.getElementById("map"); | ||
299 | + this.setState({ | ||
300 | + map: new kakao.maps.Map(el, { | ||
301 | + //map option 설정 | ||
302 | + center: new kakao.maps.LatLng(37.503716, 127.044844), | ||
303 | + level: 3, | ||
304 | + }), | ||
305 | + }); | ||
306 | + this.searchPlaces(); | ||
307 | + // marker.setMap(map); | ||
8 | } | 308 | } |
9 | 309 | ||
10 | render() { | 310 | render() { |
311 | + let currentAirCondition = null; | ||
312 | + let routeAirCondition = null; | ||
313 | + | ||
11 | return ( | 314 | return ( |
12 | - <div className="App"> | 315 | + <section id="home"> |
13 | - <header className="App-header"> | 316 | + <div className="cover"> |
14 | - <img src={logo} className="App-logo" alt="logo" /> | 317 | + <div className="Home-header">How's the Weather?!</div> |
15 | - <p> | 318 | + </div> |
16 | - Edit <code>src/App.js</code> and save to reload. | 319 | + <div className="map_wrap"> |
17 | - </p> | 320 | + <div |
18 | - <a | 321 | + id="map" |
19 | - className="App-link" | 322 | + style={{ |
20 | - href="https://reactjs.org" | 323 | + width: "1000px", |
21 | - target="_blank" | 324 | + height: "600px", |
22 | - rel="noopener noreferrer" | 325 | + align: "middle", |
23 | - > | 326 | + }} |
24 | - Learn React | 327 | + ></div> |
25 | - </a> | 328 | + <div id="menu_wrap" className="bg_white"> |
26 | - </header> | 329 | + <div className="option"> |
330 | + 지역 검색 :{" "} | ||
331 | + <input | ||
332 | + type="text" | ||
333 | + value={this.state.region} | ||
334 | + id="keyword" | ||
335 | + size="15" | ||
336 | + onChange={(e) => this.setState({ region: e.target.value })} | ||
337 | + /> | ||
338 | + <Button variant="light" type="submit" onClick={this.searchPlaces}> | ||
339 | + 검색하기 | ||
340 | + </Button> | ||
341 | + </div> | ||
342 | + <ul id="placesList"></ul> | ||
343 | + <div id="pagination"></div> | ||
344 | + </div> | ||
345 | + <ul id="placesList"></ul> | ||
346 | + <div id="pagination"></div> | ||
347 | + </div> | ||
348 | + <div id="footer"> | ||
349 | + <div className="left-box"> | ||
350 | + <h5> 현재위치 : {this.state.region} </h5> | ||
351 | + <br /> | ||
352 | + <div id="middle">{currentAirCondition}</div> | ||
353 | + </div> | ||
354 | + <div className="right-box"> | ||
355 | + <h5> | ||
356 | + 출발지 : {this.state.departureTitle} <br /> | ||
357 | + 도착지 : {this.state.arrivalTitle} <br /> | ||
358 | + <Button variant="secondary" onClick={this.getRouteAirCondition}> | ||
359 | + {" "} | ||
360 | + 경로별 미세먼지 정보 알아보기{" "} | ||
361 | + </Button>{" "} | ||
362 | + <br /> <br /> | ||
363 | + </h5> | ||
364 | + <div id="middle">{routeAirCondition}</div> | ||
365 | + </div> | ||
27 | </div> | 366 | </div> |
367 | + </section> | ||
28 | ); | 368 | ); |
29 | } | 369 | } |
30 | } | 370 | } | ... | ... |
-
Please register or login to post a comment