@vonage/vivid 5.16.0 → 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/index.cjs +1 -1
- package/accordion/index.js +1 -1
- package/accordion-item/index.cjs +1 -1
- package/accordion-item/index.js +1 -1
- package/action-group/index.cjs +3 -3
- package/action-group/index.js +5 -5
- package/alert/index.cjs +3 -3
- package/alert/index.js +17 -17
- package/audio-player/index.cjs +16 -16
- package/audio-player/index.js +27 -27
- package/avatar/index.cjs +2 -2
- package/avatar/index.js +6 -6
- package/badge/index.cjs +2 -2
- package/badge/index.js +6 -6
- package/banner/index.cjs +3 -3
- package/banner/index.js +15 -15
- package/bundled/base-color-picker.cjs +2 -2
- package/bundled/base-color-picker.js +5 -5
- package/bundled/button.cjs +1 -1
- package/bundled/button.js +2 -2
- package/bundled/calendar-picker.template.cjs +2 -2
- package/bundled/calendar-picker.template.js +498 -498
- package/bundled/definition10.cjs +18 -30
- package/bundled/definition10.js +53 -155
- package/bundled/definition11.cjs +10 -19
- package/bundled/definition11.js +25 -74
- package/bundled/definition12.cjs +72 -18
- package/bundled/definition12.js +171 -107
- package/bundled/definition13.cjs +18 -17
- package/bundled/definition13.js +45 -65
- package/bundled/definition14.cjs +5 -10
- package/bundled/definition14.js +9 -27
- package/bundled/definition15.cjs +17 -71
- package/bundled/definition15.js +64 -181
- package/bundled/definition16.cjs +12 -4
- package/bundled/definition16.js +79 -14
- package/bundled/definition17.cjs +19 -13
- package/bundled/definition17.js +119 -70
- package/bundled/definition18.cjs +87 -12
- package/bundled/definition18.js +409 -52
- package/bundled/definition19.cjs +5 -87
- package/bundled/definition19.js +14 -422
- package/bundled/definition2.cjs +3 -3
- package/bundled/definition2.js +27 -27
- package/bundled/definition20.cjs +30 -5
- package/bundled/definition20.js +159 -9
- package/bundled/definition21.cjs +28 -19
- package/bundled/definition21.js +164 -47
- package/bundled/definition22.cjs +38 -23
- package/bundled/definition22.js +64 -82
- package/bundled/definition3.cjs +1 -1
- package/bundled/definition3.js +15 -15
- package/bundled/definition4.cjs +23 -38
- package/bundled/definition4.js +82 -64
- package/bundled/definition5.cjs +2 -2
- package/bundled/definition5.js +5 -5
- package/bundled/definition6.cjs +2 -2
- package/bundled/definition6.js +24 -24
- package/bundled/definition9.cjs +12 -30
- package/bundled/definition9.js +55 -148
- package/bundled/divider.cjs +1 -1
- package/bundled/divider.js +5 -5
- package/bundled/listbox.cjs +1 -1
- package/bundled/listbox.js +1 -1
- package/bundled/mixins.cjs +4 -4
- package/bundled/mixins.js +43 -43
- package/bundled/picker-field.template.cjs +7 -7
- package/bundled/picker-field.template.js +14 -14
- package/bundled/slider.template.cjs +7 -7
- package/bundled/slider.template.js +12 -12
- package/bundled/slottable-request.cjs +1 -1
- package/bundled/slottable-request.js +8 -38
- package/bundled/time-selection-picker.template.cjs +4 -4
- package/bundled/time-selection-picker.template.js +35 -35
- package/bundled/vivid-element.cjs +1 -1
- package/bundled/vivid-element.js +1 -1
- package/calendar/index.cjs +11 -11
- package/calendar/index.js +30 -237
- package/calendar-event/index.cjs +3 -3
- package/calendar-event/index.js +4 -4
- package/card/index.cjs +14 -11
- package/card/index.js +16 -13
- package/checkbox/index.cjs +1 -1
- package/checkbox/index.js +1 -1
- package/color-picker/definition.cjs +1 -1
- package/color-picker/definition.js +1 -1
- package/color-picker/index.cjs +6 -6
- package/color-picker/index.js +24 -24
- package/combobox/definition.cjs +1 -1
- package/combobox/definition.js +1 -1
- package/combobox/index.cjs +9 -8
- package/combobox/index.js +32 -28
- package/contextual-help/definition.cjs +1 -1
- package/contextual-help/definition.js +1 -1
- package/contextual-help/index.cjs +1 -1
- package/contextual-help/index.js +1 -1
- package/custom-elements.json +1027 -615
- package/data-grid/definition.js +1 -1
- package/data-grid/index.cjs +17 -17
- package/data-grid/index.js +261 -264
- package/date-picker/index.cjs +1 -1
- package/date-picker/index.js +12 -12
- package/date-range-picker/index.cjs +1 -1
- package/date-range-picker/index.js +7 -7
- package/date-time-picker/index.cjs +4 -4
- package/date-time-picker/index.js +24 -24
- package/dial-pad/index.cjs +3 -2
- package/dial-pad/index.js +6 -5
- package/dialog/index.cjs +4 -4
- package/dialog/index.js +5 -5
- package/divider/index.cjs +1 -1
- package/divider/index.js +1 -1
- package/fab/index.cjs +3 -3
- package/fab/index.js +8 -8
- package/file-picker/index.cjs +16 -13
- package/file-picker/index.js +31 -28
- package/header/index.cjs +4 -4
- package/header/index.js +5 -5
- package/index.cjs +24 -21
- package/index.js +11 -11
- package/lib/combobox/combobox.d.ts +0 -3
- 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/menu/menu.d.ts +0 -1
- package/lib/option/option.d.ts +0 -1
- 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/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/locales/de-DE.cjs +4 -178
- package/locales/de-DE.js +2 -179
- package/locales/en-GB.cjs +4 -9
- package/locales/en-GB.js +2 -10
- package/locales/en-US.cjs +268 -2
- package/locales/en-US.js +265 -1
- package/locales/ja-JP.cjs +4 -171
- package/locales/ja-JP.js +2 -172
- package/locales/zh-CN.cjs +4 -172
- package/locales/zh-CN.js +2 -173
- package/menu/index.cjs +1 -1
- package/menu/index.js +1 -1
- package/menu-item/index.cjs +1 -1
- package/menu-item/index.js +1 -1
- package/nav-disclosure/index.cjs +3 -3
- package/nav-disclosure/index.js +8 -8
- package/nav-item/index.cjs +1 -1
- package/nav-item/index.js +7 -7
- package/note/index.cjs +2 -2
- package/note/index.js +6 -6
- package/number-field/index.cjs +4 -4
- package/number-field/index.js +31 -31
- package/option/definition.cjs +1 -1
- package/option/definition.js +1 -1
- package/option/index.cjs +1 -1
- package/option/index.js +1 -1
- package/package.json +7 -8
- package/pagination/index.cjs +3 -3
- package/pagination/index.js +15 -15
- package/popover/index.cjs +4 -4
- package/popover/index.js +5 -5
- package/progress/index.cjs +2 -2
- package/progress/index.js +5 -5
- package/radio/index.cjs +1 -1
- package/radio/index.js +1 -1
- package/radio-group/index.cjs +4 -4
- package/radio-group/index.js +10 -10
- package/range-slider/index.cjs +4 -4
- package/range-slider/index.js +17 -17
- package/rich-text-editor/definition.cjs +1 -0
- package/rich-text-editor/definition.js +2 -2
- package/rich-text-editor/index.cjs +13 -13
- package/rich-text-editor/index.js +1886 -1829
- package/rich-text-view/index.cjs +1 -1
- package/rich-text-view/index.js +8 -8
- package/searchable-select/index.cjs +12 -12
- package/searchable-select/index.js +25 -25
- package/select/index.cjs +1 -1
- package/select/index.js +1 -1
- package/selectable-box/index.cjs +7 -7
- package/selectable-box/index.js +11 -11
- package/shared/foundation/test-utilities/fixture.d.ts +1 -1
- package/shared/patterns/linkable.d.ts +1 -1
- package/simple-color-picker/index.cjs +3 -3
- package/simple-color-picker/index.js +10 -10
- package/split-button/index.cjs +5 -5
- package/split-button/index.js +10 -10
- package/status/index.cjs +2 -2
- package/status/index.js +12 -12
- package/switch/index.cjs +3 -3
- package/switch/index.js +5 -5
- package/tab/index.cjs +1 -1
- package/tab/index.js +1 -1
- package/tab-panel/index.cjs +1 -1
- package/tab-panel/index.js +1 -1
- package/table/definition.cjs +17 -14
- package/table/definition.js +3 -2
- package/table/index.cjs +19 -10
- package/table/index.js +69 -21
- package/tabs/index.cjs +2 -2
- package/tabs/index.js +4 -4
- package/tag/index.cjs +7 -7
- package/tag/index.js +9 -9
- package/tag-group/index.cjs +3 -3
- package/tag-group/index.js +5 -5
- package/text-area/index.cjs +2 -2
- package/text-area/index.js +12 -12
- package/text-field/definition.cjs +1 -1
- package/text-field/definition.js +1 -1
- package/text-field/index.cjs +1 -1
- package/text-field/index.js +1 -1
- package/time-picker/index.cjs +1 -1
- package/time-picker/index.js +1 -1
- package/toggletip/definition.cjs +1 -1
- package/toggletip/definition.js +1 -1
- package/toggletip/index.cjs +1 -1
- package/toggletip/index.js +1 -1
- package/tooltip/definition.cjs +1 -1
- package/tooltip/definition.js +1 -1
- package/tooltip/index.cjs +1 -1
- package/tooltip/index.js +1 -1
- package/tree-item/index.cjs +1 -1
- package/tree-item/index.js +1 -1
- package/tree-view/index.cjs +3 -3
- package/tree-view/index.js +17 -17
- package/unbundled/button.cjs +2 -2
- package/unbundled/button.js +2 -2
- package/unbundled/calendar-picker.template.cjs +4347 -9
- package/unbundled/calendar-picker.template.js +4345 -7
- package/unbundled/chunk.cjs +0 -22
- package/unbundled/definition13.cjs +1 -8
- package/unbundled/definition13.js +1 -8
- package/unbundled/definition14.cjs +2 -2
- package/unbundled/definition14.js +2 -2
- package/unbundled/definition2.cjs +1 -1
- package/unbundled/definition2.js +1 -1
- package/unbundled/definition21.cjs +1 -2
- package/unbundled/definition21.js +1 -2
- package/unbundled/definition22.cjs +7 -2
- package/unbundled/definition22.js +7 -2
- package/unbundled/definition24.cjs +98 -979
- package/unbundled/definition24.js +93 -974
- package/unbundled/definition25.cjs +37 -322
- package/unbundled/definition25.js +33 -318
- package/unbundled/definition26.cjs +317 -91
- package/unbundled/definition26.js +313 -87
- package/unbundled/definition27.cjs +94 -192
- package/unbundled/definition27.js +91 -183
- package/unbundled/definition28.cjs +387 -395
- package/unbundled/definition28.js +387 -395
- package/unbundled/definition29.cjs +189 -110
- package/unbundled/definition29.js +180 -107
- package/unbundled/definition30.cjs +520 -36
- package/unbundled/definition30.js +519 -35
- package/unbundled/definition32.cjs +477 -477
- package/unbundled/definition32.js +475 -475
- package/unbundled/definition33.cjs +87 -2
- package/unbundled/definition33.js +77 -4
- package/unbundled/definition35.cjs +2 -2
- package/unbundled/definition35.js +2 -2
- package/unbundled/definition36.cjs +1 -1
- package/unbundled/definition36.js +1 -1
- package/unbundled/definition37.cjs +6 -2
- package/unbundled/definition37.js +6 -2
- package/unbundled/definition38.cjs +7 -5
- package/unbundled/definition38.js +7 -5
- package/unbundled/definition39.cjs +1 -0
- package/unbundled/definition39.js +1 -0
- package/unbundled/definition42.cjs +22 -11
- package/unbundled/definition42.js +22 -11
- package/unbundled/definition49.cjs +3 -3
- package/unbundled/definition49.js +3 -3
- package/unbundled/definition56.cjs +437 -9506
- package/unbundled/definition56.js +340 -9415
- package/unbundled/definition57.cjs +5 -5
- package/unbundled/definition57.js +5 -5
- package/unbundled/definition58.cjs +4 -3
- package/unbundled/definition58.js +2 -1
- package/unbundled/definition59.cjs +4 -3
- package/unbundled/definition59.js +4 -3
- package/unbundled/definition62.cjs +2 -2
- package/unbundled/definition62.js +2 -2
- package/unbundled/definition64.cjs +1 -1
- package/unbundled/definition64.js +1 -1
- package/unbundled/definition71.cjs +2 -2
- package/unbundled/definition71.js +2 -2
- package/unbundled/definition72.cjs +1 -2
- package/unbundled/definition72.js +1 -2
- package/unbundled/definition75.cjs +3 -51711
- package/unbundled/definition75.js +1 -51711
- package/unbundled/listbox.cjs +1 -1
- package/unbundled/listbox.js +1 -1
- package/unbundled/localized.cjs +2 -2
- package/unbundled/localized.js +1 -1
- package/unbundled/picker-field.template.cjs +1 -1
- package/unbundled/picker-field.template.js +1 -1
- package/unbundled/slottable-request.cjs +2 -3168
- package/unbundled/slottable-request.js +3 -3097
- package/unbundled/time-selection-picker.template.cjs +1 -1
- package/unbundled/time-selection-picker.template.js +1 -1
- package/unbundled/vivid-element.cjs +1 -1
- package/unbundled/vivid-element.js +1 -1
- package/video-player/index.cjs +3 -3
- package/video-player/index.js +9 -9
- package/vivid.api.json +220 -282
- package/unbundled/chunk.js +0 -33
- package/unbundled/en-US.cjs +0 -447
- package/unbundled/en-US.js +0 -443
|
@@ -2,545 +2,537 @@ require("./chunk.cjs");
|
|
|
2
2
|
const require_vivid_element = require("./vivid-element.cjs");
|
|
3
3
|
const require_definition = require("./definition2.cjs");
|
|
4
4
|
const require_decorate = require("./decorate.cjs");
|
|
5
|
-
const
|
|
6
|
-
const require_form_associated = require("./form-associated.cjs");
|
|
7
|
-
const require_form_element = require("./form-element.cjs");
|
|
5
|
+
const require_delegates_aria = require("./delegates-aria.cjs");
|
|
8
6
|
const require_with_success_text = require("./with-success-text.cjs");
|
|
9
7
|
const require_with_error_text = require("./with-error-text.cjs");
|
|
10
8
|
const require_with_contextual_help = require("./with-contextual-help.cjs");
|
|
9
|
+
const require_trapped_focus = require("./trapped-focus.cjs");
|
|
11
10
|
const require_definition$1 = require("./definition7.cjs");
|
|
12
11
|
const require_dialog = require("./dialog.cjs");
|
|
13
12
|
const require_definition$2 = require("./definition10.cjs");
|
|
14
13
|
const require_mixins = require("./mixins.cjs");
|
|
15
|
-
const require_definition$3 = require("./
|
|
16
|
-
const
|
|
17
|
-
const
|
|
14
|
+
const require_definition$3 = require("./definition26.cjs");
|
|
15
|
+
const require_definition$4 = require("./definition27.cjs");
|
|
16
|
+
const require_base_color_picker = require("./base-color-picker.cjs");
|
|
18
17
|
let _microsoft_fast_element = require("@microsoft/fast-element");
|
|
19
18
|
let _microsoft_fast_web_utilities = require("@microsoft/fast-web-utilities");
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
let vanilla_colorful_hex_color_picker_js = require("vanilla-colorful/hex-color-picker.js");
|
|
20
|
+
let vanilla_colorful_hex_input_js = require("vanilla-colorful/hex-input.js");
|
|
21
|
+
//#region src/lib/color-picker/color-picker.scss?inline
|
|
22
|
+
var color_picker_default = ".palette{grid-template-columns:repeat(var(--swatches-per-row,7), var(--_color-swatch-size,24px));display:grid}.swatch{background-color:var(--swatch-color);block-size:var(--_color-swatch-size,24px);color:var(--vvd-color-canvas);cursor:pointer;inline-size:var(--_color-swatch-size,24px);border-radius:4px;padding:0;position:relative}.swatch:not(.contrast){border:none}.swatch.contrast{border:1px solid var(--vvd-color-neutral-400);color:var(--vvd-color-canvas-text)}.swatch:focus-visible{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:none;outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px));--focus-stroke-gap-color:transparent;--focus-inset:-3px}:host{--_low-ink-color:var(--vvd-color-neutral-600);display:inline-block}.base{min-inline-size:var(--_color-picker-min-inline-size,280px);display:inline-block}.control{inline-size:100%}.button{box-sizing:border-box;background-color:var(--button-color,var(--vvd-color-canvas-text));block-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8));color:var(--vvd-color-canvas);inline-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8));padding-inline:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8)) / 4);vertical-align:middle;border:0;border-radius:4px;align-items:center;margin:0;text-decoration:none;display:inline-flex}.button.contrast{color:var(--vvd-color-canvas-text)}.button:not(.disabled){cursor:pointer}.button.disabled{background-color:var(--vvd-color-neutral-300);color:var(--vvd-color-neutral-500);cursor:not-allowed}.button: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))}.button [data-vvd-component=icon]{font-size:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8)) / 2);line-height:1}.dialog{min-inline-size:var(--_color-picker-popup-min-inline-size,264px);flex-direction:column;display:flex}.dialog .header{justify-content:space-between;align-items:center;padding-block:8px;padding-inline:16px;display:inline-flex}.dialog .header-title{font:var(--vvd-typography-base-extended-bold);margin-block:0}.dialog .body{flex-direction:column;gap:16px;margin-block-end:16px;padding-inline:16px;display:flex}.dialog .hex-input-wrapper{align-items:stretch;gap:8px;display:flex}.dialog .hex-input-wrapper [data-vvd-component=button]{flex:none}.dialog .footer{border-top:1px solid var(--vvd-color-neutral-200);padding:16px}.dialog .footer-header{margin-block-end:8px}.dialog .swatches-count{color:var(--_low-ink-color);font:var(--vvd-typography-base)}.dialog .palette{gap:var(--_color-swatches-gap,8px)}vvd-hex-input{flex:auto;min-width:0}vvd-hex-input::part(input),vvd-hex-input>input{box-sizing:border-box;background-color:var(--vvd-color-canvas);width:100%;height:100%;box-shadow:inset 0 0 0 1px var(--vvd-color-neutral-500);font:var(--vvd-typography-base);padding-inline:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2))) / 2.5);border:0;border-radius:8px;outline:#0000}vvd-hex-input::part(input):focus-visible,vvd-hex-input>input:focus-visible{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));--focus-stroke-gap-color:transparent}vvd-hex-picker{width:auto;height:auto;gap:16px;inline-size:100%}vvd-hex-picker::part(saturation){border-radius:8px;block-size:120px}vvd-hex-picker::part(hue){border-radius:8px;flex:0 0 8px}vvd-hex-picker::part(hue-pointer){width:10px;height:10px}vvd-hex-picker::part(saturation-pointer){width:18px;height:18px}::part(popup-base){inline-size:max-content;min-block-size:var(--_color-picker-popup-min-inline-size,264px);min-inline-size:var(--_color-picker-popup-min-inline-size,264px)}.visually-hidden{clip:rect(0 0 0 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}";
|
|
22
23
|
//#endregion
|
|
23
|
-
//#region src/lib/
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
list: "list",
|
|
31
|
-
both: "both",
|
|
32
|
-
none: "none"
|
|
24
|
+
//#region src/lib/color-picker/color-picker.ts
|
|
25
|
+
var VC_HEX_PICKER_TAG = "vvd-hex-picker";
|
|
26
|
+
var VC_HEX_INPUT_TAG = "vvd-hex-input";
|
|
27
|
+
var VvdHexPicker = class extends vanilla_colorful_hex_color_picker_js.HexColorPicker {
|
|
28
|
+
static {
|
|
29
|
+
this.displayName = "VvdHexPicker";
|
|
30
|
+
}
|
|
33
31
|
};
|
|
34
|
-
|
|
35
|
-
|
|
32
|
+
var VvdHexInput = class extends vanilla_colorful_hex_input_js.HexInput {
|
|
33
|
+
static {
|
|
34
|
+
this.displayName = "VvdHexInput";
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
/* v8 ignore if -- @preserve */
|
|
38
|
+
if (!customElements.get(VC_HEX_PICKER_TAG)) customElements.define(VC_HEX_PICKER_TAG, VvdHexPicker);
|
|
39
|
+
/* v8 ignore if -- @preserve */
|
|
40
|
+
if (!customElements.get(VC_HEX_INPUT_TAG)) customElements.define(VC_HEX_INPUT_TAG, VvdHexInput);
|
|
41
|
+
var vcPickerTag = VC_HEX_PICKER_TAG;
|
|
42
|
+
var vcInputTag = VC_HEX_INPUT_TAG;
|
|
36
43
|
/**
|
|
37
44
|
* @public
|
|
38
|
-
* @component
|
|
39
|
-
* @slot -
|
|
40
|
-
* @slot
|
|
41
|
-
* @slot
|
|
42
|
-
* @
|
|
43
|
-
* @
|
|
44
|
-
* @vueModel modelValue value change `event.currentTarget.value`
|
|
45
|
-
* @testAction fill comboboxFill
|
|
46
|
-
* @testAction clear comboboxClear
|
|
47
|
-
* @testAction selectOptionByText selectOptionByText
|
|
48
|
-
* @testAction selectOptionByValue selectOptionByValue
|
|
49
|
-
* @testRef control shadow input.control
|
|
45
|
+
* @component color-picker
|
|
46
|
+
* @slot helper-text - Describes how to use the text-field. Alternative to the `helper-text` attribute.
|
|
47
|
+
* @slot popup-text - Overrides the default "Color Picker" title of the Popup window.
|
|
48
|
+
* @slot swatches-text - Overrides the default "Saved colors:" text above color swatches.
|
|
49
|
+
* @event {CustomEvent<undefined>} change - Fires when the value changes
|
|
50
|
+
* @vueModel modelValue value input,@lazy:change `event.currentTarget.value`
|
|
50
51
|
*/
|
|
51
|
-
var
|
|
52
|
+
var ColorPicker = class extends require_with_contextual_help.WithContextualHelp(require_mixins.WithFeedback(require_with_error_text.WithErrorText(require_with_success_text.WithSuccessText(require_delegates_aria.DelegatesAria(require_trapped_focus.TrappedFocus(require_base_color_picker.BaseColorPicker(require_vivid_element.VividElement))))))) {
|
|
52
53
|
constructor(..._args) {
|
|
53
54
|
super(..._args);
|
|
54
|
-
this.
|
|
55
|
-
this.
|
|
56
|
-
this.
|
|
57
|
-
this.
|
|
58
|
-
this.
|
|
59
|
-
|
|
60
|
-
|
|
55
|
+
this.disableSavedColors = false;
|
|
56
|
+
this.savedColors = [];
|
|
57
|
+
this.maxSwatches = 6;
|
|
58
|
+
this.copyIconName = "copy-2-line";
|
|
59
|
+
this._copyValueToClipboard = async (value) => {
|
|
60
|
+
try {
|
|
61
|
+
await navigator.clipboard.writeText(value);
|
|
62
|
+
this._setTemporaryCopyIcon("check-circle-line");
|
|
63
|
+
this._ariaLiveDescription = this.locale.colorPicker.copySuccessMessage(value);
|
|
64
|
+
} catch {
|
|
65
|
+
alert(this.locale.colorPicker.copyErrorText);
|
|
66
|
+
this._setTemporaryCopyIcon("error-line");
|
|
67
|
+
this._ariaLiveDescription = this.locale.colorPicker.copyErrorText;
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
this._ariaLiveDescription = "";
|
|
71
|
+
}
|
|
72
|
+
static {
|
|
73
|
+
this.HEX_COLOR_PATTERN = /^#(([0-9a-fA-F]{2}){3}|([0-9a-fA-F]){3})$/;
|
|
61
74
|
}
|
|
62
75
|
/**
|
|
63
76
|
* @internal
|
|
64
77
|
*/
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
this.
|
|
68
|
-
this.value = this.firstSelectedOption?.text || "";
|
|
69
|
-
}
|
|
70
|
-
/** {@inheritDoc (FormAssociated:interface).validate} */
|
|
71
|
-
validate() {
|
|
72
|
-
super.validate(this.control);
|
|
73
|
-
}
|
|
74
|
-
get isAutocompleteInline() {
|
|
75
|
-
return this.autocomplete === ComboboxAutocomplete.inline || this.isAutocompleteBoth;
|
|
76
|
-
}
|
|
77
|
-
get isAutocompleteList() {
|
|
78
|
-
return this.autocomplete === ComboboxAutocomplete.list || this.isAutocompleteBoth;
|
|
78
|
+
placeholderChanged() {
|
|
79
|
+
/* v8 ignore if -- @preserve */
|
|
80
|
+
if (this.proxy instanceof HTMLInputElement) this.proxy.placeholder = this.placeholder;
|
|
79
81
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
+
/**
|
|
83
|
+
* Change event handler for inner control.
|
|
84
|
+
* @remarks
|
|
85
|
+
* @internal
|
|
86
|
+
*/
|
|
87
|
+
handleChange() {
|
|
88
|
+
this.$emit("change");
|
|
82
89
|
}
|
|
83
90
|
/**
|
|
84
91
|
* @internal
|
|
85
92
|
*/
|
|
86
|
-
openChanged() {
|
|
87
|
-
if (this.
|
|
93
|
+
openChanged(_oldValue, newValue) {
|
|
94
|
+
if (newValue && this.isConnected) requestAnimationFrame(() => {
|
|
95
|
+
this._refreshCanvasColor();
|
|
96
|
+
});
|
|
88
97
|
}
|
|
89
98
|
/**
|
|
90
|
-
*
|
|
91
|
-
*
|
|
92
|
-
* @public
|
|
93
|
-
* @remarks
|
|
94
|
-
* Overrides `Listbox.options`.
|
|
99
|
+
* @internal
|
|
95
100
|
*/
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
return this.filteredOptions.length ? this.filteredOptions : this._options;
|
|
101
|
+
savedColorsKeyChanged() {
|
|
102
|
+
this.savedColors = this._loadSavedColors();
|
|
99
103
|
}
|
|
100
|
-
|
|
101
|
-
|
|
104
|
+
/**
|
|
105
|
+
* @internal
|
|
106
|
+
*/
|
|
107
|
+
get _savedColorsStorageKey() {
|
|
108
|
+
if (this.savedColorsKey) return this.savedColorsKey;
|
|
109
|
+
return `vvd-saved-colors:${this.tagName.toLowerCase()}`;
|
|
102
110
|
}
|
|
103
111
|
/**
|
|
104
|
-
* Updates the placeholder on the proxy element.
|
|
105
112
|
* @internal
|
|
106
113
|
*/
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
if (this.proxy instanceof HTMLInputElement) this.proxy.placeholder = this.placeholder;
|
|
114
|
+
_handleColorSaving() {
|
|
115
|
+
this._saveCurrentColor();
|
|
110
116
|
}
|
|
111
117
|
/**
|
|
112
118
|
* @internal
|
|
113
119
|
*/
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
+
_saveCurrentColor() {
|
|
121
|
+
const value = this.value;
|
|
122
|
+
if (typeof value !== "string" || !require_base_color_picker.isValidHexColor(value)) return;
|
|
123
|
+
const swatches = Array.isArray(this.savedColors) ? [...this.savedColors] : [];
|
|
124
|
+
const idx = swatches.findIndex((s) => s?.value === value);
|
|
125
|
+
if (idx !== -1) swatches.splice(idx, 1);
|
|
126
|
+
swatches.unshift({ value });
|
|
127
|
+
this.savedColors = swatches.slice(0, this._maxSwatchesNormalized);
|
|
128
|
+
this._setSavedColors(this.savedColors);
|
|
120
129
|
}
|
|
121
130
|
/**
|
|
122
|
-
* Handle opening and closing the listbox when the combobox is clicked.
|
|
123
|
-
*
|
|
124
|
-
* @param e - the mouse event
|
|
125
131
|
* @internal
|
|
126
132
|
*/
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
133
|
+
_loadSavedColors() {
|
|
134
|
+
try {
|
|
135
|
+
const savedColors = localStorage.getItem(this._savedColorsStorageKey);
|
|
136
|
+
if (!savedColors) return [];
|
|
137
|
+
const parsed = JSON.parse(savedColors);
|
|
138
|
+
if (!Array.isArray(parsed)) return [];
|
|
139
|
+
return parsed.filter((x) => x && typeof x.value === "string" && require_base_color_picker.isValidHexColor(x.value)).map((x) => ({
|
|
140
|
+
value: x.value,
|
|
141
|
+
label: typeof x.label === "string" ? x.label : void 0
|
|
142
|
+
}));
|
|
143
|
+
} catch {
|
|
144
|
+
return [];
|
|
136
145
|
}
|
|
137
|
-
this.open = !this.open;
|
|
138
|
-
if (this.open) this.control.focus();
|
|
139
|
-
return true;
|
|
140
146
|
}
|
|
141
147
|
/**
|
|
142
|
-
* Handle closing the listbox when the combobox is open and the chevron icon is clicked.
|
|
143
|
-
*
|
|
144
|
-
* @param e - the mouse event
|
|
145
148
|
* @internal
|
|
146
149
|
*/
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
150
|
+
_setSavedColors(swatches) {
|
|
151
|
+
try {
|
|
152
|
+
localStorage.setItem(this._savedColorsStorageKey, JSON.stringify(swatches));
|
|
153
|
+
} catch {}
|
|
151
154
|
}
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
155
|
+
/**
|
|
156
|
+
* Get all color swatches combined, both from swatches property and saved colors
|
|
157
|
+
* @internal
|
|
158
|
+
*/
|
|
159
|
+
get allSwatches() {
|
|
160
|
+
const predefinedColors = Array.isArray(this.swatches) ? this.swatches : [];
|
|
161
|
+
const savedColors = Array.isArray(this.savedColors) ? this.savedColors : [];
|
|
162
|
+
const seen = /* @__PURE__ */ new Set();
|
|
163
|
+
const merged = [];
|
|
164
|
+
const appendIfUniqueAndValid = (swatch) => {
|
|
165
|
+
if (!swatch || typeof swatch.value !== "string") return;
|
|
166
|
+
if (!require_base_color_picker.isValidHexColor(swatch.value) || seen.has(swatch.value)) return;
|
|
167
|
+
seen.add(swatch.value);
|
|
168
|
+
merged.push(swatch);
|
|
169
|
+
};
|
|
170
|
+
if (!this.disableSavedColors) savedColors.forEach(appendIfUniqueAndValid);
|
|
171
|
+
predefinedColors.forEach(appendIfUniqueAndValid);
|
|
172
|
+
return merged.slice(0, this._maxSwatchesNormalized);
|
|
156
173
|
}
|
|
157
174
|
/**
|
|
158
|
-
*
|
|
159
|
-
*
|
|
160
|
-
* @public
|
|
175
|
+
* @internal
|
|
161
176
|
*/
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
this.filteredOptions = this._options.filter((o) => o.text.toLowerCase().startsWith(this.filter.toLowerCase()));
|
|
165
|
-
if (this.isAutocompleteList) this._options.forEach((o) => {
|
|
166
|
-
o.hidden = !this.filteredOptions.includes(o);
|
|
167
|
-
});
|
|
177
|
+
get _maxSwatchesNormalized() {
|
|
178
|
+
return Number.isFinite(this.maxSwatches) ? Math.max(0, Math.floor(this.maxSwatches)) : 0;
|
|
168
179
|
}
|
|
169
180
|
/**
|
|
170
|
-
* Focus the control and scroll the first selected option into view.
|
|
171
|
-
*
|
|
172
181
|
* @internal
|
|
173
|
-
* @remarks
|
|
174
|
-
* Overrides: `Listbox.focusAndScrollOptionIntoView`
|
|
175
182
|
*/
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
this.
|
|
183
|
+
maxSwatchesChanged() {
|
|
184
|
+
const maxCount = this._maxSwatchesNormalized;
|
|
185
|
+
if (this.savedColors?.length > maxCount) {
|
|
186
|
+
this.savedColors = this.savedColors.slice(0, maxCount);
|
|
187
|
+
this._setSavedColors(this.savedColors);
|
|
180
188
|
}
|
|
181
189
|
}
|
|
182
190
|
/**
|
|
183
191
|
* @internal
|
|
184
192
|
*/
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
/* v8 ignore else -- @preserve */
|
|
188
|
-
if (firstSelectedOption) requestAnimationFrame(() => {
|
|
189
|
-
firstSelectedOption.scrollIntoView({ block: "nearest" });
|
|
190
|
-
});
|
|
193
|
+
_onPickerColorChanged(e) {
|
|
194
|
+
if (typeof e.detail?.value === "string") this.value = e.detail?.value;
|
|
191
195
|
}
|
|
192
196
|
/**
|
|
193
|
-
* Handle focus state when the element or its children lose focus.
|
|
194
|
-
*
|
|
195
|
-
* @param e - The focus event
|
|
196
197
|
* @internal
|
|
197
198
|
*/
|
|
198
|
-
|
|
199
|
-
this.
|
|
200
|
-
if (
|
|
201
|
-
const focusTarget = e.relatedTarget;
|
|
202
|
-
if (this.isSameNode(focusTarget)) {
|
|
203
|
-
this.focus();
|
|
204
|
-
return;
|
|
205
|
-
}
|
|
206
|
-
this.open = false;
|
|
199
|
+
valueChanged(_oldVal, newVal) {
|
|
200
|
+
if (this._vcHexPickerEl && typeof newVal === "string") this._vcHexPickerEl.color = newVal;
|
|
201
|
+
if (this._vcHexInputEl && typeof newVal === "string") this._vcHexInputEl.color = newVal;
|
|
207
202
|
}
|
|
208
203
|
/**
|
|
209
|
-
* Handle content changes on the control input.
|
|
210
|
-
*
|
|
211
|
-
* @param e - the input event
|
|
212
204
|
* @internal
|
|
213
205
|
*/
|
|
214
|
-
|
|
215
|
-
this.
|
|
216
|
-
this.filterOptions();
|
|
217
|
-
if (!this.isAutocompleteInline) this.selectedIndex = this.options.map((option) => option.text).indexOf(this.control.value);
|
|
218
|
-
if (e.inputType.includes("deleteContent") || !this.filter.length) return true;
|
|
219
|
-
if (this.isAutocompleteList && !this.open) this.open = true;
|
|
220
|
-
if (this.isAutocompleteInline) if (this.filteredOptions.length) {
|
|
221
|
-
this.selectedOptions = [this.filteredOptions[0]];
|
|
222
|
-
this.selectedIndex = this.options.indexOf(this.firstSelectedOption);
|
|
223
|
-
this.setInlineSelection();
|
|
224
|
-
} else this.selectedIndex = -1;
|
|
206
|
+
_onTextFieldInput(event) {
|
|
207
|
+
this.value = event.currentTarget.value;
|
|
225
208
|
}
|
|
226
209
|
/**
|
|
227
|
-
* Handle keydown actions for listbox navigation.
|
|
228
|
-
*
|
|
229
|
-
* @param e - the keyboard event
|
|
230
210
|
* @internal
|
|
231
211
|
*/
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
if (
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
this.syncValue();
|
|
238
|
-
/* v8 ignore else -- @preserve */
|
|
239
|
-
if (this.isAutocompleteInline) this.filter = this.value;
|
|
240
|
-
this.open = false;
|
|
241
|
-
this.clearSelectionRange();
|
|
242
|
-
break;
|
|
243
|
-
case "Escape":
|
|
244
|
-
/* v8 ignore else -- @preserve */
|
|
245
|
-
if (!this.isAutocompleteInline) this.selectedIndex = -1;
|
|
246
|
-
if (this.open) {
|
|
247
|
-
this.open = false;
|
|
248
|
-
break;
|
|
249
|
-
}
|
|
250
|
-
this.value = "";
|
|
251
|
-
this.control.value = "";
|
|
252
|
-
this.filter = "";
|
|
253
|
-
this.filterOptions();
|
|
254
|
-
break;
|
|
255
|
-
case "Tab":
|
|
256
|
-
this.setInputToSelection();
|
|
257
|
-
if (!this.open) return true;
|
|
258
|
-
e.preventDefault();
|
|
259
|
-
this.open = false;
|
|
260
|
-
break;
|
|
261
|
-
case "ArrowUp":
|
|
262
|
-
case "ArrowDown":
|
|
263
|
-
this.filterOptions();
|
|
264
|
-
if (!this.open) {
|
|
265
|
-
this.open = true;
|
|
266
|
-
break;
|
|
267
|
-
}
|
|
268
|
-
/* v8 ignore else -- @preserve */
|
|
269
|
-
if (this.filteredOptions.length > 0) super.keydownHandler(e);
|
|
270
|
-
if (this.isAutocompleteInline) this.setInlineSelection();
|
|
271
|
-
break;
|
|
272
|
-
default: return true;
|
|
273
|
-
}
|
|
212
|
+
get _buttonColor() {
|
|
213
|
+
/* v8 ignore else -- @preserve */
|
|
214
|
+
if (!this._canvasColor) this._refreshCanvasColor();
|
|
215
|
+
if (this.value && require_base_color_picker.isValidHexColor(this.value)) return this.value;
|
|
216
|
+
return "var(--vvd-color-canvas-text)";
|
|
274
217
|
}
|
|
275
218
|
/**
|
|
276
|
-
* Ensure that the selectedIndex is within the current allowable filtered range.
|
|
277
|
-
*
|
|
278
|
-
* @param prev - the previous selected index value
|
|
279
|
-
* @param next - the current selected index value
|
|
280
|
-
*
|
|
281
219
|
* @internal
|
|
282
220
|
*/
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
next = (0, _microsoft_fast_web_utilities.limit)(-1, this.options.length - 1, next);
|
|
286
|
-
if (next !== this.selectedIndex) {
|
|
287
|
-
this.selectedIndex = next;
|
|
288
|
-
return;
|
|
289
|
-
}
|
|
290
|
-
super.selectedIndexChanged(prev, next);
|
|
291
|
-
}
|
|
221
|
+
_onButtonClick() {
|
|
222
|
+
this.open = !this.open;
|
|
292
223
|
}
|
|
293
224
|
/**
|
|
294
|
-
* Move focus to the previous selectable option.
|
|
295
|
-
*
|
|
296
225
|
* @internal
|
|
297
|
-
* @remarks
|
|
298
|
-
* Overrides `Listbox.selectPreviousOption`
|
|
299
226
|
*/
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
}
|
|
303
|
-
_isDefaultSelected(option) {
|
|
304
|
-
return super._isDefaultSelected(option) || option.text !== "" && option.text === this.initialValue;
|
|
227
|
+
_handleCloseRequest() {
|
|
228
|
+
this.open = false;
|
|
305
229
|
}
|
|
306
230
|
/**
|
|
307
|
-
* Focus and set the content of the control based on the first selected option.
|
|
308
|
-
*
|
|
309
231
|
* @internal
|
|
310
232
|
*/
|
|
311
|
-
|
|
312
|
-
if (
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
}
|
|
233
|
+
_isInPath(e, el) {
|
|
234
|
+
if (!el) return false;
|
|
235
|
+
const path = e.composedPath?.();
|
|
236
|
+
return !!(path && path.includes(el));
|
|
316
237
|
}
|
|
317
238
|
/**
|
|
318
|
-
* Focus, set and select the content of the control based on the first selected option.
|
|
319
|
-
*
|
|
320
239
|
* @internal
|
|
321
240
|
*/
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
241
|
+
#closeOnPointerOutside = (e) => {
|
|
242
|
+
if (this._isInPath(e, this._buttonEl) || this._isInPath(e, this._popupEl)) return;
|
|
243
|
+
this.open = false;
|
|
244
|
+
};
|
|
245
|
+
connectedCallback() {
|
|
246
|
+
super.connectedCallback();
|
|
247
|
+
this.savedColors = this._loadSavedColors();
|
|
248
|
+
document.addEventListener("mousedown", this.#closeOnPointerOutside, true);
|
|
249
|
+
}
|
|
250
|
+
disconnectedCallback() {
|
|
251
|
+
super.disconnectedCallback();
|
|
252
|
+
document.removeEventListener("mousedown", this.#closeOnPointerOutside, true);
|
|
328
253
|
}
|
|
254
|
+
#iconResetTimer = null;
|
|
329
255
|
/**
|
|
330
|
-
* Determines if a value update should involve emitting a change event, then updates the value.
|
|
331
|
-
*
|
|
332
256
|
* @internal
|
|
333
257
|
*/
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
this
|
|
258
|
+
_setTemporaryCopyIcon(name, ms = 2e3) {
|
|
259
|
+
this.copyIconName = name;
|
|
260
|
+
if (this.#iconResetTimer) clearTimeout(this.#iconResetTimer);
|
|
261
|
+
this.#iconResetTimer = setTimeout(() => {
|
|
262
|
+
this.copyIconName = "copy-2-line";
|
|
263
|
+
this.#iconResetTimer = null;
|
|
264
|
+
}, ms);
|
|
337
265
|
}
|
|
338
266
|
/**
|
|
339
|
-
* Ensure that the entire list of options is used when setting the selected property.
|
|
340
|
-
*
|
|
341
|
-
* @param prev - the previous list of selected options
|
|
342
|
-
* @param next - the current list of selected options
|
|
343
|
-
*
|
|
344
267
|
* @internal
|
|
345
|
-
* @remarks
|
|
346
|
-
* Overrides: `Listbox.selectedOptionsChanged`
|
|
347
268
|
*/
|
|
348
|
-
|
|
349
|
-
if (this
|
|
350
|
-
|
|
351
|
-
|
|
269
|
+
_onBaseKeydown(event) {
|
|
270
|
+
if (this.open && require_dialog.handleEscapeKeyAndStopPropogation(event)) {
|
|
271
|
+
this.open = false;
|
|
272
|
+
return false;
|
|
273
|
+
}
|
|
274
|
+
if (this._trappedFocus(event, () => this._focusableElsWithinDialog())) return false;
|
|
275
|
+
return true;
|
|
352
276
|
}
|
|
353
277
|
/**
|
|
354
|
-
* Synchronize the form-associated proxy and update the value property of the element.
|
|
355
|
-
*
|
|
356
|
-
* @param prev - the previous collection of slotted option elements
|
|
357
|
-
* @param next - the next collection of slotted option elements
|
|
358
|
-
*
|
|
359
278
|
* @internal
|
|
360
279
|
*/
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
this.updateValue();
|
|
364
|
-
const scale = this.getAttribute("scale") || this.scale;
|
|
365
|
-
next.forEach((element) => {
|
|
366
|
-
if (scale) {
|
|
367
|
-
element.setAttribute("scale", scale);
|
|
368
|
-
element.scale = scale;
|
|
369
|
-
}
|
|
370
|
-
});
|
|
280
|
+
_focusableElsWithinDialog() {
|
|
281
|
+
return this._popupEl.querySelectorAll("button:not([role=\"gridcell\"]), [data-vvd-component=\"button\"], vwc-button:not([role=\"gridcell\"])");
|
|
371
282
|
}
|
|
372
283
|
/**
|
|
373
|
-
* Sets the value and to match the first selected option.
|
|
374
|
-
*
|
|
375
|
-
* @param shouldEmit - if true, the change event will be emitted
|
|
376
|
-
*
|
|
377
284
|
* @internal
|
|
378
285
|
*/
|
|
379
|
-
|
|
380
|
-
if (
|
|
381
|
-
|
|
286
|
+
_handleCellKeydown(event, value, index, isSaveCell) {
|
|
287
|
+
if (event.key === "Tab") {
|
|
288
|
+
event.preventDefault();
|
|
289
|
+
const focusableEls = this._focusableElsWithinDialog();
|
|
290
|
+
const idx = Array.prototype.indexOf.call(focusableEls, event.currentTarget);
|
|
291
|
+
focusableEls[event.shiftKey ? (idx - 1 + focusableEls.length) % focusableEls.length : (idx + 1) % focusableEls.length]?.focus();
|
|
292
|
+
return false;
|
|
293
|
+
}
|
|
294
|
+
return super._handleCellKeydown(event, value, index, isSaveCell);
|
|
382
295
|
}
|
|
383
296
|
/**
|
|
384
297
|
* @internal
|
|
385
298
|
*/
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
this.
|
|
299
|
+
_handleSwatchSelection(value) {
|
|
300
|
+
/* v8 ignore else -- @preserve */
|
|
301
|
+
if (this.value !== value) this._ariaLiveDescription = this.locale.colorPicker.selectionSuccessMessage(value);
|
|
302
|
+
super._handleSwatchSelection(value);
|
|
389
303
|
}
|
|
390
304
|
};
|
|
391
|
-
require_decorate.__decorate([
|
|
392
|
-
|
|
393
|
-
mode: "fromView"
|
|
394
|
-
})], Combobox.prototype, "autocomplete", void 0);
|
|
395
|
-
require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "appearance", void 0);
|
|
396
|
-
require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "shape", void 0);
|
|
397
|
-
require_decorate.__decorate([(0, _microsoft_fast_element.attr)()], Combobox.prototype, "scale", void 0);
|
|
398
|
-
require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "placement", void 0);
|
|
305
|
+
require_decorate.__decorate([_microsoft_fast_element.attr], ColorPicker.prototype, "placeholder", void 0);
|
|
306
|
+
require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ attribute: "saved-colors-key" })], ColorPicker.prototype, "savedColorsKey", void 0);
|
|
399
307
|
require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
|
|
400
308
|
mode: "boolean",
|
|
401
|
-
attribute: "
|
|
402
|
-
})],
|
|
403
|
-
require_decorate.__decorate([_microsoft_fast_element.observable],
|
|
404
|
-
require_decorate.__decorate([_microsoft_fast_element.observable], Combobox.prototype, "maxHeight", void 0);
|
|
309
|
+
attribute: "disable-saved-colors"
|
|
310
|
+
})], ColorPicker.prototype, "disableSavedColors", void 0);
|
|
311
|
+
require_decorate.__decorate([_microsoft_fast_element.observable], ColorPicker.prototype, "savedColors", void 0);
|
|
405
312
|
require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
|
|
406
|
-
attribute: "
|
|
407
|
-
mode: "
|
|
408
|
-
|
|
409
|
-
|
|
313
|
+
attribute: "max-swatches",
|
|
314
|
+
mode: "fromView",
|
|
315
|
+
converter: _microsoft_fast_element.nullableNumberConverter
|
|
316
|
+
})], ColorPicker.prototype, "maxSwatches", void 0);
|
|
317
|
+
require_decorate.__decorate([_microsoft_fast_element.observable], ColorPicker.prototype, "copyIconName", void 0);
|
|
318
|
+
require_decorate.__decorate([_microsoft_fast_element.observable], ColorPicker.prototype, "_ariaLiveDescription", void 0);
|
|
410
319
|
//#endregion
|
|
411
|
-
//#region src/lib/
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
return _microsoft_fast_element.html`
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
}
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
}
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
?
|
|
320
|
+
//#region src/lib/color-picker/color-picker.template.ts
|
|
321
|
+
function renderTextField(textFieldTag, iconTag) {
|
|
322
|
+
const getClasses = (_) => (0, _microsoft_fast_web_utilities.classNames)("control");
|
|
323
|
+
return _microsoft_fast_element.html`
|
|
324
|
+
<${textFieldTag}
|
|
325
|
+
id="text-field"
|
|
326
|
+
class="${getClasses}"
|
|
327
|
+
pattern="${ColorPicker.HEX_COLOR_PATTERN.source}"
|
|
328
|
+
maxlength="7"
|
|
329
|
+
label="${(x) => x.label}"
|
|
330
|
+
:value="${(x) => x.value}"
|
|
331
|
+
placeholder="${(x) => x.placeholder}"
|
|
332
|
+
helper-text="${(x) => x.helperText}"
|
|
333
|
+
error-text="${(x) => x.errorValidationMessage}"
|
|
334
|
+
success-text="${(x) => x.successText}"
|
|
335
|
+
?disabled="${(x) => x.disabled}"
|
|
336
|
+
?required="${(x) => x.required}"
|
|
337
|
+
@input='${(x, c) => x._onTextFieldInput(c.event)}'
|
|
338
|
+
@change="${(x) => x.handleChange()}"
|
|
339
|
+
@blur="${(x) => {
|
|
340
|
+
x.$emit("blur", void 0, { bubbles: false });
|
|
341
|
+
}}"
|
|
342
|
+
@focus="${(x) => {
|
|
343
|
+
x.$emit("focus", void 0, { bubbles: false });
|
|
344
|
+
}}"
|
|
345
|
+
${require_delegates_aria.delegateAria()}
|
|
346
|
+
${(0, _microsoft_fast_element.ref)("_textFieldEl")}
|
|
428
347
|
>
|
|
429
|
-
|
|
348
|
+
<button
|
|
349
|
+
aria-label="${(x) => x.locale.colorPicker.pickerButtonLabel}"
|
|
350
|
+
aria-expanded="${(x) => x.open}"
|
|
351
|
+
aria-haspopup="dialog"
|
|
352
|
+
class="button ${(x) => (0, _microsoft_fast_web_utilities.classNames)(x._applyContrastClass(x._buttonColor) ? "contrast" : "", x.disabled ? "disabled" : "")}"
|
|
353
|
+
style="--button-color: ${(x) => x._buttonColor};"
|
|
354
|
+
?disabled="${(x) => x.disabled}"
|
|
355
|
+
@click="${(x) => x._onButtonClick()}"
|
|
356
|
+
slot="action-items"
|
|
357
|
+
${(0, _microsoft_fast_element.ref)("_buttonEl")}>
|
|
358
|
+
<${iconTag} name="edit-line"></${iconTag}>
|
|
359
|
+
</button>
|
|
360
|
+
<slot
|
|
361
|
+
slot="${(x) => x._helperTextSlottedContent?.length ? "helper-text" : void 0}"
|
|
362
|
+
name="helper-text"
|
|
363
|
+
${(0, _microsoft_fast_element.slotted)("_helperTextSlottedContent")}
|
|
364
|
+
></slot>
|
|
430
365
|
<slot
|
|
431
|
-
|
|
366
|
+
slot='${(x) => x._contextualHelpSlottedContent?.length ? "contextual-help" : void 0}'
|
|
367
|
+
name='contextual-help'
|
|
432
368
|
${(0, _microsoft_fast_element.slotted)("_contextualHelpSlottedContent")}
|
|
433
369
|
></slot>
|
|
370
|
+
</${textFieldTag}>
|
|
371
|
+
`;
|
|
372
|
+
}
|
|
373
|
+
function renderPopupHeader(buttonTag, iconTag) {
|
|
374
|
+
return _microsoft_fast_element.html`
|
|
375
|
+
<div class="header">
|
|
376
|
+
<h2 class="header-title" id="color-picker-title">
|
|
377
|
+
<slot name="popup-text">${(x) => x.locale.colorPicker.popupLabel}</slot>
|
|
378
|
+
</h2>
|
|
379
|
+
<${buttonTag} size="condensed"
|
|
380
|
+
aria-label="${(x) => x.locale.colorPicker.closeButtonLabel}"
|
|
381
|
+
@click="${(x) => x._handleCloseRequest()}">
|
|
382
|
+
<${iconTag} slot="icon" name="close-line"></${iconTag}>
|
|
383
|
+
</${buttonTag}>
|
|
434
384
|
</div>
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
@input="${(x, c) => x.inputHandler(c.event)}"
|
|
454
|
-
${(0, _microsoft_fast_element.ref)("control")}
|
|
455
|
-
/>
|
|
456
|
-
</div>
|
|
457
|
-
<div class="leading-items-wrapper">
|
|
458
|
-
<slot name="meta" ${(0, _microsoft_fast_element.slotted)("metaSlottedContent")}></slot>
|
|
459
|
-
<div
|
|
460
|
-
@click="${(x, c) => x._chevronIconClickHandler(c.event)}"
|
|
385
|
+
`;
|
|
386
|
+
}
|
|
387
|
+
function renderPopupBody(buttonTag, iconTag, tooltipTag) {
|
|
388
|
+
return _microsoft_fast_element.html`
|
|
389
|
+
<div class="body">
|
|
390
|
+
<${_microsoft_fast_element.html.partial(vcPickerTag)}
|
|
391
|
+
part="hex-picker"
|
|
392
|
+
color="${(x) => x.value}"
|
|
393
|
+
@color-changed="${(x, c) => x._onPickerColorChanged(c.event)}"
|
|
394
|
+
${(0, _microsoft_fast_element.ref)("_vcHexPickerEl")}
|
|
395
|
+
></${_microsoft_fast_element.html.partial(vcPickerTag)}>
|
|
396
|
+
<div class="hex-input-wrapper">
|
|
397
|
+
<${_microsoft_fast_element.html.partial(vcInputTag)}
|
|
398
|
+
part="hex-input"
|
|
399
|
+
prefixed
|
|
400
|
+
color="${(x) => x.value}"
|
|
401
|
+
@color-changed="${(x, c) => x._onPickerColorChanged(c.event)}"
|
|
402
|
+
${(0, _microsoft_fast_element.ref)("_vcHexInputEl")}
|
|
461
403
|
>
|
|
462
|
-
${
|
|
463
|
-
|
|
404
|
+
<input name="hex-code-input" aria-label="${(x) => x.locale.colorPicker.hexInputLabel}"
|
|
405
|
+
placeholder="${(x) => x.placeholder}"
|
|
406
|
+
@blur="${(x, c) => c.event.stopImmediatePropagation()}"
|
|
407
|
+
part="input">
|
|
408
|
+
</${_microsoft_fast_element.html.partial(vcInputTag)}>
|
|
409
|
+
<${tooltipTag} placement="top"
|
|
410
|
+
text="${(x) => x.locale.colorPicker.copyButtonLabel}"
|
|
411
|
+
exportparts="vvd-theme-alternate">
|
|
412
|
+
<${buttonTag}
|
|
413
|
+
slot="anchor" size="normal"
|
|
414
|
+
aria-label="${(x) => x.locale.colorPicker.copyButtonLabel}"
|
|
415
|
+
@click="${(x) => x._copyValueToClipboard(x.value)}">
|
|
416
|
+
<${iconTag} slot="icon" name="${(x) => x.copyIconName}"></${iconTag}>
|
|
417
|
+
</${buttonTag}>
|
|
418
|
+
</${tooltipTag}>
|
|
464
419
|
</div>
|
|
465
420
|
</div>
|
|
466
|
-
|
|
421
|
+
`;
|
|
467
422
|
}
|
|
468
|
-
|
|
469
|
-
const popupTag = context.tagFor(require_definition$2.Popup);
|
|
423
|
+
function renderPopupFooter(buttonTag, iconTag, tooltipTag) {
|
|
470
424
|
return _microsoft_fast_element.html`
|
|
471
|
-
<
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
>
|
|
480
|
-
<div class="control-wrapper">
|
|
481
|
-
${() => renderInput(context)}
|
|
482
|
-
<${popupTag} class="popup"
|
|
483
|
-
style="${setFixedDropdownVarWidth}"
|
|
484
|
-
?open="${(x) => x.open}"
|
|
485
|
-
placement="${(x) => x.placement ?? "bottom-start"}"
|
|
486
|
-
strategy="${(x) => x.fixedDropdown ? "fixed" : "absolute"}"
|
|
487
|
-
${(0, _microsoft_fast_element.ref)("_popup")}>
|
|
488
|
-
<div id="${(x) => x.listboxId}"
|
|
489
|
-
class="listbox"
|
|
490
|
-
role="listbox"
|
|
491
|
-
?disabled="${(x) => x.disabled}"
|
|
492
|
-
${(0, _microsoft_fast_element.ref)("listbox")}>
|
|
493
|
-
<slot ${(0, _microsoft_fast_element.slotted)({
|
|
494
|
-
filter: require_listbox.Listbox.slottedOptionFilter,
|
|
495
|
-
flatten: true,
|
|
496
|
-
property: "slottedOptions"
|
|
497
|
-
})}>
|
|
498
|
-
</slot>
|
|
499
|
-
</div>
|
|
500
|
-
</${popupTag}>
|
|
425
|
+
<div class="footer">
|
|
426
|
+
<div class="footer-header">
|
|
427
|
+
<span class="footer-title" id="color-picker-footer-title"
|
|
428
|
+
><slot name="swatches-text"
|
|
429
|
+
>${(x) => x.locale.colorPicker.swatchesLabel}</slot
|
|
430
|
+
></span
|
|
431
|
+
>
|
|
432
|
+
${(0, _microsoft_fast_element.when)((x) => !x.disableSavedColors, renderSwatchesCount())}
|
|
501
433
|
</div>
|
|
502
|
-
<div
|
|
503
|
-
|
|
434
|
+
<div
|
|
435
|
+
class="palette"
|
|
436
|
+
role="grid"
|
|
437
|
+
aria-rowcount="${(x) => Math.ceil(x.allSwatches.length / x._getRowLength())}"
|
|
438
|
+
aria-colcount="${(x) => x._getRowLength()}"
|
|
439
|
+
style="--swatches-per-row: ${(x) => x._getRowLength()};"
|
|
440
|
+
aria-labelledby="color-picker-footer-title"
|
|
441
|
+
>
|
|
442
|
+
${(0, _microsoft_fast_element.repeat)((x) => x.allSwatches, (x) => x._renderColorSwatch(iconTag, tooltipTag), { positioning: true })}
|
|
443
|
+
${(0, _microsoft_fast_element.when)((x) => !x.disableSavedColors, _microsoft_fast_element.html`
|
|
444
|
+
<${tooltipTag} placement="top"
|
|
445
|
+
text="${(x) => x.locale.colorPicker.saveButtonLabel}"
|
|
446
|
+
exportparts="vvd-theme-alternate">
|
|
447
|
+
<${buttonTag}
|
|
448
|
+
slot="anchor"
|
|
449
|
+
appearance="outlined"
|
|
450
|
+
size="super-condensed"
|
|
451
|
+
role="gridcell"
|
|
452
|
+
tabindex="${(x) => x.allSwatches.length ? "-1" : "0"}"
|
|
453
|
+
aria-label="${(x) => x.locale.colorPicker.saveButtonLabel}"
|
|
454
|
+
@click="${(x) => x._saveCurrentColor()}"
|
|
455
|
+
@keydown="${(x, c) => x._handleCellKeydown(c.event, x.value, x.allSwatches.length, true)}">
|
|
456
|
+
<${iconTag} slot="icon" name="plus-line"></${iconTag}>
|
|
457
|
+
</${buttonTag}>
|
|
458
|
+
</${tooltipTag}>
|
|
459
|
+
`)}
|
|
504
460
|
</div>
|
|
505
|
-
|
|
461
|
+
</div>
|
|
462
|
+
`;
|
|
463
|
+
}
|
|
464
|
+
function renderSwatchesCount() {
|
|
465
|
+
return _microsoft_fast_element.html`
|
|
466
|
+
<span
|
|
467
|
+
id="swatches-count"
|
|
468
|
+
class="swatches-count"
|
|
469
|
+
aria-label="${(x) => x.locale.colorPicker.maxSwatchesMessage(x.allSwatches.length, x.maxSwatches)}"
|
|
470
|
+
>${(x) => `${x.allSwatches.length}/${x.maxSwatches}`}</span
|
|
471
|
+
>
|
|
472
|
+
`;
|
|
473
|
+
}
|
|
474
|
+
var ColorPickerTemplate = (context) => {
|
|
475
|
+
const textFieldTag = context.tagFor(require_definition$3.TextField);
|
|
476
|
+
const iconTag = context.tagFor(require_definition.Icon);
|
|
477
|
+
const popupTag = context.tagFor(require_definition$2.Popup);
|
|
478
|
+
const buttonTag = context.tagFor(require_definition$1.Button);
|
|
479
|
+
const tooltipTag = context.tagFor(require_definition$4.Tooltip);
|
|
480
|
+
return _microsoft_fast_element.html`
|
|
481
|
+
<div class="base" @keydown="${(x, { event }) => x._onBaseKeydown(event)}">
|
|
482
|
+
<span aria-live="assertive" aria-relevant="text" class="visually-hidden">
|
|
483
|
+
${(x) => x._ariaLiveDescription}
|
|
484
|
+
</span>
|
|
485
|
+
${renderTextField(textFieldTag, iconTag)}
|
|
486
|
+
<${popupTag}
|
|
487
|
+
:open="${(x) => x.open}"
|
|
488
|
+
:anchor="${(x) => x._buttonEl}"
|
|
489
|
+
placement="top"
|
|
490
|
+
offset="10"
|
|
491
|
+
${(0, _microsoft_fast_element.ref)("_popupEl")}>
|
|
492
|
+
<div class="dialog"
|
|
493
|
+
role="dialog"
|
|
494
|
+
aria-modal="true"
|
|
495
|
+
aria-labelledby="color-picker-title">
|
|
496
|
+
${renderPopupHeader(buttonTag, iconTag)}
|
|
497
|
+
${renderPopupBody(buttonTag, iconTag, tooltipTag)}
|
|
498
|
+
${(0, _microsoft_fast_element.when)((x) => !x.disableSavedColors || x.allSwatches.length > 0, renderPopupFooter(buttonTag, iconTag, tooltipTag))}
|
|
499
|
+
</div>
|
|
500
|
+
</${popupTag}>
|
|
501
|
+
</div>
|
|
506
502
|
`;
|
|
507
503
|
};
|
|
508
504
|
//#endregion
|
|
509
|
-
//#region src/lib/
|
|
510
|
-
|
|
511
|
-
* @internal
|
|
512
|
-
*/
|
|
513
|
-
var comboboxDefinition = require_vivid_element.defineVividComponent("combobox", Combobox, comboboxTemplate, [
|
|
514
|
-
require_definition.iconDefinition,
|
|
505
|
+
//#region src/lib/color-picker/definition.ts
|
|
506
|
+
var colorPickerDefinition = require_vivid_element.defineVividComponent("color-picker", ColorPicker, ColorPickerTemplate, [
|
|
515
507
|
require_definition$2.popupDefinition,
|
|
516
|
-
require_definition
|
|
508
|
+
require_definition.iconDefinition,
|
|
509
|
+
require_definition$3.textFieldDefinition,
|
|
510
|
+
require_definition$1.buttonDefinition,
|
|
511
|
+
require_definition$4.tooltipDefinition,
|
|
517
512
|
require_mixins.feedbackMessageDefinition
|
|
518
|
-
], {
|
|
519
|
-
styles: [require_text_field.text_field_default, combobox_default],
|
|
520
|
-
shadowOptions: { delegatesFocus: true }
|
|
521
|
-
});
|
|
513
|
+
], { styles: color_picker_default });
|
|
522
514
|
/**
|
|
523
|
-
* Registers the
|
|
515
|
+
* Registers the color-picker element with the design system.
|
|
524
516
|
*
|
|
525
517
|
* @param prefix - the prefix to use for the component name
|
|
526
518
|
*/
|
|
527
|
-
var
|
|
519
|
+
var registerColorPicker = require_vivid_element.createRegisterFunction(colorPickerDefinition);
|
|
528
520
|
//#endregion
|
|
529
|
-
Object.defineProperty(exports, "
|
|
521
|
+
Object.defineProperty(exports, "ColorPicker", {
|
|
530
522
|
enumerable: true,
|
|
531
523
|
get: function() {
|
|
532
|
-
return
|
|
524
|
+
return ColorPicker;
|
|
533
525
|
}
|
|
534
526
|
});
|
|
535
|
-
Object.defineProperty(exports, "
|
|
527
|
+
Object.defineProperty(exports, "colorPickerDefinition", {
|
|
536
528
|
enumerable: true,
|
|
537
529
|
get: function() {
|
|
538
|
-
return
|
|
530
|
+
return colorPickerDefinition;
|
|
539
531
|
}
|
|
540
532
|
});
|
|
541
|
-
Object.defineProperty(exports, "
|
|
533
|
+
Object.defineProperty(exports, "registerColorPicker", {
|
|
542
534
|
enumerable: true,
|
|
543
535
|
get: function() {
|
|
544
|
-
return
|
|
536
|
+
return registerColorPicker;
|
|
545
537
|
}
|
|
546
538
|
});
|