ant-design-vue/components/vc-menu/util.js
2019-01-08 23:03:13 +08:00

142 lines
3.1 KiB
JavaScript

const isMobile = require('ismobilejs')
export function noop () {
}
export function getKeyFromChildrenIndex (child, menuEventKey, index) {
const prefix = menuEventKey || ''
return child.key === undefined ? `${prefix}item_${index}` : child.key
}
export function getMenuIdFromSubMenuEventKey (eventKey) {
return `${eventKey}-menu-`
}
export function loopMenuItem (children, cb) {
let index = -1
children.forEach((c) => {
index++
if (c && c.type && c.type.isMenuItemGroup) {
c.$slots.default.forEach((c2) => {
index++
c.componentOptions && cb(c2, index)
})
} else {
c.componentOptions && cb(c, index)
}
})
}
export function loopMenuItemRecursively (children, keys, ret) {
if (!children || ret.find) {
return
}
children.forEach((c) => {
if (ret.find) {
return
}
if (c.data && c.data.slot && c.data.slot !== 'default') {
return
}
if (c && c.componentOptions) {
const options = c.componentOptions.Ctor.options
if (!options || !(options.isSubMenu || options.isMenuItem || options.isMenuItemGroup)) {
return
}
if (keys.indexOf(c.key) !== -1) {
ret.find = true
} else if (c.componentOptions.children) {
loopMenuItemRecursively(c.componentOptions.children, keys, ret)
}
}
})
}
export const menuAllProps = {
props: [
'defaultSelectedKeys',
'selectedKeys',
'defaultOpenKeys',
'openKeys',
'mode',
'getPopupContainer',
'openTransitionName',
'openAnimation',
'subMenuOpenDelay',
'subMenuCloseDelay',
'forceSubMenuRender',
'triggerSubMenuAction',
'level',
'selectable',
'multiple',
'visible',
'focusable',
'defaultActiveFirst',
'prefixCls',
'inlineIndent',
'parentMenu',
'title',
'rootPrefixCls',
'eventKey',
'active',
'popupAlign',
'popupOffset',
'isOpen',
'renderMenuItem',
'manualRef',
'subMenuKey',
'disabled',
'index',
'isSelected',
'store',
'activeKey',
'builtinPlacements',
'overflowedIndicator',
// the following keys found need to be removed from test regression
'attribute',
'value',
'popupClassName',
'inlineCollapsed',
'menu',
'theme',
'itemIcon',
'expandIcon',
],
on: [
'select',
'deselect',
'destroy',
'openChange',
'itemHover',
'titleMouseenter',
'titleMouseleave',
'titleClick',
],
}
// ref: https://github.com/ant-design/ant-design/issues/14007
// ref: https://bugs.chromium.org/p/chromium/issues/detail?id=360889
// getBoundingClientRect return the full precision value, which is
// not the same behavior as on chrome. Set the precision to 6 to
// unify their behavior
export const getWidth = (elem) => {
let width = elem &&
typeof elem.getBoundingClientRect === 'function' &&
elem.getBoundingClientRect().width
if (width) {
width = +width.toFixed(6)
}
return width || 0
}
export const setStyle = (elem, styleProperty, value) => {
if (elem && typeof elem.style === 'object') {
elem.style[styleProperty] = value
}
}
export const isMobileDevice = () => {
return isMobile.any
}