import { camelCase } from 'lodash' import apiService from '../api/api.service.js' const update = ({store, statuses, timeline, showImmediately}) => { const ccTimeline = camelCase(timeline) store.commit('addNewStatuses', { timeline: ccTimeline, statuses, showImmediately }) // $ngRedux.dispatch({type: 'UPDATE_TIMESTAMPS'}); } const fetchAndUpdate = ({store, credentials, timeline = 'friends', older = false, showImmediately = false}) => { const args = { timeline, credentials } const timelineData = store.rootState.statuses.timelines[camelCase(timeline)] if (older) { args['until'] = timelineData.minVisibleId } else { args['since'] = timelineData.maxId } apiService.fetchTimeline(args) .then((statuses) => update({store, statuses, timeline, showImmediately})) } const startFetching = ({ timeline = 'friends', credentials, store }) => { fetchAndUpdate({timeline, credentials, store, showImmediately: true}) const boundFetchAndUpdate = () => fetchAndUpdate({ timeline, credentials, store }) setInterval(boundFetchAndUpdate, 10000) } const timelineFetcher = { startFetching } export default timelineFetcher // const timelineFetcherServiceFactory = ($ngRedux, apiService, $interval) => { // let fetcher; // const update = ({statuses, timeline, showImmediately}) => { // const ccTimeline = camelCase(timeline); // const action = { // type: 'ADD_NEW_STATUSES', // data: { // statuses, // timeline: ccTimeline, // showImmediately // } // }; // $ngRedux.dispatch(action); // $ngRedux.dispatch({type: 'UPDATE_TIMESTAMPS'}); // }; // const fetchAndUpdate = ({timeline = 'friends', older = false, showImmediately = false}) => { // const args = { timeline }; // const timelineData = $ngRedux.getState().statuses.timelines[camelCase(timeline)]; // if(older) { // args['until'] = timelineData.minVisibleId; // } else { // args['since'] = timelineData.maxId; // } // apiService.fetchTimeline(args). // then((statuses) => update({statuses, timeline, showImmediately})); // }; // const startFetching = ({timeline = 'friends'}) => { // fetchAndUpdate({timeline, showImmediately: true}); // const boundFetchAndUpdate = () => fetchAndUpdate({timeline}); // fetcher = $interval(boundFetchAndUpdate, 10000); // }; // const timelineFetcherService = { // startFetching, // fetchAndUpdate // }; // return timelineFetcherService; // }; // timelineFetcherServiceFactory.$inject = ['$ngRedux', 'apiService', '$interval']; // export default timelineFetcherServiceFactory;