Add copy text on contex menu. #1541

Merged
dan1d merged 1 commit from 1538 into master 2018-06-04 22:31:36 +02:00
4 changed files with 40 additions and 34 deletions

View file

@ -7,6 +7,7 @@ import ReactModal from 'react-modal';
import throttle from 'util/throttle'; import throttle from 'util/throttle';
import SideBar from 'component/sideBar'; import SideBar from 'component/sideBar';
import Header from 'component/header'; import Header from 'component/header';
import { openContextMenu } from '../../util/contextMenu';
type Props = { type Props = {
alertError: (string | {}) => void, alertError: (string | {}) => void,
@ -79,7 +80,7 @@ class App extends React.PureComponent<Props> {
render() { render() {
return ( return (
<div id="window"> <div id="window" onContextMenu={e => openContextMenu(e)}>
<Theme /> <Theme />
<main className="page"> <main className="page">
<SideBar /> <SideBar />

View file

@ -62,6 +62,8 @@ class FileCard extends React.PureComponent<Props> {
const shouldObscureNsfw = obscureNsfw && metadata && metadata.nsfw; const shouldObscureNsfw = obscureNsfw && metadata && metadata.nsfw;
const isRewardContent = claim && rewardedContentClaimIds.includes(claim.claim_id); const isRewardContent = claim && rewardedContentClaimIds.includes(claim.claim_id);
const handleContextMenu = event => { const handleContextMenu = event => {
event.preventDefault();
event.stopPropagation();
openCopyLinkMenu(convertToShareLink(uri), event); openCopyLinkMenu(convertToShareLink(uri), event);
}; };

View file

@ -17,7 +17,6 @@ import store from 'store';
import app from './app'; import app from './app';
import analytics from './analytics'; import analytics from './analytics';
import doLogWarningConsoleMessage from './logWarningConsoleMessage'; import doLogWarningConsoleMessage from './logWarningConsoleMessage';
import { initContextMenu } from './util/contextMenu';
const { autoUpdater } = remote.require('electron-updater'); const { autoUpdater } = remote.require('electron-updater');
const APPPAGEURL = 'lbry://?'; const APPPAGEURL = 'lbry://?';
@ -113,8 +112,6 @@ document.addEventListener('click', event => {
} }
}); });
document.addEventListener('contextmenu', initContextMenu);
const init = () => { const init = () => {
autoUpdater.on('update-downloaded', () => { autoUpdater.on('update-downloaded', () => {
app.store.dispatch(doAutoUpdate()); app.store.dispatch(doAutoUpdate());
@ -149,7 +146,7 @@ const init = () => {
ReactDOM.render( ReactDOM.render(
<Provider store={store}> <Provider store={store}>
<div> <div>
<App onContextMenu={e => openContextMenu(e)} /> <App />
<SnackBar /> <SnackBar />
</div> </div>
</Provider>, </Provider>,

View file

@ -21,26 +21,41 @@ function injectDevelopmentTemplate(event, templates) {
return templates; return templates;
} }
export function openContextMenu(event, templates = [], addDefaultTemplates = true) { export function openContextMenu(event, templates = []) {
if (addDefaultTemplates) { const isSomethingSelected = window.getSelection().toString().length > 0;
const { value } = event.target; const { type } = event.target;
const inputTemplates = [ const isInput = event.target.matches('input') && (type === 'text' || type === 'number');
{ label: 'Cut', accelerator: 'CmdOrCtrl+X', role: 'cut' }, const { value } = event.target;
{ label: 'Copy', accelerator: 'CmdOrCtrl+C', role: 'copy' },
{ templates.push({
label: 'Paste', label: 'Copy',
accelerator: 'CmdOrCtrl+V', accelerator: 'CmdOrCtrl+C',
role: 'paste', role: 'copy',
enabled: clipboard.readText().length > 0, enabled: isSomethingSelected,
}, });
{
label: 'Select All', // If context menu is opened on Input and there is text on the input and something is selected.
accelerator: 'CmdOrCtrl+A', const { selectionStart, selectionEnd } = event.target;
role: 'selectall', if (!!value && isInput && selectionStart !== selectionEnd) {
enabled: !!value, templates.push({ label: 'Cut', accelerator: 'CmdOrCtrl+X', role: 'cut' });
}, }
];
templates.push(...inputTemplates); // If context menu is opened on Input and text is present on clipboard
if (clipboard.readText().length > 0 && isInput) {
templates.push({
label: 'Paste',
accelerator: 'CmdOrCtrl+V',
role: 'paste',
});
}
// If context menu is opened on Input
if (isInput && value) {
templates.push({
label: 'Select All',
accelerator: 'CmdOrCtrl+A',
role: 'selectall',
});
} }
injectDevelopmentTemplate(event, templates); injectDevelopmentTemplate(event, templates);
@ -57,12 +72,3 @@ export function openCopyLinkMenu(text, event) {
]; ];
openContextMenu(event, templates, false); openContextMenu(event, templates, false);
} }
export function initContextMenu(event) {
const { type } = event.target;
if (event.target.matches('input') && (type === 'text' || type === 'number')) {
openContextMenu(event);
} else {
event.preventDefault();
}
}