* Replace browserify with webpack * Add react-intl-translations-manager * Do not minify in development, add offline-plugin for ServiceWorker background cache updates * Adjust tests and dependencies * Fix production deployments * Fix tests * More optimizations * Improve travis cache for npm stuff * Re-run travis * Add back support for custom.scss as before * Remove offline-plugin and babili * Fix issue with Immutable.List().unshift(...values) not working as expected * Make travis load schema instead of running all migrations in sequence * Fix missing React import in WarningContainer. Optimize rendering performance by using ImmutablePureComponent instead of React.PureComponent. ImmutablePureComponent uses Immutable.is() to compare props. Replace dynamic callback bindings in <UI /> * Add react definitions to places that use JSX * Add Procfile.dev for running rails, webpack and streaming API at the same time
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import api, { getLinks } from '../api'
 | |
| import { fetchRelationships } from './accounts';
 | |
| 
 | |
| export const BLOCKS_FETCH_REQUEST = 'BLOCKS_FETCH_REQUEST';
 | |
| export const BLOCKS_FETCH_SUCCESS = 'BLOCKS_FETCH_SUCCESS';
 | |
| export const BLOCKS_FETCH_FAIL    = 'BLOCKS_FETCH_FAIL';
 | |
| 
 | |
| export const BLOCKS_EXPAND_REQUEST = 'BLOCKS_EXPAND_REQUEST';
 | |
| export const BLOCKS_EXPAND_SUCCESS = 'BLOCKS_EXPAND_SUCCESS';
 | |
| export const BLOCKS_EXPAND_FAIL    = 'BLOCKS_EXPAND_FAIL';
 | |
| 
 | |
| export function fetchBlocks() {
 | |
|   return (dispatch, getState) => {
 | |
|     dispatch(fetchBlocksRequest());
 | |
| 
 | |
|     api(getState).get('/api/v1/blocks').then(response => {
 | |
|       const next = getLinks(response).refs.find(link => link.rel === 'next');
 | |
|       dispatch(fetchBlocksSuccess(response.data, next ? next.uri : null));
 | |
|       dispatch(fetchRelationships(response.data.map(item => item.id)));
 | |
|     }).catch(error => dispatch(fetchBlocksFail(error)));
 | |
|   };
 | |
| };
 | |
| 
 | |
| export function fetchBlocksRequest() {
 | |
|   return {
 | |
|     type: BLOCKS_FETCH_REQUEST
 | |
|   };
 | |
| };
 | |
| 
 | |
| export function fetchBlocksSuccess(accounts, next) {
 | |
|   return {
 | |
|     type: BLOCKS_FETCH_SUCCESS,
 | |
|     accounts,
 | |
|     next
 | |
|   };
 | |
| };
 | |
| 
 | |
| export function fetchBlocksFail(error) {
 | |
|   return {
 | |
|     type: BLOCKS_FETCH_FAIL,
 | |
|     error
 | |
|   };
 | |
| };
 | |
| 
 | |
| export function expandBlocks() {
 | |
|   return (dispatch, getState) => {
 | |
|     const url = getState().getIn(['user_lists', 'blocks', 'next']);
 | |
| 
 | |
|     if (url === null) {
 | |
|       return;
 | |
|     }
 | |
| 
 | |
|     dispatch(expandBlocksRequest());
 | |
| 
 | |
|     api(getState).get(url).then(response => {
 | |
|       const next = getLinks(response).refs.find(link => link.rel === 'next');
 | |
|       dispatch(expandBlocksSuccess(response.data, next ? next.uri : null));
 | |
|       dispatch(fetchRelationships(response.data.map(item => item.id)));
 | |
|     }).catch(error => dispatch(expandBlocksFail(error)));
 | |
|   };
 | |
| };
 | |
| 
 | |
| export function expandBlocksRequest() {
 | |
|   return {
 | |
|     type: BLOCKS_EXPAND_REQUEST
 | |
|   };
 | |
| };
 | |
| 
 | |
| export function expandBlocksSuccess(accounts, next) {
 | |
|   return {
 | |
|     type: BLOCKS_EXPAND_SUCCESS,
 | |
|     accounts,
 | |
|     next
 | |
|   };
 | |
| };
 | |
| 
 | |
| export function expandBlocksFail(error) {
 | |
|   return {
 | |
|     type: BLOCKS_EXPAND_FAIL,
 | |
|     error
 | |
|   };
 | |
| };
 |