Cherelle Spencer
2023-04-04 02d41197b6555b20f3b084abacb9e32affbcbcc1
src/utils/propTypes.ts
@@ -1,5 +1,5 @@
import { CSSProperties, VNodeChild } from 'vue';
import { createTypes, VueTypeValidableDef, VueTypesInterface } from 'vue-types';
import { createTypes, VueTypeValidableDef, VueTypesInterface, toValidableType } from 'vue-types';
export type VueNode = VNodeChild | JSX.Element;
@@ -8,8 +8,7 @@
  readonly VNodeChild: VueTypeValidableDef<VueNode>;
  // readonly trueBool: VueTypeValidableDef<boolean>;
};
const propTypes = createTypes({
const newPropTypes = createTypes({
  func: undefined,
  bool: undefined,
  string: undefined,
@@ -18,17 +17,19 @@
  integer: undefined,
}) as PropTypes;
propTypes.extend([
  {
    name: 'style',
    getter: true,
// 从 vue-types v5.0 开始,extend()方法已经废弃,当前已改为官方推荐的ES6+方法 https://dwightjack.github.io/vue-types/advanced/extending-vue-types.html#the-extend-method
class propTypes extends newPropTypes {
  // a native-like validator that supports the `.validable` method
  static get style() {
    return toValidableType('style', {
    type: [String, Object],
    default: undefined,
  },
  {
    name: 'VNodeChild',
    getter: true,
    });
  }
  static get VNodeChild() {
    return toValidableType('VNodeChild', {
    type: undefined,
  },
]);
    });
  }
}
export { propTypes };