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 Ask DeepWiki

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.1.0.tar.gz (59.1 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.1.0-py3-none-any.whl (58.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: st_copy-1.1.0.tar.gz
  • Upload date:
  • Size: 59.1 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.1.0.tar.gz
Algorithm Hash digest
SHA256 43f0229a5e64c7813ffd9e30a5dbc1fe25fab8263bcbc859b2eae65366ac49e8
MD5 aa19badb073921e1c1fae04d1e785bf5
BLAKE2b-256 f08cae6e14a21f55ae134596af6035f231d7645eec95321c418ec2a90477ad67

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: st_copy-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 58.5 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.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 98f5629f59c51dfa9a72738289d11e5acf16a1e5a7981ee0aacd5207813b23be
MD5 500e0956ad025de98097f5b0b6fc6292
BLAKE2b-256 d1fca04d7656419db7efe7a290ba8450e42ff4a58d2764505d4510f7dfce9ac4

See more details on using hashes here.

Provenance

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