@alfadocs/ui-kit-debug 0.47.0 → 0.48.0
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.
- package/dist/_chunks/{agenda-card-CFyWSX7Z.js → agenda-card-BaSfVfrL.js} +25 -29
- package/dist/_chunks/agenda-card-BaSfVfrL.js.map +1 -0
- package/dist/_chunks/{agenda-tray-Dyj9ChHC.js → agenda-tray-DQayYmQ0.js} +50 -67
- package/dist/_chunks/agenda-tray-DQayYmQ0.js.map +1 -0
- package/dist/_chunks/ai-consent-banner-DO5ingMq.js +169 -0
- package/dist/_chunks/ai-consent-banner-DO5ingMq.js.map +1 -0
- package/dist/_chunks/ai-tools-rail-CxYG04cw.js +280 -0
- package/dist/_chunks/ai-tools-rail-CxYG04cw.js.map +1 -0
- package/dist/_chunks/{alia-sidebar-CVIPrdc9.js → alia-sidebar-DlvyXgVC.js} +3 -2
- package/dist/_chunks/alia-sidebar-DlvyXgVC.js.map +1 -0
- package/dist/_chunks/anamnesis-card-CmkBVAln.js +156 -0
- package/dist/_chunks/anamnesis-card-CmkBVAln.js.map +1 -0
- package/dist/_chunks/appointment-tray-BwDHhWWC.js +419 -0
- package/dist/_chunks/appointment-tray-BwDHhWWC.js.map +1 -0
- package/dist/_chunks/{bmi-calculator-CQqXTVNL.js → bmi-calculator-DdylQzT6.js} +2 -2
- package/dist/_chunks/{bmi-calculator-CQqXTVNL.js.map → bmi-calculator-DdylQzT6.js.map} +1 -1
- package/dist/_chunks/{booking-DlDVuWMd.js → booking-WV2GSru5.js} +291 -303
- package/dist/_chunks/booking-WV2GSru5.js.map +1 -0
- package/dist/_chunks/{calculator-dialog-D-nfvteH.js → calculator-dialog-CFk4I91b.js} +2 -2
- package/dist/_chunks/{calculator-dialog-D-nfvteH.js.map → calculator-dialog-CFk4I91b.js.map} +1 -1
- package/dist/_chunks/calendar-days-C4BmpCZg.js +23 -0
- package/dist/_chunks/calendar-days-C4BmpCZg.js.map +1 -0
- package/dist/_chunks/{calendar-YHFknAGv.js → calendar-oYWOCrnf.js} +195 -210
- package/dist/_chunks/calendar-oYWOCrnf.js.map +1 -0
- package/dist/_chunks/care-plan-card-QmNpGggC.js +252 -0
- package/dist/_chunks/care-plan-card-QmNpGggC.js.map +1 -0
- package/dist/_chunks/care-plan-entry-card-Cnra7vUc.js +318 -0
- package/dist/_chunks/care-plan-entry-card-Cnra7vUc.js.map +1 -0
- package/dist/_chunks/{chat-message-B5JpFj0F.js → chat-message-Dm8U2RY1.js} +36 -35
- package/dist/_chunks/chat-message-Dm8U2RY1.js.map +1 -0
- package/dist/_chunks/clinical-note-card-BYo437dU.js +333 -0
- package/dist/_chunks/clinical-note-card-BYo437dU.js.map +1 -0
- package/dist/_chunks/{contact-profile-card-DHyuAPXM.js → contact-profile-card-DvvVfAA2.js} +102 -115
- package/dist/_chunks/contact-profile-card-DvvVfAA2.js.map +1 -0
- package/dist/_chunks/{cycle-calculator-KxA8dqDf.js → cycle-calculator-DYvGm_m1.js} +2 -2
- package/dist/_chunks/{cycle-calculator-KxA8dqDf.js.map → cycle-calculator-DYvGm_m1.js.map} +1 -1
- package/dist/_chunks/{dialog-BTpZV6It.js → dialog-DMGnSelc.js} +55 -55
- package/dist/_chunks/dialog-DMGnSelc.js.map +1 -0
- package/dist/_chunks/{due-date-calculator-mFxpHLml.js → due-date-calculator-BXd3ANj7.js} +2 -2
- package/dist/_chunks/{due-date-calculator-mFxpHLml.js.map → due-date-calculator-BXd3ANj7.js.map} +1 -1
- package/dist/_chunks/entity-card-COhmqHly.js +69 -0
- package/dist/_chunks/entity-card-COhmqHly.js.map +1 -0
- package/dist/_chunks/{gestational-age-calculator-gWI_uRA1.js → gestational-age-calculator-Crj6FgZw.js} +2 -2
- package/dist/_chunks/{gestational-age-calculator-gWI_uRA1.js.map → gestational-age-calculator-Crj6FgZw.js.map} +1 -1
- package/dist/_chunks/{insert-result-C5ABnzDl.js → insert-result-DNdi_JYW.js} +140 -168
- package/dist/_chunks/insert-result-DNdi_JYW.js.map +1 -0
- package/dist/_chunks/is-safe-url-DkETxeHz.js +7 -0
- package/dist/_chunks/is-safe-url-DkETxeHz.js.map +1 -0
- package/dist/_chunks/languages-DsVf_WzT.js +19 -0
- package/dist/_chunks/languages-DsVf_WzT.js.map +1 -0
- package/dist/_chunks/layers-pzGcbLPj.js +34 -0
- package/dist/_chunks/layers-pzGcbLPj.js.map +1 -0
- package/dist/_chunks/{message-card-DSPw5ghw.js → message-card-Dvl1TgaN.js} +15 -19
- package/dist/_chunks/message-card-Dvl1TgaN.js.map +1 -0
- package/dist/_chunks/{message-tray-hSQff9u4.js → message-tray-Dl6GQaaV.js} +2 -2
- package/dist/_chunks/{message-tray-hSQff9u4.js.map → message-tray-Dl6GQaaV.js.map} +1 -1
- package/dist/_chunks/operator-hero-CM8949Hd.js +198 -0
- package/dist/_chunks/operator-hero-CM8949Hd.js.map +1 -0
- package/dist/_chunks/patient-summary-card-BnTqxcTr.js +443 -0
- package/dist/_chunks/patient-summary-card-BnTqxcTr.js.map +1 -0
- package/dist/_chunks/payment-request-card-B_lyobd0.js +478 -0
- package/dist/_chunks/payment-request-card-B_lyobd0.js.map +1 -0
- package/dist/_chunks/{pdf-viewer-CWEXTlwq.js → pdf-viewer-G8SU6Azw.js} +3 -3
- package/dist/_chunks/pdf-viewer-G8SU6Azw.js.map +1 -0
- package/dist/_chunks/periodontal-chart-card-BYs9hax1.js +455 -0
- package/dist/_chunks/periodontal-chart-card-BYs9hax1.js.map +1 -0
- package/dist/_chunks/phone-Bi5yUm4I.js +20 -0
- package/dist/_chunks/phone-Bi5yUm4I.js.map +1 -0
- package/dist/_chunks/{practice-results-DDi-kvaD.js → practice-results-BFL_mcDW.js} +3 -2
- package/dist/_chunks/{practice-results-DDi-kvaD.js.map → practice-results-BFL_mcDW.js.map} +1 -1
- package/dist/_chunks/{pregnancy-weight-gain-BtEHaSqy.js → pregnancy-weight-gain-C7dK89jE.js} +2 -2
- package/dist/_chunks/{pregnancy-weight-gain-BtEHaSqy.js.map → pregnancy-weight-gain-C7dK89jE.js.map} +1 -1
- package/dist/_chunks/scan-line-lGioFwLC.js +18 -0
- package/dist/_chunks/scan-line-lGioFwLC.js.map +1 -0
- package/dist/_chunks/shield-check-BjCGH_Sr.js +21 -0
- package/dist/_chunks/shield-check-BjCGH_Sr.js.map +1 -0
- package/dist/_chunks/{sign-document-BCyLpFHJ.js → sign-document-DPI2pY9V.js} +2 -2
- package/dist/_chunks/{sign-document-BCyLpFHJ.js.map → sign-document-DPI2pY9V.js.map} +1 -1
- package/dist/_chunks/{transaction-chip-B8ujzowA.js → transaction-chip-BZCa6XDn.js} +8 -6
- package/dist/_chunks/{transaction-chip-B8ujzowA.js.map → transaction-chip-BZCa6XDn.js.map} +1 -1
- package/dist/_chunks/{unit-converter-u3CwNDpP.js → unit-converter-jWp3Z85y.js} +2 -2
- package/dist/_chunks/{unit-converter-u3CwNDpP.js.map → unit-converter-jWp3Z85y.js.map} +1 -1
- package/dist/_chunks/user-cog-BS_qc8nA.js +24 -0
- package/dist/_chunks/user-cog-BS_qc8nA.js.map +1 -0
- package/dist/_chunks/video-BAeICxCT.js +21 -0
- package/dist/_chunks/video-BAeICxCT.js.map +1 -0
- package/dist/_chunks/{workflow-map-Djn1QMJc.js → workflow-map-ZXw-zsZ8.js} +138 -156
- package/dist/_chunks/workflow-map-ZXw-zsZ8.js.map +1 -0
- package/dist/agent-catalog.json +324 -1
- package/dist/components/_shared/entity-card/entity-card.d.ts +40 -0
- package/dist/components/_shared/entity-card/entity-card.d.ts.map +1 -0
- package/dist/components/_shared/entity-card/index.d.ts +3 -0
- package/dist/components/_shared/entity-card/index.d.ts.map +1 -0
- package/dist/components/_shared/index.d.ts +2 -0
- package/dist/components/_shared/index.d.ts.map +1 -1
- package/dist/components/_shared/is-safe-url.d.ts +13 -0
- package/dist/components/_shared/is-safe-url.d.ts.map +1 -0
- package/dist/components/agenda-card/agenda-card.d.ts +1 -2
- package/dist/components/agenda-card/agenda-card.d.ts.map +1 -1
- package/dist/components/agenda-card/index.d.ts +2 -1
- package/dist/components/agenda-card/index.d.ts.map +1 -1
- package/dist/components/agenda-card/index.js +6 -5
- package/dist/components/agenda-card/index.js.map +1 -1
- package/dist/components/agenda-tray/index.js +1 -1
- package/dist/components/ai-consent-banner/ai-consent-banner.agent.d.ts +4 -0
- package/dist/components/ai-consent-banner/ai-consent-banner.agent.d.ts.map +1 -0
- package/dist/components/ai-consent-banner/ai-consent-banner.d.ts +45 -0
- package/dist/components/ai-consent-banner/ai-consent-banner.d.ts.map +1 -0
- package/dist/components/ai-consent-banner/index.d.ts +4 -0
- package/dist/components/ai-consent-banner/index.d.ts.map +1 -0
- package/dist/components/ai-consent-banner/index.js +6 -0
- package/dist/components/ai-consent-banner/index.js.map +1 -0
- package/dist/components/ai-tools-rail/ai-tools-rail.agent.d.ts +4 -0
- package/dist/components/ai-tools-rail/ai-tools-rail.agent.d.ts.map +1 -0
- package/dist/components/ai-tools-rail/ai-tools-rail.d.ts +60 -0
- package/dist/components/ai-tools-rail/ai-tools-rail.d.ts.map +1 -0
- package/dist/components/ai-tools-rail/index.d.ts +4 -0
- package/dist/components/ai-tools-rail/index.d.ts.map +1 -0
- package/dist/components/ai-tools-rail/index.js +6 -0
- package/dist/components/ai-tools-rail/index.js.map +1 -0
- package/dist/components/anamnesis-card/anamnesis-card.d.ts +68 -0
- package/dist/components/anamnesis-card/anamnesis-card.d.ts.map +1 -0
- package/dist/components/anamnesis-card/index.d.ts +3 -0
- package/dist/components/anamnesis-card/index.d.ts.map +1 -0
- package/dist/components/anamnesis-card/index.js +5 -0
- package/dist/components/anamnesis-card/index.js.map +1 -0
- package/dist/components/appointment-card/appointment-card.agent.d.ts +3 -0
- package/dist/components/appointment-card/appointment-card.agent.d.ts.map +1 -0
- package/dist/components/appointment-card/appointment-card.d.ts +93 -0
- package/dist/components/appointment-card/appointment-card.d.ts.map +1 -0
- package/dist/components/appointment-card/appointment-tray.agent.d.ts +4 -0
- package/dist/components/appointment-card/appointment-tray.agent.d.ts.map +1 -0
- package/dist/components/appointment-card/appointment-tray.d.ts +48 -0
- package/dist/components/appointment-card/appointment-tray.d.ts.map +1 -0
- package/dist/components/appointment-card/index.d.ts +8 -0
- package/dist/components/appointment-card/index.d.ts.map +1 -0
- package/dist/components/appointment-card/index.js +10 -0
- package/dist/components/appointment-card/index.js.map +1 -0
- package/dist/components/badge/badge.d.ts +1 -1
- package/dist/components/bmi-calculator/index.js +1 -1
- package/dist/components/booking/index.js +1 -1
- package/dist/components/calculator-dialog/index.js +1 -1
- package/dist/components/calendar/index.js +1 -1
- package/dist/components/card/card.d.ts +1 -1
- package/dist/components/care-plan-card/care-plan-card.agent.d.ts +4 -0
- package/dist/components/care-plan-card/care-plan-card.agent.d.ts.map +1 -0
- package/dist/components/care-plan-card/care-plan-card.d.ts +102 -0
- package/dist/components/care-plan-card/care-plan-card.d.ts.map +1 -0
- package/dist/components/care-plan-card/index.d.ts +4 -0
- package/dist/components/care-plan-card/index.d.ts.map +1 -0
- package/dist/components/care-plan-card/index.js +6 -0
- package/dist/components/care-plan-card/index.js.map +1 -0
- package/dist/components/care-plan-entry-card/care-plan-entry-card.agent.d.ts +4 -0
- package/dist/components/care-plan-entry-card/care-plan-entry-card.agent.d.ts.map +1 -0
- package/dist/components/care-plan-entry-card/care-plan-entry-card.d.ts +110 -0
- package/dist/components/care-plan-entry-card/care-plan-entry-card.d.ts.map +1 -0
- package/dist/components/care-plan-entry-card/index.d.ts +4 -0
- package/dist/components/care-plan-entry-card/index.d.ts.map +1 -0
- package/dist/components/care-plan-entry-card/index.js +6 -0
- package/dist/components/care-plan-entry-card/index.js.map +1 -0
- package/dist/components/chat-message/chat-message.d.ts +7 -0
- package/dist/components/chat-message/chat-message.d.ts.map +1 -1
- package/dist/components/chat-message/index.js +1 -1
- package/dist/components/clinical-note-card/clinical-note-card.agent.d.ts +4 -0
- package/dist/components/clinical-note-card/clinical-note-card.agent.d.ts.map +1 -0
- package/dist/components/clinical-note-card/clinical-note-card.d.ts +98 -0
- package/dist/components/clinical-note-card/clinical-note-card.d.ts.map +1 -0
- package/dist/components/clinical-note-card/index.d.ts +4 -0
- package/dist/components/clinical-note-card/index.d.ts.map +1 -0
- package/dist/components/clinical-note-card/index.js +6 -0
- package/dist/components/clinical-note-card/index.js.map +1 -0
- package/dist/components/contact-profile-card/index.js +1 -1
- package/dist/components/cycle-calculator/index.js +1 -1
- package/dist/components/dialog/dialog.d.ts +7 -0
- package/dist/components/dialog/dialog.d.ts.map +1 -1
- package/dist/components/dialog/index.js +1 -1
- package/dist/components/due-date-calculator/index.js +1 -1
- package/dist/components/gestational-age-calculator/index.js +1 -1
- package/dist/components/index.d.ts +10 -0
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/message-card/index.js +5 -4
- package/dist/components/message-card/index.js.map +1 -1
- package/dist/components/message-card/message-card.d.ts +1 -2
- package/dist/components/message-card/message-card.d.ts.map +1 -1
- package/dist/components/message-tray/index.js +1 -1
- package/dist/components/operator-hero/index.js +1 -1
- package/dist/components/operator-hero/operator-hero.agent.d.ts.map +1 -1
- package/dist/components/operator-hero/operator-hero.d.ts +9 -0
- package/dist/components/operator-hero/operator-hero.d.ts.map +1 -1
- package/dist/components/patient-summary-card/index.d.ts +4 -0
- package/dist/components/patient-summary-card/index.d.ts.map +1 -0
- package/dist/components/patient-summary-card/index.js +6 -0
- package/dist/components/patient-summary-card/index.js.map +1 -0
- package/dist/components/patient-summary-card/patient-summary-card.agent.d.ts +4 -0
- package/dist/components/patient-summary-card/patient-summary-card.agent.d.ts.map +1 -0
- package/dist/components/patient-summary-card/patient-summary-card.d.ts +120 -0
- package/dist/components/patient-summary-card/patient-summary-card.d.ts.map +1 -0
- package/dist/components/payment-card/index.d.ts +7 -0
- package/dist/components/payment-card/index.d.ts.map +1 -0
- package/dist/components/payment-card/index.js +8 -0
- package/dist/components/payment-card/index.js.map +1 -0
- package/dist/components/payment-card/payment-card.agent.d.ts +4 -0
- package/dist/components/payment-card/payment-card.agent.d.ts.map +1 -0
- package/dist/components/payment-card/payment-card.d.ts +71 -0
- package/dist/components/payment-card/payment-card.d.ts.map +1 -0
- package/dist/components/payment-card/payment-request-card.agent.d.ts +4 -0
- package/dist/components/payment-card/payment-request-card.agent.d.ts.map +1 -0
- package/dist/components/payment-card/payment-request-card.d.ts +43 -0
- package/dist/components/payment-card/payment-request-card.d.ts.map +1 -0
- package/dist/components/pdf-viewer/index.js +1 -1
- package/dist/components/pdf-viewer/pdf-viewer.d.ts.map +1 -1
- package/dist/components/periodontal-chart-card/index.d.ts +4 -0
- package/dist/components/periodontal-chart-card/index.d.ts.map +1 -0
- package/dist/components/periodontal-chart-card/index.js +7 -0
- package/dist/components/periodontal-chart-card/index.js.map +1 -0
- package/dist/components/periodontal-chart-card/periodontal-chart-card.agent.d.ts +4 -0
- package/dist/components/periodontal-chart-card/periodontal-chart-card.agent.d.ts.map +1 -0
- package/dist/components/periodontal-chart-card/periodontal-chart-card.d.ts +74 -0
- package/dist/components/periodontal-chart-card/periodontal-chart-card.d.ts.map +1 -0
- package/dist/components/practice-results/index.js +1 -1
- package/dist/components/pregnancy-weight-gain/index.js +1 -1
- package/dist/components/public-header/public-header.d.ts +1 -1
- package/dist/components/sign-document/index.js +1 -1
- package/dist/components/stat/stat.d.ts +1 -1
- package/dist/components/transaction-chip/index.js +1 -1
- package/dist/components/unit-converter/index.js +1 -1
- package/dist/components/workflow/index.js +1 -1
- package/dist/i18n/locales/ar.d.ts +351 -0
- package/dist/i18n/locales/ar.d.ts.map +1 -1
- package/dist/i18n/locales/ar.js +351 -0
- package/dist/i18n/locales/ar.js.map +1 -1
- package/dist/i18n/locales/de.d.ts +351 -0
- package/dist/i18n/locales/de.d.ts.map +1 -1
- package/dist/i18n/locales/de.js +351 -0
- package/dist/i18n/locales/de.js.map +1 -1
- package/dist/i18n/locales/el.d.ts +351 -0
- package/dist/i18n/locales/el.d.ts.map +1 -1
- package/dist/i18n/locales/el.js +351 -0
- package/dist/i18n/locales/el.js.map +1 -1
- package/dist/i18n/locales/en.d.ts +351 -0
- package/dist/i18n/locales/en.d.ts.map +1 -1
- package/dist/i18n/locales/en.js +351 -0
- package/dist/i18n/locales/en.js.map +1 -1
- package/dist/i18n/locales/es.d.ts +351 -0
- package/dist/i18n/locales/es.d.ts.map +1 -1
- package/dist/i18n/locales/es.js +351 -0
- package/dist/i18n/locales/es.js.map +1 -1
- package/dist/i18n/locales/fr.d.ts +351 -0
- package/dist/i18n/locales/fr.d.ts.map +1 -1
- package/dist/i18n/locales/fr.js +351 -0
- package/dist/i18n/locales/fr.js.map +1 -1
- package/dist/i18n/locales/hi.d.ts +351 -0
- package/dist/i18n/locales/hi.d.ts.map +1 -1
- package/dist/i18n/locales/hi.js +351 -0
- package/dist/i18n/locales/hi.js.map +1 -1
- package/dist/i18n/locales/it.d.ts +351 -0
- package/dist/i18n/locales/it.d.ts.map +1 -1
- package/dist/i18n/locales/it.js +351 -0
- package/dist/i18n/locales/it.js.map +1 -1
- package/dist/i18n/locales/ja.d.ts +351 -0
- package/dist/i18n/locales/ja.d.ts.map +1 -1
- package/dist/i18n/locales/ja.js +351 -0
- package/dist/i18n/locales/ja.js.map +1 -1
- package/dist/i18n/locales/nl.d.ts +351 -0
- package/dist/i18n/locales/nl.d.ts.map +1 -1
- package/dist/i18n/locales/nl.js +351 -0
- package/dist/i18n/locales/nl.js.map +1 -1
- package/dist/i18n/locales/pl.d.ts +351 -0
- package/dist/i18n/locales/pl.d.ts.map +1 -1
- package/dist/i18n/locales/pl.js +351 -0
- package/dist/i18n/locales/pl.js.map +1 -1
- package/dist/i18n/locales/pt.d.ts +351 -0
- package/dist/i18n/locales/pt.d.ts.map +1 -1
- package/dist/i18n/locales/pt.js +351 -0
- package/dist/i18n/locales/pt.js.map +1 -1
- package/dist/i18n/locales/ro.d.ts +351 -0
- package/dist/i18n/locales/ro.d.ts.map +1 -1
- package/dist/i18n/locales/ro.js +351 -0
- package/dist/i18n/locales/ro.js.map +1 -1
- package/dist/i18n/locales/ru.d.ts +351 -0
- package/dist/i18n/locales/ru.d.ts.map +1 -1
- package/dist/i18n/locales/ru.js +351 -0
- package/dist/i18n/locales/ru.js.map +1 -1
- package/dist/i18n/locales/sq.d.ts +351 -0
- package/dist/i18n/locales/sq.d.ts.map +1 -1
- package/dist/i18n/locales/sq.js +351 -0
- package/dist/i18n/locales/sq.js.map +1 -1
- package/dist/i18n/locales/sv.d.ts +351 -0
- package/dist/i18n/locales/sv.d.ts.map +1 -1
- package/dist/i18n/locales/sv.js +351 -0
- package/dist/i18n/locales/sv.js.map +1 -1
- package/dist/i18n/locales/tr.d.ts +351 -0
- package/dist/i18n/locales/tr.d.ts.map +1 -1
- package/dist/i18n/locales/tr.js +351 -0
- package/dist/i18n/locales/tr.js.map +1 -1
- package/dist/i18n/locales/zh.d.ts +351 -0
- package/dist/i18n/locales/zh.d.ts.map +1 -1
- package/dist/i18n/locales/zh.js +351 -0
- package/dist/i18n/locales/zh.js.map +1 -1
- package/dist/index.js +527 -491
- package/dist/index.js.map +1 -1
- package/dist/locales/ar.json +351 -0
- package/dist/locales/de.json +351 -0
- package/dist/locales/el.json +351 -0
- package/dist/locales/en.json +351 -0
- package/dist/locales/es.json +351 -0
- package/dist/locales/fr.json +351 -0
- package/dist/locales/hi.json +351 -0
- package/dist/locales/it.json +351 -0
- package/dist/locales/ja.json +351 -0
- package/dist/locales/nl.json +351 -0
- package/dist/locales/pl.json +351 -0
- package/dist/locales/pt.json +351 -0
- package/dist/locales/ro.json +351 -0
- package/dist/locales/ru.json +351 -0
- package/dist/locales/sq.json +351 -0
- package/dist/locales/sv.json +351 -0
- package/dist/locales/tr.json +351 -0
- package/dist/locales/zh.json +351 -0
- package/dist/patterns/alia-assistant/alia-chat-surface.d.ts.map +1 -1
- package/dist/patterns/alia-assistant/alia-types.d.ts +15 -0
- package/dist/patterns/alia-assistant/alia-types.d.ts.map +1 -1
- package/dist/patterns/alia-assistant/index.js +1 -1
- package/dist/tokens.css +1 -1
- package/package.json +42 -1
- package/dist/_chunks/agenda-card-CFyWSX7Z.js.map +0 -1
- package/dist/_chunks/agenda-tray-Dyj9ChHC.js.map +0 -1
- package/dist/_chunks/alia-sidebar-CVIPrdc9.js.map +0 -1
- package/dist/_chunks/booking-DlDVuWMd.js.map +0 -1
- package/dist/_chunks/calendar-YHFknAGv.js.map +0 -1
- package/dist/_chunks/chat-message-B5JpFj0F.js.map +0 -1
- package/dist/_chunks/contact-profile-card-DHyuAPXM.js.map +0 -1
- package/dist/_chunks/dialog-BTpZV6It.js.map +0 -1
- package/dist/_chunks/insert-result-C5ABnzDl.js.map +0 -1
- package/dist/_chunks/message-card-DSPw5ghw.js.map +0 -1
- package/dist/_chunks/operator-hero-7LiiP7zi.js +0 -171
- package/dist/_chunks/operator-hero-7LiiP7zi.js.map +0 -1
- package/dist/_chunks/pdf-viewer-CWEXTlwq.js.map +0 -1
- package/dist/_chunks/shield-check-C73ma9Cs.js +0 -36
- package/dist/_chunks/shield-check-C73ma9Cs.js.map +0 -1
- package/dist/_chunks/workflow-map-Djn1QMJc.js.map +0 -1
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
import { jsxs as r, jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef as M, useId as C, useMemo as R } from "react";
|
|
3
|
+
import { c as q } from "./index-D2ZczOXr.js";
|
|
4
|
+
import { useTranslation as z } from "react-i18next";
|
|
5
|
+
import { B as n } from "./badge-zsf5i5bH.js";
|
|
6
|
+
import { C as N } from "./card-DPmk26CL.js";
|
|
7
|
+
import { A as G, b as O, c as Q, a as S } from "./accordion-9lJSMMsZ.js";
|
|
8
|
+
import { D as t } from "./description-list-BEbK2g93.js";
|
|
9
|
+
import { T as w } from "./timestamp-BV2lC-wV.js";
|
|
10
|
+
import { T as y } from "./triangle-alert-CBPUIzQo.js";
|
|
11
|
+
const H = q("ds:w-full ds:text-[color:var(--foreground)]", {
|
|
12
|
+
variants: {
|
|
13
|
+
// Matches the kit's other `surface` props. `'elevated'` (default)
|
|
14
|
+
// wraps in `<Card variant="elevated">`; `'flat'` drops the chrome
|
|
15
|
+
// for use inside an existing Card / Sheet.
|
|
16
|
+
surface: {
|
|
17
|
+
flat: "",
|
|
18
|
+
elevated: ""
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
defaultVariants: { surface: "elevated" }
|
|
22
|
+
}), J = M(
|
|
23
|
+
({
|
|
24
|
+
dateIso: V,
|
|
25
|
+
createdAtIso: u,
|
|
26
|
+
formName: T,
|
|
27
|
+
highlightedAnswerCount: o = 0,
|
|
28
|
+
status: s,
|
|
29
|
+
answers: d,
|
|
30
|
+
surface: p = "elevated",
|
|
31
|
+
"aria-label": A,
|
|
32
|
+
id: f,
|
|
33
|
+
className: D,
|
|
34
|
+
...F
|
|
35
|
+
}, I) => {
|
|
36
|
+
const { t: a } = z(), h = C(), L = C(), v = T ?? a("anamnesisCard.defaultFormName", { defaultValue: "Medical history" }), B = A ?? v, i = o > 0, c = (s == null ? void 0 : s.expired) === !0, m = (s == null ? void 0 : s.corrupted) === !0, g = (d == null ? void 0 : d.length) ?? 0, x = R(() => !i && !c && !m ? null : /* @__PURE__ */ r(
|
|
37
|
+
"div",
|
|
38
|
+
{
|
|
39
|
+
role: "list",
|
|
40
|
+
"aria-label": a("anamnesisCard.statusGroupLabel", {
|
|
41
|
+
defaultValue: "Questionnaire status"
|
|
42
|
+
}),
|
|
43
|
+
className: "ds:flex ds:flex-wrap ds:items-center ds:gap-[var(--spacing-2xs)]",
|
|
44
|
+
children: [
|
|
45
|
+
i ? /* @__PURE__ */ e(
|
|
46
|
+
n,
|
|
47
|
+
{
|
|
48
|
+
variant: "error",
|
|
49
|
+
withDot: !0,
|
|
50
|
+
leading: /* @__PURE__ */ e(y, { "aria-hidden": "true" }),
|
|
51
|
+
role: "listitem",
|
|
52
|
+
children: a("anamnesisCard.status.highlighted", {
|
|
53
|
+
count: o,
|
|
54
|
+
defaultValue: "{{count}} flagged answers"
|
|
55
|
+
})
|
|
56
|
+
}
|
|
57
|
+
) : null,
|
|
58
|
+
c ? /* @__PURE__ */ e(n, { variant: "warning", withDot: !0, role: "listitem", children: a("anamnesisCard.status.expired", { defaultValue: "Expired" }) }) : null,
|
|
59
|
+
m ? /* @__PURE__ */ e(n, { variant: "error", withDot: !0, role: "listitem", children: a("anamnesisCard.status.corrupted", {
|
|
60
|
+
defaultValue: "Corrupted"
|
|
61
|
+
}) }) : null
|
|
62
|
+
]
|
|
63
|
+
}
|
|
64
|
+
), [i, c, m, o, a]), j = /* @__PURE__ */ r("div", { className: "ds:flex ds:flex-col ds:gap-[var(--spacing-xs)]", children: [
|
|
65
|
+
/* @__PURE__ */ r("div", { className: "ds:flex ds:flex-wrap ds:items-start ds:gap-[var(--spacing-sm)]", children: [
|
|
66
|
+
/* @__PURE__ */ e(
|
|
67
|
+
"h3",
|
|
68
|
+
{
|
|
69
|
+
id: h,
|
|
70
|
+
className: "type-title-card ds:m-0 ds:text-[color:var(--foreground)]",
|
|
71
|
+
children: v
|
|
72
|
+
}
|
|
73
|
+
),
|
|
74
|
+
x ? /* @__PURE__ */ e("div", { className: "ds:ms-auto ds:flex ds:shrink-0 ds:items-center", children: x }) : null
|
|
75
|
+
] }),
|
|
76
|
+
/* @__PURE__ */ r("p", { className: "type-body-sm ds:m-0 ds:flex ds:flex-wrap ds:items-center ds:gap-[var(--spacing-xs)] ds:text-[color:var(--muted-foreground)]", children: [
|
|
77
|
+
/* @__PURE__ */ r("span", { children: [
|
|
78
|
+
a("anamnesisCard.compiledOn", { defaultValue: "Compiled" }),
|
|
79
|
+
" ",
|
|
80
|
+
/* @__PURE__ */ e(w, { value: V, format: "absolute", shape: "bare" })
|
|
81
|
+
] }),
|
|
82
|
+
u ? /* @__PURE__ */ r("span", { className: "ds:flex ds:items-center ds:gap-[var(--spacing-xs)]", children: [
|
|
83
|
+
/* @__PURE__ */ e("span", { "aria-hidden": "true", children: "·" }),
|
|
84
|
+
/* @__PURE__ */ r("span", { children: [
|
|
85
|
+
a("anamnesisCard.submitted", { defaultValue: "Submitted" }),
|
|
86
|
+
" ",
|
|
87
|
+
/* @__PURE__ */ e(
|
|
88
|
+
w,
|
|
89
|
+
{
|
|
90
|
+
value: u,
|
|
91
|
+
format: "relative",
|
|
92
|
+
shape: "bare"
|
|
93
|
+
}
|
|
94
|
+
)
|
|
95
|
+
] })
|
|
96
|
+
] }) : null
|
|
97
|
+
] })
|
|
98
|
+
] }), k = g > 0 ? /* @__PURE__ */ e(t, { layout: "stacked", density: "compact", divider: "between", children: d.map((l, E) => /* @__PURE__ */ r(
|
|
99
|
+
t.Row,
|
|
100
|
+
{
|
|
101
|
+
className: l.highlight ? "ds:border ds:border-[color:var(--destructive)] ds:rounded-[var(--radius-sm)] ds:p-[var(--spacing-sm)]" : void 0,
|
|
102
|
+
children: [
|
|
103
|
+
/* @__PURE__ */ e(t.Term, { children: /* @__PURE__ */ r("span", { className: "ds:flex ds:items-center ds:gap-[var(--spacing-xs)]", children: [
|
|
104
|
+
/* @__PURE__ */ e("span", { children: l.question }),
|
|
105
|
+
l.highlight ? /* @__PURE__ */ e(
|
|
106
|
+
n,
|
|
107
|
+
{
|
|
108
|
+
variant: "error",
|
|
109
|
+
size: "sm",
|
|
110
|
+
withDot: !0,
|
|
111
|
+
leading: /* @__PURE__ */ e(y, { "aria-hidden": "true" }),
|
|
112
|
+
"aria-label": a("anamnesisCard.answerFlagLabel", {
|
|
113
|
+
defaultValue: "Flagged answer"
|
|
114
|
+
})
|
|
115
|
+
}
|
|
116
|
+
) : null
|
|
117
|
+
] }) }),
|
|
118
|
+
/* @__PURE__ */ e(t.Detail, { children: l.answer })
|
|
119
|
+
]
|
|
120
|
+
},
|
|
121
|
+
E
|
|
122
|
+
)) }) : /* @__PURE__ */ e("p", { className: "type-body-sm ds:m-0 ds:text-[color:var(--muted-foreground)]", children: a("anamnesisCard.empty", {
|
|
123
|
+
defaultValue: "No answers were recorded."
|
|
124
|
+
}) }), b = /* @__PURE__ */ r("div", { className: "ds:flex ds:flex-col ds:gap-[var(--spacing-md)]", children: [
|
|
125
|
+
j,
|
|
126
|
+
/* @__PURE__ */ e(G, { type: "single", collapsible: !0, variant: "separated", children: /* @__PURE__ */ r(O, { value: L, children: [
|
|
127
|
+
/* @__PURE__ */ e(Q, { children: a("anamnesisCard.interviewToggle", {
|
|
128
|
+
count: g,
|
|
129
|
+
defaultValue: "Interview ({{count}} answers)"
|
|
130
|
+
}) }),
|
|
131
|
+
/* @__PURE__ */ e(S, { children: k })
|
|
132
|
+
] }) })
|
|
133
|
+
] });
|
|
134
|
+
return /* @__PURE__ */ e(
|
|
135
|
+
"div",
|
|
136
|
+
{
|
|
137
|
+
ref: I,
|
|
138
|
+
role: "region",
|
|
139
|
+
"aria-label": B,
|
|
140
|
+
"aria-labelledby": h,
|
|
141
|
+
"data-component": "anamnesis-card",
|
|
142
|
+
"data-component-id": f,
|
|
143
|
+
"data-has-flags": i || void 0,
|
|
144
|
+
id: f,
|
|
145
|
+
className: H({ surface: p, className: D }),
|
|
146
|
+
...F,
|
|
147
|
+
children: p === "elevated" ? /* @__PURE__ */ e(N, { variant: "elevated", children: /* @__PURE__ */ e(N.Body, { children: b }) }) : b
|
|
148
|
+
}
|
|
149
|
+
);
|
|
150
|
+
}
|
|
151
|
+
);
|
|
152
|
+
J.displayName = "AnamnesisCard";
|
|
153
|
+
export {
|
|
154
|
+
J as A
|
|
155
|
+
};
|
|
156
|
+
//# sourceMappingURL=anamnesis-card-CmkBVAln.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"anamnesis-card-CmkBVAln.js","sources":["../../src/components/anamnesis-card/anamnesis-card.tsx"],"sourcesContent":["import {\n forwardRef,\n useId,\n useMemo,\n type ComponentPropsWithoutRef,\n type ReactNode,\n} from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport { AlertTriangle } from 'lucide-react';\nimport { Badge } from '../badge/badge';\nimport { Card } from '../card/card';\nimport {\n Accordion,\n AccordionItem,\n AccordionTrigger,\n AccordionContent,\n} from '../accordion/accordion';\nimport { DescriptionList } from '../description-list/description-list';\nimport { Timestamp } from '../timestamp/timestamp';\n\n/* -------------------------------------------------------------------- */\n/* AnamnesisCard */\n/* */\n/* A completed medical-history questionnaire (anamnesi) rendered as a */\n/* collapsible interview. Replaces the bespoke \"scheda anamnestica\" */\n/* cards every clinical surface composes by hand: a header summarising */\n/* the form (compiled date, form name) with status chips, and a */\n/* collapsible body listing each question/answer pair as a */\n/* DescriptionList (dt = question, dd = answer). */\n/* */\n/* The clinical red-flag count (`highlightedAnswerCount`) is the most */\n/* prominent signal: an `error` Badge carrying a NON-colour cue */\n/* (warning glyph + dot) so colour-blind clinicians still read it. The */\n/* expired / corrupted statuses surface as warning / error chips beside */\n/* it. Per-answer `highlight` flags emphasise the matching rows inside */\n/* the interview. */\n/* */\n/* All visible text flows through `useTranslation('ui')` against the */\n/* `anamnesisCard.*` namespace. Consumers pass IDENTIFIERS + structural */\n/* data; the kit owns the chrome + i18n. No PHI lives in the agent layer. */\n/* -------------------------------------------------------------------- */\n\n/* -------------------------------------------------------------------- */\n/* CVA — root */\n/* -------------------------------------------------------------------- */\n\nconst rootVariants = cva('ds:w-full ds:text-[color:var(--foreground)]', {\n variants: {\n // Matches the kit's other `surface` props. `'elevated'` (default)\n // wraps in `<Card variant=\"elevated\">`; `'flat'` drops the chrome\n // for use inside an existing Card / Sheet.\n surface: {\n flat: '',\n elevated: '',\n },\n },\n defaultVariants: { surface: 'elevated' },\n});\n\n/* -------------------------------------------------------------------- */\n/* Public types */\n/* -------------------------------------------------------------------- */\n\nexport interface AnamnesisCardAnswer {\n /** The questionnaire question text. Rendered as the `<dt>` term. */\n question: string;\n /** The patient's recorded answer. Rendered as the `<dd>` detail. */\n answer: ReactNode;\n /**\n * Marks this row as a clinical red-flag answer. Highlighted rows render\n * a `bordered` divider + an inline-end warning chip so they stand out\n * within the interview body — with the warning glyph carrying the cue,\n * not colour alone.\n */\n highlight?: boolean;\n}\n\nexport interface AnamnesisCardStatus {\n /** The questionnaire is past its validity window — surfaces a warning chip. */\n expired?: boolean;\n /** The submission is corrupted / incomplete — surfaces an error chip. */\n corrupted?: boolean;\n}\n\nexport interface AnamnesisCardProps extends Omit<\n ComponentPropsWithoutRef<'div'>,\n 'aria-label' | 'children' | 'title'\n> {\n /**\n * The questionnaire's compiled / reference date as an ISO-8601 string.\n * Rendered as an absolute `<Timestamp>` in the header.\n */\n dateIso: string;\n /**\n * Optional submission / creation timestamp as an ISO-8601 string.\n * Rendered as a relative `<Timestamp>` caption beneath the heading.\n */\n createdAtIso?: string;\n /**\n * Form / template name (e.g. \"Anamnesi generale\"). When omitted, a\n * localised generic heading is used.\n */\n formName?: string;\n /**\n * Count of answers flagged as clinical red-flags. When `> 0`, renders\n * the prominent `error` Badge with a warning glyph + colour-blind dot.\n * Omit / `0` hides the chip.\n */\n highlightedAnswerCount?: number;\n /** Lifecycle / integrity status — drives the warning / error chips. */\n status?: AnamnesisCardStatus;\n /**\n * The question/answer pairs. Rendered inside the collapsible interview\n * as a `<DescriptionList>` (dt = question, dd = answer). When empty or\n * omitted, the interview shows a localised \"no answers\" line.\n */\n answers?: AnamnesisCardAnswer[];\n /**\n * `'elevated'` (default) wraps in `<Card variant=\"elevated\">`. `'flat'`\n * drops the Card — use inside another card / sheet.\n */\n surface?: 'flat' | 'elevated';\n\n /* ----- a11y ----- */\n\n /** Override the default region aria-label. */\n 'aria-label'?: string;\n /** Agent-readiness consumer id, surfaced as `data-component-id`. */\n id?: string;\n}\n\n/* -------------------------------------------------------------------- */\n/* Component */\n/* -------------------------------------------------------------------- */\n\nexport const AnamnesisCard = forwardRef<HTMLDivElement, AnamnesisCardProps>(\n (\n {\n dateIso,\n createdAtIso,\n formName,\n highlightedAnswerCount = 0,\n status,\n answers,\n surface = 'elevated',\n 'aria-label': ariaLabel,\n id,\n className,\n ...rest\n },\n ref,\n ) => {\n const { t } = useTranslation();\n const headingId = useId();\n const accordionItemValue = useId();\n\n const resolvedFormName =\n formName ??\n t('anamnesisCard.defaultFormName', { defaultValue: 'Medical history' });\n const resolvedAriaLabel = ariaLabel ?? resolvedFormName;\n\n const hasFlags = highlightedAnswerCount > 0;\n const isExpired = status?.expired === true;\n const isCorrupted = status?.corrupted === true;\n\n const answerCount = answers?.length ?? 0;\n\n // Chip strip — the red-flag count first (most prominent), then the\n // integrity statuses. Each carries a non-colour cue (glyph / dot) so\n // colour-blind clinicians read the signal without relying on hue.\n const statusChips = useMemo<ReactNode>(() => {\n if (!hasFlags && !isExpired && !isCorrupted) return null;\n return (\n <div\n role=\"list\"\n aria-label={t('anamnesisCard.statusGroupLabel', {\n defaultValue: 'Questionnaire status',\n })}\n className=\"ds:flex ds:flex-wrap ds:items-center ds:gap-[var(--spacing-2xs)]\"\n >\n {hasFlags ? (\n <Badge\n variant=\"error\"\n withDot\n leading={<AlertTriangle aria-hidden=\"true\" />}\n role=\"listitem\"\n >\n {t('anamnesisCard.status.highlighted', {\n count: highlightedAnswerCount,\n defaultValue: '{{count}} flagged answers',\n })}\n </Badge>\n ) : null}\n {isExpired ? (\n <Badge variant=\"warning\" withDot role=\"listitem\">\n {t('anamnesisCard.status.expired', { defaultValue: 'Expired' })}\n </Badge>\n ) : null}\n {isCorrupted ? (\n <Badge variant=\"error\" withDot role=\"listitem\">\n {t('anamnesisCard.status.corrupted', {\n defaultValue: 'Corrupted',\n })}\n </Badge>\n ) : null}\n </div>\n );\n }, [hasFlags, isExpired, isCorrupted, highlightedAnswerCount, t]);\n\n const header = (\n <div className=\"ds:flex ds:flex-col ds:gap-[var(--spacing-xs)]\">\n <div className=\"ds:flex ds:flex-wrap ds:items-start ds:gap-[var(--spacing-sm)]\">\n <h3\n id={headingId}\n className=\"type-title-card ds:m-0 ds:text-[color:var(--foreground)]\"\n >\n {resolvedFormName}\n </h3>\n {statusChips ? (\n <div className=\"ds:ms-auto ds:flex ds:shrink-0 ds:items-center\">\n {statusChips}\n </div>\n ) : null}\n </div>\n <p className=\"type-body-sm ds:m-0 ds:flex ds:flex-wrap ds:items-center ds:gap-[var(--spacing-xs)] ds:text-[color:var(--muted-foreground)]\">\n <span>\n {t('anamnesisCard.compiledOn', { defaultValue: 'Compiled' })}{' '}\n <Timestamp value={dateIso} format=\"absolute\" shape=\"bare\" />\n </span>\n {createdAtIso ? (\n <span className=\"ds:flex ds:items-center ds:gap-[var(--spacing-xs)]\">\n <span aria-hidden=\"true\">·</span>\n <span>\n {t('anamnesisCard.submitted', { defaultValue: 'Submitted' })}{' '}\n <Timestamp\n value={createdAtIso}\n format=\"relative\"\n shape=\"bare\"\n />\n </span>\n </span>\n ) : null}\n </p>\n </div>\n );\n\n const interview =\n answerCount > 0 ? (\n <DescriptionList layout=\"stacked\" density=\"compact\" divider=\"between\">\n {answers!.map((row, index) => (\n <DescriptionList.Row\n key={index}\n className={\n row.highlight\n ? 'ds:border ds:border-[color:var(--destructive)] ds:rounded-[var(--radius-sm)] ds:p-[var(--spacing-sm)]'\n : undefined\n }\n >\n <DescriptionList.Term>\n <span className=\"ds:flex ds:items-center ds:gap-[var(--spacing-xs)]\">\n <span>{row.question}</span>\n {row.highlight ? (\n <Badge\n variant=\"error\"\n size=\"sm\"\n withDot\n leading={<AlertTriangle aria-hidden=\"true\" />}\n aria-label={t('anamnesisCard.answerFlagLabel', {\n defaultValue: 'Flagged answer',\n })}\n />\n ) : null}\n </span>\n </DescriptionList.Term>\n <DescriptionList.Detail>{row.answer}</DescriptionList.Detail>\n </DescriptionList.Row>\n ))}\n </DescriptionList>\n ) : (\n <p className=\"type-body-sm ds:m-0 ds:text-[color:var(--muted-foreground)]\">\n {t('anamnesisCard.empty', {\n defaultValue: 'No answers were recorded.',\n })}\n </p>\n );\n\n const inner = (\n <div className=\"ds:flex ds:flex-col ds:gap-[var(--spacing-md)]\">\n {header}\n <Accordion type=\"single\" collapsible variant=\"separated\">\n <AccordionItem value={accordionItemValue}>\n <AccordionTrigger>\n {t('anamnesisCard.interviewToggle', {\n count: answerCount,\n defaultValue: 'Interview ({{count}} answers)',\n })}\n </AccordionTrigger>\n <AccordionContent>{interview}</AccordionContent>\n </AccordionItem>\n </Accordion>\n </div>\n );\n\n return (\n <div\n ref={ref}\n role=\"region\"\n aria-label={resolvedAriaLabel}\n aria-labelledby={headingId}\n data-component=\"anamnesis-card\"\n data-component-id={id}\n data-has-flags={hasFlags || undefined}\n id={id}\n className={rootVariants({ surface, className })}\n {...rest}\n >\n {surface === 'elevated' ? (\n <Card variant=\"elevated\">\n <Card.Body>{inner}</Card.Body>\n </Card>\n ) : (\n inner\n )}\n </div>\n );\n },\n);\n\nAnamnesisCard.displayName = 'AnamnesisCard';\n\nexport type AnamnesisCardSurface = NonNullable<\n VariantProps<typeof rootVariants>['surface']\n>;\n"],"names":["rootVariants","cva","AnamnesisCard","forwardRef","dateIso","createdAtIso","formName","highlightedAnswerCount","status","answers","surface","ariaLabel","id","className","rest","ref","t","useTranslation","headingId","useId","accordionItemValue","resolvedFormName","resolvedAriaLabel","hasFlags","isExpired","isCorrupted","answerCount","statusChips","useMemo","jsxs","jsx","Badge","AlertTriangle","header","Timestamp","interview","DescriptionList","row","index","inner","Accordion","AccordionItem","AccordionTrigger","AccordionContent","Card"],"mappings":"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"}
|
|
@@ -0,0 +1,419 @@
|
|
|
1
|
+
import { jsx as a, jsxs as s } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef as $, useRef as K, useImperativeHandle as Y, useMemo as J } from "react";
|
|
3
|
+
import { c as H } from "./index-D2ZczOXr.js";
|
|
4
|
+
import { useTranslation as G } from "react-i18next";
|
|
5
|
+
import { I as Q } from "./icon-button-CKEOrN37.js";
|
|
6
|
+
import { S as X } from "./skeleton-CZbwyJAA.js";
|
|
7
|
+
import { E as Z } from "./empty-state-BLy7tigq.js";
|
|
8
|
+
import { A as U } from "./avatar-BNQNhoyL.js";
|
|
9
|
+
import { B as P } from "./badge-zsf5i5bH.js";
|
|
10
|
+
import { T as ee } from "./tag-CdA0s_VV.js";
|
|
11
|
+
import { T as ae } from "./timestamp-BV2lC-wV.js";
|
|
12
|
+
import { T as se } from "./transaction-chip-BZCa6XDn.js";
|
|
13
|
+
import { i as re } from "./is-safe-url-DkETxeHz.js";
|
|
14
|
+
import { V as te } from "./video-BAeICxCT.js";
|
|
15
|
+
import { M as ne } from "./map-pin-B8STOPMJ.js";
|
|
16
|
+
import { c as q, a as oe } from "./entity-card-COhmqHly.js";
|
|
17
|
+
import { S as ie } from "./star-vav0SJ9e.js";
|
|
18
|
+
import { G as de } from "./globe-BkEFMNSg.js";
|
|
19
|
+
import { C as le } from "./chevron-right-BrpYejk0.js";
|
|
20
|
+
import { u as ce } from "./registry-nPAVE19X.js";
|
|
21
|
+
import { C as pe } from "./calendar-days-C4BmpCZg.js";
|
|
22
|
+
import { P as me } from "./plus-CYKNmfuA.js";
|
|
23
|
+
const ue = {
|
|
24
|
+
"var(--color-violet-500)": "ds:bg-[var(--color-violet-500)]",
|
|
25
|
+
"var(--color-purple-500)": "ds:bg-[var(--color-purple-500)]",
|
|
26
|
+
"var(--color-magenta-500)": "ds:bg-[var(--color-magenta-500)]",
|
|
27
|
+
"var(--color-blue-500)": "ds:bg-[var(--color-blue-500)]",
|
|
28
|
+
"var(--color-green-500)": "ds:bg-[var(--color-green-500)]",
|
|
29
|
+
"var(--color-red-500)": "ds:bg-[var(--color-red-500)]",
|
|
30
|
+
"var(--color-yellow-500)": "ds:bg-[var(--color-yellow-500)]",
|
|
31
|
+
"var(--color-indigo-500)": "ds:bg-[var(--color-indigo-500)]",
|
|
32
|
+
"var(--color-orange-500)": "ds:bg-[var(--color-orange-500)]",
|
|
33
|
+
"var(--color-fuchsia-500)": "ds:bg-[var(--color-fuchsia-500)]",
|
|
34
|
+
"var(--color-grey-700)": "ds:bg-[var(--color-grey-700)]"
|
|
35
|
+
};
|
|
36
|
+
function fe(e) {
|
|
37
|
+
return ue[q(e)] ?? "ds:bg-[var(--color-grey-700)]";
|
|
38
|
+
}
|
|
39
|
+
const ge = H(
|
|
40
|
+
[
|
|
41
|
+
"ds:relative ds:flex ds:items-start ds:gap-[var(--spacing-sm)]",
|
|
42
|
+
"ds:rounded-[var(--radius-md)]",
|
|
43
|
+
"ds:text-start ds:group",
|
|
44
|
+
"ds:bg-[var(--card)] ds:text-[color:var(--card-foreground)]",
|
|
45
|
+
"ds:transition-colors ds:duration-[var(--animation-duration)]",
|
|
46
|
+
"ds:motion-reduce:transition-none",
|
|
47
|
+
"ds:forced-colors:border ds:forced-colors:border-[CanvasText]"
|
|
48
|
+
].join(" "),
|
|
49
|
+
{
|
|
50
|
+
variants: {
|
|
51
|
+
size: {
|
|
52
|
+
sm: "ds:p-[var(--spacing-sm)]",
|
|
53
|
+
md: "ds:p-[var(--spacing-md)]"
|
|
54
|
+
},
|
|
55
|
+
interactive: {
|
|
56
|
+
true: "ds:hover:bg-[color:var(--muted)]/40 ds:cursor-pointer",
|
|
57
|
+
false: ""
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
defaultVariants: {
|
|
61
|
+
size: "sm",
|
|
62
|
+
interactive: !1
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
), B = [
|
|
66
|
+
"ds:focus-visible:outline-none",
|
|
67
|
+
"ds:after:content-[''] ds:after:absolute ds:after:inset-0 ds:after:rounded-[var(--radius-md)]",
|
|
68
|
+
"ds:after:pointer-events-auto",
|
|
69
|
+
"ds:focus-visible:after:outline-[length:var(--focus-ring-width)]",
|
|
70
|
+
"ds:focus-visible:after:outline-solid",
|
|
71
|
+
"ds:focus-visible:after:outline-[color:var(--ring)]",
|
|
72
|
+
"ds:focus-visible:after:outline-offset-[length:var(--focus-ring-offset)]",
|
|
73
|
+
"ds:forced-colors:focus-visible:after:outline-[CanvasText]"
|
|
74
|
+
].join(" "), ve = {
|
|
75
|
+
inPractice: ne,
|
|
76
|
+
telehealth: te
|
|
77
|
+
}, F = $(
|
|
78
|
+
({
|
|
79
|
+
item: e,
|
|
80
|
+
size: i = "sm",
|
|
81
|
+
locale: b,
|
|
82
|
+
currency: x = "EUR",
|
|
83
|
+
onActivate: o,
|
|
84
|
+
className: I,
|
|
85
|
+
...R
|
|
86
|
+
}, l) => {
|
|
87
|
+
var h, w, t, y, z, V, E, j, L, A, M, _, D;
|
|
88
|
+
const { t: r } = G(), m = !!o, N = !!e.url && re(e.url), v = ((h = e.patient) == null ? void 0 : h.name) ?? r("appointmentCard.noPatient"), c = (w = e.operator) == null ? void 0 : w.name, C = r(`appointmentCard.state.${e.state}`), k = i === "md" ? "md" : "sm", S = ve[e.type], p = r("appointmentCard.itemLabel", {
|
|
89
|
+
patient: v,
|
|
90
|
+
state: C
|
|
91
|
+
}), u = /* @__PURE__ */ a("span", { className: "ds:min-w-0 ds:truncate type-title-item ds:text-[color:var(--foreground)]", children: v });
|
|
92
|
+
let f;
|
|
93
|
+
m && N ? f = /* @__PURE__ */ a(
|
|
94
|
+
"a",
|
|
95
|
+
{
|
|
96
|
+
href: e.url,
|
|
97
|
+
"aria-label": p,
|
|
98
|
+
className: B + " ds:contents",
|
|
99
|
+
onClick: (n) => {
|
|
100
|
+
n.defaultPrevented || n.metaKey || n.ctrlKey || n.shiftKey || o == null || o(e);
|
|
101
|
+
},
|
|
102
|
+
children: u
|
|
103
|
+
}
|
|
104
|
+
) : m ? f = /* @__PURE__ */ a(
|
|
105
|
+
"button",
|
|
106
|
+
{
|
|
107
|
+
type: "button",
|
|
108
|
+
"aria-label": p,
|
|
109
|
+
className: B + " ds:contents ds:bg-transparent ds:border-0 ds:p-0 ds:text-start",
|
|
110
|
+
onClick: () => o == null ? void 0 : o(e),
|
|
111
|
+
children: u
|
|
112
|
+
}
|
|
113
|
+
) : f = u;
|
|
114
|
+
const T = (e.treatments ?? []).map((n, O) => {
|
|
115
|
+
const W = n.elements && n.elements.length > 0 ? r("appointmentCard.treatmentWithElements", {
|
|
116
|
+
care: n.careName,
|
|
117
|
+
elements: n.elements.join(", ")
|
|
118
|
+
}) : n.careName;
|
|
119
|
+
return /* @__PURE__ */ a(
|
|
120
|
+
ee,
|
|
121
|
+
{
|
|
122
|
+
label: W,
|
|
123
|
+
variant: "neutral",
|
|
124
|
+
fill: "outline",
|
|
125
|
+
size: "sm",
|
|
126
|
+
maxInlineSize: "12rem"
|
|
127
|
+
},
|
|
128
|
+
`${n.careName}-${O}`
|
|
129
|
+
);
|
|
130
|
+
}), d = (t = e.bookingReason) == null ? void 0 : t.advanceAmountCents, g = typeof d == "number" && d > 0;
|
|
131
|
+
return /* @__PURE__ */ s(
|
|
132
|
+
"div",
|
|
133
|
+
{
|
|
134
|
+
ref: l,
|
|
135
|
+
role: "listitem",
|
|
136
|
+
"data-component": "appointment-card",
|
|
137
|
+
"data-component-id": e.id,
|
|
138
|
+
"data-state": e.state,
|
|
139
|
+
"data-type": e.type,
|
|
140
|
+
className: ge({ size: i, interactive: m, className: I }),
|
|
141
|
+
...R,
|
|
142
|
+
children: [
|
|
143
|
+
/* @__PURE__ */ s("span", { className: "ds:flex ds:w-16 ds:shrink-0 ds:flex-col ds:items-start ds:gap-[var(--spacing-2xs)]", children: [
|
|
144
|
+
/* @__PURE__ */ s("span", { className: "ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)] ds:text-[color:var(--muted-foreground)]", children: [
|
|
145
|
+
/* @__PURE__ */ a(S, { "aria-hidden": "true", className: "ds:size-3.5 ds:shrink-0" }),
|
|
146
|
+
/* @__PURE__ */ a("span", { className: "ds:sr-only", children: r(`appointmentCard.type.${e.type}`) }),
|
|
147
|
+
/* @__PURE__ */ a(
|
|
148
|
+
ae,
|
|
149
|
+
{
|
|
150
|
+
value: e.startIso,
|
|
151
|
+
format: "absolute",
|
|
152
|
+
shape: "bare",
|
|
153
|
+
locale: b,
|
|
154
|
+
absoluteFormat: { hour: "numeric", minute: "2-digit" },
|
|
155
|
+
className: "type-body-sm ds:font-medium ds:text-[color:var(--foreground)] ds:tabular-nums"
|
|
156
|
+
}
|
|
157
|
+
)
|
|
158
|
+
] }),
|
|
159
|
+
/* @__PURE__ */ a("span", { className: "type-eyebrow ds:text-[color:var(--muted-foreground)]", children: r("appointmentCard.duration", { count: e.durationMin }) })
|
|
160
|
+
] }),
|
|
161
|
+
c ? /* @__PURE__ */ s("span", { className: "ds:relative ds:shrink-0", children: [
|
|
162
|
+
/* @__PURE__ */ a(
|
|
163
|
+
U,
|
|
164
|
+
{
|
|
165
|
+
name: c,
|
|
166
|
+
color: q((y = e.operator) == null ? void 0 : y.colorId),
|
|
167
|
+
size: k,
|
|
168
|
+
"aria-hidden": "true",
|
|
169
|
+
role: "presentation",
|
|
170
|
+
"aria-label": void 0
|
|
171
|
+
}
|
|
172
|
+
),
|
|
173
|
+
/* @__PURE__ */ a(
|
|
174
|
+
"span",
|
|
175
|
+
{
|
|
176
|
+
"aria-hidden": "true",
|
|
177
|
+
className: "ds:absolute ds:bottom-0 ds:end-0 ds:size-2.5 ds:rounded-[var(--radius-full)] ds:border ds:border-[color:var(--card)] " + fe((z = e.operator) == null ? void 0 : z.colorId)
|
|
178
|
+
}
|
|
179
|
+
)
|
|
180
|
+
] }) : null,
|
|
181
|
+
/* @__PURE__ */ s("div", { className: "ds:flex-1 ds:min-w-0 ds:flex ds:flex-col ds:gap-[var(--spacing-xs)]", children: [
|
|
182
|
+
/* @__PURE__ */ s("div", { className: "ds:flex ds:items-start ds:gap-[var(--spacing-sm)]", children: [
|
|
183
|
+
/* @__PURE__ */ s("div", { className: "ds:flex-1 ds:min-w-0 ds:flex ds:items-center ds:gap-[var(--spacing-xs)]", children: [
|
|
184
|
+
(V = e.patient) != null && V.avatarUrl ? /* @__PURE__ */ a(
|
|
185
|
+
U,
|
|
186
|
+
{
|
|
187
|
+
name: v,
|
|
188
|
+
src: e.patient.avatarUrl,
|
|
189
|
+
size: k,
|
|
190
|
+
className: "ds:shrink-0",
|
|
191
|
+
"aria-hidden": "true",
|
|
192
|
+
role: "presentation",
|
|
193
|
+
"aria-label": void 0
|
|
194
|
+
}
|
|
195
|
+
) : null,
|
|
196
|
+
f
|
|
197
|
+
] }),
|
|
198
|
+
/* @__PURE__ */ a(
|
|
199
|
+
P,
|
|
200
|
+
{
|
|
201
|
+
variant: oe(e.state),
|
|
202
|
+
size: "sm",
|
|
203
|
+
withDot: !0,
|
|
204
|
+
className: "ds:shrink-0",
|
|
205
|
+
children: C
|
|
206
|
+
}
|
|
207
|
+
)
|
|
208
|
+
] }),
|
|
209
|
+
c || e.chair || (E = e.bookingReason) != null && E.specialty || e.firstVisit === "yes" ? /* @__PURE__ */ s("div", { className: "ds:flex ds:flex-wrap ds:items-center ds:gap-x-[var(--spacing-sm)] ds:gap-y-[var(--spacing-2xs)] type-eyebrow ds:text-[color:var(--muted-foreground)]", children: [
|
|
210
|
+
c ? /* @__PURE__ */ a("span", { children: c }) : null,
|
|
211
|
+
e.chair ? /* @__PURE__ */ a("span", { children: r("appointmentCard.chair", { chair: e.chair }) }) : null,
|
|
212
|
+
(j = e.bookingReason) != null && j.specialty ? /* @__PURE__ */ a("span", { children: e.bookingReason.specialty }) : null,
|
|
213
|
+
e.firstVisit === "yes" ? /* @__PURE__ */ s("span", { className: "ds:inline-flex ds:items-center ds:gap-[var(--spacing-2xs)]", children: [
|
|
214
|
+
/* @__PURE__ */ a(ie, { "aria-hidden": "true", className: "ds:size-3 ds:shrink-0" }),
|
|
215
|
+
r("appointmentCard.firstVisit")
|
|
216
|
+
] }) : null
|
|
217
|
+
] }) : null,
|
|
218
|
+
(L = e.bookingReason) != null && L.description ? /* @__PURE__ */ a("span", { className: "type-body-sm ds:text-[color:var(--foreground)] ds:truncate", children: e.bookingReason.description }) : null,
|
|
219
|
+
T.length > 0 ? /* @__PURE__ */ a("div", { className: "ds:flex ds:flex-wrap ds:gap-[var(--spacing-2xs)]", children: T }) : null,
|
|
220
|
+
(A = e.flags) != null && A.bookedOnline || (M = e.flags) != null && M.highlightedAnamnesis || g ? /* @__PURE__ */ s("div", { className: "ds:flex ds:flex-wrap ds:items-center ds:gap-[var(--spacing-xs)]", children: [
|
|
221
|
+
(_ = e.flags) != null && _.bookedOnline ? /* @__PURE__ */ a(P, { variant: "info", size: "sm", leading: /* @__PURE__ */ a(de, {}), children: r("appointmentCard.flag.bookedOnline") }) : null,
|
|
222
|
+
(D = e.flags) != null && D.highlightedAnamnesis ? /* @__PURE__ */ a(P, { variant: "warning", size: "sm", withDot: !0, children: r("appointmentCard.flag.highlightedAnamnesis") }) : null,
|
|
223
|
+
g ? /* @__PURE__ */ a(
|
|
224
|
+
se,
|
|
225
|
+
{
|
|
226
|
+
state: "to-invoice",
|
|
227
|
+
amount: d / 100,
|
|
228
|
+
currency: x,
|
|
229
|
+
locale: b,
|
|
230
|
+
size: "sm",
|
|
231
|
+
showLabel: !0
|
|
232
|
+
}
|
|
233
|
+
) : null
|
|
234
|
+
] }) : null
|
|
235
|
+
] }),
|
|
236
|
+
m ? /* @__PURE__ */ a(
|
|
237
|
+
le,
|
|
238
|
+
{
|
|
239
|
+
"aria-hidden": "true",
|
|
240
|
+
className: "ds:size-4 ds:shrink-0 ds:self-center ds:text-[color:var(--muted-foreground)] ds:opacity-0 ds:transition-opacity ds:motion-reduce:transition-none ds:group-hover:opacity-100 ds:group-focus-within:opacity-100 ds:rtl:rotate-180"
|
|
241
|
+
}
|
|
242
|
+
) : null
|
|
243
|
+
]
|
|
244
|
+
}
|
|
245
|
+
);
|
|
246
|
+
}
|
|
247
|
+
);
|
|
248
|
+
F.displayName = "AppointmentCard";
|
|
249
|
+
const $e = {
|
|
250
|
+
id: "appointment-card",
|
|
251
|
+
capabilities: ["pick"],
|
|
252
|
+
state: {},
|
|
253
|
+
actions: {},
|
|
254
|
+
domHooks: {
|
|
255
|
+
root: {
|
|
256
|
+
attr: "data-component",
|
|
257
|
+
value: "appointment-card",
|
|
258
|
+
description: "Marks the element as a kit AppointmentCard. The root also emits data-component-id sourced from item.id, data-state with the appointment lifecycle, and data-type with the delivery channel."
|
|
259
|
+
},
|
|
260
|
+
instanceId: {
|
|
261
|
+
attr: "data-component-id",
|
|
262
|
+
sourceProp: "item.id",
|
|
263
|
+
description: "Sourced from item.id — the stable appointment identifier."
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
}, he = {
|
|
267
|
+
id: "appointment-tray",
|
|
268
|
+
capabilities: ["select_single"],
|
|
269
|
+
state: {
|
|
270
|
+
items: {
|
|
271
|
+
type: "Array<{ id: string; state: string }>",
|
|
272
|
+
descriptionKey: "ui.agent.appointmentTray.state.items",
|
|
273
|
+
description: "Currently-displayed appointments. Ids + lifecycle state only — never patient identity.",
|
|
274
|
+
read: (e) => e.getItems()
|
|
275
|
+
}
|
|
276
|
+
},
|
|
277
|
+
actions: {
|
|
278
|
+
select_item: {
|
|
279
|
+
safety: "read",
|
|
280
|
+
argsType: "{ id: string }",
|
|
281
|
+
descriptionKey: "ui.agent.appointmentTray.actions.selectItem",
|
|
282
|
+
description: "Activate the appointment with the given id.",
|
|
283
|
+
invoke: (e, i) => {
|
|
284
|
+
e.selectItem(i.id);
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
},
|
|
288
|
+
domHooks: {
|
|
289
|
+
root: {
|
|
290
|
+
attr: "data-component",
|
|
291
|
+
value: "appointment-tray",
|
|
292
|
+
description: "Marks the AppointmentTray wrapper."
|
|
293
|
+
},
|
|
294
|
+
instanceId: {
|
|
295
|
+
attr: "data-component-id",
|
|
296
|
+
sourceProp: "id",
|
|
297
|
+
description: "Sourced from the id prop. Required to address a specific tray from the agent."
|
|
298
|
+
},
|
|
299
|
+
item: {
|
|
300
|
+
attr: "data-appointment-id",
|
|
301
|
+
description: "Stable appointment id emitted on each rendered AppointmentCard inside the tray."
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
}, ye = H(
|
|
305
|
+
[
|
|
306
|
+
"ds:flex ds:flex-col",
|
|
307
|
+
"ds:rounded-[var(--radius-md)] ds:shadow-[var(--shadow-card)]",
|
|
308
|
+
"ds:border ds:border-[color:var(--card-border)] ds:[.theme-accessible_&]:border-2",
|
|
309
|
+
"ds:bg-[color:var(--card)] ds:text-[color:var(--card-foreground)]",
|
|
310
|
+
"ds:overflow-hidden"
|
|
311
|
+
].join(" "),
|
|
312
|
+
{
|
|
313
|
+
variants: {
|
|
314
|
+
size: {
|
|
315
|
+
sm: "",
|
|
316
|
+
md: ""
|
|
317
|
+
}
|
|
318
|
+
},
|
|
319
|
+
defaultVariants: {
|
|
320
|
+
size: "sm"
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
), be = $(
|
|
324
|
+
({
|
|
325
|
+
id: e,
|
|
326
|
+
items: i,
|
|
327
|
+
title: b,
|
|
328
|
+
caption: x,
|
|
329
|
+
size: o = "sm",
|
|
330
|
+
locale: I,
|
|
331
|
+
currency: R,
|
|
332
|
+
onOpenAppointment: l,
|
|
333
|
+
onAddAppointment: r,
|
|
334
|
+
addLabel: m,
|
|
335
|
+
loading: N = !1,
|
|
336
|
+
emptyTitle: v,
|
|
337
|
+
emptyDescription: c,
|
|
338
|
+
className: C,
|
|
339
|
+
...k
|
|
340
|
+
}, S) => {
|
|
341
|
+
const { t: p } = G(), u = b ?? p("appointmentTray.title"), f = m ?? p("appointmentTray.add"), T = !N && i.length === 0;
|
|
342
|
+
let d;
|
|
343
|
+
N ? d = /* @__PURE__ */ a("div", { className: "ds:flex ds:flex-col ds:gap-[var(--spacing-sm)] ds:p-[var(--spacing-sm)]", children: [0, 1, 2].map((t) => /* @__PURE__ */ a(X, { variant: "rectangular", height: "3.5rem" }, t)) }) : T ? d = /* @__PURE__ */ a("div", { className: "ds:p-[var(--spacing-md)]", children: /* @__PURE__ */ a(
|
|
344
|
+
Z,
|
|
345
|
+
{
|
|
346
|
+
variant: "first-use",
|
|
347
|
+
size: "sm",
|
|
348
|
+
title: v ?? p("appointmentTray.empty.title"),
|
|
349
|
+
description: c ?? p("appointmentTray.empty.description")
|
|
350
|
+
}
|
|
351
|
+
) }) : d = /* @__PURE__ */ a("ul", { className: "ds:flex ds:list-none ds:flex-col ds:gap-[var(--spacing-2xs)] ds:p-[var(--spacing-2xs)]", children: i.map((t) => /* @__PURE__ */ a(
|
|
352
|
+
F,
|
|
353
|
+
{
|
|
354
|
+
item: t,
|
|
355
|
+
size: o,
|
|
356
|
+
locale: I,
|
|
357
|
+
currency: R,
|
|
358
|
+
onActivate: l,
|
|
359
|
+
"data-appointment-id": t.id
|
|
360
|
+
},
|
|
361
|
+
t.id
|
|
362
|
+
)) });
|
|
363
|
+
const g = K(i);
|
|
364
|
+
g.current = i;
|
|
365
|
+
const h = K(null);
|
|
366
|
+
Y(S, () => h.current, []);
|
|
367
|
+
const w = J(
|
|
368
|
+
() => ({
|
|
369
|
+
getItems: () => g.current.map((t) => ({ id: t.id, state: t.state })),
|
|
370
|
+
selectItem: (t) => {
|
|
371
|
+
const y = g.current.find((z) => z.id === t);
|
|
372
|
+
y && (l == null || l(y));
|
|
373
|
+
}
|
|
374
|
+
}),
|
|
375
|
+
[l]
|
|
376
|
+
);
|
|
377
|
+
return ce(he, w, e), /* @__PURE__ */ s(
|
|
378
|
+
"section",
|
|
379
|
+
{
|
|
380
|
+
ref: h,
|
|
381
|
+
"aria-label": u,
|
|
382
|
+
"data-component": "appointment-tray",
|
|
383
|
+
"data-component-id": e,
|
|
384
|
+
className: ye({ size: o, className: C }),
|
|
385
|
+
...k,
|
|
386
|
+
children: [
|
|
387
|
+
/* @__PURE__ */ s("header", { className: "ds:flex ds:items-center ds:justify-between ds:gap-[var(--spacing-sm)] ds:p-[var(--spacing-sm)]", children: [
|
|
388
|
+
/* @__PURE__ */ s("div", { className: "ds:flex ds:flex-col ds:gap-[var(--spacing-2xs)] ds:min-w-0", children: [
|
|
389
|
+
/* @__PURE__ */ s("h3", { className: "ds:m-0 ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)] type-title-card", children: [
|
|
390
|
+
/* @__PURE__ */ a(pe, { "aria-hidden": "true", className: "ds:size-4" }),
|
|
391
|
+
u
|
|
392
|
+
] }),
|
|
393
|
+
x ? /* @__PURE__ */ a("span", { className: "type-eyebrow ds:text-[color:var(--muted-foreground)]", children: x }) : null
|
|
394
|
+
] }),
|
|
395
|
+
r ? /* @__PURE__ */ a(
|
|
396
|
+
Q,
|
|
397
|
+
{
|
|
398
|
+
icon: /* @__PURE__ */ a(me, {}),
|
|
399
|
+
intent: "outline",
|
|
400
|
+
size: "sm",
|
|
401
|
+
"aria-label": f,
|
|
402
|
+
onClick: r
|
|
403
|
+
}
|
|
404
|
+
) : null
|
|
405
|
+
] }),
|
|
406
|
+
d
|
|
407
|
+
]
|
|
408
|
+
}
|
|
409
|
+
);
|
|
410
|
+
}
|
|
411
|
+
);
|
|
412
|
+
be.displayName = "AppointmentTray";
|
|
413
|
+
export {
|
|
414
|
+
F as A,
|
|
415
|
+
be as a,
|
|
416
|
+
$e as b,
|
|
417
|
+
he as c
|
|
418
|
+
};
|
|
419
|
+
//# sourceMappingURL=appointment-tray-BwDHhWWC.js.map
|