export const EMPTY_OBJ: { readonly [key: string]: any } = Object.freeze({}) export const NOOP = () => {} export const reservedPropRE = /^(?:key|ref|slots)$|^vnode/ export const isOn = (key: string) => key[0] === 'o' && key[1] === 'n' export const isArray = Array.isArray export const isFunction = (val: any): val is Function => typeof val === 'function' export const isString = (val: any): val is string => typeof val === 'string' export const isObject = (val: any): val is Record => val !== null && typeof val === 'object' const camelizeRE = /-(\w)/g export const camelize = (str: string): string => { return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : '')) } const hyphenateRE = /\B([A-Z])/g export const hyphenate = (str: string): string => { return str.replace(hyphenateRE, '-$1').toLowerCase() } export const capitalize = (str: string): string => { return str.charAt(0).toUpperCase() + str.slice(1) }