fix(copyText): in iframe for chrome<85

This commit is contained in:
Hristo Terezov 2021-03-03 15:04:00 -06:00 committed by Дамян Минков
parent 62c06441b1
commit a2e2d31dfd
4 changed files with 45 additions and 24 deletions

View File

@ -49,9 +49,12 @@ function CopyButton({ className, displayedText, textToCopy, textOnHover, textOnC
* *
* @returns {void} * @returns {void}
*/ */
function onClick() { async function onClick() {
setIsHovered(false); setIsHovered(false);
if (copyText(textToCopy)) {
const isCopied = await copyText(textToCopy);
if (isCopied) {
setIsClicked(true); setIsClicked(true);
setTimeout(() => { setTimeout(() => {

View File

@ -7,7 +7,6 @@ import { translate } from '../../../i18n';
import { Icon, IconCopy, IconCheck } from '../../../icons'; import { Icon, IconCopy, IconCheck } from '../../../icons';
import { connect } from '../../../redux'; import { connect } from '../../../redux';
import { copyText, getDecodedURI } from '../../../util'; import { copyText, getDecodedURI } from '../../../util';
import logger from '../../logger';
type Props = { type Props = {
@ -75,8 +74,8 @@ class CopyMeetingUrl extends Component<Props, State> {
* *
* @returns {void} * @returns {void}
*/ */
_copyUrl() { async _copyUrl() {
const success = copyText(this.props.url); const success = await copyText(this.props.url);
if (success) { if (success) {
this._showLinkCopied(); this._showLinkCopied();
@ -152,15 +151,13 @@ class CopyMeetingUrl extends Component<Props, State> {
* @private * @private
* @returns {void} * @returns {void}
*/ */
_copyUrlAutomatically() { async _copyUrlAutomatically() {
navigator.clipboard.writeText(this.props.url) const isCopied = await copyText(this.props.url);
.then(() => {
this._showLinkCopied(); if (isCopied) {
window.setTimeout(this._hideLinkCopied, COPY_TIMEOUT); this._showLinkCopied();
}) window.setTimeout(this._hideLinkCopied, COPY_TIMEOUT);
.catch(e => { }
logger.error(e);
});
} }
/** /**

View File

@ -29,18 +29,36 @@ export function assignIfDefined(target: Object, source: Object) {
* Returns true if the action succeeds. * Returns true if the action succeeds.
* *
* @param {string} textToCopy - Text to be copied. * @param {string} textToCopy - Text to be copied.
* @returns {boolean} * @returns {Promise<boolean>}
*/ */
export async function copyText(textToCopy: string) { export async function copyText(textToCopy: string) {
let result;
try { try {
result = await navigator.clipboard.writeText(textToCopy); await navigator.clipboard.writeText(textToCopy);
} catch (err) {
result = false;
}
return result; return true;
} catch (clipboardAPIError) { // The Clipboard API is not supported.
let fakeTextArea = document.createElement('textarea');
// $FlowFixMe
fakeTextArea = document.body.appendChild(fakeTextArea);
fakeTextArea.value = textToCopy;
fakeTextArea.focus();
fakeTextArea.select();
let result;
try {
result = document.execCommand('copy');
} catch (error) {
result = false;
}
// $FlowFixMe
document.body.removeChild(fakeTextArea);
return result;
}
} }
/** /**

View File

@ -34,9 +34,12 @@ function LiveStreamSection({ liveStreamViewURL, t }: Props) {
* *
* @returns {void} * @returns {void}
*/ */
function onClick() { async function onClick() {
setIsHovered(false); setIsHovered(false);
if (copyText(liveStreamViewURL)) {
const isCopied = copyText(liveStreamViewURL);
if (isCopied) {
setIsClicked(true); setIsClicked(true);
setTimeout(() => { setTimeout(() => {