@xplor-education/core-stencil-components 2.0.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/LICENSE +21 -0
- package/components/index.d.ts +33 -0
- package/components/index.js +2324 -0
- package/components/index.js.map +1 -0
- package/components/p-B1W2qj2l.js +50 -0
- package/components/p-B1W2qj2l.js.map +1 -0
- package/components/p-BK_ATKuB.js +37 -0
- package/components/p-BK_ATKuB.js.map +1 -0
- package/components/p-CBSi5kQB.js +56 -0
- package/components/p-CBSi5kQB.js.map +1 -0
- package/components/p-CTD6SyTD.js +181 -0
- package/components/p-CTD6SyTD.js.map +1 -0
- package/components/p-Ddr35stE.js +117 -0
- package/components/p-Ddr35stE.js.map +1 -0
- package/components/p-x30CgLRv.js +184 -0
- package/components/p-x30CgLRv.js.map +1 -0
- package/components/xplor-alert-dialog.d.ts +11 -0
- package/components/xplor-alert-dialog.js +85 -0
- package/components/xplor-alert-dialog.js.map +1 -0
- package/components/xplor-alert-message.d.ts +11 -0
- package/components/xplor-alert-message.js +48 -0
- package/components/xplor-alert-message.js.map +1 -0
- package/components/xplor-assistant.d.ts +11 -0
- package/components/xplor-assistant.js +763 -0
- package/components/xplor-assistant.js.map +1 -0
- package/components/xplor-autocomplete.d.ts +11 -0
- package/components/xplor-autocomplete.js +268 -0
- package/components/xplor-autocomplete.js.map +1 -0
- package/components/xplor-avatar-and-name.d.ts +11 -0
- package/components/xplor-avatar-and-name.js +48 -0
- package/components/xplor-avatar-and-name.js.map +1 -0
- package/components/xplor-avatar.d.ts +11 -0
- package/components/xplor-avatar.js +9 -0
- package/components/xplor-avatar.js.map +1 -0
- package/components/xplor-badge-active.d.ts +11 -0
- package/components/xplor-badge-active.js +35 -0
- package/components/xplor-badge-active.js.map +1 -0
- package/components/xplor-badge-archived.d.ts +11 -0
- package/components/xplor-badge-archived.js +35 -0
- package/components/xplor-badge-archived.js.map +1 -0
- package/components/xplor-badge-deleted.d.ts +11 -0
- package/components/xplor-badge-deleted.js +35 -0
- package/components/xplor-badge-deleted.js.map +1 -0
- package/components/xplor-badge-expired.d.ts +11 -0
- package/components/xplor-badge-expired.js +35 -0
- package/components/xplor-badge-expired.js.map +1 -0
- package/components/xplor-badge-inactive.d.ts +11 -0
- package/components/xplor-badge-inactive.js +35 -0
- package/components/xplor-badge-inactive.js.map +1 -0
- package/components/xplor-badge-recalled.d.ts +11 -0
- package/components/xplor-badge-recalled.js +35 -0
- package/components/xplor-badge-recalled.js.map +1 -0
- package/components/xplor-badge-session-booking.d.ts +11 -0
- package/components/xplor-badge-session-booking.js +60 -0
- package/components/xplor-badge-session-booking.js.map +1 -0
- package/components/xplor-badge-upcoming.d.ts +11 -0
- package/components/xplor-badge-upcoming.js +35 -0
- package/components/xplor-badge-upcoming.js.map +1 -0
- package/components/xplor-badge-waitlist.d.ts +11 -0
- package/components/xplor-badge-waitlist.js +35 -0
- package/components/xplor-badge-waitlist.js.map +1 -0
- package/components/xplor-badge.d.ts +11 -0
- package/components/xplor-badge.js +151 -0
- package/components/xplor-badge.js.map +1 -0
- package/components/xplor-btn-back-to-parent.d.ts +11 -0
- package/components/xplor-btn-back-to-parent.js +72 -0
- package/components/xplor-btn-back-to-parent.js.map +1 -0
- package/components/xplor-btn-back.d.ts +11 -0
- package/components/xplor-btn-back.js +76 -0
- package/components/xplor-btn-back.js.map +1 -0
- package/components/xplor-btn-icon.d.ts +11 -0
- package/components/xplor-btn-icon.js +77 -0
- package/components/xplor-btn-icon.js.map +1 -0
- package/components/xplor-btn-menu.d.ts +11 -0
- package/components/xplor-btn-menu.js +105 -0
- package/components/xplor-btn-menu.js.map +1 -0
- package/components/xplor-btn-toggle-group.d.ts +11 -0
- package/components/xplor-btn-toggle-group.js +46 -0
- package/components/xplor-btn-toggle-group.js.map +1 -0
- package/components/xplor-btn-toggle-secondary.d.ts +11 -0
- package/components/xplor-btn-toggle-secondary.js +64 -0
- package/components/xplor-btn-toggle-secondary.js.map +1 -0
- package/components/xplor-btn-toggle.d.ts +11 -0
- package/components/xplor-btn-toggle.js +69 -0
- package/components/xplor-btn-toggle.js.map +1 -0
- package/components/xplor-btn-tooltip.d.ts +11 -0
- package/components/xplor-btn-tooltip.js +58 -0
- package/components/xplor-btn-tooltip.js.map +1 -0
- package/components/xplor-button.d.ts +11 -0
- package/components/xplor-button.js +9 -0
- package/components/xplor-button.js.map +1 -0
- package/components/xplor-chat-widget.d.ts +11 -0
- package/components/xplor-chat-widget.js +104 -0
- package/components/xplor-chat-widget.js.map +1 -0
- package/components/xplor-checkbox.d.ts +11 -0
- package/components/xplor-checkbox.js +124 -0
- package/components/xplor-checkbox.js.map +1 -0
- package/components/xplor-combobox.d.ts +11 -0
- package/components/xplor-combobox.js +278 -0
- package/components/xplor-combobox.js.map +1 -0
- package/components/xplor-datatable.d.ts +11 -0
- package/components/xplor-datatable.js +243 -0
- package/components/xplor-datatable.js.map +1 -0
- package/components/xplor-date-picker.d.ts +11 -0
- package/components/xplor-date-picker.js +268 -0
- package/components/xplor-date-picker.js.map +1 -0
- package/components/xplor-drag-and-drop-input.d.ts +11 -0
- package/components/xplor-drag-and-drop-input.js +137 -0
- package/components/xplor-drag-and-drop-input.js.map +1 -0
- package/components/xplor-dropdown.d.ts +11 -0
- package/components/xplor-dropdown.js +9 -0
- package/components/xplor-dropdown.js.map +1 -0
- package/components/xplor-expansion-panel.d.ts +11 -0
- package/components/xplor-expansion-panel.js +74 -0
- package/components/xplor-expansion-panel.js.map +1 -0
- package/components/xplor-expansion-panels.d.ts +11 -0
- package/components/xplor-expansion-panels.js +70 -0
- package/components/xplor-expansion-panels.js.map +1 -0
- package/components/xplor-file-upload.d.ts +11 -0
- package/components/xplor-file-upload.js +183 -0
- package/components/xplor-file-upload.js.map +1 -0
- package/components/xplor-inline-checkbox.d.ts +11 -0
- package/components/xplor-inline-checkbox.js +75 -0
- package/components/xplor-inline-checkbox.js.map +1 -0
- package/components/xplor-inline-date-picker.d.ts +11 -0
- package/components/xplor-inline-date-picker.js +9 -0
- package/components/xplor-inline-date-picker.js.map +1 -0
- package/components/xplor-inline-switch.d.ts +11 -0
- package/components/xplor-inline-switch.js +68 -0
- package/components/xplor-inline-switch.js.map +1 -0
- package/components/xplor-input-file.d.ts +11 -0
- package/components/xplor-input-file.js +121 -0
- package/components/xplor-input-file.js.map +1 -0
- package/components/xplor-input-search.d.ts +11 -0
- package/components/xplor-input-search.js +89 -0
- package/components/xplor-input-search.js.map +1 -0
- package/components/xplor-input-select.d.ts +11 -0
- package/components/xplor-input-select.js +168 -0
- package/components/xplor-input-select.js.map +1 -0
- package/components/xplor-input-send.d.ts +11 -0
- package/components/xplor-input-send.js +87 -0
- package/components/xplor-input-send.js.map +1 -0
- package/components/xplor-input-text-area.d.ts +11 -0
- package/components/xplor-input-text-area.js +131 -0
- package/components/xplor-input-text-area.js.map +1 -0
- package/components/xplor-input-text-secondary.d.ts +11 -0
- package/components/xplor-input-text-secondary.js +94 -0
- package/components/xplor-input-text-secondary.js.map +1 -0
- package/components/xplor-input-text.d.ts +11 -0
- package/components/xplor-input-text.js +129 -0
- package/components/xplor-input-text.js.map +1 -0
- package/components/xplor-input-title.d.ts +11 -0
- package/components/xplor-input-title.js +68 -0
- package/components/xplor-input-title.js.map +1 -0
- package/components/xplor-links.d.ts +11 -0
- package/components/xplor-links.js +38 -0
- package/components/xplor-links.js.map +1 -0
- package/components/xplor-modal-persistent.d.ts +11 -0
- package/components/xplor-modal-persistent.js +65 -0
- package/components/xplor-modal-persistent.js.map +1 -0
- package/components/xplor-modal.d.ts +11 -0
- package/components/xplor-modal.js +9 -0
- package/components/xplor-modal.js.map +1 -0
- package/components/xplor-nav-tabs.d.ts +11 -0
- package/components/xplor-nav-tabs.js +58 -0
- package/components/xplor-nav-tabs.js.map +1 -0
- package/components/xplor-section-card.d.ts +11 -0
- package/components/xplor-section-card.js +46 -0
- package/components/xplor-section-card.js.map +1 -0
- package/components/xplor-section-heading.d.ts +11 -0
- package/components/xplor-section-heading.js +43 -0
- package/components/xplor-section-heading.js.map +1 -0
- package/components/xplor-table.d.ts +11 -0
- package/components/xplor-table.js +275 -0
- package/components/xplor-table.js.map +1 -0
- package/components/xplor-text-bubble.d.ts +11 -0
- package/components/xplor-text-bubble.js +42 -0
- package/components/xplor-text-bubble.js.map +1 -0
- package/components/xplor-text-field.d.ts +11 -0
- package/components/xplor-text-field.js +190 -0
- package/components/xplor-text-field.js.map +1 -0
- package/components/xplor-time-picker.d.ts +11 -0
- package/components/xplor-time-picker.js +348 -0
- package/components/xplor-time-picker.js.map +1 -0
- package/components/xplor-tooltip.d.ts +11 -0
- package/components/xplor-tooltip.js +9 -0
- package/components/xplor-tooltip.js.map +1 -0
- package/dist/cjs/index-Bc5o_4vY.js +2594 -0
- package/dist/cjs/index-Bc5o_4vY.js.map +1 -0
- package/dist/cjs/index.cjs.js +5 -0
- package/dist/cjs/index.cjs.js.map +1 -0
- package/dist/cjs/loader.cjs.js +15 -0
- package/dist/cjs/loader.cjs.js.map +1 -0
- package/dist/cjs/xplor-alert-dialog_57.cjs.entry.js +4750 -0
- package/dist/cjs/xplor-alert-dialog_57.cjs.entry.js.map +1 -0
- package/dist/cjs/xplor-component-library.cjs.js +27 -0
- package/dist/cjs/xplor-component-library.cjs.js.map +1 -0
- package/dist/collection/collection-manifest.json +69 -0
- package/dist/collection/components/element-interface.js +2 -0
- package/dist/collection/components/element-interface.js.map +1 -0
- package/dist/collection/components/helpers.js +129 -0
- package/dist/collection/components/helpers.js.map +1 -0
- package/dist/collection/components/xplor-alert-dialog/xplor-alert-dialog.css +348 -0
- package/dist/collection/components/xplor-alert-dialog/xplor-alert-dialog.js +163 -0
- package/dist/collection/components/xplor-alert-dialog/xplor-alert-dialog.js.map +1 -0
- package/dist/collection/components/xplor-alert-message/xplor-alert-message.css +352 -0
- package/dist/collection/components/xplor-alert-message/xplor-alert-message.js +110 -0
- package/dist/collection/components/xplor-alert-message/xplor-alert-message.js.map +1 -0
- package/dist/collection/components/xplor-assistant/internal/AssistantInput.js +39 -0
- package/dist/collection/components/xplor-assistant/internal/AssistantInput.js.map +1 -0
- package/dist/collection/components/xplor-assistant/internal/AssistantMessage.js +35 -0
- package/dist/collection/components/xplor-assistant/internal/AssistantMessage.js.map +1 -0
- package/dist/collection/components/xplor-assistant/internal/QuickReplies.js +13 -0
- package/dist/collection/components/xplor-assistant/internal/QuickReplies.js.map +1 -0
- package/dist/collection/components/xplor-assistant/internal/TypingIndicator.js +9 -0
- package/dist/collection/components/xplor-assistant/internal/TypingIndicator.js.map +1 -0
- package/dist/collection/components/xplor-assistant/internal/types.js +2 -0
- package/dist/collection/components/xplor-assistant/internal/types.js.map +1 -0
- package/dist/collection/components/xplor-assistant/utils/api.js +138 -0
- package/dist/collection/components/xplor-assistant/utils/api.js.map +1 -0
- package/dist/collection/components/xplor-assistant/utils/icons.js +53 -0
- package/dist/collection/components/xplor-assistant/utils/icons.js.map +1 -0
- package/dist/collection/components/xplor-assistant/utils/speech.js +230 -0
- package/dist/collection/components/xplor-assistant/utils/speech.js.map +1 -0
- package/dist/collection/components/xplor-assistant/xplor-assistant.css +1384 -0
- package/dist/collection/components/xplor-assistant/xplor-assistant.js +675 -0
- package/dist/collection/components/xplor-assistant/xplor-assistant.js.map +1 -0
- package/dist/collection/components/xplor-autocomplete/xplor-autocomplete.css +458 -0
- package/dist/collection/components/xplor-autocomplete/xplor-autocomplete.js +613 -0
- package/dist/collection/components/xplor-autocomplete/xplor-autocomplete.js.map +1 -0
- package/dist/collection/components/xplor-avatar/avatar.stories.js +175 -0
- package/dist/collection/components/xplor-avatar/avatar.stories.js.map +1 -0
- package/dist/collection/components/xplor-avatar/xplor-avatar.css +271 -0
- package/dist/collection/components/xplor-avatar/xplor-avatar.js +186 -0
- package/dist/collection/components/xplor-avatar/xplor-avatar.js.map +1 -0
- package/dist/collection/components/xplor-avatar-and-name/xplor-avatar-and-name.css +284 -0
- package/dist/collection/components/xplor-avatar-and-name/xplor-avatar-and-name.js +122 -0
- package/dist/collection/components/xplor-avatar-and-name/xplor-avatar-and-name.js.map +1 -0
- package/dist/collection/components/xplor-badge/xplor-badge.css +1100 -0
- package/dist/collection/components/xplor-badge/xplor-badge.js +273 -0
- package/dist/collection/components/xplor-badge/xplor-badge.js.map +1 -0
- package/dist/collection/components/xplor-badge-active/xplor-badge-active.css +280 -0
- package/dist/collection/components/xplor-badge-active/xplor-badge-active.js +19 -0
- package/dist/collection/components/xplor-badge-active/xplor-badge-active.js.map +1 -0
- package/dist/collection/components/xplor-badge-archived/xplor-badge-archived.css +280 -0
- package/dist/collection/components/xplor-badge-archived/xplor-badge-archived.js +19 -0
- package/dist/collection/components/xplor-badge-archived/xplor-badge-archived.js.map +1 -0
- package/dist/collection/components/xplor-badge-deleted/xplor-badge-deleted.css +280 -0
- package/dist/collection/components/xplor-badge-deleted/xplor-badge-deleted.js +19 -0
- package/dist/collection/components/xplor-badge-deleted/xplor-badge-deleted.js.map +1 -0
- package/dist/collection/components/xplor-badge-expired/xplor-badge-expired.css +280 -0
- package/dist/collection/components/xplor-badge-expired/xplor-badge-expired.js +19 -0
- package/dist/collection/components/xplor-badge-expired/xplor-badge-expired.js.map +1 -0
- package/dist/collection/components/xplor-badge-inactive/xplor-badge-inactive.css +280 -0
- package/dist/collection/components/xplor-badge-inactive/xplor-badge-inactive.js +19 -0
- package/dist/collection/components/xplor-badge-inactive/xplor-badge-inactive.js.map +1 -0
- package/dist/collection/components/xplor-badge-recalled/xplor-badge-recalled.css +280 -0
- package/dist/collection/components/xplor-badge-recalled/xplor-badge-recalled.js +19 -0
- package/dist/collection/components/xplor-badge-recalled/xplor-badge-recalled.js.map +1 -0
- package/dist/collection/components/xplor-badge-session-booking/xplor-badge-session-booking.css +300 -0
- package/dist/collection/components/xplor-badge-session-booking/xplor-badge-session-booking.js +93 -0
- package/dist/collection/components/xplor-badge-session-booking/xplor-badge-session-booking.js.map +1 -0
- package/dist/collection/components/xplor-badge-upcoming/xplor-badge-upcoming.css +280 -0
- package/dist/collection/components/xplor-badge-upcoming/xplor-badge-upcoming.js +19 -0
- package/dist/collection/components/xplor-badge-upcoming/xplor-badge-upcoming.js.map +1 -0
- package/dist/collection/components/xplor-badge-waitlist/xplor-badge-waitlist.css +280 -0
- package/dist/collection/components/xplor-badge-waitlist/xplor-badge-waitlist.js +19 -0
- package/dist/collection/components/xplor-badge-waitlist/xplor-badge-waitlist.js.map +1 -0
- package/dist/collection/components/xplor-btn-back/xplor-btn-back.css +306 -0
- package/dist/collection/components/xplor-btn-back/xplor-btn-back.js +182 -0
- package/dist/collection/components/xplor-btn-back/xplor-btn-back.js.map +1 -0
- package/dist/collection/components/xplor-btn-back-to-parent/xplor-btn-back-to-parent.css +306 -0
- package/dist/collection/components/xplor-btn-back-to-parent/xplor-btn-back-to-parent.js +173 -0
- package/dist/collection/components/xplor-btn-back-to-parent/xplor-btn-back-to-parent.js.map +1 -0
- package/dist/collection/components/xplor-btn-icon/xplor-btn-icon.css +370 -0
- package/dist/collection/components/xplor-btn-icon/xplor-btn-icon.js +183 -0
- package/dist/collection/components/xplor-btn-icon/xplor-btn-icon.js.map +1 -0
- package/dist/collection/components/xplor-btn-menu/xplor-btn-menu.css +327 -0
- package/dist/collection/components/xplor-btn-menu/xplor-btn-menu.js +238 -0
- package/dist/collection/components/xplor-btn-menu/xplor-btn-menu.js.map +1 -0
- package/dist/collection/components/xplor-btn-toggle/xplor-btn-toggle.css +312 -0
- package/dist/collection/components/xplor-btn-toggle/xplor-btn-toggle.js +151 -0
- package/dist/collection/components/xplor-btn-toggle/xplor-btn-toggle.js.map +1 -0
- package/dist/collection/components/xplor-btn-toggle-group/xplor-btn-toggle-group.css +278 -0
- package/dist/collection/components/xplor-btn-toggle-group/xplor-btn-toggle-group.js +73 -0
- package/dist/collection/components/xplor-btn-toggle-group/xplor-btn-toggle-group.js.map +1 -0
- package/dist/collection/components/xplor-btn-toggle-secondary/xplor-btn-toggle-secondary.css +314 -0
- package/dist/collection/components/xplor-btn-toggle-secondary/xplor-btn-toggle-secondary.js +127 -0
- package/dist/collection/components/xplor-btn-toggle-secondary/xplor-btn-toggle-secondary.js.map +1 -0
- package/dist/collection/components/xplor-btn-tooltip/xplor-btn-tooltip.css +271 -0
- package/dist/collection/components/xplor-btn-tooltip/xplor-btn-tooltip.js +164 -0
- package/dist/collection/components/xplor-btn-tooltip/xplor-btn-tooltip.js.map +1 -0
- package/dist/collection/components/xplor-button/xplor-button.css +1253 -0
- package/dist/collection/components/xplor-button/xplor-button.js +212 -0
- package/dist/collection/components/xplor-button/xplor-button.js.map +1 -0
- package/dist/collection/components/xplor-button/xplor-buttons.stories.js +49 -0
- package/dist/collection/components/xplor-button/xplor-buttons.stories.js.map +1 -0
- package/dist/collection/components/xplor-chat-widget/xplor-chat-widget.css +276 -0
- package/dist/collection/components/xplor-chat-widget/xplor-chat-widget.js +139 -0
- package/dist/collection/components/xplor-chat-widget/xplor-chat-widget.js.map +1 -0
- package/dist/collection/components/xplor-chat-widget/xplor-chat.stories.js +31 -0
- package/dist/collection/components/xplor-chat-widget/xplor-chat.stories.js.map +1 -0
- package/dist/collection/components/xplor-checkbox/xplor-checkbox.css +453 -0
- package/dist/collection/components/xplor-checkbox/xplor-checkbox.js +230 -0
- package/dist/collection/components/xplor-checkbox/xplor-checkbox.js.map +1 -0
- package/dist/collection/components/xplor-combobox/xplor-combobox.css +473 -0
- package/dist/collection/components/xplor-combobox/xplor-combobox.js +553 -0
- package/dist/collection/components/xplor-combobox/xplor-combobox.js.map +1 -0
- package/dist/collection/components/xplor-datatable/xplor-datatable.css +580 -0
- package/dist/collection/components/xplor-datatable/xplor-datatable.js +536 -0
- package/dist/collection/components/xplor-datatable/xplor-datatable.js.map +1 -0
- package/dist/collection/components/xplor-datatable/xplor-datatable.stories.js +137 -0
- package/dist/collection/components/xplor-datatable/xplor-datatable.stories.js.map +1 -0
- package/dist/collection/components/xplor-date-picker/xplor-date-picker.css +415 -0
- package/dist/collection/components/xplor-date-picker/xplor-date-picker.js +694 -0
- package/dist/collection/components/xplor-date-picker/xplor-date-picker.js.map +1 -0
- package/dist/collection/components/xplor-drag-and-drop-input/xplor-drag-and-drop-input.css +1149 -0
- package/dist/collection/components/xplor-drag-and-drop-input/xplor-drag-and-drop-input.js +256 -0
- package/dist/collection/components/xplor-drag-and-drop-input/xplor-drag-and-drop-input.js.map +1 -0
- package/dist/collection/components/xplor-dropdown/xplor-dropdown.css +286 -0
- package/dist/collection/components/xplor-dropdown/xplor-dropdown.js +83 -0
- package/dist/collection/components/xplor-dropdown/xplor-dropdown.js.map +1 -0
- package/dist/collection/components/xplor-expansion-panel/xplor-expansion-panel.css +334 -0
- package/dist/collection/components/xplor-expansion-panel/xplor-expansion-panel.js +122 -0
- package/dist/collection/components/xplor-expansion-panel/xplor-expansion-panel.js.map +1 -0
- package/dist/collection/components/xplor-expansion-panels/xplor-expansion-panels.css +277 -0
- package/dist/collection/components/xplor-expansion-panels/xplor-expansion-panels.js +129 -0
- package/dist/collection/components/xplor-expansion-panels/xplor-expansion-panels.js.map +1 -0
- package/dist/collection/components/xplor-file-upload/xplor-file-upload.css +433 -0
- package/dist/collection/components/xplor-file-upload/xplor-file-upload.js +347 -0
- package/dist/collection/components/xplor-file-upload/xplor-file-upload.js.map +1 -0
- package/dist/collection/components/xplor-inline-checkbox/xplor-inline-checkbox.css +300 -0
- package/dist/collection/components/xplor-inline-checkbox/xplor-inline-checkbox.js +194 -0
- package/dist/collection/components/xplor-inline-checkbox/xplor-inline-checkbox.js.map +1 -0
- package/dist/collection/components/xplor-inline-date-picker/xplor-inline-date-picker.css +410 -0
- package/dist/collection/components/xplor-inline-date-picker/xplor-inline-date-picker.js +325 -0
- package/dist/collection/components/xplor-inline-date-picker/xplor-inline-date-picker.js.map +1 -0
- package/dist/collection/components/xplor-inline-switch/xplor-inline-switch.css +343 -0
- package/dist/collection/components/xplor-inline-switch/xplor-inline-switch.js +168 -0
- package/dist/collection/components/xplor-inline-switch/xplor-inline-switch.js.map +1 -0
- package/dist/collection/components/xplor-input-file/xplor-input-file.css +392 -0
- package/dist/collection/components/xplor-input-file/xplor-input-file.js +340 -0
- package/dist/collection/components/xplor-input-file/xplor-input-file.js.map +1 -0
- package/dist/collection/components/xplor-input-search/xplor-input-search.css +371 -0
- package/dist/collection/components/xplor-input-search/xplor-input-search.js +213 -0
- package/dist/collection/components/xplor-input-search/xplor-input-search.js.map +1 -0
- package/dist/collection/components/xplor-input-select/xplor-input-select.css +397 -0
- package/dist/collection/components/xplor-input-select/xplor-input-select.js +430 -0
- package/dist/collection/components/xplor-input-select/xplor-input-select.js.map +1 -0
- package/dist/collection/components/xplor-input-send/xplor-input-send.css +312 -0
- package/dist/collection/components/xplor-input-send/xplor-input-send.js +218 -0
- package/dist/collection/components/xplor-input-send/xplor-input-send.js.map +1 -0
- package/dist/collection/components/xplor-input-text/xplor-input-text.css +334 -0
- package/dist/collection/components/xplor-input-text/xplor-input-text.js +419 -0
- package/dist/collection/components/xplor-input-text/xplor-input-text.js.map +1 -0
- package/dist/collection/components/xplor-input-text-area/xplor-input-text-area.css +359 -0
- package/dist/collection/components/xplor-input-text-area/xplor-input-text-area.js +416 -0
- package/dist/collection/components/xplor-input-text-area/xplor-input-text-area.js.map +1 -0
- package/dist/collection/components/xplor-input-text-secondary/xplor-input-text-secondary.css +339 -0
- package/dist/collection/components/xplor-input-text-secondary/xplor-input-text-secondary.js +384 -0
- package/dist/collection/components/xplor-input-text-secondary/xplor-input-text-secondary.js.map +1 -0
- package/dist/collection/components/xplor-input-title/xplor-input-title.css +304 -0
- package/dist/collection/components/xplor-input-title/xplor-input-title.js +164 -0
- package/dist/collection/components/xplor-input-title/xplor-input-title.js.map +1 -0
- package/dist/collection/components/xplor-links/xplor-links.css +9 -0
- package/dist/collection/components/xplor-links/xplor-links.js +42 -0
- package/dist/collection/components/xplor-links/xplor-links.js.map +1 -0
- package/dist/collection/components/xplor-links/xplor-links.stories.js +18 -0
- package/dist/collection/components/xplor-links/xplor-links.stories.js.map +1 -0
- package/dist/collection/components/xplor-modal/xplor-modal.css +385 -0
- package/dist/collection/components/xplor-modal/xplor-modal.js +279 -0
- package/dist/collection/components/xplor-modal/xplor-modal.js.map +1 -0
- package/dist/collection/components/xplor-modal-persistent/xplor-modal-persistent.js +152 -0
- package/dist/collection/components/xplor-modal-persistent/xplor-modal-persistent.js.map +1 -0
- package/dist/collection/components/xplor-nav-tabs/xplor-nav-tabs.css +333 -0
- package/dist/collection/components/xplor-nav-tabs/xplor-nav-tabs.js +144 -0
- package/dist/collection/components/xplor-nav-tabs/xplor-nav-tabs.js.map +1 -0
- package/dist/collection/components/xplor-section-card/xplor-section-card.css +1076 -0
- package/dist/collection/components/xplor-section-card/xplor-section-card.js +92 -0
- package/dist/collection/components/xplor-section-card/xplor-section-card.js.map +1 -0
- package/dist/collection/components/xplor-section-heading/xplor-section-heading.css +285 -0
- package/dist/collection/components/xplor-section-heading/xplor-section-heading.js +69 -0
- package/dist/collection/components/xplor-section-heading/xplor-section-heading.js.map +1 -0
- package/dist/collection/components/xplor-table/xplor-table.js +695 -0
- package/dist/collection/components/xplor-table/xplor-table.js.map +1 -0
- package/dist/collection/components/xplor-table/xplor-table.stories.js +159 -0
- package/dist/collection/components/xplor-table/xplor-table.stories.js.map +1 -0
- package/dist/collection/components/xplor-text-bubble/xplor-text-bubble.css +285 -0
- package/dist/collection/components/xplor-text-bubble/xplor-text-bubble.js +50 -0
- package/dist/collection/components/xplor-text-bubble/xplor-text-bubble.js.map +1 -0
- package/dist/collection/components/xplor-text-field/xplor-text-field.css +1280 -0
- package/dist/collection/components/xplor-text-field/xplor-text-field.js +591 -0
- package/dist/collection/components/xplor-text-field/xplor-text-field.js.map +1 -0
- package/dist/collection/components/xplor-time-picker/xplor-time-picker.css +448 -0
- package/dist/collection/components/xplor-time-picker/xplor-time-picker.js +647 -0
- package/dist/collection/components/xplor-time-picker/xplor-time-picker.js.map +1 -0
- package/dist/collection/components/xplor-tooltip/xplor-tooltip.css +336 -0
- package/dist/collection/components/xplor-tooltip/xplor-tooltip.js +311 -0
- package/dist/collection/components/xplor-tooltip/xplor-tooltip.js.map +1 -0
- package/dist/collection/globals/globals.js +32 -0
- package/dist/collection/globals/globals.js.map +1 -0
- package/dist/collection/index.js +2 -0
- package/dist/collection/index.js.map +1 -0
- package/dist/collection/stories/Button.js +17 -0
- package/dist/collection/stories/Button.js.map +1 -0
- package/dist/collection/stories/Button.stories.js +50 -0
- package/dist/collection/stories/Button.stories.js.map +1 -0
- package/dist/collection/stories/Header.js +41 -0
- package/dist/collection/stories/Header.js.map +1 -0
- package/dist/collection/stories/Header.stories.js +28 -0
- package/dist/collection/stories/Header.stories.js.map +1 -0
- package/dist/collection/stories/Page.js +85 -0
- package/dist/collection/stories/Page.js.map +1 -0
- package/dist/collection/stories/Page.stories.js +25 -0
- package/dist/collection/stories/Page.stories.js.map +1 -0
- package/dist/collection/stories/assets/accessibility.svg +1 -0
- package/dist/collection/stories/assets/discord.svg +1 -0
- package/dist/collection/stories/assets/github.svg +1 -0
- package/dist/collection/stories/assets/tutorials.svg +1 -0
- package/dist/collection/stories/assets/youtube.svg +1 -0
- package/dist/collection/utils/helpers.js +25 -0
- package/dist/collection/utils/helpers.js.map +1 -0
- package/dist/components/index.d.ts +33 -0
- package/dist/components/index.js +2324 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/p-4l9DAhAo.js +182 -0
- package/dist/components/p-4l9DAhAo.js.map +1 -0
- package/dist/components/p-BHdeGt6k.js +51 -0
- package/dist/components/p-BHdeGt6k.js.map +1 -0
- package/dist/components/p-BIFlTsO8.js +185 -0
- package/dist/components/p-BIFlTsO8.js.map +1 -0
- package/dist/components/p-CJGP2_5k.js +38 -0
- package/dist/components/p-CJGP2_5k.js.map +1 -0
- package/dist/components/p-DIv_A5Gj.js +57 -0
- package/dist/components/p-DIv_A5Gj.js.map +1 -0
- package/dist/components/p-DKh6y3GY.js +118 -0
- package/dist/components/p-DKh6y3GY.js.map +1 -0
- package/dist/components/xplor-alert-dialog.d.ts +11 -0
- package/dist/components/xplor-alert-dialog.js +86 -0
- package/dist/components/xplor-alert-dialog.js.map +1 -0
- package/dist/components/xplor-alert-message.d.ts +11 -0
- package/dist/components/xplor-alert-message.js +49 -0
- package/dist/components/xplor-alert-message.js.map +1 -0
- package/dist/components/xplor-assistant.d.ts +11 -0
- package/dist/components/xplor-assistant.js +764 -0
- package/dist/components/xplor-assistant.js.map +1 -0
- package/dist/components/xplor-autocomplete.d.ts +11 -0
- package/dist/components/xplor-autocomplete.js +269 -0
- package/dist/components/xplor-autocomplete.js.map +1 -0
- package/dist/components/xplor-avatar-and-name.d.ts +11 -0
- package/dist/components/xplor-avatar-and-name.js +49 -0
- package/dist/components/xplor-avatar-and-name.js.map +1 -0
- package/dist/components/xplor-avatar.d.ts +11 -0
- package/dist/components/xplor-avatar.js +9 -0
- package/dist/components/xplor-avatar.js.map +1 -0
- package/dist/components/xplor-badge-active.d.ts +11 -0
- package/dist/components/xplor-badge-active.js +36 -0
- package/dist/components/xplor-badge-active.js.map +1 -0
- package/dist/components/xplor-badge-archived.d.ts +11 -0
- package/dist/components/xplor-badge-archived.js +36 -0
- package/dist/components/xplor-badge-archived.js.map +1 -0
- package/dist/components/xplor-badge-deleted.d.ts +11 -0
- package/dist/components/xplor-badge-deleted.js +36 -0
- package/dist/components/xplor-badge-deleted.js.map +1 -0
- package/dist/components/xplor-badge-expired.d.ts +11 -0
- package/dist/components/xplor-badge-expired.js +36 -0
- package/dist/components/xplor-badge-expired.js.map +1 -0
- package/dist/components/xplor-badge-inactive.d.ts +11 -0
- package/dist/components/xplor-badge-inactive.js +36 -0
- package/dist/components/xplor-badge-inactive.js.map +1 -0
- package/dist/components/xplor-badge-recalled.d.ts +11 -0
- package/dist/components/xplor-badge-recalled.js +36 -0
- package/dist/components/xplor-badge-recalled.js.map +1 -0
- package/dist/components/xplor-badge-session-booking.d.ts +11 -0
- package/dist/components/xplor-badge-session-booking.js +61 -0
- package/dist/components/xplor-badge-session-booking.js.map +1 -0
- package/dist/components/xplor-badge-upcoming.d.ts +11 -0
- package/dist/components/xplor-badge-upcoming.js +36 -0
- package/dist/components/xplor-badge-upcoming.js.map +1 -0
- package/dist/components/xplor-badge-waitlist.d.ts +11 -0
- package/dist/components/xplor-badge-waitlist.js +36 -0
- package/dist/components/xplor-badge-waitlist.js.map +1 -0
- package/dist/components/xplor-badge.d.ts +11 -0
- package/dist/components/xplor-badge.js +152 -0
- package/dist/components/xplor-badge.js.map +1 -0
- package/dist/components/xplor-btn-back-to-parent.d.ts +11 -0
- package/dist/components/xplor-btn-back-to-parent.js +73 -0
- package/dist/components/xplor-btn-back-to-parent.js.map +1 -0
- package/dist/components/xplor-btn-back.d.ts +11 -0
- package/dist/components/xplor-btn-back.js +77 -0
- package/dist/components/xplor-btn-back.js.map +1 -0
- package/dist/components/xplor-btn-icon.d.ts +11 -0
- package/dist/components/xplor-btn-icon.js +78 -0
- package/dist/components/xplor-btn-icon.js.map +1 -0
- package/dist/components/xplor-btn-menu.d.ts +11 -0
- package/dist/components/xplor-btn-menu.js +106 -0
- package/dist/components/xplor-btn-menu.js.map +1 -0
- package/dist/components/xplor-btn-toggle-group.d.ts +11 -0
- package/dist/components/xplor-btn-toggle-group.js +47 -0
- package/dist/components/xplor-btn-toggle-group.js.map +1 -0
- package/dist/components/xplor-btn-toggle-secondary.d.ts +11 -0
- package/dist/components/xplor-btn-toggle-secondary.js +65 -0
- package/dist/components/xplor-btn-toggle-secondary.js.map +1 -0
- package/dist/components/xplor-btn-toggle.d.ts +11 -0
- package/dist/components/xplor-btn-toggle.js +70 -0
- package/dist/components/xplor-btn-toggle.js.map +1 -0
- package/dist/components/xplor-btn-tooltip.d.ts +11 -0
- package/dist/components/xplor-btn-tooltip.js +59 -0
- package/dist/components/xplor-btn-tooltip.js.map +1 -0
- package/dist/components/xplor-button.d.ts +11 -0
- package/dist/components/xplor-button.js +9 -0
- package/dist/components/xplor-button.js.map +1 -0
- package/dist/components/xplor-chat-widget.d.ts +11 -0
- package/dist/components/xplor-chat-widget.js +105 -0
- package/dist/components/xplor-chat-widget.js.map +1 -0
- package/dist/components/xplor-checkbox.d.ts +11 -0
- package/dist/components/xplor-checkbox.js +125 -0
- package/dist/components/xplor-checkbox.js.map +1 -0
- package/dist/components/xplor-combobox.d.ts +11 -0
- package/dist/components/xplor-combobox.js +279 -0
- package/dist/components/xplor-combobox.js.map +1 -0
- package/dist/components/xplor-datatable.d.ts +11 -0
- package/dist/components/xplor-datatable.js +244 -0
- package/dist/components/xplor-datatable.js.map +1 -0
- package/dist/components/xplor-date-picker.d.ts +11 -0
- package/dist/components/xplor-date-picker.js +269 -0
- package/dist/components/xplor-date-picker.js.map +1 -0
- package/dist/components/xplor-drag-and-drop-input.d.ts +11 -0
- package/dist/components/xplor-drag-and-drop-input.js +138 -0
- package/dist/components/xplor-drag-and-drop-input.js.map +1 -0
- package/dist/components/xplor-dropdown.d.ts +11 -0
- package/dist/components/xplor-dropdown.js +9 -0
- package/dist/components/xplor-dropdown.js.map +1 -0
- package/dist/components/xplor-expansion-panel.d.ts +11 -0
- package/dist/components/xplor-expansion-panel.js +75 -0
- package/dist/components/xplor-expansion-panel.js.map +1 -0
- package/dist/components/xplor-expansion-panels.d.ts +11 -0
- package/dist/components/xplor-expansion-panels.js +71 -0
- package/dist/components/xplor-expansion-panels.js.map +1 -0
- package/dist/components/xplor-file-upload.d.ts +11 -0
- package/dist/components/xplor-file-upload.js +184 -0
- package/dist/components/xplor-file-upload.js.map +1 -0
- package/dist/components/xplor-inline-checkbox.d.ts +11 -0
- package/dist/components/xplor-inline-checkbox.js +76 -0
- package/dist/components/xplor-inline-checkbox.js.map +1 -0
- package/dist/components/xplor-inline-date-picker.d.ts +11 -0
- package/dist/components/xplor-inline-date-picker.js +9 -0
- package/dist/components/xplor-inline-date-picker.js.map +1 -0
- package/dist/components/xplor-inline-switch.d.ts +11 -0
- package/dist/components/xplor-inline-switch.js +69 -0
- package/dist/components/xplor-inline-switch.js.map +1 -0
- package/dist/components/xplor-input-file.d.ts +11 -0
- package/dist/components/xplor-input-file.js +122 -0
- package/dist/components/xplor-input-file.js.map +1 -0
- package/dist/components/xplor-input-search.d.ts +11 -0
- package/dist/components/xplor-input-search.js +90 -0
- package/dist/components/xplor-input-search.js.map +1 -0
- package/dist/components/xplor-input-select.d.ts +11 -0
- package/dist/components/xplor-input-select.js +169 -0
- package/dist/components/xplor-input-select.js.map +1 -0
- package/dist/components/xplor-input-send.d.ts +11 -0
- package/dist/components/xplor-input-send.js +88 -0
- package/dist/components/xplor-input-send.js.map +1 -0
- package/dist/components/xplor-input-text-area.d.ts +11 -0
- package/dist/components/xplor-input-text-area.js +132 -0
- package/dist/components/xplor-input-text-area.js.map +1 -0
- package/dist/components/xplor-input-text-secondary.d.ts +11 -0
- package/dist/components/xplor-input-text-secondary.js +95 -0
- package/dist/components/xplor-input-text-secondary.js.map +1 -0
- package/dist/components/xplor-input-text.d.ts +11 -0
- package/dist/components/xplor-input-text.js +130 -0
- package/dist/components/xplor-input-text.js.map +1 -0
- package/dist/components/xplor-input-title.d.ts +11 -0
- package/dist/components/xplor-input-title.js +69 -0
- package/dist/components/xplor-input-title.js.map +1 -0
- package/dist/components/xplor-links.d.ts +11 -0
- package/dist/components/xplor-links.js +39 -0
- package/dist/components/xplor-links.js.map +1 -0
- package/dist/components/xplor-modal-persistent.d.ts +11 -0
- package/dist/components/xplor-modal-persistent.js +66 -0
- package/dist/components/xplor-modal-persistent.js.map +1 -0
- package/dist/components/xplor-modal.d.ts +11 -0
- package/dist/components/xplor-modal.js +9 -0
- package/dist/components/xplor-modal.js.map +1 -0
- package/dist/components/xplor-nav-tabs.d.ts +11 -0
- package/dist/components/xplor-nav-tabs.js +59 -0
- package/dist/components/xplor-nav-tabs.js.map +1 -0
- package/dist/components/xplor-section-card.d.ts +11 -0
- package/dist/components/xplor-section-card.js +47 -0
- package/dist/components/xplor-section-card.js.map +1 -0
- package/dist/components/xplor-section-heading.d.ts +11 -0
- package/dist/components/xplor-section-heading.js +44 -0
- package/dist/components/xplor-section-heading.js.map +1 -0
- package/dist/components/xplor-table.d.ts +11 -0
- package/dist/components/xplor-table.js +276 -0
- package/dist/components/xplor-table.js.map +1 -0
- package/dist/components/xplor-text-bubble.d.ts +11 -0
- package/dist/components/xplor-text-bubble.js +43 -0
- package/dist/components/xplor-text-bubble.js.map +1 -0
- package/dist/components/xplor-text-field.d.ts +11 -0
- package/dist/components/xplor-text-field.js +191 -0
- package/dist/components/xplor-text-field.js.map +1 -0
- package/dist/components/xplor-time-picker.d.ts +11 -0
- package/dist/components/xplor-time-picker.js +349 -0
- package/dist/components/xplor-time-picker.js.map +1 -0
- package/dist/components/xplor-tooltip.d.ts +11 -0
- package/dist/components/xplor-tooltip.js +9 -0
- package/dist/components/xplor-tooltip.js.map +1 -0
- package/dist/esm/index-Zkk2NJif.js +2566 -0
- package/dist/esm/index-Zkk2NJif.js.map +1 -0
- package/dist/esm/index.js +4 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/loader.js +13 -0
- package/dist/esm/loader.js.map +1 -0
- package/dist/esm/xplor-alert-dialog_57.entry.js +4692 -0
- package/dist/esm/xplor-alert-dialog_57.entry.js.map +1 -0
- package/dist/esm/xplor-component-library.js +23 -0
- package/dist/esm/xplor-component-library.js.map +1 -0
- package/dist/hydrate/index.d.ts +273 -0
- package/dist/hydrate/index.js +25064 -0
- package/dist/hydrate/index.mjs +25056 -0
- package/dist/hydrate/package.json +12 -0
- package/dist/index.cjs.js +1 -0
- package/dist/index.js +1 -0
- package/dist/types/components/element-interface.d.ts +19 -0
- package/dist/types/components/helpers.d.ts +47 -0
- package/dist/types/components/xplor-alert-dialog/xplor-alert-dialog.d.ts +29 -0
- package/dist/types/components/xplor-alert-message/xplor-alert-message.d.ts +9 -0
- package/dist/types/components/xplor-assistant/internal/AssistantInput.d.ts +17 -0
- package/dist/types/components/xplor-assistant/internal/AssistantMessage.d.ts +6 -0
- package/dist/types/components/xplor-assistant/internal/QuickReplies.d.ts +6 -0
- package/dist/types/components/xplor-assistant/internal/TypingIndicator.d.ts +5 -0
- package/dist/types/components/xplor-assistant/internal/types.d.ts +106 -0
- package/dist/types/components/xplor-assistant/utils/api.d.ts +48 -0
- package/dist/types/components/xplor-assistant/utils/icons.d.ts +24 -0
- package/dist/types/components/xplor-assistant/utils/speech.d.ts +86 -0
- package/dist/types/components/xplor-assistant/xplor-assistant.d.ts +52 -0
- package/dist/types/components/xplor-autocomplete/xplor-autocomplete.d.ts +92 -0
- package/dist/types/components/xplor-avatar/avatar.stories.d.ts +75 -0
- package/dist/types/components/xplor-avatar/xplor-avatar.d.ts +21 -0
- package/dist/types/components/xplor-avatar-and-name/xplor-avatar-and-name.d.ts +8 -0
- package/dist/types/components/xplor-badge/xplor-badge.d.ts +52 -0
- package/dist/types/components/xplor-badge-active/xplor-badge-active.d.ts +3 -0
- package/dist/types/components/xplor-badge-archived/xplor-badge-archived.d.ts +3 -0
- package/dist/types/components/xplor-badge-deleted/xplor-badge-deleted.d.ts +3 -0
- package/dist/types/components/xplor-badge-expired/xplor-badge-expired.d.ts +3 -0
- package/dist/types/components/xplor-badge-inactive/xplor-badge-inactive.d.ts +3 -0
- package/dist/types/components/xplor-badge-recalled/xplor-badge-recalled.d.ts +3 -0
- package/dist/types/components/xplor-badge-session-booking/xplor-badge-session-booking.d.ts +20 -0
- package/dist/types/components/xplor-badge-upcoming/xplor-badge-upcoming.d.ts +3 -0
- package/dist/types/components/xplor-badge-waitlist/xplor-badge-waitlist.d.ts +3 -0
- package/dist/types/components/xplor-btn-back/xplor-btn-back.d.ts +29 -0
- package/dist/types/components/xplor-btn-back-to-parent/xplor-btn-back-to-parent.d.ts +29 -0
- package/dist/types/components/xplor-btn-icon/xplor-btn-icon.d.ts +29 -0
- package/dist/types/components/xplor-btn-menu/xplor-btn-menu.d.ts +49 -0
- package/dist/types/components/xplor-btn-toggle/xplor-btn-toggle.d.ts +25 -0
- package/dist/types/components/xplor-btn-toggle-group/xplor-btn-toggle-group.d.ts +11 -0
- package/dist/types/components/xplor-btn-toggle-secondary/xplor-btn-toggle-secondary.d.ts +21 -0
- package/dist/types/components/xplor-btn-tooltip/xplor-btn-tooltip.d.ts +10 -0
- package/dist/types/components/xplor-button/xplor-button.d.ts +19 -0
- package/dist/types/components/xplor-button/xplor-buttons.stories.d.ts +32 -0
- package/dist/types/components/xplor-chat-widget/xplor-chat-widget.d.ts +13 -0
- package/dist/types/components/xplor-chat-widget/xplor-chat.stories.d.ts +32 -0
- package/dist/types/components/xplor-checkbox/xplor-checkbox.d.ts +25 -0
- package/dist/types/components/xplor-combobox/xplor-combobox.d.ts +77 -0
- package/dist/types/components/xplor-datatable/xplor-datatable.d.ts +103 -0
- package/dist/types/components/xplor-datatable/xplor-datatable.stories.d.ts +18 -0
- package/dist/types/components/xplor-date-picker/xplor-date-picker.d.ts +53 -0
- package/dist/types/components/xplor-drag-and-drop-input/xplor-drag-and-drop-input.d.ts +42 -0
- package/dist/types/components/xplor-dropdown/xplor-dropdown.d.ts +6 -0
- package/dist/types/components/xplor-expansion-panel/xplor-expansion-panel.d.ts +18 -0
- package/dist/types/components/xplor-expansion-panels/xplor-expansion-panels.d.ts +12 -0
- package/dist/types/components/xplor-file-upload/xplor-file-upload.d.ts +51 -0
- package/dist/types/components/xplor-inline-checkbox/xplor-inline-checkbox.d.ts +33 -0
- package/dist/types/components/xplor-inline-date-picker/xplor-inline-date-picker.d.ts +57 -0
- package/dist/types/components/xplor-inline-switch/xplor-inline-switch.d.ts +29 -0
- package/dist/types/components/xplor-input-file/xplor-input-file.d.ts +60 -0
- package/dist/types/components/xplor-input-search/xplor-input-search.d.ts +36 -0
- package/dist/types/components/xplor-input-select/xplor-input-select.d.ts +76 -0
- package/dist/types/components/xplor-input-send/xplor-input-send.d.ts +18 -0
- package/dist/types/components/xplor-input-text/xplor-input-text.d.ts +73 -0
- package/dist/types/components/xplor-input-text-area/xplor-input-text-area.d.ts +72 -0
- package/dist/types/components/xplor-input-text-secondary/xplor-input-text-secondary.d.ts +25 -0
- package/dist/types/components/xplor-input-title/xplor-input-title.d.ts +30 -0
- package/dist/types/components/xplor-links/xplor-links.d.ts +4 -0
- package/dist/types/components/xplor-links/xplor-links.stories.d.ts +12 -0
- package/dist/types/components/xplor-modal/xplor-modal.d.ts +45 -0
- package/dist/types/components/xplor-modal-persistent/xplor-modal-persistent.d.ts +28 -0
- package/dist/types/components/xplor-nav-tabs/xplor-nav-tabs.d.ts +15 -0
- package/dist/types/components/xplor-section-card/xplor-section-card.d.ts +6 -0
- package/dist/types/components/xplor-section-heading/xplor-section-heading.d.ts +5 -0
- package/dist/types/components/xplor-table/xplor-table.d.ts +65 -0
- package/dist/types/components/xplor-table/xplor-table.stories.d.ts +77 -0
- package/dist/types/components/xplor-text-bubble/xplor-text-bubble.d.ts +4 -0
- package/dist/types/components/xplor-text-field/xplor-text-field.d.ts +111 -0
- package/dist/types/components/xplor-time-picker/xplor-time-picker.d.ts +55 -0
- package/dist/types/components/xplor-tooltip/xplor-tooltip.d.ts +28 -0
- package/dist/types/components.d.ts +4360 -0
- package/dist/types/globals/globals.d.ts +3 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/interfaces.d.ts +104 -0
- package/dist/types/stencil-public-runtime.d.ts +1702 -0
- package/dist/types/stories/Button.d.ts +15 -0
- package/dist/types/stories/Header.d.ts +10 -0
- package/dist/types/stories/Page.d.ts +2 -0
- package/dist/types/stories/Page.stories.d.ts +11 -0
- package/dist/types/utils/helpers.d.ts +3 -0
- package/dist/xplor-component-library/index.esm.js +2 -0
- package/dist/xplor-component-library/index.esm.js.map +1 -0
- package/dist/xplor-component-library/loader.esm.js.map +1 -0
- package/dist/xplor-component-library/p-25fa8553.entry.js +2 -0
- package/dist/xplor-component-library/p-25fa8553.entry.js.map +1 -0
- package/dist/xplor-component-library/p-Zkk2NJif.js +3 -0
- package/dist/xplor-component-library/p-Zkk2NJif.js.map +1 -0
- package/dist/xplor-component-library/xplor-component-library.css +1 -0
- package/dist/xplor-component-library/xplor-component-library.esm.js +2 -0
- package/dist/xplor-component-library/xplor-component-library.esm.js.map +1 -0
- package/loader/cdn.js +1 -0
- package/loader/index.cjs.js +1 -0
- package/loader/index.d.ts +24 -0
- package/loader/index.es2017.js +1 -0
- package/loader/index.js +2 -0
- package/package.json +124 -0
- package/readme.md +315 -0
|
@@ -0,0 +1,269 @@
|
|
|
1
|
+
import { p as proxyCustomElement, H, c as createEvent, h, a as Host } from './index.js';
|
|
2
|
+
import { d as defineCustomElement$2 } from './p-BIFlTsO8.js';
|
|
3
|
+
|
|
4
|
+
const xplorDatePickerCss = "@tailwind base;\n@tailwind components;\n@tailwind utilities;\n@layer base {\n \n :root {\n --color-primary: #db3b03;\n --color-primary-50: rgba(255, 152, 0, 1);\n --color-secondary: rgb(0, 119, 107);\n --color-secondary-50: rgba(1, 163, 157, 1);\n --color-tertiary: rgb(128, 104, 186);\n --color-tertiary: rgb(223, 242, 241);\n --color-white: white;\n --color-emphasis: rgb(8, 8, 9);\n --color-supergiant: rgb(213, 66, 99);\n --color-orange: rgb(250, 200, 127);\n --color-buttons: #fbbc05;\n --color-typography: #ea4335;\n --background: 20 66% 99%;\n --foreground: 20 51% 4%;\n --muted: 20 25% 86%;\n --muted-foreground: 20 7% 25%;\n --popover: 20 66% 98%;\n --popover-foreground: 20 51% 3%;\n --card: 20 66% 98%;\n --card-foreground: 20 51% 3%;\n --border: 20 15% 94%;\n --input: 20 15% 94%;\n --primary: 20 48% 72%;\n --primary-foreground: 20 48% 12%;\n --secondary: 20 12% 92%;\n --secondary-foreground: 20 12% 32%;\n --accent: 20 12% 92%;\n --accent-foreground: 20 12% 32%;\n --destructive: 11 80% 22%;\n --destructive-foreground: 11 80% 82%;\n --ring: 20 48% 72%;\n --radius: 0.5rem;\n --chart-1: 12 76% 61%;\n --chart-2: 173 58% 39%;\n --chart-3: 197 37% 24%;\n --chart-4: 43 74% 66%;\n --chart-5: 27 87% 67%;\n }\n .dark {\n --background: 253 43% 3%;\n --foreground: 253 31% 98%;\n --muted: 253 7% 13%;\n --muted-foreground: 253 13% 63%;\n --popover: 253 43% 3%;\n --popover-foreground: 253 31% 98%;\n --card: 253 43% 4%;\n --card-foreground: 253 31% 99%;\n --border: 215 27.9% 16.9%;\n --input: 215 27.9% 16.9%;\n --primary: 253 91% 58%;\n --primary-foreground: 253 91% 98%;\n --secondary: 253 7% 9%;\n --secondary-foreground: 253 7% 69%;\n --accent: 253 13% 14%;\n --accent-foreground: 253 13% 74%;\n --destructive: 339.2 90.36% 51.18%;\n --destructive-foreground: 0 0% 100%;\n --ring: 253 91% 58%;\n --chart-1: 220 70% 50%;\n --chart-2: 160 60% 45%;\n --chart-3: 30 80% 55%;\n --chart-4: 280 65% 60%;\n --chart-5: 340 75% 55%;\n }\n}\n@layer base {\n * {\n @apply border-border;\n }\n body {\n @apply box-border bg-background text-foreground;\n }\n}\n@layer utilities {\n .min-h-screen {\n min-height: 100vh;\n \n min-height: 100dvh;\n }\n .h-screen {\n height: 100vh;\n \n height: 100dvh;\n }\n}\n@tailwind base;\n@tailwind components;\n@tailwind utilities;\n@layer components {\n .glass {\n border: none;\n backdrop-filter: blur(var(--glass-blur, 40px));\n background-color: transparent;\n background-image: linear-gradient(135deg, rgb(255, 255, 255, var(--glass-opacity, 30%)), transparent), linear-gradient(var(--glass-reflex-degree, 100deg), rgb(255, 255, 255, var(--glass-reflex-opacity, 10%)) 25%, transparent 0);\n box-shadow: 0 0 0 1px rgb(255, 255, 255, var(--glass-border-opacity, 10%)) inset, 0 0 0 2px rgba(0, 0, 0, 0.05);\n text-shadow: 0 1px rgb(0, 0, 0, var(--glass-text-shadow-opacity, 5%));\n }\n}\n.tox.tox-tinymce.sc-xplor-date-picker {\n width: 50% !important;\n height: 400px !important;\n display: inline-flex;\n}\n\n\n@media only screen and (min-width: 600px) {\n .tox.tox-tinymce.sc-xplor-date-picker {\n width: 600px !important;\n }\n}\nh1.sc-xplor-date-picker {\n color: var(--color-primary);\n \n font-family: Inter;\n font-size: 48px;\n font-style: normal;\n font-weight: 400;\n line-height: 56px; \n}\n\nh2.sc-xplor-date-picker {\n color: var(--grey-1100252525, #252525);\n \n font-family: Inter;\n font-size: 32px;\n font-style: normal;\n font-weight: 600;\n line-height: 38px; \n letter-spacing: 0.25px;\n}\n\nh3.sc-xplor-date-picker {\n color: var(--grey-1100252525, #252525);\n \n font-family: Inter;\n font-size: 24px;\n font-style: normal;\n font-weight: 400;\n line-height: 32px; \n}\n\n.overline.sc-xplor-date-picker {\n color: var(--grey-1100252525, #252525);\n \n font-family: Inter;\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px; \n letter-spacing: 3.2px;\n text-transform: uppercase;\n}\n\nol.sc-xplor-date-picker, ul.sc-xplor-date-picker {\n list-style: none;\n margin: 1rem;\n padding: 0;\n}\nol.sc-xplor-date-picker li.sc-xplor-date-picker, ul.sc-xplor-date-picker li.sc-xplor-date-picker {\n margin: 1rem;\n padding: 0;\n}\nol.mdc-list.sc-xplor-date-picker, ul.mdc-list.sc-xplor-date-picker {\n list-style-type: none;\n list-style: none;\n}\nol.mdc-list.sc-xplor-date-picker li.mdc-list-item.sc-xplor-date-picker, ul.mdc-list.sc-xplor-date-picker li.mdc-list-item.sc-xplor-date-picker {\n list-style-type: none;\n list-style: none !important;\n}\n\n.orange-label.sc-xplor-date-picker {\n color: var(--Orange-900-Primary, #db3b03);\n \n font-family: Inter;\n font-size: 12px;\n font-style: normal;\n font-weight: 400;\n line-height: 16px; \n letter-spacing: 0.4px;\n margin: 0px 0 -9px 16px;\n z-index: 1 !important;\n position: relative;\n width: fit-content;\n}\n.orange-label.grey-bg.sc-xplor-date-picker {\n background-color: #fefcfb;\n}\n\n#spinnerLoader.sc-xplor-date-picker {\n position: fixed;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n background-color: #fff;\n padding: 20px;\n border-radius: 5px;\n box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: 100;\n pointer-events: none;\n}\n\n#textfield-Title-label.sc-xplor-date-picker {\n background-color: white;\n}\n\n.mdc-ripple-upgraded.sc-xplor-date-picker .mdc-text-field--outlined.sc-xplor-date-picker .mdc-notched-outline__notch.sc-xplor-date-picker {\n border: 0px solid transparent !important;\n border-bottom: 1px solid #db3b03 !important;\n padding: 0;\n height: 0;\n}\n\n.mdc-text-field--focused.sc-xplor-date-picker .mdc-notched-outline__notch.sc-xplor-date-picker {\n border: 0px solid transparent !important;\n border-bottom: 2px solid #db3b03 !important;\n}\n\n.mdc-text-field--outlined.sc-xplor-date-picker .mdc-notched-outline.sc-xplor-date-picker .mdc-notched-outline__notch.sc-xplor-date-picker {\n max-width: calc(100% - max(12px, var(--mdc-shape-small, 4px)) * 2);\n border-top: transparent;\n}\n\n.generate-btn.sc-xplor-date-picker {\n display: flex;\n height: 48px;\n padding: 12px 24px;\n justify-content: center;\n align-items: center;\n gap: 10px;\n border-radius: 16px;\n}\n.generate-btn.link.sc-xplor-date-picker:hover {\n background-color: var(--Cyan-700-Secondary, #e27046);\n color: var(--Cyan-700-Secondary-Text, #fff);\n}\n\n.bg-green.sc-xplor-date-picker {\n background: var(--Cyan-700-Secondary, #00776b);\n}\n\n.sc-xplor-date-picker-h {\n display: block;\n width: 100%;\n}\n\n.date-picker.sc-xplor-date-picker {\n position: relative;\n width: 100%;\n}\n.date-picker--disabled.sc-xplor-date-picker {\n opacity: 0.6;\n cursor: not-allowed;\n}\n.date-picker__label.sc-xplor-date-picker {\n display: block;\n font-size: 0.875rem;\n color: rgba(0, 0, 0, 0.6);\n margin-bottom: 0.25rem;\n}\n.date-picker__required.sc-xplor-date-picker {\n color: #d32f2f;\n margin-left: 0.25rem;\n}\n.date-picker__field.sc-xplor-date-picker {\n position: relative;\n display: flex;\n align-items: center;\n border: 1px solid rgba(0, 0, 0, 0.23);\n border-radius: 1rem;\n transition: border-color 0.2s ease;\n background: white;\n}\n.date-picker__field.sc-xplor-date-picker:focus-within {\n border-color: #008480;\n border-width: 2px;\n}\n.date-picker__field.sc-xplor-date-picker:focus-within .date-picker__input.sc-xplor-date-picker {\n padding: calc(0.875rem - 1px) calc(1rem - 1px);\n}\n.date-picker--error.sc-xplor-date-picker .date-picker__field.sc-xplor-date-picker {\n border-color: #d32f2f;\n}\n.date-picker__input.sc-xplor-date-picker {\n flex: 1;\n width: 100%;\n padding: 0.875rem 1rem;\n font-size: 1rem;\n font-family: inherit;\n border: none;\n border-radius: 1rem;\n outline: none;\n background: transparent;\n}\n.date-picker__input.sc-xplor-date-picker::placeholder {\n color: rgba(0, 0, 0, 0.38);\n}\n.date-picker__input.sc-xplor-date-picker:disabled {\n cursor: not-allowed;\n}\n.date-picker__actions.sc-xplor-date-picker {\n display: flex;\n align-items: center;\n gap: 0.25rem;\n padding-right: 0.5rem;\n flex-shrink: 0;\n}\n.date-picker__clear.sc-xplor-date-picker {\n background: none;\n border: none;\n font-size: 1.25rem;\n cursor: pointer;\n padding: 0;\n width: 1.5rem;\n height: 1.5rem;\n display: flex;\n align-items: center;\n justify-content: center;\n color: #757575;\n border-radius: 50%;\n transition: background-color 0.2s;\n}\n.date-picker__clear.sc-xplor-date-picker:hover {\n background-color: #f5f5f5;\n color: #212121;\n}\n.date-picker__icon-btn.sc-xplor-date-picker {\n background: none;\n border: none;\n cursor: pointer;\n padding: 0.25rem;\n display: flex;\n align-items: center;\n justify-content: center;\n color: #757575;\n border-radius: 50%;\n transition: background-color 0.2s;\n}\n.date-picker__icon-btn.sc-xplor-date-picker:hover:not(:disabled) {\n background-color: #f5f5f5;\n color: #212121;\n}\n.date-picker__icon-btn.sc-xplor-date-picker:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.date-picker__icon-svg.sc-xplor-date-picker {\n display: block;\n}\n.date-picker__text-display.sc-xplor-date-picker {\n display: inline-flex;\n align-items: center;\n gap: 0.5rem;\n cursor: pointer;\n padding: 0.5rem;\n border-radius: 4px;\n color: #008480;\n font-size: 1rem;\n transition: background-color 0.2s;\n}\n.date-picker__text-display.sc-xplor-date-picker:hover {\n background-color: rgba(0, 132, 128, 0.08);\n}\n.date-picker__text-value.sc-xplor-date-picker {\n text-decoration: underline;\n}\n.date-picker__dropdown.sc-xplor-date-picker {\n position: absolute;\n top: calc(100% + 4px);\n left: 0;\n z-index: 1000;\n background-color: #fff;\n border: 1px solid #e0e0e0;\n border-radius: 8px;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n}\n.date-picker__dropdown--top.sc-xplor-date-picker {\n top: auto;\n bottom: calc(100% + 4px);\n}\n.date-picker__details.sc-xplor-date-picker {\n min-height: 1.25rem;\n padding: 0 1rem;\n font-size: 0.75rem;\n}\n.date-picker__error-message.sc-xplor-date-picker {\n color: #d32f2f;\n}";
|
|
5
|
+
|
|
6
|
+
const XplorDatePicker$1 = /*@__PURE__*/ proxyCustomElement(class XplorDatePicker extends H {
|
|
7
|
+
constructor() {
|
|
8
|
+
super();
|
|
9
|
+
this.__registerHost();
|
|
10
|
+
this.dateChange = createEvent(this, "dateChange");
|
|
11
|
+
this.xplorFocus = createEvent(this, "xplorFocus");
|
|
12
|
+
this.xplorBlur = createEvent(this, "xplorBlur");
|
|
13
|
+
this.xplorClear = createEvent(this, "xplorClear");
|
|
14
|
+
/** Selected date in YYYY-MM-DD format */
|
|
15
|
+
this.value = '';
|
|
16
|
+
this.label = '';
|
|
17
|
+
this.placeholder = 'Select date';
|
|
18
|
+
/** 'date' or 'month' */
|
|
19
|
+
this.type = 'date';
|
|
20
|
+
/** For month type: select start or end of month */
|
|
21
|
+
this.monthType = 'start';
|
|
22
|
+
/** 'input' shows text input, 'text' shows clickable text */
|
|
23
|
+
this.display = 'input';
|
|
24
|
+
/** Date display format: 'short' (DD/MM/YYYY), 'long' (1 Jan 2025), 'iso' (YYYY-MM-DD) */
|
|
25
|
+
this.dateFormat = 'short';
|
|
26
|
+
this.min = '';
|
|
27
|
+
this.max = '';
|
|
28
|
+
this.readonly = false;
|
|
29
|
+
this.disabled = false;
|
|
30
|
+
this.clearable = false;
|
|
31
|
+
this.closeOnSelect = true;
|
|
32
|
+
this.bgColor = 'white';
|
|
33
|
+
this.color = '#008480';
|
|
34
|
+
this.startWeekOnSunday = true;
|
|
35
|
+
this.error = '';
|
|
36
|
+
this.hideDetails = 'auto';
|
|
37
|
+
this.required = false;
|
|
38
|
+
this.isOpen = false;
|
|
39
|
+
this.inputText = '';
|
|
40
|
+
this.dropdownPosition = 'bottom';
|
|
41
|
+
this.toggleDropdown = () => {
|
|
42
|
+
if (this.disabled || this.readonly)
|
|
43
|
+
return;
|
|
44
|
+
this.updateDropdownPosition();
|
|
45
|
+
this.isOpen = !this.isOpen;
|
|
46
|
+
};
|
|
47
|
+
this.handleInputFocus = (event) => {
|
|
48
|
+
this.xplorFocus.emit(event);
|
|
49
|
+
};
|
|
50
|
+
this.handleInputBlur = (event) => {
|
|
51
|
+
this.xplorBlur.emit(event);
|
|
52
|
+
// Try to parse typed text
|
|
53
|
+
const parsed = this.parseInputText(this.inputText);
|
|
54
|
+
if (parsed && this.isDateInRange(parsed)) {
|
|
55
|
+
this.value = parsed;
|
|
56
|
+
this.inputText = this.formatDateForDisplay(parsed);
|
|
57
|
+
this.dateChange.emit(parsed);
|
|
58
|
+
}
|
|
59
|
+
else if (this.value) {
|
|
60
|
+
// Revert to current value display
|
|
61
|
+
this.inputText = this.formatDateForDisplay(this.value);
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
this.inputText = '';
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
this.handleInputChange = (event) => {
|
|
68
|
+
const input = event.target;
|
|
69
|
+
this.inputText = input.value;
|
|
70
|
+
};
|
|
71
|
+
this.handleDateSelected = (event) => {
|
|
72
|
+
event.stopPropagation();
|
|
73
|
+
const iso = event.detail;
|
|
74
|
+
if (!this.isDateInRange(iso))
|
|
75
|
+
return;
|
|
76
|
+
if (this.type === 'month') {
|
|
77
|
+
const d = this.parseISODate(iso);
|
|
78
|
+
if (d) {
|
|
79
|
+
let finalDate;
|
|
80
|
+
if (this.monthType === 'end') {
|
|
81
|
+
finalDate = new Date(d.getFullYear(), d.getMonth() + 1, 0);
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
finalDate = new Date(d.getFullYear(), d.getMonth(), 1);
|
|
85
|
+
}
|
|
86
|
+
const finalIso = this.toISO(finalDate);
|
|
87
|
+
this.value = finalIso;
|
|
88
|
+
this.inputText = this.formatDateForDisplay(finalIso);
|
|
89
|
+
this.dateChange.emit(finalIso);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
this.value = iso;
|
|
94
|
+
this.inputText = this.formatDateForDisplay(iso);
|
|
95
|
+
this.dateChange.emit(iso);
|
|
96
|
+
}
|
|
97
|
+
if (this.closeOnSelect) {
|
|
98
|
+
this.isOpen = false;
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
this.handleClear = (event) => {
|
|
102
|
+
event.stopPropagation();
|
|
103
|
+
this.value = '';
|
|
104
|
+
this.inputText = '';
|
|
105
|
+
this.dateChange.emit('');
|
|
106
|
+
this.xplorClear.emit();
|
|
107
|
+
};
|
|
108
|
+
this.handleTextClick = () => {
|
|
109
|
+
if (this.disabled || this.readonly)
|
|
110
|
+
return;
|
|
111
|
+
this.updateDropdownPosition();
|
|
112
|
+
this.isOpen = !this.isOpen;
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
componentWillLoad() {
|
|
116
|
+
if (this.value) {
|
|
117
|
+
this.inputText = this.formatDateForDisplay(this.value);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
handleDocumentClick(event) {
|
|
121
|
+
const target = event.target;
|
|
122
|
+
if (!this.el.contains(target)) {
|
|
123
|
+
this.isOpen = false;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
/** Parse YYYY-MM-DD safely without UTC shift */
|
|
127
|
+
parseISODate(iso) {
|
|
128
|
+
if (!iso)
|
|
129
|
+
return null;
|
|
130
|
+
const d = new Date(iso + 'T00:00:00');
|
|
131
|
+
return isNaN(d.getTime()) ? null : d;
|
|
132
|
+
}
|
|
133
|
+
formatDateForDisplay(iso) {
|
|
134
|
+
const date = this.parseISODate(iso);
|
|
135
|
+
if (!date)
|
|
136
|
+
return iso;
|
|
137
|
+
if (this.type === 'month') {
|
|
138
|
+
return new Intl.DateTimeFormat('en-AU', { month: 'long', year: 'numeric' }).format(date);
|
|
139
|
+
}
|
|
140
|
+
switch (this.dateFormat) {
|
|
141
|
+
case 'long':
|
|
142
|
+
return new Intl.DateTimeFormat('en-AU', { day: 'numeric', month: 'short', year: 'numeric' }).format(date);
|
|
143
|
+
case 'iso':
|
|
144
|
+
return iso;
|
|
145
|
+
case 'short':
|
|
146
|
+
default:
|
|
147
|
+
return new Intl.DateTimeFormat('en-AU', { day: '2-digit', month: '2-digit', year: 'numeric' }).format(date);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
toISO(date) {
|
|
151
|
+
const year = date.getFullYear();
|
|
152
|
+
const month = String(date.getMonth() + 1).padStart(2, '0');
|
|
153
|
+
const day = String(date.getDate()).padStart(2, '0');
|
|
154
|
+
return `${year}-${month}-${day}`;
|
|
155
|
+
}
|
|
156
|
+
/** Parse user-typed text into YYYY-MM-DD */
|
|
157
|
+
parseInputText(text) {
|
|
158
|
+
const trimmed = text.trim();
|
|
159
|
+
if (!trimmed)
|
|
160
|
+
return null;
|
|
161
|
+
// Try DD/MM/YYYY
|
|
162
|
+
const slashMatch = trimmed.match(/^(\d{1,2})[/\-.](\d{1,2})[/\-.](\d{4})$/);
|
|
163
|
+
if (slashMatch) {
|
|
164
|
+
const day = parseInt(slashMatch[1], 10);
|
|
165
|
+
const month = parseInt(slashMatch[2], 10);
|
|
166
|
+
const year = parseInt(slashMatch[3], 10);
|
|
167
|
+
const d = new Date(year, month - 1, day);
|
|
168
|
+
if (d.getFullYear() === year && d.getMonth() === month - 1 && d.getDate() === day) {
|
|
169
|
+
return this.toISO(d);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
// Try YYYY-MM-DD
|
|
173
|
+
const isoMatch = trimmed.match(/^(\d{4})-(\d{1,2})-(\d{1,2})$/);
|
|
174
|
+
if (isoMatch) {
|
|
175
|
+
const year = parseInt(isoMatch[1], 10);
|
|
176
|
+
const month = parseInt(isoMatch[2], 10);
|
|
177
|
+
const day = parseInt(isoMatch[3], 10);
|
|
178
|
+
const d = new Date(year, month - 1, day);
|
|
179
|
+
if (d.getFullYear() === year && d.getMonth() === month - 1 && d.getDate() === day) {
|
|
180
|
+
return this.toISO(d);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
// Try natural string via Date.parse
|
|
184
|
+
const d = new Date(trimmed);
|
|
185
|
+
if (!isNaN(d.getTime())) {
|
|
186
|
+
return this.toISO(d);
|
|
187
|
+
}
|
|
188
|
+
return null;
|
|
189
|
+
}
|
|
190
|
+
isDateInRange(iso) {
|
|
191
|
+
if (!iso)
|
|
192
|
+
return true;
|
|
193
|
+
if (this.min && iso < this.min)
|
|
194
|
+
return false;
|
|
195
|
+
if (this.max && iso > this.max)
|
|
196
|
+
return false;
|
|
197
|
+
return true;
|
|
198
|
+
}
|
|
199
|
+
updateDropdownPosition() {
|
|
200
|
+
const rect = this.el.getBoundingClientRect();
|
|
201
|
+
const spaceBelow = window.innerHeight - rect.bottom;
|
|
202
|
+
this.dropdownPosition = spaceBelow < 350 ? 'top' : 'bottom';
|
|
203
|
+
}
|
|
204
|
+
render() {
|
|
205
|
+
const showDetails = this.hideDetails === false || (this.hideDetails === 'auto' && this.error);
|
|
206
|
+
const calendarIcon = (h("svg", { key: '9a8e37792f14af7af7f14ec86602b5c9bfb28b56', class: "date-picker__icon-svg", viewBox: "0 0 24 24", width: "20", height: "20", fill: "none", stroke: "currentColor", "stroke-width": "2", "stroke-linecap": "round", "stroke-linejoin": "round" }, h("rect", { key: 'bfbc6e0022ea0c4d5d9ebd49636d9d8b32c2d32c', x: "3", y: "4", width: "18", height: "18", rx: "2", ry: "2" }), h("line", { key: '0d1fd4f951edd7bf388709e4db248d1421c67832', x1: "16", y1: "2", x2: "16", y2: "6" }), h("line", { key: '0995228bc198c5a09de2c9213a4713c2b3e3f054', x1: "8", y1: "2", x2: "8", y2: "6" }), h("line", { key: 'c938471721e6e72b25cbc7d46ddf823f5a37bfe5', x1: "3", y1: "10", x2: "21", y2: "10" })));
|
|
207
|
+
return (h(Host, { key: '5acf3baf9f4d5cece68b25339a68a05f572a1bb9' }, h("div", { key: 'b1c2d84e87ab4d99a1af317397c6b442fbb49f93', class: {
|
|
208
|
+
'date-picker': true,
|
|
209
|
+
'date-picker--disabled': this.disabled,
|
|
210
|
+
'date-picker--error': !!this.error,
|
|
211
|
+
'date-picker--open': this.isOpen,
|
|
212
|
+
} }, this.label && (h("label", { key: '94d43b8d44f60806824f4ef72fe4cb0113441351', class: "date-picker__label" }, this.label, this.required && h("span", { key: '2ae8a33b2a46d7e81a990368390f52c167879013', class: "date-picker__required" }, "*"))), this.display === 'text' ? (h("div", { class: "date-picker__text-display", onClick: this.handleTextClick }, h("span", { class: "date-picker__text-value" }, this.value ? this.formatDateForDisplay(this.value) : this.placeholder), calendarIcon)) : (h("div", { class: "date-picker__field" }, h("input", { type: "text", class: "date-picker__input", value: this.inputText, placeholder: this.placeholder, disabled: this.disabled, readonly: this.readonly, onFocus: this.handleInputFocus, onBlur: this.handleInputBlur, onInput: this.handleInputChange, style: { backgroundColor: this.bgColor } }), h("div", { class: "date-picker__actions" }, this.clearable && this.value && !this.disabled && !this.readonly && (h("button", { type: "button", class: "date-picker__clear", onClick: this.handleClear, "aria-label": "Clear" }, "\u00D7")), h("button", { type: "button", class: "date-picker__icon-btn", onClick: this.toggleDropdown, disabled: this.disabled, "aria-label": "Open calendar" }, calendarIcon)))), showDetails && (h("div", { key: 'eff419a0def4d85e0df8e3182132eeeb57454cef', class: "date-picker__details" }, this.error && h("div", { key: '554878b0d415e16dd8715f58db0da94259a2e3c8', class: "date-picker__error-message" }, this.error))), this.isOpen && (h("div", { key: '75ec84dd8849b3007cb4f99b73098e52b458a476', class: {
|
|
213
|
+
'date-picker__dropdown': true,
|
|
214
|
+
'date-picker__dropdown--top': this.dropdownPosition === 'top',
|
|
215
|
+
} }, h("xplor-inline-date-picker", { key: '74c870356063103474e60245888b8b2ae67fcd1a', selectedDate: this.value, min: this.min, max: this.max, readonly: this.readonly, color: this.color, startWeekOnSunday: this.startWeekOnSunday, onDateSelected: this.handleDateSelected }))))));
|
|
216
|
+
}
|
|
217
|
+
get el() { return this; }
|
|
218
|
+
static get style() { return xplorDatePickerCss; }
|
|
219
|
+
}, [2, "xplor-date-picker", {
|
|
220
|
+
"value": [1025],
|
|
221
|
+
"label": [1],
|
|
222
|
+
"placeholder": [1],
|
|
223
|
+
"type": [1],
|
|
224
|
+
"monthType": [1, "month-type"],
|
|
225
|
+
"display": [1],
|
|
226
|
+
"dateFormat": [1, "date-format"],
|
|
227
|
+
"min": [1],
|
|
228
|
+
"max": [1],
|
|
229
|
+
"readonly": [4],
|
|
230
|
+
"disabled": [4],
|
|
231
|
+
"clearable": [4],
|
|
232
|
+
"closeOnSelect": [4, "close-on-select"],
|
|
233
|
+
"bgColor": [1, "bg-color"],
|
|
234
|
+
"color": [1],
|
|
235
|
+
"startWeekOnSunday": [4, "start-week-on-sunday"],
|
|
236
|
+
"error": [1],
|
|
237
|
+
"hideDetails": [8, "hide-details"],
|
|
238
|
+
"required": [4],
|
|
239
|
+
"isOpen": [32],
|
|
240
|
+
"inputText": [32],
|
|
241
|
+
"dropdownPosition": [32]
|
|
242
|
+
}, [[4, "click", "handleDocumentClick"]]]);
|
|
243
|
+
function defineCustomElement$1() {
|
|
244
|
+
if (typeof customElements === "undefined") {
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
const components = ["xplor-date-picker", "xplor-inline-date-picker"];
|
|
248
|
+
components.forEach(tagName => { switch (tagName) {
|
|
249
|
+
case "xplor-date-picker":
|
|
250
|
+
if (!customElements.get(tagName)) {
|
|
251
|
+
customElements.define(tagName, XplorDatePicker$1);
|
|
252
|
+
}
|
|
253
|
+
break;
|
|
254
|
+
case "xplor-inline-date-picker":
|
|
255
|
+
if (!customElements.get(tagName)) {
|
|
256
|
+
defineCustomElement$2();
|
|
257
|
+
}
|
|
258
|
+
break;
|
|
259
|
+
} });
|
|
260
|
+
}
|
|
261
|
+
defineCustomElement$1();
|
|
262
|
+
|
|
263
|
+
const XplorDatePicker = XplorDatePicker$1;
|
|
264
|
+
const defineCustomElement = defineCustomElement$1;
|
|
265
|
+
|
|
266
|
+
export { XplorDatePicker, defineCustomElement };
|
|
267
|
+
//# sourceMappingURL=xplor-date-picker.js.map
|
|
268
|
+
|
|
269
|
+
//# sourceMappingURL=xplor-date-picker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"xplor-date-picker.js","mappings":"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","names":["XplorDatePicker","__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/xplor-date-picker/xplor-date-picker.scss?tag=xplor-date-picker&encapsulation=scoped","src/components/xplor-date-picker/xplor-date-picker.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n}\n\n.date-picker {\n position: relative;\n width: 100%;\n\n &--disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n\n &__label {\n display: block;\n font-size: 0.875rem;\n color: rgba(0, 0, 0, 0.6);\n margin-bottom: 0.25rem;\n }\n\n &__required {\n color: #d32f2f;\n margin-left: 0.25rem;\n }\n\n &__field {\n position: relative;\n display: flex;\n align-items: center;\n border: 1px solid rgba(0, 0, 0, 0.23);\n border-radius: 1rem;\n transition: border-color 0.2s ease;\n background: white;\n\n &:focus-within {\n border-color: #008480;\n border-width: 2px;\n\n .date-picker__input {\n padding: calc(0.875rem - 1px) calc(1rem - 1px);\n }\n }\n }\n\n &--error &__field {\n border-color: #d32f2f;\n }\n\n &__input {\n flex: 1;\n width: 100%;\n padding: 0.875rem 1rem;\n font-size: 1rem;\n font-family: inherit;\n border: none;\n border-radius: 1rem;\n outline: none;\n background: transparent;\n\n &::placeholder {\n color: rgba(0, 0, 0, 0.38);\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n }\n\n &__actions {\n display: flex;\n align-items: center;\n gap: 0.25rem;\n padding-right: 0.5rem;\n flex-shrink: 0;\n }\n\n &__clear {\n background: none;\n border: none;\n font-size: 1.25rem;\n cursor: pointer;\n padding: 0;\n width: 1.5rem;\n height: 1.5rem;\n display: flex;\n align-items: center;\n justify-content: center;\n color: #757575;\n border-radius: 50%;\n transition: background-color 0.2s;\n\n &:hover {\n background-color: #f5f5f5;\n color: #212121;\n }\n }\n\n &__icon-btn {\n background: none;\n border: none;\n cursor: pointer;\n padding: 0.25rem;\n display: flex;\n align-items: center;\n justify-content: center;\n color: #757575;\n border-radius: 50%;\n transition: background-color 0.2s;\n\n &:hover:not(:disabled) {\n background-color: #f5f5f5;\n color: #212121;\n }\n\n &:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n }\n }\n\n &__icon-svg {\n display: block;\n }\n\n &__text-display {\n display: inline-flex;\n align-items: center;\n gap: 0.5rem;\n cursor: pointer;\n padding: 0.5rem;\n border-radius: 4px;\n color: #008480;\n font-size: 1rem;\n transition: background-color 0.2s;\n\n &:hover {\n background-color: rgba(0, 132, 128, 0.08);\n }\n }\n\n &__text-value {\n text-decoration: underline;\n }\n\n &__dropdown {\n position: absolute;\n top: calc(100% + 4px);\n left: 0;\n z-index: 1000;\n background-color: #fff;\n border: 1px solid #e0e0e0;\n border-radius: 8px;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n\n &--top {\n top: auto;\n bottom: calc(100% + 4px);\n }\n }\n\n &__details {\n min-height: 1.25rem;\n padding: 0 1rem;\n font-size: 0.75rem;\n }\n\n &__error-message {\n color: #d32f2f;\n }\n}\n","import { Component, Host, h, Prop, State, Event, EventEmitter, Element, Listen } from '@stencil/core';\n\n@Component({\n tag: 'xplor-date-picker',\n styleUrl: 'xplor-date-picker.scss',\n scoped: true,\n})\nexport class XplorDatePicker {\n @Element() el: HTMLElement;\n\n /** Selected date in YYYY-MM-DD format */\n @Prop({ mutable: true }) value: string = '';\n\n @Prop() label: string = '';\n @Prop() placeholder: string = 'Select date';\n\n /** 'date' or 'month' */\n @Prop() type: 'date' | 'month' = 'date';\n\n /** For month type: select start or end of month */\n @Prop() monthType: 'start' | 'end' = 'start';\n\n /** 'input' shows text input, 'text' shows clickable text */\n @Prop() display: 'input' | 'text' = 'input';\n\n /** Date display format: 'short' (DD/MM/YYYY), 'long' (1 Jan 2025), 'iso' (YYYY-MM-DD) */\n @Prop() dateFormat: 'short' | 'long' | 'iso' = 'short';\n\n @Prop() min: string = '';\n @Prop() max: string = '';\n @Prop() readonly: boolean = false;\n @Prop() disabled: boolean = false;\n @Prop() clearable: boolean = false;\n @Prop() closeOnSelect: boolean = true;\n @Prop() bgColor: string = 'white';\n @Prop() color: string = '#008480';\n @Prop() startWeekOnSunday: boolean = true;\n @Prop() error: string = '';\n @Prop() hideDetails: boolean | 'auto' = 'auto';\n @Prop() required: boolean = false;\n\n @State() isOpen: boolean = false;\n @State() inputText: string = '';\n @State() dropdownPosition: 'bottom' | 'top' = 'bottom';\n\n @Event() dateChange: EventEmitter<string>;\n @Event() xplorFocus: EventEmitter<FocusEvent>;\n @Event() xplorBlur: EventEmitter<FocusEvent>;\n @Event() xplorClear: EventEmitter<void>;\n\n componentWillLoad() {\n if (this.value) {\n this.inputText = this.formatDateForDisplay(this.value);\n }\n }\n\n @Listen('click', { target: 'document' })\n handleDocumentClick(event: MouseEvent) {\n const target = event.target as Node;\n if (!this.el.contains(target)) {\n this.isOpen = false;\n }\n }\n\n /** Parse YYYY-MM-DD safely without UTC shift */\n private parseISODate(iso: string): Date | null {\n if (!iso) return null;\n const d = new Date(iso + 'T00:00:00');\n return isNaN(d.getTime()) ? null : d;\n }\n\n private formatDateForDisplay(iso: string): string {\n const date = this.parseISODate(iso);\n if (!date) return iso;\n\n if (this.type === 'month') {\n return new Intl.DateTimeFormat('en-AU', { month: 'long', year: 'numeric' }).format(date);\n }\n\n switch (this.dateFormat) {\n case 'long':\n return new Intl.DateTimeFormat('en-AU', { day: 'numeric', month: 'short', year: 'numeric' }).format(date);\n case 'iso':\n return iso;\n case 'short':\n default:\n return new Intl.DateTimeFormat('en-AU', { day: '2-digit', month: '2-digit', year: 'numeric' }).format(date);\n }\n }\n\n private toISO(date: Date): string {\n const year = date.getFullYear();\n const month = String(date.getMonth() + 1).padStart(2, '0');\n const day = String(date.getDate()).padStart(2, '0');\n return `${year}-${month}-${day}`;\n }\n\n /** Parse user-typed text into YYYY-MM-DD */\n private parseInputText(text: string): string | null {\n const trimmed = text.trim();\n if (!trimmed) return null;\n\n // Try DD/MM/YYYY\n const slashMatch = trimmed.match(/^(\\d{1,2})[/\\-.](\\d{1,2})[/\\-.](\\d{4})$/);\n if (slashMatch) {\n const day = parseInt(slashMatch[1], 10);\n const month = parseInt(slashMatch[2], 10);\n const year = parseInt(slashMatch[3], 10);\n const d = new Date(year, month - 1, day);\n if (d.getFullYear() === year && d.getMonth() === month - 1 && d.getDate() === day) {\n return this.toISO(d);\n }\n }\n\n // Try YYYY-MM-DD\n const isoMatch = trimmed.match(/^(\\d{4})-(\\d{1,2})-(\\d{1,2})$/);\n if (isoMatch) {\n const year = parseInt(isoMatch[1], 10);\n const month = parseInt(isoMatch[2], 10);\n const day = parseInt(isoMatch[3], 10);\n const d = new Date(year, month - 1, day);\n if (d.getFullYear() === year && d.getMonth() === month - 1 && d.getDate() === day) {\n return this.toISO(d);\n }\n }\n\n // Try natural string via Date.parse\n const d = new Date(trimmed);\n if (!isNaN(d.getTime())) {\n return this.toISO(d);\n }\n\n return null;\n }\n\n private isDateInRange(iso: string): boolean {\n if (!iso) return true;\n if (this.min && iso < this.min) return false;\n if (this.max && iso > this.max) return false;\n return true;\n }\n\n private updateDropdownPosition() {\n const rect = this.el.getBoundingClientRect();\n const spaceBelow = window.innerHeight - rect.bottom;\n this.dropdownPosition = spaceBelow < 350 ? 'top' : 'bottom';\n }\n\n private toggleDropdown = () => {\n if (this.disabled || this.readonly) return;\n this.updateDropdownPosition();\n this.isOpen = !this.isOpen;\n };\n\n private handleInputFocus = (event: FocusEvent) => {\n this.xplorFocus.emit(event);\n };\n\n private handleInputBlur = (event: FocusEvent) => {\n this.xplorBlur.emit(event);\n // Try to parse typed text\n const parsed = this.parseInputText(this.inputText);\n if (parsed && this.isDateInRange(parsed)) {\n this.value = parsed;\n this.inputText = this.formatDateForDisplay(parsed);\n this.dateChange.emit(parsed);\n } else if (this.value) {\n // Revert to current value display\n this.inputText = this.formatDateForDisplay(this.value);\n } else {\n this.inputText = '';\n }\n };\n\n private handleInputChange = (event: Event) => {\n const input = event.target as HTMLInputElement;\n this.inputText = input.value;\n };\n\n private handleDateSelected = (event: CustomEvent<string>) => {\n event.stopPropagation();\n const iso = event.detail;\n if (!this.isDateInRange(iso)) return;\n\n if (this.type === 'month') {\n const d = this.parseISODate(iso);\n if (d) {\n let finalDate: Date;\n if (this.monthType === 'end') {\n finalDate = new Date(d.getFullYear(), d.getMonth() + 1, 0);\n } else {\n finalDate = new Date(d.getFullYear(), d.getMonth(), 1);\n }\n const finalIso = this.toISO(finalDate);\n this.value = finalIso;\n this.inputText = this.formatDateForDisplay(finalIso);\n this.dateChange.emit(finalIso);\n }\n } else {\n this.value = iso;\n this.inputText = this.formatDateForDisplay(iso);\n this.dateChange.emit(iso);\n }\n\n if (this.closeOnSelect) {\n this.isOpen = false;\n }\n };\n\n private handleClear = (event: Event) => {\n event.stopPropagation();\n this.value = '';\n this.inputText = '';\n this.dateChange.emit('');\n this.xplorClear.emit();\n };\n\n private handleTextClick = () => {\n if (this.disabled || this.readonly) return;\n this.updateDropdownPosition();\n this.isOpen = !this.isOpen;\n };\n\n render() {\n const showDetails = this.hideDetails === false || (this.hideDetails === 'auto' && this.error);\n\n const calendarIcon = (\n <svg class=\"date-picker__icon-svg\" viewBox=\"0 0 24 24\" width=\"20\" height=\"20\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <rect x=\"3\" y=\"4\" width=\"18\" height=\"18\" rx=\"2\" ry=\"2\"></rect>\n <line x1=\"16\" y1=\"2\" x2=\"16\" y2=\"6\"></line>\n <line x1=\"8\" y1=\"2\" x2=\"8\" y2=\"6\"></line>\n <line x1=\"3\" y1=\"10\" x2=\"21\" y2=\"10\"></line>\n </svg>\n );\n\n return (\n <Host>\n <div class={{\n 'date-picker': true,\n 'date-picker--disabled': this.disabled,\n 'date-picker--error': !!this.error,\n 'date-picker--open': this.isOpen,\n }}>\n {this.label && (\n <label class=\"date-picker__label\">\n {this.label}\n {this.required && <span class=\"date-picker__required\">*</span>}\n </label>\n )}\n\n {this.display === 'text' ? (\n <div class=\"date-picker__text-display\" onClick={this.handleTextClick}>\n <span class=\"date-picker__text-value\">\n {this.value ? this.formatDateForDisplay(this.value) : this.placeholder}\n </span>\n {calendarIcon}\n </div>\n ) : (\n <div class=\"date-picker__field\">\n <input\n type=\"text\"\n class=\"date-picker__input\"\n value={this.inputText}\n placeholder={this.placeholder}\n disabled={this.disabled}\n readonly={this.readonly}\n onFocus={this.handleInputFocus}\n onBlur={this.handleInputBlur}\n onInput={this.handleInputChange}\n style={{ backgroundColor: this.bgColor }}\n />\n <div class=\"date-picker__actions\">\n {this.clearable && this.value && !this.disabled && !this.readonly && (\n <button type=\"button\" class=\"date-picker__clear\" onClick={this.handleClear} aria-label=\"Clear\">\n ×\n </button>\n )}\n <button type=\"button\" class=\"date-picker__icon-btn\" onClick={this.toggleDropdown} disabled={this.disabled} aria-label=\"Open calendar\">\n {calendarIcon}\n </button>\n </div>\n </div>\n )}\n\n {showDetails && (\n <div class=\"date-picker__details\">\n {this.error && <div class=\"date-picker__error-message\">{this.error}</div>}\n </div>\n )}\n\n {this.isOpen && (\n <div class={{\n 'date-picker__dropdown': true,\n 'date-picker__dropdown--top': this.dropdownPosition === 'top',\n }}>\n <xplor-inline-date-picker\n selectedDate={this.value}\n min={this.min}\n max={this.max}\n readonly={this.readonly}\n color={this.color}\n startWeekOnSunday={this.startWeekOnSunday}\n onDateSelected={this.handleDateSelected}\n ></xplor-inline-date-picker>\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Components, JSX } from "../types/components";
|
|
2
|
+
|
|
3
|
+
interface XplorDragAndDropInput extends Components.XplorDragAndDropInput, HTMLElement {}
|
|
4
|
+
export const XplorDragAndDropInput: {
|
|
5
|
+
prototype: XplorDragAndDropInput;
|
|
6
|
+
new (): XplorDragAndDropInput;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Used to define this component and all nested components recursively.
|
|
10
|
+
*/
|
|
11
|
+
export const defineCustomElement: () => void;
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { p as proxyCustomElement, H, c as createEvent, h, a as Host } from './index.js';
|
|
2
|
+
import { d as defineCustomElement$2 } from './p-DIv_A5Gj.js';
|
|
3
|
+
|
|
4
|
+
const xplorDragAndDropInputCss = "@tailwind base;\n@tailwind components;\n@tailwind utilities;\n@layer base {\n \n :root {\n --color-primary: #db3b03;\n --color-primary-50: rgba(255, 152, 0, 1);\n --color-secondary: rgb(0, 119, 107);\n --color-secondary-50: rgba(1, 163, 157, 1);\n --color-tertiary: rgb(128, 104, 186);\n --color-tertiary: rgb(223, 242, 241);\n --color-white: white;\n --color-emphasis: rgb(8, 8, 9);\n --color-supergiant: rgb(213, 66, 99);\n --color-orange: rgb(250, 200, 127);\n --color-buttons: #fbbc05;\n --color-typography: #ea4335;\n --background: 20 66% 99%;\n --foreground: 20 51% 4%;\n --muted: 20 25% 86%;\n --muted-foreground: 20 7% 25%;\n --popover: 20 66% 98%;\n --popover-foreground: 20 51% 3%;\n --card: 20 66% 98%;\n --card-foreground: 20 51% 3%;\n --border: 20 15% 94%;\n --input: 20 15% 94%;\n --primary: 20 48% 72%;\n --primary-foreground: 20 48% 12%;\n --secondary: 20 12% 92%;\n --secondary-foreground: 20 12% 32%;\n --accent: 20 12% 92%;\n --accent-foreground: 20 12% 32%;\n --destructive: 11 80% 22%;\n --destructive-foreground: 11 80% 82%;\n --ring: 20 48% 72%;\n --radius: 0.5rem;\n --chart-1: 12 76% 61%;\n --chart-2: 173 58% 39%;\n --chart-3: 197 37% 24%;\n --chart-4: 43 74% 66%;\n --chart-5: 27 87% 67%;\n }\n .dark {\n --background: 253 43% 3%;\n --foreground: 253 31% 98%;\n --muted: 253 7% 13%;\n --muted-foreground: 253 13% 63%;\n --popover: 253 43% 3%;\n --popover-foreground: 253 31% 98%;\n --card: 253 43% 4%;\n --card-foreground: 253 31% 99%;\n --border: 215 27.9% 16.9%;\n --input: 215 27.9% 16.9%;\n --primary: 253 91% 58%;\n --primary-foreground: 253 91% 98%;\n --secondary: 253 7% 9%;\n --secondary-foreground: 253 7% 69%;\n --accent: 253 13% 14%;\n --accent-foreground: 253 13% 74%;\n --destructive: 339.2 90.36% 51.18%;\n --destructive-foreground: 0 0% 100%;\n --ring: 253 91% 58%;\n --chart-1: 220 70% 50%;\n --chart-2: 160 60% 45%;\n --chart-3: 30 80% 55%;\n --chart-4: 280 65% 60%;\n --chart-5: 340 75% 55%;\n }\n}\n@layer base {\n * {\n @apply border-border;\n }\n body {\n @apply box-border bg-background text-foreground;\n }\n}\n@layer utilities {\n .min-h-screen {\n min-height: 100vh;\n \n min-height: 100dvh;\n }\n .h-screen {\n height: 100vh;\n \n height: 100dvh;\n }\n}\n@tailwind base;\n@tailwind components;\n@tailwind utilities;\n@layer components {\n .glass {\n border: none;\n backdrop-filter: blur(var(--glass-blur, 40px));\n background-color: transparent;\n background-image: linear-gradient(135deg, rgb(255, 255, 255, var(--glass-opacity, 30%)), transparent), linear-gradient(var(--glass-reflex-degree, 100deg), rgb(255, 255, 255, var(--glass-reflex-opacity, 10%)) 25%, transparent 0);\n box-shadow: 0 0 0 1px rgb(255, 255, 255, var(--glass-border-opacity, 10%)) inset, 0 0 0 2px rgba(0, 0, 0, 0.05);\n text-shadow: 0 1px rgb(0, 0, 0, var(--glass-text-shadow-opacity, 5%));\n }\n}\n.tox.tox-tinymce.sc-xplor-drag-and-drop-input {\n width: 50% !important;\n height: 400px !important;\n display: inline-flex;\n}\n\n\n@media only screen and (min-width: 600px) {\n .tox.tox-tinymce.sc-xplor-drag-and-drop-input {\n width: 600px !important;\n }\n}\nh1.sc-xplor-drag-and-drop-input {\n color: var(--color-primary);\n \n font-family: Inter;\n font-size: 48px;\n font-style: normal;\n font-weight: 400;\n line-height: 56px; \n}\n\nh2.sc-xplor-drag-and-drop-input {\n color: var(--grey-1100252525, #252525);\n \n font-family: Inter;\n font-size: 32px;\n font-style: normal;\n font-weight: 600;\n line-height: 38px; \n letter-spacing: 0.25px;\n}\n\nh3.sc-xplor-drag-and-drop-input {\n color: var(--grey-1100252525, #252525);\n \n font-family: Inter;\n font-size: 24px;\n font-style: normal;\n font-weight: 400;\n line-height: 32px; \n}\n\n.overline.sc-xplor-drag-and-drop-input {\n color: var(--grey-1100252525, #252525);\n \n font-family: Inter;\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px; \n letter-spacing: 3.2px;\n text-transform: uppercase;\n}\n\nol.sc-xplor-drag-and-drop-input, ul.sc-xplor-drag-and-drop-input {\n list-style: none;\n margin: 1rem;\n padding: 0;\n}\nol.sc-xplor-drag-and-drop-input li.sc-xplor-drag-and-drop-input, ul.sc-xplor-drag-and-drop-input li.sc-xplor-drag-and-drop-input {\n margin: 1rem;\n padding: 0;\n}\nol.mdc-list.sc-xplor-drag-and-drop-input, ul.mdc-list.sc-xplor-drag-and-drop-input {\n list-style-type: none;\n list-style: none;\n}\nol.mdc-list.sc-xplor-drag-and-drop-input li.mdc-list-item.sc-xplor-drag-and-drop-input, ul.mdc-list.sc-xplor-drag-and-drop-input li.mdc-list-item.sc-xplor-drag-and-drop-input {\n list-style-type: none;\n list-style: none !important;\n}\n\n.orange-label.sc-xplor-drag-and-drop-input {\n color: var(--Orange-900-Primary, #db3b03);\n \n font-family: Inter;\n font-size: 12px;\n font-style: normal;\n font-weight: 400;\n line-height: 16px; \n letter-spacing: 0.4px;\n margin: 0px 0 -9px 16px;\n z-index: 1 !important;\n position: relative;\n width: fit-content;\n}\n.orange-label.grey-bg.sc-xplor-drag-and-drop-input {\n background-color: #fefcfb;\n}\n\n#spinnerLoader.sc-xplor-drag-and-drop-input {\n position: fixed;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n background-color: #fff;\n padding: 20px;\n border-radius: 5px;\n box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: 100;\n pointer-events: none;\n}\n\n#textfield-Title-label.sc-xplor-drag-and-drop-input {\n background-color: white;\n}\n\n.mdc-ripple-upgraded.sc-xplor-drag-and-drop-input .mdc-text-field--outlined.sc-xplor-drag-and-drop-input .mdc-notched-outline__notch.sc-xplor-drag-and-drop-input {\n border: 0px solid transparent !important;\n border-bottom: 1px solid #db3b03 !important;\n padding: 0;\n height: 0;\n}\n\n.mdc-text-field--focused.sc-xplor-drag-and-drop-input .mdc-notched-outline__notch.sc-xplor-drag-and-drop-input {\n border: 0px solid transparent !important;\n border-bottom: 2px solid #db3b03 !important;\n}\n\n.mdc-text-field--outlined.sc-xplor-drag-and-drop-input .mdc-notched-outline.sc-xplor-drag-and-drop-input .mdc-notched-outline__notch.sc-xplor-drag-and-drop-input {\n max-width: calc(100% - max(12px, var(--mdc-shape-small, 4px)) * 2);\n border-top: transparent;\n}\n\n.generate-btn.sc-xplor-drag-and-drop-input {\n display: flex;\n height: 48px;\n padding: 12px 24px;\n justify-content: center;\n align-items: center;\n gap: 10px;\n border-radius: 16px;\n}\n.generate-btn.link.sc-xplor-drag-and-drop-input:hover {\n background-color: var(--Cyan-700-Secondary, #e27046);\n color: var(--Cyan-700-Secondary-Text, #fff);\n}\n\n.bg-green.sc-xplor-drag-and-drop-input {\n background: var(--Cyan-700-Secondary, #00776b);\n}\n\n.margin-128.sc-xplor-drag-and-drop-input {\n margin: 8rem;\n}\n\n.margin-t-128.sc-xplor-drag-and-drop-input {\n margin-top: 8rem;\n}\n\n.margin-r-128.sc-xplor-drag-and-drop-input {\n margin-right: 8rem;\n}\n\n.margin-b-128.sc-xplor-drag-and-drop-input {\n margin-bottom: 8rem;\n}\n\n.margin-l-128.sc-xplor-drag-and-drop-input {\n margin-left: 8rem;\n}\n\n.margin-x-128.sc-xplor-drag-and-drop-input {\n margin-left: 8rem;\n margin-right: 8rem;\n}\n\n.margin-y-128.sc-xplor-drag-and-drop-input {\n margin-top: 8rem;\n margin-bottom: 8rem;\n}\n\n.margin-80.sc-xplor-drag-and-drop-input {\n margin: 5rem;\n}\n\n.margin-t-80.sc-xplor-drag-and-drop-input {\n margin-top: 5rem;\n}\n\n.margin-r-80.sc-xplor-drag-and-drop-input {\n margin-right: 5rem;\n}\n\n.margin-b-80.sc-xplor-drag-and-drop-input {\n margin-bottom: 5rem;\n}\n\n.margin-l-80.sc-xplor-drag-and-drop-input {\n margin-left: 5rem;\n}\n\n.margin-x-80.sc-xplor-drag-and-drop-input {\n margin-left: 5rem;\n margin-right: 5rem;\n}\n\n.margin-y-80.sc-xplor-drag-and-drop-input {\n margin-top: 5rem;\n margin-bottom: 5rem;\n}\n\n.margin-64.sc-xplor-drag-and-drop-input {\n margin: 4rem;\n}\n\n.margin-t-64.sc-xplor-drag-and-drop-input {\n margin-top: 4rem;\n}\n\n.margin-r-64.sc-xplor-drag-and-drop-input {\n margin-right: 4rem;\n}\n\n.margin-b-64.sc-xplor-drag-and-drop-input {\n margin-bottom: 4rem;\n}\n\n.margin-l-64.sc-xplor-drag-and-drop-input {\n margin-left: 4rem;\n}\n\n.margin-x-64.sc-xplor-drag-and-drop-input {\n margin-left: 4rem;\n margin-right: 4rem;\n}\n\n.margin-y-64.sc-xplor-drag-and-drop-input {\n margin-top: 4rem;\n margin-bottom: 4rem;\n}\n\n.margin-56.sc-xplor-drag-and-drop-input {\n margin: 3.5rem;\n}\n\n.margin-t-56.sc-xplor-drag-and-drop-input {\n margin-top: 3.5rem;\n}\n\n.margin-r-56.sc-xplor-drag-and-drop-input {\n margin-right: 3.5rem;\n}\n\n.margin-b-56.sc-xplor-drag-and-drop-input {\n margin-bottom: 3.5rem;\n}\n\n.margin-l-56.sc-xplor-drag-and-drop-input {\n margin-left: 3.5rem;\n}\n\n.margin-x-56.sc-xplor-drag-and-drop-input {\n margin-left: 3.5rem;\n margin-right: 3.5rem;\n}\n\n.margin-y-56.sc-xplor-drag-and-drop-input {\n margin-top: 3.5rem;\n margin-bottom: 3.5rem;\n}\n\n.margin-48.sc-xplor-drag-and-drop-input {\n margin: 3rem;\n}\n\n.margin-t-48.sc-xplor-drag-and-drop-input {\n margin-top: 3rem;\n}\n\n.margin-r-48.sc-xplor-drag-and-drop-input {\n margin-right: 3rem;\n}\n\n.margin-b-48.sc-xplor-drag-and-drop-input {\n margin-bottom: 3rem;\n}\n\n.margin-l-48.sc-xplor-drag-and-drop-input {\n margin-left: 3rem;\n}\n\n.margin-x-48.sc-xplor-drag-and-drop-input {\n margin-left: 3rem;\n margin-right: 3rem;\n}\n\n.margin-y-48.sc-xplor-drag-and-drop-input {\n margin-top: 3rem;\n margin-bottom: 3rem;\n}\n\n.margin-40.sc-xplor-drag-and-drop-input {\n margin: 2.5rem;\n}\n\n.margin-t-40.sc-xplor-drag-and-drop-input {\n margin-top: 2.5rem;\n}\n\n.margin-r-40.sc-xplor-drag-and-drop-input {\n margin-right: 2.5rem;\n}\n\n.margin-b-40.sc-xplor-drag-and-drop-input {\n margin-bottom: 2.5rem;\n}\n\n.margin-l-40.sc-xplor-drag-and-drop-input {\n margin-left: 2.5rem;\n}\n\n.margin-x-40.sc-xplor-drag-and-drop-input {\n margin-left: 2.5rem;\n margin-right: 2.5rem;\n}\n\n.margin-y-40.sc-xplor-drag-and-drop-input {\n margin-top: 2.5rem;\n margin-bottom: 2.5rem;\n}\n\n.margin-32.sc-xplor-drag-and-drop-input {\n margin: 2rem;\n}\n\n.margin-t-32.sc-xplor-drag-and-drop-input {\n margin-top: 2rem;\n}\n\n.margin-r-32.sc-xplor-drag-and-drop-input {\n margin-right: 2rem;\n}\n\n.margin-b-32.sc-xplor-drag-and-drop-input {\n margin-bottom: 2rem;\n}\n\n.margin-l-32.sc-xplor-drag-and-drop-input {\n margin-left: 2rem;\n}\n\n.margin-x-32.sc-xplor-drag-and-drop-input {\n margin-left: 2rem;\n margin-right: 2rem;\n}\n\n.margin-y-32.sc-xplor-drag-and-drop-input {\n margin-top: 2rem;\n margin-bottom: 2rem;\n}\n\n.margin-24.sc-xplor-drag-and-drop-input {\n margin: 1.5rem;\n}\n\n.margin-t-24.sc-xplor-drag-and-drop-input {\n margin-top: 1.5rem;\n}\n\n.margin-r-24.sc-xplor-drag-and-drop-input {\n margin-right: 1.5rem;\n}\n\n.margin-b-24.sc-xplor-drag-and-drop-input {\n margin-bottom: 1.5rem;\n}\n\n.margin-l-24.sc-xplor-drag-and-drop-input {\n margin-left: 1.5rem;\n}\n\n.margin-x-24.sc-xplor-drag-and-drop-input {\n margin-left: 1.5rem;\n margin-right: 1.5rem;\n}\n\n.margin-y-24.sc-xplor-drag-and-drop-input {\n margin-top: 1.5rem;\n margin-bottom: 1.5rem;\n}\n\n.margin-20.sc-xplor-drag-and-drop-input {\n margin: 1.25rem;\n}\n\n.margin-t-20.sc-xplor-drag-and-drop-input {\n margin-top: 1.25rem;\n}\n\n.margin-r-20.sc-xplor-drag-and-drop-input {\n margin-right: 1.25rem;\n}\n\n.margin-b-20.sc-xplor-drag-and-drop-input {\n margin-bottom: 1.25rem;\n}\n\n.margin-l-20.sc-xplor-drag-and-drop-input {\n margin-left: 1.25rem;\n}\n\n.margin-x-20.sc-xplor-drag-and-drop-input {\n margin-left: 1.25rem;\n margin-right: 1.25rem;\n}\n\n.margin-y-20.sc-xplor-drag-and-drop-input {\n margin-top: 1.25rem;\n margin-bottom: 1.25rem;\n}\n\n.margin-16.sc-xplor-drag-and-drop-input {\n margin: 1rem;\n}\n\n.margin-t-16.sc-xplor-drag-and-drop-input {\n margin-top: 1rem;\n}\n\n.margin-r-16.sc-xplor-drag-and-drop-input {\n margin-right: 1rem;\n}\n\n.margin-b-16.sc-xplor-drag-and-drop-input {\n margin-bottom: 1rem;\n}\n\n.margin-l-16.sc-xplor-drag-and-drop-input {\n margin-left: 1rem;\n}\n\n.margin-x-16.sc-xplor-drag-and-drop-input {\n margin-left: 1rem;\n margin-right: 1rem;\n}\n\n.margin-y-16.sc-xplor-drag-and-drop-input {\n margin-top: 1rem;\n margin-bottom: 1rem;\n}\n\n.margin-12.sc-xplor-drag-and-drop-input {\n margin: 0.75rem;\n}\n\n.margin-t-12.sc-xplor-drag-and-drop-input {\n margin-top: 0.75rem;\n}\n\n.margin-r-12.sc-xplor-drag-and-drop-input {\n margin-right: 0.75rem;\n}\n\n.margin-b-12.sc-xplor-drag-and-drop-input {\n margin-bottom: 0.75rem;\n}\n\n.margin-l-12.sc-xplor-drag-and-drop-input {\n margin-left: 0.75rem;\n}\n\n.margin-x-12.sc-xplor-drag-and-drop-input {\n margin-left: 0.75rem;\n margin-right: 0.75rem;\n}\n\n.margin-y-12.sc-xplor-drag-and-drop-input {\n margin-top: 0.75rem;\n margin-bottom: 0.75rem;\n}\n\n.margin-8.sc-xplor-drag-and-drop-input {\n margin: 0.5rem;\n}\n\n.margin-t-8.sc-xplor-drag-and-drop-input {\n margin-top: 0.5rem;\n}\n\n.margin-r-8.sc-xplor-drag-and-drop-input {\n margin-right: 0.5rem;\n}\n\n.margin-b-8.sc-xplor-drag-and-drop-input {\n margin-bottom: 0.5rem;\n}\n\n.margin-l-8.sc-xplor-drag-and-drop-input {\n margin-left: 0.5rem;\n}\n\n.margin-x-8.sc-xplor-drag-and-drop-input {\n margin-left: 0.5rem;\n margin-right: 0.5rem;\n}\n\n.margin-y-8.sc-xplor-drag-and-drop-input {\n margin-top: 0.5rem;\n margin-bottom: 0.5rem;\n}\n\n.margin-4.sc-xplor-drag-and-drop-input {\n margin: 0.25rem;\n}\n\n.margin-t-4.sc-xplor-drag-and-drop-input {\n margin-top: 0.25rem;\n}\n\n.margin-r-4.sc-xplor-drag-and-drop-input {\n margin-right: 0.25rem;\n}\n\n.margin-b-4.sc-xplor-drag-and-drop-input {\n margin-bottom: 0.25rem;\n}\n\n.margin-l-4.sc-xplor-drag-and-drop-input {\n margin-left: 0.25rem;\n}\n\n.margin-x-4.sc-xplor-drag-and-drop-input {\n margin-left: 0.25rem;\n margin-right: 0.25rem;\n}\n\n.margin-y-4.sc-xplor-drag-and-drop-input {\n margin-top: 0.25rem;\n margin-bottom: 0.25rem;\n}\n\n.padding-128.sc-xplor-drag-and-drop-input {\n padding: 8rem;\n}\n\n.padding-t-128.sc-xplor-drag-and-drop-input {\n padding-top: 8rem;\n}\n\n.padding-r-128.sc-xplor-drag-and-drop-input {\n padding-right: 8rem;\n}\n\n.padding-b-128.sc-xplor-drag-and-drop-input {\n padding-bottom: 8rem;\n}\n\n.padding-l-128.sc-xplor-drag-and-drop-input {\n padding-left: 8rem;\n}\n\n.padding-x-128.sc-xplor-drag-and-drop-input {\n padding-left: 8rem;\n padding-right: 8rem;\n}\n\n.padding-y-128.sc-xplor-drag-and-drop-input {\n padding-top: 8rem;\n padding-bottom: 8rem;\n}\n\n.padding-80.sc-xplor-drag-and-drop-input {\n padding: 5rem;\n}\n\n.padding-t-80.sc-xplor-drag-and-drop-input {\n padding-top: 5rem;\n}\n\n.padding-r-80.sc-xplor-drag-and-drop-input {\n padding-right: 5rem;\n}\n\n.padding-b-80.sc-xplor-drag-and-drop-input {\n padding-bottom: 5rem;\n}\n\n.padding-l-80.sc-xplor-drag-and-drop-input {\n padding-left: 5rem;\n}\n\n.padding-x-80.sc-xplor-drag-and-drop-input {\n padding-left: 5rem;\n padding-right: 5rem;\n}\n\n.padding-y-80.sc-xplor-drag-and-drop-input {\n padding-top: 5rem;\n padding-bottom: 5rem;\n}\n\n.padding-64.sc-xplor-drag-and-drop-input {\n padding: 4rem;\n}\n\n.padding-t-64.sc-xplor-drag-and-drop-input {\n padding-top: 4rem;\n}\n\n.padding-r-64.sc-xplor-drag-and-drop-input {\n padding-right: 4rem;\n}\n\n.padding-b-64.sc-xplor-drag-and-drop-input {\n padding-bottom: 4rem;\n}\n\n.padding-l-64.sc-xplor-drag-and-drop-input {\n padding-left: 4rem;\n}\n\n.padding-x-64.sc-xplor-drag-and-drop-input {\n padding-left: 4rem;\n padding-right: 4rem;\n}\n\n.padding-y-64.sc-xplor-drag-and-drop-input {\n padding-top: 4rem;\n padding-bottom: 4rem;\n}\n\n.padding-56.sc-xplor-drag-and-drop-input {\n padding: 3.5rem;\n}\n\n.padding-t-56.sc-xplor-drag-and-drop-input {\n padding-top: 3.5rem;\n}\n\n.padding-r-56.sc-xplor-drag-and-drop-input {\n padding-right: 3.5rem;\n}\n\n.padding-b-56.sc-xplor-drag-and-drop-input {\n padding-bottom: 3.5rem;\n}\n\n.padding-l-56.sc-xplor-drag-and-drop-input {\n padding-left: 3.5rem;\n}\n\n.padding-x-56.sc-xplor-drag-and-drop-input {\n padding-left: 3.5rem;\n padding-right: 3.5rem;\n}\n\n.padding-y-56.sc-xplor-drag-and-drop-input {\n padding-top: 3.5rem;\n padding-bottom: 3.5rem;\n}\n\n.padding-48.sc-xplor-drag-and-drop-input {\n padding: 3rem;\n}\n\n.padding-t-48.sc-xplor-drag-and-drop-input {\n padding-top: 3rem;\n}\n\n.padding-r-48.sc-xplor-drag-and-drop-input {\n padding-right: 3rem;\n}\n\n.padding-b-48.sc-xplor-drag-and-drop-input {\n padding-bottom: 3rem;\n}\n\n.padding-l-48.sc-xplor-drag-and-drop-input {\n padding-left: 3rem;\n}\n\n.padding-x-48.sc-xplor-drag-and-drop-input {\n padding-left: 3rem;\n padding-right: 3rem;\n}\n\n.padding-y-48.sc-xplor-drag-and-drop-input {\n padding-top: 3rem;\n padding-bottom: 3rem;\n}\n\n.padding-40.sc-xplor-drag-and-drop-input {\n padding: 2.5rem;\n}\n\n.padding-t-40.sc-xplor-drag-and-drop-input {\n padding-top: 2.5rem;\n}\n\n.padding-r-40.sc-xplor-drag-and-drop-input {\n padding-right: 2.5rem;\n}\n\n.padding-b-40.sc-xplor-drag-and-drop-input {\n padding-bottom: 2.5rem;\n}\n\n.padding-l-40.sc-xplor-drag-and-drop-input {\n padding-left: 2.5rem;\n}\n\n.padding-x-40.sc-xplor-drag-and-drop-input {\n padding-left: 2.5rem;\n padding-right: 2.5rem;\n}\n\n.padding-y-40.sc-xplor-drag-and-drop-input {\n padding-top: 2.5rem;\n padding-bottom: 2.5rem;\n}\n\n.padding-32.sc-xplor-drag-and-drop-input {\n padding: 2rem;\n}\n\n.padding-t-32.sc-xplor-drag-and-drop-input {\n padding-top: 2rem;\n}\n\n.padding-r-32.sc-xplor-drag-and-drop-input {\n padding-right: 2rem;\n}\n\n.padding-b-32.sc-xplor-drag-and-drop-input {\n padding-bottom: 2rem;\n}\n\n.padding-l-32.sc-xplor-drag-and-drop-input {\n padding-left: 2rem;\n}\n\n.padding-x-32.sc-xplor-drag-and-drop-input {\n padding-left: 2rem;\n padding-right: 2rem;\n}\n\n.padding-y-32.sc-xplor-drag-and-drop-input {\n padding-top: 2rem;\n padding-bottom: 2rem;\n}\n\n.padding-24.sc-xplor-drag-and-drop-input {\n padding: 1.5rem;\n}\n\n.padding-t-24.sc-xplor-drag-and-drop-input {\n padding-top: 1.5rem;\n}\n\n.padding-r-24.sc-xplor-drag-and-drop-input {\n padding-right: 1.5rem;\n}\n\n.padding-b-24.sc-xplor-drag-and-drop-input {\n padding-bottom: 1.5rem;\n}\n\n.padding-l-24.sc-xplor-drag-and-drop-input {\n padding-left: 1.5rem;\n}\n\n.padding-x-24.sc-xplor-drag-and-drop-input {\n padding-left: 1.5rem;\n padding-right: 1.5rem;\n}\n\n.padding-y-24.sc-xplor-drag-and-drop-input {\n padding-top: 1.5rem;\n padding-bottom: 1.5rem;\n}\n\n.padding-20.sc-xplor-drag-and-drop-input {\n padding: 1.25rem;\n}\n\n.padding-t-20.sc-xplor-drag-and-drop-input {\n padding-top: 1.25rem;\n}\n\n.padding-r-20.sc-xplor-drag-and-drop-input {\n padding-right: 1.25rem;\n}\n\n.padding-b-20.sc-xplor-drag-and-drop-input {\n padding-bottom: 1.25rem;\n}\n\n.padding-l-20.sc-xplor-drag-and-drop-input {\n padding-left: 1.25rem;\n}\n\n.padding-x-20.sc-xplor-drag-and-drop-input {\n padding-left: 1.25rem;\n padding-right: 1.25rem;\n}\n\n.padding-y-20.sc-xplor-drag-and-drop-input {\n padding-top: 1.25rem;\n padding-bottom: 1.25rem;\n}\n\n.padding-16.sc-xplor-drag-and-drop-input {\n padding: 1rem;\n}\n\n.padding-t-16.sc-xplor-drag-and-drop-input {\n padding-top: 1rem;\n}\n\n.padding-r-16.sc-xplor-drag-and-drop-input {\n padding-right: 1rem;\n}\n\n.padding-b-16.sc-xplor-drag-and-drop-input {\n padding-bottom: 1rem;\n}\n\n.padding-l-16.sc-xplor-drag-and-drop-input {\n padding-left: 1rem;\n}\n\n.padding-x-16.sc-xplor-drag-and-drop-input {\n padding-left: 1rem;\n padding-right: 1rem;\n}\n\n.padding-y-16.sc-xplor-drag-and-drop-input {\n padding-top: 1rem;\n padding-bottom: 1rem;\n}\n\n.padding-12.sc-xplor-drag-and-drop-input {\n padding: 0.75rem;\n}\n\n.padding-t-12.sc-xplor-drag-and-drop-input {\n padding-top: 0.75rem;\n}\n\n.padding-r-12.sc-xplor-drag-and-drop-input {\n padding-right: 0.75rem;\n}\n\n.padding-b-12.sc-xplor-drag-and-drop-input {\n padding-bottom: 0.75rem;\n}\n\n.padding-l-12.sc-xplor-drag-and-drop-input {\n padding-left: 0.75rem;\n}\n\n.padding-x-12.sc-xplor-drag-and-drop-input {\n padding-left: 0.75rem;\n padding-right: 0.75rem;\n}\n\n.padding-y-12.sc-xplor-drag-and-drop-input {\n padding-top: 0.75rem;\n padding-bottom: 0.75rem;\n}\n\n.padding-8.sc-xplor-drag-and-drop-input {\n padding: 0.5rem;\n}\n\n.padding-t-8.sc-xplor-drag-and-drop-input {\n padding-top: 0.5rem;\n}\n\n.padding-r-8.sc-xplor-drag-and-drop-input {\n padding-right: 0.5rem;\n}\n\n.padding-b-8.sc-xplor-drag-and-drop-input {\n padding-bottom: 0.5rem;\n}\n\n.padding-l-8.sc-xplor-drag-and-drop-input {\n padding-left: 0.5rem;\n}\n\n.padding-x-8.sc-xplor-drag-and-drop-input {\n padding-left: 0.5rem;\n padding-right: 0.5rem;\n}\n\n.padding-y-8.sc-xplor-drag-and-drop-input {\n padding-top: 0.5rem;\n padding-bottom: 0.5rem;\n}\n\n.padding-4.sc-xplor-drag-and-drop-input {\n padding: 0.25rem;\n}\n\n.padding-t-4.sc-xplor-drag-and-drop-input {\n padding-top: 0.25rem;\n}\n\n.padding-r-4.sc-xplor-drag-and-drop-input {\n padding-right: 0.25rem;\n}\n\n.padding-b-4.sc-xplor-drag-and-drop-input {\n padding-bottom: 0.25rem;\n}\n\n.padding-l-4.sc-xplor-drag-and-drop-input {\n padding-left: 0.25rem;\n}\n\n.padding-x-4.sc-xplor-drag-and-drop-input {\n padding-left: 0.25rem;\n padding-right: 0.25rem;\n}\n\n.padding-y-4.sc-xplor-drag-and-drop-input {\n padding-top: 0.25rem;\n padding-bottom: 0.25rem;\n}\n\n.sc-xplor-drag-and-drop-input-h {\n display: block;\n}\n\n.drag-drop-wrapper.sc-xplor-drag-and-drop-input {\n position: relative;\n padding-bottom: 2.5rem;\n}\n\n.drag-drop-input-hidden.sc-xplor-drag-and-drop-input {\n display: none;\n}\n\n.drag-drop-card.sc-xplor-drag-and-drop-input {\n background-color: var(--color-secondary-50, #f3e5f5);\n border-radius: 8px;\n border: 3px dashed #e0e0e0;\n min-height: 240px;\n padding: 1rem 1.5rem 2.5rem;\n text-align: center;\n transition: all 0.2s ease;\n cursor: default;\n}\n.drag-drop-card.sc-xplor-drag-and-drop-input:hover:not(.drag-drop-card--disabled) {\n border-color: var(--color-secondary);\n}\n.drag-drop-card--dragover.sc-xplor-drag-and-drop-input {\n border: 3px dashed var(--color-secondary);\n background-color: var(--color-secondary-100, #e1bee7);\n}\n.drag-drop-card--disabled.sc-xplor-drag-and-drop-input {\n opacity: 0.6;\n cursor: not-allowed;\n}\n\n.drag-drop-card__content.sc-xplor-drag-and-drop-input {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 1rem;\n padding: 0.5rem 0 0;\n}\n\n.drag-drop-card__icon.sc-xplor-drag-and-drop-input {\n color: var(--color-secondary);\n width: 68px;\n height: 68px;\n}\n\n.drag-drop-card__title.sc-xplor-drag-and-drop-input {\n color: #000000;\n font-family: Inter, sans-serif;\n font-size: 24px;\n font-weight: 700;\n line-height: 32px;\n letter-spacing: 0;\n margin: 0;\n}\n\n.drag-drop-card__accepts.sc-xplor-drag-and-drop-input, .drag-drop-card__divider.sc-xplor-drag-and-drop-input {\n color: #000000;\n font-family: Inter, sans-serif;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n margin: 0;\n}\n\n.drag-drop-card__action.sc-xplor-drag-and-drop-input {\n position: absolute;\n left: 50%;\n bottom: 0;\n transform: translateX(-50%);\n}\n\n.drag-drop-card__file-info.sc-xplor-drag-and-drop-input {\n margin-top: 1rem;\n color: #616161;\n font-family: Inter, sans-serif;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n padding: 0.25rem;\n text-align: center;\n}\n\n@media (max-width: 768px) {\n .drag-drop-card.sc-xplor-drag-and-drop-input {\n min-height: 200px;\n }\n .drag-drop-card__title.sc-xplor-drag-and-drop-input {\n font-size: 20px;\n line-height: 28px;\n }\n .drag-drop-card__accepts.sc-xplor-drag-and-drop-input, .drag-drop-card__divider.sc-xplor-drag-and-drop-input {\n font-size: 13px;\n line-height: 18px;\n }\n}";
|
|
5
|
+
|
|
6
|
+
const DEFAULT_ACCEPT_ALL = '*' + '/' + '*';
|
|
7
|
+
const XplorDragAndDropInput$1 = /*@__PURE__*/ proxyCustomElement(class XplorDragAndDropInput extends H {
|
|
8
|
+
constructor() {
|
|
9
|
+
super();
|
|
10
|
+
this.__registerHost();
|
|
11
|
+
this.fileSelect = createEvent(this, "fileSelect");
|
|
12
|
+
this.fileClear = createEvent(this, "fileClear");
|
|
13
|
+
/**
|
|
14
|
+
* Disable the file upload
|
|
15
|
+
*/
|
|
16
|
+
this.disabled = false;
|
|
17
|
+
/**
|
|
18
|
+
* Accepted file types (e.g., 'image/png,.pdf')
|
|
19
|
+
*/
|
|
20
|
+
this.accepts = DEFAULT_ACCEPT_ALL;
|
|
21
|
+
/**
|
|
22
|
+
* Instruction text displayed in the drop zone
|
|
23
|
+
*/
|
|
24
|
+
this.label = 'Drag and drop your file here';
|
|
25
|
+
/**
|
|
26
|
+
* Browse button label text
|
|
27
|
+
*/
|
|
28
|
+
this.browseLabel = 'Browse Files';
|
|
29
|
+
this.dragover = false;
|
|
30
|
+
this.currentFile = null;
|
|
31
|
+
this.onDrop = (e) => {
|
|
32
|
+
var _a, _b;
|
|
33
|
+
e.preventDefault();
|
|
34
|
+
this.dragover = false;
|
|
35
|
+
if (this.disabled)
|
|
36
|
+
return;
|
|
37
|
+
const file = (_b = (_a = e.dataTransfer) === null || _a === void 0 ? void 0 : _a.files) === null || _b === void 0 ? void 0 : _b[0];
|
|
38
|
+
if (file) {
|
|
39
|
+
this.currentFile = file;
|
|
40
|
+
this.fileSelect.emit(this.currentFile);
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
this.onDragOver = (e) => {
|
|
44
|
+
e.preventDefault();
|
|
45
|
+
if (!this.disabled) {
|
|
46
|
+
this.dragover = true;
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
this.onDragEnter = (e) => {
|
|
50
|
+
e.preventDefault();
|
|
51
|
+
if (!this.disabled) {
|
|
52
|
+
this.dragover = true;
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
this.onDragLeave = (e) => {
|
|
56
|
+
e.preventDefault();
|
|
57
|
+
this.dragover = false;
|
|
58
|
+
};
|
|
59
|
+
this.onFileSelect = (e) => {
|
|
60
|
+
var _a;
|
|
61
|
+
const input = e.target;
|
|
62
|
+
const file = (_a = input.files) === null || _a === void 0 ? void 0 : _a[0];
|
|
63
|
+
if (file) {
|
|
64
|
+
this.currentFile = file;
|
|
65
|
+
this.fileSelect.emit(this.currentFile);
|
|
66
|
+
}
|
|
67
|
+
input.value = '';
|
|
68
|
+
};
|
|
69
|
+
this.openFileDialog = () => {
|
|
70
|
+
var _a;
|
|
71
|
+
if (this.disabled) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
(_a = this.fileInputEl) === null || _a === void 0 ? void 0 : _a.click();
|
|
75
|
+
};
|
|
76
|
+
this.getAcceptsLabel = () => {
|
|
77
|
+
var _a;
|
|
78
|
+
const accepts = (_a = this.accepts) === null || _a === void 0 ? void 0 : _a.trim();
|
|
79
|
+
if (!accepts || accepts === DEFAULT_ACCEPT_ALL) {
|
|
80
|
+
return '*';
|
|
81
|
+
}
|
|
82
|
+
return accepts;
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Clears the currently selected file
|
|
87
|
+
*/
|
|
88
|
+
async clearCurrentFile() {
|
|
89
|
+
this.currentFile = null;
|
|
90
|
+
if (this.fileInputEl) {
|
|
91
|
+
this.fileInputEl.value = '';
|
|
92
|
+
}
|
|
93
|
+
this.fileClear.emit();
|
|
94
|
+
}
|
|
95
|
+
render() {
|
|
96
|
+
return (h(Host, { key: 'b72e4af7297041c85e4739d815a306ff911e7aa1' }, h("div", { key: '40ffa20b154c281bfc25b9b84ad4c2f0b8ed8ccb', class: "drag-drop-wrapper" }, h("div", { key: '32129f70d878d4d9521125038ea19deddfed91d4', class: {
|
|
97
|
+
'drag-drop-card': true,
|
|
98
|
+
'drag-drop-card--dragover': this.dragover,
|
|
99
|
+
'drag-drop-card--disabled': this.disabled,
|
|
100
|
+
}, onDrop: this.onDrop, onDragOver: this.onDragOver, onDragEnter: this.onDragEnter, onDragLeave: this.onDragLeave }, h("div", { key: 'a85fdd90c7906f3aaaa7abc8d32242c8187962fe', class: "drag-drop-card__content" }, h("svg", { key: '6db73c93ac4466f211877acf4624e619e1a720f3', class: "drag-drop-card__icon", xmlns: "http://www.w3.org/2000/svg", width: "60", height: "60", viewBox: "0 0 24 24", fill: "none" }, h("path", { key: '498a203a5dd4bae94216812bbd0bb50e7754ab87', d: "M19.35 10.04C18.67 6.59 15.64 4 12 4C9.11 4 6.6 5.64 5.35 8.04C2.34 8.36 0 10.91 0 14C0 17.31 2.69 20 6 20H19C21.76 20 24 17.76 24 15C24 12.36 21.95 10.22 19.35 10.04Z", fill: "currentColor", opacity: "0.3" }), h("path", { key: 'eb67e96947f184dab5a6b85987ef7938993b5f33', d: "M19.35 10.04C18.67 6.59 15.64 4 12 4C9.11 4 6.6 5.64 5.35 8.04C2.34 8.36 0 10.91 0 14C0 17.31 2.69 20 6 20H19C21.76 20 24 17.76 24 15C24 12.36 21.95 10.22 19.35 10.04ZM14 13V17H10V13H7L12 8L17 13H14Z", fill: "currentColor" })), h("h3", { key: 'e37febff26d168eee495b5bc7dd49346fdb1079f', class: "drag-drop-card__title" }, this.label), h("p", { key: '514955f0836288b51e45d1ddaefe5eb2361e6007', class: "drag-drop-card__accepts" }, "Accepted file types: ", this.getAcceptsLabel()), h("p", { key: 'd390f6dc61ba8d87a512ca216c46dc8faf6d76a8', class: "drag-drop-card__divider" }, "or"))), h("div", { key: '2127925fcb39ec6adea03f107ffe6faaee5a0c48', class: "drag-drop-card__action" }, h("xplor-button", { key: '0659fa9bcc6f363516aebc12f66329f1aee630ab', text: this.browseLabel, type: this.disabled ? 'disabled' : 'secondary', clickAction: this.openFileDialog })), this.currentFile && (h("div", { key: 'f6a788d77dd8d6f725ee0c6fde06ee3dbbadd77b', class: "drag-drop-card__file-info" }, "File Selected: ", this.currentFile.name))), h("input", { key: 'c514f68ceea5a5c6fd51e9bbe2098d100c6a9870', id: "drag-drop-file-select", type: "file", disabled: this.disabled, accept: this.accepts, class: "drag-drop-input-hidden", ref: (el) => (this.fileInputEl = el), onChange: this.onFileSelect })));
|
|
101
|
+
}
|
|
102
|
+
static get style() { return xplorDragAndDropInputCss; }
|
|
103
|
+
}, [2, "xplor-drag-and-drop-input", {
|
|
104
|
+
"disabled": [4],
|
|
105
|
+
"accepts": [1],
|
|
106
|
+
"label": [1],
|
|
107
|
+
"browseLabel": [1, "browse-label"],
|
|
108
|
+
"dragover": [32],
|
|
109
|
+
"currentFile": [32],
|
|
110
|
+
"clearCurrentFile": [64]
|
|
111
|
+
}]);
|
|
112
|
+
function defineCustomElement$1() {
|
|
113
|
+
if (typeof customElements === "undefined") {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
const components = ["xplor-drag-and-drop-input", "xplor-button"];
|
|
117
|
+
components.forEach(tagName => { switch (tagName) {
|
|
118
|
+
case "xplor-drag-and-drop-input":
|
|
119
|
+
if (!customElements.get(tagName)) {
|
|
120
|
+
customElements.define(tagName, XplorDragAndDropInput$1);
|
|
121
|
+
}
|
|
122
|
+
break;
|
|
123
|
+
case "xplor-button":
|
|
124
|
+
if (!customElements.get(tagName)) {
|
|
125
|
+
defineCustomElement$2();
|
|
126
|
+
}
|
|
127
|
+
break;
|
|
128
|
+
} });
|
|
129
|
+
}
|
|
130
|
+
defineCustomElement$1();
|
|
131
|
+
|
|
132
|
+
const XplorDragAndDropInput = XplorDragAndDropInput$1;
|
|
133
|
+
const defineCustomElement = defineCustomElement$1;
|
|
134
|
+
|
|
135
|
+
export { XplorDragAndDropInput, defineCustomElement };
|
|
136
|
+
//# sourceMappingURL=xplor-drag-and-drop-input.js.map
|
|
137
|
+
|
|
138
|
+
//# sourceMappingURL=xplor-drag-and-drop-input.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"xplor-drag-and-drop-input.js","mappings":"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","names":["XplorDragAndDropInput","__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/xplor-drag-and-drop-input/xplor-drag-and-drop-input.scss?tag=xplor-drag-and-drop-input&encapsulation=scoped","src/components/xplor-drag-and-drop-input/xplor-drag-and-drop-input.tsx"],"sourcesContent":["@use '../../styles/colours.scss' as colours;\n@use '../../styles/spacing.scss' as spacing;\n\n:host {\n display: block;\n}\n\n.drag-drop-wrapper {\n position: relative;\n padding-bottom: spacing.$spacing-40;\n}\n\n.drag-drop-input-hidden {\n display: none;\n}\n\n.drag-drop-card {\n background-color: colours.$secondary-50;\n border-radius: 8px;\n border: 3px dashed colours.$gray-300;\n min-height: 240px;\n padding: spacing.$spacing-16 spacing.$spacing-24 spacing.$spacing-40;\n text-align: center;\n transition: all 0.2s ease;\n cursor: default;\n\n &:hover:not(&--disabled) {\n border-color: colours.$secondary;\n }\n\n &--dragover {\n border: 3px dashed colours.$secondary;\n background-color: colours.$secondary-100;\n }\n\n &--disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n}\n\n.drag-drop-card__content {\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: spacing.$spacing-16;\n padding: spacing.$spacing-8 0 0;\n}\n\n.drag-drop-card__icon {\n color: colours.$secondary;\n width: 68px;\n height: 68px;\n}\n\n.drag-drop-card__title {\n color: colours.$black;\n font-family: Inter, sans-serif;\n font-size: 24px;\n font-weight: 700;\n line-height: 32px;\n letter-spacing: 0;\n margin: 0;\n}\n\n.drag-drop-card__accepts,\n.drag-drop-card__divider {\n color: colours.$black;\n font-family: Inter, sans-serif;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n margin: 0;\n}\n\n.drag-drop-card__action {\n position: absolute;\n left: 50%;\n bottom: 0;\n transform: translateX(-50%);\n}\n\n.drag-drop-card__file-info {\n margin-top: spacing.$spacing-16;\n color: colours.$gray-700;\n font-family: Inter, sans-serif;\n font-size: 14px;\n font-weight: 400;\n line-height: 20px;\n padding: spacing.$spacing-4;\n text-align: center;\n}\n\n@media (max-width: 768px) {\n .drag-drop-card {\n min-height: 200px;\n }\n\n .drag-drop-card__title {\n font-size: 20px;\n line-height: 28px;\n }\n\n .drag-drop-card__accepts,\n .drag-drop-card__divider {\n font-size: 13px;\n line-height: 18px;\n }\n}\n","import { Component, Host, h, Prop, State, Event, EventEmitter, Method } from '@stencil/core';\n\nconst DEFAULT_ACCEPT_ALL = '*' + '/' + '*';\n\n@Component({\n tag: 'xplor-drag-and-drop-input',\n styleUrl: 'xplor-drag-and-drop-input.scss',\n scoped: true,\n})\nexport class XplorDragAndDropInput {\n /**\n * Disable the file upload\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Accepted file types (e.g., 'image/png,.pdf')\n */\n @Prop() accepts: string = DEFAULT_ACCEPT_ALL;\n\n /**\n * Instruction text displayed in the drop zone\n */\n @Prop() label: string = 'Drag and drop your file here';\n\n /**\n * Browse button label text\n */\n @Prop() browseLabel: string = 'Browse Files';\n\n @State() dragover: boolean = false;\n @State() currentFile: File | null = null;\n\n /**\n * Emitted when a file is selected via drop or click\n */\n @Event() fileSelect: EventEmitter<File>;\n\n /**\n * Emitted when the current file is cleared\n */\n @Event() fileClear: EventEmitter<void>;\n\n private fileInputEl: HTMLInputElement;\n\n /**\n * Clears the currently selected file\n */\n @Method()\n async clearCurrentFile() {\n this.currentFile = null;\n if (this.fileInputEl) {\n this.fileInputEl.value = '';\n }\n this.fileClear.emit();\n }\n\n private onDrop = (e: DragEvent) => {\n e.preventDefault();\n this.dragover = false;\n\n if (this.disabled) return;\n\n const file = e.dataTransfer?.files?.[0];\n if (file) {\n this.currentFile = file;\n this.fileSelect.emit(this.currentFile);\n }\n };\n\n private onDragOver = (e: DragEvent) => {\n e.preventDefault();\n if (!this.disabled) {\n this.dragover = true;\n }\n };\n\n private onDragEnter = (e: DragEvent) => {\n e.preventDefault();\n if (!this.disabled) {\n this.dragover = true;\n }\n };\n\n private onDragLeave = (e: DragEvent) => {\n e.preventDefault();\n this.dragover = false;\n };\n\n private onFileSelect = (e: Event) => {\n const input = e.target as HTMLInputElement;\n const file = input.files?.[0];\n if (file) {\n this.currentFile = file;\n this.fileSelect.emit(this.currentFile);\n }\n input.value = '';\n };\n\n private openFileDialog = () => {\n if (this.disabled) {\n return;\n }\n\n this.fileInputEl?.click();\n };\n\n private getAcceptsLabel = () => {\n const accepts = this.accepts?.trim();\n if (!accepts || accepts === DEFAULT_ACCEPT_ALL) {\n return '*';\n }\n\n return accepts;\n };\n\n render() {\n return (\n <Host>\n <div class=\"drag-drop-wrapper\">\n <div\n class={{\n 'drag-drop-card': true,\n 'drag-drop-card--dragover': this.dragover,\n 'drag-drop-card--disabled': this.disabled,\n }}\n onDrop={this.onDrop}\n onDragOver={this.onDragOver}\n onDragEnter={this.onDragEnter}\n onDragLeave={this.onDragLeave}\n >\n <div class=\"drag-drop-card__content\">\n <svg\n class=\"drag-drop-card__icon\"\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"60\"\n height=\"60\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n >\n <path\n d=\"M19.35 10.04C18.67 6.59 15.64 4 12 4C9.11 4 6.6 5.64 5.35 8.04C2.34 8.36 0 10.91 0 14C0 17.31 2.69 20 6 20H19C21.76 20 24 17.76 24 15C24 12.36 21.95 10.22 19.35 10.04Z\"\n fill=\"currentColor\"\n opacity=\"0.3\"\n />\n <path\n d=\"M19.35 10.04C18.67 6.59 15.64 4 12 4C9.11 4 6.6 5.64 5.35 8.04C2.34 8.36 0 10.91 0 14C0 17.31 2.69 20 6 20H19C21.76 20 24 17.76 24 15C24 12.36 21.95 10.22 19.35 10.04ZM14 13V17H10V13H7L12 8L17 13H14Z\"\n fill=\"currentColor\"\n />\n </svg>\n <h3 class=\"drag-drop-card__title\">{this.label}</h3>\n <p class=\"drag-drop-card__accepts\">Accepted file types: {this.getAcceptsLabel()}</p>\n <p class=\"drag-drop-card__divider\">or</p>\n </div>\n </div>\n\n <div class=\"drag-drop-card__action\">\n <xplor-button\n text={this.browseLabel}\n type={this.disabled ? 'disabled' : 'secondary'}\n clickAction={this.openFileDialog}\n ></xplor-button>\n </div>\n\n {this.currentFile && (\n <div class=\"drag-drop-card__file-info\">\n File Selected: {this.currentFile.name}\n </div>\n )}\n </div>\n\n <input\n id=\"drag-drop-file-select\"\n type=\"file\"\n disabled={this.disabled}\n accept={this.accepts}\n class=\"drag-drop-input-hidden\"\n ref={(el) => (this.fileInputEl = el)}\n onChange={this.onFileSelect}\n />\n </Host>\n );\n }\n}\n"],"version":3}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Components, JSX } from "../types/components";
|
|
2
|
+
|
|
3
|
+
interface XplorDropdown extends Components.XplorDropdown, HTMLElement {}
|
|
4
|
+
export const XplorDropdown: {
|
|
5
|
+
prototype: XplorDropdown;
|
|
6
|
+
new (): XplorDropdown;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Used to define this component and all nested components recursively.
|
|
10
|
+
*/
|
|
11
|
+
export const defineCustomElement: () => void;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { X as XplorDropdown$1, d as defineCustomElement$1 } from './p-CJGP2_5k.js';
|
|
2
|
+
|
|
3
|
+
const XplorDropdown = XplorDropdown$1;
|
|
4
|
+
const defineCustomElement = defineCustomElement$1;
|
|
5
|
+
|
|
6
|
+
export { XplorDropdown, defineCustomElement };
|
|
7
|
+
//# sourceMappingURL=xplor-dropdown.js.map
|
|
8
|
+
|
|
9
|
+
//# sourceMappingURL=xplor-dropdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"xplor-dropdown.js","mappings":";;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Components, JSX } from "../types/components";
|
|
2
|
+
|
|
3
|
+
interface XplorExpansionPanel extends Components.XplorExpansionPanel, HTMLElement {}
|
|
4
|
+
export const XplorExpansionPanel: {
|
|
5
|
+
prototype: XplorExpansionPanel;
|
|
6
|
+
new (): XplorExpansionPanel;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Used to define this component and all nested components recursively.
|
|
10
|
+
*/
|
|
11
|
+
export const defineCustomElement: () => void;
|