Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Breaking API changes for 1.0 #195

Merged
merged 129 commits into from
Aug 14, 2015
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
129 commits
Select commit Hold shift + click to select a range
e426039
Breaking API changes for 1.0
gaearon Jun 30, 2015
34d90b9
Remove unnecessary changes
gaearon Jun 30, 2015
8c8e429
s/atom/state and s/Composition/composition
iamdustan Jul 1, 2015
72aa974
Merge pull request #201 from iamdustan/breaking-changes-s-atom-store
gaearon Jul 1, 2015
667d8f5
state preservation when replacing a reducer: continue incrementing th…
iamdustan Jul 1, 2015
069d641
Merge pull request #200 from iamdustan/breaking-changes-test-id-incre…
gaearon Jul 1, 2015
6a2730d
Implement applyMiddleware higher-order store
acdlite Jul 4, 2015
9a1a0cd
Fix composeMiddleware and move back into separate module
acdlite Jul 4, 2015
b72f909
Fix linting
acdlite Jul 4, 2015
b8e7e1e
Throw error on undefined value from reducer function
Jul 1, 2015
c6312df
Merge branch 'master' into breaking-changes-1.0
gaearon Jul 8, 2015
97d90d0
Merge remote-tracking branch 'taylorhakes/compose-reducer-undefined' …
gaearon Jul 8, 2015
de685de
Add more helpful error messages
gaearon Jul 8, 2015
1791e2a
Merge branch 'update-middleware-api' into breaking-changes-1.0
gaearon Jul 8, 2015
039c30f
composeReducers -> combineReducers
gaearon Jul 8, 2015
7245b58
Fix duplicate React when running examples
gaearon Jul 8, 2015
e621c79
Fix counter example
gaearon Jul 8, 2015
152c886
Fix lint
gaearon Jul 9, 2015
406ca62
Handle changes from dispatch inside componentDidMount (fixes #208)
gaearon Jul 9, 2015
038cd25
Added test for shallowEqualScalar in connect decorator
Jul 9, 2015
5d5dbcc
Merge pull request #236 from taylorhakes/shallow-equal-scalar-test
gaearon Jul 9, 2015
4c68696
Add Flow type annotations
acdlite Jul 10, 2015
e854617
Fix linting
acdlite Jul 10, 2015
0daeec9
Merge branch 'master' into breaking-changes-1.0
gaearon Jul 10, 2015
51f798c
Merge branch 'master' into breaking-changes-1.0
gaearon Jul 10, 2015
c46494b
Remove React-specific code in favor of gaearon/redux-react
gaearon Jul 11, 2015
ab347bf
Bump the versions
gaearon Jul 11, 2015
a38e4ad
Dispatch sends action through entire middleware chain
jquense Jul 12, 2015
c80a77a
Merge pull request #250 from jquense/fix-middleware-dispatch
gaearon Jul 12, 2015
dc44972
Merge branch 'breaking-changes-1.0' into flow-types-take-2
acdlite Jul 12, 2015
66ec814
Merge pull request #249 from gaearon/remove-react
gaearon Jul 12, 2015
f7e92d9
Merge with master
gaearon Jul 12, 2015
18aceee
Remove nesting from tests
gaearon Jul 12, 2015
0b5207f
Remove thunk middleware from the core
gaearon Jul 12, 2015
60b2119
Merge pull request #256 from gaearon/remove-thunk-middleware
gaearon Jul 12, 2015
650f002
Remove combineReducers shortcut in favor of an explicit call
gaearon Jul 12, 2015
6fe0625
Merge pull request #257 from gaearon/combine-reducers-explicitly
gaearon Jul 12, 2015
5eaa7b6
Merge remote-tracking branch 'origin/master' into breaking-changes-1.0
gaearon Jul 12, 2015
749b4ab
Tweak dependencies
gaearon Jul 13, 2015
e3ec501
Extract thunk
gaearon Jul 13, 2015
afd4260
Move test files
gaearon Jul 13, 2015
9045a0c
Handling private actions is an anti-pattern. Enforce it. (Fixes #186)
gaearon Jul 13, 2015
99a9cee
Merge pull request #259 from gaearon/forbid-handling-private-actions
gaearon Jul 13, 2015
e39afbe
1.0.0-rc
gaearon Jul 13, 2015
2aa83ff
Bad idea to call that React Redux 1.0 alpha. Stick to 0.x for now
gaearon Jul 13, 2015
baede74
update wrap dispatch test with the failure case.
tappleby Jul 14, 2015
b4766b3
update applyMiddleware to only compose dispatch method once.
tappleby Jul 14, 2015
3481fdb
Use npm for tasks
emmenko Jul 14, 2015
2b4d416
Merge pull request #262 from tappleby/bugfix-apply-middleware-single-…
gaearon Jul 15, 2015
0623cf4
Replace class with a factory function
gaearon Jul 19, 2015
eaa20fa
Update Flow annotations with Redux 1.0 API changes
gaearon Jul 19, 2015
ac8a184
Fix the missing Flow annotations
gaearon Jul 19, 2015
98ab1de
Merge pull request #254 from gaearon/flow-types-take-3
gaearon Jul 19, 2015
e355ccd
Move Flow type definitions into index
gaearon Jul 21, 2015
a4b8aff
Remove src from .npmignore for Flow, add test instead
gaearon Jul 21, 2015
7ad209a
Allow es6 symbols to be used as action types
jhewlett Jul 22, 2015
adbfbdd
Fix lint errors
jhewlett Jul 22, 2015
55776ad
Fix Flow signature for Store#getReducer
gaearon Jul 22, 2015
3d252c3
Exclude coverage files from NPM
gaearon Jul 22, 2015
91acd42
Fix merge conflict
gaearon Jul 22, 2015
ed3edea
Tweak build scripts
gaearon Jul 22, 2015
b51338f
Merge pull request #267 from gaearon/npm-tasks
gaearon Jul 22, 2015
9321dea
Remove Flow types for now
gaearon Jul 22, 2015
305f142
Merge pull request #299 from gaearon/remove-flow
gaearon Jul 22, 2015
100ce3c
composeMiddleware is an implementation detail of applyMiddleware
gaearon Jul 22, 2015
af474ba
Inline composeMiddleware because it is not used outside applyMiddleware
gaearon Jul 22, 2015
8bb94c7
Merge pull request #295 from jhewlett/breaking-changes-1.0
gaearon Jul 22, 2015
27752e6
Style fixup
gaearon Jul 22, 2015
259c6bf
Add JSDoc annotations
gaearon Jul 22, 2015
7418203
Merge pull request #300 from gaearon/jsdoc
gaearon Jul 22, 2015
941a2e1
Merge branch 'master' into breaking-changes-1.0
gaearon Jul 23, 2015
be4b589
fix isPlainObject, is comparing object stringified object constructor…
michalkvasnicak Jul 23, 2015
0c87ead
add contextify to simulate another realm (context) and test case wher…
michalkvasnicak Jul 23, 2015
5734779
replace const with var for flow-friendly code
michalkvasnicak Jul 23, 2015
0fc5802
Merge pull request #306 from michalkvasnicak/is-plain-object-fix
gaearon Jul 23, 2015
d92f08e
Allow `bindActionCreators` to be used with function as actionCreator
michaelcontento Jul 29, 2015
3cfdd73
Merge pull request #352 from michaelcontento/function-support-for-bin…
gaearon Jul 29, 2015
fca60c8
add verifyStateShape function and tests
ellbee Jul 22, 2015
9a1ad4f
Remove ES7 features from counter example
rwillrich Jul 30, 2015
3dfbb1f
Remove ES7 features from todomvc example
rwillrich Jul 30, 2015
5e87896
Merge pull request #373 from rwillrich/remove-es7-from-examples
gaearon Jul 30, 2015
848bb8e
Throw error when trying to dispatch from action
Jul 30, 2015
de301ce
Merge pull request #372 from quicksnap/no_dispatch_in_actions
gaearon Jul 30, 2015
1879d00
Add script to help travis build all examples
Jul 30, 2015
4358fc4
Merge pull request #375 from quicksnap/example_build_tools
gaearon Jul 31, 2015
46276c0
Fix Windows build
gaearon Jul 31, 2015
94d0944
Merge pull request #379 from gaearon/fix-windows-build
gaearon Jul 31, 2015
b619853
Bump minimal required Expect version
gaearon Jul 31, 2015
a467c41
Merge branch 'verify-state-shape' into breaking-changes-1.0
gaearon Jul 31, 2015
fbf06c5
tests for the examples
sambs Jul 16, 2015
8cbd405
run tests in the examples build script
sambs Aug 3, 2015
2a08009
Merge pull request #380 from sambs/example-tests-rebased
gaearon Aug 4, 2015
c1b8acd
Use connect instead of Connector in examples
gaearon Aug 5, 2015
4efcfcb
Lock io.js Travis version because contextify install fails
gaearon Aug 6, 2015
ae1c2e2
add jsnext:main in package.json for next gen bundling
Aug 6, 2015
22ca4be
Add invariant errors for bindActionCreator.
Aug 6, 2015
f614bf6
Merge pull request #411 from jarsbe/bind-warning
gaearon Aug 6, 2015
9985ac8
Merge pull request #412 from clintwood/jsnext
gaearon Aug 6, 2015
2798abb
Modify package.json description
Aug 6, 2015
199a5bc
Merge pull request #415 from quicksnap/breaking-changes-1.0
gaearon Aug 6, 2015
573a84b
Update react-redux
gaearon Aug 7, 2015
09b3b1d
Update react-redux
gaearon Aug 7, 2015
6e8127c
adjust scoping for opts to avoid error with spawnSync
kevinold Aug 9, 2015
dc922d6
Merge pull request #439 from kevinold/fix-spawnSync
gaearon Aug 9, 2015
79f90bc
Style tweaks + update react-redux
gaearon Aug 10, 2015
06134f7
Add test:watch to examples
gaearon Aug 10, 2015
9db0c57
update counter example
Aug 7, 2015
27fa07c
Clarify action and prop naming: mark => complete
gaearon Aug 10, 2015
f0132a0
Merge pull request #453 from hartzis/update-counter-example
gaearon Aug 10, 2015
2ddfd71
Fixes #461 - Copy listeners array, so subscribes can't affect the loop.
arian Aug 11, 2015
d594232
Merge pull request #462 from arian/fix-461-unsubscribing-listeners
gaearon Aug 11, 2015
b94f9a8
Port flux-react-router-example to Redux
gaearon Aug 11, 2015
df01a1f
Rename packages
gaearon Aug 11, 2015
41e609d
Merge pull request #460 from gaearon/add-async-example
gaearon Aug 11, 2015
6446dfd
Update index.js
gaearon Aug 11, 2015
dd2de74
remove spread from api middleware
Aug 12, 2015
2ea278e
prefer Object.assign
Aug 12, 2015
8b5298c
remove usage of `static` and extend from React.Component
Aug 12, 2015
889a7be
Merge pull request #466 from danmartinez101/use-es6-in-real-world-exa…
gaearon Aug 12, 2015
4fba03f
Fix syntax error in Object.assign in real world example
Aug 12, 2015
30122f6
Merge pull request #467 from nbostrom/fix-object-assign-in-example
gaearon Aug 12, 2015
bf349bb
Real World Example - Fix typo in API middleware error string
HPate-Riptide Aug 12, 2015
8b1c075
Merge pull request #471 from HPate-Riptide/patch-1
gaearon Aug 12, 2015
b9bb28f
Add redux-logger
gaearon Aug 12, 2015
ed33ec1
Fixes pagination
gaearon Aug 12, 2015
4de6324
Tweak example conventions
gaearon Aug 12, 2015
f179ba8
Merge pull request #473 from gaearon/tweak-example-conventions
gaearon Aug 12, 2015
01c3cf0
Add simple async example
gaearon Aug 13, 2015
fd7f884
Merge pull request #474 from gaearon/add-async-example-2
gaearon Aug 13, 2015
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions .eslintrc
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,16 @@
"node": true
},
"rules": {
"valid-jsdoc": 2,

"react/jsx-uses-react": 2,
"react/jsx-uses-vars": 2,
"react/react-in-jsx-scope": 2,

// Disable until Flow supports let and const
"no-var": 0,
"vars-on-top": 0,

//Temporarirly disabled due to a possible bug in babel-eslint (todomvc example)
"block-scoped-var": 0,
// Temporarily disabled for test/* until babel/babel-eslint#33 is resolved
Expand Down
9 changes: 9 additions & 0 deletions .flowconfig
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
[ignore]
.*/lib
.*/test

[include]

[libs]

[options]
6 changes: 2 additions & 4 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
node_modules
npm-debug.log
.DS_Store
*.log
node_modules
dist
lib
coverage
react.js
react-native.js
5 changes: 4 additions & 1 deletion .npmignore
Original file line number Diff line number Diff line change
@@ -1,2 +1,5 @@
src
.DS_Store
*.log
examples
test
coverage
6 changes: 5 additions & 1 deletion .travis.yml
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
language: node_js
node_js:
- "iojs"
- "iojs-2"
script:
- npm test
- npm run build:examples

3 changes: 3 additions & 0 deletions examples/async/.babelrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"stage": 2
}
64 changes: 64 additions & 0 deletions examples/async/actions/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
import fetch from 'isomorphic-fetch';

export const REQUEST_POSTS = 'REQUEST_POSTS';
export const RECEIVE_POSTS = 'RECEIVE_POSTS';
export const SELECT_REDDIT = 'SELECT_REDDIT';
export const INVALIDATE_REDDIT = 'INVALIDATE_REDDIT';

export function selectReddit(reddit) {
return {
type: SELECT_REDDIT,
reddit
};
}

export function invalidateReddit(reddit) {
return {
type: INVALIDATE_REDDIT,
reddit
};
}

function requestPosts(reddit) {
return {
type: REQUEST_POSTS,
reddit
};
}

function receivePosts(reddit, json) {
return {
type: RECEIVE_POSTS,
reddit: reddit,
posts: json.data.children,
receivedAt: Date.now()
};
}

function fetchPosts(reddit) {
return dispatch => {
dispatch(requestPosts(reddit));
return fetch(`http://www.reddit.com/r/${reddit}.json`)
.then(req => req.json())
.then(json => dispatch(receivePosts(reddit, json)));
}
}

function shouldFetchPosts(state, reddit) {
const posts = state.postsByReddit[reddit];
if (!posts) {
return true;
} else if (posts.isFetching) {
return false;
} else {
return posts.didInvalidate;
}
}

export function fetchPostsIfNeeded(reddit) {
return (dispatch, getState) => {
if (shouldFetchPosts(getState(), reddit)) {
return dispatch(fetchPosts(reddit));
}
};
}
29 changes: 29 additions & 0 deletions examples/async/components/Picker.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import React, { Component, PropTypes } from 'react';

export default class Picker extends Component {
render () {
const { value, onChange, options } = this.props;

return (
<span>
<h1>{value}</h1>
<select onChange={e => onChange(e.target.value)}
value={value}>
{options.map(option =>
<option value={option} key={option}>
{option}
</option>)
}
</select>
</span>
);
}
}

Picker.propTypes = {
options: PropTypes.arrayOf(
PropTypes.string.isRequired
).isRequired,
value: PropTypes.string.isRequired,
onChange: PropTypes.func.isRequired
};
17 changes: 17 additions & 0 deletions examples/async/components/Posts.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import React, { PropTypes, Component } from 'react';

export default class Posts extends Component {
render () {
return (
<ul>
{this.props.posts.map((post, i) =>
<li key={i}>{post.data.title}</li>
)}
</ul>
);
}
}

Posts.propTypes = {
posts: PropTypes.array.isRequired
};
102 changes: 102 additions & 0 deletions examples/async/containers/AsyncApp.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
import React, { Component, PropTypes } from 'react';
import { connect } from 'react-redux';
import { selectReddit, fetchPostsIfNeeded, invalidateReddit } from '../actions';
import Picker from '../components/Picker';
import Posts from '../components/Posts';

class AsyncApp extends Component {
constructor(props) {
super(props);
this.handleChange = this.handleChange.bind(this);
this.handleRefreshClick = this.handleRefreshClick.bind(this);
}

componentDidMount() {
const { dispatch, selectedReddit } = this.props;
dispatch(fetchPostsIfNeeded(selectedReddit));
}

componentWillReceiveProps(nextProps) {
if (nextProps.selectedReddit !== this.props.selectedReddit) {
const { dispatch, selectedReddit } = nextProps;
dispatch(fetchPostsIfNeeded(selectedReddit));
}
}

handleChange(nextReddit) {
this.props.dispatch(selectReddit(nextReddit));
}

handleRefreshClick(e) {
e.preventDefault();

const { dispatch, selectedReddit } = this.props;
dispatch(invalidateReddit(selectedReddit));
dispatch(fetchPostsIfNeeded(selectedReddit));
}

render () {
const { selectedReddit, posts, isFetching, lastUpdated } = this.props;
return (
<div>
<Picker value={selectedReddit}
onChange={this.handleChange}
options={['reactjs', 'frontend']} />
<p>
{lastUpdated &&
<span>
Last updated at {new Date(lastUpdated).toLocaleTimeString()}.
{' '}
</span>
}
{!isFetching &&
<a href='#'
onClick={this.handleRefreshClick}>
Refresh
</a>
}
</p>
{isFetching && posts.length === 0 &&
<h2>Loading...</h2>
}
{!isFetching && posts.length === 0 &&
<h2>Empty.</h2>
}
{posts.length > 0 &&
<div style={{ opacity: isFetching ? 0.5 : 1 }}>
<Posts posts={posts} />
</div>
}
</div>
);
}
}

AsyncApp.propTypes = {
selectedReddit: PropTypes.string.isRequired,
posts: PropTypes.array.isRequired,
isFetching: PropTypes.bool.isRequired,
lastUpdated: PropTypes.number,
dispatch: PropTypes.func.isRequired
};

function mapStateToProps(state) {
const { selectedReddit, postsByReddit } = state;
const {
isFetching,
lastUpdated,
items: posts
} = postsByReddit[selectedReddit] || {
isFetching: true,
items: []
};

return {
selectedReddit,
posts,
isFetching,
lastUpdated
};
}

export default connect(mapStateToProps)(AsyncApp);
16 changes: 16 additions & 0 deletions examples/async/containers/Root.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import React, { Component } from 'react';
import { Provider } from 'react-redux';
import configureStore from '../store/configureStore';
import AsyncApp from './AsyncApp';

const store = configureStore();

export default class Root extends Component {
render() {
return (
<Provider store={store}>
{() => <AsyncApp />}
</Provider>
);
}
}
10 changes: 10 additions & 0 deletions examples/async/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
<html>
<head>
<title>Redux async example</title>
</head>
<body>
<div id="root">
</div>
</body>
<script src="/static/bundle.js"></script>
</html>
9 changes: 9 additions & 0 deletions examples/async/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import 'babel-core/polyfill';

import React from 'react';
import Root from './containers/Root';

React.render(
<Root />,
document.getElementById('root')
);
49 changes: 49 additions & 0 deletions examples/async/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
{
"name": "redux-async-example",
"version": "0.0.0",
"description": "Redux async example",
"main": "server.js",
"scripts": {
"start": "node server.js"
},
"repository": {
"type": "git",
"url": "https://github.com/gaearon/redux.git"
},
"keywords": [
"react",
"reactjs",
"hot",
"reload",
"hmr",
"live",
"edit",
"webpack",
"flux"
],
"license": "MIT",
"bugs": {
"url": "https://github.com/gaearon/redux/issues"
},
"homepage": "https://github.com/gaearon/redux#readme",
"dependencies": {
"isomorphic-fetch": "^2.1.1",
"react": "^0.13.3",
"react-redux": "^0.8.0",
"redux": "^1.0.0-rc",
"redux-logger": "0.0.3",
"redux-thunk": "^0.1.0"
},
"devDependencies": {
"babel-core": "^5.6.18",
"babel-loader": "^5.1.4",
"expect": "^1.6.0",
"jsdom": "^5.6.1",
"mocha": "^2.2.5",
"mocha-jsdom": "^1.0.0",
"node-libs-browser": "^0.5.2",
"react-hot-loader": "^1.2.8",
"webpack": "^1.9.11",
"webpack-dev-server": "^1.9.0"
}
}
Loading