{"version":3,"sources":["assets/logo.png","utils/savetoMongo.js","utils/resultHandler.js","utils/SearchBar.js","Home.js","utils/ResultCard.js","utils/NewsCard.js","utils/VideoCard.js","utils/ImageCard.js","Search.js","index.js"],"names":["saveToMongo","searchText","data","fetch","method","mode","body","JSON","stringify","headers","then","res","console","log","catch","err","storeData","result","type","page","query","localStorage","setItem","SearchBar","props","state","getItem","collapse","searchButton","activeSuggestion","filteredSuggestions","showSuggestions","handleKeyPress","e","key","webSearch","handleTextChange","setState","target","value","fetchSuggestions","a","searchString","encodeURIComponent","apiURL","json","webResults","webPages","window","location","bind","response","suggestions","suggestionGroups","searchSuggestions","map","item","push","displayText","length","this","display","style","fontSize","fontWeight","color","cursor","onClick","setInput","marginRight","position","backgroundColor","width","overflowY","boxShadow","borderBottomLeftRadius","borderBottomRightRadius","paddingTop","zIndex","Grid","lg","className","FormControl","fullWidth","onSubmit","search","Input","placeholder","id","onKeyPress","onChange","autoComplete","onFocus","endAdornment","InputAdornment","IconButton","Component","Home","removeItem","Container","Row","Col","marginTop","href","src","require","default","alt","outline","border","background","ResultCard","dataFromParent","url","name","replace","rel","displayUrl","snippet","NewsCard","description","VideoCard","class","thumbnailUrl","hostPageUrl","ImageCard","textAlign","verticalAlign","padding","textDecoration","Search","newsSearch","newsResults","imageSearch","imageResults","videoSearch","parse","parseInt","minPage","paginationArray","i","details","xs","margin","sm","marginBottom","flexDirection","paginationSearch","number","ReactDOM","render","exact","path","document","getElementById"],"mappings":"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","file":"static/js/main.811a7313.chunk.js","sourcesContent":["export default \"\"","const saveToMongo = (searchText) => {\n\n    const data = { \"searchString\": searchText };\n    fetch(\"https://dufodufo.com:4443\", {\n        method: \"POST\",\n        mode: \"cors\",\n        body: JSON.stringify(data),\n        headers: {\n        \"content-type\": \"application/json\",\n        },\n\n    })\n    .then((res) => {\n        console.log(res);\n    })\n    .catch((err) => {\n        console.log(err);\n    });\n}\n\nexport default saveToMongo","const storeData = (result, type, page, query) => {\n    localStorage.setItem('searchResults', JSON.stringify(result))\n    localStorage.setItem(\"searchResultsType\", type)\n    localStorage.setItem(\"searchedPage\", page)\n    localStorage.setItem(\"searchText\", query)\n}\n\nconst getData = () => {\n    return [\n        JSON.parse(localStorage.getItem('searchResults')),\n        localStorage.getItem(\"searchResultsType\"),\n        parseInt(localStorage.getItem(\"searchedPage\")),\n        localStorage.getItem(\"searchText\")\n    ]\n}\n\nconst clearData = () => {\n    localStorage.removeItem('searchResults')\n    localStorage.removeItem(\"searchResultsType\")\n    localStorage.removeItem(\"searchedPage\")\n    localStorage.removeItem(\"searchText\")\n}\n\nexport {\n    storeData,\n    getData,\n    clearData\n}","import React, { Component } from \"react\";\nimport \"../assets/main.css\";\nimport {\n  Grid,\n  Input,\n  FormControl,\n//   TextField\n} from \"@material-ui/core\";\nimport saveToMongo from \"./savetoMongo\";\nimport { storeData } from './resultHandler'\nimport SearchIcon from '@material-ui/icons/SearchOutlined';\nimport InputAdornment from '@material-ui/core/InputAdornment';\nimport IconButton from '@material-ui/core/IconButton';\n\n// import { Container } from \"react-bootstrap\";\n// import { browserHistory } from \"react-router\";\n// import { dataService } from \"./dataService\";\n// import { apiKey } from \"../assets/apiKey\";\n\n// function saveToMongo(searchText) {\n//   const data = { \"searchString\": searchText };\n//   fetch(\"https://dufodufo.com:4443\", {\n//     method: \"POST\",\n//     mode: \"cors\",\n//     body: JSON.stringify(data),\n//     headers: {\n//       \"content-type\": \"application/json\",\n//     },\n    \n//   })\n//     .then((res) => {\n//       console.log(res);\n//     })\n//     .catch((err) => {\n//       console.log(err);\n//     });\n// }\n\nclass SearchBar extends Component {\n  state = {\n    searchText: localStorage.getItem('searchText') ? localStorage.getItem('searchText'): \"\",\n    collapse: false,\n    searchButton: true,\n    activeSuggestion: 0,\n    filteredSuggestions: [],\n    showSuggestions: false,\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.fetchSuggestions = this.fetchSuggestions.bind(this)\n    // this.search = this.search.bind(this);\n    // let params = new URLSearchParams(\n    //   browserHistory.getCurrentLocation().search\n    // ).get(\"searchText\");\n    // console.log(\"Params at searchBar => \", params)\n    // this.searchText = params ? params.split(\"=\")[0].split(\"?\")[0] : null;\n    // this.state.searchText = this.searchText;\n    // this.setInput = this.setInput.bind(this)\n  }\n\n  handleKeyPress = (e) => {\n    console.log(\"Key pressed => \", e.key)\n    if (e.key === \"Enter\") {\n      this.webSearch(1);\n    }\n  };\n\n  fetchSuggestions(query) {\n    fetch('https://api.bing.microsoft.com/v7.0/suggestions?q='+ encodeURIComponent(query), {\n        headers: {\n            'Ocp-Apim-Subscription-Key': 'ab553acd4424436096d4ef3b183b46ec'\n        }, \n        method: 'GET'\n    })\n    .then(res => res.json())\n    .then(response => {\n        // console.log(\"Suggestions are ===> \", JSON.stringify(response.suggestionGroups[0].searchSuggestions))\n        let suggestions = response.suggestionGroups[0].searchSuggestions\n        let filteredSuggestions = []\n        suggestions.map(item => {\n            filteredSuggestions.push({\"displayText\": item.displayText, query: item.query})\n        })\n        if(filteredSuggestions.length === 0) {\n            this.setState({\n                showSuggestions: false\n            })\n        }\n        else {\n            this.setState({\n                filteredSuggestions: filteredSuggestions,\n                showSuggestions: true\n            })\n        }\n    })\n  }\n\n  handleTextChange = (e) => {\n    this.setState({ searchText: e.target.value });\n      this.fetchSuggestions(e.target.value)\n  };\n\n  webSearch = async (page) => {\n    console.log(\"Web search ===> \", this.state.searchText);\n    let apiURL = \"https://api.bing.microsoft.com/\";\n    let headers = { \"Ocp-Apim-Subscription-Key\": 'ab553acd4424436096d4ef3b183b46ec' };\n    let searchString = encodeURIComponent(this.state.searchText);\n    if (this.state.searchText) {\n      saveToMongo(this.state.searchText);\n      fetch(apiURL + \"v7.0/search?responseFilter=webpages&q=\" + searchString+\"&offset=\"+((page - 1) * 10), {\n        headers,\n      }).then((res) => {\n        res.json().then((json) => {\n            // console.log(\"Web results => \", JSON.stringify(json.webPages.value))\n            // store type of results, result, current page\n\n            let webResults = json.webPages.value\n            let resultType = \"web\"\n            let currentpage = page\n\n            // storeData()\n            storeData(webResults, resultType, currentpage, this.state.searchText)\n\n            // redirect to the new page to display the results\n            window.location = '/search'\n        });\n      });\n    }\n  };\n\n//   imagesearch = () => {\n//     console.log(\"image clicked\");\n//     let imageApiURL = \"https://bing-image-search1.p.rapidapi.com/images/search\";\n//     let headers = {\n//       'x-rapidapi-key': '3fe9872e94mshf148b0071798372p1b8684jsndae02e4e3799',\n//       'x-rapidapi-host': 'bing-image-search1.p.rapidapi.com'\n//     }\n//     let searchString = encodeURIComponent(this.state.searchText);\n//     if (this.state.searchText) {\n//       saveToMongo(this.state.searchText);\n//       fetch(imageApiURL+\"?q=\"+searchString, {\n//         headers,\n//         method: 'GET'\n//       })\n//       .then(res => res.json())\n//       .then(jsonResponse => {\n//         // console.log(jsonResponse)\n//         let resultsId = Math.random();\n//         let resultsKey = \"results\" + resultsId;\n//         let resultType = \"image\"\n//         if(this.state.searchText) {\n//           let dataObject = {\n//             searchText: this.state.searchText,\n//             currPage: 1,\n//             resultsKey: resultsKey,\n//             resultsId: resultsId,\n//             resultsType: resultType\n//           };\n//           console.log(\"Image stored in ===> \", resultsId)\n//           dataObject[resultsKey] = jsonResponse.value ? jsonResponse.value : null;\n//           dataService.setData(dataObject);\n//         }\n//         let redirectObj = {\n//           pathname: \"/search\",\n//           search:\n//             \"?searchText=\" +\n//             encodeURIComponent(this.state.searchText) +\n//             \"?resultsId=\" +\n//             encodeURIComponent(resultsId) +\n//             \"?currPage=\" +\n//             encodeURIComponent(1),\n//         };\n//         browserHistory.push(redirectObj);\n//         window.location.reload(false);\n//       })\n//     }\n//   }\n\n//   newssearch = () => {\n//     console.log(\"news clicked\");\n//     let newsApiURL = \"https://bing-news-search1.p.rapidapi.com/news/search\";\n//     let headers = {\n//       'x-bingapis-sdk': 'true',\n//       'x-rapidapi-key': '3fe9872e94mshf148b0071798372p1b8684jsndae02e4e3799',\n//       'x-rapidapi-host': 'bing-news-search1.p.rapidapi.com'\n//     }\n//     let searchString = encodeURIComponent(this.state.searchText);\n//     if (this.state.searchText) {\n//       saveToMongo(this.state.searchText);\n//       fetch(newsApiURL+\"?q=\"+searchString+\"&safeSearch=Off&textFormat=Raw&freshness=Day\", {\n//         headers,\n//         method: 'GET'\n//       })\n//       .then(res => res.json())\n//       .then(jsonResponse => {\n//         // console.log(jsonResponse)\n//         let resultsId = Math.random();\n//         let resultsKey = \"results\" + resultsId;\n//         let resultType = \"news\"\n//         if(this.state.searchText) {\n//           let dataObject = {\n//             searchText: this.state.searchText,\n//             currPage: 1,\n//             resultsKey: resultsKey,\n//             resultsId: resultsId,\n//             resultsType: resultType\n//           };\n//           console.log(\"News stored in ===> \", resultsId)\n//           dataObject[resultsKey] = jsonResponse.value ? jsonResponse.value : null;\n//           dataService.setData(dataObject);\n//         }\n//         let redirectObj = {\n//           pathname: \"/search\",\n//           search:\n//             \"?searchText=\" +\n//             encodeURIComponent(this.state.searchText) +\n//             \"?resultsId=\" +\n//             encodeURIComponent(resultsId) +\n//             \"?currPage=\" +\n//             encodeURIComponent(1),\n//         };\n//         browserHistory.push(redirectObj);\n//         window.location.reload(false);\n//       })\n//     }\n//   }\n\n  setInput(data){\n    this.setState({\n      searchText: data,\n    //   showSuggestions: false\n    }, () => {\n        this.webSearch(1)\n    })\n  }\n\n  render() {\n    let suggestions = \"\", display = \"\"\n    // console.log(\"Searching for  ===> \", this.state.searchText)\n    if(this.state.showSuggestions) {\n        suggestions = this.state.filteredSuggestions.map(item => {\n            return <ul style={{fontSize: 16, fontWeight: 'bold', color: '#33333d', cursor: 'pointer'}} onClick={() => {this.setInput(item.query)}}><SearchIcon style={{marginRight: 12}}/>{item.displayText}</ul>\n        })\n        \n        display = <div style={{position: 'absolute', backgroundColor: '#fff', width: '100%', overflowY: 'none', boxShadow: \"5px 10px 18px #888888\", borderBottomLeftRadius: '20px', borderBottomRightRadius: '20px', paddingTop: 20, zIndex: 11111}}>{suggestions}</div>\n    }\n\n    // // console.log(\"Suggestions are => \", this.state.filteredSuggestions)\n    // let button;\n    // if (browserHistory.getCurrentLocation().pathname === \"/\") {\n    //   button = (\n    //     <div>\n    //     <button type=\"button\" className=\"s-button\" onClick={this.search}>\n    //       Web Search\n    //     </button>\n    //     <button type=\"button\" className=\"s-button\" onClick={this.imagesearch}>\n    //     Image Search\n    //   </button>\n    //   <button type=\"button\" className=\"s-button\" onClick={this.newssearch}>\n    //     News Search\n    //   </button>\n    //   </div>\n    //   );\n    // } else {\n    //   button = null;\n    // }\n    return (\n        <Grid item lg={6} className=\"search-bar\">\n          <FormControl type=\"search\" fullWidth={true} onSubmit={this.search} >\n            <Input\n              placeholder=\"Type anything here\"\n              value={this.state.searchText ? this.state.searchText : \"\"}\n              type=\"search\"\n              id=\"searchBar\"\n              onKeyPress={this.handleKeyPress}\n              onChange={this.handleTextChange}\n              autoComplete={'off'}\n              onFocus={() => this.fetchSuggestions(this.state.searchText)}\n              endAdornment={\n                <InputAdornment position=\"end\">\n                  <IconButton\n                    aria-label=\"toggle password visibility\"\n                    onClick={() => this.webSearch(1)}\n                  >\n                    <SearchIcon />\n                  </IconButton>\n                </InputAdornment>\n              }\n            />\n            <div>\n            {display}\n            </div>\n          </FormControl>\n        </Grid>\n    );\n  }\n}\n\nexport default SearchBar;\n","import React, { Component } from \"react\";\nimport \"./assets/main.css\";\nimport SearchBar from \"./utils/SearchBar\";\nimport {Container, Col, Row} from 'react-bootstrap'\nimport {storeData, clearData} from './utils/resultHandler'\nimport SearchIcon from '@material-ui/icons/SearchOutlined';\nimport saveToMongo from \"./utils/savetoMongo\";\n\nclass Home extends Component {\n\n    constructor(props) {\n        super(props)\n        clearData()\n\n        this.state = {\n            searchText: \"\"\n        }\n    }\n\n    webSearch = async (page) => {\n        console.log(\"Web search ===> \", this.state.searchText);\n        let apiURL = \"https://api.bing.microsoft.com/\";\n        let headers = { \"Ocp-Apim-Subscription-Key\": 'ab553acd4424436096d4ef3b183b46ec' };\n        let searchString = encodeURIComponent(this.state.searchText);\n        if (this.state.searchText) {\n          saveToMongo(this.state.searchText);\n          fetch(apiURL + \"v7.0/search?responseFilter=webpages&q=\" + searchString+\"&offset=\"+((page - 1) * 10), {\n            headers,\n          }).then((res) => {\n            res.json().then((json) => {\n                // console.log(\"Web results => \", JSON.stringify(json.webPages.value))\n                // store type of results, result, current page\n    \n                let webResults = json.webPages.value\n                let resultType = \"web\"\n                let currentpage = page\n    \n                // storeData()\n                storeData(webResults, resultType, currentpage, this.state.searchText)\n    \n                // redirect to the new page to display the results\n                window.location = '/search'\n            });\n          });\n        }\n      };\n\n    render() {\n        return(\n            <Container>\n                <Row>\n                    <Col style={{marginTop: '10%'}}>\n                        <div className=\"logo\">\n                            <a href=\"/\">\n                                <img src={require('./assets/logo.png').default} alt=\"logo\" />\n                            </a>\n                        </div>\n                        <div className=\"search-container\">\n                            <SearchBar />\n                        </div>\n                        <a onClick={() => {\n                                    // this.type = \"news\"\n                                    this.webSearch(1)\n                                }}><div className={\"main-s-button\"}>\n                                <SearchIcon />\n                                <button type=\"button\"  style={{outline: 'none', border: 'none', background: 'transparent'}}>\n                                    Search\n                                </button>\n                            </div></a>\n                    </Col>\n                </Row>\n            </Container>\n            // <div className=\"body-container\">\n            //     <div className=\"row logo-home-container\">\n            //         <div className=\"col-md-12\">\n            //             <div className=\"logo\">\n            //                 <a href=\"/\">\n            //                     <img src={require('./assets/logo.png').default} alt=\"logo\" />\n            //                 </a>\n            //             </div>\n            //         </div>\n            //     </div>\n            //     <div className=\"search-container\">\n            //         <SearchBar />\n            //     </div>\n            // </div>\n        )\n    }\n}\n\nexport default Home\n","import React, { Component } from \"react\";\nimport \"../assets/main.css\";\n\nclass ResultCard extends Component {\n    state = {};\n    constructor(props) {\n        super(props);\n        this.data = this.props.dataFromParent;\n    }\n\n    render() {\n        return (\n            <div className=\"result-card\">\n                <div>\n                    <a className=\"link-text\" href={this.data.url}>{this.data.name.replace(/<[^>]*>?/gm, '')}</a>\n                </div>\n                <div>\n                    <a target=\"_blank\" rel=\"noopener noreferrer\" className=\"result-title\" href={this.data.url}>{this.data.displayUrl.replace(/<[^>]*>?/gm, '')}</a>\n                </div>\n                <div>\n                    <span className=\"result-description\">{this.data.snippet.replace(/<[^>]*>?/gm, '')}</span>\n                </div>\n            </div>\n        );\n    }\n}\nexport default ResultCard;\n","import React, { Component } from \"react\";\nimport \"../assets/main.css\";\n\nclass NewsCard extends Component {\n    state = {};\n    constructor(props) {\n        super(props);\n        this.data = this.props.dataFromParent;\n    }\n\n    render() {\n        return (\n            <div className=\"result-card\">\n                <div>\n                    <a className=\"link-text\" href={this.data.url}>{this.data.name.replace(/<[^>]*>?/gm, '')}</a>\n                </div>\n                <div>\n                    <a target=\"_blank\" rel=\"noopener noreferrer\" className=\"result-title\" href={this.data.url}>{this.data.url.replace(/<[^>]*>?/gm, '')}</a>\n                </div>\n                <div>\n                    <span className=\"result-description\">{this.data.description.replace(/<[^>]*>?/gm, '')}</span>\n                </div>\n            </div>\n        );\n    }\n}\nexport default NewsCard;\n","import React, { Component } from \"react\";\nimport \"../assets/main.css\";\n\nclass VideoCard extends Component {\n    state = {};\n    constructor(props) {\n        super(props);\n        this.data = this.props.dataFromParent;\n        // console.log(\"Video data => \", this.data.motionThumbnailUrl)\n    }\n\n    render() {\n        return (\n            // <div className=\"result-card\">\n            //     <div>\n            //         <a className=\"link-text\" href={this.data.url}>{this.data.name.replace(/<[^>]*>?/gm, '')}</a>\n            //     </div>\n            //     <div>\n            //         <a target=\"_blank\" rel=\"noopener noreferrer\" className=\"result-title\" href={this.data.url}>{this.data.displayUrl.replace(/<[^>]*>?/gm, '')}</a>\n            //     </div>\n            //     <div>\n            //         <span className=\"result-description\">{this.data.snippet.replace(/<[^>]*>?/gm, '')}</span>\n            //     </div>\n            // </div>\n            <div class=\"flex-container\">\n                <div class=\"video-image\">\n                    <img src={this.data.thumbnailUrl} alt={this.data.name} />\n                </div>\n                <div>\n                    <div>\n                        <a className=\"link-text-video\" href={this.data.hostPageUrl}>{this.data.name.replace(/<[^>]*>?/gm, '')}</a>\n                    </div>\n                    <div>\n                        <a target=\"_blank\" rel=\"noopener noreferrer\" className=\"result-title\" href={this.data.hostPageUrl}>{this.data.hostPageUrl.replace(/<[^>]*>?/gm, '')}</a>\n                    </div>\n                    <div>\n                        {/* <span className=\"result-description\">{this.data.description.replace(/<[^>]*>?/gm, '')}</span> */}\n                    </div>\n                </div>\n            </div>\n        );\n    }\n}\nexport default VideoCard;\n","import React, { Component } from \"react\";\nimport \"../assets/main.css\";\n\nclass ImageCard extends Component {\n    state = {};\n    constructor(props) {\n        super(props);\n        this.data = this.props.dataFromParent\n    }\n\n    render() {\n        return (\n            <a href={this.data.hostPageUrl} className=\"img-container\">\n                <img src={this.data.thumbnailUrl} alt={this.data.name}/>\n                <div className=\"img-description\">\n                    <span style={{color: '#fff', textAlign: 'center', display: 'inline-block', verticalAlign: 'middle', padding: 5, fontSize: 10}}>{this.data.name}{'\\n'}</span>\n                    <a href={this.data.hostPageUrl} style={{color: '#fff',display: 'inline-block', verticalAlign: 'middle', padding: 5, textDecoration: 'none', fontSize: 6}}>{this.data.hostPageUrl}</a>\n                </div>\n            </a>\n        );\n    }\n}\nexport default ImageCard;\n","import React, { Component } from \"react\";\nimport SearchBar from \"./utils/SearchBar\";\nimport \"./assets/main.css\";\nimport {Container, Col, Row} from 'react-bootstrap'\nimport {storeData, getData} from './utils/resultHandler'\nimport ResultCard from \"./utils/ResultCard\";\nimport NewsCard from \"./utils/NewsCard\";\nimport saveToMongo from \"./utils/savetoMongo\";\nimport ImageList from '@material-ui/core/ImageList';\nimport ImageListItem from '@material-ui/core/ImageListItem';\nimport ImageListItemBar from '@material-ui/core/ImageListItemBar';\nimport SearchIcon from '@material-ui/icons/SearchOutlined';\nimport ImageIcon from '@material-ui/icons/ImageOutlined'\nimport NewsIcon from '@material-ui/icons/AnnouncementOutlined'\nimport VideoIcon from '@material-ui/icons/Videocam'\nimport VideoCard from './utils/VideoCard'\nimport ImageCard from './utils/ImageCard'\n\nclass Search extends Component {\n\n    constructor(props) {\n        super(props)\n\n        let [ result, type, page, query ] = getData()\n        this.result = result\n        this.type = type\n        this.page = page\n        this.searchText = query\n        // console.log(\"type => \", this.searchText)\n\n\n        let minPage = (this.page - 2 > 0) ? this.page - 2 : 1;\n        // console.log(\"minPage ===> \", minPage, typeof(minPage))\n        this.paginationArray = [];\n        for (let i = 0; i < 5; i++) {\n            this.paginationArray.push(minPage + i);\n        }\n\n        this.state = {\n            searchText: this.searchText\n        }\n    }\n\n    paginationSearch(page) {\n        if(this.type === \"web\") {\n            this.webSearch(page)\n        } else if(this.type === \"image\") {\n            this.imageSearch(page)\n        } else if(this.type === \"news\") {\n            this.newsSearch(page)\n        } else if(this.type === \"video\") {\n            this.videoSearch(page)\n        }\n    }\n\n    webSearch = async (page) => {\n        console.log(\"Web search ===> \", this.state.searchText);\n        let apiURL = \"https://api.bing.microsoft.com/\";\n        let headers = { \"Ocp-Apim-Subscription-Key\": 'ab553acd4424436096d4ef3b183b46ec' };\n        let searchString = encodeURIComponent(this.state.searchText);\n        if (this.state.searchText) {\n          saveToMongo(this.state.searchText);\n          fetch(apiURL + \"v7.0/search?responseFilter=webpages&q=\" + searchString+\"&offset=\"+((page - 1) * 10), {\n            headers,\n          }).then((res) => {\n            res.json().then((json) => {\n                // console.log(\"Web results => \", JSON.stringify(json.webPages.value))\n                // store type of results, result, current page\n    \n                let webResults = json.webPages.value\n                let resultType = \"web\"\n                let currentpage = page\n    \n                // storeData()\n                storeData(webResults, resultType, currentpage, this.state.searchText)\n    \n                // redirect to the new page to display the results\n                window.location = '/search'\n            });\n          });\n        }\n      };\n\n    newsSearch = async (page) => {\n        console.log(\"News search ===> \", this.state.searchText) \n        let apiURL = \"https://bing-news-search1.p.rapidapi.com/news/search\"+\"?q=\"+encodeURIComponent(this.state.searchText)+\"&safeSearch=Off&textFormat=Raw&freshness=Day&offset=\" + ((page - 1) * 10);\n        let headers = {\n            'x-bingapis-sdk': 'true',\n            'x-rapidapi-key': '3fe9872e94mshf148b0071798372p1b8684jsndae02e4e3799',\n            'x-rapidapi-host': 'bing-news-search1.p.rapidapi.com'\n        }\n        // let searchString = encodeURIComponent(this.state.searchText);\n        if (this.state.searchText) {\n            saveToMongo(this.state.searchText);\n            fetch(apiURL, { headers})\n            .then((res) => {\n                res.json().then((json) => {\n                // console.log(\"News results => \", JSON.stringify(json.value))\n                  // store type of results, result, current page\n      \n                  let newsResults = json.value\n                  let resultType = \"news\"\n                  let currentpage = page\n      \n                  // storeData()\n                  storeData(newsResults, resultType, currentpage, this.state.searchText)\n      \n                  // redirect to the new page to display the results\n                  window.location = '/search'\n              });\n            });\n        }\n    }\n\n    imageSearch = async (page) => {\n        console.log(\"Image search ===> \", this.state.searchText);\n        let apiURL = \"https://bing-image-search1.p.rapidapi.com/images/search\" + '?q='+ encodeURIComponent(this.state.searchText) +'&offset=' + ((page - 1) * 10);\n        let headers = {\n        'x-rapidapi-key': '3fe9872e94mshf148b0071798372p1b8684jsndae02e4e3799',\n        'x-rapidapi-host': 'bing-image-search1.p.rapidapi.com'\n      }\n    //     let searchString = encodeURIComponent(this.state.searchText);\n        if (this.state.searchText) {\n          saveToMongo(this.state.searchText);\n          fetch(apiURL, {\n            headers,\n          }).then((res) => {\n            res.json().then((json) => {\n                // console.log(\"Web results => \", JSON.stringify(json.value))\n                // store type of results, result, current page\n    \n                let imageResults = json.value\n                let resultType = \"image\"\n                let currentpage = page\n    \n                // storeData()\n                storeData(imageResults, resultType, currentpage, this.state.searchText)\n    \n                // redirect to the new page to display the results\n                window.location = '/search'\n            });\n          });\n        }\n      };\n\n    videoSearch = async (page) => {\n        console.log(\"Video Search ===> \", this.state.searchText)\n        let apiURL = \"https://bing-video-search1.p.rapidapi.com/videos/search?q=\"+ encodeURIComponent(this.state.searchText) +'&offset=' + ((page - 1) * 10);\n\n        let headers = {\n            'x-rapidapi-key': '3fe9872e94mshf148b0071798372p1b8684jsndae02e4e3799',\n            'x-rapidapi-host': 'bing-video-search1.p.rapidapi.com'\n        }\n\n        if (this.state.searchText) {\n            saveToMongo(this.state.searchText);\n            fetch(apiURL, {\n              headers,\n            }).then((res) => {\n              res.json().then((json) => {\n                  // console.log(\"Web results => \", JSON.stringify(json.value))\n                  // store type of results, result, current page\n      \n                  let imageResults = json.value\n                  let resultType = \"video\"\n                  let currentpage = page\n      \n                  // storeData()\n                  storeData(imageResults, resultType, currentpage, this.state.searchText)\n      \n                  // redirect to the new page to display the results\n                  window.location = '/search'\n              });\n            });\n        }\n    }\n\n    render() {\n        // console.log(\"Search text => \", this.state.searchText)\n        // console.log(\"This page is => \", this.page, typeof(this.page))\n        let details = \"\"\n        if(this.type === \"web\") {\n            details = this.result.map(result => (\n                <ResultCard dataFromParent={result}/>\n            ))\n        } else if(this.type === \"news\") {\n            details = this.result.map(result => (\n                <NewsCard dataFromParent={result} />\n            ))\n        } else if(this.type === \"image\") {\n        //     details = <ImageList rowHeight={200} className=\"imageList\" cols={4} gap={24}>\n        //     {this.result.map((item) => (\n        //       <ImageListItem key={item.imageInsightsToken} className=\"image-item\">\n        //         <img src={item.contentUrl} alt={item.name} />\n        //         <ImageListItemBar\n        //           title={item.name}\n        //           subtitle={<a target=\"_blank\" rel=\"noopener noreferrer\" href={item.hostPageUrl} style={{color: 'inherit'}}>{item.hostPageDisplayUrl}</a>}\n        //         //   actionIcon={\n        //         //     <IconButton aria-label={`info about ${item.title}`}>\n        //         //       <InfoIcon />\n        //         //     </IconButton>\n        //         //   }\n        //         />\n        //       </ImageListItem>\n        //     ))}\n        //   </ImageList>\n            details = this.result.map(result => (\n                <ImageCard dataFromParent={result} />\n            ))\n        } else if(this.type === \"video\") {\n            details = this.result.map(result => (\n                <VideoCard dataFromParent={result} />\n            ))\n        }\n        return(\n            <Container>\n                <Row>\n                    <Col xs={12} lg={2}>\n                        <div className=\"logo\" style={{ margin: '3vh auto 0 auto' }}>\n                            <a href=\"/\"><img src={require('./assets/logo.png').default} alt=\"logo\" /></a>\n                        </div>\n                    </Col>\n                    <Col xs={12} lg={7} sm={12}>\n                        <div className=\"search-page-bar-container\">\n                            <SearchBar />\n                        </div>\n                        <div style={{marginBottom: '3vh', display: 'flex', flexDirection:'row'}}>\n                            {/* <Col> */}\n                            <a onClick={() => {\n                                    // this.type = \"web\"\n                                    this.webSearch(1)\n                                }}><div className={this.type === \"web\" ? \"s-button-active\" : \"s-button\"} >\n                                <SearchIcon />\n                                <button type=\"button\"  style={{outline: 'none', border: 'none', background: 'transparent'}}>\n                                    Web\n                                </button>\n                            </div></a>\n                            {/* </Col> */}\n                            {/* <Col> */}\n                            <a onClick={() => {\n                                    // this.type = \"image\"\n                                    this.imageSearch(1)\n                                }}><div className={this.type === \"image\" ? \"s-button-active\" : \"s-button\"}>\n                                <ImageIcon />\n                                <button type=\"button\"  style={{outline: 'none', border: 'none', background: 'transparent'}}>\n                                    Image\n                                </button>\n                            </div></a>\n                            {/* </Col> */}\n                            {/* <Col> */}\n                            <a onClick={() => {\n                                    // this.type = \"news\"\n                                    this.newsSearch(1)\n                                }}><div className={this.type === \"news\" ? \"s-button-active\" : \"s-button\"}>\n                                <NewsIcon />\n                                <button type=\"button\"  style={{outline: 'none', border: 'none', background: 'transparent'}}>\n                                    News\n                                </button>\n                            </div></a>\n                            {/* </Col> */}\n                            <a onClick={() => {\n                                    // this.type = \"news\"\n                                    this.videoSearch(1)\n                                }}><div className={this.type === \"video\" ? \"s-button-active\" : \"s-button\"}>\n                                <VideoIcon />\n                                <button type=\"button\"  style={{outline: 'none', border: 'none', background: 'transparent'}}>\n                                    Videos\n                                </button>\n                            </div></a>\n                        </div>\n                        <Row>\n                            {\n                                details\n                            }\n                        </Row>\n                    </Col>\n                </Row>\n                <div className=\"row\">\n                    <div className=\"col-md-3\"></div>\n                    <div className=\"col-md-6\">\n                        <div className=\"results-footer\">\n                        <div className=\"pagination-container\">\n                            {\n                            this.page > 3 ?\n                                <span onClick={() => this.paginationSearch(this.paginationArray[0] - 1)}>{\"<<\"}</span> : null\n                            }\n                            {\n                            this.paginationArray.map(number => (\n                                <span onClick={() => this.paginationSearch(number)} className={this.page === number ? \"currentPage\" : \"\"}>{number}</span>\n                            ))\n                            }\n                            <span onClick={() => this.paginationSearch(this.paginationArray[4] + 1)}>{\">>\"}</span>\n                        </div>\n                        </div>\n                    </div>\n                </div>\n                <div className=\"row\">\n          <div className=\"col-md-3\"></div>\n          <div className=\"col-md-6\">\n            <div className=\"logo-footer\">\n              <a href=\"/\"><img src={require('./assets/logo.png').default} alt=\"logo\" /></a>\n            </div>\n          </div>\n        </div>\n            </Container>\n        )\n    }\n}\n\nexport default Search","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport Home from './Home';\nimport { BrowserRouter as Router, Switch, Route} from 'react-router-dom'\nimport Search from './Search'\nimport 'bootstrap/dist/css/bootstrap.min.css';\n\nReactDOM.render(\n\t<Router>\n\t\t<Switch>\n\t\t\t<Route exact path='/'>\n\t\t\t\t<Home />\n\t\t\t</Route>\n\t\t\t<Route exact path='/search'>\n\t\t\t\t<Search />\n\t\t\t</Route>\n    \t</Switch>\n  </Router>,\n  document.getElementById('root')\n);"],"sourceRoot":""}