mirror of
https://github.com/gradio-app/gradio.git
synced 2025-01-12 10:34:32 +08:00
287fe67828
* squash commit * BugFix: Make FileExplorer Component Templateable (#5933) * Make FileExplorer templateable * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix notebooks (#5935) * V4: Update Component pyi file (#5937) * Add code * add changeset * delete --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * V4: Use beta release versions for '@gradio' packages (#5938) * Fix versions * add changeset * fix * add changeset * fix * add changeset * Fix * fix preview * add changeset * final fix * add changeset * fix * add changeset * fix * add changeset * revert change --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * maybe fix (#5946) * Merge main again (#5948) * maybe fix * fix * Merge main again (#5949) * maybe fix * fix * weird weird weird * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Merge main again (#5950) * maybe fix * fix * weird weird weird * fix * log * log * fix changesets * rererefactor frontend files (#5960) * do all the things * add changeset * remove codemod * fix * change casing * condense upload button --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Strip vite import warning (#5962) * Add code * Remove comment * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5769) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * release wasm (#5963) * release wasm * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Wasm release (#5964) * release wasm * release wasm * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5965) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Add json schema unit tests (#5970) * Add tests * add changeset * Fix tests * api-info * Add test * Add test * Add email tests * 3.8 fix 🙄 --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * V4: Simple textbox (#5990) * Simple textbox * add changeset * Trim down events * Trim * Clean up change event * Add comment --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * File upload optimization (#5961) * Use custom multipart parser * add changeset * remove print * Add comment * Lint * fix code * remove print --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Removes deprecated arguments and parameters from v4 (#5968) * Removes deprecated arguments and methods for v4 * remove update * style * add changeset * added params * typign * fixed all of the typing * tests * fix layouts * layout * fix config * fix * fix form * fix * fix blocks tests * fix some more tests * lint * fix test routes * doc * notebooks * remove doc * format * format * remove group * label docstring * remov test --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * V4: Simple dropdown (#5996) * Add code * lint * comment * add changeset * revert * Fix update + docstring cleanup * Add code --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * pass props to example components and to example outputs (#6014) * pass props to example components and to example outputs * add changeset * make util less egenric/ more useful * fix demo * fix demo * fix * fix test * Fix test --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> * Format js in v4 branch (#6016) * Format v4 branch js * add changeset * lint --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * V4: Fix component update bug (#6027) * Fix tests + bugs * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * lockfile update * Fixing test * fix test * Add a cli command to list available templates (#6018) * Add code * dataset * Add test * add changeset * add changeset * add changeset * add changeset * Exclude FormComponent * Paginate the output * No colors but emojis: --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * fix tests (#6046) * fix storybook (#6065) * fix storybook * add changeset * fix * add changeset * fix * fix * fix components * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * remove dupe component (#6067) * remove dupe component * add changeset * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Simplify File Component (#6044) * Add code * Add code * Add code * Reuse code UploadButton * Use two files for UploadButton * Address feedback * Lint * add changeset * Update js/uploadbutton/shared/UploadButton.svelte Co-authored-by: pngwn <hello@pngwn.io> --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: pngwn <hello@pngwn.io> * Clean up backend of `File` and `UploadButton` and change the return type of `preprocess()` from TemporaryFIle to string filepath (#6060) * changes * add changeset * upload button * file * add changeset * valid types * fix tests * address review --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix Dropdown Example component and example processing logic (#6075) * fix examples * helpers * dropdown * fix cc build (#6079) * fix cc build * add changeset * throw error if build fails * fix entry points * add changeset * fix lockfile * Add test * update workflow * try resolve * lint 🙄 * Use xfail --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> * Fixes markdown rendering in examples (#6071) * Fixes markdown rendering in examples * add changeset * update delimiters * format * format * docstrings * test --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Proposal: sample demo for custom components should be a `gr.Interface` (#6077) * update sample demo to interface * add changeset * modify * Update gradio/cli/commands/components/_create_utils.py Co-authored-by: Freddy Boulton <alfonsoboulton@gmail.com> * added layout and static * fix * refine --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Freddy Boulton <alfonsoboulton@gmail.com> * WIP: Fix docs (#6082) * Website fix * add changeset * Fix code * pin version * Add code * skip code --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Pending events behavior (#5826) * enter changesets pre-release mode * release first version (#5500) * release packages * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * fix changeset (#5502) * add changeset * release first version * Custom components (#5507) * Add flag * Copy front-end * Add backend code * Remove breakpoint * Fix init * Add code * File reorg * Fix types * Upload files * Fix code * Custom components * Add code * Client changes * More changes * Add code * Add code * Fix reversion * build hook integration * Add code * rm file * Add code * rename cli * Add code * Nicer cli * Add display class * Add backend devmide * Add code? * Add code * Add paths and fix reload mdoe * Fix .then * changes * fix * fix * changes * changes * changes * Fix versions * Fix wheel build from source * Add code * Get no template case working * Cc fe (#5509) * tweaks * fix 18n * fix 18n * tweaks * Change name --------- Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> * Do not use live display for dev mode * Clean up front-end server print statements a little bit * Fix success event * Cc fe 2 (#5526) * tweaks * fix examples * fix backend port * fix things * fix * Fix json component flagging * fix * fuix --------- Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> * Fix template (#5533) * Fix type hint (#5536) * fix custom components when installed from wheel (#5552) * Fix all demos custom components (#5555) * Fix all_demos * Fix issues * trigger ci * add changeset * Fix merge * lockfile * Add code * add code * Fix command * Add code * Fix highlighted text * fix interactive highlighted text * tweak ci * Disable example caching for load right now --------- Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * image fixes (#5589) * Add flag * Copy front-end * Add backend code * Remove breakpoint * Fix init * Add code * File reorg * Fix types * Upload files * Fix code * Custom components * Add code * Client changes * More changes * Add code * Add code * Fix reversion * build hook integration * Add code * rm file * Add code * rename cli * Add code * Nicer cli * Add display class * Add backend devmide * Add code? * Add code * Add paths and fix reload mdoe * Fix .then * changes * fix * fix * changes * changes * changes * Fix versions * Fix wheel build from source * Add code * Get no template case working * Cc fe (#5509) * tweaks * fix 18n * fix 18n * tweaks * Change name --------- Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> * Do not use live display for dev mode * Clean up front-end server print statements a little bit * Fix success event * Cc fe 2 (#5526) * tweaks * fix examples * fix backend port * fix things * fix * Fix json component flagging * fix * fuix --------- Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> * Fix template (#5533) * Fix type hint (#5536) * fix custom components when installed from wheel (#5552) * Fix all demos custom components (#5555) * Fix all_demos * Fix issues * trigger ci * add changeset * Fix merge * lockfile * Add code * add code * Fix command * Add code * Fix highlighted text * fix interactive highlighted text * tweak ci * fix image uploads * add changeset * remove changeset * add changeset --------- Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Support Literal Typehints (#5591) * Fix updateable * Deploy for failing actions * fix enum * Add code * remove gradio lite from publish ci * fix * fix * chore: update versions (beta) (#5501) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Fix js deps in cli and add gradio-preview artifacts to build (#5610) * Fix js dependencies in cli * Add preview to build command * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5612) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * backend linting (#5613) * backend linting * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Publish js theme (#5615) * Publish js theme * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5614) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Add code (#5617) * Add docstring to trigger release (#5618) * Add docstring * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5619) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * fix build and broken imports (#5620) * fix broken import * fix build scripts * add changeset * Update js/statustracker/static/index.svelte --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5621) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Fix esbuild (#5624) * fix build * fix build * add changeset * fix build * fix --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5626) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Fix esbuild (#5629) * fix build * fix build * add changeset * fix build * fix * asd * more fix --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * asd (#5630) * chore: update versions (beta) (#5631) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Some minor v4 fixes (#5637) * Add code * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Publish all components to npm (#5648) * Publish image component * publish components * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5638) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Fix front-end imports + other misc fixes (#5649) * Fix console error * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Add overwrite flag to create command (#5651) * Add overwrite flag to create command * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5650) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Make layout components templateable (#5665) * Split out layouts * Refactor cli * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Patch fixes (#5678) * Handle lowercase template name frontend * Lint * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix build and file route (#5680) * Add code * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5662) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * V4 fix typing (#5686) * Add examples for series and parallel * v4 fix typing * add changeset * Fix * Fix * Fix 3.8 * Fix typing 3.8 * Lint * Add code * Add key * Fix typing * Add code * Fix deps * Fix fastapi * Fix version ' : --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Use overrides (#5695) * Use overrides * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * ensure client is copied along with components (#5709) * ensure client is copied along with components * add changeset * add changeset * chore: update versions (beta) (#5688) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * fix build config (#5710) * Fix python unit tests for v4 (#5715) * Add code * Fix tests * Add ci * Add code * fix test_blocks * More fixes * Last changes * add changeset * Add code * Continue for the sake of some green ci * Proper api info --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Better test dir check (#5719) * FIx test-dir check * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Use path to npm executable in subprocess (#5736) * Use path to npm in subprocess * Fix dev mode too * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Add Error + test (#5738) * Add Error + test * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix component regex (#5739) * Add code * Fix component regex * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix layout templates (#5740) * Fix templates * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix template remaining components (#5743) * add code * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * --overwrite deletes previous content (#5744) * Add code * Add code * add changeset * Add test --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Support call method (#5751) * Support call method * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix windows ci build (#5752) * Try bash * Use cross-env * Trigger CI * Fix comma * add changeset * Modify lock file * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix windows paths (#5745) * Use posix path * add changeset * add changeset * Try normalize * to_posix v2 * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * chore: update versions (beta) (#5717) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * Simplify how files are handled in components in 4.0 (#5768) * Client and upload route hash files * Refactor logic * add changeset * Add code * View API fix * Fix client tests * Dumb windows fix --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix deployed demos on v4 branch (#5770) * Template fixes * add changeset * add changeset * Fix streaming audio * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Name Endpoints if api_name is None (#5782) * Implementation and test * add changeset * fix lint * Fix nits --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * pending events * add changeset * Set api=False for cancel events (#5851) * Set api=False for cancel events * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * V4: Set cache dir for some component tests (#5852) * Add code * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * V4: Use async version of shutil in upload route (#5853) * Use async shutil copy * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * trigger_mode * changes * undo * undo * add changeset * undo * add changeset * image undo * add changeset * fix merge errors * remove prints * change * fix * fix error * change * quick fix * trigger_mode param * type * value error --------- Co-authored-by: pngwn <hello@pngwn.io> Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * Fixes: slider bar are too thin on FireFox (#5984) * firefox slider fix * add changeset * fix --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * Fix remaining xfail tests in backend (#6073) * Add code' * Add code * Add code * Fix dataset * add changeset * Add some comments * Add recover_kwargs * Remove from docstring * Audio-to-audio --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix dev mode model3D (#5955) * Fix dev mode * Lint * add changeset * Fix dev mode * Lint * remove console.log * add changeset * interactive fix * Fix tests --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Dawood <dawoodkhan82@gmail.com> * V4: Single-file implementation of form components (#6026) * Checkbox and number * Number, Checkboxgroup, Radio, and Slider * Format * remove range * Refactor checkbox * Forgot to add * Refactor * Lint * add changeset * use rich emoji markup * Fix ts --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Update logos for v4 (#6089) * update v4 logo * add changeset * size * fix on website * fix on demos * add changeset * favicon for demos * margin on footer logo * margin bottom to footer logo --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> * Add a stand-alone install command and tidy-up the fallback template (#6092) * Add code * add changeset * Add test * Make install default * Better error message --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * V4: Fix constructor_args (#6093) * Fix * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix: Move to cache in init postprocess + Fallback Fixes (#6107) * Add code and test * restore * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * fix build (#6112) * fix build * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Update cold-lemons-roll.md * Revert "Update cold-lemons-roll.md" (#6113) This reverts commit20dbf90811
. * Try to trigger a major beta release (#6114) * pyproject fix * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Delete bad changelog (#6115) * Delete bad changelog * Revert "Delete bad changelog" This reverts commita8ca614eaf
. * Delete bad * formatting * Revert "formatting" This reverts commit94f43859e7
. * Improve Audio Component (#5966) * replace <audio> with wavesurfer: add recording, playing and trimming, playback * add changeset * merge cleanup * improving recording styling * add recording timer * add trim region duration * allow trimming recordings * clean up playing logic * add pause_recording event * remove crop min/max * add waveform options param * remove trimmingmode and use mode * streaming + cleanup * add changeset * clean up types * mobile adjustments * add min/max length + trim accessibility * update pnpm lock * amend source to a list and allow source switching * fix no microphone found logic * change undo logic to reset trims * tweaks * tweak reset logic * ensure recording is sent to backend * fix audio duration reactivity * list tweak * clean up * change source -> sources + restore wasm changes * formatting * fix tests * fix test * add default sources value in fe + fix audio demos * fix audio file name test * add better sources typing * ui test tweaks * add default value in templates.py * formatting * remove unused prop * add audio story * add changeset * revert sources changes * remove story id * fix be test * fix be test * fix notebooks * formatting * fix test * fix test again --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Abubakar Abid <abubakar@huggingface.co> Co-authored-by: pngwn <hello@pngwn.io> * Fix changesets 2 (#6116) * fix changesets * release major * Fix changesets 2 (#6117) * fix changesets * release major * asd * fix version * chore: update versions (beta) (#5973) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * v4 * Open source FRP server and allow `gradio` to connect to custom share servers (#6091) * add param * add support for custom address * add changeset * share guide * guide * add params * add changeset * fix launch * add test --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Gradio custom component publish (#6098) * Add code * add changeset * F-string * Add pwd * Add source to space * Add template * Twine import * add changeset * ignore * restore * add changeset * Address feedback * Update gradio/cli/commands/components/publish.py Co-authored-by: Abubakar Abid <abubakar@huggingface.co> --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * Fix static issues with Lite on v4 (#6124) * fix missing props * fix path to types * add changeset * fix path to i18n * fix audio tests * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Ali Abid <aabid94@gmail.com> * Refactor `Blocks.load()` so that it is in the same style as the other listeners (#6126) * restore decorator * remove * refactor load * remove restriction * add changeset * add pyi * add test * add test * fix tests * metaclass * future * reduce' * docstring --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Small change to make `api_open=False` by default (#6138) * set api_open to False by default * add changeset * tests --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Image v4 (#6094) * simplify image interface * changes * asd * asd * more * add code (#6095) * more * fix tests * add changeset * fix client build * fix linting * fix test * lint * Fix tests + lint * asd * finish * webcam selection * fix backend * address comments * fix static checks * fix everything * add changeset * Apply suggestions from code review Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * fix examples * fix tests * fix tests --------- Co-authored-by: Freddy Boulton <alfonsoboulton@gmail.com> Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * Fix fallback demo app template code (#6129) * Add test * add changeset * Add JSON note * Fix test * Update gradio/cli/commands/components/_create_utils.py * Update test/test_gradio_component_cli.py --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * fix video path * Revert "fix video path" This reverts commit5916b3dc8a
. * Fix selectable prop in the backend (#6135) * Add to init * Fix events * add changeset * Add code * add changeset * Fix typo * Add code * Fix highlighted text typo * remove from docs --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix video (#6140) * fix video * add changeset * fixes * fixes * lint --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * fix some tests on mac * fix circular dependency with client + upload (#6143) * fix circular dependency * add changeset * fix test --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix image double change bug (#6146) * fix test * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * make lite private (#6147) * make lite private * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * fix dropdown arrow size (#6148) * fix dropdown arrow size * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * swap `mode` on the frontned to `interactive` to match the backend (#6149) * JS READMEs and Storybook on Docs (#6142) * changes * changes * working * remove storybook path * add changeset * pin code --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Don't serve files in working directory by default (#6128) * don't serve files in working directory by default * add changeset * handle examples * remove dotfiles * guide * guide * fix tests --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Fix issues with website deploy (#6151) * fixes * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Swap websockets for SSE (#6069) * changes * changes * changes * changes * changes * merge * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * changes * add changeset * changes * changes * changes * add changeset * changes * changes * changes * add changeset * changes * changes * changes * add changeset * changes * changes * changes * changes * changes * add changeset * Fix client tests sse branch (#6150) * Switch spaces * Fix tests * Add code * changes * changes --------- Co-authored-by: Ali Abid <aabid94@gmail.com> --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Freddy Boulton <alfonsoboulton@gmail.com> * Remove duplicate `elem_ids` from components (#6152) * remove elem_ids from components * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Moves `gradio_cached_folder` inside the gradio temp direcotry (#6155) * cache -> temp * restore * add changeset * add exception for cached examples * security policy * join --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Remove `show_edit_button` param in Audio (#6153) * remove `show_edit_button` param * add changeset * hide overflow * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Remove interpretation for good (#6154) * interpretation * notebooks * add changeset * removed from readme * lint * fix demo --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Make output components not editable if they are being updated (#6157) * make outputs not editable * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * JS Component Documentation (#6136) * Simple template * More changes * Properly handle change event video * add changeset * Add code' * Fix play/pause bugs * add changeset * atoms doc * Chatbot * add changeset * Some more components * Add code * add changeset * Lint * add changeset * Simple template * More changes * Properly handle change event video * add changeset * Add code' * Fix play/pause bugs * add changeset * atoms doc * Chatbot * add changeset * Some more components * Add code * add changeset * Lint * Merge in latest changes * Fix typo * Fix build * Lockfile * Fix * Fix interactive * correct the title * add versions to readme * only document public * add changeset * Remove simplevideo and audio * add changeset * changes to readmes * add changeset * remove tootils and theme --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> * Improve Video Component (#6118) * change source to sources + add length logic * add changeset * add min/max logic * tweak tests * change sources * formatting * fix test_components.py test * add trimming * add changeset * add keyboard events to trimming timeline * UX improvements * Add fix * add loading status * flip if webcam is only source * generate notebooks * remove scroll * add file extension * trim (#6156) Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * add loading indicator to video * ensure correct file ext is used * tweak * change where ffmpeg is loaded --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> Co-authored-by: Abubakar Abid <abubakar@huggingface.co> * chore: update versions (beta) (#6122) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * V4 fixes (#6161) * changes * changes * Pin 8.9 (#6162) * Pending outputs fix (#6160) * fix * add changeset --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * Clean root url (#6159) * clean * cleanup * formatting * add changeset * fe * add changeset * selectable * block * fix * fixes * fix update * gradio/events * configs * remove --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> * V4 fixes (#6167) * changes * changes * Fixes remaining backend tests (#6165) * fix backend tests * add changeset * changes * fix strings * lint * lint * fixes * delete test --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> --------- Co-authored-by: freddyaboulton <alfonsoboulton@gmail.com> Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Abubakar Abid <abubakar@huggingface.co> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Dawood Khan <dawoodkhan82@gmail.com> Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> Co-authored-by: Hannah <hannahblair@users.noreply.github.com> Co-authored-by: Ali Abid <aabid94@gmail.com>
511 lines
13 KiB
Svelte
511 lines
13 KiB
Svelte
<script lang="ts">
|
||
const browser = typeof document !== "undefined";
|
||
import { get_next_color } from "@gradio/utils";
|
||
import type { SelectData } from "@gradio/utils";
|
||
import { createEventDispatcher, onMount } from "svelte";
|
||
import { correct_color_map, merge_elements } from "./utils";
|
||
import LabelInput from "./LabelInput.svelte";
|
||
|
||
export let value: {
|
||
token: string;
|
||
class_or_confidence: string | number | null;
|
||
}[] = [];
|
||
export let show_legend = false;
|
||
export let color_map: Record<string, string> = {};
|
||
export let selectable = false;
|
||
|
||
let activeElementIndex = -1;
|
||
let ctx: CanvasRenderingContext2D;
|
||
let _color_map: Record<string, { primary: string; secondary: string }> = {};
|
||
let active = "";
|
||
let selection: Selection | null;
|
||
let labelToEdit = -1;
|
||
|
||
onMount(() => {
|
||
const mouseUpHandler = (): void => {
|
||
selection = window.getSelection();
|
||
handleSelectionComplete();
|
||
window.removeEventListener("mouseup", mouseUpHandler);
|
||
};
|
||
|
||
window.addEventListener("mousedown", () => {
|
||
window.addEventListener("mouseup", mouseUpHandler);
|
||
});
|
||
});
|
||
|
||
async function handleTextSelected(
|
||
startIndex: number,
|
||
endIndex: number
|
||
): Promise<void> {
|
||
if (
|
||
selection?.toString() &&
|
||
activeElementIndex !== -1 &&
|
||
value[activeElementIndex].token.toString().includes(selection.toString())
|
||
) {
|
||
const tempFlag = Symbol();
|
||
|
||
const str = value[activeElementIndex].token;
|
||
const [before, selected, after] = [
|
||
str.substring(0, startIndex),
|
||
str.substring(startIndex, endIndex),
|
||
str.substring(endIndex)
|
||
];
|
||
|
||
let tempValue: {
|
||
token: string;
|
||
class_or_confidence: string | number | null;
|
||
flag?: symbol;
|
||
}[] = [
|
||
...value.slice(0, activeElementIndex),
|
||
{ token: before, class_or_confidence: null },
|
||
{
|
||
token: selected,
|
||
class_or_confidence: mode === "scores" ? 1 : "label",
|
||
flag: tempFlag
|
||
}, // add a temp flag to the new highlighted text element
|
||
{ token: after, class_or_confidence: null },
|
||
...value.slice(activeElementIndex + 1)
|
||
];
|
||
|
||
// store the index of the new highlighted text element and remove the flag
|
||
labelToEdit = tempValue.findIndex(({ flag }) => flag === tempFlag);
|
||
// tempValue[labelToEdit].pop();
|
||
|
||
// remove elements with empty labels
|
||
tempValue = tempValue.filter((item) => item.token.trim() !== "");
|
||
value = tempValue.map(({ flag, ...rest }) => rest);
|
||
|
||
handleValueChange();
|
||
document.getElementById(`label-input-${labelToEdit}`)?.focus();
|
||
}
|
||
}
|
||
|
||
const dispatch = createEventDispatcher<{
|
||
select: SelectData;
|
||
change: typeof value;
|
||
input: never;
|
||
}>();
|
||
|
||
function splitTextByNewline(text: string): string[] {
|
||
return text.split("\n");
|
||
}
|
||
|
||
function removeHighlightedText(index: number): void {
|
||
if (!value || index < 0 || index >= value.length) return;
|
||
value[index].class_or_confidence = null;
|
||
value = merge_elements(value, "equal");
|
||
handleValueChange();
|
||
window.getSelection()?.empty();
|
||
}
|
||
|
||
function handleValueChange(): void {
|
||
dispatch("change", value);
|
||
labelToEdit = -1;
|
||
|
||
// reset legend color maps
|
||
if (show_legend) {
|
||
color_map = {};
|
||
_color_map = {};
|
||
}
|
||
}
|
||
|
||
let mode: "categories" | "scores";
|
||
|
||
$: {
|
||
if (!color_map) {
|
||
color_map = {};
|
||
}
|
||
if (value.length > 0) {
|
||
for (let entry of value) {
|
||
if (entry.class_or_confidence !== null) {
|
||
if (typeof entry.class_or_confidence === "string") {
|
||
mode = "categories";
|
||
if (!(entry.class_or_confidence in color_map)) {
|
||
let color = get_next_color(Object.keys(color_map).length);
|
||
color_map[entry.class_or_confidence] = color;
|
||
}
|
||
} else {
|
||
mode = "scores";
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
correct_color_map(color_map, _color_map, browser, ctx);
|
||
}
|
||
|
||
function handle_mouseover(label: string): void {
|
||
active = label;
|
||
}
|
||
function handle_mouseout(): void {
|
||
active = "";
|
||
}
|
||
|
||
async function handleKeydownSelection(event: KeyboardEvent): Promise<void> {
|
||
selection = window.getSelection();
|
||
|
||
if (event.key === "Enter") {
|
||
handleSelectionComplete();
|
||
}
|
||
}
|
||
|
||
function handleSelectionComplete(): void {
|
||
if (selection && selection?.toString().trim() !== "") {
|
||
const textBeginningIndex = selection.getRangeAt(0).startOffset;
|
||
const textEndIndex = selection.getRangeAt(0).endOffset;
|
||
handleTextSelected(textBeginningIndex, textEndIndex);
|
||
}
|
||
}
|
||
|
||
function handleSelect(
|
||
i: number,
|
||
text: string,
|
||
class_or_confidence: string | number | null
|
||
): void {
|
||
dispatch("select", {
|
||
index: i,
|
||
value: [text, class_or_confidence]
|
||
});
|
||
}
|
||
</script>
|
||
|
||
<div class="container">
|
||
{#if mode === "categories"}
|
||
{#if show_legend}
|
||
<div
|
||
class="class_or_confidence-legend"
|
||
data-testid="highlighted-text:class_or_confidence-legend"
|
||
>
|
||
{#if _color_map}
|
||
{#each Object.entries(_color_map) as [class_or_confidence, color], i}
|
||
<div
|
||
role="button"
|
||
aria-roledescription="Categories of highlighted text. Hover to see text with this class_or_confidence highlighted."
|
||
tabindex="0"
|
||
on:mouseover={() => handle_mouseover(class_or_confidence)}
|
||
on:focus={() => handle_mouseover(class_or_confidence)}
|
||
on:mouseout={() => handle_mouseout()}
|
||
on:blur={() => handle_mouseout()}
|
||
class="class_or_confidence-label"
|
||
style={"background-color:" + color.secondary}
|
||
>
|
||
{class_or_confidence}
|
||
</div>
|
||
{/each}
|
||
{/if}
|
||
</div>
|
||
{/if}
|
||
|
||
<div class="textfield">
|
||
{#each value as { token, class_or_confidence }, i}
|
||
{#each splitTextByNewline(token) as line, j}
|
||
{#if line.trim() !== ""}
|
||
<span class="text-class_or_confidence-container">
|
||
<span
|
||
role="button"
|
||
tabindex="0"
|
||
class="textspan"
|
||
style:background-color={class_or_confidence === null ||
|
||
(active && active !== class_or_confidence)
|
||
? ""
|
||
: class_or_confidence && _color_map[class_or_confidence]
|
||
? _color_map[class_or_confidence].secondary
|
||
: ""}
|
||
class:no-cat={class_or_confidence === null ||
|
||
(active && active !== class_or_confidence)}
|
||
class:hl={class_or_confidence !== null}
|
||
class:selectable
|
||
on:click={() => {
|
||
if (class_or_confidence !== null) {
|
||
handleSelect(i, token, class_or_confidence);
|
||
}
|
||
}}
|
||
on:keydown={(e) => {
|
||
if (class_or_confidence !== null) {
|
||
labelToEdit = i;
|
||
handleSelect(i, token, class_or_confidence);
|
||
} else {
|
||
handleKeydownSelection(e);
|
||
}
|
||
}}
|
||
on:focus={() => (activeElementIndex = i)}
|
||
on:mouseover={() => (activeElementIndex = i)}
|
||
>
|
||
<span
|
||
class:no-label={class_or_confidence === null}
|
||
class="text"
|
||
role="button"
|
||
on:keydown={(e) => handleKeydownSelection(e)}
|
||
on:focus={() => (activeElementIndex = i)}
|
||
on:mouseover={() => (activeElementIndex = i)}
|
||
on:click={() => (labelToEdit = i)}
|
||
tabindex="0">{line}</span
|
||
>
|
||
{#if !show_legend && class_or_confidence !== null && labelToEdit !== i}
|
||
<span
|
||
id={`label-tag-${i}`}
|
||
class="label"
|
||
role="button"
|
||
tabindex="0"
|
||
style:background-color={class_or_confidence === null ||
|
||
(active && active !== class_or_confidence)
|
||
? ""
|
||
: _color_map[class_or_confidence].primary}
|
||
on:click={() => (labelToEdit = i)}
|
||
on:keydown={() => (labelToEdit = i)}
|
||
>
|
||
{class_or_confidence}
|
||
</span>
|
||
{/if}
|
||
{#if labelToEdit === i && class_or_confidence !== null}
|
||
|
||
<LabelInput
|
||
bind:value
|
||
{labelToEdit}
|
||
category={class_or_confidence}
|
||
{active}
|
||
{_color_map}
|
||
indexOfLabel={i}
|
||
text={token}
|
||
{handleValueChange}
|
||
/>
|
||
{/if}
|
||
</span>
|
||
{#if class_or_confidence !== null}
|
||
<span
|
||
class="label-clear-button"
|
||
role="button"
|
||
aria-roledescription="Remove label from text"
|
||
tabindex="0"
|
||
on:click={() => removeHighlightedText(i)}
|
||
on:keydown={(event) => {
|
||
if (event.key === "Enter") {
|
||
removeHighlightedText(i);
|
||
}
|
||
}}
|
||
>×
|
||
</span>
|
||
{/if}
|
||
</span>
|
||
{/if}
|
||
{#if j < splitTextByNewline(token).length - 1}
|
||
<br />
|
||
{/if}
|
||
{/each}
|
||
{/each}
|
||
</div>
|
||
{:else}
|
||
{#if show_legend}
|
||
<div class="color-legend" data-testid="highlighted-text:color-legend">
|
||
<span>-1</span>
|
||
<span>0</span>
|
||
<span>+1</span>
|
||
</div>
|
||
{/if}
|
||
|
||
<div class="textfield" data-testid="highlighted-text:textfield">
|
||
{#each value as { token, class_or_confidence }, i}
|
||
{@const score =
|
||
typeof class_or_confidence === "string"
|
||
? parseInt(class_or_confidence)
|
||
: class_or_confidence}
|
||
<span class="score-text-container">
|
||
<span
|
||
class="textspan score-text"
|
||
role="button"
|
||
tabindex="0"
|
||
class:no-cat={class_or_confidence === null ||
|
||
(active && active !== class_or_confidence)}
|
||
class:hl={class_or_confidence !== null}
|
||
on:mouseover={() => (activeElementIndex = i)}
|
||
on:focus={() => (activeElementIndex = i)}
|
||
on:click={() => (labelToEdit = i)}
|
||
on:keydown={(e) => {
|
||
if (e.key === "Enter") {
|
||
labelToEdit = i;
|
||
}
|
||
}}
|
||
style={"background-color: rgba(" +
|
||
(score && score < 0
|
||
? "128, 90, 213," + -score
|
||
: "239, 68, 60," + score) +
|
||
")"}
|
||
>
|
||
<span class="text">{token}</span>
|
||
{#if class_or_confidence && labelToEdit === i}
|
||
<LabelInput
|
||
bind:value
|
||
{labelToEdit}
|
||
{_color_map}
|
||
category={class_or_confidence}
|
||
{active}
|
||
indexOfLabel={i}
|
||
text={token}
|
||
{handleValueChange}
|
||
isScoresMode
|
||
/>
|
||
{/if}
|
||
</span>
|
||
{#if class_or_confidence && activeElementIndex === i}
|
||
<span
|
||
class="label-clear-button"
|
||
role="button"
|
||
aria-roledescription="Remove label from text"
|
||
tabindex="0"
|
||
on:click={() => removeHighlightedText(i)}
|
||
on:keydown={(event) => {
|
||
if (event.key === "Enter") {
|
||
removeHighlightedText(i);
|
||
}
|
||
}}
|
||
>×
|
||
</span>
|
||
{/if}
|
||
</span>
|
||
{/each}
|
||
</div>
|
||
{/if}
|
||
</div>
|
||
|
||
<style>
|
||
.label-clear-button {
|
||
display: none;
|
||
border-radius: var(--radius-xs);
|
||
padding-top: 2.5px;
|
||
padding-right: var(--size-1);
|
||
padding-bottom: 3.5px;
|
||
padding-left: var(--size-1);
|
||
color: black;
|
||
background-color: var(--background-fill-secondary);
|
||
user-select: none;
|
||
position: relative;
|
||
left: -3px;
|
||
border-radius: 0 var(--radius-xs) var(--radius-xs) 0;
|
||
color: var(--block-label-text-color);
|
||
}
|
||
|
||
.text-class_or_confidence-container:hover .label-clear-button,
|
||
.text-class_or_confidence-container:focus-within .label-clear-button,
|
||
.score-text-container:hover .label-clear-button,
|
||
.score-text-container:focus-within .label-clear-button {
|
||
display: inline;
|
||
}
|
||
|
||
.text-class_or_confidence-container:hover .textspan.hl,
|
||
.text-class_or_confidence-container:focus-within .textspan.hl,
|
||
.score-text:hover {
|
||
border-radius: var(--radius-xs) 0 0 var(--radius-xs);
|
||
}
|
||
|
||
.container {
|
||
display: flex;
|
||
flex-direction: column;
|
||
gap: var(--spacing-sm);
|
||
padding: var(--block-padding);
|
||
}
|
||
|
||
.hl {
|
||
margin-left: var(--size-1);
|
||
transition: background-color 0.3s;
|
||
user-select: none;
|
||
}
|
||
|
||
.textspan:last-child > .label {
|
||
margin-right: 0;
|
||
}
|
||
|
||
.class_or_confidence-legend {
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
gap: var(--spacing-sm);
|
||
color: black;
|
||
}
|
||
|
||
.class_or_confidence-label {
|
||
cursor: pointer;
|
||
border-radius: var(--radius-xs);
|
||
padding-right: var(--size-2);
|
||
padding-left: var(--size-2);
|
||
font-weight: var(--weight-semibold);
|
||
}
|
||
|
||
.color-legend {
|
||
display: flex;
|
||
justify-content: space-between;
|
||
border-radius: var(--radius-xs);
|
||
background: linear-gradient(
|
||
to right,
|
||
var(--color-purple),
|
||
rgba(255, 255, 255, 0),
|
||
var(--color-red)
|
||
);
|
||
padding: var(--size-1) var(--size-2);
|
||
font-weight: var(--weight-semibold);
|
||
}
|
||
|
||
.textfield {
|
||
box-sizing: border-box;
|
||
border-radius: var(--radius-xs);
|
||
background: var(--background-fill-primary);
|
||
background-color: transparent;
|
||
max-width: var(--size-full);
|
||
line-height: var(--scale-4);
|
||
word-break: break-all;
|
||
}
|
||
|
||
.textspan {
|
||
transition: 150ms;
|
||
border-radius: var(--radius-xs);
|
||
padding-top: 2.5px;
|
||
padding-right: var(--size-1);
|
||
padding-bottom: 3.5px;
|
||
padding-left: var(--size-1);
|
||
color: black;
|
||
cursor: text;
|
||
}
|
||
|
||
.label {
|
||
transition: 150ms;
|
||
margin-top: 1px;
|
||
border-radius: var(--radius-xs);
|
||
padding: 1px 5px;
|
||
color: var(--body-text-color);
|
||
color: white;
|
||
font-weight: var(--weight-bold);
|
||
font-size: var(--text-sm);
|
||
text-transform: uppercase;
|
||
user-select: none;
|
||
}
|
||
|
||
.text {
|
||
color: black;
|
||
white-space: pre-wrap;
|
||
}
|
||
|
||
.textspan.hl {
|
||
user-select: none;
|
||
}
|
||
|
||
.score-text-container {
|
||
margin-right: var(--size-1);
|
||
}
|
||
|
||
.score-text .text {
|
||
color: var(--body-text-color);
|
||
}
|
||
|
||
.no-cat {
|
||
color: var(--body-text-color);
|
||
}
|
||
|
||
.no-label {
|
||
color: var(--body-text-color);
|
||
user-select: text;
|
||
}
|
||
|
||
.selectable {
|
||
cursor: text;
|
||
user-select: text;
|
||
}
|
||
</style>
|