Skip to main content

Streamlit copy‑to‑clipboard button component

Project description

Streamlit Copy-to-Clipboard Button Component

Streamlit App Python Version GitHub License

A tiny, theme‑aware Streamlit component that adds a one‑click "copy-to-clipboard" button to your app — perfect for the chat UI, URLs or any other text the user might need to copy.

✨ Features

  • Streamlit theme aware: Adapts icon colour & tooltip style automatically; works in both light and dark themes.
  • Two icon styles: Google Material Symbols (default) or the native Streamlit code‑block icon.
  • Custom tooltip & "Copied!" label: Localised UI in one line.
  • Keyboard‑friendly: Fully focusable, press Enter/Space to copy.

🔧 Installation

pip install st-copy

⚡ Quick start

import streamlit as st
from st_copy import copy_button

st.title('Minimal demo')

copy_button('Hello, Streamlit!')  # one line – that's it 🎉

Run your script:

streamlit run app.py

🛠 API

def copy_button(
    text: str,
    *,
    icon: Literal['material_symbols', 'st'] = 'material_symbols',
    tooltip: str = 'Copy',
    copied_label: str = 'Copied!',
    key: Optional[str] = None,
) -> Optional[bool]:
Parameter Type / Default Description
text str Text placed on the user’s clipboard.
icon Literal['material_symbols', 'st']
default 'material_symbols'
Icon style: Google Material content_copy (material_symbols) or Streamlit’s native code‑block icon (st).
tooltip str, default 'Copy' Tooltip shown on hover/focus.
copied_label str, default 'Copied!' Small label displayed for ~1 s after a successful copy.
key str | None, default None Unique component key; if omitted a random UUIDv4 is generated.
Returns bool | None True – copy succeeded; False – Clipboard API failed; None – button not clicked yet.

🎨 Examples

See examples/app.py for a chat‑style demo that showcases every argument and the deployed version at https://st-copy.streamlit.app/.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

st_copy-1.0.0.tar.gz (108.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

st_copy-1.0.0-py3-none-any.whl (108.2 kB view details)

Uploaded Python 3

File details

Details for the file st_copy-1.0.0.tar.gz.

File metadata

  • Download URL: st_copy-1.0.0.tar.gz
  • Upload date:
  • Size: 108.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for st_copy-1.0.0.tar.gz
Algorithm Hash digest
SHA256 6a2cbcf30c35b52339fcd992ddd61c1872f46480404b7f885235a620a182b9fb
MD5 f7811feb087689d4ec91bcad4c4af2a1
BLAKE2b-256 8cd3ac4b97637c89a10468f4676bc4b4be7a58ad030eef3cb01e7aed66a71727

See more details on using hashes here.

Provenance

The following attestation bundles were made for st_copy-1.0.0.tar.gz:

Publisher: python-publish.yml on alex-feel/st-copy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file st_copy-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: st_copy-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 108.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for st_copy-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 35f9da85f3cffd89526d7958079be85d814f192cb0f51bcf993f3216cb5a7a28
MD5 6aa2de2a41e8deb21f16909ffa10fa63
BLAKE2b-256 84ec3e161e0c97f52d80c6c9736532960e29b4bdd3a711667067dd5f83650e4d

See more details on using hashes here.

Provenance

The following attestation bundles were made for st_copy-1.0.0-py3-none-any.whl:

Publisher: python-publish.yml on alex-feel/st-copy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page