Streamlit component for date input with Japanese localization
Project description
Japanese Date Input Component for Streamlit
日本語表記に対応したStreamlit用のdate inputコンポーネントです。
サードパーティコンポーネントとして実装する場合、制限事項があるため、基本的にはst.date_inputの使用を推奨します。
特徴
- 📅 日本語の曜日表示(月、火、水、木、金、土、日)
- 📆 日本語の月表示(1月、2月、...、12月)
インストール
pip install streamlit-japanese-date-input
使い方
基本的な使用例
以下のスクリプトを実行することで、アプリケーションの諸々の挙動を確認することができます。 以下のgifのような挙動になります。
streamlit run example.py
パラメータ
label(str): 入力フィールドのラベルvalue(date/datetime/str, optional): 初期値min_value(date/datetime/str, optional): 選択可能な最小日付max_value(date/datetime/str, optional): 選択可能な最大日付format(str): 日付フォーマット(デフォルト: "YYYY/MM/DD")disabled(bool): 入力を無効化するかどうかwidth(str or int): ウィジェットの幅("stretch"または固定ピクセル値)sidebar_mode(bool): サイドバーでの表示に最適化するかどうか(デフォルト: False)key(str, optional): コンポーネントの一意のキー
サイドバーでの使用について
Streamlitのカスタムコンポーネントは独立したiframe内で動作するため、Streamlitのサイドバーの中に、このコンポーネントを配置していることを自動的に検出することができません。
そのため、サイドバーで使用する場合はsidebar_mode=Trueを明示的に指定する必要があります。
# サイドバーでの使用例
with st.sidebar:
selected_date = japanese_date_input(
"日付を選択",
sidebar_mode=True # サイドバーでは必ずTrueに設定
)
sidebar_mode=Trueを設定すると、背景色が白色・テキストが黒色となり、サイドバーのデザインに調和します
制限事項
1. iframe内での表示制約
カスタムコンポーネントは iframe 内で動作するため、カレンダーを親ウィンドウの上に重ねて表示する「ダイアログ形式」は実現できません。 以下の制限があります。
- 狭いコンテナやサイドバーではカレンダーが見切れる
- iframe を超えて表示することはできない
- 高さを動的に調整しても限界がある
一方、st.date_input は iframe ではなく Streamlit 本体のウィジェットのため、こうした制約がなく常に正しく表示されます。
2. サイドバーや狭いレイアウトでの自動検出不可
カスタムコンポーネントは親ウィンドウのDOMを参照できないため、
サイドバーで使う場合は手動でsidebar_mode=Trueを設定する必要があります。
これにより、背景色や文字色の調整が行えます。
3. メンテナンスや互換性の面
カスタムコンポーネントは React と Streamlit Components API に依存するため、Streamlit のアップデートやテーマ変更により動作が壊れる可能性があります。 また、iframe の制約を回避するために複雑な実装や高さ調整が必要になる場合があります。
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file streamlit_japanese_date_input-0.1.3.tar.gz.
File metadata
- Download URL: streamlit_japanese_date_input-0.1.3.tar.gz
- Upload date:
- Size: 6.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bb130434c631f7f42bc3f9fc28c9296cde85ff912d167a2beb704d1ef9aad213
|
|
| MD5 |
c413b43cfb86b1bebfc67417226bec5b
|
|
| BLAKE2b-256 |
351a3b7e329ed44d858ffc825f3daca578702961aae2ee2ed16e3775315709e7
|
File details
Details for the file streamlit_japanese_date_input-0.1.3-py3-none-any.whl.
File metadata
- Download URL: streamlit_japanese_date_input-0.1.3-py3-none-any.whl
- Upload date:
- Size: 6.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d76ce8da0fed2fd3fbda6d55ba9572b2915d5a1ed51ef47133babc8e8b33a7c4
|
|
| MD5 |
0ded7c0fdfddbb90e4811eecb39b818c
|
|
| BLAKE2b-256 |
5fe171da47f27ac542a640b41da49532a199dd62e87981cc53e5c0c0fd23c655
|