UNPKG

vxe-pc-ui

Version:
1 lines • 8.2 kB
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _vue=require("vue"),_comp=require("../../ui/src/comp"),_xeUtils=_interopRequireDefault(require("xe-utils")),_ui=require("../../ui"),_dom=require("../../ui/src/dom"),_utils=require("../../ui/src/utils"),_vn=require("../../ui/src/vn");function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}var _default=exports.default=(0,_comp.defineVxeComponent)({name:"VxeIconPicker",props:{modelValue:String,placeholder:String,clearable:Boolean,size:{type:String,default:()=>(0,_ui.getConfig)().iconPicker.size||(0,_ui.getConfig)().size},className:[String,Function],popupClassName:[String,Function],showIconTitle:{type:Boolean,default:()=>(0,_ui.getConfig)().iconPicker.showIconTitle},readonly:{type:Boolean,default:null},disabled:{type:Boolean,default:null},icons:Array,placement:String,popupConfig:Object,transfer:{type:Boolean,default:null}},emits:["update:modelValue","change","clear","click"],setup(d,e){const n=e["emit"],l=(0,_vue.inject)("$xeModal",null),t=(0,_vue.inject)("$xeDrawer",null),a=(0,_vue.inject)("$xeTable",null),u=(0,_vue.inject)("$xeForm",null),r=(0,_vue.inject)("xeFormItemInfo",null);var i=_xeUtils.default.uniqueId();const p=(0,_ui.useSize)(d)["computeSize"],f=(0,_vue.reactive)({initialized:!1,selectIcon:""+(d.modelValue||""),panelIndex:0,panelStyle:{},panelPlacement:null,visiblePanel:!1,isAniVisible:!1,isActivated:!1}),o={},g=(0,_vue.ref)(),m=(0,_vue.ref)(),x=(0,_vue.ref)(),c={refElem:g},E={xID:i,props:d,context:e,reactData:f,getRefMaps:()=>c};const b=(0,_vue.computed)(()=>{var e=d["readonly"];return null===e?!!u&&u.props.readonly:e}),h=(0,_vue.computed)(()=>{var e=d["disabled"];return null===e?!!u&&u.props.disabled:e}),k=(0,_vue.computed)(()=>{var e=d["transfer"],i=I.value;if(_xeUtils.default.isBoolean(i.transfer))return i.transfer;if(null===e){i=(0,_ui.getConfig)().iconPicker.transfer;if(_xeUtils.default.isBoolean(i))return i;if(a||l||t||u)return!0}return e}),P=(0,_vue.computed)(()=>{var e=d["placeholder"];return(e=e||(0,_ui.getConfig)().select.placeholder)?(0,_utils.getFuncText)(e):(0,_ui.getI18n)("vxe.base.pleaseSelect")}),s=(0,_vue.computed)(()=>{let e=d["icons"];return(e=e&&e.length?e:(0,_ui.getConfig)().iconPicker.icons||[]).map(e=>_xeUtils.default.isString(e)?{title:e,icon:"vxe-icon-"+(""+(e||"")).replace(/^vxe-icon-/,"")}:{title:""+(e.title||""),icon:e.icon||"",iconRender:e.iconRender})}),I=(0,_vue.computed)(()=>Object.assign({},(0,_ui.getConfig)().iconPicker.popupConfig,d.popupConfig)),T=(0,_vue.computed)(()=>{var e=s.value;return _xeUtils.default.chunk(e,4)}),A=(0,_vue.computed)(()=>{const i=f["selectIcon"];var e=s.value;return i?e.find(e=>e.icon===i):null}),v=()=>{const l=d["placement"],n=f["panelIndex"],t=g.value,a=x.value,u=k.value,r=I.value;var e=()=>{var e=(0,_dom.updatePanelPlacement)(t,a,{placement:r.placement||l,teleportTo:u}),i=Object.assign(e.style,{zIndex:n});f.panelStyle=i,f.panelPlacement=e.placement};return e(),(0,_vue.nextTick)().then(e)},_=()=>{var e=o["hpTimeout"];h.value||(e&&(clearTimeout(e),o.hpTimeout=void 0),f.initialized||(f.initialized=!0),f.isActivated=!0,f.isAniVisible=!0,setTimeout(()=>{f.visiblePanel=!0,v()},10),f.panelIndex<(0,_utils.getLastZIndex)()&&(f.panelIndex=(0,_utils.nextZIndex)()),v())},y=()=>{f.visiblePanel=!1,o.hpTimeout=setTimeout(()=>{f.isAniVisible=!1},350)},C=(e,i)=>{(f.selectIcon=i)!==d.modelValue&&(n("update:modelValue",i),K("change",{value:i},e),u)&&r&&u.triggerItemEvent(e,r.itemConfig.field,i)},N=()=>{h.value||f.visiblePanel||_()},S=()=>{f.isActivated=!1},V=(e,i)=>{C(e,i),K("clear",{value:i},e)},O=(e,i)=>{V(i,null),y()},L=e=>{e.preventDefault(),(f.visiblePanel?y:_)()},B=e=>{L(e),K("click",{},e)},R=e=>{var i=f["visiblePanel"];h.value||i&&(i=x.value,((0,_dom.getEventTargetNode)(e,i).flag?v:y)())},w=e=>{var i,l,n=f["visiblePanel"];h.value||(i=g.value,l=x.value,f.isActivated=(0,_dom.getEventTargetNode)(e,i).flag||(0,_dom.getEventTargetNode)(e,l).flag,n&&!f.isActivated&&y())},z=e=>{var i,l,n,t,a,u,r,o=d["clearable"],c=f["visiblePanel"];h.value||(i=_ui.globalEvents.hasKey(e,_ui.GLOBAL_EVENT_KEYS.TAB),l=_ui.globalEvents.hasKey(e,_ui.GLOBAL_EVENT_KEYS.ENTER),n=_ui.globalEvents.hasKey(e,_ui.GLOBAL_EVENT_KEYS.ESCAPE),t=_ui.globalEvents.hasKey(e,_ui.GLOBAL_EVENT_KEYS.ARROW_UP),a=_ui.globalEvents.hasKey(e,_ui.GLOBAL_EVENT_KEYS.ARROW_DOWN),u=_ui.globalEvents.hasKey(e,_ui.GLOBAL_EVENT_KEYS.DELETE),r=_ui.globalEvents.hasKey(e,_ui.GLOBAL_EVENT_KEYS.SPACEBAR),i&&(f.isActivated=!1),c?n||i?y():l?(e.preventDefault(),e.stopPropagation()):(t||a||r)&&e.preventDefault():(t||a||l||r)&&f.isActivated&&(e.preventDefault(),_()),f.isActivated&&u&&o&&V(e,null))},D=()=>{var{visiblePanel:e,isActivated:i}=f;e&&y(),i&&(f.isActivated=!1),(e||i)&&(e=m.value)&&e.blur()},K=(e,i,l)=>{n(e,(0,_ui.createEvent)(l,{$iconPicker:E},i))},U=(i={dispatchEvent:K,isPanelVisible(){return f.visiblePanel},togglePanel(){return(f.visiblePanel?y:_)(),(0,_vue.nextTick)()},hidePanel(){return f.visiblePanel&&y(),(0,_vue.nextTick)()},showPanel(){return f.visiblePanel||_(),(0,_vue.nextTick)()},focus(){var e=m.value;return f.isActivated=!0,e&&e.blur(),(0,_vue.nextTick)()},blur(){var e=m.value;return e&&e.blur(),(f.isActivated=!1,_vue.nextTick)()}},(e,i)=>{i=i.icon;C(e,i),y()});Object.assign(E,i);return(0,_vue.watch)(()=>d.modelValue,e=>{f.selectIcon=""+(e||"")}),(0,_vue.onMounted)(()=>{_ui.globalEvents.on(E,"mousewheel",R),_ui.globalEvents.on(E,"mousedown",w),_ui.globalEvents.on(E,"keydown",z),_ui.globalEvents.on(E,"blur",D)}),(0,_vue.onUnmounted)(()=>{_ui.globalEvents.off(E,"mousewheel"),_ui.globalEvents.off(E,"mousedown"),_ui.globalEvents.off(E,"keydown"),_ui.globalEvents.off(E,"blur")}),(0,_vue.provide)("$xeIconPicker",E),E.renderVN=()=>{var{className:e,clearable:i}=d,{initialized:l,isActivated:n,isAniVisible:t,visiblePanel:a,selectIcon:u}=f,r=p.value,o=h.value,c=k.value,s=b.value,v=P.value,_=I.value.className||d.popupClassName;return s?(0,_vue.h)("div",{ref:g,class:["vxe-ico-picker--readonly",e]},[(0,_vue.h)("i",{class:u})]):(0,_vue.h)("div",{ref:g,class:["vxe-ico-picker",e?_xeUtils.default.isFunction(e)?e({$iconPicker:E}):e:"",{["size--"+r]:r,"show--clear":i&&!o&&!!u,"is--visible":a,"is--disabled":o,"is--active":n}]},[(0,_vue.h)("div",{class:"vxe-ico-picker--inner",onClick:B},[(0,_vue.h)("input",{ref:m,class:"vxe-ico-picker--input",onFocus:N,onBlur:S}),u?(()=>{var e=f["selectIcon"],i=A.value;if(i){var l=i["iconRender"],n=l?_ui.renderer.get(l.name):null,n=n?n.renderIconPickerOptionIcon:null;if(n&&l)return(0,_vue.h)("div",{key:"inc",class:"vxe-ico-picker--icon"},(0,_vn.getSlotVNs)(n(l,{$iconPicker:E,option:i})))}return(0,_vue.h)("div",{key:"ind",class:"vxe-ico-picker--icon"},[(0,_vue.h)("i",{class:e})])})():(0,_vue.h)("div",{class:"vxe-ico-picker--placeholder"},v),(0,_vue.h)("div",{class:"vxe-ico-picker--suffix"},[(0,_vue.h)("div",{class:"vxe-ico-picker--clear-icon",onClick:O},[(0,_vue.h)("i",{class:(0,_ui.getIcon)().INPUT_CLEAR})]),(0,_vue.h)("div",{class:"vxe-ico-picker--suffix-icon"},[(0,_vue.h)("i",{class:a?(0,_ui.getIcon)().ICON_PICKER_OPEN:(0,_ui.getIcon)().ICON_PICKER_CLOSE})])])]),(0,_vue.h)(_vue.Teleport,{to:"body",disabled:!c||!l},[(0,_vue.h)("div",{ref:x,class:["vxe-table--ignore-clear vxe-ico-picker--panel",_?_xeUtils.default.isFunction(_)?_({$iconPicker:E}):_:"",{["size--"+r]:r,"is--transfer":c,"ani--leave":t,"ani--enter":a}],placement:f.panelPlacement,style:f.panelStyle},[l&&(a||t)?(0,_vue.h)("div",{class:"vxe-ico-picker--panel-wrapper"},[(()=>{const n=d["showIconTitle"];var e=T.value;const t=h.value;return(0,_vue.h)("div",{class:"vxe-ico-picker--list-wrapper"},e.map(e=>(0,_vue.h)("div",{class:"vxe-ico-picker--list"},e.map(i=>{var e=i["iconRender"],l=e?_ui.renderer.get(e.name):null,l=l?l.renderIconPickerOptionIcon:null;return(0,_vue.h)("div",{class:"vxe-ico-picker--item",onClick(e){t||U(e,i)}},[(0,_vue.h)("div",{class:"vxe-ico-picker--item-icon"},l&&e?(0,_vn.getSlotVNs)(l(e,{$iconPicker:E,option:i})):[(0,_vue.h)("i",{class:i.icon||""})]),n?(0,_vue.h)("div",{class:"vxe-ico-picker--item-title"},""+(i.title||"")):(0,_ui.renderEmptyElement)(E)])}))))})()]):(0,_ui.renderEmptyElement)(E)])])])},E},render(){return this.renderVN()}});