@vonage/vivid 5.5.0 → 5.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +201 -0
- package/accordion/definition.cjs +5 -0
- package/accordion/definition.js +5 -0
- package/accordion/index.cjs +1 -1
- package/accordion/index.js +14 -3
- package/alert/definition.cjs +4 -12
- package/alert/definition.js +5 -13
- package/alert/index.cjs +11 -11
- package/alert/index.js +33 -37
- package/audio-player/definition.cjs +4 -0
- package/audio-player/definition.js +4 -0
- package/audio-player/index.cjs +1 -1
- package/audio-player/index.js +8 -2
- package/banner/definition.cjs +2 -4
- package/banner/definition.js +2 -4
- package/banner/index.cjs +2 -2
- package/banner/index.js +1 -1
- package/breadcrumb/definition.cjs +1 -0
- package/breadcrumb/definition.js +1 -0
- package/breadcrumb/index.cjs +1 -1
- package/breadcrumb/index.js +1 -0
- package/bundled/affix.js +1 -1
- package/bundled/anchored.cjs +1 -1
- package/bundled/anchored.js +6 -6
- package/bundled/attribute-binding-behaviour.cjs +1 -1
- package/bundled/attribute-binding-behaviour.js +3 -1
- package/bundled/base-color-picker.cjs +1 -1
- package/bundled/base-color-picker.js +9 -3
- package/bundled/base-progress.cjs +1 -1
- package/bundled/base-progress.js +3 -0
- package/bundled/button.cjs +1 -1
- package/bundled/button.js +14 -10
- package/bundled/calendar-picker.template.cjs +1 -1
- package/bundled/calendar-picker.template.js +2 -0
- package/bundled/definition10.cjs +7 -7
- package/bundled/definition10.js +27 -17
- package/bundled/definition11.cjs +2 -2
- package/bundled/definition11.js +5 -5
- package/bundled/definition12.cjs +1 -1
- package/bundled/definition12.js +1 -0
- package/bundled/definition17.cjs +1 -1
- package/bundled/definition17.js +4 -1
- package/bundled/definition18.cjs +1 -1
- package/bundled/definition18.js +13 -2
- package/bundled/definition19.cjs +6 -6
- package/bundled/definition19.js +68 -33
- package/bundled/definition2.cjs +8 -9
- package/bundled/definition2.js +67 -75
- package/bundled/definition22.cjs +1 -1
- package/bundled/definition22.js +1 -0
- package/bundled/definition3.cjs +1 -1
- package/bundled/definition3.js +1 -0
- package/bundled/definition5.cjs +1 -1
- package/bundled/definition5.js +9 -3
- package/bundled/definition6.cjs +1 -1
- package/bundled/definition6.js +1 -0
- package/bundled/definition7.cjs +1 -1
- package/bundled/definition7.js +7 -4
- package/bundled/definition8.cjs +1 -1
- package/bundled/definition8.js +1 -0
- package/bundled/definition9.cjs +6 -6
- package/bundled/definition9.js +545 -488
- package/bundled/delegates-aria.cjs +1 -1
- package/bundled/delegates-aria.js +3 -1
- package/bundled/form-associated.cjs +1 -1
- package/bundled/form-associated.js +11 -3
- package/bundled/host-semantics.js +4 -4
- package/bundled/listbox.cjs +1 -1
- package/bundled/listbox.js +21 -3
- package/bundled/localized.cjs +1 -1
- package/bundled/localized.js +137 -67
- package/bundled/mixins.cjs +4 -4
- package/bundled/mixins.js +10 -7
- package/bundled/picker-field.template.cjs +1 -1
- package/bundled/picker-field.template.js +1 -0
- package/bundled/scrollIntoView.cjs +1 -1
- package/bundled/scrollIntoView.js +4 -1
- package/bundled/text-field.cjs +1 -1
- package/bundled/text-field.js +1 -1
- package/bundled/time-selection-picker.template.cjs +2 -2
- package/bundled/time-selection-picker.template.js +3 -0
- package/bundled/vivid-element.cjs +4 -4
- package/bundled/vivid-element.js +529 -492
- package/calendar/definition.cjs +2 -0
- package/calendar/definition.js +2 -0
- package/calendar/index.cjs +1 -1
- package/calendar/index.js +2 -0
- package/checkbox/definition.cjs +1 -0
- package/checkbox/definition.js +1 -0
- package/color-picker/definition.cjs +5 -0
- package/color-picker/definition.js +5 -0
- package/color-picker/index.cjs +1 -1
- package/color-picker/index.js +5 -0
- package/combobox/definition.cjs +17 -6
- package/combobox/definition.js +17 -6
- package/combobox/index.cjs +14 -9
- package/combobox/index.js +53 -41
- package/custom-elements.json +6985 -542
- package/data-grid/definition.cjs +105 -7
- package/data-grid/definition.js +105 -7
- package/data-grid/index.cjs +52 -38
- package/data-grid/index.js +313 -242
- package/date-range-picker/definition.cjs +2 -0
- package/date-range-picker/definition.js +2 -0
- package/date-range-picker/index.cjs +1 -1
- package/date-range-picker/index.js +5 -1
- package/dial-pad/definition.cjs +9 -0
- package/dial-pad/definition.js +9 -0
- package/dial-pad/index.cjs +2 -2
- package/dial-pad/index.js +36 -12
- package/dialog/definition.cjs +1 -0
- package/dialog/definition.js +1 -0
- package/dialog/index.cjs +1 -1
- package/dialog/index.js +1 -0
- package/fab/definition.cjs +1 -0
- package/fab/definition.js +1 -0
- package/fab/index.cjs +1 -1
- package/fab/index.js +1 -0
- package/file-picker/definition.cjs +7 -2
- package/file-picker/definition.js +7 -2
- package/file-picker/index.cjs +6 -6
- package/file-picker/index.js +82 -73
- package/icon/definition.cjs +12 -21
- package/icon/definition.js +13 -22
- package/index.cjs +21 -0
- package/index.js +1 -1
- package/lib/data-grid/locale.d.ts +5 -0
- package/lib/date-picker/date-picker.d.ts +38 -38
- package/lib/date-range-picker/date-range-picker.d.ts +20 -20
- package/lib/date-time-picker/date-time-picker.d.ts +40 -40
- package/lib/icon/icon.d.ts +0 -1
- package/lib/menu/menu.d.ts +4 -4
- package/lib/rich-text-editor/definition.d.ts +3 -2
- package/lib/rich-text-editor/locale.d.ts +29 -3
- package/lib/rich-text-editor/popover.d.ts +19 -0
- package/lib/rich-text-editor/rich-text-editor.d.ts +16 -45
- package/lib/rich-text-editor/rich-text-editor.template.d.ts +2 -2
- package/lib/rich-text-editor/rte/config.d.ts +18 -0
- package/lib/rich-text-editor/rte/document.d.ts +28 -0
- package/lib/rich-text-editor/rte/exports.d.ts +23 -0
- package/lib/rich-text-editor/rte/feature.d.ts +46 -0
- package/lib/rich-text-editor/rte/features/internal/basic-text-blocks.d.ts +33 -0
- package/lib/rich-text-editor/rte/features/internal/foreign-html.d.ts +11 -0
- package/lib/rich-text-editor/rte/features/internal/history.d.ts +10 -0
- package/lib/rich-text-editor/rte/features/internal/text-style.d.ts +18 -0
- package/lib/rich-text-editor/rte/html-parser.d.ts +24 -0
- package/lib/rich-text-editor/rte/html-serializer.d.ts +30 -0
- package/lib/rich-text-editor/rte/instance.d.ts +57 -0
- package/lib/rich-text-editor/rte/utils/default-textblock.d.ts +2 -0
- package/lib/rich-text-editor/rte/utils/impl.d.ts +1 -0
- package/lib/rich-text-editor/rte/utils/textblock-attrs.d.ts +29 -0
- package/lib/rich-text-editor/rte/utils/textblock-marks.d.ts +10 -0
- package/lib/rich-text-editor/rte/utils/ui.d.ts +109 -0
- package/lib/simple-color-picker/simple-color-picker.d.ts +4 -4
- package/lib/text-area/text-area.d.ts +1 -1
- package/lib/text-field/text-field.d.ts +1 -1
- package/lib/time-picker/time-picker.d.ts +20 -20
- package/lib/toggletip/toggletip.d.ts +4 -4
- package/lib/tooltip/tooltip.d.ts +4 -4
- package/locales/de-DE.cjs +42 -4
- package/locales/de-DE.js +42 -4
- package/locales/en-GB.cjs +43 -5
- package/locales/en-GB.js +43 -5
- package/locales/en-US.cjs +43 -5
- package/locales/en-US.js +43 -5
- package/locales/ja-JP.cjs +43 -5
- package/locales/ja-JP.js +43 -5
- package/locales/zh-CN.cjs +43 -5
- package/locales/zh-CN.js +43 -5
- package/menu/definition.cjs +1 -0
- package/menu/definition.js +1 -0
- package/number-field/definition.cjs +5 -3
- package/number-field/definition.js +5 -3
- package/number-field/index.cjs +5 -3
- package/number-field/index.js +31 -29
- package/package.json +76 -62
- package/pagination/definition.cjs +2 -0
- package/pagination/definition.js +2 -0
- package/pagination/index.cjs +1 -1
- package/pagination/index.js +2 -0
- package/radio/definition.cjs +4 -0
- package/radio/definition.js +4 -0
- package/range-slider/definition.cjs +2 -1
- package/range-slider/definition.js +2 -1
- package/range-slider/index.cjs +1 -1
- package/range-slider/index.js +3 -1
- package/rich-text-editor/definition.cjs +17942 -1074
- package/rich-text-editor/definition.js +17926 -1079
- package/rich-text-editor/index.cjs +29 -130
- package/rich-text-editor/index.js +5565 -2474
- package/searchable-select/definition.cjs +6 -2
- package/searchable-select/definition.js +6 -2
- package/searchable-select/index.cjs +1 -1
- package/searchable-select/index.js +11 -7
- package/select/definition.cjs +17 -2
- package/select/definition.js +17 -2
- package/shared/patterns/anchored.d.ts +8 -8
- package/shared/patterns/char-count/char-count.d.ts +1 -1
- package/shared/patterns/localized.d.ts +386 -0
- package/shared/picker-field/mixins/calendar-picker.d.ts +10 -10
- package/shared/picker-field/mixins/calendar-picker.template.d.ts +10 -10
- package/shared/picker-field/mixins/min-max-calendar-picker.d.ts +20 -20
- package/shared/picker-field/mixins/single-date-picker.d.ts +28 -28
- package/shared/picker-field/mixins/single-value-picker.d.ts +8 -8
- package/shared/picker-field/mixins/time-selection-picker.d.ts +20 -20
- package/shared/picker-field/mixins/time-selection-picker.template.d.ts +20 -20
- package/shared/utils/promise.d.ts +7 -0
- package/simple-color-picker/definition.cjs +3 -0
- package/simple-color-picker/definition.js +3 -0
- package/simple-color-picker/index.cjs +1 -1
- package/simple-color-picker/index.js +3 -0
- package/slider/definition.cjs +7 -1
- package/slider/definition.js +7 -1
- package/styles/core/all.css +5 -1
- package/styles/core/theme.css +5 -1
- package/styles/core/typography.css +1 -1
- package/styles/tokens/theme-dark.css +4 -4
- package/styles/tokens/theme-light.css +4 -4
- package/styles/tokens/vivid-2-compat.css +1 -1
- package/switch/definition.cjs +1 -0
- package/switch/definition.js +1 -0
- package/switch/index.cjs +1 -1
- package/switch/index.js +1 -0
- package/tabs/definition.cjs +2 -0
- package/tabs/definition.js +2 -0
- package/tabs/index.cjs +1 -1
- package/tabs/index.js +2 -0
- package/text-area/definition.cjs +13 -7
- package/text-area/definition.js +13 -7
- package/text-area/index.cjs +6 -6
- package/text-area/index.js +20 -14
- package/text-field/definition.cjs +16 -6
- package/text-field/definition.js +16 -6
- package/toggletip/definition.cjs +5 -1
- package/toggletip/definition.js +5 -1
- package/tooltip/definition.cjs +4 -1
- package/tooltip/definition.js +4 -1
- package/tree-view/definition.cjs +28 -6
- package/tree-view/definition.js +28 -6
- package/tree-view/index.cjs +1 -1
- package/tree-view/index.js +28 -6
- package/unbundled/_commonjsHelpers.cjs +0 -26
- package/unbundled/_commonjsHelpers.js +1 -26
- package/unbundled/attribute-binding-behaviour.cjs +1 -0
- package/unbundled/attribute-binding-behaviour.js +1 -0
- package/unbundled/base-color-picker.cjs +9 -3
- package/unbundled/base-color-picker.js +9 -3
- package/unbundled/base-progress.cjs +3 -0
- package/unbundled/base-progress.js +3 -0
- package/unbundled/button.cjs +14 -10
- package/unbundled/button.js +14 -10
- package/unbundled/calendar-picker.template.cjs +2 -0
- package/unbundled/calendar-picker.template.js +2 -0
- package/unbundled/definition.cjs +1 -0
- package/unbundled/definition.js +1 -0
- package/unbundled/definition2.cjs +4 -1
- package/unbundled/definition2.js +4 -1
- package/unbundled/definition3.cjs +1 -0
- package/unbundled/definition3.js +1 -0
- package/unbundled/definition4.cjs +1 -0
- package/unbundled/definition4.js +1 -0
- package/unbundled/definition5.cjs +3 -2
- package/unbundled/definition5.js +4 -3
- package/unbundled/delegates-aria.cjs +1 -0
- package/unbundled/delegates-aria.js +1 -0
- package/unbundled/form-associated.cjs +4 -0
- package/unbundled/form-associated.js +4 -0
- package/unbundled/listbox.cjs +16 -1
- package/unbundled/listbox.js +16 -1
- package/unbundled/localized.cjs +36 -0
- package/unbundled/localized.js +37 -2
- package/unbundled/mixins.cjs +2 -0
- package/unbundled/mixins.js +2 -0
- package/unbundled/picker-field.template.cjs +1 -0
- package/unbundled/picker-field.template.js +1 -0
- package/unbundled/scrollIntoView.cjs +1 -0
- package/unbundled/scrollIntoView.js +1 -0
- package/unbundled/text-field.cjs +1 -1
- package/unbundled/text-field.js +1 -1
- package/unbundled/time-selection-picker.template.cjs +3 -0
- package/unbundled/time-selection-picker.template.js +3 -0
- package/unbundled/vivid-element.cjs +1 -1
- package/unbundled/vivid-element.js +1 -1
- package/video-player/definition.cjs +54 -44
- package/video-player/definition.js +50 -40
- package/video-player/index.cjs +28 -28
- package/video-player/index.js +1448 -1442
- package/vivid.api.json +6463 -6099
- package/lib/rich-text-editor/facades/prose-mirror-vivid.schema.d.ts +0 -4
- package/lib/rich-text-editor/facades/vivid-prose-mirror.facade.d.ts +0 -18
- package/lib/rich-text-editor/image-placeholder/definition.d.ts +0 -2
- package/lib/rich-text-editor/image-placeholder/image-placeholder.d.ts +0 -7
- package/lib/rich-text-editor/image-placeholder/image-placeholder.template.d.ts +0 -4
- package/lib/rich-text-editor/menubar/consts.d.ts +0 -18
- package/lib/rich-text-editor/menubar/definition.d.ts +0 -2
- package/lib/rich-text-editor/menubar/menubar.d.ts +0 -386
- package/lib/rich-text-editor/menubar/menubar.template.d.ts +0 -4
package/file-picker/index.cjs
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
"use strict";const u=require("../bundled/definition2.cjs"),h=require("../bundled/definition3.cjs"),l=require("../bundled/vivid-element.cjs"),f=require("../bundled/mixins.cjs"),m=require("../bundled/delegates-aria.cjs"),x=require("../bundled/form-associated.cjs"),F=require("../bundled/with-contextual-help.cjs"),w=require("../bundled/with-error-text.cjs"),y=require("../bundled/form-element.cjs"),k=require("../bundled/localized.cjs"),_=require("../bundled/when.cjs"),E=require("../bundled/slotted.cjs"),p=require("../bundled/ref.cjs"),C=require("../bundled/repeat.cjs"),b=require("../bundled/class-names.cjs"),$=":host{display:block;max-inline-size:400px}.base{display:flex;flex-direction:column;block-size:inherit;max-block-size:inherit;--_low-ink-color: var(--vvd-color-neutral-600)}.control-wrapper{display:flex;flex-direction:column;block-size:inherit;gap:4px;max-block-size:inherit}.control{position:relative;display:flex;box-sizing:border-box;flex-wrap:wrap;align-items:center;justify-content:center;padding:16px;border:1px dashed var(--vvd-color-neutral-400);border-radius:8px;background-color:var(--vvd-color-cta-50);color:var(--vvd-color-neutral-600);cursor:pointer;font:var(--vvd-typography-base);gap:8px;inline-size:100%;min-block-size:52px;outline:none;transition:all .3s ease}.control .upload-text{display:flex;align-items:center;justify-content:center;color:var(--vvd-color-neutral-600);isolation:isolate;pointer-events:none;text-align:center;transition:all .3s ease}@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(--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);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}@media (hover: hover){.control:hover{border-color:var(--vvd-color-cta-400);background-color:var(--vvd-color-cta-100);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}}.control:active{box-shadow:0 1px 4px #0000001a;transform:translateY(0)}.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{animation:subtle-pulse 2s ease-in-out infinite;color:var(--vvd-color-cta-600);pointer-events:none;transition:all .3s ease}@media (hover: hover){.control:hover .upload-icon{animation:none;color:var(--vvd-color-cta-700);transform:scale(1.1)}}.control:active .upload-icon{transform:scale(1.05)}.control.drag-hover .upload-icon{animation:none;color:var(--vvd-color-neutral-800);transform:scale(1.15)}@keyframes subtle-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.main{pointer-events:none}.preview{display:grid;box-sizing:border-box;padding:8px;border:1px solid var(--vvd-color-neutral-300);border-radius:8px;background-color:var(--file-picker-list-item-background-color, var(--vvd-color-canvas));grid-template-columns:1fr auto;grid-template-rows:auto auto;inline-size:100%}.preview .details{display:flex;min-width:0;flex-direction:column;max-inline-size:100%}.preview .details .filename{overflow:hidden;color:var(--vvd-color-canvas-text);font:var(--vvd-typography-base);text-overflow:ellipsis;white-space:nowrap}.preview .details .size{color:var(--vvd-color-neutral-600);font:var(--vvd-typography-base-condensed)}.preview .error-message{display:flex;align-items:center;color:var(--vvd-color-alert-600);font:var(--vvd-typography-base-condensed-bold);gap:4px;margin-block-start:4px}.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{display:inline;align-self:center;grid-column:2/-1;grid-row:1/-1}.preview-list{--scrollbar-track-color: transparent;--scrollbar-thumb-color: color-mix(in srgb, var(--vvd-color-neutral-950), transparent 70%)}.preview-list{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{border:0;border-radius:4px;background-color:var(--scrollbar-fallback-track-color, var(--scrollbar-thumb-color))}.preview-list{display:flex;flex-direction:column;gap:12px;margin-block-start:12px;overflow-y:auto}.preview-list:not(:has(.preview)){display:none}.hidden-input{position:absolute;top:0;left:0;width:0;height:0;visibility:hidden}.label-wrapper{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:var(--label-wrapper-gap, 8px)}.label-wrapper[hidden]{display:none}.label-wrapper .label{flex:1 1 auto}.label-wrapper slot[name=contextual-help]::slotted([data-vvd-component=contextual-help]){margin-inline-start:auto}";async function z(a){return a.items?.[0]?.webkitGetAsEntry!=null?await D(a.items):Array.from(a.files)}async function D(a){const r=[];for(const t of a){const e=t.getAsFile();if(e)r.push(Promise.resolve([e]));else{const o=t.webkitGetAsEntry();o&&r.push(g(o,!1))}}return(await Promise.all(r)).flat()}const g=(a,r)=>{const t=o=>new Promise((i,c)=>{o.file(d=>{r&&d.name.substring(0,1)==="."?i([]):i([d])},c)}),e=a.isFile?t(a):a.isDirectory?T(a):Promise.resolve([]);return e.catch(()=>null),e},T=async a=>new Promise((r,t)=>{const e=[],o=a.createReader(),i=()=>{o.readEntries(c=>{for(const d of c)e.push(g(d,!0));c.length?i():r(Promise.all(e).then(d=>d.flat()))},t)};i()});function P(a,r){if(!r)return!0;const t=r.split(","),e=i=>/\/\*$/.test(i),o=i=>i.replace(/\/.*$/,"");for(let i of t)if(i=i.trim(),i.charAt(0)==="."){if(a.name.toLowerCase().endsWith(i.toLowerCase()))return!0}else if(e(i)){if(o(a.type)===o(i))return!0}else if(a.type===i)return!0;return!1}var V=Object.defineProperty,A=Object.getOwnPropertyDescriptor,n=(a,r,t,e)=>{for(var o=e>1?void 0:e?A(r,t):r,i=a.length-1,c;i>=0;i--)(c=a[i])&&(o=(e?c(r,t,o):c(o))||o);return e&&o&&V(r,t,o),o};class s extends F.WithContextualHelp(f.WithFeedback(w.WithErrorText(y.FormElement(m.DelegatesAria(k.Localized(x.FormAssociated(l.VividElement))))))){constructor(){super(...arguments),this.singleFile=!1,this.maxFileSize=256,this.valueChanged=(r,t)=>{super.valueChanged(r,t),t===""&&this.files.length&&this.removeAllFiles()},this.proxy=document.createElement("input"),this.setFormValue=(r,t)=>{typeof r!="string"&&super.setFormValue(r,t)},this._customValidationError=null,this.#e={handleChange:()=>{this._customValidationError=this.#r.observe(this,l.ExecutionContext.default)}},this._dragHover=!1,this._allFiles=[]}nameChanged(r,t){super.nameChanged(r,t),this.#t()}#t(){const r=this.files;if(!this.name)this.setFormValue(null);else{const t=new FormData;for(const e of r)t.append(this.name,e);this.setFormValue(t)}this.#i()}#i(){this.value=this.files.length>0?`C:\\fakepath\\${this.files[0].name}`:""}validate(){super.validate(this.control)}formResetCallback(){this.removeAllFiles(),super.formResetCallback()}#a(){return this.rejectedFiles.length>0?this.locale.filePicker.invalidFilesError:null}_customValidationErrorChanged(){this.proxy&&this.proxy.setCustomValidity(this._customValidationError??""),this.validate()}#e;#r;#l(){this.#r=l.Observable.binding(()=>this.#a(),this.#e,!0),this.#e.handleChange()}#s(){this.#r.dispose()}connectedCallback(){super.connectedCallback(),this.#l()}disconnectedCallback(){super.disconnectedCallback(),this.#s()}_onDragEnter(){return this._dragHover=!0,!0}_onDragOver(r){if(!r.dataTransfer)return!0;const t=r.dataTransfer.effectAllowed;return r.dataTransfer.dropEffect=t==="move"||t==="linkMove"?"move":"copy",!1}_onDragLeave(r){return r.currentTarget===r.target&&(this._dragHover=!1),!0}_onDrop(r){return this._dragHover=!1,r.dataTransfer?(z(r.dataTransfer).then(t=>this.#o(t)).catch(t=>{console.error(t)}),!1):!0}_onDragEnd(){return this._dragHover=!1,!0}_onControlClick(){this._hiddenInput.click()}_onRemoveFileClick(r){this._allFiles=this._allFiles.filter(t=>t!==r),this.$emit("change")}_allFilesChanged(){this.#t()}#o(r){this.singleFile?r.length>0&&(this._allFiles=[r[r.length-1]]):this._allFiles=[...this._allFiles,...r],this.$emit("change")}removeAllFiles(){this._allFiles=[]}get _validatedFiles(){const r=(o,i)=>this.maxFileSize&&o.size>this.maxFileSize*1024*1024?(this.fileTooBigError||this.locale.filePicker.fileTooBigError).replace("{{filesize}}",this._formatNumber(Math.round(o.size/1024/10.24)/100)).replace("{{maxFilesize}}",this._formatNumber(this.maxFileSize)):P(o,this.accept)?typeof this.maxFiles=="number"&&i>=this.maxFiles?(this.maxFilesExceededError||this.locale.filePicker.maxFilesExceededError).replace("{{maxFiles}}",String(this.maxFiles)):null:this.invalidFileTypeError||this.locale.filePicker.invalidFileTypeError,t=[];let e=0;for(const o of this._allFiles){const i={file:o,validationError:r(o,e)};t.push(i),i.validationError||e++}return t}get files(){return this._validatedFiles.filter(r=>!r.validationError).map(r=>r.file)}get rejectedFiles(){return this._validatedFiles.filter(r=>!!r.validationError).map(r=>r.file)}_onHiddenInputChange(r){this.#o(this._hiddenInput.files),this._hiddenInput.value="",r.stopPropagation()}_formatNumber(r){const t=String(r);return this.locale.common.useCommaAsDecimalSeparator?t.replace(".",","):t}}n([l.attr({attribute:"single-file",mode:"boolean"})],s.prototype,"singleFile",2);n([l.attr({attribute:"max-files"})],s.prototype,"maxFiles",2);n([l.attr({mode:"fromView",attribute:"max-file-size"})],s.prototype,"maxFileSize",2);n([l.attr],s.prototype,"accept",2);n([l.attr],s.prototype,"size",2);n([l.attr({attribute:"invalid-file-type-error"})],s.prototype,"invalidFileTypeError",2);n([l.attr({attribute:"max-files-exceeded-error"})],s.prototype,"maxFilesExceededError",2);n([l.attr({attribute:"file-too-big-error"})],s.prototype,"fileTooBigError",2);n([l.observable],s.prototype,"_customValidationError",2);n([l.observable],s.prototype,"_dragHover",2);n([l.observable],s.prototype,"_allFiles",2);n([l.volatile],s.prototype,"_validatedFiles",1);const v=1e3,q={tb:"TB",gb:"GB",mb:"MB",kb:"KB",b:"b"},S=(a,r)=>{let t=0,e="b";if(r>0){const o=["tb","gb","mb","kb","b"];for(let i=0;i<o.length;i++){const c=o[i],d=Math.pow(v,4-i)/10;if(r>=d){t=r/Math.pow(v,4-i),e=c;break}}t=Math.round(10*t)/10}return l.html`<strong>${a._formatNumber(t)}</strong>
|
|
2
|
-
${q[e]}`},H=({size:
|
|
1
|
+
"use strict";const u=require("../bundled/definition2.cjs"),h=require("../bundled/definition3.cjs"),a=require("../bundled/vivid-element.cjs"),f=require("../bundled/mixins.cjs"),m=require("../bundled/delegates-aria.cjs"),x=require("../bundled/form-associated.cjs"),F=require("../bundled/with-contextual-help.cjs"),y=require("../bundled/with-error-text.cjs"),w=require("../bundled/form-element.cjs"),k=require("../bundled/localized.cjs"),_=require("../bundled/when.cjs"),E=require("../bundled/slotted.cjs"),p=require("../bundled/ref.cjs"),C=require("../bundled/repeat.cjs"),b=require("../bundled/class-names.cjs"),$=".label-wrapper{display:flex;flex-direction:row;align-items:center;gap:var(--label-wrapper-gap, 4px)}.label-wrapper[hidden]{display:none}.label:not(slot),.label::slotted(label){flex:0 1 auto}:host{display:block;max-inline-size:400px}.base{display:flex;flex-direction:column;block-size:inherit;max-block-size:inherit;--_low-ink-color: var(--vvd-color-neutral-600)}.control-wrapper{display:flex;flex-direction:column;block-size:inherit;gap:4px;max-block-size:inherit}.control{position:relative;display:flex;box-sizing:border-box;flex-wrap:wrap;align-items:center;justify-content:center;padding:16px;border:1px dashed var(--vvd-color-neutral-400);border-radius:8px;background-color:var(--vvd-color-cta-50);color:var(--vvd-color-neutral-600);cursor:pointer;font:var(--vvd-typography-base);gap:8px;inline-size:100%;min-block-size:52px;outline:none;transition:all .3s ease}.control .upload-text{display:flex;align-items:center;justify-content:center;color:var(--vvd-color-neutral-600);isolation:isolate;pointer-events:none;text-align:center;transition:all .3s ease}@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(--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);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}@media (hover: hover){.control:hover{border-color:var(--vvd-color-cta-400);background-color:var(--vvd-color-cta-100);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}}.control:active{box-shadow:0 1px 4px #0000001a;transform:translateY(0)}.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{animation:subtle-pulse 2s ease-in-out infinite;color:var(--vvd-color-cta-600);pointer-events:none;transition:all .3s ease}@media (hover: hover){.control:hover .upload-icon{animation:none;color:var(--vvd-color-cta-700);transform:scale(1.1)}}.control:active .upload-icon{transform:scale(1.05)}.control.drag-hover .upload-icon{animation:none;color:var(--vvd-color-neutral-800);transform:scale(1.15)}@keyframes subtle-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.main{pointer-events:none}.preview{display:grid;box-sizing:border-box;padding:8px;border:1px solid var(--vvd-color-neutral-300);border-radius:8px;background-color:var(--file-picker-list-item-background-color, var(--vvd-color-canvas));grid-template-columns:1fr auto;grid-template-rows:auto auto;inline-size:100%}.preview .details{display:flex;min-width:0;flex-direction:column;max-inline-size:100%}.preview .details .filename{overflow:hidden;color:var(--vvd-color-canvas-text);font:var(--vvd-typography-base);text-overflow:ellipsis;white-space:nowrap}.preview .details .size{color:var(--vvd-color-neutral-600);font:var(--vvd-typography-base-condensed)}.preview .error-message{display:flex;align-items:center;color:var(--vvd-color-alert-600);font:var(--vvd-typography-base-condensed-bold);gap:4px;margin-block-start:4px}.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{display:inline;align-self:center;grid-column:2/-1;grid-row:1/-1}.preview-list{--scrollbar-track-color: transparent;--scrollbar-thumb-color: color-mix(in srgb, var(--vvd-color-neutral-950), transparent 70%)}.preview-list{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{border:0;border-radius:4px;background-color:var(--scrollbar-fallback-track-color, var(--scrollbar-thumb-color))}.preview-list{display:flex;flex-direction:column;gap:12px;margin-block-start:12px;overflow-y:auto}.preview-list:not(:has(.preview)){display:none}.hidden-input{position:absolute;top:0;left:0;width:0;height:0;visibility:hidden}";async function z(l){return l.items?.[0]?.webkitGetAsEntry!=null?await D(l.items):Array.from(l.files)}async function D(l){const r=[];for(const t of l){const e=t.getAsFile();if(e)r.push(Promise.resolve([e]));else{const o=t.webkitGetAsEntry();o&&r.push(g(o,!1))}}return(await Promise.all(r)).flat()}const g=(l,r)=>{const t=o=>new Promise((i,c)=>{o.file(d=>{r&&d.name.substring(0,1)==="."?i([]):i([d])},c)}),e=l.isFile?t(l):l.isDirectory?T(l):Promise.resolve([]);return e.catch(()=>null),e},T=async l=>new Promise((r,t)=>{const e=[],o=l.createReader(),i=()=>{o.readEntries(c=>{for(const d of c)e.push(g(d,!0));c.length?i():r(Promise.all(e).then(d=>d.flat()))},t)};i()});function P(l,r){if(!r)return!0;const t=r.split(","),e=i=>/\/\*$/.test(i),o=i=>i.replace(/\/.*$/,"");for(let i of t)if(i=i.trim(),i.charAt(0)==="."){if(l.name.toLowerCase().endsWith(i.toLowerCase()))return!0}else if(e(i)){if(o(l.type)===o(i))return!0}else if(l.type===i)return!0;return!1}var V=Object.defineProperty,A=Object.getOwnPropertyDescriptor,n=(l,r,t,e)=>{for(var o=e>1?void 0:e?A(r,t):r,i=l.length-1,c;i>=0;i--)(c=l[i])&&(o=(e?c(r,t,o):c(o))||o);return e&&o&&V(r,t,o),o};class s extends F.WithContextualHelp(f.WithFeedback(y.WithErrorText(w.FormElement(m.DelegatesAria(k.Localized(x.FormAssociated(a.VividElement))))))){constructor(){super(...arguments),this.singleFile=!1,this.maxFileSize=256,this.valueChanged=(r,t)=>{super.valueChanged(r,t),t===""&&this.files.length&&this.removeAllFiles()},this.proxy=document.createElement("input"),this.setFormValue=(r,t)=>{typeof r!="string"&&super.setFormValue(r,t)},this._customValidationError=null,this.#e={handleChange:()=>{this._customValidationError=this.#r.observe(this,a.ExecutionContext.default)}},this._dragHover=!1,this._allFiles=[]}nameChanged(r,t){super.nameChanged(r,t),this.#t()}#t(){const r=this.files;if(!this.name)this.setFormValue(null);else{const t=new FormData;for(const e of r)t.append(this.name,e);this.setFormValue(t)}this.#i()}#i(){this.value=this.files.length>0?`C:\\fakepath\\${this.files[0].name}`:""}validate(){super.validate(this.control)}formResetCallback(){this.removeAllFiles(),super.formResetCallback()}#l(){return this.rejectedFiles.length>0?this.locale.filePicker.invalidFilesError:null}_customValidationErrorChanged(){/* v8 ignore if -- @preserve */this.proxy&&this.proxy.setCustomValidity(this._customValidationError??""),this.validate()}#e;#r;#a(){this.#r=a.Observable.binding(()=>this.#l(),this.#e,!0),this.#e.handleChange()}#s(){this.#r.dispose()}connectedCallback(){super.connectedCallback(),this.#a()}disconnectedCallback(){super.disconnectedCallback(),this.#s()}_onDragEnter(){return this._dragHover=!0,!0}_onDragOver(r){if(!r.dataTransfer)return!0;const t=r.dataTransfer.effectAllowed;return r.dataTransfer.dropEffect=t==="move"||t==="linkMove"?"move":"copy",!1}_onDragLeave(r){/* v8 ignore else -- @preserve */return r.currentTarget===r.target&&(this._dragHover=!1),!0}_onDrop(r){return this._dragHover=!1,r.dataTransfer?(z(r.dataTransfer).then(t=>this.#o(t)).catch(t=>{console.error(t)}),!1):!0}_onDragEnd(){return this._dragHover=!1,!0}_onControlClick(){this._hiddenInput.click()}_onRemoveFileClick(r){this._allFiles=this._allFiles.filter(t=>t!==r),this.$emit("change")}_allFilesChanged(){this.#t()}#o(r){if(this.singleFile){/* v8 ignore else -- @preserve */r.length>0&&(this._allFiles=[r[r.length-1]])}else this._allFiles=[...this._allFiles,...r];this.$emit("change")}removeAllFiles(){this._allFiles=[]}get _validatedFiles(){const r=(o,i)=>this.maxFileSize&&o.size>this.maxFileSize*1024*1024?(this.fileTooBigError||this.locale.filePicker.fileTooBigError).replace("{{filesize}}",this._formatNumber(Math.round(o.size/1024/10.24)/100)).replace("{{maxFilesize}}",this._formatNumber(this.maxFileSize)):P(o,this.accept)?typeof this.maxFiles=="number"&&i>=this.maxFiles?(this.maxFilesExceededError||this.locale.filePicker.maxFilesExceededError).replace("{{maxFiles}}",String(this.maxFiles)):null:this.invalidFileTypeError||this.locale.filePicker.invalidFileTypeError,t=[];let e=0;for(const o of this._allFiles){const i={file:o,validationError:r(o,e)};t.push(i),i.validationError||e++}return t}get files(){return this._validatedFiles.filter(r=>!r.validationError).map(r=>r.file)}get rejectedFiles(){return this._validatedFiles.filter(r=>!!r.validationError).map(r=>r.file)}_onHiddenInputChange(r){this.#o(this._hiddenInput.files),this._hiddenInput.value="",r.stopPropagation()}_formatNumber(r){const t=String(r);return this.locale.common.useCommaAsDecimalSeparator?t.replace(".",","):t}}n([a.attr({attribute:"single-file",mode:"boolean"})],s.prototype,"singleFile",2);n([a.attr({attribute:"max-files"})],s.prototype,"maxFiles",2);n([a.attr({mode:"fromView",attribute:"max-file-size"})],s.prototype,"maxFileSize",2);n([a.attr],s.prototype,"accept",2);n([a.attr],s.prototype,"size",2);n([a.attr({attribute:"invalid-file-type-error"})],s.prototype,"invalidFileTypeError",2);n([a.attr({attribute:"max-files-exceeded-error"})],s.prototype,"maxFilesExceededError",2);n([a.attr({attribute:"file-too-big-error"})],s.prototype,"fileTooBigError",2);n([a.observable],s.prototype,"_customValidationError",2);n([a.observable],s.prototype,"_dragHover",2);n([a.observable],s.prototype,"_allFiles",2);n([a.volatile],s.prototype,"_validatedFiles",1);const v=1e3,q={tb:"TB",gb:"GB",mb:"MB",kb:"KB",b:"b"},S=(l,r)=>{let t=0,e="b";/* v8 ignore else -- @preserve */if(r>0){const o=["tb","gb","mb","kb","b"];for(let i=0;i<o.length;i++){const c=o[i],d=Math.pow(v,4-i)/10;if(r>=d){t=r/Math.pow(v,4-i),e=c;break}}t=Math.round(10*t)/10}return a.html`<strong>${l._formatNumber(t)}</strong>
|
|
2
|
+
${q[e]}`},H=({size:l,_dragHover:r})=>b.classNames("control",[`size-${l}`,!!l],["drag-hover",r]),B=l=>{const r=l.tagFor(u.Icon),t=l.tagFor(h.Button);return a.html`
|
|
3
3
|
<div class="base">
|
|
4
4
|
<div class="label-wrapper" ?hidden=${e=>!e.label&&!e._hasContextualHelp}>
|
|
5
|
-
${_.when(e=>e.label,
|
|
5
|
+
${_.when(e=>e.label,a.html`<label class="label">${e=>e.label}</label>`)}
|
|
6
6
|
<slot name="contextual-help" ${E.slotted("_contextualHelpSlottedContent")}></slot>
|
|
7
7
|
</div>
|
|
8
8
|
<div class="control-wrapper">
|
|
@@ -28,10 +28,10 @@
|
|
|
28
28
|
></vwc-icon>
|
|
29
29
|
<span class="upload-text"><slot></slot></span>
|
|
30
30
|
</button>
|
|
31
|
-
${e=>e._getFeedbackTemplate(
|
|
31
|
+
${e=>e._getFeedbackTemplate(l)}
|
|
32
32
|
</div>
|
|
33
33
|
<div class="preview-list">
|
|
34
|
-
${C.repeat(e=>e._validatedFiles,
|
|
34
|
+
${C.repeat(e=>e._validatedFiles,a.html`
|
|
35
35
|
<div class="${e=>b.classNames("preview",["has-error",!!e.validationError])}">
|
|
36
36
|
<div class="details">
|
|
37
37
|
<div class="filename">${e=>e.file.name}</div>
|
|
@@ -58,4 +58,4 @@
|
|
|
58
58
|
tabindex="-1"
|
|
59
59
|
@change="${(e,o)=>e._onHiddenInputChange(o.event)}"
|
|
60
60
|
/>
|
|
61
|
-
`},O=
|
|
61
|
+
`},O=a.defineVividComponent("file-picker",s,B,[u.iconDefinition,h.buttonDefinition,f.feedbackMessageDefinition],{styles:$,shadowOptions:{delegatesFocus:!0}}),I=a.createRegisterFunction(O);I();
|
package/file-picker/index.js
CHANGED
|
@@ -12,60 +12,60 @@ import { w as H } from "../bundled/when.js";
|
|
|
12
12
|
import { s as O } from "../bundled/slotted.js";
|
|
13
13
|
import { r as u } from "../bundled/ref.js";
|
|
14
14
|
import { r as I } from "../bundled/repeat.js";
|
|
15
|
-
import { c as
|
|
16
|
-
const L = ":host{display:block;max-inline-size:400px}.base{display:flex;flex-direction:column;block-size:inherit;max-block-size:inherit;--_low-ink-color: var(--vvd-color-neutral-600)}.control-wrapper{display:flex;flex-direction:column;block-size:inherit;gap:4px;max-block-size:inherit}.control{position:relative;display:flex;box-sizing:border-box;flex-wrap:wrap;align-items:center;justify-content:center;padding:16px;border:1px dashed var(--vvd-color-neutral-400);border-radius:8px;background-color:var(--vvd-color-cta-50);color:var(--vvd-color-neutral-600);cursor:pointer;font:var(--vvd-typography-base);gap:8px;inline-size:100%;min-block-size:52px;outline:none;transition:all .3s ease}.control .upload-text{display:flex;align-items:center;justify-content:center;color:var(--vvd-color-neutral-600);isolation:isolate;pointer-events:none;text-align:center;transition:all .3s ease}@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(--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);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}@media (hover: hover){.control:hover{border-color:var(--vvd-color-cta-400);background-color:var(--vvd-color-cta-100);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}}.control:active{box-shadow:0 1px 4px #0000001a;transform:translateY(0)}.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{animation:subtle-pulse 2s ease-in-out infinite;color:var(--vvd-color-cta-600);pointer-events:none;transition:all .3s ease}@media (hover: hover){.control:hover .upload-icon{animation:none;color:var(--vvd-color-cta-700);transform:scale(1.1)}}.control:active .upload-icon{transform:scale(1.05)}.control.drag-hover .upload-icon{animation:none;color:var(--vvd-color-neutral-800);transform:scale(1.15)}@keyframes subtle-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.main{pointer-events:none}.preview{display:grid;box-sizing:border-box;padding:8px;border:1px solid var(--vvd-color-neutral-300);border-radius:8px;background-color:var(--file-picker-list-item-background-color, var(--vvd-color-canvas));grid-template-columns:1fr auto;grid-template-rows:auto auto;inline-size:100%}.preview .details{display:flex;min-width:0;flex-direction:column;max-inline-size:100%}.preview .details .filename{overflow:hidden;color:var(--vvd-color-canvas-text);font:var(--vvd-typography-base);text-overflow:ellipsis;white-space:nowrap}.preview .details .size{color:var(--vvd-color-neutral-600);font:var(--vvd-typography-base-condensed)}.preview .error-message{display:flex;align-items:center;color:var(--vvd-color-alert-600);font:var(--vvd-typography-base-condensed-bold);gap:4px;margin-block-start:4px}.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{display:inline;align-self:center;grid-column:2/-1;grid-row:1/-1}.preview-list{--scrollbar-track-color: transparent;--scrollbar-thumb-color: color-mix(in srgb, var(--vvd-color-neutral-950), transparent 70%)}.preview-list{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{border:0;border-radius:4px;background-color:var(--scrollbar-fallback-track-color, var(--scrollbar-thumb-color))}.preview-list{display:flex;flex-direction:column;gap:12px;margin-block-start:12px;overflow-y:auto}.preview-list:not(:has(.preview)){display:none}.hidden-input{position:absolute;top:0;left:0;width:0;height:0;visibility:hidden}
|
|
17
|
-
async function j(a) {
|
|
18
|
-
return a.items?.[0]?.webkitGetAsEntry != null ? await M(a.items) : Array.from(a.files);
|
|
19
|
-
}
|
|
15
|
+
import { c as m } from "../bundled/class-names.js";
|
|
16
|
+
const L = ".label-wrapper{display:flex;flex-direction:row;align-items:center;gap:var(--label-wrapper-gap, 4px)}.label-wrapper[hidden]{display:none}.label:not(slot),.label::slotted(label){flex:0 1 auto}:host{display:block;max-inline-size:400px}.base{display:flex;flex-direction:column;block-size:inherit;max-block-size:inherit;--_low-ink-color: var(--vvd-color-neutral-600)}.control-wrapper{display:flex;flex-direction:column;block-size:inherit;gap:4px;max-block-size:inherit}.control{position:relative;display:flex;box-sizing:border-box;flex-wrap:wrap;align-items:center;justify-content:center;padding:16px;border:1px dashed var(--vvd-color-neutral-400);border-radius:8px;background-color:var(--vvd-color-cta-50);color:var(--vvd-color-neutral-600);cursor:pointer;font:var(--vvd-typography-base);gap:8px;inline-size:100%;min-block-size:52px;outline:none;transition:all .3s ease}.control .upload-text{display:flex;align-items:center;justify-content:center;color:var(--vvd-color-neutral-600);isolation:isolate;pointer-events:none;text-align:center;transition:all .3s ease}@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(--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);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}@media (hover: hover){.control:hover{border-color:var(--vvd-color-cta-400);background-color:var(--vvd-color-cta-100);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}}.control:active{box-shadow:0 1px 4px #0000001a;transform:translateY(0)}.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{animation:subtle-pulse 2s ease-in-out infinite;color:var(--vvd-color-cta-600);pointer-events:none;transition:all .3s ease}@media (hover: hover){.control:hover .upload-icon{animation:none;color:var(--vvd-color-cta-700);transform:scale(1.1)}}.control:active .upload-icon{transform:scale(1.05)}.control.drag-hover .upload-icon{animation:none;color:var(--vvd-color-neutral-800);transform:scale(1.15)}@keyframes subtle-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.main{pointer-events:none}.preview{display:grid;box-sizing:border-box;padding:8px;border:1px solid var(--vvd-color-neutral-300);border-radius:8px;background-color:var(--file-picker-list-item-background-color, var(--vvd-color-canvas));grid-template-columns:1fr auto;grid-template-rows:auto auto;inline-size:100%}.preview .details{display:flex;min-width:0;flex-direction:column;max-inline-size:100%}.preview .details .filename{overflow:hidden;color:var(--vvd-color-canvas-text);font:var(--vvd-typography-base);text-overflow:ellipsis;white-space:nowrap}.preview .details .size{color:var(--vvd-color-neutral-600);font:var(--vvd-typography-base-condensed)}.preview .error-message{display:flex;align-items:center;color:var(--vvd-color-alert-600);font:var(--vvd-typography-base-condensed-bold);gap:4px;margin-block-start:4px}.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{display:inline;align-self:center;grid-column:2/-1;grid-row:1/-1}.preview-list{--scrollbar-track-color: transparent;--scrollbar-thumb-color: color-mix(in srgb, var(--vvd-color-neutral-950), transparent 70%)}.preview-list{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{border:0;border-radius:4px;background-color:var(--scrollbar-fallback-track-color, var(--scrollbar-thumb-color))}.preview-list{display:flex;flex-direction:column;gap:12px;margin-block-start:12px;overflow-y:auto}.preview-list:not(:has(.preview)){display:none}.hidden-input{position:absolute;top:0;left:0;width:0;height:0;visibility:hidden}";
|
|
20
17
|
async function M(a) {
|
|
18
|
+
return a.items?.[0]?.webkitGetAsEntry != null ? await R(a.items) : Array.from(a.files);
|
|
19
|
+
}
|
|
20
|
+
async function R(a) {
|
|
21
21
|
const r = [];
|
|
22
|
-
for (const
|
|
23
|
-
const e =
|
|
22
|
+
for (const o of a) {
|
|
23
|
+
const e = o.getAsFile();
|
|
24
24
|
if (e)
|
|
25
25
|
r.push(Promise.resolve([e]));
|
|
26
26
|
else {
|
|
27
|
-
const
|
|
28
|
-
|
|
27
|
+
const t = o.webkitGetAsEntry();
|
|
28
|
+
t && r.push(h(t, !1));
|
|
29
29
|
}
|
|
30
30
|
}
|
|
31
31
|
return (await Promise.all(r)).flat();
|
|
32
32
|
}
|
|
33
33
|
const h = (a, r) => {
|
|
34
|
-
const
|
|
35
|
-
|
|
34
|
+
const o = (t) => new Promise((i, n) => {
|
|
35
|
+
t.file((c) => {
|
|
36
36
|
r && c.name.substring(0, 1) === "." ? i([]) : i([c]);
|
|
37
37
|
}, n);
|
|
38
|
-
}), e = a.isFile ?
|
|
38
|
+
}), e = a.isFile ? o(a) : a.isDirectory ? W(a) : Promise.resolve([]);
|
|
39
39
|
return e.catch(() => null), e;
|
|
40
|
-
},
|
|
41
|
-
const e = [],
|
|
42
|
-
|
|
40
|
+
}, W = async (a) => new Promise((r, o) => {
|
|
41
|
+
const e = [], t = a.createReader(), i = () => {
|
|
42
|
+
t.readEntries((n) => {
|
|
43
43
|
for (const c of n)
|
|
44
44
|
e.push(h(c, !0));
|
|
45
45
|
n.length ? i() : r(Promise.all(e).then((c) => c.flat()));
|
|
46
|
-
},
|
|
46
|
+
}, o);
|
|
47
47
|
};
|
|
48
48
|
i();
|
|
49
49
|
});
|
|
50
|
-
function
|
|
50
|
+
function j(a, r) {
|
|
51
51
|
if (!r)
|
|
52
52
|
return !0;
|
|
53
|
-
const
|
|
54
|
-
for (let i of
|
|
53
|
+
const o = r.split(","), e = (i) => /\/\*$/.test(i), t = (i) => i.replace(/\/.*$/, "");
|
|
54
|
+
for (let i of o)
|
|
55
55
|
if (i = i.trim(), i.charAt(0) === ".") {
|
|
56
56
|
if (a.name.toLowerCase().endsWith(i.toLowerCase()))
|
|
57
57
|
return !0;
|
|
58
58
|
} else if (e(i)) {
|
|
59
|
-
if (
|
|
59
|
+
if (t(a.type) === t(i))
|
|
60
60
|
return !0;
|
|
61
61
|
} else if (a.type === i)
|
|
62
62
|
return !0;
|
|
63
63
|
return !1;
|
|
64
64
|
}
|
|
65
|
-
var N = Object.defineProperty, G = Object.getOwnPropertyDescriptor, s = (a, r,
|
|
66
|
-
for (var
|
|
67
|
-
(n = a[i]) && (
|
|
68
|
-
return e &&
|
|
65
|
+
var N = Object.defineProperty, G = Object.getOwnPropertyDescriptor, s = (a, r, o, e) => {
|
|
66
|
+
for (var t = e > 1 ? void 0 : e ? G(r, o) : r, i = a.length - 1, n; i >= 0; i--)
|
|
67
|
+
(n = a[i]) && (t = (e ? n(r, o, t) : n(t)) || t);
|
|
68
|
+
return e && t && N(r, o, t), t;
|
|
69
69
|
};
|
|
70
70
|
class l extends V(
|
|
71
71
|
$(
|
|
@@ -75,10 +75,10 @@ class l extends V(
|
|
|
75
75
|
)
|
|
76
76
|
) {
|
|
77
77
|
constructor() {
|
|
78
|
-
super(...arguments), this.singleFile = !1, this.maxFileSize = 256, this.valueChanged = (r,
|
|
79
|
-
super.valueChanged(r,
|
|
80
|
-
}, this.proxy = document.createElement("input"), this.setFormValue = (r,
|
|
81
|
-
typeof r != "string" && super.setFormValue(r,
|
|
78
|
+
super(...arguments), this.singleFile = !1, this.maxFileSize = 256, this.valueChanged = (r, o) => {
|
|
79
|
+
super.valueChanged(r, o), o === "" && this.files.length && this.removeAllFiles();
|
|
80
|
+
}, this.proxy = document.createElement("input"), this.setFormValue = (r, o) => {
|
|
81
|
+
typeof r != "string" && super.setFormValue(r, o);
|
|
82
82
|
}, this._customValidationError = null, this.#e = {
|
|
83
83
|
handleChange: () => {
|
|
84
84
|
this._customValidationError = this.#r.observe(
|
|
@@ -91,18 +91,18 @@ class l extends V(
|
|
|
91
91
|
/**
|
|
92
92
|
* @internal
|
|
93
93
|
*/
|
|
94
|
-
nameChanged(r,
|
|
95
|
-
super.nameChanged(r,
|
|
94
|
+
nameChanged(r, o) {
|
|
95
|
+
super.nameChanged(r, o), this.#o();
|
|
96
96
|
}
|
|
97
|
-
#
|
|
97
|
+
#o() {
|
|
98
98
|
const r = this.files;
|
|
99
99
|
if (!this.name)
|
|
100
100
|
this.setFormValue(null);
|
|
101
101
|
else {
|
|
102
|
-
const
|
|
102
|
+
const o = new FormData();
|
|
103
103
|
for (const e of r)
|
|
104
|
-
|
|
105
|
-
this.setFormValue(
|
|
104
|
+
o.append(this.name, e);
|
|
105
|
+
this.setFormValue(o);
|
|
106
106
|
}
|
|
107
107
|
this.#i();
|
|
108
108
|
}
|
|
@@ -126,6 +126,7 @@ class l extends V(
|
|
|
126
126
|
* @internal
|
|
127
127
|
*/
|
|
128
128
|
_customValidationErrorChanged() {
|
|
129
|
+
/* v8 ignore if -- @preserve */
|
|
129
130
|
this.proxy && this.proxy.setCustomValidity(this._customValidationError ?? ""), this.validate();
|
|
130
131
|
}
|
|
131
132
|
#e;
|
|
@@ -158,21 +159,22 @@ class l extends V(
|
|
|
158
159
|
_onDragOver(r) {
|
|
159
160
|
if (!r.dataTransfer)
|
|
160
161
|
return !0;
|
|
161
|
-
const
|
|
162
|
-
return r.dataTransfer.dropEffect =
|
|
162
|
+
const o = r.dataTransfer.effectAllowed;
|
|
163
|
+
return r.dataTransfer.dropEffect = o === "move" || o === "linkMove" ? "move" : "copy", !1;
|
|
163
164
|
}
|
|
164
165
|
/**
|
|
165
166
|
* @internal
|
|
166
167
|
*/
|
|
167
168
|
_onDragLeave(r) {
|
|
169
|
+
/* v8 ignore else -- @preserve */
|
|
168
170
|
return r.currentTarget === r.target && (this._dragHover = !1), !0;
|
|
169
171
|
}
|
|
170
172
|
/**
|
|
171
173
|
* @internal
|
|
172
174
|
*/
|
|
173
175
|
_onDrop(r) {
|
|
174
|
-
return this._dragHover = !1, r.dataTransfer ? (
|
|
175
|
-
console.error(
|
|
176
|
+
return this._dragHover = !1, r.dataTransfer ? (M(r.dataTransfer).then((o) => this.#t(o)).catch((o) => {
|
|
177
|
+
console.error(o);
|
|
176
178
|
}), !1) : !0;
|
|
177
179
|
}
|
|
178
180
|
/**
|
|
@@ -191,16 +193,21 @@ class l extends V(
|
|
|
191
193
|
* @internal
|
|
192
194
|
*/
|
|
193
195
|
_onRemoveFileClick(r) {
|
|
194
|
-
this._allFiles = this._allFiles.filter((
|
|
196
|
+
this._allFiles = this._allFiles.filter((o) => o !== r), this.$emit("change");
|
|
195
197
|
}
|
|
196
198
|
/**
|
|
197
199
|
* @internal
|
|
198
200
|
*/
|
|
199
201
|
_allFilesChanged() {
|
|
200
|
-
this.#
|
|
202
|
+
this.#o();
|
|
201
203
|
}
|
|
202
|
-
#
|
|
203
|
-
|
|
204
|
+
#t(r) {
|
|
205
|
+
if (this.singleFile) {
|
|
206
|
+
/* v8 ignore else -- @preserve */
|
|
207
|
+
r.length > 0 && (this._allFiles = [r[r.length - 1]]);
|
|
208
|
+
} else
|
|
209
|
+
this._allFiles = [...this._allFiles, ...r];
|
|
210
|
+
this.$emit("change");
|
|
204
211
|
}
|
|
205
212
|
/**
|
|
206
213
|
* Removes all files from the File Picker.
|
|
@@ -209,19 +216,19 @@ class l extends V(
|
|
|
209
216
|
this._allFiles = [];
|
|
210
217
|
}
|
|
211
218
|
get _validatedFiles() {
|
|
212
|
-
const r = (
|
|
219
|
+
const r = (t, i) => this.maxFileSize && t.size > this.maxFileSize * 1024 * 1024 ? (this.fileTooBigError || this.locale.filePicker.fileTooBigError).replace(
|
|
213
220
|
"{{filesize}}",
|
|
214
|
-
this._formatNumber(Math.round(
|
|
215
|
-
).replace("{{maxFilesize}}", this._formatNumber(this.maxFileSize)) :
|
|
221
|
+
this._formatNumber(Math.round(t.size / 1024 / 10.24) / 100)
|
|
222
|
+
).replace("{{maxFilesize}}", this._formatNumber(this.maxFileSize)) : j(t, this.accept) ? typeof this.maxFiles == "number" && i >= this.maxFiles ? (this.maxFilesExceededError || this.locale.filePicker.maxFilesExceededError).replace("{{maxFiles}}", String(this.maxFiles)) : null : this.invalidFileTypeError || this.locale.filePicker.invalidFileTypeError, o = [];
|
|
216
223
|
let e = 0;
|
|
217
|
-
for (const
|
|
224
|
+
for (const t of this._allFiles) {
|
|
218
225
|
const i = {
|
|
219
|
-
file:
|
|
220
|
-
validationError: r(
|
|
226
|
+
file: t,
|
|
227
|
+
validationError: r(t, e)
|
|
221
228
|
};
|
|
222
|
-
|
|
229
|
+
o.push(i), i.validationError || e++;
|
|
223
230
|
}
|
|
224
|
-
return
|
|
231
|
+
return o;
|
|
225
232
|
}
|
|
226
233
|
/**
|
|
227
234
|
* Files that have been added to the file picker and passed validation.
|
|
@@ -243,14 +250,14 @@ class l extends V(
|
|
|
243
250
|
* @internal
|
|
244
251
|
*/
|
|
245
252
|
_onHiddenInputChange(r) {
|
|
246
|
-
this.#
|
|
253
|
+
this.#t(this._hiddenInput.files), this._hiddenInput.value = "", r.stopPropagation();
|
|
247
254
|
}
|
|
248
255
|
/**
|
|
249
256
|
* @internal
|
|
250
257
|
*/
|
|
251
258
|
_formatNumber(r) {
|
|
252
|
-
const
|
|
253
|
-
return this.locale.common.useCommaAsDecimalSeparator ?
|
|
259
|
+
const o = String(r);
|
|
260
|
+
return this.locale.common.useCommaAsDecimalSeparator ? o.replace(".", ",") : o;
|
|
254
261
|
}
|
|
255
262
|
}
|
|
256
263
|
s([
|
|
@@ -289,27 +296,28 @@ s([
|
|
|
289
296
|
s([
|
|
290
297
|
_
|
|
291
298
|
], l.prototype, "_validatedFiles", 1);
|
|
292
|
-
const
|
|
293
|
-
let
|
|
299
|
+
const f = 1e3, Y = { tb: "TB", gb: "GB", mb: "MB", kb: "KB", b: "b" }, U = (a, r) => {
|
|
300
|
+
let o = 0, e = "b";
|
|
301
|
+
/* v8 ignore else -- @preserve */
|
|
294
302
|
if (r > 0) {
|
|
295
|
-
const
|
|
296
|
-
for (let i = 0; i <
|
|
297
|
-
const n =
|
|
303
|
+
const t = ["tb", "gb", "mb", "kb", "b"];
|
|
304
|
+
for (let i = 0; i < t.length; i++) {
|
|
305
|
+
const n = t[i], c = Math.pow(f, 4 - i) / 10;
|
|
298
306
|
if (r >= c) {
|
|
299
|
-
|
|
307
|
+
o = r / Math.pow(f, 4 - i), e = n;
|
|
300
308
|
break;
|
|
301
309
|
}
|
|
302
310
|
}
|
|
303
|
-
|
|
311
|
+
o = Math.round(10 * o) / 10;
|
|
304
312
|
}
|
|
305
|
-
return p`<strong>${a._formatNumber(
|
|
313
|
+
return p`<strong>${a._formatNumber(o)}</strong>
|
|
306
314
|
${Y[e]}`;
|
|
307
|
-
}, K = ({ size: a, _dragHover: r }) =>
|
|
315
|
+
}, K = ({ size: a, _dragHover: r }) => m(
|
|
308
316
|
"control",
|
|
309
317
|
[`size-${a}`, !!a],
|
|
310
318
|
["drag-hover", r]
|
|
311
319
|
), q = (a) => {
|
|
312
|
-
const r = a.tagFor(b),
|
|
320
|
+
const r = a.tagFor(b), o = a.tagFor(x);
|
|
313
321
|
return p`
|
|
314
322
|
<div class="base">
|
|
315
323
|
<div class="label-wrapper" ?hidden=${(e) => !e.label && !e._hasContextualHelp}>
|
|
@@ -325,11 +333,12 @@ const m = 1e3, Y = { tb: "TB", gb: "GB", mb: "MB", kb: "KB", b: "b" }, U = (a, r
|
|
|
325
333
|
${u("control")}
|
|
326
334
|
class="${K}"
|
|
327
335
|
@click="${(e) => e._onControlClick()}"
|
|
328
|
-
@keydown"${
|
|
336
|
+
@keydown"${/* v8 ignore next -- @preserve -- Prevent implicit form submission on Enter */
|
|
337
|
+
() => !1}"
|
|
329
338
|
@dragenter="${(e) => e._onDragEnter()}"
|
|
330
|
-
@dragover="${(e,
|
|
331
|
-
@dragleave="${(e,
|
|
332
|
-
@drop="${(e,
|
|
339
|
+
@dragover="${(e, t) => e._onDragOver(t.event)}"
|
|
340
|
+
@dragleave="${(e, t) => e._onDragLeave(t.event)}"
|
|
341
|
+
@drop="${(e, t) => e._onDrop(t.event)}"
|
|
333
342
|
@dragend="${(e) => e._onDragEnd()}"
|
|
334
343
|
aria-describedby="${(e) => e._feedbackDescribedBy}"
|
|
335
344
|
${P()}
|
|
@@ -348,19 +357,19 @@ const m = 1e3, Y = { tb: "TB", gb: "GB", mb: "MB", kb: "KB", b: "b" }, U = (a, r
|
|
|
348
357
|
${I(
|
|
349
358
|
(e) => e._validatedFiles,
|
|
350
359
|
p`
|
|
351
|
-
<div class="${(e) =>
|
|
360
|
+
<div class="${(e) => m("preview", ["has-error", !!e.validationError])}">
|
|
352
361
|
<div class="details">
|
|
353
362
|
<div class="filename">${(e) => e.file.name}</div>
|
|
354
|
-
<div class="size">${(e,
|
|
363
|
+
<div class="size">${(e, t) => U(t.parent, e.file.size)}</div>
|
|
355
364
|
</div>
|
|
356
365
|
<div class="error-message">
|
|
357
366
|
<${r} name="info-line" size="-6"></${r}>
|
|
358
367
|
${(e) => e.validationError}
|
|
359
368
|
</div>
|
|
360
|
-
<${
|
|
369
|
+
<${o}
|
|
361
370
|
class="remove-btn" icon="delete-line" appearance="ghost-light" size="condensed"
|
|
362
|
-
aria-label="${(e,
|
|
363
|
-
@click="${(e,
|
|
371
|
+
aria-label="${(e, t) => t.parent.locale.filePicker.removeFileLabel}"
|
|
372
|
+
@click="${(e, t) => t.parent._onRemoveFileClick(e.file)}"></${o}>
|
|
364
373
|
</div>`
|
|
365
374
|
)}
|
|
366
375
|
</div>
|
|
@@ -373,7 +382,7 @@ const m = 1e3, Y = { tb: "TB", gb: "GB", mb: "MB", kb: "KB", b: "b" }, U = (a, r
|
|
|
373
382
|
?multiple="${(e) => !e.singleFile && (!e.maxFiles || e.maxFiles > 1)}"
|
|
374
383
|
accept="${(e) => e.accept || null}"
|
|
375
384
|
tabindex="-1"
|
|
376
|
-
@change="${(e,
|
|
385
|
+
@change="${(e, t) => e._onHiddenInputChange(t.event)}"
|
|
377
386
|
/>
|
|
378
387
|
`;
|
|
379
388
|
}, J = C(
|
package/icon/definition.cjs
CHANGED
|
@@ -44,13 +44,12 @@ const PLACEHOLDER_ICON = `<svg width="80%" height="80%" viewBox="0 0 64 64">
|
|
|
44
44
|
</svg>`;
|
|
45
45
|
|
|
46
46
|
var __defProp = Object.defineProperty;
|
|
47
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
48
47
|
var __decorateClass = (decorators, target, key, kind) => {
|
|
49
|
-
var result =
|
|
48
|
+
var result = void 0 ;
|
|
50
49
|
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
51
50
|
if (decorator = decorators[i])
|
|
52
|
-
result = (
|
|
53
|
-
if (
|
|
51
|
+
result = (decorator(target, key, result) ) || result;
|
|
52
|
+
if (result) __defProp(target, key, result);
|
|
54
53
|
return result;
|
|
55
54
|
};
|
|
56
55
|
const PLACEHOLDER_DELAY = 500;
|
|
@@ -102,10 +101,6 @@ class Icon extends vividElement.VividElement {
|
|
|
102
101
|
this.#abortController = null;
|
|
103
102
|
}
|
|
104
103
|
#currentRequestId;
|
|
105
|
-
get iconUrl() {
|
|
106
|
-
const key = normalizeKey(this.name);
|
|
107
|
-
return key ? baseUrlTemplate(`${key}.svg`, ICONS_VERSION) : this._svg;
|
|
108
|
-
}
|
|
109
104
|
#abortController;
|
|
110
105
|
async nameChanged() {
|
|
111
106
|
const requestId = ++this.#currentRequestId;
|
|
@@ -116,9 +111,11 @@ class Icon extends vividElement.VividElement {
|
|
|
116
111
|
this._svg = void 0;
|
|
117
112
|
this.iconLoaded = false;
|
|
118
113
|
let timeout = setTimeout(() => {
|
|
114
|
+
/* v8 ignore else -- @preserve */
|
|
119
115
|
if (this.#currentRequestId === requestId) {
|
|
120
116
|
this._svg = PLACEHOLDER_ICON;
|
|
121
117
|
timeout = setTimeout(() => {
|
|
118
|
+
/* v8 ignore else -- @preserve */
|
|
122
119
|
if (this.#currentRequestId === requestId && this._svg === PLACEHOLDER_ICON) {
|
|
123
120
|
this._svg = void 0;
|
|
124
121
|
}
|
|
@@ -127,6 +124,7 @@ class Icon extends vividElement.VividElement {
|
|
|
127
124
|
}, PLACEHOLDER_DELAY);
|
|
128
125
|
try {
|
|
129
126
|
const svg = await resolveIcon(this.name, this.#abortController.signal);
|
|
127
|
+
/* v8 ignore else -- @preserve */
|
|
130
128
|
if (this.#currentRequestId === requestId) {
|
|
131
129
|
this._svg = svg;
|
|
132
130
|
}
|
|
@@ -144,25 +142,22 @@ class Icon extends vividElement.VividElement {
|
|
|
144
142
|
}
|
|
145
143
|
__decorateClass([
|
|
146
144
|
fastElement.attr
|
|
147
|
-
], Icon.prototype, "connotation"
|
|
145
|
+
], Icon.prototype, "connotation");
|
|
148
146
|
__decorateClass([
|
|
149
147
|
fastElement.attr({ converter: numberConverter })
|
|
150
|
-
], Icon.prototype, "size"
|
|
148
|
+
], Icon.prototype, "size");
|
|
151
149
|
__decorateClass([
|
|
152
150
|
fastElement.observable
|
|
153
|
-
], Icon.prototype, "_svg"
|
|
151
|
+
], Icon.prototype, "_svg");
|
|
154
152
|
__decorateClass([
|
|
155
153
|
fastElement.observable
|
|
156
|
-
], Icon.prototype, "iconLoaded"
|
|
154
|
+
], Icon.prototype, "iconLoaded");
|
|
157
155
|
__decorateClass([
|
|
158
156
|
fastElement.attr
|
|
159
|
-
], Icon.prototype, "label"
|
|
157
|
+
], Icon.prototype, "label");
|
|
160
158
|
__decorateClass([
|
|
161
159
|
fastElement.attr
|
|
162
|
-
], Icon.prototype, "name"
|
|
163
|
-
__decorateClass([
|
|
164
|
-
fastElement.volatile
|
|
165
|
-
], Icon.prototype, "iconUrl", 1);
|
|
160
|
+
], Icon.prototype, "name");
|
|
166
161
|
|
|
167
162
|
const getClasses = ({ connotation, size }) => fastWebUtilities.classNames(
|
|
168
163
|
"control",
|
|
@@ -180,10 +175,6 @@ const iconTemplate = (context) => {
|
|
|
180
175
|
>
|
|
181
176
|
<slot>
|
|
182
177
|
${fastElement.when(
|
|
183
|
-
(x) => !x?.iconLoaded,
|
|
184
|
-
fastElement.html`<img alt="${(x) => x?.name}" src="${(x) => x?.iconUrl}" />`
|
|
185
|
-
)}
|
|
186
|
-
${fastElement.when(
|
|
187
178
|
(x) => x?.iconLoaded && x?._svg,
|
|
188
179
|
(x) => fastElement.html`${fastElement.html.partial(x._svg)}`
|
|
189
180
|
)}
|
package/icon/definition.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { V as VividElement, d as defineVividComponent, c as createRegisterFunction } from '../unbundled/vivid-element.js';
|
|
2
2
|
import { VwcVisuallyHiddenElement as VisuallyHidden, visuallyHiddenDefinition } from '../visually-hidden/definition.js';
|
|
3
|
-
import { attr, observable,
|
|
3
|
+
import { attr, observable, when, html } from '@microsoft/fast-element';
|
|
4
4
|
import { classNames } from '@microsoft/fast-web-utilities';
|
|
5
5
|
|
|
6
6
|
const styles = ":host{display:inline-block;vertical-align:sub}.control.connotation-accent{--_connotation-color-primary: var(--vvd-icon-accent-primary, var(--vvd-color-canvas-text))}.control.connotation-announcement{--_connotation-color-primary: var(--vvd-icon-announcement-primary, var(--vvd-color-announcement-500))}.control.connotation-cta{--_connotation-color-primary: var(--vvd-icon-cta-primary, var(--vvd-color-cta-500))}.control.connotation-success{--_connotation-color-primary: var(--vvd-icon-success-primary, var(--vvd-color-success-500))}.control.connotation-warning{--_connotation-color-primary: var(--vvd-icon-warning-primary, var(--vvd-color-warning-300))}.control.connotation-alert{--_connotation-color-primary: var(--vvd-icon-alert-primary, var(--vvd-color-alert-500))}.control.connotation-information{--_connotation-color-primary: var(--vvd-icon-information-primary, var(--vvd-color-information-500))}.control.size--6{--_icon-block-size: calc(1px*(40 + 4*clamp(-1, var(--vvd-size-density, 0), 2)) - (1px*(24 + 4*clamp(-1, var(--vvd-size-density, 0), 2)))) }.control.size--5{--_icon-block-size: calc(1px*(20 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size--4{--_icon-block-size: calc(1px*(24 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size--3{--_icon-block-size: calc(1px*(28 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size--2{--_icon-block-size: calc(1px*(32 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size--1{--_icon-block-size: calc(1px*(36 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size-0{--_icon-block-size: calc(1px*(40 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size-1{--_icon-block-size: calc(1px*(44 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size-2{--_icon-block-size: calc(1px*(48 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size-3{--_icon-block-size: calc(1px*(52 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size-4{--_icon-block-size: calc(1px*(56 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control.size-5{--_icon-block-size: calc(1px*(60 + 4*clamp(-1, var(--vvd-size-density, 0), 2))) }.control:not(.size--6,.size--5,.size--4,.size--3,.size--2,.size--1,.size-0,.size-1,.size-2,.size-3,.size-4,.size-5){--_icon-block-size: 1em}.control{display:flex;margin:unset;block-size:var(--_icon-block-size);color:currentColor;contain:strict;inline-size:var(--_icon-block-size)}.control[class*=connotation]{color:var(--_connotation-color-primary)}slot,svg,::slotted(:where(svg,img)){margin:auto;block-size:inherit;inline-size:inherit}";
|
|
@@ -40,13 +40,12 @@ const PLACEHOLDER_ICON = `<svg width="80%" height="80%" viewBox="0 0 64 64">
|
|
|
40
40
|
</svg>`;
|
|
41
41
|
|
|
42
42
|
var __defProp = Object.defineProperty;
|
|
43
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
44
43
|
var __decorateClass = (decorators, target, key, kind) => {
|
|
45
|
-
var result =
|
|
44
|
+
var result = void 0 ;
|
|
46
45
|
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
47
46
|
if (decorator = decorators[i])
|
|
48
|
-
result = (
|
|
49
|
-
if (
|
|
47
|
+
result = (decorator(target, key, result) ) || result;
|
|
48
|
+
if (result) __defProp(target, key, result);
|
|
50
49
|
return result;
|
|
51
50
|
};
|
|
52
51
|
const PLACEHOLDER_DELAY = 500;
|
|
@@ -98,10 +97,6 @@ class Icon extends VividElement {
|
|
|
98
97
|
this.#abortController = null;
|
|
99
98
|
}
|
|
100
99
|
#currentRequestId;
|
|
101
|
-
get iconUrl() {
|
|
102
|
-
const key = normalizeKey(this.name);
|
|
103
|
-
return key ? baseUrlTemplate(`${key}.svg`, ICONS_VERSION) : this._svg;
|
|
104
|
-
}
|
|
105
100
|
#abortController;
|
|
106
101
|
async nameChanged() {
|
|
107
102
|
const requestId = ++this.#currentRequestId;
|
|
@@ -112,9 +107,11 @@ class Icon extends VividElement {
|
|
|
112
107
|
this._svg = void 0;
|
|
113
108
|
this.iconLoaded = false;
|
|
114
109
|
let timeout = setTimeout(() => {
|
|
110
|
+
/* v8 ignore else -- @preserve */
|
|
115
111
|
if (this.#currentRequestId === requestId) {
|
|
116
112
|
this._svg = PLACEHOLDER_ICON;
|
|
117
113
|
timeout = setTimeout(() => {
|
|
114
|
+
/* v8 ignore else -- @preserve */
|
|
118
115
|
if (this.#currentRequestId === requestId && this._svg === PLACEHOLDER_ICON) {
|
|
119
116
|
this._svg = void 0;
|
|
120
117
|
}
|
|
@@ -123,6 +120,7 @@ class Icon extends VividElement {
|
|
|
123
120
|
}, PLACEHOLDER_DELAY);
|
|
124
121
|
try {
|
|
125
122
|
const svg = await resolveIcon(this.name, this.#abortController.signal);
|
|
123
|
+
/* v8 ignore else -- @preserve */
|
|
126
124
|
if (this.#currentRequestId === requestId) {
|
|
127
125
|
this._svg = svg;
|
|
128
126
|
}
|
|
@@ -140,25 +138,22 @@ class Icon extends VividElement {
|
|
|
140
138
|
}
|
|
141
139
|
__decorateClass([
|
|
142
140
|
attr
|
|
143
|
-
], Icon.prototype, "connotation"
|
|
141
|
+
], Icon.prototype, "connotation");
|
|
144
142
|
__decorateClass([
|
|
145
143
|
attr({ converter: numberConverter })
|
|
146
|
-
], Icon.prototype, "size"
|
|
144
|
+
], Icon.prototype, "size");
|
|
147
145
|
__decorateClass([
|
|
148
146
|
observable
|
|
149
|
-
], Icon.prototype, "_svg"
|
|
147
|
+
], Icon.prototype, "_svg");
|
|
150
148
|
__decorateClass([
|
|
151
149
|
observable
|
|
152
|
-
], Icon.prototype, "iconLoaded"
|
|
150
|
+
], Icon.prototype, "iconLoaded");
|
|
153
151
|
__decorateClass([
|
|
154
152
|
attr
|
|
155
|
-
], Icon.prototype, "label"
|
|
153
|
+
], Icon.prototype, "label");
|
|
156
154
|
__decorateClass([
|
|
157
155
|
attr
|
|
158
|
-
], Icon.prototype, "name"
|
|
159
|
-
__decorateClass([
|
|
160
|
-
volatile
|
|
161
|
-
], Icon.prototype, "iconUrl", 1);
|
|
156
|
+
], Icon.prototype, "name");
|
|
162
157
|
|
|
163
158
|
const getClasses = ({ connotation, size }) => classNames(
|
|
164
159
|
"control",
|
|
@@ -176,10 +171,6 @@ const iconTemplate = (context) => {
|
|
|
176
171
|
>
|
|
177
172
|
<slot>
|
|
178
173
|
${when(
|
|
179
|
-
(x) => !x?.iconLoaded,
|
|
180
|
-
html`<img alt="${(x) => x?.name}" src="${(x) => x?.iconUrl}" />`
|
|
181
|
-
)}
|
|
182
|
-
${when(
|
|
183
174
|
(x) => x?.iconLoaded && x?._svg,
|
|
184
175
|
(x) => html`${html.partial(x._svg)}`
|
|
185
176
|
)}
|
package/index.cjs
CHANGED
|
@@ -228,6 +228,27 @@ exports.registerRadio = radio_definition.registerRadio;
|
|
|
228
228
|
exports.VwcRangeSliderElement = rangeSlider_definition.VwcRangeSliderElement;
|
|
229
229
|
exports.rangeSliderDefinition = rangeSlider_definition.rangeSliderDefinition;
|
|
230
230
|
exports.registerRangeSlider = rangeSlider_definition.registerRangeSlider;
|
|
231
|
+
exports.RteAlignmentFeature = richTextEditor_definition.RteAlignmentFeature;
|
|
232
|
+
exports.RteBase = richTextEditor_definition.RteBase;
|
|
233
|
+
exports.RteBoldFeature = richTextEditor_definition.RteBoldFeature;
|
|
234
|
+
exports.RteConfig = richTextEditor_definition.RteConfig;
|
|
235
|
+
exports.RteDropHandlerFeature = richTextEditor_definition.RteDropHandlerFeature;
|
|
236
|
+
exports.RteFileHandlerFeature = richTextEditor_definition.RteFileHandlerFeature;
|
|
237
|
+
exports.RteFontSizePickerFeature = richTextEditor_definition.RteFontSizePickerFeature;
|
|
238
|
+
exports.RteHardBreakFeature = richTextEditor_definition.RteHardBreakFeature;
|
|
239
|
+
exports.RteHtmlParser = richTextEditor_definition.RteHtmlParser;
|
|
240
|
+
exports.RteHtmlSerializer = richTextEditor_definition.RteHtmlSerializer;
|
|
241
|
+
exports.RteInlineImageFeature = richTextEditor_definition.RteInlineImageFeature;
|
|
242
|
+
exports.RteItalicFeature = richTextEditor_definition.RteItalicFeature;
|
|
243
|
+
exports.RteLinkFeature = richTextEditor_definition.RteLinkFeature;
|
|
244
|
+
exports.RteListFeature = richTextEditor_definition.RteListFeature;
|
|
245
|
+
exports.RteMonospaceFeature = richTextEditor_definition.RteMonospaceFeature;
|
|
246
|
+
exports.RtePlaceholderFeature = richTextEditor_definition.RtePlaceholderFeature;
|
|
247
|
+
exports.RteStrikethroughFeature = richTextEditor_definition.RteStrikethroughFeature;
|
|
248
|
+
exports.RteTextBlockPickerFeature = richTextEditor_definition.RteTextBlockPickerFeature;
|
|
249
|
+
exports.RteTextColorPickerFeature = richTextEditor_definition.RteTextColorPickerFeature;
|
|
250
|
+
exports.RteToolbarFeature = richTextEditor_definition.RteToolbarFeature;
|
|
251
|
+
exports.RteUnderlineFeature = richTextEditor_definition.RteUnderlineFeature;
|
|
231
252
|
exports.VwcRichTextEditorElement = richTextEditor_definition.VwcRichTextEditorElement;
|
|
232
253
|
exports.registerRichTextEditor = richTextEditor_definition.registerRichTextEditor;
|
|
233
254
|
exports.richTextEditorDefinition = richTextEditor_definition.richTextEditorDefinition;
|