import { makeMap } from './makeMap' export { makeMap } export * from './patchFlags' export * from './shapeFlags' export * from './slotFlags' export * from './globalsWhitelist' export * from './codeframe' export * from './mockWarn' export * from './normalizeProp' export * from './domTagConfig' export * from './domAttrConfig' export * from './escapeHtml' export * from './looseEqual' export * from './toDisplayString' /** * List of @babel/parser plugins that are used for template expression * transforms and SFC script transforms. By default we enable proposals slated * for ES2020. This will need to be updated as the spec moves forward. * Full list at https://babeljs.io/docs/en/next/babel-parser#plugins */ export const babelParserDefautPlugins = [ 'bigInt', 'optionalChaining', 'nullishCoalescingOperator' ] as const export const EMPTY_OBJ: { readonly [key: string]: any } = __DEV__ ? Object.freeze({}) : {} export const EMPTY_ARR: [] = [] export const NOOP = () => {} /** * Always return false. */ export const NO = () => false const onRE = /^on[^a-z]/ export const isOn = (key: string) => onRE.test(key) export const extend = Object.assign export const remove = (arr: T[], el: T) => { const i = arr.indexOf(el) if (i > -1) { arr.splice(i, 1) } } const hasOwnProperty = Object.prototype.hasOwnProperty export const hasOwn = ( val: object, key: string | symbol ): key is keyof typeof val => hasOwnProperty.call(val, key) export const isArray = Array.isArray export const isDate = (val: unknown): val is Date => val instanceof Date export const isFunction = (val: unknown): val is Function => typeof val === 'function' export const isString = (val: unknown): val is string => typeof val === 'string' export const isSymbol = (val: unknown): val is symbol => typeof val === 'symbol' export const isObject = (val: unknown): val is Record => val !== null && typeof val === 'object' export const isPromise = (val: unknown): val is Promise => { return isObject(val) && isFunction(val.then) && isFunction(val.catch) } export const objectToString = Object.prototype.toString export const toTypeString = (value: unknown): string => objectToString.call(value) export const toRawType = (value: unknown): string => { return toTypeString(value).slice(8, -1) } export const isPlainObject = (val: unknown): val is object => toTypeString(val) === '[object Object]' export const isReservedProp = /*#__PURE__*/ makeMap( 'key,ref,' + 'onVnodeBeforeMount,onVnodeMounted,' + 'onVnodeBeforeUpdate,onVnodeUpdated,' + 'onVnodeBeforeUnmount,onVnodeUnmounted' ) const cacheStringFunction = string>(fn: T): T => { const cache: Record = Object.create(null) return ((str: string) => { const hit = cache[str] return hit || (cache[str] = fn(str)) }) as any } const camelizeRE = /-(\w)/g /** * @private */ export const camelize = cacheStringFunction( (str: string): string => { return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : '')) } ) const hyphenateRE = /\B([A-Z])/g /** * @private */ export const hyphenate = cacheStringFunction( (str: string): string => { return str.replace(hyphenateRE, '-$1').toLowerCase() } ) /** * @private */ export const capitalize = cacheStringFunction( (str: string): string => { return str.charAt(0).toUpperCase() + str.slice(1) } ) // compare whether a value has changed, accounting for NaN. export const hasChanged = (value: any, oldValue: any): boolean => value !== oldValue && (value === value || oldValue === oldValue) export const invokeArrayFns = (fns: Function[], arg?: any) => { for (let i = 0; i < fns.length; i++) { fns[i](arg) } } export const def = (obj: object, key: string | symbol, value: any) => { Object.defineProperty(obj, key, { configurable: true, enumerable: false, value }) } export const toNumber = (val: any): any => { const n = parseFloat(val) return isNaN(n) ? val : n } let _globalThis: any export const getGlobalThis = (): any => { return ( _globalThis || (_globalThis = typeof globalThis !== 'undefined' ? globalThis : typeof self !== 'undefined' ? self : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : {}) ) }