Skip to main content

Streamlit copy‑to‑clipboard button component

Project description

Streamlit Copy-to-Clipboard Button Component

Streamlit App PyPI 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.2.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.2-py3-none-any.whl (108.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: st_copy-1.0.2.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.2.tar.gz
Algorithm Hash digest
SHA256 ae6139a16f60a91f84b671c4ab3c1f807ede79f1a8df23267983fa3dba0f87c7
MD5 43808c6c66a2f3a6d84a00fd114ceda9
BLAKE2b-256 65c539c14debaf60d3070d5690375f6ed4d29e1fbf42b3974f6b20eabe87b19f

See more details on using hashes here.

Provenance

The following attestation bundles were made for st_copy-1.0.2.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.2-py3-none-any.whl.

File metadata

  • Download URL: st_copy-1.0.2-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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 04fdc37c58d802c277c3f67370e5be7fd73aabb07c2062e1083cd37ee40c6331
MD5 a9839e2d783e28d2ab881c3b8d1a3361
BLAKE2b-256 ca0997911103fb3cca2d974d91acb4f780c2b492b39b53f7932777ea5ca6b172

See more details on using hashes here.

Provenance

The following attestation bundles were made for st_copy-1.0.2-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