@fewangsit/wangsvue 1.5.219-alpha.0 → 1.5.219-alpha.2
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/animation/index.es.js +54 -37
- package/assets/lottiejs/loading-page.es.js +14 -9
- package/assets/lottiejs/loading-plane.es.js +2 -2
- package/assets/lottiejs/loading-table.es.js +14 -9
- package/assets/lottiejs/no-data.es.js +14 -9
- package/backgroundimagecropper/index.es.js +61 -37
- package/badge/index.es.js +77 -67
- package/badgegroup/index.es.js +62 -50
- package/basecalendar/index.es.js +1258 -735
- package/basetree/index.es.js +213 -113
- package/breadcrumb/index.es.js +46 -38
- package/button/index.es.js +60 -54
- package/buttonbulkaction/index.es.js +168 -117
- package/buttoncopy/index.es.js +25 -22
- package/buttondownload/index.es.js +125 -76
- package/buttonfilter/index.es.js +21 -15
- package/buttonradio/index.es.js +91 -67
- package/buttonsearch/index.es.js +62 -46
- package/buttonselecttree/index.es.js +233 -172
- package/buttontoggle/index.es.js +8 -6
- package/calendar/index.es.js +113 -58
- package/card/index.es.js +44 -42
- package/checkbox/index.es.js +105 -74
- package/codesnippet/index.es.js +91 -71
- package/codesnippetadapter/index.es.js +25 -21
- package/columnlist/index.es.js +249 -171
- package/components.d.ts +0 -21
- package/config/defaultProps.es.js +9 -9
- package/config/index.es.js +11 -10
- package/config/locale.es.js +2 -2
- package/customcolumn/index.es.js +95 -78
- package/datatable/index.es.js +1071 -732
- package/dialog/index.es.js +54 -54
- package/dialogconfirm/index.es.js +90 -75
- package/dialogform/index.es.js +170 -133
- package/dialogselecttree/index.es.js +242 -194
- package/directives/focus.es.js +13 -8
- package/dropdown/index.es.js +250 -196
- package/editor/index.es.js +694 -498
- package/editorbutton/index.es.js +21 -19
- package/event-bus/index.es.js +3 -3
- package/event-bus/mitt.es.js +37 -20
- package/fieldwrapper/index.es.js +30 -25
- package/fileupload/index.es.js +230 -140
- package/filtercontainer/index.es.js +299 -222
- package/form/index.es.js +176 -126
- package/gallerypreview/index.es.js +138 -101
- package/icon/index.es.js +38 -36
- package/image/index.es.js +161 -108
- package/imagecompressor/index.es.js +616 -449
- package/imageinputinfo/index.es.js +26 -22
- package/inlinemessage/index.es.js +77 -65
- package/inputbadge/index.es.js +230 -156
- package/inputcurrency/index.es.js +146 -109
- package/inputemail/index.es.js +18 -16
- package/inputgroup/index.es.js +19 -16
- package/inputnumber/index.es.js +252 -182
- package/inputpassword/index.es.js +120 -94
- package/inputphonenumber/index.es.js +1017 -550
- package/inputrangenumber/index.es.js +129 -98
- package/inputtext/index.es.js +264 -189
- package/inputurl/index.es.js +31 -29
- package/invisiblefield/index.es.js +24 -16
- package/litedropdown/index.es.js +87 -81
- package/loading/index.es.js +21 -19
- package/loading-page-BXZ4fLOS.js +8 -0
- package/loading-page-BuLpsb_1.js +8 -0
- package/loading-page-CNqVBg__.js +4 -0
- package/loading-page-DbhhZih2.js +4 -0
- package/loading-page-DjfWXoOy.js +8 -0
- package/loading-page-S-KRY5zm.js +4 -0
- package/loading-plane-C1mi7Whv.js +4 -0
- package/loading-plane-CWq1hz_l.js +8 -0
- package/loading-table-B7LAXzAp.js +4 -0
- package/loading-table-BLmgKUsR.js +4 -0
- package/loading-table-CG7-cuhv.js +8 -0
- package/loading-table-CUPS49ta.js +4 -0
- package/loading-table-CuWWrTbv.js +8 -0
- package/loading-table-DbBzVwaZ.js +8 -0
- package/mentionlist/index.es.js +77 -44
- package/mentionsection/index.es.js +53 -43
- package/menu/index.es.js +65 -51
- package/menuitem/index.es.js +39 -37
- package/multirow/index.es.js +29 -28
- package/multiselect/index.es.js +184 -152
- package/no-data-B781skt3.js +4 -0
- package/no-data-CAksOnDl.js +4 -0
- package/no-data-DCsjBXQR.js +4 -0
- package/no-data-Dz0QOe7Q.js +8 -0
- package/no-data-_Huxiv9q.js +8 -0
- package/no-data-ybRQontJ.js +8 -0
- package/overlaypanel/index.es.js +49 -36
- package/package.json +1 -1
- package/paginator/index.es.js +36 -33
- package/plugins/WangsVue.es.js +63 -45
- package/plugins/formValidation.es.js +15 -11
- package/progressbar/index.es.js +39 -32
- package/quickfilter/index.es.js +94 -81
- package/stats.html +1 -1
- package/style.css +2 -2
- package/tabmenu/index.es.js +18 -16
- package/textarea/index.es.js +94 -72
- package/timeline/index.es.js +124 -102
- package/timelinecontentbytype/index.es.js +114 -92
- package/toast/index.es.js +67 -54
- package/toggleswitch/index.es.js +83 -66
- package/tree/index.es.js +306 -198
- package/treenode/index.es.js +464 -339
- package/treesearchinput/index.es.js +32 -26
- package/usergroup/index.es.js +83 -67
- package/username/index.es.js +99 -85
- package/utils/addAttachment.util.es.js +47 -21
- package/utils/baseToast.util.es.js +41 -33
- package/utils/convertJsonImage.util.es.js +24 -24
- package/utils/date.util.es.js +131 -106
- package/utils/exportToExcel.util.es.js +81 -47
- package/utils/filterOptions.util.es.js +8 -2
- package/utils/genPlaceholder.util.es.js +30 -16
- package/utils/getProjectPermission.util.es.js +15 -12
- package/utils/getSalesRole.util.es.js +4 -4
- package/utils/getUser.util.es.js +2 -2
- package/utils/getUserType.util.es.js +13 -8
- package/utils/isIntersect.es.js +4 -2
- package/utils/mergePropsWithDefaults.util.es.js +7 -6
- package/utils/object.util.es.js +88 -54
- package/utils/queryParamsStringfy.util.es.js +19 -11
- package/utils/role.util.es.js +5 -4
- package/utils/statusSeverity.util.es.js +20 -5
- package/utils/textFormatter.util.es.js +28 -50
- package/utils/toast.util.es.js +8 -5
- package/utils/xlsx.util.es.js +12 -6
- package/validatormessage/index.es.js +9 -9
- package/vendor/@popperjs/core/lib/createPopper.es.js +110 -83
- package/vendor/@popperjs/core/lib/dom-utils/contains.es.js +14 -13
- package/vendor/@popperjs/core/lib/dom-utils/getBoundingClientRect.es.js +33 -18
- package/vendor/@popperjs/core/lib/dom-utils/getClippingRect.es.js +55 -31
- package/vendor/@popperjs/core/lib/dom-utils/getCompositeRect.es.js +43 -22
- package/vendor/@popperjs/core/lib/dom-utils/getComputedStyle.es.js +4 -4
- package/vendor/@popperjs/core/lib/dom-utils/getDocumentElement.es.js +5 -5
- package/vendor/@popperjs/core/lib/dom-utils/getDocumentRect.es.js +23 -13
- package/vendor/@popperjs/core/lib/dom-utils/getHTMLElementScroll.es.js +4 -4
- package/vendor/@popperjs/core/lib/dom-utils/getLayoutRect.es.js +17 -9
- package/vendor/@popperjs/core/lib/dom-utils/getNodeName.es.js +3 -3
- package/vendor/@popperjs/core/lib/dom-utils/getNodeScroll.es.js +11 -7
- package/vendor/@popperjs/core/lib/dom-utils/getOffsetParent.es.js +42 -26
- package/vendor/@popperjs/core/lib/dom-utils/getParentNode.es.js +13 -10
- package/vendor/@popperjs/core/lib/dom-utils/getScrollParent.es.js +13 -7
- package/vendor/@popperjs/core/lib/dom-utils/getViewportRect.es.js +25 -15
- package/vendor/@popperjs/core/lib/dom-utils/getWindow.es.js +8 -7
- package/vendor/@popperjs/core/lib/dom-utils/getWindowScroll.es.js +8 -6
- package/vendor/@popperjs/core/lib/dom-utils/getWindowScrollBarX.es.js +6 -6
- package/vendor/@popperjs/core/lib/dom-utils/instanceOf.es.js +16 -15
- package/vendor/@popperjs/core/lib/dom-utils/isLayoutViewport.es.js +4 -4
- package/vendor/@popperjs/core/lib/dom-utils/isScrollParent.es.js +5 -5
- package/vendor/@popperjs/core/lib/dom-utils/isTableElement.es.js +4 -4
- package/vendor/@popperjs/core/lib/dom-utils/listScrollParents.es.js +17 -11
- package/vendor/@popperjs/core/lib/enums.es.js +43 -20
- package/vendor/@popperjs/core/lib/modifiers/applyStyles.es.js +49 -25
- package/vendor/@popperjs/core/lib/modifiers/arrow.es.js +61 -26
- package/vendor/@popperjs/core/lib/modifiers/computeStyles.es.js +101 -69
- package/vendor/@popperjs/core/lib/modifiers/eventListeners.es.js +30 -16
- package/vendor/@popperjs/core/lib/modifiers/flip.es.js +99 -60
- package/vendor/@popperjs/core/lib/modifiers/hide.es.js +44 -31
- package/vendor/@popperjs/core/lib/modifiers/offset.es.js +32 -20
- package/vendor/@popperjs/core/lib/modifiers/popperOffsets.es.js +11 -11
- package/vendor/@popperjs/core/lib/modifiers/preventOverflow.es.js +91 -40
- package/vendor/@popperjs/core/lib/popper.es.js +14 -13
- package/vendor/@popperjs/core/lib/utils/computeAutoPlacement.es.js +29 -21
- package/vendor/@popperjs/core/lib/utils/computeOffsets.es.js +41 -36
- package/vendor/@popperjs/core/lib/utils/debounce.es.js +11 -7
- package/vendor/@popperjs/core/lib/utils/detectOverflow.es.js +42 -28
- package/vendor/@popperjs/core/lib/utils/expandToHashMap.es.js +5 -4
- package/vendor/@popperjs/core/lib/utils/getAltAxis.es.js +3 -3
- package/vendor/@popperjs/core/lib/utils/getBasePlacement.es.js +3 -3
- package/vendor/@popperjs/core/lib/utils/getFreshSideObject.es.js +2 -2
- package/vendor/@popperjs/core/lib/utils/getMainAxisFromPlacement.es.js +3 -3
- package/vendor/@popperjs/core/lib/utils/getOppositePlacement.es.js +5 -5
- package/vendor/@popperjs/core/lib/utils/getOppositeVariationPlacement.es.js +5 -5
- package/vendor/@popperjs/core/lib/utils/getVariation.es.js +3 -3
- package/vendor/@popperjs/core/lib/utils/math.es.js +6 -4
- package/vendor/@popperjs/core/lib/utils/mergeByName.es.js +11 -10
- package/vendor/@popperjs/core/lib/utils/mergePaddingObject.es.js +4 -4
- package/vendor/@popperjs/core/lib/utils/orderModifiers.es.js +30 -22
- package/vendor/@popperjs/core/lib/utils/rectToClientRect.es.js +7 -7
- package/vendor/@popperjs/core/lib/utils/userAgent.es.js +9 -6
- package/vendor/@popperjs/core/lib/utils/within.es.js +8 -8
- package/vendor/@tiptap/core/dist/index.es.js +3494 -2000
- package/vendor/@tiptap/extension-bold/dist/index.es.js +29 -19
- package/vendor/@tiptap/extension-bubble-menu/dist/index.es.js +145 -71
- package/vendor/@tiptap/extension-bullet-list/dist/index.es.js +32 -19
- package/vendor/@tiptap/extension-code/dist/index.es.js +22 -14
- package/vendor/@tiptap/extension-document/dist/index.es.js +4 -4
- package/vendor/@tiptap/extension-floating-menu/dist/index.es.js +106 -51
- package/vendor/@tiptap/extension-heading/dist/index.es.js +38 -22
- package/vendor/@tiptap/extension-history/dist/index.es.js +11 -7
- package/vendor/@tiptap/extension-image/dist/index.es.js +20 -17
- package/vendor/@tiptap/extension-italic/dist/index.es.js +28 -18
- package/vendor/@tiptap/extension-link/dist/index.es.js +236 -147
- package/vendor/@tiptap/extension-list-item/dist/index.es.js +6 -6
- package/vendor/@tiptap/extension-mention/dist/index.es.js +98 -63
- package/vendor/@tiptap/extension-ordered-list/dist/index.es.js +38 -25
- package/vendor/@tiptap/extension-paragraph/dist/index.es.js +8 -6
- package/vendor/@tiptap/extension-placeholder/dist/index.es.js +34 -27
- package/vendor/@tiptap/extension-text/dist/index.es.js +3 -3
- package/vendor/@tiptap/extension-underline/dist/index.es.js +16 -10
- package/vendor/@tiptap/suggestion/dist/index.es.js +174 -90
- package/vendor/@tiptap/vue-3/dist/index.es.js +287 -188
- package/vendor/@wangs-ui/core/components/p-BU8h34na.es.js +17 -14
- package/vendor/@wangs-ui/core/components/p-C5lMEBcj.es.js +69 -55
- package/vendor/@wangs-ui/core/components/p-CKYwZoTo.es.js +26 -22
- package/vendor/@wangs-ui/core/components/p-CsoK-EWG.es.js +147 -102
- package/vendor/@wangs-ui/core/components/p-DPHEi31J.es.js +102 -77
- package/vendor/@wangs-ui/core/components/p-DTTCzifR.es.js +1298 -551
- package/vendor/@wangs-ui/core/components/p-Duri5p90.es.js +60 -49
- package/vendor/@wangs-ui/core/components/wangs-button.es.js +19 -15
- package/vendor/@wangs-ui/core/components/wangs-icon.es.js +3 -3
- package/vendor/@wangs-ui/core/components/wangs-input-otp.es.js +3 -3
- package/vendor/@wangs-ui/core/components/wangs-tab-menu.es.js +3 -3
- package/vendor/@wangs-ui/core/dist/esm/index-DCkh3cGv.es.js +116 -102
- package/vendor/@wangs-ui/vue/dist/index.es.js +77 -77
- package/vendor/base64toblob/base64toblob.es.js +31 -15
- package/vendor/highlight.js/es/core.es.js +5 -5
- package/vendor/highlight.js/es/languages/javascript.es.js +237 -193
- package/vendor/highlight.js/es/languages/json.es.js +18 -15
- package/vendor/highlight.js/es/languages/typescript.es.js +288 -228
- package/vendor/highlight.js/es/languages/vbscript-html.es.js +2 -2
- package/vendor/highlight.js/lib/core.es.js +1144 -666
- package/vendor/linkifyjs/dist/linkify.es.es.js +858 -405
- package/vendor/lodash/_Symbol.es.js +11 -8
- package/vendor/lodash/_baseGetTag.es.js +19 -12
- package/vendor/lodash/_baseTrim.es.js +13 -10
- package/vendor/lodash/_freeGlobal.es.js +10 -8
- package/vendor/lodash/_getRawTag.es.js +28 -15
- package/vendor/lodash/_objectToString.es.js +12 -9
- package/vendor/lodash/_root.es.js +12 -8
- package/vendor/lodash/_trimmedEndIndex.es.js +14 -11
- package/vendor/lodash/debounce.es.js +92 -54
- package/vendor/lodash/isObject.es.js +11 -9
- package/vendor/lodash/isObjectLike.es.js +10 -8
- package/vendor/lodash/isSymbol.es.js +14 -11
- package/vendor/lodash/now.es.js +12 -9
- package/vendor/lodash/throttle.es.js +25 -17
- package/vendor/lodash/toNumber.es.js +33 -23
- package/vendor/lodash-es/_DataView.es.js +4 -4
- package/vendor/lodash-es/_Hash.es.js +17 -16
- package/vendor/lodash-es/_ListCache.es.js +17 -16
- package/vendor/lodash-es/_Map.es.js +4 -4
- package/vendor/lodash-es/_MapCache.es.js +17 -16
- package/vendor/lodash-es/_Promise.es.js +4 -4
- package/vendor/lodash-es/_Set.es.js +4 -4
- package/vendor/lodash-es/_SetCache.es.js +12 -10
- package/vendor/lodash-es/_Stack.es.js +15 -15
- package/vendor/lodash-es/_Symbol.es.js +3 -3
- package/vendor/lodash-es/_Uint8Array.es.js +3 -3
- package/vendor/lodash-es/_WeakMap.es.js +4 -4
- package/vendor/lodash-es/_arrayEach.es.js +9 -5
- package/vendor/lodash-es/_arrayFilter.es.js +9 -6
- package/vendor/lodash-es/_arrayLikeKeys.es.js +21 -17
- package/vendor/lodash-es/_arrayPush.es.js +7 -5
- package/vendor/lodash-es/_arraySome.es.js +9 -6
- package/vendor/lodash-es/_assignValue.es.js +10 -7
- package/vendor/lodash-es/_assocIndexOf.es.js +9 -6
- package/vendor/lodash-es/_baseAssignValue.es.js +13 -9
- package/vendor/lodash-es/_baseClone.es.js +67 -49
- package/vendor/lodash-es/_baseCreate.es.js +15 -11
- package/vendor/lodash-es/_baseGetAllKeys.es.js +6 -6
- package/vendor/lodash-es/_baseGetTag.es.js +11 -7
- package/vendor/lodash-es/_baseIsArguments.es.js +6 -6
- package/vendor/lodash-es/_baseIsEqual.es.js +11 -5
- package/vendor/lodash-es/_baseIsEqualDeep.es.js +39 -26
- package/vendor/lodash-es/_baseIsMap.es.js +6 -6
- package/vendor/lodash-es/_baseIsNative.es.js +18 -12
- package/vendor/lodash-es/_baseIsSet.es.js +6 -6
- package/vendor/lodash-es/_baseIsTypedArray.es.js +11 -9
- package/vendor/lodash-es/_baseKeys.es.js +16 -11
- package/vendor/lodash-es/_baseTimes.es.js +7 -5
- package/vendor/lodash-es/_baseTrim.es.js +5 -5
- package/vendor/lodash-es/_baseUnary.es.js +4 -4
- package/vendor/lodash-es/_cacheHas.es.js +3 -3
- package/vendor/lodash-es/_cloneArrayBuffer.es.js +6 -5
- package/vendor/lodash-es/_cloneBuffer.es.js +11 -6
- package/vendor/lodash-es/_cloneDataView.es.js +5 -5
- package/vendor/lodash-es/_cloneRegExp.es.js +6 -5
- package/vendor/lodash-es/_cloneSymbol.es.js +5 -5
- package/vendor/lodash-es/_cloneTypedArray.es.js +5 -5
- package/vendor/lodash-es/_coreJsData.es.js +3 -3
- package/vendor/lodash-es/_defineProperty.es.js +7 -6
- package/vendor/lodash-es/_equalArrays.es.js +38 -28
- package/vendor/lodash-es/_equalByTag.es.js +55 -41
- package/vendor/lodash-es/_equalObjects.es.js +42 -28
- package/vendor/lodash-es/_freeGlobal.es.js +2 -2
- package/vendor/lodash-es/_getAllKeys.es.js +6 -6
- package/vendor/lodash-es/_getMapData.es.js +5 -5
- package/vendor/lodash-es/_getNative.es.js +6 -6
- package/vendor/lodash-es/_getPrototype.es.js +3 -3
- package/vendor/lodash-es/_getRawTag.es.js +20 -10
- package/vendor/lodash-es/_getSymbols.es.js +15 -8
- package/vendor/lodash-es/_getTag.es.js +31 -25
- package/vendor/lodash-es/_getValue.es.js +3 -3
- package/vendor/lodash-es/_hashClear.es.js +5 -4
- package/vendor/lodash-es/_hashDelete.es.js +5 -4
- package/vendor/lodash-es/_hashGet.es.js +11 -9
- package/vendor/lodash-es/_hashHas.es.js +7 -6
- package/vendor/lodash-es/_hashSet.es.js +8 -6
- package/vendor/lodash-es/_initCloneArray.es.js +10 -5
- package/vendor/lodash-es/_initCloneByTag.es.js +39 -38
- package/vendor/lodash-es/_initCloneObject.es.js +6 -6
- package/vendor/lodash-es/_isIndex.es.js +7 -5
- package/vendor/lodash-es/_isKeyable.es.js +4 -4
- package/vendor/lodash-es/_isMasked.es.js +7 -7
- package/vendor/lodash-es/_isPrototype.es.js +5 -5
- package/vendor/lodash-es/_listCacheClear.es.js +4 -3
- package/vendor/lodash-es/_listCacheDelete.es.js +17 -9
- package/vendor/lodash-es/_listCacheGet.es.js +5 -5
- package/vendor/lodash-es/_listCacheHas.es.js +4 -4
- package/vendor/lodash-es/_listCacheSet.es.js +11 -5
- package/vendor/lodash-es/_mapCacheClear.es.js +10 -9
- package/vendor/lodash-es/_mapCacheDelete.es.js +6 -5
- package/vendor/lodash-es/_mapCacheGet.es.js +4 -4
- package/vendor/lodash-es/_mapCacheHas.es.js +4 -4
- package/vendor/lodash-es/_mapCacheSet.es.js +7 -5
- package/vendor/lodash-es/_mapToArray.es.js +7 -6
- package/vendor/lodash-es/_nativeCreate.es.js +3 -3
- package/vendor/lodash-es/_nativeKeys.es.js +3 -3
- package/vendor/lodash-es/_nodeUtil.es.js +13 -6
- package/vendor/lodash-es/_objectToString.es.js +5 -4
- package/vendor/lodash-es/_overArg.es.js +4 -4
- package/vendor/lodash-es/_root.es.js +4 -3
- package/vendor/lodash-es/_setCacheAdd.es.js +5 -4
- package/vendor/lodash-es/_setCacheHas.es.js +3 -3
- package/vendor/lodash-es/_setToArray.es.js +7 -6
- package/vendor/lodash-es/_stackClear.es.js +5 -4
- package/vendor/lodash-es/_stackDelete.es.js +5 -4
- package/vendor/lodash-es/_stackGet.es.js +3 -3
- package/vendor/lodash-es/_stackHas.es.js +3 -3
- package/vendor/lodash-es/_stackSet.es.js +18 -13
- package/vendor/lodash-es/_toSource.es.js +9 -8
- package/vendor/lodash-es/_trimmedEndIndex.es.js +7 -6
- package/vendor/lodash-es/cloneDeep.es.js +5 -5
- package/vendor/lodash-es/debounce.es.js +84 -49
- package/vendor/lodash-es/eq.es.js +3 -3
- package/vendor/lodash-es/isArguments.es.js +9 -6
- package/vendor/lodash-es/isArray.es.js +2 -2
- package/vendor/lodash-es/isArrayLike.es.js +5 -5
- package/vendor/lodash-es/isBuffer.es.js +9 -4
- package/vendor/lodash-es/isEqual.es.js +4 -4
- package/vendor/lodash-es/isFunction.es.js +10 -9
- package/vendor/lodash-es/isLength.es.js +4 -4
- package/vendor/lodash-es/isMap.es.js +6 -5
- package/vendor/lodash-es/isObject.es.js +4 -4
- package/vendor/lodash-es/isObjectLike.es.js +3 -3
- package/vendor/lodash-es/isSet.es.js +6 -5
- package/vendor/lodash-es/isSymbol.es.js +6 -6
- package/vendor/lodash-es/isTypedArray.es.js +6 -5
- package/vendor/lodash-es/keys.es.js +6 -6
- package/vendor/lodash-es/now.es.js +4 -4
- package/vendor/lodash-es/stubArray.es.js +2 -2
- package/vendor/lodash-es/stubFalse.es.js +3 -3
- package/vendor/lodash-es/toNumber.es.js +25 -18
- package/vendor/lodash-es/toString.es.js +2 -2
- package/vendor/lodash-es/uniqueId.es.js +6 -6
- package/vendor/orderedmap/dist/index.es.js +65 -49
- package/vendor/primevue/api/api.esm.es.js +214 -121
- package/vendor/primevue/avatar/avatar.esm.es.js +44 -41
- package/vendor/primevue/avatar/style/avatarstyle.esm.es.js +12 -11
- package/vendor/primevue/avatargroup/avatargroup.esm.es.js +17 -16
- package/vendor/primevue/avatargroup/style/avatargroupstyle.esm.es.js +6 -5
- package/vendor/primevue/badge/badge.esm.es.js +21 -20
- package/vendor/primevue/badge/style/badgestyle.esm.es.js +19 -18
- package/vendor/primevue/base/style/basestyle.esm.es.js +88 -99
- package/vendor/primevue/basecomponent/basecomponent.esm.es.js +327 -261
- package/vendor/primevue/basedirective/basedirective.esm.es.js +257 -186
- package/vendor/primevue/baseicon/baseicon.esm.es.js +55 -49
- package/vendor/primevue/baseicon/style/baseiconstyle.esm.es.js +5 -35
- package/vendor/primevue/button/button.esm.es.js +76 -72
- package/vendor/primevue/button/style/buttonstyle.esm.es.js +46 -39
- package/vendor/primevue/card/card.esm.es.js +30 -29
- package/vendor/primevue/card/style/cardstyle.esm.es.js +6 -5
- package/vendor/primevue/checkbox/checkbox.esm.es.js +109 -101
- package/vendor/primevue/checkbox/style/checkboxstyle.esm.es.js +12 -11
- package/vendor/primevue/config/config.esm.es.js +76 -58
- package/vendor/primevue/dialog/dialog.esm.es.js +421 -281
- package/vendor/primevue/dialog/style/dialogstyle.esm.es.js +26 -22
- package/vendor/primevue/dropdown/dropdown.esm.es.js +956 -742
- package/vendor/primevue/dropdown/style/dropdownstyle.esm.es.js +33 -31
- package/vendor/primevue/fileupload/fileupload.esm.es.js +559 -450
- package/vendor/primevue/fileupload/style/fileuploadstyle.esm.es.js +14 -13
- package/vendor/primevue/focustrap/focustrap.esm.es.js +128 -90
- package/vendor/primevue/focustrap/style/focustrapstyle.esm.es.js +2 -2
- package/vendor/primevue/icons/angledoubleleft/index.esm.es.js +13 -11
- package/vendor/primevue/icons/angledoubleright/index.esm.es.js +13 -11
- package/vendor/primevue/icons/angledown/index.esm.es.js +13 -11
- package/vendor/primevue/icons/angleleft/index.esm.es.js +13 -11
- package/vendor/primevue/icons/angleright/index.esm.es.js +13 -11
- package/vendor/primevue/icons/angleup/index.esm.es.js +13 -11
- package/vendor/primevue/icons/blank/index.esm.es.js +13 -11
- package/vendor/primevue/icons/check/index.esm.es.js +13 -11
- package/vendor/primevue/icons/chevrondown/index.esm.es.js +13 -11
- package/vendor/primevue/icons/exclamationtriangle/index.esm.es.js +17 -13
- package/vendor/primevue/icons/eye/index.esm.es.js +13 -11
- package/vendor/primevue/icons/eyeslash/index.esm.es.js +13 -11
- package/vendor/primevue/icons/infocircle/index.esm.es.js +13 -11
- package/vendor/primevue/icons/plus/index.esm.es.js +13 -11
- package/vendor/primevue/icons/refresh/index.esm.es.js +13 -11
- package/vendor/primevue/icons/search/index.esm.es.js +13 -11
- package/vendor/primevue/icons/searchminus/index.esm.es.js +13 -11
- package/vendor/primevue/icons/searchplus/index.esm.es.js +13 -11
- package/vendor/primevue/icons/spinner/index.esm.es.js +13 -11
- package/vendor/primevue/icons/times/index.esm.es.js +13 -11
- package/vendor/primevue/icons/timescircle/index.esm.es.js +13 -11
- package/vendor/primevue/icons/undo/index.esm.es.js +13 -11
- package/vendor/primevue/icons/upload/index.esm.es.js +13 -11
- package/vendor/primevue/icons/windowmaximize/index.esm.es.js +13 -11
- package/vendor/primevue/icons/windowminimize/index.esm.es.js +13 -11
- package/vendor/primevue/image/image.esm.es.js +280 -235
- package/vendor/primevue/image/style/imagestyle.esm.es.js +18 -17
- package/vendor/primevue/inputgroup/inputgroup.esm.es.js +17 -16
- package/vendor/primevue/inputgroup/style/inputgroupstyle.esm.es.js +6 -5
- package/vendor/primevue/inputgroupaddon/inputgroupaddon.esm.es.js +17 -16
- package/vendor/primevue/inputgroupaddon/style/inputgroupaddonstyle.esm.es.js +6 -5
- package/vendor/primevue/inputnumber/inputnumber.esm.es.js +834 -566
- package/vendor/primevue/inputnumber/style/inputnumberstyle.esm.es.js +23 -22
- package/vendor/primevue/inputtext/inputtext.esm.es.js +32 -30
- package/vendor/primevue/inputtext/style/inputtextstyle.esm.es.js +13 -12
- package/vendor/primevue/menu/menu.esm.es.js +402 -304
- package/vendor/primevue/menu/style/menustyle.esm.es.js +14 -13
- package/vendor/primevue/message/message.esm.es.js +126 -112
- package/vendor/primevue/message/style/messagestyle.esm.es.js +9 -8
- package/vendor/primevue/multiselect/multiselect.esm.es.js +1083 -835
- package/vendor/primevue/multiselect/style/multiselectstyle.esm.es.js +38 -36
- package/vendor/primevue/overlayeventbus/overlayeventbus.esm.es.js +3 -3
- package/vendor/primevue/overlaypanel/overlaypanel.esm.es.js +275 -169
- package/vendor/primevue/overlaypanel/style/overlaypanelstyle.esm.es.js +9 -8
- package/vendor/primevue/paginator/paginator.esm.es.js +513 -469
- package/vendor/primevue/paginator/style/paginatorstyle.esm.es.js +50 -43
- package/vendor/primevue/password/password.esm.es.js +306 -233
- package/vendor/primevue/password/style/passwordstyle.esm.es.js +26 -24
- package/vendor/primevue/portal/portal.esm.es.js +17 -17
- package/vendor/primevue/progressbar/progressbar.esm.es.js +37 -35
- package/vendor/primevue/progressbar/style/progressbarstyle.esm.es.js +10 -9
- package/vendor/primevue/ripple/ripple.esm.es.js +90 -62
- package/vendor/primevue/ripple/style/ripplestyle.esm.es.js +6 -5
- package/vendor/primevue/selectbutton/selectbutton.esm.es.js +213 -167
- package/vendor/primevue/selectbutton/style/selectbuttonstyle.esm.es.js +14 -13
- package/vendor/primevue/skeleton/skeleton.esm.es.js +28 -26
- package/vendor/primevue/skeleton/style/skeletonstyle.esm.es.js +13 -11
- package/vendor/primevue/textarea/style/textareastyle.esm.es.js +12 -11
- package/vendor/primevue/textarea/textarea.esm.es.js +49 -33
- package/vendor/primevue/timeline/style/timelinestyle.esm.es.js +9 -8
- package/vendor/primevue/timeline/timeline.esm.es.js +53 -52
- package/vendor/primevue/toast/style/toaststyle.esm.es.js +54 -46
- package/vendor/primevue/toast/toast.esm.es.js +309 -260
- package/vendor/primevue/toasteventbus/toasteventbus.esm.es.js +3 -3
- package/vendor/primevue/toastservice/toastservice.esm.es.js +16 -15
- package/vendor/primevue/tooltip/style/tooltipstyle.esm.es.js +6 -5
- package/vendor/primevue/tooltip/tooltip.esm.es.js +383 -186
- package/vendor/primevue/usestyle/usestyle.esm.es.js +94 -64
- package/vendor/primevue/usetoast/usetoast.esm.es.js +9 -8
- package/vendor/primevue/utils/utils.esm.es.js +1078 -772
- package/vendor/primevue/virtualscroller/style/virtualscrollerstyle.esm.es.js +5 -67
- package/vendor/primevue/virtualscroller/virtualscroller.esm.es.js +655 -428
- package/vendor/prosemirror-commands/dist/index.es.js +454 -316
- package/vendor/prosemirror-history/dist/index.es.js +286 -178
- package/vendor/prosemirror-keymap/dist/index.es.js +68 -48
- package/vendor/prosemirror-model/dist/index.es.js +1905 -1436
- package/vendor/prosemirror-schema-list/dist/index.es.js +115 -73
- package/vendor/prosemirror-state/dist/index.es.js +467 -353
- package/vendor/prosemirror-transform/dist/index.es.js +1146 -829
- package/vendor/prosemirror-view/dist/index.es.js +4127 -2719
- package/vendor/rope-sequence/dist/index.es.js +165 -82
- package/vendor/simplebar-core/dist/index.es.js +670 -242
- package/vendor/simplebar-vue/dist/simplebar-vue.esm.es.js +73 -60
- package/vendor/single-spa/lib/es2015/esm/single-spa.min.es.js +511 -510
- package/vendor/tippy.js/dist/tippy.esm.es.js +971 -525
- package/vendor/vee-validate/dist/vee-validate.esm.es.js +1830 -1097
- package/vendor/vue-advanced-cropper/dist/index.esm-bundler.es.js +740 -738
- package/vendor/w3c-keyname/index.es.js +25 -13
- package/wangsvue.es.js +167 -208
- package/wangsvue.esm.browser.js +49417 -48026
- package/wangsvue.system.js +67600 -234
- package/api/index.es.js +0 -149
- package/apiitem/index.es.js +0 -611
- package/assignmember/index.es.js +0 -434
- package/attachment/index.es.js +0 -118
- package/attachmentchangelog/index.es.js +0 -79
- package/attachmentitem/index.es.js +0 -231
- package/attachmentthumbnail/index.es.js +0 -83
- package/changelog/index.d.ts +0 -164
- package/changelog/index.es.js +0 -85
- package/changelogfilter/index.es.js +0 -113
- package/changelogpage/index.d.ts +0 -184
- package/changelogpage/index.es.js +0 -176
- package/checklist/index.es.js +0 -571
- package/checklistchangelog/index.es.js +0 -85
- package/comment/index.d.ts +0 -187
- package/comment/index.es.js +0 -267
- package/commentblock/index.es.js +0 -337
- package/confirmdeploy/index.es.js +0 -64
- package/dependencycol/index.es.js +0 -32
- package/description/index.es.js +0 -135
- package/descriptiontab/index.es.js +0 -30
- package/detailmember/index.d.ts +0 -77
- package/detailmember/index.es.js +0 -32
- package/detailmemberadmin/index.es.js +0 -210
- package/detailmemberleader/index.es.js +0 -164
- package/detailmemberlog/index.es.js +0 -117
- package/detailsprint/index.d.ts +0 -86
- package/detailsprint/index.es.js +0 -414
- package/dialogaddattachment/index.es.js +0 -273
- package/dialogaddchecklist/index.es.js +0 -120
- package/dialogaddeditapi/index.es.js +0 -87
- package/dialogaddpbi/index.es.js +0 -197
- package/dialogadjustmenttask/index.es.js +0 -484
- package/dialogadjustmenttaskheader/index.es.js +0 -193
- package/dialogapichangelog/index.es.js +0 -83
- package/dialogassignmember/index.es.js +0 -171
- package/dialogconfirmapproval/index.es.js +0 -54
- package/dialogconfirmchecklist/index.es.js +0 -189
- package/dialogconfirmdeletetask/index.es.js +0 -70
- package/dialogconfirmdeletetaskpermanently/index.es.js +0 -50
- package/dialogconfirmedit/index.es.js +0 -50
- package/dialogconfirmfinishtask/index.es.js +0 -50
- package/dialogconfirmrestoretask/index.es.js +0 -46
- package/dialogconfirmsprint/index.es.js +0 -42
- package/dialogcopyapi/index.es.js +0 -130
- package/dialogcustomdependency/index.es.js +0 -55
- package/dialogdetailchecklisttemplate/index.es.js +0 -214
- package/dialogdetailcomponent/index.es.js +0 -121
- package/dialogdetailpbi/index.es.js +0 -192
- package/dialogfinishreview/index.es.js +0 -126
- package/dialogimprovementtask/index.es.js +0 -191
- package/dialogmemberadmin/index.es.js +0 -93
- package/dialogpreparepbi/index.es.js +0 -93
- package/dialogpriorityvalue/index.es.js +0 -85
- package/dialogreportbug/index.es.js +0 -207
- package/dialogreviewleader/index.es.js +0 -280
- package/dialogsavechecklisttemplate/index.es.js +0 -127
- package/dialogselectproject/index.es.js +0 -69
- package/dialogsetduration/index.es.js +0 -109
- package/dialogsettasklink/index.es.js +0 -153
- package/dialogtestapi/index.es.js +0 -389
- package/eventlogtab/index.es.js +0 -50
- package/infotasktab/index.es.js +0 -186
- package/inputadditional/index.es.js +0 -62
- package/inputinitialname/index.d.ts +0 -118
- package/inputinitialname/index.es.js +0 -95
- package/inputrepositoryname/index.d.ts +0 -86
- package/inputrepositoryname/index.es.js +0 -41
- package/isrequiredtext/index.es.js +0 -16
- package/legend/index.es.js +0 -727
- package/legendlist/index.es.js +0 -33
- package/loading-page-BrQattYE.js +0 -1
- package/loading-page-CgfbWppy.js +0 -1
- package/loading-page-CoC9UhfC.js +0 -4
- package/loading-page-CoXtqoc9.js +0 -4
- package/loading-page-DbLuqCHa.js +0 -1
- package/loading-page-f8D03l3G.js +0 -4
- package/loading-plane-CgfbWppy.js +0 -1
- package/loading-plane-CoXtqoc9.js +0 -4
- package/loading-table-Bdr9ZhtP.js +0 -1
- package/loading-table-ByUoWqUo.js +0 -4
- package/loading-table-BygEMzFM.js +0 -4
- package/loading-table-BzrSQlA0.js +0 -1
- package/loading-table-D9bw9OcI.js +0 -4
- package/loading-table-chOgXi94.js +0 -1
- package/no-data-CTKux8RI.js +0 -4
- package/no-data-Cgze_Rvp.js +0 -1
- package/no-data-DLHO1L_u.js +0 -4
- package/no-data-Dep79CBh.js +0 -1
- package/no-data-g0dJCy2p.js +0 -4
- package/no-data-y1X5WtcQ.js +0 -1
- package/notificationitem/index.d.ts +0 -107
- package/notificationitem/index.es.js +0 -333
- package/reviewitem/index.es.js +0 -65
- package/reviewtab/index.es.js +0 -44
- package/services/calendar.service.es.js +0 -32
- package/sonarqubesummary/index.es.js +0 -234
- package/sprintsummary/index.es.js +0 -73
- package/summaryaccordion/index.d.ts +0 -121
- package/summaryaccordion/index.es.js +0 -365
- package/taskdependency/index.es.js +0 -686
- package/taskdetail/index.d.ts +0 -82
- package/taskdetail/index.es.js +0 -491
- package/taskdetailpbi/index.d.ts +0 -35
- package/taskdetailpbi/index.es.js +0 -172
- package/taskdetailunassignedpbi/index.es.js +0 -261
- package/tasklink/index.es.js +0 -257
- package/tasklinkchangelog/index.es.js +0 -93
- package/tasklist/index.es.js +0 -92
- package/taskmore/index.es.js +0 -52
- package/taskstatusbadge/index.es.js +0 -18
- package/tasktable/index.d.ts +0 -87
- package/tasktable/index.es.js +0 -832
- package/ticket/index.es.js +0 -151
- package/tooltipspan/index.es.js +0 -30
- package/utils/updateSprintStatus.util.es.js +0 -17
- package/valueformdatainput/index.es.js +0 -70
- package/workcalendar/index.es.js +0 -351
|
@@ -1,68 +1,78 @@
|
|
|
1
|
-
import { defineComponent
|
|
2
|
-
import { r as
|
|
3
|
-
import { u as
|
|
4
|
-
import { f as
|
|
5
|
-
import { u as
|
|
6
|
-
import { g as
|
|
7
|
-
import { _ as
|
|
8
|
-
import { _ as
|
|
9
|
-
import { _ as
|
|
10
|
-
import { _ as
|
|
11
|
-
import { _ as
|
|
12
|
-
import { _ as
|
|
13
|
-
import { _ as
|
|
14
|
-
import { _ as
|
|
15
|
-
import { _ as
|
|
16
|
-
import { B as
|
|
17
|
-
import { _ as
|
|
1
|
+
import { defineComponent, mergeModels, inject, onMounted, onUnmounted, ref, shallowRef, useModel, reactive, computed, watch, createElementBlock, openBlock, Fragment, createVNode, normalizeClass, withCtx, createElementVNode, createCommentVNode, createBlock, renderList, unref } from "vue";
|
|
2
|
+
import { r as requireBase64toblob } from "../vendor/base64toblob/base64toblob.es.js";
|
|
3
|
+
import { u as useField } from "../vendor/vee-validate/dist/vee-validate.esm.es.js";
|
|
4
|
+
import { f as fe } from "../vendor/vue-advanced-cropper/dist/index.esm-bundler.es.js";
|
|
5
|
+
import { u as useWangsVueConfig } from "../plugins/WangsVue.es.js";
|
|
6
|
+
import { g as genPlaceholder, a as genRandomPlaceholderBg } from "../utils/genPlaceholder.util.es.js";
|
|
7
|
+
import { _ as _sfc_main$2 } from "../image/index.es.js";
|
|
8
|
+
import { _ as _sfc_main$4 } from "../button/index.es.js";
|
|
9
|
+
import { _ as _sfc_main$7 } from "../buttonradio/index.es.js";
|
|
10
|
+
import { _ as _sfc_main$a } from "../dialog/index.es.js";
|
|
11
|
+
import { _ as _sfc_main$5 } from "../dialogconfirm/index.es.js";
|
|
12
|
+
import { _ as _sfc_main$1 } from "../fieldwrapper/index.es.js";
|
|
13
|
+
import { _ as _sfc_main$3 } from "../icon/index.es.js";
|
|
14
|
+
import { _ as _sfc_main$9 } from "../invisiblefield/index.es.js";
|
|
15
|
+
import { _ as _sfc_main$8 } from "../validatormessage/index.es.js";
|
|
16
|
+
import { B as BackgroundImageCropper } from "../backgroundimagecropper/index.es.js";
|
|
17
|
+
import { _ as _sfc_main$6 } from "../imageinputinfo/index.es.js";
|
|
18
18
|
/* empty css */
|
|
19
|
-
var
|
|
20
|
-
function
|
|
21
|
-
return
|
|
19
|
+
var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
|
|
20
|
+
function getDefaultExportFromCjs(x) {
|
|
21
|
+
return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, "default") ? x["default"] : x;
|
|
22
22
|
}
|
|
23
|
-
var
|
|
24
|
-
const
|
|
23
|
+
var base64toblobExports = requireBase64toblob();
|
|
24
|
+
const base64toblob = /* @__PURE__ */ getDefaultExportFromCjs(base64toblobExports);
|
|
25
|
+
const _hoisted_1 = {
|
|
25
26
|
key: 1,
|
|
26
27
|
class: "flex gap-1 items-start"
|
|
27
|
-
}
|
|
28
|
+
};
|
|
29
|
+
const _hoisted_2 = ["id", "multiple"];
|
|
30
|
+
const _hoisted_3 = ["for"];
|
|
31
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
28
32
|
__name: "ImageCompressor",
|
|
29
|
-
props: /* @__PURE__ */
|
|
33
|
+
props: /* @__PURE__ */ mergeModels({
|
|
30
34
|
initialName: {},
|
|
31
35
|
multiple: { type: Boolean },
|
|
32
36
|
defaultImage: {},
|
|
33
|
-
disabled: { type: Boolean, default:
|
|
37
|
+
disabled: { type: Boolean, default: false },
|
|
34
38
|
compressedBlob: { default: void 0 },
|
|
35
39
|
imagePreviewUrl: { default: void 0 },
|
|
36
40
|
imagePreviewSize: { default: "big" },
|
|
37
|
-
rounded: { type: Boolean, default:
|
|
38
|
-
useDeleteButton: { type: Boolean, default:
|
|
39
|
-
useValidator: { type: Boolean, default:
|
|
40
|
-
mandatory: { type: Boolean, default:
|
|
41
|
+
rounded: { type: Boolean, default: false },
|
|
42
|
+
useDeleteButton: { type: Boolean, default: true },
|
|
43
|
+
useValidator: { type: Boolean, default: false },
|
|
44
|
+
mandatory: { type: Boolean, default: false },
|
|
41
45
|
invalid: { type: Boolean },
|
|
42
46
|
validatorMessage: { default: "Photo must be uploaded" },
|
|
43
47
|
label: { default: void 0 },
|
|
44
48
|
fieldName: { default: "imageInput" },
|
|
45
49
|
fieldInfo: { default: void 0 },
|
|
46
|
-
showInfo: { type: Boolean, default:
|
|
50
|
+
showInfo: { type: Boolean, default: true },
|
|
47
51
|
customRequirements: { default: void 0 },
|
|
48
52
|
confirmOnDelete: { type: Boolean },
|
|
49
53
|
emitDeleteFn: { type: Boolean },
|
|
50
|
-
showValidatorMessage: { type: Boolean, default:
|
|
54
|
+
showValidatorMessage: { type: Boolean, default: true },
|
|
51
55
|
fileType: { default: "webp" },
|
|
52
56
|
type: { default: "normal" }
|
|
53
57
|
}, {
|
|
54
|
-
defaultImage: { default: 0 },
|
|
55
|
-
defaultImageModifiers: {}
|
|
58
|
+
"defaultImage": { default: 0 },
|
|
59
|
+
"defaultImageModifiers": {}
|
|
56
60
|
}),
|
|
57
|
-
emits: /* @__PURE__ */
|
|
58
|
-
setup(
|
|
59
|
-
const
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
}
|
|
63
|
-
|
|
61
|
+
emits: /* @__PURE__ */ mergeModels(["apply", "applyProp", "update:defaultImage", "update:fieldValue", "delete"], ["update:defaultImage"]),
|
|
62
|
+
setup(__props, { expose: __expose, emit: __emit }) {
|
|
63
|
+
const ImagePreset = inject("preset", {}).image;
|
|
64
|
+
const props = __props;
|
|
65
|
+
const emit = __emit;
|
|
66
|
+
const { locale } = useWangsVueConfig("ImageCompressor");
|
|
67
|
+
onMounted(async () => {
|
|
68
|
+
setField();
|
|
69
|
+
assignPreviewImagesFromProp();
|
|
70
|
+
});
|
|
71
|
+
onUnmounted(() => {
|
|
72
|
+
revokeObjectURL(0);
|
|
73
|
+
revokeObjectURL(1);
|
|
64
74
|
});
|
|
65
|
-
const
|
|
75
|
+
const image = ref([
|
|
66
76
|
{
|
|
67
77
|
src: null,
|
|
68
78
|
type: null
|
|
@@ -71,81 +81,170 @@ const Ge = /* @__PURE__ */ xe(Ke), He = {
|
|
|
71
81
|
src: null,
|
|
72
82
|
type: null
|
|
73
83
|
}
|
|
74
|
-
])
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
84
|
+
]);
|
|
85
|
+
const randomBg = genRandomPlaceholderBg();
|
|
86
|
+
const canvasPlaceholder = ref();
|
|
87
|
+
const canvas = ref();
|
|
88
|
+
const previewImages = ref([]);
|
|
89
|
+
const inputImageFile = ref();
|
|
90
|
+
const inputImageFileKey = shallowRef(0);
|
|
91
|
+
const vueAdvanceCropper = ref();
|
|
92
|
+
const resolveFn = ref();
|
|
93
|
+
const currentCropingImageIndex = shallowRef();
|
|
94
|
+
const defaultImage = useModel(__props, "defaultImage");
|
|
95
|
+
const field = reactive({
|
|
96
|
+
value: props.multiple ? [] : void 0
|
|
97
|
+
});
|
|
98
|
+
const invalidInput = shallowRef(false);
|
|
99
|
+
const invalidMessage = shallowRef();
|
|
100
|
+
const inputImageKey = shallowRef(0);
|
|
101
|
+
const showImageCropper = shallowRef(false);
|
|
102
|
+
const showDeleteConfirm = ref([false, false]);
|
|
103
|
+
const formattedFileType = computed(() => `image/${props.fileType}`);
|
|
104
|
+
const isInitialImage = (index) => {
|
|
105
|
+
return typeof previewImages.value[index] == "string" && previewImages.value[index].includes("data:image/png;base64");
|
|
106
|
+
};
|
|
107
|
+
const assignPreviewImagesFromProp = async () => {
|
|
108
|
+
var _a, _b;
|
|
109
|
+
if ((_a = props.imagePreviewUrl) == null ? void 0 : _a.length) {
|
|
110
|
+
previewImages.value = Array.isArray(props.imagePreviewUrl) ? props.imagePreviewUrl : [props.imagePreviewUrl];
|
|
111
|
+
} else if (Array.isArray(props.compressedBlob)) {
|
|
112
|
+
previewImages.value = props.compressedBlob;
|
|
113
|
+
} else if (props.compressedBlob) {
|
|
114
|
+
previewImages.value = [props.compressedBlob];
|
|
115
|
+
} else if (props.initialName) {
|
|
116
|
+
canvasPlaceholder.value = genPlaceholder(props.initialName, 125, randomBg);
|
|
117
|
+
previewImages.value = [(_b = canvasPlaceholder.value) == null ? void 0 : _b.toDataURL()];
|
|
118
|
+
} else {
|
|
119
|
+
previewImages.value = [];
|
|
120
|
+
}
|
|
121
|
+
if (props.imagePreviewUrl) {
|
|
122
|
+
field.value = props.imagePreviewUrl;
|
|
123
|
+
} else if (props.initialName) {
|
|
124
|
+
field.value = await canvasToFile();
|
|
125
|
+
}
|
|
126
|
+
emit("applyProp");
|
|
127
|
+
};
|
|
128
|
+
const canvasToFile = async () => {
|
|
129
|
+
return new Promise((resolve) => {
|
|
130
|
+
var _a;
|
|
131
|
+
(_a = canvasPlaceholder.value) == null ? void 0 : _a.toBlob((blob) => {
|
|
132
|
+
resolve(
|
|
133
|
+
new File([blob ?? new Blob()], Date.now() + ".png", {
|
|
134
|
+
type: "image/png"
|
|
135
|
+
})
|
|
136
|
+
);
|
|
137
|
+
});
|
|
87
138
|
});
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
139
|
+
};
|
|
140
|
+
const pickImage = (addPhoto = false) => {
|
|
141
|
+
var _a;
|
|
142
|
+
if (props.disabled) return;
|
|
143
|
+
if (addPhoto) currentCropingImageIndex.value = 1;
|
|
144
|
+
(_a = inputImageFile.value) == null ? void 0 : _a.click();
|
|
145
|
+
};
|
|
146
|
+
const handleImageSelected = async (event) => {
|
|
147
|
+
const { files } = event.target;
|
|
148
|
+
const imageFiles = Array.from(files ?? []).slice(
|
|
93
149
|
0,
|
|
94
|
-
|
|
150
|
+
previewImages.value.length ? 1 : 2
|
|
95
151
|
);
|
|
96
|
-
for (const [
|
|
152
|
+
for (const [index, file] of imageFiles.entries()) {
|
|
97
153
|
try {
|
|
98
|
-
const
|
|
99
|
-
await
|
|
100
|
-
} catch (
|
|
101
|
-
console.error("Error loading image:",
|
|
154
|
+
const imageIndex = currentCropingImageIndex.value ?? index;
|
|
155
|
+
await loadImage(file, imageIndex);
|
|
156
|
+
} catch (error) {
|
|
157
|
+
console.error("Error loading image:", error);
|
|
102
158
|
} finally {
|
|
103
|
-
|
|
159
|
+
currentCropingImageIndex.value = void 0;
|
|
104
160
|
}
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
161
|
+
}
|
|
162
|
+
};
|
|
163
|
+
const loadImage = async (file, index) => {
|
|
164
|
+
const isImageType = (type) => {
|
|
165
|
+
return type.includes("image");
|
|
166
|
+
};
|
|
167
|
+
const isExceededLimit = (size) => size > 1e6;
|
|
168
|
+
return new Promise((resolve, reject) => {
|
|
169
|
+
var _a, _b;
|
|
170
|
+
if (file) {
|
|
171
|
+
resetCropper(index);
|
|
172
|
+
if (!isImageType(file.type)) {
|
|
173
|
+
invalidInput.value = true;
|
|
174
|
+
invalidMessage.value = typeof props.validatorMessage !== "string" && ((_a = props.validatorMessage) == null ? void 0 : _a.invalidFormat) ? props.validatorMessage.invalidFormat : "Tipe file harus berupa gambar!";
|
|
175
|
+
assignPreviewImagesFromProp();
|
|
176
|
+
showImageCropper.value = false;
|
|
177
|
+
revokeObjectURL(index);
|
|
178
|
+
reject("Tipe file harus berupa gambar!");
|
|
179
|
+
} else if (isExceededLimit(file.size)) {
|
|
180
|
+
invalidInput.value = true;
|
|
181
|
+
invalidMessage.value = typeof props.validatorMessage !== "string" && ((_b = props.validatorMessage) == null ? void 0 : _b.exceed) ? props.validatorMessage.exceed : "Ukuran gambar terlalu besar! Maks. 1 MB";
|
|
182
|
+
assignPreviewImagesFromProp();
|
|
183
|
+
showImageCropper.value = false;
|
|
184
|
+
revokeObjectURL(index);
|
|
185
|
+
reject("Ukuran gambar terlalu besar! Maks. 1 MB");
|
|
186
|
+
} else {
|
|
187
|
+
revokeObjectURL(index);
|
|
188
|
+
const blob = URL.createObjectURL(file);
|
|
189
|
+
const reader = new FileReader();
|
|
190
|
+
reader.onload = (e) => {
|
|
191
|
+
var _a2;
|
|
192
|
+
image.value[index].src = blob;
|
|
193
|
+
image.value[index].type = getMimeType(
|
|
194
|
+
(_a2 = e == null ? void 0 : e.target) == null ? void 0 : _a2.result,
|
|
195
|
+
file.type
|
|
122
196
|
);
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
|
|
197
|
+
};
|
|
198
|
+
reader.onerror = (e) => {
|
|
199
|
+
console.error("🚀 ~ returnnewPromise ~ e:", e);
|
|
200
|
+
};
|
|
201
|
+
reader.readAsArrayBuffer(file);
|
|
202
|
+
if (currentCropingImageIndex.value == null)
|
|
203
|
+
currentCropingImageIndex.value = index;
|
|
204
|
+
if (!showImageCropper.value) showImageCropper.value = true;
|
|
205
|
+
invalidInput.value = false;
|
|
206
|
+
invalidMessage.value = void 0;
|
|
126
207
|
}
|
|
127
|
-
|
|
208
|
+
}
|
|
209
|
+
inputImageKey.value += 1;
|
|
210
|
+
resolveFn.value = resolve;
|
|
128
211
|
});
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
212
|
+
};
|
|
213
|
+
const setField = () => {
|
|
214
|
+
if (props.useValidator) {
|
|
215
|
+
Object.assign(
|
|
216
|
+
field,
|
|
217
|
+
useField(props.fieldName, (value) => {
|
|
218
|
+
var _a;
|
|
219
|
+
if (!value && props.mandatory) {
|
|
220
|
+
if (typeof props.validatorMessage !== "string" && ((_a = props.validatorMessage) == null ? void 0 : _a.empty)) {
|
|
221
|
+
return props.validatorMessage.empty;
|
|
222
|
+
}
|
|
223
|
+
return (props.label ?? "Photo") + " must be uploaded";
|
|
224
|
+
} else if (props.invalid && props.validatorMessage) {
|
|
225
|
+
return props.validatorMessage;
|
|
226
|
+
} else if (invalidMessage.value) {
|
|
227
|
+
return invalidMessage.value;
|
|
228
|
+
}
|
|
229
|
+
return true;
|
|
230
|
+
})
|
|
231
|
+
);
|
|
232
|
+
}
|
|
233
|
+
};
|
|
234
|
+
const resetCropper = (index) => {
|
|
235
|
+
image.value[index] = {
|
|
139
236
|
src: null,
|
|
140
237
|
type: null
|
|
141
238
|
};
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
239
|
+
};
|
|
240
|
+
const getMimeType = (file, fallback = null) => {
|
|
241
|
+
if (file) {
|
|
242
|
+
const byteArray = new Uint8Array(file).subarray(0, 4);
|
|
243
|
+
let header = "";
|
|
244
|
+
for (const element of byteArray) {
|
|
245
|
+
header += element.toString(16);
|
|
246
|
+
}
|
|
247
|
+
switch (header) {
|
|
149
248
|
case "89504e47":
|
|
150
249
|
return "image/png";
|
|
151
250
|
case "47494638":
|
|
@@ -155,380 +254,448 @@ const Ge = /* @__PURE__ */ xe(Ke), He = {
|
|
|
155
254
|
case "ffd8ffe2":
|
|
156
255
|
case "ffd8ffe3":
|
|
157
256
|
case "ffd8ffe8":
|
|
158
|
-
return
|
|
257
|
+
return formattedFileType.value;
|
|
159
258
|
default:
|
|
160
|
-
return
|
|
259
|
+
return fallback;
|
|
161
260
|
}
|
|
162
261
|
}
|
|
163
262
|
return null;
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
const
|
|
263
|
+
};
|
|
264
|
+
const toBlobObjectURL = (imgUrl) => {
|
|
265
|
+
const blob = base64toblob(imgUrl.split(",")[1], formattedFileType.value);
|
|
266
|
+
const url = window.URL.createObjectURL(blob);
|
|
267
|
+
return url;
|
|
268
|
+
};
|
|
269
|
+
const blobToFile = async (url, name) => {
|
|
270
|
+
const blobFile = await fetch(url).then((f) => f.blob());
|
|
271
|
+
return new File([blobFile], name, { type: formattedFileType.value });
|
|
272
|
+
};
|
|
273
|
+
const applyImageCropper = async () => {
|
|
274
|
+
const currentImageIndex = currentCropingImageIndex.value ?? 0;
|
|
172
275
|
try {
|
|
173
|
-
await
|
|
174
|
-
} catch (
|
|
175
|
-
console.error(
|
|
276
|
+
await cropImage(currentImageIndex);
|
|
277
|
+
} catch (error) {
|
|
278
|
+
console.error(error);
|
|
176
279
|
}
|
|
177
|
-
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
280
|
+
closeImageCropper();
|
|
281
|
+
};
|
|
282
|
+
const closeImageCropper = () => {
|
|
283
|
+
var _a;
|
|
284
|
+
showImageCropper.value = false;
|
|
285
|
+
(_a = resolveFn.value) == null ? void 0 : _a.call(resolveFn);
|
|
286
|
+
resolveFn.value = void 0;
|
|
287
|
+
};
|
|
288
|
+
const cropImage = async (index) => {
|
|
289
|
+
if (vueAdvanceCropper.value) {
|
|
290
|
+
const croppedImage = vueAdvanceCropper.value.getResult();
|
|
291
|
+
if (croppedImage.canvas) {
|
|
292
|
+
const base64 = croppedImage.canvas.toDataURL(formattedFileType.value);
|
|
293
|
+
await drawCroppedImage(base64, index);
|
|
187
294
|
}
|
|
188
295
|
}
|
|
189
|
-
}
|
|
296
|
+
};
|
|
297
|
+
const drawCroppedImage = async (imageDataURL, index) => {
|
|
190
298
|
try {
|
|
191
|
-
|
|
192
|
-
const
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
const
|
|
197
|
-
|
|
299
|
+
canvas.value = document.createElement("canvas");
|
|
300
|
+
const canvasContext = canvas.value.getContext("2d");
|
|
301
|
+
const newImage = new Image();
|
|
302
|
+
newImage.src = imageDataURL;
|
|
303
|
+
await newImage.decode();
|
|
304
|
+
const formattedScale = 80 / 100;
|
|
305
|
+
const width = newImage.width * formattedScale;
|
|
306
|
+
const height = newImage.height * formattedScale;
|
|
307
|
+
canvas.value.setAttribute("width", width.toString());
|
|
308
|
+
canvas.value.setAttribute("height", height.toString());
|
|
309
|
+
if (canvasContext) canvasContext.drawImage(newImage, 0, 0, width, height);
|
|
310
|
+
const base64 = canvas.value.toDataURL(formattedFileType.value, 0.95);
|
|
311
|
+
const fileName = Date.now() + `.${props.fileType}`;
|
|
312
|
+
const imageCompressorPayload = {
|
|
313
|
+
canvas: canvas.value,
|
|
198
314
|
compressed: {
|
|
199
|
-
blob:
|
|
200
|
-
base64
|
|
201
|
-
fileName
|
|
202
|
-
file: await
|
|
315
|
+
blob: toBlobObjectURL(base64),
|
|
316
|
+
base64,
|
|
317
|
+
fileName,
|
|
318
|
+
file: await blobToFile(toBlobObjectURL(base64), fileName),
|
|
203
319
|
size: "",
|
|
204
|
-
type:
|
|
320
|
+
type: formattedFileType.value
|
|
205
321
|
},
|
|
206
322
|
message: "File has been compressed."
|
|
207
323
|
};
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
324
|
+
imageCompressorPayload.compressed.size = Math.round(imageCompressorPayload.compressed.file.size / 1e3) + "KB";
|
|
325
|
+
previewImages.value[index] = imageCompressorPayload.compressed.blob;
|
|
326
|
+
if (props.multiple) {
|
|
327
|
+
if (field.value && Array.isArray(field.value)) {
|
|
328
|
+
field.value[index] = imageCompressorPayload.compressed.file;
|
|
329
|
+
} else {
|
|
330
|
+
field.value = [imageCompressorPayload.compressed.file];
|
|
331
|
+
}
|
|
332
|
+
} else {
|
|
333
|
+
field.value = imageCompressorPayload.compressed.file;
|
|
334
|
+
}
|
|
335
|
+
emit("apply", imageCompressorPayload);
|
|
336
|
+
} catch (error) {
|
|
337
|
+
console.error(error);
|
|
338
|
+
}
|
|
339
|
+
};
|
|
340
|
+
const revokeObjectURL = (index) => {
|
|
341
|
+
if (image.value[index].src) URL.revokeObjectURL(image.value[index].src);
|
|
342
|
+
};
|
|
343
|
+
const onBeforeDeleteImage = (index) => {
|
|
344
|
+
if (props.confirmOnDelete) {
|
|
345
|
+
showDeleteConfirm.value[index] = true;
|
|
346
|
+
} else if (props.emitDeleteFn) {
|
|
347
|
+
emit("delete", deleteImage, index);
|
|
348
|
+
} else deleteImage(index);
|
|
349
|
+
};
|
|
350
|
+
const deleteImage = (index = 0) => {
|
|
351
|
+
invalidInput.value = false;
|
|
352
|
+
invalidMessage.value = void 0;
|
|
353
|
+
previewImages.value = previewImages.value.toSpliced(index, 1);
|
|
354
|
+
revokeObjectURL(index);
|
|
355
|
+
image.value[index] = { src: null, type: null };
|
|
356
|
+
image.value = [image.value[+!index], image.value[index]];
|
|
357
|
+
currentCropingImageIndex.value = 0;
|
|
358
|
+
defaultImage.value = 0;
|
|
359
|
+
if (!props.confirmOnDelete) emit("delete");
|
|
360
|
+
if (props.multiple && Array.isArray(field.value)) {
|
|
361
|
+
field.value = field.value.toSpliced(index, 1);
|
|
362
|
+
} else if (field.handleReset) field.handleReset();
|
|
363
|
+
};
|
|
364
|
+
const editImage = (index) => {
|
|
365
|
+
var _a;
|
|
366
|
+
const currentPreviewImage = (_a = previewImages.value[index]) == null ? void 0 : _a.toString();
|
|
367
|
+
currentCropingImageIndex.value = index;
|
|
368
|
+
if (currentPreviewImage == null ? void 0 : currentPreviewImage.includes("blob")) {
|
|
369
|
+
currentCropingImageIndex.value = index;
|
|
370
|
+
showImageCropper.value = true;
|
|
371
|
+
} else {
|
|
372
|
+
resetCropper(index);
|
|
373
|
+
pickImage();
|
|
211
374
|
}
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
return V(
|
|
226
|
-
() => i.value,
|
|
227
|
-
(e) => {
|
|
228
|
-
(e instanceof File || Array.isArray(e) && e.some((a) => a instanceof File)) && C("update:fieldValue", e);
|
|
375
|
+
};
|
|
376
|
+
const changeImage = () => {
|
|
377
|
+
pickImage();
|
|
378
|
+
};
|
|
379
|
+
const isChromeBased = computed(() => {
|
|
380
|
+
return navigator.userAgent.includes("Chrome");
|
|
381
|
+
});
|
|
382
|
+
watch(
|
|
383
|
+
() => field.value,
|
|
384
|
+
(value) => {
|
|
385
|
+
if (value instanceof File || Array.isArray(value) && value.some((v) => v instanceof File)) {
|
|
386
|
+
emit("update:fieldValue", value);
|
|
387
|
+
}
|
|
229
388
|
}
|
|
230
|
-
)
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
()
|
|
389
|
+
);
|
|
390
|
+
watch(invalidMessage, (value) => {
|
|
391
|
+
if (value && field.setErrors) field.setErrors(value);
|
|
392
|
+
});
|
|
393
|
+
watch(showImageCropper, (value) => {
|
|
394
|
+
if (!value) inputImageFileKey.value++;
|
|
395
|
+
});
|
|
396
|
+
watch(
|
|
397
|
+
() => props.initialName,
|
|
236
398
|
() => {
|
|
237
|
-
|
|
399
|
+
assignPreviewImagesFromProp();
|
|
238
400
|
}
|
|
239
|
-
)
|
|
240
|
-
|
|
401
|
+
);
|
|
402
|
+
watch(
|
|
403
|
+
() => props.imagePreviewUrl,
|
|
241
404
|
() => {
|
|
242
|
-
|
|
405
|
+
assignPreviewImagesFromProp();
|
|
243
406
|
},
|
|
244
|
-
{ once:
|
|
245
|
-
)
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
"
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
"flex gap-1 items-center",
|
|
278
|
-
{ "max-w-[80px]": e.imagePreviewSize === "medium" },
|
|
279
|
-
{ "max-w-[125px]": e.imagePreviewSize === "big" },
|
|
280
|
-
{ "flex-col": e.type === "normal" }
|
|
281
|
-
]),
|
|
282
|
-
"data-wv-section": "preview-image-wrapper"
|
|
407
|
+
{ once: true }
|
|
408
|
+
);
|
|
409
|
+
__expose({ assignPreviewImagesFromProp });
|
|
410
|
+
return (_ctx, _cache) => {
|
|
411
|
+
return openBlock(), createElementBlock(Fragment, null, [
|
|
412
|
+
createVNode(_sfc_main$1, {
|
|
413
|
+
class: normalizeClass([{ "!w-max": !props.multiple, "!w-full": props.multiple }]),
|
|
414
|
+
info: props.fieldInfo,
|
|
415
|
+
label: props.label,
|
|
416
|
+
mandatory: props.mandatory,
|
|
417
|
+
"data-wv-name": "image-compressor",
|
|
418
|
+
"data-wv-section": "root"
|
|
419
|
+
}, {
|
|
420
|
+
default: withCtx(() => [
|
|
421
|
+
createElementVNode("div", {
|
|
422
|
+
class: normalizeClass([
|
|
423
|
+
"w-full",
|
|
424
|
+
{ "grid gap-6 items-start grid-cols-2": _ctx.multiple && _ctx.type === "normal" },
|
|
425
|
+
{
|
|
426
|
+
"grid gap-3 items-start grid-cols-[max-content,max-content]": _ctx.multiple && _ctx.type === "inline-table"
|
|
427
|
+
}
|
|
428
|
+
]),
|
|
429
|
+
"data-wv-section": "wrapper"
|
|
430
|
+
}, [
|
|
431
|
+
previewImages.value.length ? (openBlock(true), createElementBlock(Fragment, { key: 0 }, renderList(previewImages.value, (previewImage, index) => {
|
|
432
|
+
var _a;
|
|
433
|
+
return openBlock(), createElementBlock("div", {
|
|
434
|
+
key: index,
|
|
435
|
+
class: normalizeClass([[
|
|
436
|
+
{ "items-start": _ctx.type === "normal" },
|
|
437
|
+
{ "items-center": _ctx.type === "inline-table" }
|
|
438
|
+
], "flex gap-1"]),
|
|
439
|
+
"data-wv-section": "preview"
|
|
283
440
|
}, [
|
|
284
|
-
|
|
285
|
-
class:
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
},
|
|
289
|
-
"
|
|
290
|
-
{
|
|
291
|
-
"w-[125px] h-[125px]": e.imagePreviewSize === "big" && e.type === "normal",
|
|
292
|
-
"w-[30px] h-[30px]": e.imagePreviewSize === "small" || e.type === "inline-table",
|
|
293
|
-
"w-[80px] h-[80px]": e.imagePreviewSize === "medium" && e.type === "normal"
|
|
294
|
-
}
|
|
441
|
+
createElementVNode("div", {
|
|
442
|
+
class: normalizeClass([
|
|
443
|
+
"flex gap-1 items-center",
|
|
444
|
+
{ "max-w-[80px]": _ctx.imagePreviewSize === "medium" },
|
|
445
|
+
{ "max-w-[125px]": _ctx.imagePreviewSize === "big" },
|
|
446
|
+
{ "flex-col": _ctx.type === "normal" }
|
|
295
447
|
]),
|
|
296
|
-
"data-wv-section": "image-wrapper"
|
|
448
|
+
"data-wv-section": "preview-image-wrapper"
|
|
297
449
|
}, [
|
|
298
|
-
|
|
299
|
-
class:
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
"hover:bg-opacity-0 rounded-lg opacity-0"
|
|
450
|
+
createElementVNode("div", {
|
|
451
|
+
class: normalizeClass([
|
|
452
|
+
{
|
|
453
|
+
"[&>span]:hover:opacity-30 [&>[data-wv-section=input-image-trigger]]:hover:opacity-100": isInitialImage(index)
|
|
454
|
+
},
|
|
455
|
+
"relative",
|
|
456
|
+
{
|
|
457
|
+
"w-[125px] h-[125px]": _ctx.imagePreviewSize === "big" && _ctx.type === "normal",
|
|
458
|
+
"w-[30px] h-[30px]": _ctx.imagePreviewSize === "small" || _ctx.type === "inline-table",
|
|
459
|
+
"w-[80px] h-[80px]": _ctx.imagePreviewSize === "medium" && _ctx.type === "normal"
|
|
460
|
+
}
|
|
310
461
|
]),
|
|
311
|
-
|
|
312
|
-
"data-wv-section": "input-image-trigger",
|
|
313
|
-
type: "button"
|
|
462
|
+
"data-wv-section": "image-wrapper"
|
|
314
463
|
}, [
|
|
315
|
-
|
|
316
|
-
class: "w-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
icon: "
|
|
336
|
-
label: "Edit",
|
|
337
|
-
text: ""
|
|
338
|
-
}, null, 8, ["onClick"]),
|
|
339
|
-
e.useDeleteButton ? (n(), k(z, {
|
|
340
|
-
key: 0,
|
|
341
|
-
onClick: (r) => ee(t),
|
|
342
|
-
class: "!py-0 !px-1 !h-max",
|
|
343
|
-
icon: "delete-bin",
|
|
344
|
-
label: "Delete",
|
|
345
|
-
severity: "danger",
|
|
346
|
-
text: ""
|
|
347
|
-
}, null, 8, ["onClick"])) : c("", !0)
|
|
348
|
-
], 64)) : (n(), v(T, { key: 1 }, [
|
|
349
|
-
m(x, {
|
|
350
|
-
onClick: (r) => ae(t),
|
|
351
|
-
class: "text-xs p-0.5 rounded-xs mr-1",
|
|
352
|
-
icon: "pencil",
|
|
464
|
+
createVNode(_sfc_main$2, {
|
|
465
|
+
class: normalizeClass([{ "w-[30px] h-[30px]": _ctx.type === "inline-table" }, "transition-opacity duration-300"]),
|
|
466
|
+
rounded: _ctx.rounded,
|
|
467
|
+
size: _ctx.type === "normal" ? _ctx.imagePreviewSize : "small",
|
|
468
|
+
src: previewImage,
|
|
469
|
+
"data-wv-section": "preview-image"
|
|
470
|
+
}, null, 8, ["class", "rounded", "size", "src"]),
|
|
471
|
+
isInitialImage(index) ? (openBlock(), createElementBlock("button", {
|
|
472
|
+
key: 0,
|
|
473
|
+
class: normalizeClass([
|
|
474
|
+
(_a = unref(ImagePreset)) == null ? void 0 : _a.button.class,
|
|
475
|
+
"hover:bg-opacity-0 rounded-lg opacity-0"
|
|
476
|
+
]),
|
|
477
|
+
onClick: _cache[0] || (_cache[0] = ($event) => pickImage(false)),
|
|
478
|
+
"data-wv-section": "input-image-trigger",
|
|
479
|
+
type: "button"
|
|
480
|
+
}, [
|
|
481
|
+
createVNode(_sfc_main$3, {
|
|
482
|
+
class: "w-6 h-6",
|
|
483
|
+
"data-wv-section": "trigger-icon",
|
|
484
|
+
icon: "image-add",
|
|
353
485
|
severity: "primary"
|
|
354
|
-
}
|
|
355
|
-
|
|
356
|
-
onClick: (r) => ee(t),
|
|
357
|
-
class: "text-xs p-0.5 rounded-xs",
|
|
358
|
-
icon: "delete-bin",
|
|
359
|
-
severity: "danger"
|
|
360
|
-
}, null, 8, ["onClick"])
|
|
361
|
-
], 64))
|
|
486
|
+
})
|
|
487
|
+
], 2)) : createCommentVNode("", true)
|
|
362
488
|
], 2),
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
489
|
+
!props.disabled && !isInitialImage(index) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
|
|
490
|
+
createElementVNode("div", {
|
|
491
|
+
class: normalizeClass([
|
|
492
|
+
"flex gap-0.5 justify-center",
|
|
493
|
+
{ "scale-75": _ctx.imagePreviewSize === "medium" }
|
|
494
|
+
]),
|
|
495
|
+
"data-wv-section": "preview-buttons"
|
|
496
|
+
}, [
|
|
497
|
+
_ctx.type === "normal" ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
|
|
498
|
+
createVNode(_sfc_main$4, {
|
|
499
|
+
onClick: ($event) => editImage(index),
|
|
500
|
+
class: "!py-0 !px-1 !h-max",
|
|
501
|
+
icon: "pencil",
|
|
502
|
+
label: "Edit",
|
|
503
|
+
text: ""
|
|
504
|
+
}, null, 8, ["onClick"]),
|
|
505
|
+
_ctx.useDeleteButton ? (openBlock(), createBlock(_sfc_main$4, {
|
|
506
|
+
key: 0,
|
|
507
|
+
onClick: ($event) => onBeforeDeleteImage(index),
|
|
508
|
+
class: "!py-0 !px-1 !h-max",
|
|
509
|
+
icon: "delete-bin",
|
|
510
|
+
label: "Delete",
|
|
511
|
+
severity: "danger",
|
|
512
|
+
text: ""
|
|
513
|
+
}, null, 8, ["onClick"])) : createCommentVNode("", true)
|
|
514
|
+
], 64)) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [
|
|
515
|
+
createVNode(_sfc_main$3, {
|
|
516
|
+
onClick: ($event) => editImage(index),
|
|
517
|
+
class: "text-xs p-0.5 rounded-xs mr-1",
|
|
518
|
+
icon: "pencil",
|
|
519
|
+
severity: "primary"
|
|
520
|
+
}, null, 8, ["onClick"]),
|
|
521
|
+
createVNode(_sfc_main$3, {
|
|
522
|
+
onClick: ($event) => onBeforeDeleteImage(index),
|
|
523
|
+
class: "text-xs p-0.5 rounded-xs",
|
|
524
|
+
icon: "delete-bin",
|
|
525
|
+
severity: "danger"
|
|
526
|
+
}, null, 8, ["onClick"])
|
|
527
|
+
], 64))
|
|
528
|
+
], 2),
|
|
529
|
+
createVNode(_sfc_main$5, {
|
|
530
|
+
visible: showDeleteConfirm.value[index],
|
|
531
|
+
"onUpdate:visible": ($event) => showDeleteConfirm.value[index] = $event,
|
|
532
|
+
closable: false,
|
|
533
|
+
onConfirm: ($event) => emit("delete", deleteImage, index),
|
|
534
|
+
body: "Are you sure you want to delete it?",
|
|
535
|
+
"confirm-label": "Delete",
|
|
536
|
+
header: "Delete Photo",
|
|
537
|
+
severity: "danger"
|
|
538
|
+
}, null, 8, ["visible", "onUpdate:visible", "onConfirm"])
|
|
539
|
+
], 64)) : createCommentVNode("", true)
|
|
540
|
+
], 2),
|
|
541
|
+
_ctx.type === "normal" ? (openBlock(), createBlock(_sfc_main$6, {
|
|
542
|
+
key: 0,
|
|
543
|
+
"custom-requirements": _ctx.customRequirements,
|
|
544
|
+
"show-add-button": previewImages.value.length === 1 && props.multiple,
|
|
545
|
+
"show-info": _ctx.showInfo,
|
|
546
|
+
onAddPhoto: _cache[2] || (_cache[2] = ($event) => pickImage(true))
|
|
547
|
+
}, {
|
|
548
|
+
default: withCtx(() => [
|
|
549
|
+
previewImages.value.length === 2 && props.multiple ? (openBlock(), createBlock(_sfc_main$7, {
|
|
550
|
+
key: 0,
|
|
551
|
+
modelValue: defaultImage.value,
|
|
552
|
+
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => defaultImage.value = $event),
|
|
553
|
+
"label-id": "default-" + index,
|
|
554
|
+
value: index,
|
|
555
|
+
label: "Set as default"
|
|
556
|
+
}, null, 8, ["modelValue", "label-id", "value"])) : createCommentVNode("", true)
|
|
557
|
+
]),
|
|
558
|
+
_: 2
|
|
559
|
+
}, 1032, ["custom-requirements", "show-add-button", "show-info"])) : createCommentVNode("", true),
|
|
560
|
+
_ctx.multiple && previewImages.value.length == 1 && _ctx.type === "inline-table" ? (openBlock(), createBlock(_sfc_main$4, {
|
|
561
|
+
key: 1,
|
|
562
|
+
onClick: _cache[3] || (_cache[3] = ($event) => pickImage(true)),
|
|
563
|
+
icon: "add",
|
|
564
|
+
label: "Photo",
|
|
565
|
+
text: ""
|
|
566
|
+
})) : createCommentVNode("", true)
|
|
567
|
+
], 2);
|
|
568
|
+
}), 128)) : _ctx.type != "inline-table" ? (openBlock(), createElementBlock("div", _hoisted_1, [
|
|
569
|
+
createElementVNode("button", {
|
|
570
|
+
class: normalizeClass([
|
|
571
|
+
{
|
|
572
|
+
"w-[125px] h-[125px]": _ctx.imagePreviewSize === "big",
|
|
573
|
+
"w-[30px] h-[30px]": _ctx.imagePreviewSize === "small",
|
|
574
|
+
"w-[80px] h-[80px]": _ctx.imagePreviewSize === "medium"
|
|
575
|
+
},
|
|
576
|
+
"flex items-center justify-center",
|
|
577
|
+
"ring-inset",
|
|
578
|
+
"cursor-pointer",
|
|
579
|
+
{
|
|
580
|
+
"ring-1": !isChromeBased.value,
|
|
581
|
+
"ring-[0.5px]": isChromeBased.value
|
|
582
|
+
},
|
|
583
|
+
{ "rounded-full": _ctx.rounded, "rounded-lg": !_ctx.rounded },
|
|
584
|
+
{
|
|
585
|
+
"ring-general-400 focus-visible:ring-primary-500": !invalidInput.value && !field.errorMessage,
|
|
586
|
+
"ring-danger-500": invalidInput.value || field.errorMessage
|
|
587
|
+
},
|
|
588
|
+
{
|
|
589
|
+
"bg-white": !props.disabled,
|
|
590
|
+
"bg-general-50": props.disabled
|
|
591
|
+
}
|
|
391
592
|
]),
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
(
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
text: "",
|
|
495
|
-
type: "button"
|
|
496
|
-
}, null, 8, ["label"]),
|
|
497
|
-
m(z, {
|
|
498
|
-
label: R(j).changeImageLabel,
|
|
499
|
-
onClick: Ie,
|
|
500
|
-
"data-wv-section": "change-image-button",
|
|
501
|
-
text: "",
|
|
502
|
-
type: "button"
|
|
503
|
-
}, null, 8, ["label"]),
|
|
504
|
-
m(z, {
|
|
505
|
-
label: R(j).applyCropLabel,
|
|
506
|
-
onClick: be,
|
|
507
|
-
"data-wv-section": "apply-image-button",
|
|
508
|
-
severity: "success",
|
|
509
|
-
type: "button"
|
|
510
|
-
}, null, 8, ["label"])
|
|
511
|
-
]),
|
|
512
|
-
default: q(() => [
|
|
513
|
-
d.value != null ? (n(), k(R($e), {
|
|
514
|
-
key: 0,
|
|
515
|
-
ref_key: "vueAdvanceCropper",
|
|
516
|
-
ref: G,
|
|
517
|
-
"auto-zoom": !1,
|
|
518
|
-
"background-wrapper-component": qe,
|
|
519
|
-
src: f.value[d.value].src,
|
|
520
|
-
class: "upload-example-cropper h-400",
|
|
521
|
-
"foreground-class": "h-400",
|
|
522
|
-
"image-class": "h-400"
|
|
523
|
-
}, null, 8, ["src"])) : c("", !0)
|
|
524
|
-
]),
|
|
525
|
-
_: 1
|
|
526
|
-
}, 8, ["visible", "header"])
|
|
527
|
-
], 64));
|
|
593
|
+
onClick: _cache[4] || (_cache[4] = ($event) => pickImage(false)),
|
|
594
|
+
"data-wv-section": "input-image-trigger",
|
|
595
|
+
type: "button"
|
|
596
|
+
}, [
|
|
597
|
+
createVNode(_sfc_main$3, {
|
|
598
|
+
class: "w-6 h-6",
|
|
599
|
+
"data-wv-section": "trigger-icon",
|
|
600
|
+
icon: "image-add",
|
|
601
|
+
severity: "primary"
|
|
602
|
+
})
|
|
603
|
+
], 2),
|
|
604
|
+
createVNode(_sfc_main$6, {
|
|
605
|
+
"custom-requirements": _ctx.customRequirements,
|
|
606
|
+
"show-info": _ctx.showInfo
|
|
607
|
+
}, null, 8, ["custom-requirements", "show-info"])
|
|
608
|
+
])) : createCommentVNode("", true)
|
|
609
|
+
], 2),
|
|
610
|
+
(openBlock(), createElementBlock("input", {
|
|
611
|
+
id: _ctx.fieldName,
|
|
612
|
+
key: inputImageFileKey.value,
|
|
613
|
+
ref_key: "inputImageFile",
|
|
614
|
+
ref: inputImageFile,
|
|
615
|
+
multiple: props.multiple && !previewImages.value.length,
|
|
616
|
+
onChange: handleImageSelected,
|
|
617
|
+
accept: "image/*",
|
|
618
|
+
class: "hidden",
|
|
619
|
+
"data-wv-section": "hidden-image-input",
|
|
620
|
+
type: "file"
|
|
621
|
+
}, null, 40, _hoisted_2)),
|
|
622
|
+
_ctx.type === "inline-table" && !previewImages.value.length ? (openBlock(), createElementBlock("label", {
|
|
623
|
+
key: 0,
|
|
624
|
+
for: _ctx.fieldName,
|
|
625
|
+
class: "inline-flex items-center cursor-pointer"
|
|
626
|
+
}, _cache[6] || (_cache[6] = [
|
|
627
|
+
createElementVNode("span", { class: "inline-flex items-center text-body-medium rounded-bl rounded-tl bg-general-50 px-3 h-[26px] border-[0.5px] border-general-200" }, " Browse ", -1),
|
|
628
|
+
createElementVNode("span", { class: "inline-flex items-center text-body-medium !text-general-200 !font-light rounded-br rounded-tr px-3 h-[26px] leading-4 border-[0.5px] border-l-0 border-general-200" }, " Select File ", -1)
|
|
629
|
+
]), 8, _hoisted_3)) : createCommentVNode("", true),
|
|
630
|
+
_ctx.showValidatorMessage ? (openBlock(), createBlock(_sfc_main$8, {
|
|
631
|
+
key: 1,
|
|
632
|
+
format: false,
|
|
633
|
+
message: field.errorMessage ?? invalidMessage.value
|
|
634
|
+
}, null, 8, ["message"])) : createCommentVNode("", true),
|
|
635
|
+
props.multiple ? (openBlock(), createBlock(_sfc_main$9, {
|
|
636
|
+
key: 2,
|
|
637
|
+
value: defaultImage.value ? "secondImage" : "firstImage",
|
|
638
|
+
"field-name": "defaultImage"
|
|
639
|
+
}, null, 8, ["value"])) : createCommentVNode("", true)
|
|
640
|
+
]),
|
|
641
|
+
_: 1
|
|
642
|
+
}, 8, ["class", "info", "label", "mandatory"]),
|
|
643
|
+
createVNode(_sfc_main$a, {
|
|
644
|
+
visible: showImageCropper.value,
|
|
645
|
+
"onUpdate:visible": _cache[5] || (_cache[5] = ($event) => showImageCropper.value = $event),
|
|
646
|
+
draggable: false,
|
|
647
|
+
header: unref(locale).cropDialogHeader,
|
|
648
|
+
class: "w-max max-w-[98vw] min-w-[min(500px,98vw)] !max-h-[94vh]",
|
|
649
|
+
"content-class": "overflow-hidden overflow-y-auto min-h-[100px]",
|
|
650
|
+
"data-wv-section": "dialog-cropper",
|
|
651
|
+
"footer-class": "!gap-1",
|
|
652
|
+
modal: ""
|
|
653
|
+
}, {
|
|
654
|
+
footer: withCtx(() => [
|
|
655
|
+
createVNode(_sfc_main$4, {
|
|
656
|
+
label: unref(locale).cancelCropLabel,
|
|
657
|
+
onClick: closeImageCropper,
|
|
658
|
+
"data-wv-section": "cancel-crop",
|
|
659
|
+
severity: "secondary",
|
|
660
|
+
text: "",
|
|
661
|
+
type: "button"
|
|
662
|
+
}, null, 8, ["label"]),
|
|
663
|
+
createVNode(_sfc_main$4, {
|
|
664
|
+
label: unref(locale).changeImageLabel,
|
|
665
|
+
onClick: changeImage,
|
|
666
|
+
"data-wv-section": "change-image-button",
|
|
667
|
+
text: "",
|
|
668
|
+
type: "button"
|
|
669
|
+
}, null, 8, ["label"]),
|
|
670
|
+
createVNode(_sfc_main$4, {
|
|
671
|
+
label: unref(locale).applyCropLabel,
|
|
672
|
+
onClick: applyImageCropper,
|
|
673
|
+
"data-wv-section": "apply-image-button",
|
|
674
|
+
severity: "success",
|
|
675
|
+
type: "button"
|
|
676
|
+
}, null, 8, ["label"])
|
|
677
|
+
]),
|
|
678
|
+
default: withCtx(() => [
|
|
679
|
+
currentCropingImageIndex.value != null ? (openBlock(), createBlock(unref(fe), {
|
|
680
|
+
key: 0,
|
|
681
|
+
ref_key: "vueAdvanceCropper",
|
|
682
|
+
ref: vueAdvanceCropper,
|
|
683
|
+
"auto-zoom": false,
|
|
684
|
+
"background-wrapper-component": BackgroundImageCropper,
|
|
685
|
+
src: image.value[currentCropingImageIndex.value].src,
|
|
686
|
+
class: "upload-example-cropper h-400",
|
|
687
|
+
"foreground-class": "h-400",
|
|
688
|
+
"image-class": "h-400"
|
|
689
|
+
}, null, 8, ["src"])) : createCommentVNode("", true)
|
|
690
|
+
]),
|
|
691
|
+
_: 1
|
|
692
|
+
}, 8, ["visible", "header"])
|
|
693
|
+
], 64);
|
|
694
|
+
};
|
|
528
695
|
}
|
|
529
696
|
});
|
|
530
697
|
export {
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
698
|
+
_sfc_main as _,
|
|
699
|
+
commonjsGlobal as c,
|
|
700
|
+
getDefaultExportFromCjs as g
|
|
534
701
|
};
|