create the results page action,reducer

This commit is contained in:
Ahmed-Ayman 2018-12-19 18:08:22 +02:00
parent 1779d04546
commit b5ae097872
5 changed files with 102 additions and 15 deletions

View File

@ -13,10 +13,10 @@ import Footer from "./components/Footer";
import Search from "./components/Search"; import Search from "./components/Search";
import Nav from "./components/Nav"; import Nav from "./components/Nav";
import Video from "./containers/Video"; import Video from "./containers/Video";
import Results from "./containers/Results";
class App extends Component { class App extends Component {
render() { render() {
console.log('store', history, store);
return ( return (
<Provider store={store}> <Provider store={store}>
<ConnectedRouter history={ history }> <ConnectedRouter history={ history }>
@ -26,7 +26,7 @@ class App extends Component {
<Switch> <Switch>
<Route exact={true} path="/" component={Home}/> <Route exact={true} path="/" component={Home}/>
<Route path="/topics" component={TopicsListContainer}/> <Route path="/topics" component={TopicsListContainer}/>
{/*<Route path="/results/:categoryKey/:searchValue" component={Results}/>*/} <Route path="/results/:categoryKey/:searchValue" component={Results}/>
<Route path="/videos/:videoId" component={Video}/> <Route path="/videos/:videoId" component={Video}/>
</Switch> </Switch>
<Nav/> <Nav/>

View File

@ -1,12 +1,43 @@
import {LOADED_ALL_RESULTS,START_LOADING_ALL_RESULTS} from "./action_types"; import {LOADED_ALL_RESULTS, LOADED_ALL_TOPICS, START_LOADING_ALL_RESULTS} from "./action_types";
import {fetchAllTopics} from "../utils/api";
export function getAllResuts(categoryKey, searchValue){ import {APIError} from "./errors";
import {setItem} from "../utils/safe-storage";
export function getSearchResults(categoryKey, searchValue) {
// get the stuff from the api // get the stuff from the api
// dispatch loaded // dispatch loaded
switch (categoryKey) {
case 'topic':
console.log('topic')
return dispatch => { return dispatch => {
dispatch(loadingAllResults()) dispatch(loadingAllResults())
// this calls the API
fetchAllTopics()
.then(topics => {
dispatch(loadedTopics(topics));
}).catch(error => {
dispatch(APIError(error));
})
};
case 'date':
console.log('date')
case 'location':
console.log('location')
default:
console.log('none')
} }
} }
function loadingAllResults() { function loadingAllResults() {
} }
function loadedTopics(topics) {
// cache
setItem('allTopics', JSON.stringify(topics));
setItem('topicsUpdatedAt', new Date());
return {
type: LOADED_ALL_TOPICS,
payload: topics
};
};

View File

@ -1,26 +1,59 @@
import React from 'react'; import React from 'react';
import Grid from "react-css-grid";
import VideoItem from "../components/VideoItem";
import PropTypes from "prop-types";
import {getSearchResults} from "../actions/search";
import connect from "react-redux/es/connect/connect";
class Results extends React.Component { class Results extends React.Component {
componentDidMount() { componentDidMount() {
// get params from url
const categoryKey = this.props.match.params.categoryKey; const categoryKey = this.props.match.params.categoryKey;
const searchValue = this.props.match.params.searchValue; const searchValue = this.props.match.params.searchValue;
console.log(categoryKey)
console.log(searchValue)
} }
render() { render() {
return ( return (
<Grid className="random-topics"
width={220}
gap={12}>
{this.props.searchResults.map(video =>
<VideoItem id={video.id} key={video.id} title={video.title}/>
)}
</Grid>
); );
} }
} }
const mapStateToProps = state => ({ const mapStateToProps = state => ({
searchResults: this.state.results.currentItems, searchResults: this.state.results.currentItems,
currentKey: this.state.results.currentKey,
currentValue: this.state.results.currentValue,
currentQuery: this.state.results.queryParams
}); });
const mapDispatchToProps = dispatch => ({ const mapDispatchToProps = dispatch => ({
searchResults: (categoryKey, searchValue) => dispatch(getSearchResults(categoryKey, searchValue)), // the category key is either {topic, date, date}
// the search value could be something like 25th-jan.
getSearchResults: (categoryKey, searchValue) => dispatch(getSearchResults(categoryKey, searchValue)),
}); });
export default; // each result page has :
// - currentKey: 858.ma/{key}/ where key could be like 'topic'
// - currentValue: 858.ma/topic/{value} where value could be like 'alaa abd al fatah'
// - currentQuery: 858.ma/{query} ?? not getting this! @TODO: clarify this please.
// - currentItems: the list of items/videos.
Results.propTypes = {
// the category key is either a {topic, location, date}.
currentKey: PropTypes.string,
currentValue: PropTypes.string,
currentItems: PropTypes.array,
loading: PropTypes.bool,
categoryItemCount: PropTypes.number,
getSearchResults: PropTypes.func
};
export default connect(mapStateToProps, mapDispatchToProps)(Results);

View File

@ -2,10 +2,12 @@ import { combineReducers } from 'redux';
import TopicsReducer from './topics'; import TopicsReducer from './topics';
import VideosReducer from './videos'; import VideosReducer from './videos';
import { connectRouter } from 'connected-react-router' import SearchReducer from './search';
import { connectRouter } from 'connected-react-router'
export default (history) => combineReducers({ export default (history) => combineReducers({
router: connectRouter(history), router: connectRouter(history),
topics: TopicsReducer, topics: TopicsReducer,
videos: VideosReducer videos: VideosReducer,
searchResults: SearchReducer,
}); });

21
src/reducers/search.js Normal file
View File

@ -0,0 +1,21 @@
import {
START_LOADING_ALL_RESULTS,
LOADED_ALL_RESULTS
} from '../actions/action_types';
export default function(state={}, action) {
switch (action.type) {
case START_LOADING_ALL_RESULTS:
return Object.assign({}, state, { loadingAllTopics: true });
case LOADED_ALL_RESULTS:
return Object.assign({}, state, {
loadingAllTopics: false,
currentItems: action.payload
});
default:
return state;
}
};