ksaa 2025.11b1__py3-none-any.whl → 2025.11.post1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- kaa/__init__.py +0 -0
- kaa/application/__init__.py +0 -0
- kaa/application/core/misc_core.py +4 -1
- kaa/application/services/__init__.py +0 -0
- kaa/application/services/config_service.py +112 -0
- kaa/application/services/feedback_service.py +121 -0
- kaa/application/services/produce_solution_service.py +83 -0
- kaa/application/services/task_service.py +145 -0
- kaa/application/services/update_service.py +208 -0
- kaa/application/ui/__init__.py +0 -0
- kaa/application/ui/common.py +123 -0
- kaa/application/ui/components/alert.py +251 -0
- kaa/application/ui/components/alert.pyi +257 -0
- kaa/application/ui/components/categorized_select.pyi +697 -0
- kaa/application/ui/facade.py +189 -0
- kaa/application/ui/gradio_view.py +135 -0
- kaa/application/ui/views/__init__.py +0 -0
- kaa/application/ui/views/feedback_view.py +65 -0
- kaa/application/ui/views/produce_view.py +251 -0
- kaa/application/ui/views/settings_view.py +581 -0
- kaa/application/ui/views/status_view.py +171 -0
- kaa/application/ui/views/task_view.py +102 -0
- kaa/application/ui/views/update_view.py +106 -0
- kaa/config/schema.py +8 -0
- kaa/db/constants.py +3 -2
- kaa/errors.py +60 -0
- kaa/main/gr.py +60 -3132
- kaa/main/kaa.py +11 -3
- kaa/metadata.py +80 -0
- kaa/resources/__pycache__/__init__.cpython-310.pyc +0 -0
- kaa/resources/game.db +0 -0
- kaa/resources/game_ver.txt +0 -0
- kaa/resources/idol_cards/i_card-skin-amao-3-014_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-amao-3-015_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-atbm-1-000_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-atbm-1-000_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-atbm-2-000_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-atbm-2-000_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-atbm-3-000_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-atbm-3-000_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-fktn-3-016_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-fktn-3-016_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hmsz-3-003_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hmsz-3-003_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hmsz-3-009_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hmsz-3-009_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hmsz-3-013_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hmsz-3-013_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hrnm-3-015_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hrnm-3-015_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hski-3-015_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hski-3-015_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hume-3-009_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hume-3-009_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hume-3-015_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-hume-3-015_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-jsna-3-009_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-jsna-3-009_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-jsna-3-014_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-jsna-3-014_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-kcna-3-014_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-kcna-3-015_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-kcna-3-015_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-kllj-3-014_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-kllj-3-014_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-shro-3-015_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-shro-3-015_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-ssmk-3-015_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-ssmk-3-015_1.png +0 -0
- kaa/resources/idol_cards/i_card-skin-ttmr-3-015_0.png +0 -0
- kaa/resources/idol_cards/i_card-skin-ttmr-3-015_1.png +0 -0
- kaa/sprites/052ab0f5-8d95-4b5d-8678-3838322d9e5e.png +0 -0
- kaa/sprites/18adb1a5-b95d-41ff-9cb9-16613fa4cf6a.png +0 -0
- kaa/sprites/2aac3a97-435e-4c02-925f-e2d1673b7982.png +0 -0
- kaa/sprites/2cc63c6d-5988-4f72-ae88-b03b8246ad97.png +0 -0
- kaa/sprites/3208d803-2c92-4775-80dc-0527df4b63d9.png +0 -0
- kaa/sprites/345435d0-5a5c-494b-95ab-1e086fb88f51.png +0 -0
- kaa/sprites/3ad30d90-8b57-4641-a9e2-33970e5cea1d.png +0 -0
- kaa/sprites/3e0da5df-a4de-42bd-83bd-13df3c393af4.png +0 -0
- kaa/sprites/41904062-e218-4b28-972a-b5cfcd058d2c.png +0 -0
- kaa/sprites/44a50906-1835-4e29-ae97-496b4cdde9e9.png +0 -0
- kaa/sprites/488a1403-d300-4fa6-94c7-da71d09fd4bb.png +0 -0
- kaa/sprites/48c16d60-05d6-43bc-97c3-7f099bfc0881.png +0 -0
- kaa/sprites/4e3dbeb5-70bb-4642-9f73-01f9f98bc3aa.png +0 -0
- kaa/sprites/54987de4-3e1b-4640-b203-1e4c82d7e98d.png +0 -0
- kaa/sprites/5a0bfeac-fb22-4b0c-b775-4aa6220bae89.png +0 -0
- kaa/sprites/5aad0930-54a3-4b6d-bec8-250228963f69.png +0 -0
- kaa/sprites/5c49d3b3-656e-4c8c-ae1a-9b0209b9dcc3.png +0 -0
- kaa/sprites/5c9a1581-a14a-449b-a1b0-7a31a965facc.png +0 -0
- kaa/sprites/62411b55-7be8-46d9-aa4a-fb56dab6658c.png +0 -0
- kaa/sprites/6580ea89-553e-4445-a855-f834d580e6e6.png +0 -0
- kaa/sprites/686a2bf5-0498-4d53-8ba1-1110ff36f046.png +0 -0
- kaa/sprites/699ca639-3006-45c1-b5fd-8cf9631fd3ea.png +0 -0
- kaa/sprites/6e8325f9-7fdb-4729-ac13-ca67244d97bc.png +0 -0
- kaa/sprites/71051aa7-81f1-4144-9318-4405e10547ee.png +0 -0
- kaa/sprites/732ffc6c-6a17-41f8-9cd1-f218ebc0c23f.png +0 -0
- kaa/sprites/744ea25a-9b6e-4f8f-9a00-0ac714571b09.png +0 -0
- kaa/sprites/74b50642-0b18-45c3-8a5d-013ef1e0eb78.png +0 -0
- kaa/sprites/77e7262f-0d12-4bd9-9f22-e8f41a600bf8.png +0 -0
- kaa/sprites/78b928c6-0d24-4e87-a84f-0091d42f8e49.png +0 -0
- kaa/sprites/7c193df5-0a1d-444d-9f92-e9c0db79e53a.png +0 -0
- kaa/sprites/7e729638-f54a-48bb-8bbf-eeaa4d697502.png +0 -0
- kaa/sprites/802e717f-d70a-4f34-8b96-be586a8dfde9.png +0 -0
- kaa/sprites/831cac7e-49e9-45d1-bb65-b1db733cda90.png +0 -0
- kaa/sprites/8411b102-866d-4e41-ab12-507397b80ca5.png +0 -0
- kaa/sprites/84b3c8e2-6e37-443c-be9b-8a95aedc6f37.png +0 -0
- kaa/sprites/85308e03-ba72-499a-9d12-870269fa3cd0.png +0 -0
- kaa/sprites/8922feef-17db-4b10-93da-1bad30492ac2.png +0 -0
- kaa/sprites/8a6ed80c-79c6-4df6-ab65-64d67afb2d5b.png +0 -0
- kaa/sprites/8c0439d9-9eb7-43f3-8d1e-7e41c57c1bbd.png +0 -0
- kaa/sprites/8dd3de6d-07d5-4d93-9663-71a3a4c57a32.png +0 -0
- kaa/sprites/9009323d-1418-4aed-8a93-075b326d2e7a.png +0 -0
- kaa/sprites/904d22f7-51be-486f-8dd1-1871c0cf28e3.png +0 -0
- kaa/sprites/90943f62-0a03-4a75-804a-0c2fa7b27af4.png +0 -0
- kaa/sprites/9180e0e7-2cc4-46c7-95ff-fbe83806baf2.png +0 -0
- kaa/sprites/93f5c33e-ec81-4a70-a11f-b2e8cb1751ee.png +0 -0
- kaa/sprites/9558b2a5-3961-4ad0-9ce8-379d71920d78.png +0 -0
- kaa/sprites/968dff88-5a2f-42c7-b64b-406801e22c87.png +0 -0
- kaa/sprites/99d99d78-ee37-4e84-8768-b5a7f4f9bd51.png +0 -0
- kaa/sprites/9caa102c-70af-4a8c-b595-82df9f4c05d8.png +0 -0
- kaa/sprites/9e06b7d6-5d15-4844-bbfe-ad1af7da3113.png +0 -0
- kaa/sprites/__pycache__/__init__.cpython-310.pyc +0 -0
- kaa/sprites/a04ed558-25e3-42d7-a662-250cad9fa5df.png +0 -0
- kaa/sprites/a0a62dbf-a027-4b63-86e4-2e863b2edb01.png +0 -0
- kaa/sprites/a4b898aa-405e-4235-8075-a34640a2b023.png +0 -0
- kaa/sprites/a5c3108f-c92d-4ce7-8c4e-93b79f55ceb3.png +0 -0
- kaa/sprites/a7e6222f-f8ca-47c2-af1e-f158a87f6a03.png +0 -0
- kaa/sprites/ab3d3301-8297-43a8-bf0b-85413c115a7d.png +0 -0
- kaa/sprites/ad589feb-6d19-47c7-a582-55ee130ee89d.png +0 -0
- kaa/sprites/ae4742aa-acda-442d-bf73-b3fe7b66e85c.png +0 -0
- kaa/sprites/aed87cd4-eb05-4c24-8adf-cd3fab20e9a3.png +0 -0
- kaa/sprites/afb9e4a9-29a5-4202-9f75-e7d2f1b64aa4.png +0 -0
- kaa/sprites/b1f547d4-c1ba-43fc-9398-4ccdc25b8b62.png +0 -0
- kaa/sprites/b61bd48f-1fe7-49fd-a588-09aac3b66f5a.png +0 -0
- kaa/sprites/b6219452-323a-44eb-9f44-97b2ad0ee49a.png +0 -0
- kaa/sprites/b7550a50-5943-45e7-9c1b-771117364844.png +0 -0
- kaa/sprites/b865eedf-7bea-46f6-bf14-7f8f4e9ab000.png +0 -0
- kaa/sprites/b8f0ed47-6115-4b88-848a-2fc4a1ab25d8.png +0 -0
- kaa/sprites/b9224799-d0c1-43d9-9f11-1d35903fc4d9.png +0 -0
- kaa/sprites/baa9c530-68cb-4111-85f6-060823ad32c4.png +0 -0
- kaa/sprites/bed54f67-d828-403c-9cb3-6a7c85695c2a.png +0 -0
- kaa/sprites/befadc5e-862a-4818-9223-5d58e4ac03cb.png +0 -0
- kaa/sprites/c0d1896c-71a1-47d6-9847-b87543a942e9.png +0 -0
- kaa/sprites/c2984c0f-3e17-45c3-9d7c-dc4f14440b13.png +0 -0
- kaa/sprites/c6b53acc-bc89-465e-9814-0138513327ac.png +0 -0
- kaa/sprites/c72a4609-6bf0-4568-8ebc-73c30d67c61e.png +0 -0
- kaa/sprites/c7829f82-bfce-4259-9ec6-f1cfb7bac925.png +0 -0
- kaa/sprites/c82ebc01-0127-417f-831a-9d17a84b2691.png +0 -0
- kaa/sprites/c8747b3b-745c-45ed-84b6-dde1b2558ce8.png +0 -0
- kaa/sprites/c98ef89e-4a1c-40f0-a82e-6851f7b6bbc9.png +0 -0
- kaa/sprites/cb04d87c-f5a9-405c-92ac-b3603e482221.png +0 -0
- kaa/sprites/cb43f670-6623-4af9-ac1d-746372e40511.png +0 -0
- kaa/sprites/ce357023-436b-4a39-882f-8410acd8f0d7.png +0 -0
- kaa/sprites/cea9f5ea-5923-4c6e-bd24-90d2e084112c.png +0 -0
- kaa/sprites/cf62e2df-3be1-4d03-9f34-1518280abd90.png +0 -0
- kaa/sprites/d0a483a9-400f-4b6e-87a0-9781b4454da0.png +0 -0
- kaa/sprites/d10d480c-e96e-475e-815c-0969f37fe3bc.png +0 -0
- kaa/sprites/d1839450-8d60-41a4-b035-8e1acd0f1c7a.png +0 -0
- kaa/sprites/d19859f3-f7cc-46ef-8bc6-86df7856fd53.png +0 -0
- kaa/sprites/d2d3d77d-a06f-4167-b02b-5ca688c0c0c3.png +0 -0
- kaa/sprites/d38c5015-e461-4e09-8b56-731472bdf59e.png +0 -0
- kaa/sprites/d473b5bd-4be3-4f0f-bb92-b909050f273a.png +0 -0
- kaa/sprites/d609a029-5407-43c2-a9a9-07bfd43fcbb8.png +0 -0
- kaa/sprites/d6491f82-9637-47eb-8f35-eb272b5ef8df.png +0 -0
- kaa/sprites/d8dd8b59-c05c-4350-a15d-be75c94d46cc.png +0 -0
- kaa/sprites/d98263bf-15fb-430e-ba39-2558fa99cac0.png +0 -0
- kaa/sprites/d9bc9bbb-9a1a-4cbe-b6ed-24112d7c5ac7.png +0 -0
- kaa/sprites/da922566-97ba-4477-bcad-35ea02a3ee48.png +0 -0
- kaa/sprites/dac8d8fd-006c-4f50-a4e0-d79dbf3f5915.png +0 -0
- kaa/sprites/db33ab8d-160d-48c7-b464-dfe194e762d4.png +0 -0
- kaa/sprites/dcfdfab4-8dfb-4069-bf88-8e8401ef86f3.png +0 -0
- kaa/sprites/de354b53-2fd0-4039-87e2-fcad2e070579.png +0 -0
- kaa/sprites/e28ea25e-0bcf-4d52-b501-9ef7a4863870.png +0 -0
- kaa/sprites/e2ac927f-257e-4537-995d-fbfbe4983b70.png +0 -0
- kaa/sprites/e642b9ef-c8a7-41d5-8d71-5cfbaf3017a1.png +0 -0
- kaa/sprites/e749feec-6bf2-4c24-bb12-948e696b8116.png +0 -0
- kaa/sprites/ed3aa6e6-4256-416b-9d04-d57ca340e39d.png +0 -0
- kaa/sprites/ed4c0554-84df-4c29-af18-7c38523cc59b.png +0 -0
- kaa/sprites/ef1bfd47-78e9-4cb7-a344-53d980fc3e5e.png +0 -0
- kaa/sprites/ef1ddc7d-75f9-4798-afa1-733e16794a81.png +0 -0
- kaa/sprites/efb01328-b6e1-438e-9471-bef3ea77a22c.png +0 -0
- kaa/sprites/f06b1a4f-eeb6-4dea-9543-5ec27640bdd9.png +0 -0
- kaa/sprites/f07bac27-9201-498f-9f26-a58291a70542.png +0 -0
- kaa/sprites/f0fd613b-d2f8-4b18-90d8-0b328373e715.png +0 -0
- kaa/sprites/f1fbe46a-759d-467d-b8ca-2158f530f7c5.png +0 -0
- kaa/sprites/f2314c76-3a2b-4644-831a-343a601145df.png +0 -0
- kaa/sprites/f329d4ba-e836-4be6-a05b-879b53667df3.png +0 -0
- kaa/sprites/f469d235-552f-4b07-9d03-9bcae425b6d8.png +0 -0
- kaa/sprites/f5177258-a3cf-4d4f-9c69-0b49556f754f.png +0 -0
- kaa/sprites/f5dcac82-7c54-4020-84c5-b1334b595612.png +0 -0
- kaa/sprites/f6656842-1460-41ab-95ed-561aefaf08e2.png +0 -0
- kaa/sprites/f70e9455-7cc8-449c-8282-89a9e69f7ac3.png +0 -0
- kaa/sprites/f7fd469f-791e-4bf7-ae3f-b5aaed92f999.png +0 -0
- kaa/sprites/f873280f-bc68-40d1-8d8d-3d86964264f0.png +0 -0
- kaa/sprites/f9da6eeb-ff9e-45b3-94b0-e7ba34938dec.png +0 -0
- kaa/sprites/fa24f5d5-d7e5-4421-8cbc-2ce3a0189654.png +0 -0
- kaa/sprites/fb61dbf3-fbc1-400a-adde-83ea08b5027d.png +0 -0
- kaa/sprites/fc8457b6-f8a3-4b01-9864-0cd624c312b6.png +0 -0
- kaa/sprites/fdbf6a89-b95a-481f-a269-be53e05b18de.png +0 -0
- kaa/sprites/fed11307-2186-4ede-875f-ffa0383f410c.png +0 -0
- kaa/sprites/ff0d3db2-c4e5-41e7-a85b-df4fd392924c.png +0 -0
- kaa/sprites/ff40ff91-4e8c-46cb-a254-66cd5ffd363e.png +0 -0
- kaa/sprites/ff614071-c318-4263-af3e-01ea0ab45b73.png +0 -0
- kaa/tasks/R.py +136 -128
- kaa/tasks/R2.py +24 -0
- kaa/tasks/common.py +5 -0
- kaa/tasks/daily/club_reward.py +1 -0
- kaa/tasks/daily/contest.py +2 -1
- kaa/tasks/daily/purchase.py +33 -1
- kaa/tasks/daily/upgrade_support_card.py +12 -2
- kaa/tasks/produce/cards.py +5 -4
- kaa/tasks/produce/common.py +202 -105
- kaa/tasks/produce/in_purodyuusu.py +35 -17
- kaa/tasks/produce/non_lesson_actions.py +10 -33
- kaa/tasks/produce/p_drink.py +5 -1
- kaa/tasks/produce/produce.py +2 -1
- kaa/tasks/start_game.py +2 -1
- kaa/util/reactive.py +182 -0
- {ksaa-2025.11b1.dist-info → ksaa-2025.11.post1.dist-info}/METADATA +27 -24
- {ksaa-2025.11b1.dist-info → ksaa-2025.11.post1.dist-info}/RECORD +352 -181
- /kaa/sprites/{35341839-4469-4ab6-aa40-33642fe43e82.png → 01e93c2c-28dc-41f8-8f9a-ec62ec12aa01.png} +0 -0
- /kaa/sprites/{68d9f340-a3d2-4708-8eb1-c1ed857decda.png → 02ac01e0-00b0-46d8-a6db-56248c843c6d.png} +0 -0
- /kaa/sprites/{39f6d657-3b3e-40aa-849b-7ad87a0be1d0.png → 033e73d1-9f45-4bca-bf96-6778410f2fc4.png} +0 -0
- /kaa/sprites/{799fe395-2264-4bc5-b515-813dadda8fe1.png → 04036690-5b0f-4ee0-a9d0-022ee822bf0e.png} +0 -0
- /kaa/sprites/{256ffeba-8e9e-4cc5-8a1c-9eaee427f1a5.png → 041bd3fc-d040-4773-8641-4e4509300d2f.png} +0 -0
- /kaa/sprites/{5ffd3f29-db4f-4f66-b9ed-be5a70b7ebf9.png → 04974917-b1e8-4ccc-807b-6f651026c955.png} +0 -0
- /kaa/sprites/{8be81341-a74d-42c8-8231-5d1854bc08e7.png → 04c4e4c2-9908-4be7-bcbe-4d926ca76737.png} +0 -0
- /kaa/sprites/{043e753e-db15-45ba-8513-53c3fc9c7f3c.png → 05b97cdf-f7df-4d91-9ec8-5e9594a46382.png} +0 -0
- /kaa/sprites/{5431dc38-c257-40b3-8f7b-8bceaa7fe587.png → 061b032f-860b-4c53-889b-aa126797f062.png} +0 -0
- /kaa/sprites/{cb6dffd9-6474-4d09-aee6-26352ea51d31.png → 07b43eb9-db32-4046-96d3-9f4314bfd80a.png} +0 -0
- /kaa/sprites/{3e087b8d-420d-48ff-b526-29c4a65d8cbe.png → 08b12ded-8230-4c7e-bb9f-27c85b0fdabb.png} +0 -0
- /kaa/sprites/{68e20ebf-02fd-46a1-88d7-b4472824e7bc.png → 09364c3a-f892-4911-abdc-2f5fea09289f.png} +0 -0
- /kaa/sprites/{c69dcdcf-42a7-420e-aa8e-bb8639ea80b6.png → 09d2a63d-d2f0-4b97-b3cb-22a61b1530f7.png} +0 -0
- /kaa/sprites/{d644faa3-ff16-417f-928c-4c62b040bfdb.png → 0cad6e46-276f-424e-a79e-d272ebaa7c8e.png} +0 -0
- /kaa/sprites/{db6707a2-2964-4919-9992-4d801fa43dae.png → 0e49fbde-6be6-42b3-b8d1-36e0cb9cc35d.png} +0 -0
- /kaa/sprites/{cd00a2d7-af48-48b1-b2e1-5360ceed249f.png → 0e51d671-928c-4972-8ac0-de446202070b.png} +0 -0
- /kaa/sprites/{736a9daf-05d6-46ba-810b-5a8f509152d1.png → 0e6f8981-f46c-4c7d-9d90-fe349f0a1d77.png} +0 -0
- /kaa/sprites/{92c3de1b-eed1-45b9-82e0-c9e97bb479e7.png → 0e9e3dbf-6e94-4a12-b558-3d8ab500c0a6.png} +0 -0
- /kaa/sprites/{913dbd4e-ebb1-4c9f-b145-9960cde59c17.png → 0eafb6c1-9d85-4fe0-8011-7235704ca9d3.png} +0 -0
- /kaa/sprites/{ec3cad5f-e0c9-4577-8499-79b50248344e.png → 1002a830-1ad5-47a7-b7dd-ed2989e6fc1b.png} +0 -0
- /kaa/sprites/{e5e49b44-dcc2-4e77-9180-0d2beaa3f9ad.png → 10943367-c1d8-41c7-a831-d5d05288875a.png} +0 -0
- /kaa/sprites/{c1d502eb-c77f-45cb-86b5-11b4a8a3aef5.png → 10f37db0-8c3e-4790-a5c3-cdb841f106a7.png} +0 -0
- /kaa/sprites/{802db04f-77c2-46a4-a6eb-f81d48ea03ce.png → 11f65378-b982-4936-9ac7-68560a74a042.png} +0 -0
- /kaa/sprites/{1befe09b-cb77-417a-b21e-7746804d4e03.png → 1660acf7-a420-4d92-a90c-55c5ff208da6.png} +0 -0
- /kaa/sprites/{16a0fd47-e85b-4848-8894-9d071ea993ac.png → 170d28bf-d262-4bf1-b35f-8f3d4b4fff6e.png} +0 -0
- /kaa/sprites/{5906d986-d0e5-452d-a7c4-ddeb7af8751d.png → 182d8c71-5ce5-4ee1-9f66-ef99aadae654.png} +0 -0
- /kaa/sprites/{cfe3563d-a24b-4197-a0cb-5628bd990c08.png → 18d26894-fd12-4644-8269-a09d11be9520.png} +0 -0
- /kaa/sprites/{8e5e968b-edad-4c03-abc8-3f2a7e8879ae.png → 1b0dd18b-eb41-4c9c-b031-bab91c93fd5d.png} +0 -0
- /kaa/sprites/{3fa5f81c-9223-44ba-bf07-71932350e845.png → 1e7a6e19-760c-4fbc-b0f1-f620f51056b9.png} +0 -0
- /kaa/sprites/{9e7eaa8e-3178-44da-a5ec-34b889f8facf.png → 1fbe13d6-3a4d-4935-b687-a76a76a1e32c.png} +0 -0
- /kaa/sprites/{1ad89ee4-1bb1-41d2-a92c-79caf6baa38a.png → 1fe31432-a050-48db-acc1-becde42deaf9.png} +0 -0
- /kaa/sprites/{94d54ba7-0ccf-4fd9-a5bf-488bac1364c8.png → 20146fe6-e62b-4c57-b229-901994903b70.png} +0 -0
- /kaa/sprites/{6c926e92-9af9-402d-8512-6417ca116928.png → 20c673e9-fcbe-469b-be35-7844a1d5a9cd.png} +0 -0
- /kaa/sprites/{572a921d-633f-4465-b177-7a0d9ad7e099.png → 21747ae5-d94d-45d1-bda8-939389dc4874.png} +0 -0
- /kaa/sprites/{aa1624ff-88b0-447b-8e2b-8a50fd9e4062.png → 21fbbe96-02bf-4835-aa04-068bc5cc6ca3.png} +0 -0
- /kaa/sprites/{3b4dc708-1d34-4a88-9fe3-d8de2ec1d5c8.png → 24be7d90-7944-4a0a-a60c-67c9737b322c.png} +0 -0
- /kaa/sprites/{b59c0e9b-1f20-4194-ab37-286f505fa656.png → 24d6a47c-2099-45e2-9a67-b37767f459fc.png} +0 -0
- /kaa/sprites/{023b8f4c-15ab-4845-b141-446c861ad475.png → 2568d3d3-b642-4ea4-b929-4dee0b09738a.png} +0 -0
- /kaa/sprites/{7d7df15f-707e-4e27-826f-21e42af1dae0.png → 263b1037-fb51-4eb1-8c71-5232b03235d2.png} +0 -0
- /kaa/sprites/{f0aef696-2106-46a4-8b7f-9f16b6c89d3f.png → 27dbd535-7f95-4698-8fea-2bed67dd6968.png} +0 -0
- /kaa/sprites/{81686816-c723-47d1-9824-a68d9ebe1bd4.png → 286801f7-3af5-4cd0-9c25-46c12c2cd8f8.png} +0 -0
- /kaa/sprites/{dc97fea3-898f-4135-9c40-ad41570ab4ae.png → 298182ae-747a-44e3-8511-a64d3532b8ac.png} +0 -0
- /kaa/sprites/{8e019262-ad23-4cbb-84da-86b34775a91e.png → 2d3470f8-a714-4175-a8fe-71eef80921b6.png} +0 -0
- /kaa/sprites/{01247ebe-8d63-4573-90f4-d8dc2b7ca14c.png → 2e3b2982-d14b-4b49-bb64-da8178311d75.png} +0 -0
- /kaa/sprites/{fcc72120-2a77-4c26-a27e-e1027c6088c0.png → 2e41df89-a8d7-4e7e-96cb-7f551414823b.png} +0 -0
- /kaa/sprites/{31f2de0a-567b-425a-9be6-536e4532d813.png → 31e02e56-f266-47b5-8b10-fe79fe06d614.png} +0 -0
- /kaa/sprites/{7daaca55-e3fd-4e12-bf31-872105ceb726.png → 3314dc6c-868f-4045-9f60-1f3a17fed324.png} +0 -0
- /kaa/sprites/{fdf0da06-f088-424f-9941-8c883fea3db3.png → 358f1561-c16f-45a0-842d-d62fc735dc80.png} +0 -0
- /kaa/sprites/{51b95c81-4ff9-434c-ade2-3518e63337cb.png → 3782897a-f1c2-4f05-a02d-4c760672f52a.png} +0 -0
- /kaa/sprites/{847eb5c0-0350-4b7c-9c9c-43c796709795.png → 385e60df-2063-4caf-b1ea-e6ac909bc49d.png} +0 -0
- /kaa/sprites/{8e4d8a0f-4a9d-4562-9234-63806b11d85f.png → 39450419-26b5-4fbd-a5d4-1bab369ced30.png} +0 -0
- /kaa/sprites/{424a0ef5-102d-4734-a731-2b3b3c7c9682.png → 397c0e24-f35a-48c9-a576-aa1fcfc517b5.png} +0 -0
- /kaa/sprites/{23b9cda9-8be8-438e-8e54-57d91a4bd875.png → 3adef8f4-629d-4cb7-b54a-dadabfea155e.png} +0 -0
- /kaa/sprites/{2234f709-1703-4589-905c-175f4db09b1b.png → 3b86b4ac-aa29-4309-82da-f47a174d88cc.png} +0 -0
- /kaa/sprites/{e933cd55-e47a-4327-89d7-b25995cb4a3f.png → 3c6bbcea-488d-4df8-ab40-21e263aa0b16.png} +0 -0
- /kaa/sprites/{49bde219-f9a3-41b5-84b8-e417160a0f40.png → 3db54e0b-672d-4dfd-8a9b-5db37a08be74.png} +0 -0
- /kaa/sprites/{2204967a-a0ee-4dd3-aecb-4d531e8e954c.png → 402d430d-b507-4aa6-b3e1-db66b38c71b4.png} +0 -0
- /kaa/sprites/{70768479-5d7a-4941-8774-ad556c47bee2.png → 414140a2-de67-4c7f-a7f6-c8b30a6c8d6a.png} +0 -0
- /kaa/sprites/{dd7bd6cd-90f1-4773-9b68-5df7f2f84da5.png → 4147514f-4f3f-4dd5-952b-0f2cf5f62181.png} +0 -0
- /kaa/sprites/{0562f69f-0300-4a2b-8252-63f3e7180e4c.png → 43e53b71-9d69-4f4f-b217-a1abeea8991e.png} +0 -0
- /kaa/sprites/{55c3af20-58dc-4407-a383-312a57417c39.png → 44fab632-3920-4cd8-9967-f7a8a1ee29a0.png} +0 -0
- /kaa/sprites/{645909d7-b960-46c7-b208-db44b6b7feec.png → 45f705f9-58fb-4729-ae55-ee10848678d6.png} +0 -0
- /kaa/sprites/{da48db0d-09d9-47c3-9e08-8b69ad547be6.png → 4678a5fa-5b1c-4fdc-b7c4-e0b820039546.png} +0 -0
- /kaa/sprites/{37215a56-f8e1-4f22-a148-9894136f6ab1.png → 4738974e-60b8-4583-8548-94211c164291.png} +0 -0
- /kaa/sprites/{338d7e71-98ce-4cd1-9954-bf7155150780.png → 474c1678-9c36-495b-aef2-cadbb47b237d.png} +0 -0
- /kaa/sprites/{01256311-237c-476f-96ce-4136dc4bfbd3.png → 47783412-9cc7-4ba0-904d-8cd300222889.png} +0 -0
- /kaa/sprites/{9f7150bc-c0b8-48d6-862c-456aaf518b2b.png → 47ed66a4-9e7e-4646-b554-469dc86322db.png} +0 -0
- /kaa/sprites/{5930140e-effe-4bcf-b0be-c20d3990d833.png → 4d0074ad-6db4-4060-b71a-05c0e36e57a6.png} +0 -0
- /kaa/sprites/{22dc4cfe-8c66-4461-8660-e2d11bbe6154.png → 4f2f8328-a698-40d3-a40f-1f1ae77dc843.png} +0 -0
- /kaa/sprites/{694879e8-ecca-45e2-8ea4-1b447fd43ace.png → 52d0ff68-7a55-4d53-bc20-a1fa05cfe876.png} +0 -0
- /kaa/sprites/{962aa0b9-1dd3-4260-a4fb-c069c26e5a84.png → 52d737a7-5b0b-4ce0-ae3f-5d4048060f12.png} +0 -0
- /kaa/sprites/{87f3c1ae-5117-4871-a7d6-3f5ff0c9f9fb.png → 54a9cae1-62e5-4546-a46a-a5157f51e8b4.png} +0 -0
- /kaa/sprites/{e7f2734f-9fdc-4521-8d7e-8b0fe270a223.png → 56d35e14-ada9-4bfa-a48f-e4601054e7eb.png} +0 -0
- /kaa/sprites/{3b4f90c9-6de7-4ac3-8e41-5f8757bf3f3e.png → 575784c1-7c4a-4484-9f38-aa3c280ce56e.png} +0 -0
- /kaa/sprites/{57c81080-7b53-4286-8fa5-848ad63e4774.png → 577417ee-6635-4cb4-9f28-d1e1b47ae2cd.png} +0 -0
- /kaa/sprites/{72634cb3-4c76-4ca2-8898-ebb837ec19e3.png → 58358122-984b-4c31-91d7-eaf5c8c9353d.png} +0 -0
- /kaa/sprites/{179c0fff-ebd2-4a16-8db2-297552cca218.png → 5a06a662-ffa9-49a9-a86d-136e5983abdd.png} +0 -0
- /kaa/sprites/{2b6d2eb0-bcf7-4bea-b037-6293d9c6d728.png → 5c8eebc5-6d5e-445e-a3d1-66dce2bb6338.png} +0 -0
- /kaa/sprites/{2a8626df-056c-46a2-aaf3-0060a5aef6a3.png → 5d2b03a2-acb6-4bd2-86e8-1b203d1aeaec.png} +0 -0
- /kaa/sprites/{0af1d573-1dc7-427e-997d-173308ea3649.png → 5f02656f-1314-44d0-ae31-a176c24d758c.png} +0 -0
- /kaa/sprites/{84cabff2-7a1b-4018-b74b-46f4db06304f.png → 608c12e2-95dd-4efa-93b2-e648e9583062.png} +0 -0
- /kaa/sprites/{8f7b55d8-0143-4d27-bef8-560d4d510500.png → 647bb09a-13f8-4d54-a8ac-5b534f1a8d87.png} +0 -0
- /kaa/sprites/{1cf03f98-63e9-467c-804d-c74dd97b69bd.png → 6483c406-26cc-44ee-ad12-2a30ec47aedb.png} +0 -0
- /kaa/sprites/{889a4153-b713-49cb-a4d5-e302bcdd002d.png → 67d6a201-dfb9-4c88-b42b-d968cf9a034c.png} +0 -0
- /kaa/sprites/{ea430652-e263-4a15-bb6f-8a8807be6c8f.png → 6a93b483-0848-45e4-a937-51850f296c3d.png} +0 -0
- /kaa/sprites/{e4dc3b35-195c-415f-9484-c2459bd8675a.png → 6b4e4351-b370-48cd-8e8f-ca663d44aa0c.png} +0 -0
- /kaa/sprites/{f6b042a8-a91e-4811-99f9-18bbb5197468.png → 6c961dee-87f3-42f1-acef-9fe7d6be4df1.png} +0 -0
- /kaa/sprites/{ab237c6d-c4d8-4716-8ef7-99b8e995c9a7.png → 6d22b7ee-6e0f-4f5d-96a4-d4cba26a4d04.png} +0 -0
- /kaa/sprites/{d7750f81-de10-4d6f-9cc7-35223bda9d70.png → 6d5a3e08-257c-4394-96a6-e0719a66e5ae.png} +0 -0
- /kaa/sprites/{847226a3-b7d2-4156-b732-9215a3e14f3a.png → 71d0d086-50f1-4f50-bb24-a0190827bd08.png} +0 -0
- /kaa/sprites/{2cec1d6a-9e8c-49b3-b885-0b0d7c4b95ee.png → 71f87e1c-77f1-45c7-bb9c-16f14498682b.png} +0 -0
- /kaa/sprites/{30e12bf1-8fa5-4de1-8d7b-28fa0fec0cb6.png → 737570a7-b8f9-4cd7-b5bd-f40cd51b49f8.png} +0 -0
- /kaa/sprites/{ae1e70bc-f735-4749-8c23-95735b91897a.png → 745ee069-0f22-4b99-9327-513f365eb922.png} +0 -0
- /kaa/sprites/{8bd22fe1-b544-4d2e-b74a-34f3cf0eb512.png → 7601152e-a216-4bf8-92a6-4e3e6ea01d3d.png} +0 -0
- /kaa/sprites/{bfdc9b53-2fe5-43f1-8588-7ab71217d31c.png → 7a23d548-4395-40cc-ac19-4497fa3d9fe2.png} +0 -0
- /kaa/sprites/{96704aa3-b5ad-4e34-bb88-fad766415362.png → 7a7871dd-fd07-4234-bd01-c3c9e41bad45.png} +0 -0
- /kaa/sprites/{43a367e1-91dd-495e-8c30-41903f75a99a.png → 7d3c3a12-8d0f-48a7-9fd4-66db5e58488f.png} +0 -0
- /kaa/sprites/{756f4ca7-acac-48e1-8bcd-1c5cd8937e3a.png → 7d9f8ea3-1fdf-4675-8ddf-38393e235746.png} +0 -0
- /kaa/sprites/{31e3ac2b-ecd4-4c37-88bc-985ef32e73a3.png → 83f258af-35b8-4918-a971-80ea938a854e.png} +0 -0
- /kaa/sprites/{91b30f5e-31b2-4756-a3f7-f0f82a335442.png → 848a6c94-97a5-44f7-b84b-2f3283dc446b.png} +0 -0
- /kaa/sprites/{8ed51be4-815c-4a3d-805e-030fdfa341e2.png → 86a56df9-47ff-4741-822d-5b7e024d1598.png} +0 -0
- /kaa/sprites/{f0462447-5226-4819-a39b-19ab90583f83.png → 8b04d1a8-6cd6-4d2e-91e7-bdc58c46d939.png} +0 -0
- /kaa/sprites/{4a081370-b0a1-4067-8470-e3007cc68a12.png → 8b60ce9f-09c0-48a0-93f0-d51e0aa16afb.png} +0 -0
- /kaa/sprites/{91a50322-52d9-4516-9e46-bc121f20667d.png → 8c59d3ca-baff-4260-aa0a-6cedac1c2771.png} +0 -0
- /kaa/sprites/{f635499a-943d-47da-952a-1feb58daa25b.png → 8d7b4761-2555-4398-bb74-b70de3b75e22.png} +0 -0
- /kaa/sprites/{13cb0309-b713-4725-b10b-26afe46eb9c0.png → 901a2e7a-37f3-4dda-a58b-5a7644ead6b9.png} +0 -0
- /kaa/sprites/{cd0e8663-2ea1-436a-b9fb-3caa0c3ed9e8.png → 9cc77f5e-e7d0-4de4-aeb8-587ab8cb212a.png} +0 -0
- /kaa/sprites/{9991b19c-7330-42c4-9d7d-db3cb00103b7.png → 9e45adeb-4637-4b8b-a687-f1d2cd8c6c18.png} +0 -0
- /kaa/sprites/{5734e48a-1e58-42de-be7b-b7db67db4a01.png → a006054e-61fb-4d2b-a98e-45ce3c663662.png} +0 -0
- /kaa/sprites/{d1ea0ea6-4a6a-4036-b140-922c95a648b5.png → a0f98517-e4cf-422c-b29f-395a55939772.png} +0 -0
- /kaa/sprites/{3aed50a2-d640-4178-9b8a-4dd7973eebf1.png → a94d76ef-db70-45a9-aeca-ba16344cc572.png} +0 -0
- /kaa/sprites/{978873bb-e4d0-451b-9126-6977144f5395.png → afe7f086-723e-4999-a7aa-3342a797d828.png} +0 -0
- /kaa/sprites/{dce410ee-fa56-41c4-b75e-e1bff79cd94f.png → b2036053-36fb-4aa7-8348-e31942731a93.png} +0 -0
- /kaa/sprites/{ad94041c-f30b-40b9-b11a-1a26e9962274.png → b6da02bf-3f43-4ed0-9b13-f15becb42ce9.png} +0 -0
- /kaa/sprites/{a5694c76-3c5d-462e-81d5-1e0e6cef0ec9.png → ba2fd21c-6228-4e2d-b2db-a6d085cb38a6.png} +0 -0
- /kaa/sprites/{cba0646d-dffe-4c5b-a44d-1f8d827624a6.png → bb224de8-828e-4bc5-a986-632c72fc9157.png} +0 -0
- /kaa/sprites/{5bf2a814-df85-4d0a-b4b5-8883ac2ee434.png → bcc6ee72-ad5a-4d5c-b6c7-1b3fdfc5fa81.png} +0 -0
- /kaa/sprites/{edcec31d-d5de-4f22-b666-3e3c656e06d8.png → bebf9f6d-7cca-44c5-9b9f-fa36e29e97b3.png} +0 -0
- /kaa/sprites/{9008fbb2-f23f-424f-9be7-5bae6a3697ab.png → c4d0b0c9-ffbe-4b6c-9bf3-b05919e1a07c.png} +0 -0
- /kaa/sprites/{f32a41a2-c482-41ba-b718-28f048f5148c.png → c893e762-f328-4ef6-b862-5da8eb049f9c.png} +0 -0
- /kaa/sprites/{2d0e9d49-365a-4bcb-a416-38b87defaa3c.png → c944d298-a46b-4799-aea3-eec22fc7d4ac.png} +0 -0
- /kaa/sprites/{5c310fe5-7e92-4167-9eba-6e8e14a2863a.png → d28a18db-0f66-45a6-b3cd-69173ecdd790.png} +0 -0
- /kaa/sprites/{464b1dd8-ca2e-41e9-a5b5-90545c584db7.png → d8d5019c-52e6-4767-a9aa-d8da6ffcbd00.png} +0 -0
- /kaa/sprites/{dd873ac0-ffba-4335-9cf2-2162c6835ed8.png → d9cb2f43-2786-48d8-90f8-8cf1929f6172.png} +0 -0
- /kaa/sprites/{e13fc34b-accc-4986-865d-f8d8410b45e9.png → dbc5db78-81f5-41e6-bdc4-dafaa9173320.png} +0 -0
- /kaa/sprites/{e9310e38-a418-4561-bf33-eb3e6dccf477.png → e2ac106f-edeb-4375-af8c-45f33e9bfae6.png} +0 -0
- /kaa/sprites/{d81b1325-e57a-4f22-93e1-6ad4baa28935.png → e8a33d3f-a4fb-4851-b47a-b5f3d85e882f.png} +0 -0
- /kaa/sprites/{2289d38f-dc98-4310-9f34-4cf5023f8545.png → f7facb3a-1b41-4409-b128-d4ad03245845.png} +0 -0
- {ksaa-2025.11b1.dist-info → ksaa-2025.11.post1.dist-info}/WHEEL +0 -0
- {ksaa-2025.11b1.dist-info → ksaa-2025.11.post1.dist-info}/entry_points.txt +0 -0
- {ksaa-2025.11b1.dist-info → ksaa-2025.11.post1.dist-info}/licenses/LICENSE +0 -0
- {ksaa-2025.11b1.dist-info → ksaa-2025.11.post1.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,697 @@
|
|
|
1
|
+
import json
|
|
2
|
+
from typing import List, Optional, Any, Dict, TypedDict, Union
|
|
3
|
+
import gradio as gr
|
|
4
|
+
|
|
5
|
+
# --- Types ---
|
|
6
|
+
|
|
7
|
+
class SelectItem(TypedDict):
|
|
8
|
+
label: str
|
|
9
|
+
value: str
|
|
10
|
+
icon: Optional[str]
|
|
11
|
+
size: Optional[str] # e.g. "32px", "2rem"
|
|
12
|
+
|
|
13
|
+
class SelectCategory(TypedDict):
|
|
14
|
+
label: str
|
|
15
|
+
icon: Optional[str]
|
|
16
|
+
children: List[SelectItem]
|
|
17
|
+
|
|
18
|
+
# --- Styles (Converted from Tailwind to CSS) ---
|
|
19
|
+
|
|
20
|
+
CSS = """
|
|
21
|
+
/* Scoped styles for CategorizedSelect */
|
|
22
|
+
.gs-wrapper {
|
|
23
|
+
position: relative;
|
|
24
|
+
font-family: 'Inter', -apple-system, sans-serif;
|
|
25
|
+
width: 100%;
|
|
26
|
+
color: #1f2937;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/* Input Area */
|
|
30
|
+
.gs-input-wrapper {
|
|
31
|
+
position: relative;
|
|
32
|
+
display: flex;
|
|
33
|
+
align-items: center;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.gs-input {
|
|
37
|
+
width: 100%;
|
|
38
|
+
background-color: #ffffff;
|
|
39
|
+
color: #1f2937;
|
|
40
|
+
border: 1px solid #d1d5db;
|
|
41
|
+
border-radius: 0.375rem;
|
|
42
|
+
padding: 0.5rem 0.75rem;
|
|
43
|
+
padding-right: 2.5rem; /* space for icon */
|
|
44
|
+
font-size: 0.875rem;
|
|
45
|
+
line-height: 1.25rem;
|
|
46
|
+
box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
|
|
47
|
+
transition: all 0.15s ease-in-out;
|
|
48
|
+
outline: none;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
.gs-input:hover {
|
|
52
|
+
border-color: #93c5fd;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.gs-input:focus {
|
|
56
|
+
border-color: #60a5fa;
|
|
57
|
+
box-shadow: 0 0 0 2px #dbeafe;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
.gs-icon-container {
|
|
61
|
+
position: absolute;
|
|
62
|
+
right: 0.75rem;
|
|
63
|
+
display: flex;
|
|
64
|
+
align-items: center;
|
|
65
|
+
justify-content: center;
|
|
66
|
+
color: #9ca3af;
|
|
67
|
+
pointer-events: none;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
.gs-clear-btn {
|
|
71
|
+
cursor: pointer;
|
|
72
|
+
pointer-events: auto;
|
|
73
|
+
color: #9ca3af;
|
|
74
|
+
display: none; /* hidden by default */
|
|
75
|
+
}
|
|
76
|
+
.gs-clear-btn:hover { color: #4b5563; }
|
|
77
|
+
|
|
78
|
+
.gs-arrow-icon {
|
|
79
|
+
transition: transform 0.2s;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
.gs-arrow-icon.rotate-180 {
|
|
83
|
+
transform: rotate(180deg);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
/* Dropdown Panel */
|
|
87
|
+
.gs-dropdown-panel {
|
|
88
|
+
position: absolute;
|
|
89
|
+
z-index: 50;
|
|
90
|
+
left: 0;
|
|
91
|
+
right: 0;
|
|
92
|
+
margin-top: 0.25rem;
|
|
93
|
+
background-color: white;
|
|
94
|
+
border: 1px solid #e5e7eb;
|
|
95
|
+
border-radius: 0.5rem;
|
|
96
|
+
box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
|
|
97
|
+
display: none; /* hidden by default */
|
|
98
|
+
height: 24rem; /* h-96 */
|
|
99
|
+
overflow: hidden;
|
|
100
|
+
flex-direction: row;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
.gs-dropdown-panel.open {
|
|
104
|
+
display: flex;
|
|
105
|
+
animation: fadeIn 0.15s ease-out forwards;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
@media (max-width: 768px) {
|
|
109
|
+
.gs-dropdown-panel {
|
|
110
|
+
flex-direction: column;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
@keyframes fadeIn {
|
|
115
|
+
from { opacity: 0; transform: translateY(-4px); }
|
|
116
|
+
to { opacity: 1; transform: translateY(0); }
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
/* Category List (Left) */
|
|
120
|
+
.gs-category-col {
|
|
121
|
+
width: 30%;
|
|
122
|
+
border-right: 1px solid #f3f4f6;
|
|
123
|
+
background-color: rgba(249, 250, 251, 0.5); /* bg-gray-50/50 */
|
|
124
|
+
overflow-y: auto;
|
|
125
|
+
padding: 0.5rem;
|
|
126
|
+
display: flex;
|
|
127
|
+
flex-direction: column;
|
|
128
|
+
gap: 0.25rem;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
.gs-cat-item {
|
|
132
|
+
display: flex;
|
|
133
|
+
align-items: center;
|
|
134
|
+
padding: 0.625rem 0.75rem;
|
|
135
|
+
border-radius: 0.5rem;
|
|
136
|
+
cursor: pointer;
|
|
137
|
+
font-size: 0.875rem;
|
|
138
|
+
user-select: none;
|
|
139
|
+
color: #4b5563;
|
|
140
|
+
transition: all 0.15s;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
.gs-cat-item:hover {
|
|
144
|
+
background-color: #f3f4f6;
|
|
145
|
+
color: #111827;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
.gs-cat-item.active {
|
|
149
|
+
background-color: #ffedd5; /* orange-100 */
|
|
150
|
+
color: #c2410c; /* orange-700 */
|
|
151
|
+
box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
|
|
152
|
+
font-weight: 600;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
.gs-cat-icon {
|
|
156
|
+
margin-right: 0.75rem;
|
|
157
|
+
display: flex;
|
|
158
|
+
align-items: center;
|
|
159
|
+
color: #9ca3af;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
.gs-cat-item.active .gs-cat-icon {
|
|
163
|
+
color: #f97316; /* orange-500 */
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
.gs-cat-indicator {
|
|
167
|
+
width: 0.375rem;
|
|
168
|
+
height: 0.375rem;
|
|
169
|
+
border-radius: 9999px;
|
|
170
|
+
background-color: #fb923c; /* orange-400 */
|
|
171
|
+
margin-left: 0.5rem;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
/* Items Grid (Right) */
|
|
175
|
+
.gs-items-col {
|
|
176
|
+
width: 70%;
|
|
177
|
+
background-color: white;
|
|
178
|
+
overflow-y: auto;
|
|
179
|
+
padding: 1rem;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
.gs-items-grid {
|
|
183
|
+
display: grid;
|
|
184
|
+
grid-template-columns: repeat(3, minmax(0, 1fr));
|
|
185
|
+
gap: 0.75rem;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
.gs-item-card {
|
|
189
|
+
border: 1px solid #f3f4f6;
|
|
190
|
+
background-color: white;
|
|
191
|
+
border-radius: 0.5rem;
|
|
192
|
+
padding: 0.75rem;
|
|
193
|
+
display: flex;
|
|
194
|
+
flex-direction: column;
|
|
195
|
+
align-items: center;
|
|
196
|
+
justify-content: center;
|
|
197
|
+
text-align: center;
|
|
198
|
+
cursor: pointer;
|
|
199
|
+
transition: all 0.2s;
|
|
200
|
+
height: 100%;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
.gs-item-card:hover {
|
|
204
|
+
background-color: #fff7ed; /* orange-50 */
|
|
205
|
+
border-color: #fed7aa; /* orange-200 */
|
|
206
|
+
transform: translateY(-1px);
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
.gs-item-icon {
|
|
210
|
+
margin-bottom: 0.5rem;
|
|
211
|
+
color: #9ca3af;
|
|
212
|
+
transition: color 0.2s, transform 0.2s;
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
.gs-item-card:hover .gs-item-icon {
|
|
216
|
+
color: #f97316; /* orange-500 */
|
|
217
|
+
transform: scale(1.05);
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
.gs-item-label {
|
|
221
|
+
font-size: 0.75rem;
|
|
222
|
+
font-weight: 500;
|
|
223
|
+
color: #4b5563;
|
|
224
|
+
display: -webkit-box;
|
|
225
|
+
-webkit-line-clamp: 2;
|
|
226
|
+
-webkit-box-orient: vertical;
|
|
227
|
+
overflow: hidden;
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
.gs-item-card:hover .gs-item-label {
|
|
231
|
+
color: #111827;
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
/* Empty State */
|
|
235
|
+
.gs-empty-state {
|
|
236
|
+
height: 100%;
|
|
237
|
+
display: flex;
|
|
238
|
+
flex-direction: column;
|
|
239
|
+
align-items: center;
|
|
240
|
+
justify-content: center;
|
|
241
|
+
color: #9ca3af;
|
|
242
|
+
font-size: 0.875rem;
|
|
243
|
+
}
|
|
244
|
+
.gs-empty-icon {
|
|
245
|
+
width: 3rem;
|
|
246
|
+
height: 3rem;
|
|
247
|
+
border-radius: 9999px;
|
|
248
|
+
background-color: #f9fafb;
|
|
249
|
+
display: flex;
|
|
250
|
+
align-items: center;
|
|
251
|
+
justify-content: center;
|
|
252
|
+
margin-bottom: 0.75rem;
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
/* Scrollbar */
|
|
256
|
+
.gs-scroll::-webkit-scrollbar { width: 6px; height: 6px; }
|
|
257
|
+
.gs-scroll::-webkit-scrollbar-track { background: transparent; }
|
|
258
|
+
.gs-scroll::-webkit-scrollbar-thumb { background-color: #e5e7eb; border-radius: 20px; }
|
|
259
|
+
.gs-scroll::-webkit-scrollbar-thumb:hover { background-color: #d1d5db; }
|
|
260
|
+
|
|
261
|
+
.hidden { display: none !important; }
|
|
262
|
+
"""
|
|
263
|
+
|
|
264
|
+
# --- Javascript (Web Component Definition) ---
|
|
265
|
+
|
|
266
|
+
JS_CLASS_DEF = """
|
|
267
|
+
if (!customElements.get('gradio-search-select')) {
|
|
268
|
+
class GradioSearchSelect extends HTMLElement {
|
|
269
|
+
constructor() {
|
|
270
|
+
super();
|
|
271
|
+
this._data = [];
|
|
272
|
+
this._value = null;
|
|
273
|
+
this._selectedItem = null;
|
|
274
|
+
this._activeCategoryIndex = 0;
|
|
275
|
+
this._isOpen = false;
|
|
276
|
+
this._searchTerm = '';
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
static get observedAttributes() {
|
|
280
|
+
return ['initial-data', 'placeholder', 'value'];
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
attributeChangedCallback(name, oldValue, newValue) {
|
|
284
|
+
if (oldValue === newValue) return;
|
|
285
|
+
if (name === 'initial-data') {
|
|
286
|
+
try {
|
|
287
|
+
this.data = JSON.parse(newValue);
|
|
288
|
+
} catch (e) {
|
|
289
|
+
console.error('Invalid JSON in initial-data', e);
|
|
290
|
+
}
|
|
291
|
+
} else if (name === 'placeholder') {
|
|
292
|
+
const input = this.querySelector('.gs-input');
|
|
293
|
+
if (input) input.placeholder = newValue;
|
|
294
|
+
} else if (name === 'value') {
|
|
295
|
+
// External update to value
|
|
296
|
+
this.value = newValue;
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
connectedCallback() {
|
|
301
|
+
this.render();
|
|
302
|
+
|
|
303
|
+
this._handleDocumentClick = (e) => {
|
|
304
|
+
if (!e.composedPath().includes(this)) {
|
|
305
|
+
this.close();
|
|
306
|
+
}
|
|
307
|
+
};
|
|
308
|
+
document.addEventListener('click', this._handleDocumentClick);
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
disconnectedCallback() {
|
|
312
|
+
document.removeEventListener('click', this._handleDocumentClick);
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
get data() { return this._data; }
|
|
316
|
+
set data(val) {
|
|
317
|
+
this._data = Array.isArray(val) ? val : [];
|
|
318
|
+
this._activeCategoryIndex = 0;
|
|
319
|
+
this.updateDropdown();
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
get value() { return this._value; }
|
|
323
|
+
set value(val) {
|
|
324
|
+
if (!val) {
|
|
325
|
+
this.clearSelection(false);
|
|
326
|
+
return;
|
|
327
|
+
}
|
|
328
|
+
|
|
329
|
+
let found = false;
|
|
330
|
+
// Search in data to find item metadata
|
|
331
|
+
if (this._data) {
|
|
332
|
+
for (const cat of this._data) {
|
|
333
|
+
const item = cat.children?.find(c => c.value === val);
|
|
334
|
+
if (item) {
|
|
335
|
+
this.selectItem(item, false); // Do not emit event if setting programmatically
|
|
336
|
+
found = true;
|
|
337
|
+
break;
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
if (!found) {
|
|
343
|
+
// If value set but item not found (or data not loaded yet), just set raw value
|
|
344
|
+
this._value = val;
|
|
345
|
+
const input = this.querySelector('.gs-input');
|
|
346
|
+
if (input) {
|
|
347
|
+
input.value = val;
|
|
348
|
+
this._updateInputState();
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
|
|
353
|
+
render() {
|
|
354
|
+
const placeholder = this.getAttribute('placeholder') || 'Select...';
|
|
355
|
+
|
|
356
|
+
this.innerHTML = `
|
|
357
|
+
<div class="gs-wrapper">
|
|
358
|
+
<div class="gs-input-wrapper">
|
|
359
|
+
<input
|
|
360
|
+
type="text"
|
|
361
|
+
class="gs-input"
|
|
362
|
+
placeholder="${placeholder}"
|
|
363
|
+
autocomplete="off"
|
|
364
|
+
>
|
|
365
|
+
<div class="gs-icon-container">
|
|
366
|
+
<div class="gs-arrow-icon">
|
|
367
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 20 20" fill="currentColor">
|
|
368
|
+
<path fill-rule="evenodd" d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z" clip-rule="evenodd" />
|
|
369
|
+
</svg>
|
|
370
|
+
</div>
|
|
371
|
+
<div class="gs-clear-btn">
|
|
372
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 20 20" fill="currentColor">
|
|
373
|
+
<path fill-rule="evenodd" d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z" clip-rule="evenodd" />
|
|
374
|
+
</svg>
|
|
375
|
+
</div>
|
|
376
|
+
</div>
|
|
377
|
+
</div>
|
|
378
|
+
|
|
379
|
+
<div class="gs-dropdown-panel">
|
|
380
|
+
<div class="gs-category-col gs-scroll"></div>
|
|
381
|
+
<div class="gs-items-col gs-scroll">
|
|
382
|
+
<div class="gs-items-grid"></div>
|
|
383
|
+
<div class="gs-empty-state hidden">
|
|
384
|
+
<div class="gs-empty-icon">
|
|
385
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="none" viewBox="0 0 24 24" stroke="currentColor" style="opacity: 0.4;">
|
|
386
|
+
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z" />
|
|
387
|
+
</svg>
|
|
388
|
+
</div>
|
|
389
|
+
<p>��ƥ����</p>
|
|
390
|
+
</div>
|
|
391
|
+
</div>
|
|
392
|
+
</div>
|
|
393
|
+
</div>
|
|
394
|
+
`;
|
|
395
|
+
|
|
396
|
+
this._bindEvents();
|
|
397
|
+
this.updateDropdown();
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
_bindEvents() {
|
|
401
|
+
const input = this.querySelector('.gs-input');
|
|
402
|
+
const clearBtn = this.querySelector('.gs-clear-btn');
|
|
403
|
+
|
|
404
|
+
input.addEventListener('focus', () => this.open());
|
|
405
|
+
|
|
406
|
+
input.addEventListener('input', (e) => {
|
|
407
|
+
this._searchTerm = e.target.value.toLowerCase();
|
|
408
|
+
this._updateInputState();
|
|
409
|
+
this.open();
|
|
410
|
+
this.updateDropdown();
|
|
411
|
+
});
|
|
412
|
+
|
|
413
|
+
clearBtn.addEventListener('click', (e) => {
|
|
414
|
+
e.stopPropagation();
|
|
415
|
+
this.clearSelection(true);
|
|
416
|
+
this.close();
|
|
417
|
+
});
|
|
418
|
+
}
|
|
419
|
+
|
|
420
|
+
_updateInputState() {
|
|
421
|
+
const input = this.querySelector('.gs-input');
|
|
422
|
+
const arrowBtn = this.querySelector('.gs-arrow-icon');
|
|
423
|
+
const clearBtn = this.querySelector('.gs-clear-btn');
|
|
424
|
+
|
|
425
|
+
if (input.value && input.value.length > 0) {
|
|
426
|
+
arrowBtn.classList.add('hidden');
|
|
427
|
+
clearBtn.style.display = 'block';
|
|
428
|
+
} else {
|
|
429
|
+
arrowBtn.classList.remove('hidden');
|
|
430
|
+
clearBtn.style.display = 'none';
|
|
431
|
+
}
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
clearSelection(emitEvent = true) {
|
|
435
|
+
this._value = null;
|
|
436
|
+
this._selectedItem = null;
|
|
437
|
+
this._searchTerm = '';
|
|
438
|
+
|
|
439
|
+
const input = this.querySelector('.gs-input');
|
|
440
|
+
if (input) {
|
|
441
|
+
input.value = '';
|
|
442
|
+
this._updateInputState();
|
|
443
|
+
}
|
|
444
|
+
|
|
445
|
+
this.updateDropdown();
|
|
446
|
+
|
|
447
|
+
if (emitEvent) {
|
|
448
|
+
this.dispatchEvent(new CustomEvent('change', {
|
|
449
|
+
detail: { value: null, item: null },
|
|
450
|
+
bubbles: true
|
|
451
|
+
}));
|
|
452
|
+
}
|
|
453
|
+
}
|
|
454
|
+
|
|
455
|
+
open() {
|
|
456
|
+
if (this._isOpen) return;
|
|
457
|
+
this._isOpen = true;
|
|
458
|
+
const panel = this.querySelector('.gs-dropdown-panel');
|
|
459
|
+
const arrow = this.querySelector('.gs-arrow-icon');
|
|
460
|
+
panel.classList.add('open');
|
|
461
|
+
arrow.classList.add('rotate-180');
|
|
462
|
+
}
|
|
463
|
+
|
|
464
|
+
close() {
|
|
465
|
+
if (!this._isOpen) return;
|
|
466
|
+
this._isOpen = false;
|
|
467
|
+
const panel = this.querySelector('.gs-dropdown-panel');
|
|
468
|
+
const arrow = this.querySelector('.gs-arrow-icon');
|
|
469
|
+
panel.classList.remove('open');
|
|
470
|
+
arrow.classList.remove('rotate-180');
|
|
471
|
+
}
|
|
472
|
+
|
|
473
|
+
selectItem(item, emitEvent = true) {
|
|
474
|
+
this._value = item.value;
|
|
475
|
+
this._selectedItem = item;
|
|
476
|
+
|
|
477
|
+
const input = this.querySelector('.gs-input');
|
|
478
|
+
input.value = item.label;
|
|
479
|
+
this._updateInputState();
|
|
480
|
+
|
|
481
|
+
if (emitEvent) {
|
|
482
|
+
this.dispatchEvent(new CustomEvent('change', {
|
|
483
|
+
detail: { value: this._value, item: item },
|
|
484
|
+
bubbles: true
|
|
485
|
+
}));
|
|
486
|
+
}
|
|
487
|
+
|
|
488
|
+
this.close();
|
|
489
|
+
}
|
|
490
|
+
|
|
491
|
+
setCategory(index) {
|
|
492
|
+
this._activeCategoryIndex = index;
|
|
493
|
+
this.updateDropdown(true);
|
|
494
|
+
}
|
|
495
|
+
|
|
496
|
+
_renderIcon(iconStr, size = '1.25rem') {
|
|
497
|
+
if (!iconStr) return '';
|
|
498
|
+
if (iconStr.trim().startsWith('<')) {
|
|
499
|
+
return `<div style="width: ${size}; height: ${size}; display: flex; align-items: center; justify-content: center;">${iconStr}</div>`;
|
|
500
|
+
}
|
|
501
|
+
return `<img src="${iconStr}" style="width: ${size}; height: ${size}; object-fit: contain;" alt="icon">`;
|
|
502
|
+
}
|
|
503
|
+
|
|
504
|
+
updateDropdown() {
|
|
505
|
+
const catList = this.querySelector('.gs-category-col');
|
|
506
|
+
const itemsGrid = this.querySelector('.gs-items-grid');
|
|
507
|
+
const emptyState = this.querySelector('.gs-empty-state');
|
|
508
|
+
|
|
509
|
+
if (!this._data || this._data.length === 0) return;
|
|
510
|
+
|
|
511
|
+
// Render Categories
|
|
512
|
+
catList.innerHTML = this._data.map((cat, index) => {
|
|
513
|
+
const isActive = index === this._activeCategoryIndex;
|
|
514
|
+
const icon = this._renderIcon(cat.icon, '1.1rem');
|
|
515
|
+
const activeClass = isActive ? 'active' : '';
|
|
516
|
+
const indicator = isActive ? '<span class="gs-cat-indicator"></span>' : '';
|
|
517
|
+
|
|
518
|
+
return `
|
|
519
|
+
<div class="gs-cat-item ${activeClass}" data-index="${index}">
|
|
520
|
+
<span class="gs-cat-icon">${icon}</span>
|
|
521
|
+
<span style="flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;">${cat.label}</span>
|
|
522
|
+
${indicator}
|
|
523
|
+
</div>
|
|
524
|
+
`;
|
|
525
|
+
}).join('');
|
|
526
|
+
|
|
527
|
+
catList.querySelectorAll('.gs-cat-item').forEach(el => {
|
|
528
|
+
el.addEventListener('click', () => {
|
|
529
|
+
this.setCategory(parseInt(el.dataset.index));
|
|
530
|
+
});
|
|
531
|
+
});
|
|
532
|
+
|
|
533
|
+
// Render Items
|
|
534
|
+
const currentCategory = this._data[this._activeCategoryIndex];
|
|
535
|
+
let items = currentCategory ? currentCategory.children : [];
|
|
536
|
+
|
|
537
|
+
if (this._searchTerm) {
|
|
538
|
+
items = items.filter(item =>
|
|
539
|
+
item.label.toLowerCase().includes(this._searchTerm) ||
|
|
540
|
+
(item.value && item.value.toLowerCase().includes(this._searchTerm))
|
|
541
|
+
);
|
|
542
|
+
}
|
|
543
|
+
|
|
544
|
+
if (items.length === 0) {
|
|
545
|
+
itemsGrid.innerHTML = '';
|
|
546
|
+
itemsGrid.classList.add('hidden');
|
|
547
|
+
emptyState.classList.remove('hidden');
|
|
548
|
+
} else {
|
|
549
|
+
itemsGrid.classList.remove('hidden');
|
|
550
|
+
emptyState.classList.add('hidden');
|
|
551
|
+
|
|
552
|
+
itemsGrid.innerHTML = items.map((item, idx) => {
|
|
553
|
+
const iconSize = item.size || '2rem';
|
|
554
|
+
const icon = this._renderIcon(item.icon, iconSize);
|
|
555
|
+
|
|
556
|
+
return `
|
|
557
|
+
<div class="gs-item-card" data-idx="${idx}">
|
|
558
|
+
<div class="gs-item-icon">
|
|
559
|
+
${icon}
|
|
560
|
+
</div>
|
|
561
|
+
<span class="gs-item-label">${item.label}</span>
|
|
562
|
+
</div>
|
|
563
|
+
`;
|
|
564
|
+
}).join('');
|
|
565
|
+
|
|
566
|
+
itemsGrid.querySelectorAll('.gs-item-card').forEach((el, idx) => {
|
|
567
|
+
el.addEventListener('click', () => {
|
|
568
|
+
this.selectItem(items[idx]);
|
|
569
|
+
});
|
|
570
|
+
});
|
|
571
|
+
}
|
|
572
|
+
}
|
|
573
|
+
}
|
|
574
|
+
customElements.define('gradio-search-select', GradioSearchSelect);
|
|
575
|
+
}
|
|
576
|
+
"""
|
|
577
|
+
from gradio.events import Dependency
|
|
578
|
+
|
|
579
|
+
class CategorizedSelect(gr.HTML):
|
|
580
|
+
"""
|
|
581
|
+
A categorised select component with search capability, similar to Gradio-Style Search Component.
|
|
582
|
+
Accepts hierarchical data (Categories -> Items).
|
|
583
|
+
"""
|
|
584
|
+
|
|
585
|
+
def __init__(
|
|
586
|
+
self,
|
|
587
|
+
options: List[SelectCategory],
|
|
588
|
+
value: Optional[str] = None,
|
|
589
|
+
placeholder: str = "Search or select...",
|
|
590
|
+
label: Optional[str] = None,
|
|
591
|
+
elem_id: Optional[str] = None,
|
|
592
|
+
visible: bool = True,
|
|
593
|
+
**kwargs: Any
|
|
594
|
+
):
|
|
595
|
+
"""
|
|
596
|
+
Args:
|
|
597
|
+
options: List of categories with children items.
|
|
598
|
+
value: Initial selected value (matches item 'value').
|
|
599
|
+
placeholder: Input placeholder text.
|
|
600
|
+
label: Optional label (not strictly used in HTML but good for parity).
|
|
601
|
+
elem_id: HTML element ID.
|
|
602
|
+
visible: Initial visibility.
|
|
603
|
+
"""
|
|
604
|
+
self.options = options
|
|
605
|
+
json_data = json.dumps(options)
|
|
606
|
+
|
|
607
|
+
# HTML template instantiates the Web Component
|
|
608
|
+
# We pass initial data as attributes
|
|
609
|
+
html_template = f"""
|
|
610
|
+
<gradio-search-select
|
|
611
|
+
id="{elem_id or 'cat-select'}"
|
|
612
|
+
initial-data='{escape_json_string(json_data)}'
|
|
613
|
+
value='{value or ""}'
|
|
614
|
+
placeholder='{placeholder}'
|
|
615
|
+
></gradio-search-select>
|
|
616
|
+
"""
|
|
617
|
+
|
|
618
|
+
# JS to run on load:
|
|
619
|
+
# 1. Defines the Web Component class (once).
|
|
620
|
+
# 2. Attaches event listener to bridge component events to Gradio's `trigger`.
|
|
621
|
+
js_on_load = f"""
|
|
622
|
+
{JS_CLASS_DEF}
|
|
623
|
+
|
|
624
|
+
const selectEl = element.querySelector('gradio-search-select');
|
|
625
|
+
|
|
626
|
+
// Forward 'change' events from the web component to Gradio
|
|
627
|
+
if (selectEl) {{
|
|
628
|
+
selectEl.addEventListener('change', (e) => {{
|
|
629
|
+
console.log(e);
|
|
630
|
+
// trigger is injected by Gradio's JS wrapper
|
|
631
|
+
trigger('click', e.detail);
|
|
632
|
+
}});
|
|
633
|
+
}}
|
|
634
|
+
"""
|
|
635
|
+
|
|
636
|
+
super().__init__(
|
|
637
|
+
value=value, # Pass value to base though mostly for init
|
|
638
|
+
label=label,
|
|
639
|
+
elem_id=elem_id,
|
|
640
|
+
visible=visible,
|
|
641
|
+
html_template=html_template,
|
|
642
|
+
css_template=CSS,
|
|
643
|
+
js_on_load=js_on_load,
|
|
644
|
+
**kwargs
|
|
645
|
+
)
|
|
646
|
+
|
|
647
|
+
# def _wrap(evt: gr.EventData):
|
|
648
|
+
# return gr.update(value=evt._data['value'])
|
|
649
|
+
# self.click(_wrap, outputs=self)
|
|
650
|
+
|
|
651
|
+
def change(self, fn, inputs, outputs):
|
|
652
|
+
def _wrap(evt: gr.EventData):
|
|
653
|
+
return gr.update(value=evt._data['value'])
|
|
654
|
+
self.click(_wrap, outputs=self)
|
|
655
|
+
super().change(fn, inputs, outputs)
|
|
656
|
+
from typing import Callable, Literal, Sequence, Any, TYPE_CHECKING
|
|
657
|
+
from gradio.blocks import Block
|
|
658
|
+
if TYPE_CHECKING:
|
|
659
|
+
from gradio.components import Timer
|
|
660
|
+
from gradio.components.base import Component
|
|
661
|
+
|
|
662
|
+
|
|
663
|
+
if __name__ == "__main__":
|
|
664
|
+
# Example usage
|
|
665
|
+
demo = gr.Blocks()
|
|
666
|
+
|
|
667
|
+
with demo:
|
|
668
|
+
cat_select = CategorizedSelect(
|
|
669
|
+
options=[
|
|
670
|
+
{
|
|
671
|
+
"label": "Fruits",
|
|
672
|
+
"icon": "<svg>...</svg>",
|
|
673
|
+
"children": [
|
|
674
|
+
{"label": "Apple", "value": "apple", "icon": "<svg>...</svg>", "size": "2rem"},
|
|
675
|
+
{"label": "Banana", "value": "banana", "icon": "<svg>...</svg>", "size": "2rem"},
|
|
676
|
+
],
|
|
677
|
+
},
|
|
678
|
+
{
|
|
679
|
+
"label": "Vegetables",
|
|
680
|
+
"icon": "<svg>...</svg>",
|
|
681
|
+
"children": [
|
|
682
|
+
{"label": "Carrot", "value": "carrot", "icon": "<svg>...</svg>", "size": "2rem"},
|
|
683
|
+
{"label": "Lettuce", "value": "lettuce", "icon": "<svg>...</svg>", "size": "2rem"},
|
|
684
|
+
],
|
|
685
|
+
},
|
|
686
|
+
],
|
|
687
|
+
placeholder="Select a food item...",
|
|
688
|
+
)
|
|
689
|
+
|
|
690
|
+
def on_change(detail):
|
|
691
|
+
return f"Selected: {detail['value']}"
|
|
692
|
+
|
|
693
|
+
output = gr.Textbox(label="Selection Output")
|
|
694
|
+
|
|
695
|
+
cat_select.change(on_change, inputs=[], outputs=output)
|
|
696
|
+
|
|
697
|
+
demo.launch()
|