2018-03-26 14:32:43 -07:00
|
|
|
// @flow
|
2018-10-29 13:23:53 -04:00
|
|
|
import * as MODALS from 'constants/modal_types';
|
2019-07-12 10:58:24 -04:00
|
|
|
import * as ACTIONS from 'constants/action_types';
|
2019-10-23 15:39:51 -04:00
|
|
|
import * as PAGES from 'constants/pages';
|
|
|
|
import { batchActions, doError, selectMyClaims, doPublish, doCheckPendingPublishes } from 'lbry-redux';
|
2019-07-12 22:59:45 -04:00
|
|
|
import { selectosNotificationsEnabled } from 'redux/selectors/settings';
|
|
|
|
import { push } from 'connected-react-router';
|
|
|
|
import analytics from 'analytics';
|
2019-12-02 12:30:08 -05:00
|
|
|
import { formatLbryUrlForWeb } from 'util/url';
|
2019-07-02 22:30:34 -04:00
|
|
|
import { doOpenModal } from './app';
|
2018-03-26 14:32:43 -07:00
|
|
|
|
2019-11-01 13:27:01 -04:00
|
|
|
export const doPublishDesktop = (filePath: string) => (dispatch: Dispatch, getState: () => {}) => {
|
2019-07-12 10:58:24 -04:00
|
|
|
const publishSuccess = successResponse => {
|
|
|
|
const state = getState();
|
2019-07-12 22:59:45 -04:00
|
|
|
const myClaims = selectMyClaims(state);
|
2019-04-24 10:02:08 -04:00
|
|
|
const pendingClaim = successResponse.outputs[0];
|
2019-10-16 17:36:50 -04:00
|
|
|
analytics.apiLogPublish(pendingClaim);
|
2019-10-11 21:55:54 -04:00
|
|
|
const { permanent_url: url } = pendingClaim;
|
2018-11-02 14:33:00 -04:00
|
|
|
const actions = [];
|
|
|
|
|
2019-11-13 10:59:34 -05:00
|
|
|
// @if TARGET='app'
|
2019-11-07 14:39:22 -05:00
|
|
|
actions.push(push(`/$/${PAGES.PUBLISHED}`));
|
2019-11-13 10:59:34 -05:00
|
|
|
// @endif
|
2019-11-07 14:39:22 -05:00
|
|
|
|
2018-11-02 14:33:00 -04:00
|
|
|
actions.push({
|
2018-04-06 02:00:36 -04:00
|
|
|
type: ACTIONS.PUBLISH_SUCCESS,
|
|
|
|
});
|
2018-11-02 14:33:00 -04:00
|
|
|
// We have to fake a temp claim until the new pending one is returned by claim_list_mine
|
|
|
|
// We can't rely on claim_list_mine because there might be some delay before the new claims are returned
|
|
|
|
// Doing this allows us to show the pending claim immediately, it will get overwritten by the real one
|
|
|
|
const isMatch = claim => claim.claim_id === pendingClaim.claim_id;
|
|
|
|
const isEdit = myClaims.some(isMatch);
|
2019-06-24 23:05:46 -05:00
|
|
|
|
2018-11-02 14:33:00 -04:00
|
|
|
const myNewClaims = isEdit
|
2019-04-24 10:02:08 -04:00
|
|
|
? myClaims.map(claim => (isMatch(claim) ? pendingClaim : claim))
|
|
|
|
: myClaims.concat(pendingClaim);
|
2019-11-13 10:59:34 -05:00
|
|
|
actions.push(
|
|
|
|
doOpenModal(MODALS.PUBLISH, {
|
|
|
|
uri: url,
|
|
|
|
isEdit,
|
|
|
|
filePath,
|
|
|
|
})
|
|
|
|
);
|
2018-11-02 14:33:00 -04:00
|
|
|
actions.push({
|
|
|
|
type: ACTIONS.FETCH_CLAIM_LIST_MINE_COMPLETED,
|
|
|
|
data: {
|
|
|
|
claims: myNewClaims,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
dispatch(batchActions(...actions));
|
2018-04-06 02:00:36 -04:00
|
|
|
};
|
2018-03-26 14:32:43 -07:00
|
|
|
|
2019-07-12 10:58:24 -04:00
|
|
|
const publishFail = error => {
|
|
|
|
const actions = [];
|
2019-11-13 10:59:34 -05:00
|
|
|
actions.push({
|
|
|
|
type: ACTIONS.PUBLISH_FAIL,
|
|
|
|
});
|
2019-07-12 10:58:24 -04:00
|
|
|
actions.push(doError(error.message));
|
|
|
|
dispatch(batchActions(...actions));
|
2018-03-26 14:32:43 -07:00
|
|
|
};
|
2019-07-09 02:02:08 -04:00
|
|
|
|
2019-11-13 10:59:34 -05:00
|
|
|
// Redirect on web immediately because we have a file upload progress componenet
|
|
|
|
// on the publishes page. This doesn't exist on desktop so wait until we get a response
|
|
|
|
// from the SDK
|
|
|
|
// @if TARGET='web'
|
2019-11-14 11:30:29 -05:00
|
|
|
dispatch(push(`/$/${PAGES.PUBLISHED}`));
|
2019-11-13 10:59:34 -05:00
|
|
|
// @endif
|
|
|
|
|
2019-10-23 15:39:51 -04:00
|
|
|
dispatch(doPublish(publishSuccess, publishFail));
|
2018-03-26 14:32:43 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
// Calls claim_list_mine until any pending publishes are confirmed
|
2019-07-12 22:59:45 -04:00
|
|
|
export const doCheckPendingPublishesApp = () => (dispatch: Dispatch, getState: GetState) => {
|
|
|
|
const onConfirmed = claim => {
|
|
|
|
if (selectosNotificationsEnabled(getState())) {
|
|
|
|
const notif = new window.Notification('LBRY Publish Complete', {
|
2019-10-03 17:40:54 -04:00
|
|
|
body: __('%nameOrTitle% has been published to lbry://%name%. Click here to view it.', {
|
|
|
|
nameOrTitle: claim.value_type === 'channel' ? `@${claim.name}` : claim.value.title,
|
|
|
|
name: claim.name,
|
|
|
|
}),
|
2019-07-12 22:59:45 -04:00
|
|
|
silent: false,
|
|
|
|
});
|
|
|
|
notif.onclick = () => {
|
2019-12-02 12:30:08 -05:00
|
|
|
dispatch(push(formatLbryUrlForWeb(claim.permanent_url)));
|
2019-07-12 22:59:45 -04:00
|
|
|
};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
return dispatch(doCheckPendingPublishes(onConfirmed));
|
|
|
|
};
|