2017-12-21 14:32:51 -03:00
|
|
|
import * as ACTIONS from 'constants/action_types';
|
2019-03-04 23:46:57 -05:00
|
|
|
// @if TARGET='app'
|
2017-12-27 20:48:11 -03:00
|
|
|
import { shell } from 'electron';
|
2019-03-04 23:46:57 -05:00
|
|
|
// @endif
|
2020-07-22 18:39:24 -04:00
|
|
|
import {
|
|
|
|
Lbry,
|
|
|
|
batchActions,
|
|
|
|
doAbandonClaim,
|
|
|
|
makeSelectFileInfoForUri,
|
|
|
|
makeSelectClaimForUri,
|
|
|
|
ABANDON_STATES,
|
|
|
|
} from 'lbry-redux';
|
2018-10-29 13:23:53 -04:00
|
|
|
import { doHideModal } from 'redux/actions/app';
|
2019-04-19 12:55:21 -04:00
|
|
|
import { goBack } from 'connected-react-router';
|
2019-08-13 23:56:11 -04:00
|
|
|
import { doSetPlayingUri } from 'redux/actions/content';
|
2019-08-14 22:50:41 -04:00
|
|
|
import { selectPlayingUri } from 'redux/selectors/content';
|
2017-04-28 22:14:44 +07:00
|
|
|
|
2017-12-21 14:32:51 -03:00
|
|
|
export function doOpenFileInFolder(path) {
|
2017-12-27 20:48:11 -03:00
|
|
|
return () => {
|
2017-12-21 14:32:51 -03:00
|
|
|
shell.showItemInFolder(path);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2017-09-20 08:47:08 -04:00
|
|
|
export function doOpenFileInShell(path) {
|
2017-12-27 20:48:11 -03:00
|
|
|
return dispatch => {
|
2017-09-20 08:47:08 -04:00
|
|
|
const success = shell.openItem(path);
|
2017-08-06 19:18:38 -04:00
|
|
|
if (!success) {
|
2017-09-20 08:47:08 -04:00
|
|
|
dispatch(doOpenFileInFolder(path));
|
2017-08-06 19:18:38 -04:00
|
|
|
}
|
2017-06-06 17:19:12 -04:00
|
|
|
};
|
2017-04-30 00:02:25 +07:00
|
|
|
}
|
|
|
|
|
2020-07-22 18:39:24 -04:00
|
|
|
export function doDeleteFile(outpoint, deleteFromComputer, abandonClaim, cb) {
|
2020-07-22 14:22:32 -04:00
|
|
|
return dispatch => {
|
|
|
|
if (abandonClaim) {
|
2019-05-10 02:27:51 -04:00
|
|
|
const [txid, nout] = outpoint.split(':');
|
2020-07-22 18:39:24 -04:00
|
|
|
dispatch(doAbandonClaim(txid, Number(nout), cb));
|
2017-06-29 14:44:34 +07:00
|
|
|
}
|
2020-07-22 14:22:32 -04:00
|
|
|
|
2020-03-27 12:49:41 -04:00
|
|
|
// @if TARGET='app'
|
2020-04-27 18:22:09 -04:00
|
|
|
Lbry.file_delete({
|
|
|
|
outpoint,
|
|
|
|
delete_from_download_dir: deleteFromComputer,
|
|
|
|
});
|
2020-07-22 14:22:32 -04:00
|
|
|
|
2017-04-30 00:02:25 +07:00
|
|
|
dispatch({
|
2017-12-21 14:32:51 -03:00
|
|
|
type: ACTIONS.FILE_DELETE,
|
2017-04-30 00:02:25 +07:00
|
|
|
data: {
|
2017-06-06 17:19:12 -04:00
|
|
|
outpoint,
|
|
|
|
},
|
|
|
|
});
|
2020-03-27 12:49:41 -04:00
|
|
|
// @endif
|
2017-07-21 15:13:45 +07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-08-14 22:50:41 -04:00
|
|
|
export function doDeleteFileAndMaybeGoBack(uri, deleteFromComputer, abandonClaim) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const state = getState();
|
|
|
|
const playingUri = selectPlayingUri(state);
|
2019-08-15 07:36:03 -04:00
|
|
|
const { outpoint } = makeSelectFileInfoForUri(uri)(state) || '';
|
2019-10-01 09:44:37 -04:00
|
|
|
const { nout, txid } = makeSelectClaimForUri(uri)(state);
|
|
|
|
const claimOutpoint = `${txid}:${nout}`;
|
2017-07-21 15:13:45 +07:00
|
|
|
const actions = [];
|
2020-07-22 18:39:24 -04:00
|
|
|
|
|
|
|
if (!abandonClaim) {
|
|
|
|
actions.push(doHideModal());
|
|
|
|
}
|
|
|
|
|
|
|
|
actions.push(
|
|
|
|
doDeleteFile(outpoint || claimOutpoint, deleteFromComputer, abandonClaim, abandonState => {
|
|
|
|
if (abandonState === ABANDON_STATES.DONE) {
|
|
|
|
if (abandonClaim) {
|
|
|
|
dispatch(goBack());
|
|
|
|
dispatch(doHideModal());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
);
|
2019-08-14 22:50:41 -04:00
|
|
|
|
|
|
|
if (playingUri === uri) {
|
|
|
|
actions.push(doSetPlayingUri(null));
|
|
|
|
}
|
2019-08-30 10:01:39 -04:00
|
|
|
// it would be nice to stay on the claim if you just want to delete it
|
|
|
|
// we need to alter autoplay to not start downloading again after you delete it
|
2019-08-14 22:50:41 -04:00
|
|
|
|
|
|
|
dispatch(batchActions(...actions));
|
2017-06-06 17:19:12 -04:00
|
|
|
};
|
2017-04-30 23:01:43 +07:00
|
|
|
}
|