From 34855500f019127ff506cde986318c3553b894f2 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Wed, 1 Jun 2022 08:35:47 -0600 Subject: [PATCH 01/12] chore(typescript): converted victory-theme --- .../src/victory-theme/{grayscale.js => grayscale.tsx} | 3 ++- .../src/victory-theme/{material.js => material.tsx} | 3 ++- ...victory-theme.d.ts => victory-theme-definition.ts} | 11 +---------- .../victory-core/src/victory-theme/victory-theme.js | 7 ------- .../victory-core/src/victory-theme/victory-theme.tsx | 3 +++ 5 files changed, 8 insertions(+), 19 deletions(-) rename packages/victory-core/src/victory-theme/{grayscale.js => grayscale.tsx} (97%) rename packages/victory-core/src/victory-theme/{material.js => material.tsx} (97%) rename packages/victory-core/src/victory-theme/{victory-theme.d.ts => victory-theme-definition.ts} (97%) delete mode 100644 packages/victory-core/src/victory-theme/victory-theme.js create mode 100644 packages/victory-core/src/victory-theme/victory-theme.tsx diff --git a/packages/victory-core/src/victory-theme/grayscale.js b/packages/victory-core/src/victory-theme/grayscale.tsx similarity index 97% rename from packages/victory-core/src/victory-theme/grayscale.js rename to packages/victory-core/src/victory-theme/grayscale.tsx index 4faf212a5..e494cf24b 100644 --- a/packages/victory-core/src/victory-theme/grayscale.js +++ b/packages/victory-core/src/victory-theme/grayscale.tsx @@ -1,4 +1,5 @@ import { assign } from "lodash"; +import { VictoryThemeDefinition } from "./victory-theme-definition"; // * // * Colors @@ -49,7 +50,7 @@ const centeredLabelStyles = assign({ textAnchor: "middle" }, baseLabelStyles); const strokeLinecap = "round"; const strokeLinejoin = "round"; -export default { +export const grayscale: VictoryThemeDefinition = { area: assign( { style: { diff --git a/packages/victory-core/src/victory-theme/material.js b/packages/victory-core/src/victory-theme/material.tsx similarity index 97% rename from packages/victory-core/src/victory-theme/material.js rename to packages/victory-core/src/victory-theme/material.tsx index 947287bc3..4de8062d3 100644 --- a/packages/victory-core/src/victory-theme/material.js +++ b/packages/victory-core/src/victory-theme/material.tsx @@ -1,4 +1,5 @@ import { assign } from "lodash"; +import { VictoryThemeDefinition } from "./victory-theme-definition"; // * // * Colors @@ -57,7 +58,7 @@ const strokeDasharray = "10, 5"; const strokeLinecap = "round"; const strokeLinejoin = "round"; -export default { +export const material: VictoryThemeDefinition = { area: assign( { style: { diff --git a/packages/victory-core/src/victory-theme/victory-theme.d.ts b/packages/victory-core/src/victory-theme/victory-theme-definition.ts similarity index 97% rename from packages/victory-core/src/victory-theme/victory-theme.d.ts rename to packages/victory-core/src/victory-theme/victory-theme-definition.ts index 061467da3..374130c41 100644 --- a/packages/victory-core/src/victory-theme/victory-theme.d.ts +++ b/packages/victory-core/src/victory-theme/victory-theme-definition.ts @@ -1,10 +1,9 @@ import * as React from "react"; import { - CallbackArgs, - StringOrNumberOrCallback, VictoryCommonThemeProps, VictoryDatableProps } from "../index"; +import { CallbackArgs, StringOrNumberOrCallback } from "../types"; export type BlockProps = { top?: number; @@ -263,11 +262,3 @@ export interface VictoryThemeDefinition { } & VictoryCommonThemeProps & VictoryDatableProps; } - -export interface VictoryThemeInterface { - grayscale: VictoryThemeDefinition; - material: VictoryThemeDefinition; -} - -const VictoryTheme: VictoryThemeInterface; -export default VictoryTheme; diff --git a/packages/victory-core/src/victory-theme/victory-theme.js b/packages/victory-core/src/victory-theme/victory-theme.js deleted file mode 100644 index 0193e6d55..000000000 --- a/packages/victory-core/src/victory-theme/victory-theme.js +++ /dev/null @@ -1,7 +0,0 @@ -import materialTheme from "./material"; -import grayscaleTheme from "./grayscale"; - -export default { - material: materialTheme, - grayscale: grayscaleTheme -}; diff --git a/packages/victory-core/src/victory-theme/victory-theme.tsx b/packages/victory-core/src/victory-theme/victory-theme.tsx new file mode 100644 index 000000000..0c5f7bab1 --- /dev/null +++ b/packages/victory-core/src/victory-theme/victory-theme.tsx @@ -0,0 +1,3 @@ +export * from "./material"; +export * from "./grayscale"; +export * from './victory-theme-definition'; From a2e7e3429c750b1a0b31d47eaa2f2dcbb338cba9 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Wed, 1 Jun 2022 11:39:52 -0600 Subject: [PATCH 02/12] chore(typescript): converted victory-transition and victory-animation --- .eslintrc.js | 2 + .../victory-animation/{util.js => util.ts} | 4 +- .../victory-animation/victory-animation.d.ts | 66 ------------- ...ory-animation.js => victory-animation.tsx} | 97 ++++++++++++++++--- ...y-transition.js => victory-transition.tsx} | 85 ++++++++++++---- .../{timer-context.js => timer-context.ts} | 0 .../src/victory-util/{timer.js => timer.ts} | 23 ++++- 7 files changed, 173 insertions(+), 104 deletions(-) rename packages/victory-core/src/victory-animation/{util.js => util.ts} (98%) delete mode 100644 packages/victory-core/src/victory-animation/victory-animation.d.ts rename packages/victory-core/src/victory-animation/{victory-animation.js => victory-animation.tsx} (75%) rename packages/victory-core/src/victory-transition/{victory-transition.js => victory-transition.tsx} (72%) rename packages/victory-core/src/victory-util/{timer-context.js => timer-context.ts} (100%) rename packages/victory-core/src/victory-util/{timer.js => timer.ts} (72%) diff --git a/.eslintrc.js b/.eslintrc.js index 0a44b62c4..9aaa90951 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -59,6 +59,8 @@ module.exports = { typedefs: false } ], + "no-invalid-this": "off", + "@typescript-eslint/no-invalid-this": ["error"], "@typescript-eslint/no-unsafe-argument": "warn", "@typescript-eslint/no-unsafe-assignment": "warn", diff --git a/packages/victory-core/src/victory-animation/util.js b/packages/victory-core/src/victory-animation/util.ts similarity index 98% rename from packages/victory-core/src/victory-animation/util.js rename to packages/victory-core/src/victory-animation/util.ts index ff67e3626..355e234ab 100644 --- a/packages/victory-core/src/victory-animation/util.js +++ b/packages/victory-core/src/victory-animation/util.ts @@ -82,8 +82,8 @@ export const interpolateFunction = function (a, b) { if (t >= 1) { return b; } - return function () { - /* eslint-disable no-invalid-this */ + return function (this: unknown) { + /* eslint-disable no-invalid-this, prefer-rest-params */ const aval = typeof a === "function" ? a.apply(this, arguments) : a; const bval = typeof b === "function" ? b.apply(this, arguments) : b; return interpolate(aval, bval)(t); diff --git a/packages/victory-core/src/victory-animation/victory-animation.d.ts b/packages/victory-core/src/victory-animation/victory-animation.d.ts deleted file mode 100644 index 844d166df..000000000 --- a/packages/victory-core/src/victory-animation/victory-animation.d.ts +++ /dev/null @@ -1,66 +0,0 @@ -import * as React from "react"; - -/** - * Single animation object to interpolate - */ -export type AnimationStyle = { [key: string]: string | number }; -/** - * Animation styles to interpolate - */ - -export type AnimationData = AnimationStyle | AnimationStyle[]; -export type AnimationEasing = - | "back" - | "backIn" - | "backOut" - | "backInOut" - | "bounce" - | "bounceIn" - | "bounceOut" - | "bounceInOut" - | "circle" - | "circleIn" - | "circleOut" - | "circleInOut" - | "linear" - | "linearIn" - | "linearOut" - | "linearInOut" - | "cubic" - | "cubicIn" - | "cubicOut" - | "cubicInOut" - | "elastic" - | "elasticIn" - | "elasticOut" - | "elasticInOut" - | "exp" - | "expIn" - | "expOut" - | "expInOut" - | "poly" - | "polyIn" - | "polyOut" - | "polyInOut" - | "quad" - | "quadIn" - | "quadOut" - | "quadInOut" - | "sin" - | "sinIn" - | "sinOut" - | "sinInOut"; - -export interface VictoryAnimationProps { - children?: (style: AnimationStyle) => React.ReactElement; - duration?: number; - easing?: AnimationEasing; - delay?: number; - onEnd?: () => void; - data?: AnimationData; -} - -export default class VictoryAnimation extends React.Component< - VictoryAnimationProps, - any -> {} diff --git a/packages/victory-core/src/victory-animation/victory-animation.js b/packages/victory-core/src/victory-animation/victory-animation.tsx similarity index 75% rename from packages/victory-core/src/victory-animation/victory-animation.js rename to packages/victory-core/src/victory-animation/victory-animation.tsx index 571b0f643..882b4a895 100644 --- a/packages/victory-core/src/victory-animation/victory-animation.js +++ b/packages/victory-core/src/victory-animation/victory-animation.tsx @@ -5,8 +5,81 @@ import * as d3Ease from "victory-vendor/d3-ease"; import { victoryInterpolator } from "./util"; import TimerContext from "../victory-util/timer-context"; import isEqual from "react-fast-compare"; +import type Timer from "../victory-util/timer"; -export default class VictoryAnimation extends React.Component { +/** + * Single animation object to interpolate + */ +export type AnimationStyle = { [key: string]: string | number }; +/** + * Animation styles to interpolate + */ + +export type AnimationData = AnimationStyle | AnimationStyle[]; +export type AnimationEasing = + | "back" + | "backIn" + | "backOut" + | "backInOut" + | "bounce" + | "bounceIn" + | "bounceOut" + | "bounceInOut" + | "circle" + | "circleIn" + | "circleOut" + | "circleInOut" + | "linear" + | "linearIn" + | "linearOut" + | "linearInOut" + | "cubic" + | "cubicIn" + | "cubicOut" + | "cubicInOut" + | "elastic" + | "elasticIn" + | "elasticOut" + | "elasticInOut" + | "exp" + | "expIn" + | "expOut" + | "expInOut" + | "poly" + | "polyIn" + | "polyOut" + | "polyInOut" + | "quad" + | "quadIn" + | "quadOut" + | "quadInOut" + | "sin" + | "sinIn" + | "sinOut" + | "sinInOut"; + +export interface VictoryAnimationProps { + children: (style: AnimationStyle, info: AnimationInfo) => React.ReactNode; + duration?: number; + easing?: AnimationEasing; + delay?: number; + onEnd?: () => void; + data: AnimationData; +} +export interface VictoryAnimationState { + data: AnimationStyle; + animationInfo: AnimationInfo; +} +export interface AnimationInfo { + progress: number; + animating: boolean; + terminating?: boolean; +} + +export default class VictoryAnimation extends React.Component< + VictoryAnimationProps, + VictoryAnimationState +> { static displayName = "VictoryAnimation"; static propTypes = { @@ -67,6 +140,11 @@ export default class VictoryAnimation extends React.Component { }; static contextType = TimerContext; + private interpolator: null | ((value: number) => AnimationStyle); + private queue: AnimationStyle[]; + private ease: any; + private timer: Timer; + private loopID?: number; constructor(props, context) { super(props, context); @@ -84,11 +162,6 @@ export default class VictoryAnimation extends React.Component { this.queue = Array.isArray(this.props.data) ? this.props.data.slice(1) : []; /* build easing function */ this.ease = d3Ease[this.toNewName(this.props.easing)]; - /* - There is no autobinding of this in ES6 classes - so we bind functionToBeRunEachFrame to current instance of victory animation class - */ - this.functionToBeRunEachFrame = this.functionToBeRunEachFrame.bind(this); this.timer = this.context.animationTimer; } @@ -163,13 +236,13 @@ export default class VictoryAnimation extends React.Component { setTimeout(() => { this.loopID = this.timer.subscribe( this.functionToBeRunEachFrame, - this.props.duration + this.props.duration! ); }, this.props.delay); } else { this.loopID = this.timer.subscribe( this.functionToBeRunEachFrame, - this.props.duration + this.props.duration! ); } } else if (this.props.onEnd) { @@ -177,7 +250,7 @@ export default class VictoryAnimation extends React.Component { } } /* every frame we... */ - functionToBeRunEachFrame(elapsed, duration) { + functionToBeRunEachFrame = (elapsed, duration) => { /* step can generate imprecise values, sometimes greater than 1 if this happens set the state to 1 and return, cancelling the timer @@ -186,7 +259,7 @@ export default class VictoryAnimation extends React.Component { const step = duration ? elapsed / duration : 1; if (step >= 1) { this.setState({ - data: this.interpolator(1), + data: this.interpolator!(1), animationInfo: { progress: 1, animating: false, @@ -206,13 +279,13 @@ export default class VictoryAnimation extends React.Component { interpolator, which is cached for performance whenever props are received */ this.setState({ - data: this.interpolator(this.ease(step)), + data: this.interpolator!(this.ease(step)), animationInfo: { progress: step, animating: step < 1 } }); - } + }; render() { return this.props.children(this.state.data, this.state.animationInfo); diff --git a/packages/victory-core/src/victory-transition/victory-transition.js b/packages/victory-core/src/victory-transition/victory-transition.tsx similarity index 72% rename from packages/victory-core/src/victory-transition/victory-transition.js rename to packages/victory-core/src/victory-transition/victory-transition.tsx index 5a67cc152..4d267fb00 100644 --- a/packages/victory-core/src/victory-transition/victory-transition.js +++ b/packages/victory-core/src/victory-transition/victory-transition.tsx @@ -1,14 +1,48 @@ -import React from "react"; +import React, { Component } from "react"; import PropTypes from "prop-types"; import VictoryAnimation from "../victory-animation/victory-animation"; import * as Collection from "../victory-util/collection"; import * as Helpers from "../victory-util/helpers"; import TimerContext from "../victory-util/timer-context"; import * as Transitions from "../victory-util/transitions"; -import { defaults, isFunction, pick, isObject } from "lodash"; +import { defaults, isFunction, isObject, pick } from "lodash"; import isEqual from "react-fast-compare"; +import Timer from "../victory-util/timer"; -export default class VictoryTransition extends React.Component { +type VictoryTransitionChild = React.ReactElement< + // Props: + { + polar?: boolean; + domain?: number[] | { x: number[]; y: number[] }; + groupComponent?: React.ReactElement; + }, + // Type: + { + new (props: any): Component; + continuous?: boolean; + } +>; +interface VictoryTransitionProps { + animate?: boolean | any; + animationWhitelist?: string[]; + children: VictoryTransitionChild; +} + +interface VictoryTransitionState { + oldProps?: VictoryTransitionProps; + nextProps?: VictoryTransitionProps; + nodesShouldLoad?: boolean; + nodesDoneLoad?: boolean; + nodesWillExit?: boolean; + nodesWillEnter?: boolean; + nodesShouldEnter?: boolean; + childrenTransitions?: unknown; +} + +export default class VictoryTransition extends React.Component< + VictoryTransitionProps, + VictoryTransitionState +> { static displayName = "VictoryTransition"; static propTypes = { @@ -18,6 +52,9 @@ export default class VictoryTransition extends React.Component { }; static contextType = TimerContext; + private continuous: boolean; + private timer: Timer; + private transitionProps: any; constructor(props, context) { super(props, context); @@ -28,7 +65,6 @@ export default class VictoryTransition extends React.Component { const child = this.props.children; const polar = child.props.polar; this.continuous = !polar && child.type && child.type.continuous === true; - this.getTransitionState = this.getTransitionState.bind(this); this.timer = this.context.transitionTimer; } @@ -36,7 +72,7 @@ export default class VictoryTransition extends React.Component { this.setState({ nodesShouldLoad: true }); //eslint-disable-line react/no-did-mount-set-state } - shouldComponentUpdate(nextProps) { + shouldComponentUpdate(nextProps: VictoryTransitionProps) { if (!isEqual(this.props, nextProps)) { this.timer.bypassAnimation(); this.setState(this.getTransitionState(this.props, nextProps), () => @@ -50,13 +86,16 @@ export default class VictoryTransition extends React.Component { this.timer.stop(); } - getTransitionState(props, nextProps) { + private getTransitionState( + props: VictoryTransitionProps, + nextProps: VictoryTransitionProps + ): VictoryTransitionState { const { animate } = props; if (!animate) { return {}; } else if (animate.parentState) { const state = animate.parentState; - const oldProps = state.nodesWillExit ? props : null; + const oldProps = state.nodesWillExit ? props : undefined; return { oldProps, nextProps }; } else { const oldChildren = React.Children.toArray(props.children); @@ -72,13 +111,16 @@ export default class VictoryTransition extends React.Component { nodesWillEnter, childrenTransitions, nodesShouldEnter, - oldProps: nodesWillExit ? props : null, + oldProps: nodesWillExit ? props : undefined, nextProps }; } } - getDomainFromChildren(props, axis) { + private getDomainFromChildren( + props: VictoryTransitionProps, + axis: "x" | "y" + ) { const getChildDomains = (children) => { return children.reduce((memo, child) => { if (child.type && isFunction(child.type.getDomain)) { @@ -94,8 +136,10 @@ export default class VictoryTransition extends React.Component { }, []); }; - const child = React.Children.toArray(props.children)[0]; - const childProps = child.props || {}; + const child = React.Children.toArray( + props.children + )[0] as VictoryTransitionChild; + const childProps: any = child.props || {}; const domain = Array.isArray(childProps.domain) ? childProps.domain : childProps.domain && childProps.domain[axis]; @@ -121,8 +165,8 @@ export default class VictoryTransition extends React.Component { : this.props; } - pickDomainProps(props) { - const parentState = isObject(props.animate) && props.animate.parentState; + private pickDomainProps(props: VictoryTransitionProps) { + const parentState = props.animate?.parentState; if (parentState && parentState.nodesWillExit) { return this.continous || parentState.continuous ? parentState.nextProps || this.state.nextProps || props @@ -146,13 +190,14 @@ export default class VictoryTransition extends React.Component { render() { const props = this.pickProps(); - const getTransitionProps = - isObject(this.props.animate) && this.props.animate.getTransitions - ? this.props.animate.getTransitions - : Transitions.getTransitionPropsFactory(props, this.state, (newState) => - this.setState(newState) - ); - const child = React.Children.toArray(props.children)[0]; + const getTransitionProps = this.props.animate?.getTransitions + ? this.props.animate.getTransitions + : Transitions.getTransitionPropsFactory(props, this.state, (newState) => + this.setState(newState) + ); + const child = React.Children.toArray( + props.children + )[0] as VictoryTransitionChild; const transitionProps = getTransitionProps(child); this.transitionProps = transitionProps; const domain = { diff --git a/packages/victory-core/src/victory-util/timer-context.js b/packages/victory-core/src/victory-util/timer-context.ts similarity index 100% rename from packages/victory-core/src/victory-util/timer-context.js rename to packages/victory-core/src/victory-util/timer-context.ts diff --git a/packages/victory-core/src/victory-util/timer.js b/packages/victory-core/src/victory-util/timer.ts similarity index 72% rename from packages/victory-core/src/victory-util/timer.js rename to packages/victory-core/src/victory-util/timer.ts index 812d07238..cd2968cdc 100644 --- a/packages/victory-core/src/victory-util/timer.js +++ b/packages/victory-core/src/victory-util/timer.ts @@ -1,10 +1,25 @@ import { timer, now } from "victory-vendor/d3-timer"; +interface D3Timer { + new (callback): void; + stop(): void; +} + +type Callback = (elapsed: number, duration: number) => void; + export default class Timer { + private shouldAnimate: boolean; + private readonly subscribers: Array<{ + callback: Callback; + startTime: number; + duration: number; + }>; + private activeSubscriptions: number; + private timer: D3Timer | null; + constructor() { this.shouldAnimate = true; this.subscribers = []; - this.loop = this.loop.bind(this); this.timer = null; this.activeSubscriptions = 0; } @@ -17,11 +32,11 @@ export default class Timer { this.shouldAnimate = true; } - loop() { + loop = () => { this.subscribers.forEach((s) => { s.callback(now() - s.startTime, s.duration); }); - } + }; start() { if (!this.timer) { @@ -36,7 +51,7 @@ export default class Timer { } } - subscribe(callback, duration) { + subscribe(callback: Callback, duration: number) { duration = this.shouldAnimate ? duration : 0; const subscriptionID = this.subscribers.push({ startTime: now(), From 1f555c75bc81394904e7741546d72725aee1e610 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Wed, 1 Jun 2022 12:02:22 -0600 Subject: [PATCH 03/12] chore(typescript): ensure `@types/react` are consistent --- package.json | 7 +++++-- yarn.lock | 22 ++-------------------- 2 files changed, 7 insertions(+), 22 deletions(-) diff --git a/package.json b/package.json index d25f35005..43b391138 100644 --- a/package.json +++ b/package.json @@ -69,7 +69,7 @@ "@testing-library/react": "^12.1.2", "@types/jest": "^27.5.1", "@types/lodash": "^4.14.149", - "@types/react": "^16.9.19", + "@types/react": "^16.14.26", "@types/react-dom": "^16.9.5", "@typescript-eslint/eslint-plugin": "^5.26.0", "@typescript-eslint/parser": "^5.26.0", @@ -125,7 +125,7 @@ "nps-utils": "^1.5.0", "prettier": "^2.6.2", "prop-types": "^15.8.1", - "react": "^16.13.1", + "react": "^16.14.0", "react-dom": "^16.13.1", "react-hot-loader": "v2.0.0-alpha-4", "rimraf": "^3.0.2", @@ -141,5 +141,8 @@ "webpack-dev-server": "^4.9.0", "webpack-stats-plugin": "^1.0.3" }, + "resolutions": { + "@types/react": "^16.14.26" + }, "sideEffects": false } diff --git a/yarn.lock b/yarn.lock index bc5fca91f..281a704c2 100644 --- a/yarn.lock +++ b/yarn.lock @@ -4401,16 +4401,7 @@ dependencies: "@types/react" "*" -"@types/react@*": - version "18.0.9" - resolved "https://registry.yarnpkg.com/@types/react/-/react-18.0.9.tgz#d6712a38bd6cd83469603e7359511126f122e878" - integrity sha512-9bjbg1hJHUm4De19L1cHiW0Jvx3geel6Qczhjd0qY5VKVE2X5+x77YxAepuCwVh4vrgZJdgEJw48zrhRIeF4Nw== - dependencies: - "@types/prop-types" "*" - "@types/scheduler" "*" - csstype "^3.0.2" - -"@types/react@^16", "@types/react@^16.9.19": +"@types/react@*", "@types/react@^16", "@types/react@^16.14.26", "@types/react@^17": version "16.14.26" resolved "https://registry.yarnpkg.com/@types/react/-/react-16.14.26.tgz#82540a240ba7207ebe87d9579051bc19c9ef7605" integrity sha512-c/5CYyciOO4XdFcNhZW1O2woVx86k4T+DO2RorHZL7EhitkNQgSD/SgpdZJAUJa/qjVgOmTM44gHkAdZSXeQuQ== @@ -4419,15 +4410,6 @@ "@types/scheduler" "*" csstype "^3.0.2" -"@types/react@^17": - version "17.0.45" - resolved "https://registry.yarnpkg.com/@types/react/-/react-17.0.45.tgz#9b3d5b661fd26365fefef0e766a1c6c30ccf7b3f" - integrity sha512-YfhQ22Lah2e3CHPsb93tRwIGNiSwkuz1/blk4e6QrWS0jQzCSNbGLtOEYhPg02W0yGTTmpajp7dCTbBAMN3qsg== - dependencies: - "@types/prop-types" "*" - "@types/scheduler" "*" - csstype "^3.0.2" - "@types/responselike@*", "@types/responselike@^1.0.0": version "1.0.0" resolved "https://registry.yarnpkg.com/@types/responselike/-/responselike-1.0.0.tgz#251f4fe7d154d2bad125abe1b429b23afd262e29" @@ -17036,7 +17018,7 @@ react-transform-hmr@^1.0.4: global "^4.3.0" react-proxy "^1.1.7" -react@^16.13.1, react@^16.8.3: +react@^16.14.0, react@^16.8.3: version "16.14.0" resolved "https://registry.yarnpkg.com/react/-/react-16.14.0.tgz#94d776ddd0aaa37da3eda8fc5b6b18a4c9a3114d" integrity sha512-0X2CImDkJGApiAlcf0ODKIneSwBPhqJawOa5wCtKbu7ZECrmS26NvtSILynQ66cgkT/RJ4LidJOc3bUESwmU8g== From f8c223a704c3e4ad374f4fc634902a86173d48bc Mon Sep 17 00:00:00 2001 From: scottrippey Date: Wed, 1 Jun 2022 12:02:57 -0600 Subject: [PATCH 04/12] chore(typescript): fixed typo in `continuous` --- .../victory-core/src/victory-transition/victory-transition.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/victory-core/src/victory-transition/victory-transition.tsx b/packages/victory-core/src/victory-transition/victory-transition.tsx index 4d267fb00..a06a4d155 100644 --- a/packages/victory-core/src/victory-transition/victory-transition.tsx +++ b/packages/victory-core/src/victory-transition/victory-transition.tsx @@ -168,7 +168,7 @@ export default class VictoryTransition extends React.Component< private pickDomainProps(props: VictoryTransitionProps) { const parentState = props.animate?.parentState; if (parentState && parentState.nodesWillExit) { - return this.continous || parentState.continuous + return this.continuous || parentState.continuous ? parentState.nextProps || this.state.nextProps || props : props; } From c4c16a8796be577a13ec808c839f14a3768d19c9 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Wed, 1 Jun 2022 12:07:44 -0600 Subject: [PATCH 05/12] chore(typescript): export * from victory-theme --- packages/victory-core/src/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/victory-core/src/index.ts b/packages/victory-core/src/index.ts index 50b8376dd..6e96dae8f 100644 --- a/packages/victory-core/src/index.ts +++ b/packages/victory-core/src/index.ts @@ -6,7 +6,7 @@ export { default as VictoryContainer } from "./victory-container/victory-contain export { default as VictoryLabel } from "./victory-label/victory-label"; export { default as VictoryTransition } from "./victory-transition/victory-transition"; export { default as VictoryClipContainer } from "./victory-clip-container/victory-clip-container"; -export { default as VictoryTheme } from "./victory-theme/victory-theme"; +export * from "./victory-theme/victory-theme"; export { default as VictoryPortal } from "./victory-portal/victory-portal"; export { default as Portal } from "./victory-portal/portal"; export { default as Arc } from "./victory-primitives/arc"; From 849e0f82191d006fe1d771b658e25e60ce58b880 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Wed, 1 Jun 2022 13:07:56 -0600 Subject: [PATCH 06/12] chore(typescript): improved imports --- .../src/victory-transition/victory-transition.tsx | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/victory-core/src/victory-transition/victory-transition.tsx b/packages/victory-core/src/victory-transition/victory-transition.tsx index a06a4d155..a6f032e7b 100644 --- a/packages/victory-core/src/victory-transition/victory-transition.tsx +++ b/packages/victory-core/src/victory-transition/victory-transition.tsx @@ -1,11 +1,11 @@ -import React, { Component } from "react"; +import React from "react"; import PropTypes from "prop-types"; import VictoryAnimation from "../victory-animation/victory-animation"; import * as Collection from "../victory-util/collection"; import * as Helpers from "../victory-util/helpers"; import TimerContext from "../victory-util/timer-context"; import * as Transitions from "../victory-util/transitions"; -import { defaults, isFunction, isObject, pick } from "lodash"; +import { defaults, isFunction, pick } from "lodash"; import isEqual from "react-fast-compare"; import Timer from "../victory-util/timer"; @@ -18,7 +18,7 @@ type VictoryTransitionChild = React.ReactElement< }, // Type: { - new (props: any): Component; + new (props: any): React.Component; continuous?: boolean; } >; From 1b3724d9def72cef3ff6c20ec207456ed84f2881 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Wed, 1 Jun 2022 13:10:49 -0600 Subject: [PATCH 07/12] chore(typescript): fixed type issus with label --- packages/victory-core/src/victory-label/victory-label.tsx | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/packages/victory-core/src/victory-label/victory-label.tsx b/packages/victory-core/src/victory-label/victory-label.tsx index f2d13c19c..735d7bb8c 100644 --- a/packages/victory-core/src/victory-label/victory-label.tsx +++ b/packages/victory-core/src/victory-label/victory-label.tsx @@ -591,7 +591,7 @@ const VictoryLabel: { const currentStyle = getSingleValue(style!, i); const capHeightPx = TextSize.convertLengthToPixels( `${capHeight}em`, - currentStyle.fontSize + currentStyle.fontSize as number ); const currentLineHeight = getSingleValue(lineHeight, i); return { @@ -599,6 +599,7 @@ const VictoryLabel: { fontSize: currentStyle.fontSize || defaultStyles.fontSize, capHeight: capHeightPx, text: line, + // @ts-expect-error TODO: This looks like a bug: textSize: TextSize.approximateTextSize(line, currentStyle), lineHeight: currentLineHeight, backgroundPadding: getSingleValue(backgroundPadding, i) From 8fe1f2eee97fbfd3153daf7bf221cc64eb2ccd68 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Wed, 1 Jun 2022 13:12:07 -0600 Subject: [PATCH 08/12] chore(typescript): allow 'oldProps' to be null --- .../src/victory-transition/victory-transition.tsx | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/victory-core/src/victory-transition/victory-transition.tsx b/packages/victory-core/src/victory-transition/victory-transition.tsx index a6f032e7b..03754186c 100644 --- a/packages/victory-core/src/victory-transition/victory-transition.tsx +++ b/packages/victory-core/src/victory-transition/victory-transition.tsx @@ -29,7 +29,7 @@ interface VictoryTransitionProps { } interface VictoryTransitionState { - oldProps?: VictoryTransitionProps; + oldProps?: VictoryTransitionProps | null; nextProps?: VictoryTransitionProps; nodesShouldLoad?: boolean; nodesDoneLoad?: boolean; @@ -95,7 +95,7 @@ export default class VictoryTransition extends React.Component< return {}; } else if (animate.parentState) { const state = animate.parentState; - const oldProps = state.nodesWillExit ? props : undefined; + const oldProps = state.nodesWillExit ? props : null; return { oldProps, nextProps }; } else { const oldChildren = React.Children.toArray(props.children); @@ -111,7 +111,7 @@ export default class VictoryTransition extends React.Component< nodesWillEnter, childrenTransitions, nodesShouldEnter, - oldProps: nodesWillExit ? props : undefined, + oldProps: nodesWillExit ? props : null, nextProps }; } From caa06854b7d9a573093a35cffa9491ba19c37980 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Thu, 2 Jun 2022 10:37:05 -0600 Subject: [PATCH 09/12] chore(typescript): fixed prettier --- .../src/victory-theme/victory-theme-definition.ts | 5 +---- packages/victory-core/src/victory-theme/victory-theme.tsx | 2 +- 2 files changed, 2 insertions(+), 5 deletions(-) diff --git a/packages/victory-core/src/victory-theme/victory-theme-definition.ts b/packages/victory-core/src/victory-theme/victory-theme-definition.ts index 374130c41..7f79bfb0d 100644 --- a/packages/victory-core/src/victory-theme/victory-theme-definition.ts +++ b/packages/victory-core/src/victory-theme/victory-theme-definition.ts @@ -1,8 +1,5 @@ import * as React from "react"; -import { - VictoryCommonThemeProps, - VictoryDatableProps -} from "../index"; +import { VictoryCommonThemeProps, VictoryDatableProps } from "../index"; import { CallbackArgs, StringOrNumberOrCallback } from "../types"; export type BlockProps = { diff --git a/packages/victory-core/src/victory-theme/victory-theme.tsx b/packages/victory-core/src/victory-theme/victory-theme.tsx index 0c5f7bab1..833524cdf 100644 --- a/packages/victory-core/src/victory-theme/victory-theme.tsx +++ b/packages/victory-core/src/victory-theme/victory-theme.tsx @@ -1,3 +1,3 @@ export * from "./material"; export * from "./grayscale"; -export * from './victory-theme-definition'; +export * from "./victory-theme-definition"; From bd40029c7c227fc65d55e1b8673d3c1ac42d2fa1 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Thu, 2 Jun 2022 10:42:10 -0600 Subject: [PATCH 10/12] chore(typescript): build `vendor` before `core` --- package-scripts.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/package-scripts.js b/package-scripts.js index bd2472aaa..c1bc89f10 100644 --- a/package-scripts.js +++ b/package-scripts.js @@ -127,8 +127,8 @@ module.exports = { "build-package-libs-vendor": "lerna exec --scope victory-vendor -- yarn build", "build-package-libs": npsUtils.series.nps( - "build-package-libs-core", - "build-package-libs-vendor" + "build-package-libs-vendor", + "build-package-libs-core" ), "build-dist-dev": "webpack --bail --config ../../config/webpack/webpack.config.dev.js", From 38693aa0101434a3ef46e9f5823c412ad8191278 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Thu, 2 Jun 2022 12:14:20 -0600 Subject: [PATCH 11/12] chore(typescript): ensure we build before we typecheck --- package-scripts.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package-scripts.js b/package-scripts.js index c1bc89f10..4a39de46d 100644 --- a/package-scripts.js +++ b/package-scripts.js @@ -86,8 +86,8 @@ module.exports = { ci: npsUtils.series.nps( "format.ci", "lint", - "typecheck", "build-package-libs", + "typecheck", "build-package-dists", "test-node", "jest", From 6e5fa9f899df13514ebbad5932776cb82543a692 Mon Sep 17 00:00:00 2001 From: scottrippey Date: Thu, 2 Jun 2022 12:16:18 -0600 Subject: [PATCH 12/12] chore(typescript): fixed VictoryTheme export --- packages/victory-core/src/victory-theme/victory-theme.tsx | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/packages/victory-core/src/victory-theme/victory-theme.tsx b/packages/victory-core/src/victory-theme/victory-theme.tsx index 833524cdf..6569834ea 100644 --- a/packages/victory-core/src/victory-theme/victory-theme.tsx +++ b/packages/victory-core/src/victory-theme/victory-theme.tsx @@ -1,3 +1,5 @@ -export * from "./material"; -export * from "./grayscale"; +import { grayscale } from "./grayscale"; +import { material } from "./material"; export * from "./victory-theme-definition"; + +export const VictoryTheme = { grayscale, material };