@vonage/vivid 5.15.1 → 5.17.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/accordion/definition.cjs +7 -207
- package/accordion/definition.js +2 -199
- package/accordion/index.cjs +4 -4
- package/accordion/index.js +93 -127
- package/accordion-item/definition.cjs +6 -146
- package/accordion-item/definition.js +2 -139
- package/accordion-item/index.cjs +1 -1
- package/accordion-item/index.js +6 -2
- package/action-group/definition.cjs +5 -69
- package/action-group/definition.js +1 -62
- package/action-group/index.cjs +4 -4
- package/action-group/index.js +16 -46
- package/alert/definition.cjs +6 -201
- package/alert/definition.js +2 -194
- package/alert/index.cjs +15 -15
- package/alert/index.js +90 -136
- package/audio-player/definition.cjs +6 -459
- package/audio-player/definition.js +2 -452
- package/audio-player/index.cjs +49 -49
- package/audio-player/index.js +234 -302
- package/avatar/definition.cjs +6 -117
- package/avatar/definition.js +2 -110
- package/avatar/index.cjs +14 -14
- package/avatar/index.js +44 -84
- package/badge/definition.cjs +6 -85
- package/badge/definition.js +2 -78
- package/badge/index.cjs +4 -4
- package/badge/index.js +21 -65
- package/banner/definition.cjs +6 -160
- package/banner/definition.js +2 -153
- package/banner/index.cjs +13 -13
- package/banner/index.js +76 -109
- package/breadcrumb/definition.cjs +5 -97
- package/breadcrumb/definition.js +1 -90
- package/breadcrumb/index.cjs +4 -4
- package/breadcrumb/index.js +33 -59
- package/breadcrumb-item/definition.cjs +7 -47
- package/breadcrumb-item/definition.js +3 -40
- package/breadcrumb-item/index.cjs +5 -5
- package/breadcrumb-item/index.js +20 -32
- package/bundled/affix.cjs +10 -10
- package/bundled/affix.js +44 -57
- package/bundled/anchored.cjs +3 -3
- package/bundled/anchored.js +47 -65
- package/bundled/aria.cjs +1 -1
- package/bundled/aria.js +6 -6
- package/bundled/attribute-binding-behaviour.cjs +1 -1
- package/bundled/attribute-binding-behaviour.js +17 -28
- package/bundled/base-color-picker.cjs +10 -10
- package/bundled/base-color-picker.js +115 -197
- package/bundled/base-progress.cjs +1 -1
- package/bundled/base-progress.js +29 -56
- package/bundled/breadcrumb-item.cjs +1 -1
- package/bundled/breadcrumb-item.js +11 -20
- package/bundled/button.cjs +1 -1
- package/bundled/button.js +65 -100
- package/bundled/calendar-event.cjs +1 -1
- package/bundled/calendar-event.js +11 -34
- package/bundled/calendar-picker.template.cjs +77 -77
- package/bundled/calendar-picker.template.js +2883 -3347
- package/bundled/char-count.cjs +7 -7
- package/bundled/char-count.js +31 -46
- package/bundled/children.cjs +1 -1
- package/bundled/children.js +27 -45
- package/bundled/class-names.cjs +1 -1
- package/bundled/class-names.js +8 -8
- package/bundled/data-grid.options.cjs +1 -1
- package/bundled/data-grid.options.js +22 -26
- package/bundled/decorate.cjs +1 -0
- package/bundled/decorate.js +9 -0
- package/bundled/definition.cjs +1 -39
- package/bundled/definition.js +5 -122
- package/bundled/definition10.cjs +18 -72
- package/bundled/definition10.js +74 -355
- package/bundled/definition11.cjs +10 -12
- package/bundled/definition11.js +28 -92
- package/bundled/definition12.cjs +72 -18
- package/bundled/definition12.js +192 -222
- package/bundled/definition13.cjs +20 -10
- package/bundled/definition13.js +55 -41
- package/bundled/definition14.cjs +5 -1
- package/bundled/definition14.js +11 -20
- package/bundled/definition15.cjs +19 -5
- package/bundled/definition15.js +77 -28
- package/bundled/definition16.cjs +12 -29
- package/bundled/definition16.js +80 -78
- package/bundled/definition17.cjs +17 -17
- package/bundled/definition17.js +126 -98
- package/bundled/definition18.cjs +87 -13
- package/bundled/definition18.js +423 -134
- package/bundled/definition19.cjs +5 -87
- package/bundled/definition19.js +16 -742
- package/bundled/definition2.cjs +8 -8
- package/bundled/definition2.js +79 -122
- package/bundled/definition20.cjs +26 -16
- package/bundled/definition20.js +153 -98
- package/bundled/definition21.cjs +29 -5
- package/bundled/definition21.js +174 -18
- package/bundled/definition22.cjs +38 -23
- package/bundled/definition22.js +70 -149
- package/bundled/definition3.cjs +1 -29
- package/bundled/definition3.js +183 -194
- package/bundled/definition4.cjs +24 -6
- package/bundled/definition4.js +88 -40
- package/bundled/definition5.cjs +30 -1
- package/bundled/definition5.js +48 -346
- package/bundled/definition6.cjs +28 -30
- package/bundled/definition6.js +110 -264
- package/bundled/definition7.cjs +6 -30
- package/bundled/definition7.js +22 -288
- package/bundled/definition8.cjs +13 -18
- package/bundled/definition8.js +150 -132
- package/bundled/definition9.cjs +12 -14
- package/bundled/definition9.js +67 -235
- package/bundled/delegates-aria.cjs +1 -1
- package/bundled/delegates-aria.js +56 -88
- package/bundled/dialog.cjs +1 -0
- package/bundled/dialog.js +6 -0
- package/bundled/divider.cjs +1 -1
- package/bundled/divider.js +16 -33
- package/bundled/dom.cjs +1 -1
- package/bundled/dom.js +5 -5
- package/bundled/enums.cjs +1 -1
- package/bundled/enums.js +16 -9
- package/bundled/floating-ui.dom.cjs +1 -1
- package/bundled/floating-ui.dom.js +953 -1238
- package/bundled/form-associated.cjs +1 -1
- package/bundled/form-associated.js +165 -318
- package/bundled/form-element.cjs +1 -1
- package/bundled/form-element.js +33 -55
- package/bundled/host-semantics.cjs +1 -1
- package/bundled/host-semantics.js +46 -69
- package/bundled/key-codes.cjs +1 -1
- package/bundled/key-codes.js +4 -16
- package/bundled/linkable.cjs +6 -6
- package/bundled/linkable.js +25 -45
- package/bundled/listbox.cjs +1 -1
- package/bundled/listbox.js +176 -351
- package/bundled/localized.cjs +1 -1
- package/bundled/localized.js +451 -564
- package/bundled/mixins.cjs +20 -20
- package/bundled/mixins.js +162 -210
- package/bundled/normalize.cjs +1 -1
- package/bundled/normalize.js +6 -6
- package/bundled/numbers.cjs +1 -1
- package/bundled/numbers.js +9 -11
- package/bundled/picker-field.template.cjs +23 -23
- package/bundled/picker-field.template.js +108 -171
- package/bundled/playbackRates.cjs +1 -1
- package/bundled/playbackRates.js +10 -10
- package/bundled/ref.cjs +1 -1
- package/bundled/ref.js +10 -14
- package/bundled/repeat.cjs +1 -1
- package/bundled/repeat.js +421 -552
- package/bundled/scrollIntoView.cjs +1 -1
- package/bundled/scrollIntoView.js +26 -29
- package/bundled/single-date-picker.cjs +1 -1
- package/bundled/single-date-picker.js +23 -38
- package/bundled/single-value-picker.cjs +1 -1
- package/bundled/single-value-picker.js +58 -86
- package/bundled/slider.template.cjs +14 -14
- package/bundled/slider.template.js +67 -78
- package/bundled/slottable-request.cjs +4 -4
- package/bundled/slottable-request.js +1907 -2904
- package/bundled/slotted.cjs +1 -1
- package/bundled/slotted.js +47 -97
- package/bundled/strings.cjs +1 -1
- package/bundled/strings.js +6 -6
- package/bundled/text-field.cjs +1 -1
- package/bundled/text-field.js +4 -4
- package/bundled/time-selection-picker.template.cjs +26 -26
- package/bundled/time-selection-picker.template.js +355 -552
- package/bundled/trapped-focus.cjs +1 -1
- package/bundled/trapped-focus.js +18 -25
- package/bundled/vivid-element.cjs +4 -5
- package/bundled/vivid-element.js +1781 -2806
- package/bundled/when.cjs +1 -1
- package/bundled/when.js +10 -10
- package/bundled/with-contextual-help.cjs +1 -1
- package/bundled/with-contextual-help.js +15 -31
- package/bundled/with-error-text.cjs +1 -1
- package/bundled/with-error-text.js +25 -38
- package/bundled/with-success-text.cjs +1 -1
- package/bundled/with-success-text.js +8 -15
- package/button/definition.cjs +6 -14
- package/button/definition.js +3 -4
- package/button/index.cjs +1 -1
- package/button/index.js +6 -2
- package/calendar/definition.cjs +5 -358
- package/calendar/definition.js +1 -351
- package/calendar/index.cjs +20 -20
- package/calendar/index.js +165 -427
- package/calendar-event/definition.cjs +6 -58
- package/calendar-event/definition.js +2 -51
- package/calendar-event/index.cjs +7 -7
- package/calendar-event/index.js +25 -41
- package/card/definition.cjs +6 -194
- package/card/definition.js +2 -187
- package/card/index.cjs +37 -34
- package/card/index.js +83 -133
- package/checkbox/definition.cjs +6 -209
- package/checkbox/definition.js +2 -202
- package/checkbox/index.cjs +1 -1
- package/checkbox/index.js +6 -2
- package/color-picker/definition.cjs +6 -1175
- package/color-picker/definition.js +2 -1168
- package/color-picker/index.cjs +94 -94
- package/color-picker/index.js +605 -737
- package/combobox/definition.cjs +6 -647
- package/combobox/definition.js +2 -640
- package/combobox/index.cjs +38 -37
- package/combobox/index.js +258 -458
- package/contextual-help/definition.cjs +6 -63
- package/contextual-help/definition.js +2 -56
- package/contextual-help/index.cjs +1 -1
- package/contextual-help/index.js +6 -2
- package/country/definition.cjs +6 -340
- package/country/definition.js +2 -333
- package/country/index.cjs +6 -6
- package/country/index.js +1209 -308
- package/custom-elements.json +1247 -1173
- package/data-grid/definition.cjs +10 -2350
- package/data-grid/definition.js +2 -2339
- package/data-grid/index.cjs +65 -65
- package/data-grid/index.js +644 -997
- package/date-picker/definition.cjs +6 -152
- package/date-picker/definition.js +2 -145
- package/date-picker/index.cjs +1 -1
- package/date-picker/index.js +66 -114
- package/date-range-picker/definition.cjs +6 -467
- package/date-range-picker/definition.js +2 -460
- package/date-range-picker/index.cjs +1 -1
- package/date-range-picker/index.js +218 -334
- package/date-time-picker/definition.cjs +6 -285
- package/date-time-picker/definition.js +2 -278
- package/date-time-picker/index.cjs +4 -4
- package/date-time-picker/index.js +116 -211
- package/dial-pad/definition.cjs +6 -460
- package/dial-pad/definition.js +2 -453
- package/dial-pad/index.cjs +44 -43
- package/dial-pad/index.js +197 -288
- package/dialog/definition.cjs +6 -349
- package/dialog/definition.js +2 -342
- package/dialog/index.cjs +28 -28
- package/dialog/index.js +148 -229
- package/divider/definition.cjs +6 -42
- package/divider/definition.js +2 -35
- package/divider/index.cjs +1 -1
- package/divider/index.js +5 -2
- package/elevation/definition.cjs +4 -11
- package/elevation/definition.js +2 -2
- package/elevation/index.cjs +1 -1
- package/elevation/index.js +5 -2
- package/empty-state/definition.cjs +6 -86
- package/empty-state/definition.js +2 -79
- package/empty-state/index.cjs +9 -9
- package/empty-state/index.js +28 -60
- package/fab/definition.cjs +6 -105
- package/fab/definition.js +2 -98
- package/fab/index.cjs +17 -17
- package/fab/index.js +46 -81
- package/file-picker/definition.cjs +6 -523
- package/file-picker/definition.js +2 -516
- package/file-picker/index.cjs +32 -29
- package/file-picker/index.js +254 -356
- package/header/definition.cjs +5 -78
- package/header/definition.js +1 -71
- package/header/index.cjs +6 -6
- package/header/index.js +28 -42
- package/icon/definition.cjs +5 -202
- package/icon/definition.js +1 -195
- package/icon/index.cjs +1 -1
- package/icon/index.js +5 -2
- package/index.cjs +353 -356
- package/index.js +79 -78
- package/layout/definition.cjs +5 -72
- package/layout/definition.js +1 -65
- package/layout/index.cjs +2 -2
- package/layout/index.js +10 -51
- package/lib/alert/alert.d.ts +0 -1
- package/lib/audio-player/audio-player.d.ts +0 -1
- package/lib/banner/banner.d.ts +0 -2
- package/lib/button/button.d.ts +0 -1
- package/lib/calendar/calendar.d.ts +0 -1
- package/lib/combobox/combobox.d.ts +0 -3
- package/lib/data-grid/data-grid-cell.d.ts +0 -3
- package/lib/data-grid/data-grid-row.d.ts +0 -3
- package/lib/data-grid/data-grid.d.ts +0 -1
- package/lib/date-time-picker/date-time-picker.d.ts +0 -4
- package/lib/dial-pad/dial-pad.d.ts +6 -2
- package/lib/dialog/dialog.d.ts +0 -1
- package/lib/fab/fab.d.ts +0 -1
- package/lib/file-picker/file-picker.d.ts +1 -1
- package/lib/icon/icon.d.ts +0 -1
- package/lib/menu/menu.d.ts +0 -1
- package/lib/option/option.d.ts +4 -1
- package/lib/pagination/pagination.d.ts +0 -4
- package/lib/popover/popover.d.ts +0 -5
- package/lib/rich-text-editor/rte/exports.d.ts +1 -0
- package/lib/rich-text-editor/rte/features/alignment.d.ts +1 -1
- package/lib/rich-text-editor/rte/features/character-count.d.ts +21 -0
- package/lib/rich-text-editor/rte/features/font-size-picker.d.ts +1 -1
- package/lib/rich-text-editor/rte/features/internal/basic-text-blocks.d.ts +1 -1
- package/lib/rich-text-editor/rte/features/keyboard-shortcuts.d.ts +1 -1
- package/lib/rich-text-editor/rte/features/text-color-picker.d.ts +1 -1
- package/lib/rich-text-editor/rte/public-interface.d.ts +6 -0
- package/lib/searchable-select/option-tag.d.ts +0 -1
- package/lib/split-button/split-button.d.ts +0 -2
- package/lib/tab/tab.d.ts +0 -2
- package/lib/table/definition.d.ts +2 -1
- package/lib/table/table-header-cell.d.ts +3 -0
- package/lib/table/table-sorting-button.d.ts +415 -0
- package/lib/table/table-sorting-button.template.d.ts +3 -0
- package/lib/tag/tag.d.ts +0 -2
- package/lib/toggletip/toggletip.d.ts +0 -1
- package/lib/tree-item/tree-item.d.ts +0 -2
- package/lib/tree-view/tree-view.d.ts +0 -1
- package/locales/de-DE.cjs +266 -550
- package/locales/de-DE.js +264 -548
- package/locales/en-GB.cjs +266 -382
- package/locales/en-GB.js +264 -380
- package/locales/en-US.cjs +266 -550
- package/locales/en-US.js +264 -548
- package/locales/ja-JP.cjs +266 -549
- package/locales/ja-JP.js +264 -547
- package/locales/zh-CN.cjs +266 -551
- package/locales/zh-CN.js +264 -549
- package/menu/definition.cjs +6 -393
- package/menu/definition.js +2 -386
- package/menu/index.cjs +1 -1
- package/menu/index.js +6 -2
- package/menu-item/definition.cjs +7 -14
- package/menu-item/definition.js +3 -3
- package/menu-item/index.cjs +1 -1
- package/menu-item/index.js +6 -2
- package/nav/definition.cjs +5 -27
- package/nav/definition.js +1 -20
- package/nav/index.cjs +3 -3
- package/nav/index.js +7 -10
- package/nav-disclosure/definition.cjs +6 -122
- package/nav-disclosure/definition.js +2 -115
- package/nav-disclosure/index.cjs +8 -8
- package/nav-disclosure/index.js +49 -86
- package/nav-item/definition.cjs +6 -79
- package/nav-item/definition.js +2 -72
- package/nav-item/index.cjs +2 -2
- package/nav-item/index.js +33 -58
- package/note/definition.cjs +6 -61
- package/note/definition.js +2 -54
- package/note/index.cjs +5 -5
- package/note/index.js +24 -38
- package/number-field/definition.cjs +6 -440
- package/number-field/definition.js +2 -433
- package/number-field/index.cjs +31 -31
- package/number-field/index.js +160 -328
- package/option/definition.cjs +6 -13
- package/option/definition.js +3 -3
- package/option/index.cjs +1 -1
- package/option/index.js +6 -2
- package/package.json +15 -17
- package/pagination/definition.cjs +6 -254
- package/pagination/definition.js +2 -247
- package/pagination/index.cjs +37 -37
- package/pagination/index.js +148 -186
- package/popover/definition.cjs +6 -356
- package/popover/definition.js +2 -349
- package/popover/index.cjs +16 -16
- package/popover/index.js +161 -239
- package/popup/definition.cjs +5 -13
- package/popup/definition.js +3 -4
- package/popup/index.cjs +1 -1
- package/popup/index.js +6 -2
- package/progress/definition.cjs +5 -87
- package/progress/definition.js +1 -80
- package/progress/index.cjs +9 -9
- package/progress/index.js +33 -55
- package/progress-ring/definition.cjs +5 -95
- package/progress-ring/definition.js +1 -88
- package/progress-ring/index.cjs +1 -1
- package/progress-ring/index.js +5 -2
- package/radio/definition.cjs +5 -227
- package/radio/definition.js +1 -220
- package/radio/index.cjs +1 -1
- package/radio/index.js +5 -2
- package/radio-group/definition.cjs +6 -361
- package/radio-group/definition.js +2 -354
- package/radio-group/index.cjs +10 -10
- package/radio-group/index.js +160 -242
- package/range-slider/definition.cjs +6 -632
- package/range-slider/definition.js +2 -625
- package/range-slider/index.cjs +41 -41
- package/range-slider/index.js +259 -429
- package/rich-text-editor/definition.cjs +33 -15694
- package/rich-text-editor/definition.js +3 -15662
- package/rich-text-editor/index.cjs +18 -18
- package/rich-text-editor/index.js +9129 -11475
- package/rich-text-view/definition.cjs +5 -171
- package/rich-text-view/definition.js +1 -164
- package/rich-text-view/index.cjs +1 -1
- package/rich-text-view/index.js +68 -102
- package/searchable-select/definition.cjs +5 -1401
- package/searchable-select/definition.js +2 -1395
- package/searchable-select/index.cjs +94 -94
- package/searchable-select/index.js +600 -1015
- package/select/definition.cjs +6 -1002
- package/select/definition.js +2 -995
- package/select/index.cjs +1 -1
- package/select/index.js +6 -2
- package/selectable-box/definition.cjs +6 -174
- package/selectable-box/definition.js +2 -167
- package/selectable-box/index.cjs +18 -18
- package/selectable-box/index.js +66 -127
- package/shared/foundation/test-utilities/fixture.d.ts +1 -1
- package/shared/patterns/linkable.d.ts +1 -1
- package/side-drawer/definition.cjs +5 -130
- package/side-drawer/definition.js +1 -123
- package/side-drawer/index.cjs +7 -7
- package/side-drawer/index.js +47 -89
- package/simple-color-picker/definition.cjs +6 -225
- package/simple-color-picker/definition.js +2 -218
- package/simple-color-picker/index.cjs +15 -15
- package/simple-color-picker/index.js +98 -135
- package/slider/definition.cjs +6 -499
- package/slider/definition.js +2 -492
- package/slider/index.cjs +1 -1
- package/slider/index.js +6 -2
- package/split-button/definition.cjs +6 -176
- package/split-button/definition.js +2 -169
- package/split-button/index.cjs +15 -15
- package/split-button/index.js +74 -135
- package/status/definition.cjs +6 -82
- package/status/definition.js +2 -75
- package/status/index.cjs +7 -7
- package/status/index.js +35 -52
- package/switch/definition.cjs +6 -148
- package/switch/definition.js +2 -141
- package/switch/index.cjs +8 -8
- package/switch/index.js +48 -92
- package/tab/definition.cjs +6 -127
- package/tab/definition.js +2 -120
- package/tab/index.cjs +1 -1
- package/tab/index.js +6 -2
- package/tab-panel/definition.cjs +5 -29
- package/tab-panel/definition.js +1 -22
- package/tab-panel/index.cjs +1 -1
- package/tab-panel/index.js +5 -2
- package/table/definition.cjs +18 -174
- package/table/definition.js +3 -158
- package/table/index.cjs +19 -10
- package/table/index.js +74 -82
- package/tabs/definition.cjs +7 -467
- package/tabs/definition.js +2 -459
- package/tabs/index.cjs +11 -11
- package/tabs/index.js +169 -296
- package/tag/definition.cjs +6 -176
- package/tag/definition.js +2 -169
- package/tag/index.cjs +26 -26
- package/tag/index.js +64 -125
- package/tag-group/definition.cjs +5 -40
- package/tag-group/definition.js +1 -33
- package/tag-group/index.cjs +4 -4
- package/tag-group/index.js +10 -21
- package/text-area/definition.cjs +6 -355
- package/text-area/definition.js +2 -348
- package/text-area/index.cjs +11 -11
- package/text-area/index.js +153 -260
- package/text-field/definition.cjs +6 -423
- package/text-field/definition.js +2 -416
- package/text-field/index.cjs +1 -1
- package/text-field/index.js +6 -2
- package/time-picker/definition.cjs +7 -43
- package/time-picker/definition.js +3 -36
- package/time-picker/index.cjs +1 -1
- package/time-picker/index.js +24 -29
- package/toggletip/definition.cjs +6 -159
- package/toggletip/definition.js +2 -152
- package/toggletip/index.cjs +1 -1
- package/toggletip/index.js +6 -2
- package/tooltip/definition.cjs +6 -139
- package/tooltip/definition.js +2 -132
- package/tooltip/index.cjs +1 -1
- package/tooltip/index.js +6 -2
- package/tree-item/definition.cjs +6 -13
- package/tree-item/definition.js +3 -3
- package/tree-item/index.cjs +1 -1
- package/tree-item/index.js +6 -2
- package/tree-view/definition.cjs +6 -302
- package/tree-view/definition.js +2 -295
- package/tree-view/index.cjs +11 -11
- package/tree-view/index.js +145 -174
- package/unbundled/affix.cjs +89 -62
- package/unbundled/affix.js +58 -55
- package/unbundled/anchored.cjs +87 -94
- package/unbundled/anchored.js +74 -90
- package/unbundled/attribute-binding-behaviour.cjs +37 -42
- package/unbundled/attribute-binding-behaviour.js +31 -40
- package/unbundled/base-color-picker.cjs +226 -275
- package/unbundled/base-color-picker.js +214 -272
- package/unbundled/base-progress.cjs +63 -78
- package/unbundled/base-progress.js +57 -76
- package/unbundled/breadcrumb-item.cjs +24 -28
- package/unbundled/breadcrumb-item.js +18 -26
- package/unbundled/button.cjs +115 -166
- package/unbundled/button.js +109 -164
- package/unbundled/calendar-event.cjs +28 -41
- package/unbundled/calendar-event.js +22 -39
- package/unbundled/calendar-picker.template.cjs +4967 -792
- package/unbundled/calendar-picker.template.js +4907 -781
- package/unbundled/char-count.cjs +50 -80
- package/unbundled/char-count.js +44 -78
- package/unbundled/chunk.cjs +28 -0
- package/unbundled/data-grid.options.cjs +80 -29
- package/unbundled/data-grid.options.js +51 -23
- package/unbundled/decorate.cjs +14 -0
- package/unbundled/decorate.js +9 -0
- package/unbundled/definition.cjs +42 -405
- package/unbundled/definition.js +24 -399
- package/unbundled/definition10.cjs +253 -0
- package/unbundled/definition10.js +229 -0
- package/unbundled/definition11.cjs +397 -0
- package/unbundled/definition11.js +379 -0
- package/unbundled/definition12.cjs +317 -0
- package/unbundled/definition12.js +287 -0
- package/unbundled/definition13.cjs +321 -0
- package/unbundled/definition13.js +303 -0
- package/unbundled/definition14.cjs +406 -0
- package/unbundled/definition14.js +388 -0
- package/unbundled/definition15.cjs +107 -0
- package/unbundled/definition15.js +89 -0
- package/unbundled/definition16.cjs +63 -0
- package/unbundled/definition16.js +45 -0
- package/unbundled/definition17.cjs +151 -0
- package/unbundled/definition17.js +133 -0
- package/unbundled/definition18.cjs +47 -0
- package/unbundled/definition18.js +35 -0
- package/unbundled/definition19.cjs +98 -0
- package/unbundled/definition19.js +80 -0
- package/unbundled/definition2.cjs +180 -220
- package/unbundled/definition2.js +162 -215
- package/unbundled/definition20.cjs +56 -0
- package/unbundled/definition20.js +43 -0
- package/unbundled/definition21.cjs +304 -0
- package/unbundled/definition21.js +285 -0
- package/unbundled/definition22.cjs +179 -0
- package/unbundled/definition22.js +161 -0
- package/unbundled/definition23.cjs +161 -0
- package/unbundled/definition23.js +143 -0
- package/unbundled/definition24.cjs +157 -0
- package/unbundled/definition24.js +139 -0
- package/unbundled/definition25.cjs +75 -0
- package/unbundled/definition25.js +57 -0
- package/unbundled/definition26.cjs +363 -0
- package/unbundled/definition26.js +345 -0
- package/unbundled/definition27.cjs +137 -0
- package/unbundled/definition27.js +119 -0
- package/unbundled/definition28.cjs +538 -0
- package/unbundled/definition28.js +520 -0
- package/unbundled/definition29.cjs +236 -0
- package/unbundled/definition29.js +212 -0
- package/unbundled/definition3.cjs +131 -284
- package/unbundled/definition3.js +113 -279
- package/unbundled/definition30.cjs +559 -0
- package/unbundled/definition30.js +541 -0
- package/unbundled/definition31.cjs +1265 -0
- package/unbundled/definition31.js +1247 -0
- package/unbundled/definition32.cjs +1908 -0
- package/unbundled/definition32.js +1866 -0
- package/unbundled/definition33.cjs +346 -0
- package/unbundled/definition33.js +256 -0
- package/unbundled/definition34.cjs +46 -0
- package/unbundled/definition34.js +33 -0
- package/unbundled/definition35.cjs +152 -0
- package/unbundled/definition35.js +134 -0
- package/unbundled/definition36.cjs +426 -0
- package/unbundled/definition36.js +408 -0
- package/unbundled/definition37.cjs +247 -0
- package/unbundled/definition37.js +229 -0
- package/unbundled/definition38.cjs +411 -0
- package/unbundled/definition38.js +393 -0
- package/unbundled/definition39.cjs +299 -0
- package/unbundled/definition39.js +281 -0
- package/unbundled/definition4.cjs +186 -205
- package/unbundled/definition4.js +162 -200
- package/unbundled/definition40.cjs +81 -0
- package/unbundled/definition40.js +63 -0
- package/unbundled/definition41.cjs +100 -0
- package/unbundled/definition41.js +82 -0
- package/unbundled/definition42.cjs +468 -0
- package/unbundled/definition42.js +450 -0
- package/unbundled/definition43.cjs +86 -0
- package/unbundled/definition43.js +68 -0
- package/unbundled/definition44.cjs +60 -0
- package/unbundled/definition44.js +41 -0
- package/unbundled/definition45.cjs +124 -0
- package/unbundled/definition45.js +106 -0
- package/unbundled/definition46.cjs +85 -0
- package/unbundled/definition46.js +67 -0
- package/unbundled/definition47.cjs +52 -0
- package/unbundled/definition47.js +31 -0
- package/unbundled/definition48.cjs +69 -0
- package/unbundled/definition48.js +51 -0
- package/unbundled/definition49.cjs +377 -0
- package/unbundled/definition49.js +359 -0
- package/unbundled/definition5.cjs +69 -298
- package/unbundled/definition5.js +44 -293
- package/unbundled/definition50.cjs +246 -0
- package/unbundled/definition50.js +228 -0
- package/unbundled/definition51.cjs +337 -0
- package/unbundled/definition51.js +319 -0
- package/unbundled/definition52.cjs +86 -0
- package/unbundled/definition52.js +67 -0
- package/unbundled/definition53.cjs +193 -0
- package/unbundled/definition53.js +174 -0
- package/unbundled/definition54.cjs +297 -0
- package/unbundled/definition54.js +279 -0
- package/unbundled/definition55.cjs +510 -0
- package/unbundled/definition55.js +492 -0
- package/unbundled/definition56.cjs +3659 -0
- package/unbundled/definition56.js +3478 -0
- package/unbundled/definition57.cjs +837 -0
- package/unbundled/definition57.js +819 -0
- package/unbundled/definition58.cjs +147 -0
- package/unbundled/definition58.js +129 -0
- package/unbundled/definition59.cjs +1081 -0
- package/unbundled/definition59.js +1063 -0
- package/unbundled/definition6.cjs +88 -56
- package/unbundled/definition6.js +69 -52
- package/unbundled/definition60.cjs +149 -0
- package/unbundled/definition60.js +131 -0
- package/unbundled/definition61.cjs +116 -0
- package/unbundled/definition61.js +97 -0
- package/unbundled/definition62.cjs +213 -0
- package/unbundled/definition62.js +195 -0
- package/unbundled/definition63.cjs +159 -0
- package/unbundled/definition63.js +141 -0
- package/unbundled/definition64.cjs +86 -0
- package/unbundled/definition64.js +68 -0
- package/unbundled/definition65.cjs +126 -0
- package/unbundled/definition65.js +107 -0
- package/unbundled/definition66.cjs +49 -0
- package/unbundled/definition66.js +28 -0
- package/unbundled/definition67.cjs +119 -0
- package/unbundled/definition67.js +101 -0
- package/unbundled/definition68.cjs +374 -0
- package/unbundled/definition68.js +349 -0
- package/unbundled/definition69.cjs +57 -0
- package/unbundled/definition69.js +38 -0
- package/unbundled/definition7.cjs +190 -0
- package/unbundled/definition7.js +166 -0
- package/unbundled/definition70.cjs +155 -0
- package/unbundled/definition70.js +137 -0
- package/unbundled/definition71.cjs +302 -0
- package/unbundled/definition71.js +284 -0
- package/unbundled/definition72.cjs +48 -0
- package/unbundled/definition72.js +37 -0
- package/unbundled/definition73.cjs +171 -0
- package/unbundled/definition73.js +147 -0
- package/unbundled/definition74.cjs +232 -0
- package/unbundled/definition74.js +213 -0
- package/unbundled/definition75.cjs +533 -0
- package/unbundled/definition75.js +513 -0
- package/unbundled/definition8.cjs +63 -0
- package/unbundled/definition8.js +44 -0
- package/unbundled/definition9.cjs +183 -0
- package/unbundled/definition9.js +165 -0
- package/unbundled/delegates-aria.cjs +90 -131
- package/unbundled/delegates-aria.js +77 -127
- package/unbundled/dialog.cjs +15 -0
- package/unbundled/dialog.js +10 -0
- package/unbundled/divider.cjs +42 -50
- package/unbundled/divider.js +30 -47
- package/unbundled/enums.cjs +166 -107
- package/unbundled/enums.js +95 -94
- package/unbundled/form-associated.cjs +408 -463
- package/unbundled/form-associated.js +396 -460
- package/unbundled/form-element.cjs +74 -83
- package/unbundled/form-element.js +68 -81
- package/unbundled/host-semantics.cjs +70 -89
- package/unbundled/host-semantics.js +57 -85
- package/unbundled/key-codes.cjs +16 -10
- package/unbundled/key-codes.js +5 -7
- package/unbundled/linkable.cjs +35 -56
- package/unbundled/linkable.js +27 -52
- package/unbundled/listbox.cjs +363 -465
- package/unbundled/listbox.js +357 -463
- package/unbundled/localized.cjs +79 -74
- package/unbundled/localized.js +61 -70
- package/unbundled/mixins.cjs +222 -223
- package/unbundled/mixins.js +186 -211
- package/unbundled/picker-field.template.cjs +188 -217
- package/unbundled/picker-field.template.js +165 -208
- package/unbundled/playbackRates.cjs +18 -11
- package/unbundled/playbackRates.js +13 -9
- package/unbundled/scrollIntoView.cjs +38 -43
- package/unbundled/scrollIntoView.js +33 -41
- package/unbundled/single-date-picker.cjs +48 -45
- package/unbundled/single-date-picker.js +43 -43
- package/unbundled/single-value-picker.cjs +106 -114
- package/unbundled/single-value-picker.js +101 -112
- package/unbundled/slider.template.cjs +107 -73
- package/unbundled/slider.template.js +67 -62
- package/unbundled/slottable-request.cjs +145 -3700
- package/unbundled/slottable-request.js +98 -3681
- package/unbundled/text-field.cjs +9 -5
- package/unbundled/text-field.js +4 -3
- package/unbundled/time-selection-picker.template.cjs +611 -755
- package/unbundled/time-selection-picker.template.js +554 -742
- package/unbundled/trapped-focus.cjs +45 -35
- package/unbundled/trapped-focus.js +34 -32
- package/unbundled/vivid-element.cjs +281 -274
- package/unbundled/vivid-element.js +239 -266
- package/unbundled/with-contextual-help.cjs +35 -39
- package/unbundled/with-contextual-help.js +29 -37
- package/unbundled/with-error-text.cjs +45 -55
- package/unbundled/with-error-text.js +39 -53
- package/unbundled/with-success-text.cjs +18 -22
- package/unbundled/with-success-text.js +12 -20
- package/video-player/definition.cjs +5 -69835
- package/video-player/definition.js +1 -69828
- package/video-player/index.cjs +44 -39
- package/video-player/index.js +23517 -35507
- package/visually-hidden/definition.cjs +5 -30
- package/visually-hidden/definition.js +1 -23
- package/visually-hidden/index.cjs +1 -1
- package/visually-hidden/index.js +5 -2
- package/vivid.api.json +331 -1874
- package/bundled/index.cjs +0 -1
- package/bundled/index.js +0 -6
- package/unbundled/_commonjsHelpers.cjs +0 -40
- package/unbundled/_commonjsHelpers.js +0 -36
- package/unbundled/index.cjs +0 -11
- package/unbundled/index.js +0 -9
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { o as defineVividComponent, s as createRegisterFunction } from "./vivid-element.js";
|
|
2
|
+
import { t as iconDefinition } from "./definition2.js";
|
|
3
|
+
import { t as __decorate } from "./decorate.js";
|
|
4
|
+
import { a as affixIconTemplateFactory, i as IconWrapper, n as AffixIconWithTrailing } from "./affix.js";
|
|
5
|
+
import { n as delegateAria } from "./delegates-aria.js";
|
|
6
|
+
import { t as VividFoundationButton } from "./button.js";
|
|
7
|
+
import { attr, html, ref } from "@microsoft/fast-element";
|
|
8
|
+
import { classNames } from "@microsoft/fast-web-utilities";
|
|
9
|
+
//#region src/lib/fab/fab.scss?inline
|
|
10
|
+
var fab_default = ".control.connotation-accent{--_connotation-color-primary:var(--vvd-fab-accent-primary,var(--vvd-color-canvas-text));--_connotation-color-primary-text:var(--vvd-fab-accent-primary-text,var(--vvd-color-canvas));--_connotation-color-primary-increment:var(--vvd-fab-accent-primary-increment,var(--vvd-color-neutral-800));--_connotation-color-contrast:var(--vvd-fab-accent-contrast,var(--vvd-color-neutral-800));--_connotation-color-fierce:var(--vvd-fab-accent-fierce,var(--vvd-color-neutral-700));--_connotation-color-firm:var(--vvd-fab-accent-firm,var(--vvd-color-canvas-text))}.control.connotation-cta{--_connotation-color-primary:var(--vvd-fab-cta-primary,var(--vvd-color-cta-500));--_connotation-color-primary-text:var(--vvd-fab-cta-primary-text,var(--vvd-color-canvas));--_connotation-color-primary-increment:var(--vvd-fab-cta-primary-increment,var(--vvd-color-cta-600));--_connotation-color-contrast:var(--vvd-fab-cta-contrast,var(--vvd-color-cta-800));--_connotation-color-fierce:var(--vvd-fab-cta-fierce,var(--vvd-color-cta-700));--_connotation-color-firm:var(--vvd-fab-cta-firm,var(--vvd-color-cta-600))}.control.connotation-announcement{--_connotation-color-primary:var(--vvd-fab-announcement-primary,var(--vvd-color-announcement-500));--_connotation-color-primary-text:var(--vvd-fab-announcement-primary-text,var(--vvd-color-canvas));--_connotation-color-primary-increment:var(--vvd-fab-announcement-primary-increment,var(--vvd-color-announcement-600));--_connotation-color-contrast:var(--vvd-fab-announcement-contrast,var(--vvd-color-announcement-800));--_connotation-color-fierce:var(--vvd-fab-announcement-fierce,var(--vvd-color-announcement-700));--_connotation-color-firm:var(--vvd-fab-announcement-firm,var(--vvd-color-announcement-600))}.control{--_appearance-color-text:var(--_connotation-color-primary-text);--_appearance-color-fill:var(--_connotation-color-primary);--_appearance-color-outline:transparent}@media (hover:hover){.control:hover:where(:not(.disabled,:disabled,.readonly)){--_appearance-color-text:var(--_connotation-color-primary-text);--_appearance-color-fill:var(--_connotation-color-primary-increment);--_appearance-color-outline:transparent}}.control.hover:where(:not(.disabled,:disabled,.readonly)){--_appearance-color-text:var(--_connotation-color-primary-text);--_appearance-color-fill:var(--_connotation-color-primary-increment);--_appearance-color-outline:transparent}.control:disabled,.control.disabled{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:var(--vvd-color-neutral-100);--_appearance-color-outline:transparent}.control:active:where(:not(.disabled,:disabled)),.control.active:where(:not(.disabled,:disabled)){--_appearance-color-text:var(--_connotation-color-primary-text);--_appearance-color-fill:var(--_connotation-color-fierce);--_appearance-color-outline:transparent}.control{--_fab-inline-padding:12px;box-sizing:border-box;border-radius:var(--_fab-border-radius);background:var(--_appearance-color-fill,var(--_elevation-fill));block-size:var(--_fab-block-size);color:var(--_appearance-color-text,var(--vvd-color-canvas-text));align-items:center;column-gap:var(--fab-icon-gap);filter:var(--_elevation-shadow);font:var(--vvd-typography-base-bold);padding-inline:var(--_fab-inline-padding);vertical-align:middle;border:0;transition:background-color .15s linear,filter .15s linear;display:inline-flex}.control:not(.connotation-accent,.connotation-cta,.connotation-announcement){--focus-stroke-gap-color:transparent}.control:focus-visible{outline:none;position:relative}.control:focus-visible:after{box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px));border-radius:var(--focus-border-radius,inherit);block-size:calc(100% + var(--focus-block-size-addition,4px));content:\"\";inline-size:calc(100% + var(--focus-block-size-addition,4px));display:block;position:absolute;inset-block-start:50%;inset-inline-start:50%;transform:translate(-50%,-50%)}@supports (user-select:none){.control{user-select:none}}.control.size-expanded{--_fab-border-radius:40px;--_fab-block-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) + 16));--_fab-inline-padding:20px}.control.size-condensed{--_fab-border-radius:20px;--_fab-block-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8));font:var(--vvd-typography-base-condensed-bold)}.control.size-condensed vwc-icon{font-size:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8)) / 2)}.control:not(.size-expanded,.size-condensed){--_fab-border-radius:24px;--_fab-block-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2)))}.control:not(.size-condensed){font:var(--vvd-typography-base-bold)}.control.icon-only{--_fab-inline-padding:0;border-radius:50%;place-content:center}@supports (aspect-ratio:1){.control.icon-only{aspect-ratio:1}}@supports not (aspect-ratio:1){.control.icon-only{inline-size:var(--_fab-block-size)}}.control:not(.icon-only){--fab-icon-gap:10px}.control.disabled{--_elevation-fill:var(--_vvd-tinted-color-surface-nonedp,var(--vvd-color-surface-nonedp));--_elevation-shadow:var(--_vvd-tinted-shadow-surface-nonedp,var(--vvd-shadow-surface-nonedp));cursor:not-allowed}.control:not(.disabled){--_elevation-fill:var(--_vvd-tinted-color-surface-4dp,var(--vvd-color-surface-4dp));--_elevation-shadow:var(--_vvd-tinted-shadow-surface-4dp,var(--vvd-shadow-surface-4dp));cursor:pointer}@media (hover:hover){.control:not(.disabled):hover{--_elevation-fill:var(--_vvd-tinted-color-surface-12dp,var(--vvd-color-surface-12dp));--_elevation-shadow:var(--_vvd-tinted-shadow-surface-12dp,var(--vvd-shadow-surface-12dp))}}.control:not(.disabled):active{--_elevation-fill:var(--_vvd-tinted-color-surface-24dp,var(--vvd-color-surface-24dp));--_elevation-shadow:var(--_vvd-tinted-shadow-surface-24dp,var(--vvd-shadow-surface-24dp))}slot[name=icon]{line-height:1}.icon-trailing slot[name=icon]{order:1;display:inline-block}.control.size-extended slot[name=icon]{font-size:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) + 16)) / 2.3333)}.control:not(.size-extended) slot[name=icon]{font-size:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2))) / 2)}";
|
|
11
|
+
//#endregion
|
|
12
|
+
//#region src/lib/fab/fab.ts
|
|
13
|
+
/**
|
|
14
|
+
* @public
|
|
15
|
+
* @component fab
|
|
16
|
+
* @slot icon - The preferred way to add an icon to the component.
|
|
17
|
+
* @testSelector byLabel byLabel
|
|
18
|
+
* @testAction click click #control
|
|
19
|
+
* @testRef control shadow button.control
|
|
20
|
+
*/
|
|
21
|
+
var Fab = class extends AffixIconWithTrailing(VividFoundationButton) {
|
|
22
|
+
/**
|
|
23
|
+
* Handles click events.
|
|
24
|
+
* Prevents interaction when disabled.
|
|
25
|
+
*
|
|
26
|
+
* @internal
|
|
27
|
+
*/
|
|
28
|
+
clickHandler(event) {
|
|
29
|
+
/* v8 ignore else -- @preserve */
|
|
30
|
+
if (this.disabled) {
|
|
31
|
+
event.preventDefault();
|
|
32
|
+
event.stopImmediatePropagation();
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
__decorate([attr], Fab.prototype, "connotation", void 0);
|
|
38
|
+
__decorate([attr], Fab.prototype, "size", void 0);
|
|
39
|
+
__decorate([attr], Fab.prototype, "label", void 0);
|
|
40
|
+
//#endregion
|
|
41
|
+
//#region src/lib/fab/fab.template.ts
|
|
42
|
+
var getClasses = ({ connotation, size, icon, label, iconTrailing, disabled, iconSlottedContent }) => classNames("control", [`connotation-${connotation}`, Boolean(connotation)], [`size-${size}`, Boolean(size)], ["icon-only", !label && !!(icon || iconSlottedContent?.length)], ["icon-trailing", iconTrailing], ["disabled", disabled]);
|
|
43
|
+
var FabTemplate = (context) => {
|
|
44
|
+
const affixIconTemplate = affixIconTemplateFactory(context);
|
|
45
|
+
return html`
|
|
46
|
+
<button
|
|
47
|
+
class="${getClasses} "
|
|
48
|
+
?autofocus="${(x) => x.autofocus}"
|
|
49
|
+
form="${(x) => x.formId}"
|
|
50
|
+
formaction="${(x) => x.formaction}"
|
|
51
|
+
formenctype="${(x) => x.formenctype}"
|
|
52
|
+
formmethod="${(x) => x.formmethod}"
|
|
53
|
+
formnovalidate="${(x) => x.formnovalidate}"
|
|
54
|
+
formtarget="${(x) => x.formtarget}"
|
|
55
|
+
name="${(x) => x.name}"
|
|
56
|
+
type="${(x) => x.type}"
|
|
57
|
+
value="${(x) => x.value}"
|
|
58
|
+
${delegateAria({ ariaDisabled: (x) => x.disabled })}
|
|
59
|
+
${ref("control")}
|
|
60
|
+
@click="${(x, c) => x.clickHandler(c.event)}"
|
|
61
|
+
>
|
|
62
|
+
${(x) => affixIconTemplate(x.icon, IconWrapper.Slot)} ${(x) => x.label}
|
|
63
|
+
</button>
|
|
64
|
+
`;
|
|
65
|
+
};
|
|
66
|
+
//#endregion
|
|
67
|
+
//#region src/lib/fab/definition.ts
|
|
68
|
+
/**
|
|
69
|
+
* @internal
|
|
70
|
+
*/
|
|
71
|
+
var fabDefinition = defineVividComponent("fab", Fab, FabTemplate, [iconDefinition], {
|
|
72
|
+
styles: fab_default,
|
|
73
|
+
shadowOptions: { delegatesFocus: true }
|
|
74
|
+
});
|
|
75
|
+
/**
|
|
76
|
+
* Registers the FAB elements with the design system.
|
|
77
|
+
*
|
|
78
|
+
* @param prefix - the prefix to use for the component name
|
|
79
|
+
*/
|
|
80
|
+
var registerFab = createRegisterFunction(fabDefinition);
|
|
81
|
+
//#endregion
|
|
82
|
+
export { registerFab as n, Fab as r, fabDefinition as t };
|
|
@@ -0,0 +1,468 @@
|
|
|
1
|
+
require("./chunk.cjs");
|
|
2
|
+
const require_vivid_element = require("./vivid-element.cjs");
|
|
3
|
+
const require_definition = require("./definition2.cjs");
|
|
4
|
+
const require_decorate = require("./decorate.cjs");
|
|
5
|
+
const require_delegates_aria = require("./delegates-aria.cjs");
|
|
6
|
+
const require_form_associated = require("./form-associated.cjs");
|
|
7
|
+
const require_form_element = require("./form-element.cjs");
|
|
8
|
+
const require_with_error_text = require("./with-error-text.cjs");
|
|
9
|
+
const require_with_contextual_help = require("./with-contextual-help.cjs");
|
|
10
|
+
const require_localized = require("./localized.cjs");
|
|
11
|
+
const require_definition$1 = require("./definition7.cjs");
|
|
12
|
+
const require_mixins = require("./mixins.cjs");
|
|
13
|
+
let _microsoft_fast_element = require("@microsoft/fast-element");
|
|
14
|
+
let _microsoft_fast_web_utilities = require("@microsoft/fast-web-utilities");
|
|
15
|
+
//#region src/lib/file-picker/file-picker.scss?inline
|
|
16
|
+
var file_picker_default = ".label-wrapper{align-items:center;gap:var(--label-wrapper-gap,4px);flex-direction:row;display:flex}.label-wrapper[hidden]{display:none}.label:not(slot),.label::slotted(label){flex:0 auto}:host{max-inline-size:400px;display:block}:host([disabled]){cursor:not-allowed}.base{block-size:inherit;max-block-size:inherit;--_low-ink-color:var(--vvd-color-neutral-600);flex-direction:column;display:flex}.control-wrapper{block-size:inherit;max-block-size:inherit;flex-direction:column;gap:4px;display:flex}.control{box-sizing:border-box;border:1px dashed var(--vvd-color-neutral-400);background-color:var(--vvd-color-cta-50);color:var(--vvd-color-neutral-600);cursor:pointer;font:var(--vvd-typography-base);border-radius:8px;outline:none;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;min-block-size:52px;inline-size:100%;padding:16px;transition:all .3s;display:flex;position:relative}.control .upload-text{color:var(--vvd-color-neutral-600);isolation:isolate;pointer-events:none;text-align:center;justify-content:center;align-items:center;transition:all .3s;display:flex}.control.disabled{border-color:var(--vvd-color-neutral-300);background-color:var(--vvd-color-neutral-100);box-shadow:none;color:var(--vvd-color-neutral-300);pointer-events:none;transform:none}.control.disabled .upload-text{color:var(--vvd-color-neutral-300)}@media (hover:hover){.control:hover .upload-text{color:var(--vvd-color-neutral-800)}}.control.drag-hover .upload-text{color:var(--vvd-color-neutral-800)}.control:not(.size-expanded){min-block-size:52px}.control.size-expanded{min-block-size:120px}.control:focus-visible{--focus-stroke-gap-color:transparent;box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px))}.control:active,.control:focus-visible{border-color:var(--vvd-color-cta-400);background-color:var(--vvd-color-cta-100);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}@media (hover:hover){.control:hover{border-color:var(--vvd-color-cta-400);background-color:var(--vvd-color-cta-100);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}}.control:active{transform:translateY(0);box-shadow:0 1px 4px #0000001a}.control.drag-hover{border-color:var(--vvd-color-cta-200);background-color:var(--vvd-color-cta-200);outline:2px dashed var(--vvd-color-cta-500);transform:scale(1.02)}.upload-icon{color:var(--vvd-color-cta-600);pointer-events:none;transition:all .3s;animation:2s ease-in-out infinite subtle-pulse}@media (hover:hover){.control:hover .upload-icon{color:var(--vvd-color-cta-700);animation:none;transform:scale(1.1)}}.control:active .upload-icon{transform:scale(1.05)}.control.drag-hover .upload-icon{color:var(--vvd-color-neutral-800);animation:none;transform:scale(1.15)}.control.disabled .upload-icon{color:var(--vvd-color-neutral-300);animation:none}@keyframes subtle-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.main{pointer-events:none}.preview{box-sizing:border-box;border:1px solid var(--vvd-color-neutral-300);background-color:var(--file-picker-list-item-background-color,var(--vvd-color-canvas));border-radius:8px;grid-template-rows:auto auto;grid-template-columns:1fr auto;inline-size:100%;padding:8px;display:grid}.preview .details{min-width:0;flex-direction:column;max-inline-size:100%;display:flex}.preview .details .filename{color:var(--vvd-color-canvas-text);font:var(--vvd-typography-base);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.preview .details .size{color:var(--vvd-color-neutral-600);font:var(--vvd-typography-base-condensed)}.preview .error-message{color:var(--vvd-color-alert-600);font:var(--vvd-typography-base-condensed-bold);align-items:center;gap:4px;margin-block-start:4px;display:flex}.preview:not(.has-error) .error-message{display:none}.preview.has-error{border:1px solid var(--vvd-color-alert-500);background-color:var(--vvd-color-alert-50)}.preview.has-error .size{display:none}.preview .remove-btn{grid-area:1/2/-1/-1;align-self:center;display:inline}.preview-list{--scrollbar-track-color:transparent;--scrollbar-thumb-color:color-mix(in srgb, var(--vvd-color-neutral-950), transparent 70%);scrollbar-color:var(--scrollbar-thumb-color) var(--scrollbar-track-color);scrollbar-width:thin}.preview-list ::-webkit-scrollbar{width:4px}.preview-list ::-webkit-scrollbar-track{background:var(--scrollbar-track-color)}.preview-list ::-webkit-scrollbar-thumb{background-color:var(--scrollbar-fallback-track-color,var(--scrollbar-thumb-color));border:0;border-radius:4px}.preview-list{flex-direction:column;gap:12px;margin-block-start:12px;display:flex;overflow-y:auto}.preview-list:not(:has(.preview)){display:none}.hidden-input{visibility:hidden;width:0;height:0;position:absolute;top:0;left:0}";
|
|
17
|
+
//#endregion
|
|
18
|
+
//#region src/lib/file-picker/data-transfer.ts
|
|
19
|
+
/**
|
|
20
|
+
* Extracts files from a DataTransfer, including files from directories.
|
|
21
|
+
*/
|
|
22
|
+
async function filesFromDataTransfer(dataTransfer) {
|
|
23
|
+
return dataTransfer.items?.[0]?.webkitGetAsEntry != null ? await filesFromDataTransferItems(dataTransfer.items) : Array.from(dataTransfer.files);
|
|
24
|
+
}
|
|
25
|
+
async function filesFromDataTransferItems(items) {
|
|
26
|
+
const result = [];
|
|
27
|
+
for (const item of items) {
|
|
28
|
+
const file = item.getAsFile();
|
|
29
|
+
if (file) result.push(Promise.resolve([file]));
|
|
30
|
+
else {
|
|
31
|
+
const entry = item.webkitGetAsEntry();
|
|
32
|
+
if (entry) result.push(filesFromEntry(entry, false));
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return (await Promise.all(result)).flat();
|
|
36
|
+
}
|
|
37
|
+
var filesFromEntry = (entry, ignoreHiddenFiles) => {
|
|
38
|
+
const handleFileEntry = (file) => new Promise((resolve, reject) => {
|
|
39
|
+
file.file((f) => {
|
|
40
|
+
if (ignoreHiddenFiles && f.name.substring(0, 1) === ".") resolve([]);
|
|
41
|
+
else resolve([f]);
|
|
42
|
+
}, reject);
|
|
43
|
+
});
|
|
44
|
+
const promise = entry.isFile ? handleFileEntry(entry) : entry.isDirectory ? filesFromDirectory(entry) : Promise.resolve([]);
|
|
45
|
+
promise.catch(() => null);
|
|
46
|
+
return promise;
|
|
47
|
+
};
|
|
48
|
+
var filesFromDirectory = async (directory) => new Promise((resolve, reject) => {
|
|
49
|
+
const result = [];
|
|
50
|
+
const dirReader = directory.createReader();
|
|
51
|
+
const readEntries = () => {
|
|
52
|
+
dirReader.readEntries((entries) => {
|
|
53
|
+
for (const entry of entries) result.push(filesFromEntry(entry, true));
|
|
54
|
+
if (entries.length) readEntries();
|
|
55
|
+
else resolve(Promise.all(result).then((r) => r.flat()));
|
|
56
|
+
}, reject);
|
|
57
|
+
};
|
|
58
|
+
readEntries();
|
|
59
|
+
});
|
|
60
|
+
//#endregion
|
|
61
|
+
//#region src/lib/file-picker/accept.ts
|
|
62
|
+
/**
|
|
63
|
+
* Match a file against an accept string, like native file input
|
|
64
|
+
*/
|
|
65
|
+
function isAcceptedFileType(file, accept) {
|
|
66
|
+
if (!accept) return true;
|
|
67
|
+
const validTypes = accept.split(",");
|
|
68
|
+
const isBasePattern = (type) => /\/\*$/.test(type);
|
|
69
|
+
const baseType = (type) => type.replace(/\/.*$/, "");
|
|
70
|
+
for (let validType of validTypes) {
|
|
71
|
+
validType = validType.trim();
|
|
72
|
+
if (validType.charAt(0) === ".") {
|
|
73
|
+
if (file.name.toLowerCase().endsWith(validType.toLowerCase())) return true;
|
|
74
|
+
} else if (isBasePattern(validType)) {
|
|
75
|
+
if (baseType(file.type) === baseType(validType)) return true;
|
|
76
|
+
} else if (file.type === validType) return true;
|
|
77
|
+
}
|
|
78
|
+
return false;
|
|
79
|
+
}
|
|
80
|
+
//#endregion
|
|
81
|
+
//#region src/lib/file-picker/file-picker.ts
|
|
82
|
+
/**
|
|
83
|
+
* @public
|
|
84
|
+
* @component file-picker
|
|
85
|
+
* @slot helper-text - Describes how to use the file-picker. Alternative to the `helper-text` attribute.
|
|
86
|
+
* @event {CustomEvent<undefined>} change - Emitted when files are added or removed.
|
|
87
|
+
*/
|
|
88
|
+
var FilePicker = class extends require_with_contextual_help.WithContextualHelp(require_mixins.WithFeedback(require_with_error_text.WithErrorText(require_form_element.FormElement(require_delegates_aria.DelegatesAria(require_localized.Localized(require_form_associated.FormAssociated(require_vivid_element.VividElement))))))) {
|
|
89
|
+
constructor(..._args) {
|
|
90
|
+
super(..._args);
|
|
91
|
+
this.singleFile = false;
|
|
92
|
+
this.maxFiles = null;
|
|
93
|
+
this.maxFileSize = 256;
|
|
94
|
+
this.valueChanged = (previous, next) => {
|
|
95
|
+
super.valueChanged(previous, next);
|
|
96
|
+
if (next === "" && this.files.length) this.removeAllFiles();
|
|
97
|
+
};
|
|
98
|
+
this.proxy = document.createElement("input");
|
|
99
|
+
this.setFormValue = (value, state) => {
|
|
100
|
+
if (typeof value === "string") return;
|
|
101
|
+
super.setFormValue(value, state);
|
|
102
|
+
};
|
|
103
|
+
this._customValidationError = null;
|
|
104
|
+
this._dragHover = false;
|
|
105
|
+
this._allFiles = [];
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* @internal
|
|
109
|
+
*/
|
|
110
|
+
nameChanged(previous, next) {
|
|
111
|
+
super.nameChanged(previous, next);
|
|
112
|
+
this.#updateFormValue();
|
|
113
|
+
}
|
|
114
|
+
#updateFormValue() {
|
|
115
|
+
const files = this.files;
|
|
116
|
+
if (!this.name) this.setFormValue(null);
|
|
117
|
+
else {
|
|
118
|
+
const formData = new FormData();
|
|
119
|
+
for (const file of files) formData.append(this.name, file);
|
|
120
|
+
this.setFormValue(formData);
|
|
121
|
+
}
|
|
122
|
+
this.#setValueToAFakePathLikeNativeInput();
|
|
123
|
+
}
|
|
124
|
+
#setValueToAFakePathLikeNativeInput() {
|
|
125
|
+
this.value = this.files.length > 0 ? `C:\\fakepath\\${this.files[0].name}` : "";
|
|
126
|
+
}
|
|
127
|
+
/** @internal */
|
|
128
|
+
validate() {
|
|
129
|
+
super.validate(this.control);
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* @internal
|
|
133
|
+
*/
|
|
134
|
+
formResetCallback() {
|
|
135
|
+
this.removeAllFiles();
|
|
136
|
+
super.formResetCallback();
|
|
137
|
+
}
|
|
138
|
+
#getCustomValidationError() {
|
|
139
|
+
if (this.rejectedFiles.length > 0) return this.locale.filePicker.invalidFilesError;
|
|
140
|
+
return null;
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* @internal
|
|
144
|
+
*/
|
|
145
|
+
_customValidationErrorChanged() {
|
|
146
|
+
/* v8 ignore if -- @preserve */
|
|
147
|
+
if (this.proxy) this.proxy.setCustomValidity(this._customValidationError ?? "");
|
|
148
|
+
this.validate();
|
|
149
|
+
}
|
|
150
|
+
#customValidationChangeHandler = { handleChange: () => {
|
|
151
|
+
this._customValidationError = this.#customValidationChangeObserver.observe(this, _microsoft_fast_element.ExecutionContext.default);
|
|
152
|
+
} };
|
|
153
|
+
#customValidationChangeObserver;
|
|
154
|
+
#startObservingCustomValidation() {
|
|
155
|
+
this.#customValidationChangeObserver = _microsoft_fast_element.Observable.binding(() => this.#getCustomValidationError(), this.#customValidationChangeHandler, true);
|
|
156
|
+
this.#customValidationChangeHandler.handleChange();
|
|
157
|
+
}
|
|
158
|
+
#stopObservingCustomValidation() {
|
|
159
|
+
this.#customValidationChangeObserver.dispose();
|
|
160
|
+
}
|
|
161
|
+
connectedCallback() {
|
|
162
|
+
super.connectedCallback();
|
|
163
|
+
this.#startObservingCustomValidation();
|
|
164
|
+
}
|
|
165
|
+
disconnectedCallback() {
|
|
166
|
+
super.disconnectedCallback();
|
|
167
|
+
this.#stopObservingCustomValidation();
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* @internal
|
|
171
|
+
*/
|
|
172
|
+
_onDragEnter() {
|
|
173
|
+
if (this.disabled) return true;
|
|
174
|
+
this._dragHover = true;
|
|
175
|
+
return true;
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* @internal
|
|
179
|
+
*/
|
|
180
|
+
_onDragOver(e) {
|
|
181
|
+
if (this.disabled) return true;
|
|
182
|
+
if (!e.dataTransfer) return true;
|
|
183
|
+
const effect = e.dataTransfer.effectAllowed;
|
|
184
|
+
e.dataTransfer.dropEffect = "move" === effect || "linkMove" === effect ? "move" : "copy";
|
|
185
|
+
return false;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* @internal
|
|
189
|
+
*/
|
|
190
|
+
_onDragLeave(e) {
|
|
191
|
+
if (this.disabled) return true;
|
|
192
|
+
/* v8 ignore else -- @preserve */
|
|
193
|
+
if (e.currentTarget === e.target) this._dragHover = false;
|
|
194
|
+
return true;
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* @internal
|
|
198
|
+
*/
|
|
199
|
+
_onDrop(e) {
|
|
200
|
+
if (this.disabled) return true;
|
|
201
|
+
this._dragHover = false;
|
|
202
|
+
if (!e.dataTransfer) return true;
|
|
203
|
+
filesFromDataTransfer(e.dataTransfer).then((files) => this.#addFiles(files)).catch((err) => {
|
|
204
|
+
console.error(err);
|
|
205
|
+
});
|
|
206
|
+
return false;
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* @internal
|
|
210
|
+
*/
|
|
211
|
+
_onDragEnd() {
|
|
212
|
+
if (this.disabled) return true;
|
|
213
|
+
this._dragHover = false;
|
|
214
|
+
return true;
|
|
215
|
+
}
|
|
216
|
+
/**
|
|
217
|
+
* @internal
|
|
218
|
+
*/
|
|
219
|
+
_onControlClick() {
|
|
220
|
+
/* v8 ignore if -- @preserve */
|
|
221
|
+
if (this.disabled) return;
|
|
222
|
+
this._hiddenInput.click();
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* @internal
|
|
226
|
+
*/
|
|
227
|
+
_onRemoveFileClick(file) {
|
|
228
|
+
if (this.disabled) return;
|
|
229
|
+
this._allFiles = this._allFiles.filter((f) => f !== file);
|
|
230
|
+
this.$emit("change");
|
|
231
|
+
}
|
|
232
|
+
/**
|
|
233
|
+
* @internal
|
|
234
|
+
*/
|
|
235
|
+
_allFilesChanged() {
|
|
236
|
+
this.#updateFormValue();
|
|
237
|
+
}
|
|
238
|
+
#addFiles(files) {
|
|
239
|
+
const newFiles = Array.from(files).filter((file) => !this._allFiles.some((existingFile) => existingFile.name === file.name && existingFile.size === file.size));
|
|
240
|
+
if (this.singleFile && newFiles.length > 0) this._allFiles = [newFiles[newFiles.length - 1]];
|
|
241
|
+
else this._allFiles = [...this._allFiles, ...newFiles];
|
|
242
|
+
this.$emit("change");
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* Removes all files from the File Picker.
|
|
246
|
+
*/
|
|
247
|
+
removeAllFiles() {
|
|
248
|
+
this._allFiles = [];
|
|
249
|
+
}
|
|
250
|
+
/**
|
|
251
|
+
* All files with their current validation status.
|
|
252
|
+
* @internal
|
|
253
|
+
*/
|
|
254
|
+
get _validatedFiles() {
|
|
255
|
+
const validationError = (file, validFileIndex) => {
|
|
256
|
+
if (this.maxFileSize && file.size > this.maxFileSize * 1024 * 1024) return (this.fileTooBigError || this.locale.filePicker.fileTooBigError).replace("{{filesize}}", this._formatNumber(Math.round(file.size / 1024 / 10.24) / 100)).replace("{{maxFilesize}}", this._formatNumber(this.maxFileSize));
|
|
257
|
+
else if (!isAcceptedFileType(file, this.accept)) return this.invalidFileTypeError || this.locale.filePicker.invalidFileTypeError;
|
|
258
|
+
else if (typeof this.maxFiles === "number" && validFileIndex >= this.maxFiles) return (this.maxFilesExceededError || this.locale.filePicker.maxFilesExceededError).replace("{{maxFiles}}", String(this.maxFiles));
|
|
259
|
+
else return null;
|
|
260
|
+
};
|
|
261
|
+
const result = [];
|
|
262
|
+
let validFileIndex = 0;
|
|
263
|
+
for (const file of this._allFiles) {
|
|
264
|
+
const validatedFile = {
|
|
265
|
+
file,
|
|
266
|
+
validationError: validationError(file, validFileIndex)
|
|
267
|
+
};
|
|
268
|
+
result.push(validatedFile);
|
|
269
|
+
if (!validatedFile.validationError) validFileIndex++;
|
|
270
|
+
}
|
|
271
|
+
return result;
|
|
272
|
+
}
|
|
273
|
+
/**
|
|
274
|
+
* List of files that have been added to the file picker and passed validation
|
|
275
|
+
*
|
|
276
|
+
* @public
|
|
277
|
+
*/
|
|
278
|
+
get files() {
|
|
279
|
+
return this._validatedFiles.filter((f) => !f.validationError).map((f) => f.file);
|
|
280
|
+
}
|
|
281
|
+
/**
|
|
282
|
+
* List of files that have been added to the file picker but failed validation
|
|
283
|
+
*
|
|
284
|
+
* @public
|
|
285
|
+
*/
|
|
286
|
+
get rejectedFiles() {
|
|
287
|
+
return this._validatedFiles.filter((f) => !!f.validationError).map((f) => f.file);
|
|
288
|
+
}
|
|
289
|
+
/**
|
|
290
|
+
* @internal
|
|
291
|
+
*/
|
|
292
|
+
_onHiddenInputChange(e) {
|
|
293
|
+
this.#addFiles(this._hiddenInput.files);
|
|
294
|
+
this._hiddenInput.value = "";
|
|
295
|
+
e.stopPropagation();
|
|
296
|
+
}
|
|
297
|
+
/**
|
|
298
|
+
* @internal
|
|
299
|
+
*/
|
|
300
|
+
_formatNumber(value) {
|
|
301
|
+
const str = String(value);
|
|
302
|
+
if (this.locale.common.useCommaAsDecimalSeparator) return str.replace(".", ",");
|
|
303
|
+
return str;
|
|
304
|
+
}
|
|
305
|
+
};
|
|
306
|
+
require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
|
|
307
|
+
attribute: "single-file",
|
|
308
|
+
mode: "boolean"
|
|
309
|
+
})], FilePicker.prototype, "singleFile", void 0);
|
|
310
|
+
require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
|
|
311
|
+
attribute: "max-files",
|
|
312
|
+
converter: _microsoft_fast_element.nullableNumberConverter,
|
|
313
|
+
mode: "fromView"
|
|
314
|
+
})], FilePicker.prototype, "maxFiles", void 0);
|
|
315
|
+
require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
|
|
316
|
+
mode: "fromView",
|
|
317
|
+
attribute: "max-file-size"
|
|
318
|
+
})], FilePicker.prototype, "maxFileSize", void 0);
|
|
319
|
+
require_decorate.__decorate([_microsoft_fast_element.attr], FilePicker.prototype, "accept", void 0);
|
|
320
|
+
require_decorate.__decorate([_microsoft_fast_element.attr], FilePicker.prototype, "size", void 0);
|
|
321
|
+
require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ attribute: "invalid-file-type-error" })], FilePicker.prototype, "invalidFileTypeError", void 0);
|
|
322
|
+
require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ attribute: "max-files-exceeded-error" })], FilePicker.prototype, "maxFilesExceededError", void 0);
|
|
323
|
+
require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ attribute: "file-too-big-error" })], FilePicker.prototype, "fileTooBigError", void 0);
|
|
324
|
+
require_decorate.__decorate([_microsoft_fast_element.observable], FilePicker.prototype, "_customValidationError", void 0);
|
|
325
|
+
require_decorate.__decorate([_microsoft_fast_element.observable], FilePicker.prototype, "_dragHover", void 0);
|
|
326
|
+
require_decorate.__decorate([_microsoft_fast_element.observable], FilePicker.prototype, "_allFiles", void 0);
|
|
327
|
+
require_decorate.__decorate([_microsoft_fast_element.volatile], FilePicker.prototype, "_validatedFiles", null);
|
|
328
|
+
//#endregion
|
|
329
|
+
//#region src/lib/file-picker/file-picker.template.ts
|
|
330
|
+
var filesizeBase = 1e3;
|
|
331
|
+
var dictFileSizeUnits = {
|
|
332
|
+
tb: "TB",
|
|
333
|
+
gb: "GB",
|
|
334
|
+
mb: "MB",
|
|
335
|
+
kb: "KB",
|
|
336
|
+
b: "b"
|
|
337
|
+
};
|
|
338
|
+
var renderFileSize = (x, size) => {
|
|
339
|
+
let selectedSize = 0;
|
|
340
|
+
let selectedUnit = "b";
|
|
341
|
+
/* v8 ignore else -- @preserve */
|
|
342
|
+
if (size > 0) {
|
|
343
|
+
const units = [
|
|
344
|
+
"tb",
|
|
345
|
+
"gb",
|
|
346
|
+
"mb",
|
|
347
|
+
"kb",
|
|
348
|
+
"b"
|
|
349
|
+
];
|
|
350
|
+
for (let i = 0; i < units.length; i++) {
|
|
351
|
+
const unit = units[i];
|
|
352
|
+
if (size >= Math.pow(filesizeBase, 4 - i) / 10) {
|
|
353
|
+
selectedSize = size / Math.pow(filesizeBase, 4 - i);
|
|
354
|
+
selectedUnit = unit;
|
|
355
|
+
break;
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
selectedSize = Math.round(10 * selectedSize) / 10;
|
|
359
|
+
}
|
|
360
|
+
return _microsoft_fast_element.html`<strong>${x._formatNumber(selectedSize)}</strong>
|
|
361
|
+
${dictFileSizeUnits[selectedUnit]}`;
|
|
362
|
+
};
|
|
363
|
+
var getClasses = ({ size, _dragHover, disabled }) => (0, _microsoft_fast_web_utilities.classNames)("control", [`size-${size}`, Boolean(size)], ["drag-hover", _dragHover], ["disabled", disabled]);
|
|
364
|
+
var FilePickerTemplate = (context) => {
|
|
365
|
+
const iconTag = context.tagFor(require_definition.Icon);
|
|
366
|
+
const buttonTag = context.tagFor(require_definition$1.Button);
|
|
367
|
+
return _microsoft_fast_element.html`
|
|
368
|
+
<div class="base">
|
|
369
|
+
<div class="label-wrapper" ?hidden=${(x) => !x.label && !x._hasContextualHelp}>
|
|
370
|
+
${(0, _microsoft_fast_element.when)((x) => x.label, _microsoft_fast_element.html`<label class="label">${(x) => x.label}</label>`)}
|
|
371
|
+
<slot name="contextual-help" ${(0, _microsoft_fast_element.slotted)("_contextualHelpSlottedContent")}></slot>
|
|
372
|
+
</div>
|
|
373
|
+
<div class="control-wrapper">
|
|
374
|
+
<button
|
|
375
|
+
type="button"
|
|
376
|
+
${(0, _microsoft_fast_element.ref)("control")}
|
|
377
|
+
class="${getClasses}"
|
|
378
|
+
?disabled="${(x) => x.disabled}"
|
|
379
|
+
@click="${(x) => x._onControlClick()}"
|
|
380
|
+
@keydown="${() => false}"
|
|
381
|
+
@dragenter="${(x) => x._onDragEnter()}"
|
|
382
|
+
@dragover="${(x, c) => x._onDragOver(c.event)}"
|
|
383
|
+
@dragleave="${(x, c) => x._onDragLeave(c.event)}"
|
|
384
|
+
@drop="${(x, c) => x._onDrop(c.event)}"
|
|
385
|
+
@dragend="${(x) => x._onDragEnd()}"
|
|
386
|
+
aria-describedby="${(x) => x._feedbackDescribedBy}"
|
|
387
|
+
${require_delegates_aria.delegateAria()}
|
|
388
|
+
>
|
|
389
|
+
<${iconTag}
|
|
390
|
+
class="upload-icon"
|
|
391
|
+
name="cloud-upload-line"
|
|
392
|
+
size="-4"
|
|
393
|
+
label="${(x) => x.locale.filePicker.uploadFilesLabel}"
|
|
394
|
+
></${iconTag}>
|
|
395
|
+
<span class="upload-text"><slot></slot></span>
|
|
396
|
+
</button>
|
|
397
|
+
${(x) => x._getFeedbackTemplate(context)}
|
|
398
|
+
</div>
|
|
399
|
+
<div class="preview-list">
|
|
400
|
+
${(0, _microsoft_fast_element.repeat)((x) => x._validatedFiles, _microsoft_fast_element.html`
|
|
401
|
+
<div class="${(x) => (0, _microsoft_fast_web_utilities.classNames)("preview", ["has-error", !!x.validationError])}">
|
|
402
|
+
<div class="details">
|
|
403
|
+
<div class="filename">${(x) => x.file.name}</div>
|
|
404
|
+
<div class="size">${(x, c) => renderFileSize(c.parent, x.file.size)}</div>
|
|
405
|
+
</div>
|
|
406
|
+
<div class="error-message">
|
|
407
|
+
<${iconTag} name="info-line" size="-6"></${iconTag}>
|
|
408
|
+
${(x) => x.validationError}
|
|
409
|
+
</div>
|
|
410
|
+
<${buttonTag}
|
|
411
|
+
class="remove-btn" icon="delete-line" appearance="ghost-light" size="condensed"
|
|
412
|
+
?disabled="${(_, c) => c.parent.disabled}"
|
|
413
|
+
aria-label="${(_, c) => c.parent.locale.filePicker.removeFileLabel}"
|
|
414
|
+
@click="${(x, c) => c.parent._onRemoveFileClick(x.file)}"></${buttonTag}>
|
|
415
|
+
</div>`)}
|
|
416
|
+
</div>
|
|
417
|
+
</div>
|
|
418
|
+
<input
|
|
419
|
+
${(0, _microsoft_fast_element.ref)("_hiddenInput")}
|
|
420
|
+
class="hidden-input"
|
|
421
|
+
aria-hidden="true"
|
|
422
|
+
type="file"
|
|
423
|
+
?disabled="${(x) => x.disabled}"
|
|
424
|
+
?multiple="${(x) => !x.singleFile && (x.maxFiles == null || x.maxFiles > 1)}"
|
|
425
|
+
accept="${(x) => x.accept || null}"
|
|
426
|
+
tabindex="-1"
|
|
427
|
+
@change="${(x, c) => x._onHiddenInputChange(c.event)}"
|
|
428
|
+
/>
|
|
429
|
+
`;
|
|
430
|
+
};
|
|
431
|
+
//#endregion
|
|
432
|
+
//#region src/lib/file-picker/definition.ts
|
|
433
|
+
/**
|
|
434
|
+
* @internal
|
|
435
|
+
*/
|
|
436
|
+
var filePickerDefinition = require_vivid_element.defineVividComponent("file-picker", FilePicker, FilePickerTemplate, [
|
|
437
|
+
require_definition.iconDefinition,
|
|
438
|
+
require_definition$1.buttonDefinition,
|
|
439
|
+
require_mixins.feedbackMessageDefinition
|
|
440
|
+
], {
|
|
441
|
+
styles: file_picker_default,
|
|
442
|
+
shadowOptions: { delegatesFocus: true }
|
|
443
|
+
});
|
|
444
|
+
/**
|
|
445
|
+
* Registers the file-picker element with the design system.
|
|
446
|
+
*
|
|
447
|
+
* @param prefix - the prefix to use for the component name
|
|
448
|
+
*/
|
|
449
|
+
var registerFilePicker = require_vivid_element.createRegisterFunction(filePickerDefinition);
|
|
450
|
+
//#endregion
|
|
451
|
+
Object.defineProperty(exports, "FilePicker", {
|
|
452
|
+
enumerable: true,
|
|
453
|
+
get: function() {
|
|
454
|
+
return FilePicker;
|
|
455
|
+
}
|
|
456
|
+
});
|
|
457
|
+
Object.defineProperty(exports, "filePickerDefinition", {
|
|
458
|
+
enumerable: true,
|
|
459
|
+
get: function() {
|
|
460
|
+
return filePickerDefinition;
|
|
461
|
+
}
|
|
462
|
+
});
|
|
463
|
+
Object.defineProperty(exports, "registerFilePicker", {
|
|
464
|
+
enumerable: true,
|
|
465
|
+
get: function() {
|
|
466
|
+
return registerFilePicker;
|
|
467
|
+
}
|
|
468
|
+
});
|