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

Add on_keyup and value_input for code editor #6919

Merged
merged 16 commits into from
Aug 20, 2024
Merged

Conversation

ahuang11
Copy link
Contributor

Closes #5486

Although this is a breaking change, I think it's worth it because if you try to bind a callback that runs the code from value, it triggers on every keystroke... and as you might imagine, writing valid code often requires more than one character change.

import panel as pn

pn.extension()


def callback(value):
    exec(value)

code = pn.widgets.CodeEditor(value="import this")
pn.bind(callback, code.param.value, watch=True)
code.show()

Previously, removing one character would trigger this error:

image

The workaround to this before is having a separate pn.widgets.Button to submit the code, but now, users can simply watch value, or if they want to watch on every keystroke value_input

@ahuang11 ahuang11 requested a review from philippjfr June 13, 2024 19:43
@ahuang11 ahuang11 changed the title Add value_input for code editor Add value_input for code editor (breaking change) Jun 13, 2024
@MarcSkovMadsen
Copy link
Collaborator

Why not have a value_throttled instead?

@ahuang11
Copy link
Contributor Author

ahuang11 commented Jun 13, 2024

value_input is what other Bokeh text widgets use:
https://panel.holoviz.org/reference/widgets/TextInput.html
https://panel.holoviz.org/reference/widgets/TextAreaInput.html

I see that sliders use value_throttled.

Copy link

codecov bot commented Jun 13, 2024

Codecov Report

Attention: Patch coverage is 52.05479% with 35 lines in your changes missing coverage. Please review.

Project coverage is 81.75%. Comparing base (7c90f7b) to head (c627038).
Report is 67 commits behind head on main.

Files Patch % Lines
panel/tests/ui/widgets/test_codeeditor.py 37.50% 35 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #6919      +/-   ##
==========================================
- Coverage   81.79%   81.75%   -0.04%     
==========================================
  Files         326      327       +1     
  Lines       48350    48421      +71     
==========================================
+ Hits        39546    39587      +41     
- Misses       8804     8834      +30     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

panel/models/ace.ts Outdated Show resolved Hide resolved
@philippjfr
Copy link
Member

This does end up being a fairly major change in behavior. I agree with it but still.

@hoxbro
Copy link
Member

hoxbro commented Jun 28, 2024

Is there a way to have a flag that reverts back to the old version to smooth the transition?

@ahuang11
Copy link
Contributor Author

ahuang11 commented Jun 28, 2024

Or maybe it'd make sense to keep the current behavior with a flag that toggles the new behavior.

@ahuang11 ahuang11 changed the title Add value_input for code editor (breaking change) Add on_keyup and value_input for code editor Jun 28, 2024
@ahuang11
Copy link
Contributor Author

Is there a way to have a flag that reverts back to the old version to smooth the transition?

I think this is a good suggestion to prevent breaking changes so I have implemented a flag that de-syncs value from value_input, i.e. update value only on loss of focus / command hotkey.

@ahuang11
Copy link
Contributor Author

ahuang11 commented Jun 28, 2024

Test failure seems unrelated

timeout waiting for merge ref

Oh might be https://www.githubstatus.com/

@ahuang11 ahuang11 requested a review from philippjfr July 1, 2024 19:58
@ahuang11 ahuang11 added this to the v1.5.0 milestone Aug 15, 2024
@philippjfr philippjfr merged commit 43f19c0 into main Aug 20, 2024
14 of 15 checks passed
@philippjfr philippjfr deleted the code_editor_value_input branch August 20, 2024 16:27
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

Successfully merging this pull request may close these issues.

CodeEditor changes acts like value_input instead of value
4 participants