Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Handling exceptions for writeText() #565

Open
ejiektpobehuk opened this issue Sep 10, 2024 · 0 comments
Open

Handling exceptions for writeText() #565

ejiektpobehuk opened this issue Sep 10, 2024 · 0 comments

Comments

@ejiektpobehuk
Copy link

I'm unable to handle exception while a coping text to a clipboard idiomatically. Maybe it's not the only place for such behavior but it's the only one I've found.

I'm using qutebrowser and I've blocked programmatic access to a clipboard for websites.
Unfortunately, I don't know how to block access the same way for other browses =\

Use case: I want to show a notification that user has successfully copied text to the clipboard or if there is an error. To do so I have to handle exception that writeText() might throw.

I expect the following code to work:

<script src="https://unpkg.com/[email protected]"></script>

<button
  _="on click
       writeText('text to copy') into the navigator's clipboard
       then put 'Success' into the next <output/>
     catch e
       put `Error: $e` into the next <output/>">
    Copy
</button>
<output>--</output>

Output shows Success and console logs Uncaught (in promise) DOMException: Write permission denied.. catch doesn't seem to work.

There is another way to catch exceptions for an element (on exception):

<script src="https://unpkg.com/[email protected]"></script>

<button
  _="on click
       writeText('text to copy') into the navigator's clipboard
       then put 'Success' into the next <output/>
     on exception(e)
       put `Error: $e` into the next <output/>">
    Copy
</button>
<output>--</output>

The same result: output shows Success and console logs Uncaught (in promise) DOMException: Write permission denied..

Feels like exception isn't related to the element in any way.

Sanity check

Just to make sure that exceptions are catchable:

<script src="https://unpkg.com/[email protected]"></script>

<button
  _="on click
       throw 'I am thrown manually'
       then put 'Success' into the next <output/>
     catch e
       put `Error: $e` into the next <output/>">
    Copy
</button>
<output>--</output>

Shows Error: I am thrown manually in output and console is clean.

<script src="https://unpkg.com/[email protected]"></script>

<button
  _="on click
       throw 'I am thrown manually'
       then put 'Success' into the next <output/>
     on exception(e)
       put `Error: $e` into the next <output/>">
    Copy
</button>
<output>--</output>

This one is interesting. It shows Error: in output and picrelated in console

image

Workaround

I've managed to get it working by calling writeText() in a more traditional way:

<script src="https://unpkg.com/[email protected]"></script>

<button
  _="on click
       call navigator.clipboard.writeText('text to copy')
       then put 'Success' into the next <output/>
     catch e
       put `Error: $e` into the next <output/>">
    Copy
</button>
<output>--</output>

Output has Error: NotAllowedError: Write permission denied. and a clean console.

<script src="https://unpkg.com/[email protected]"></script>

<button
  _="on click
       call navigator.clipboard.writeText('text to copy')
       then put 'Success' into the next <output/>
     on exception(e)
       put `Error: $e` into the next <output/>">
    Copy
</button>
<output>--</output>

This one behaves the same way it does in sanity check. In catches the exception but error is empty while console has the following:

image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant