Skip to content

Commit

Permalink
refactor: introduce redux toolkit (apache#23460)
Browse files Browse the repository at this point in the history
Co-authored-by: Michael S. Molina <[email protected]>
  • Loading branch information
justinpark and michael-s-molina authored Apr 12, 2023
1 parent 350723b commit 75021a1
Show file tree
Hide file tree
Showing 12 changed files with 186 additions and 131 deletions.
95 changes: 66 additions & 29 deletions superset-frontend/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion superset-frontend/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,7 @@
"@emotion/react": "^11.4.1",
"@emotion/styled": "^11.3.0",
"@fontsource/inter": "^4.0.0",
"@reduxjs/toolkit": "^1.9.3",
"@superset-ui/chart-controls": "file:./packages/superset-ui-chart-controls",
"@superset-ui/core": "file:./packages/superset-ui-core",
"@superset-ui/legacy-plugin-chart-calendar": "file:./plugins/legacy-plugin-chart-calendar",
Expand Down Expand Up @@ -197,7 +198,7 @@
"react-virtualized": "9.19.1",
"react-virtualized-auto-sizer": "^1.0.7",
"react-window": "^1.8.8",
"redux": "^4.0.5",
"redux": "^4.2.1",
"redux-localstorage": "^0.4.1",
"redux-thunk": "^2.1.0",
"redux-undo": "^1.0.0-beta9-9-7",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -103,8 +103,10 @@ class SuperChart extends React.PureComponent<Props, {}> {
private createChartProps = ChartProps.createSelector();

private parseDimension = createSelector(
({ width }: { width: string | number; height: string | number }) => width,
({ height }) => height,
[
({ width }: { width: string | number; height: string | number }) => width,
({ height }) => height,
],
(width, height) => {
// Parse them in case they are % or 'auto'
const widthInfo = parseLength(width);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -95,15 +95,17 @@ export default class SuperChartCore extends React.PureComponent<Props, {}> {
* is changed.
*/
processChartProps = createSelector(
(input: {
chartProps: ChartProps;
preTransformProps?: PreTransformProps;
transformProps?: TransformProps;
postTransformProps?: PostTransformProps;
}) => input.chartProps,
input => input.preTransformProps,
input => input.transformProps,
input => input.postTransformProps,
[
(input: {
chartProps: ChartProps;
preTransformProps?: PreTransformProps;
transformProps?: TransformProps;
postTransformProps?: PostTransformProps;
}) => input.chartProps,
input => input.preTransformProps,
input => input.transformProps,
input => input.postTransformProps,
],
(chartProps, pre = IDENTITY, transform = IDENTITY, post = IDENTITY) =>
post(transform(pre(chartProps))),
);
Expand All @@ -117,9 +119,11 @@ export default class SuperChartCore extends React.PureComponent<Props, {}> {
* is changed.
*/
private createLoadableRenderer = createSelector(
(input: { chartType: string; overrideTransformProps?: TransformProps }) =>
input.chartType,
input => input.overrideTransformProps,
[
(input: { chartType: string; overrideTransformProps?: TransformProps }) =>
input.chartType,
input => input.overrideTransformProps,
],
(chartType, overrideTransformProps) => {
if (chartType) {
const Renderer = createLoadableRenderer({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -106,11 +106,15 @@ export interface SeriesValue {
const CIRCLE_STYLE = { strokeWidth: 1.5 };

export default class LineChart extends PureComponent<Props> {
private createEncoder = lineEncoderFactory.createSelector();
private createEncoder = lineEncoderFactory.createSelector() as (
encoding: Partial<LineEncoding>,
) => LineEncoder;

private createAllSeries = createSelector(
(input: { encoder: LineEncoder; data: Dataset }) => input.encoder,
input => input.data,
[
(input: { encoder: LineEncoder; data: Dataset }) => input.encoder,
input => input.data,
],
(encoder, data) => {
const { channels } = encoder;
const fieldNames = encoder.getGroupBys();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,10 +26,12 @@ export default function createMarginSelector(
defaultMargin: Margin = DEFAULT_MARGIN,
) {
return createSelector(
(margin: Partial<Margin>) => margin.bottom,
margin => margin.left,
margin => margin.right,
margin => margin.top,
[
(margin: Partial<Margin>) => margin.bottom,
margin => margin.left,
margin => margin.right,
margin => margin.top,
],
(
bottom = defaultMargin.bottom,
left = defaultMargin.left,
Expand Down
47 changes: 25 additions & 22 deletions superset-frontend/spec/fixtures/mockStore.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,7 @@
* specific language governing permissions and limitations
* under the License.
*/
import { createStore, applyMiddleware, compose } from 'redux';
import thunk from 'redux-thunk';

import { rootReducer } from 'src/views/store';
import { setupStore } from 'src/views/store';
import { FilterBarOrientation } from 'src/dashboard/types';

import mockState from './mockState';
Expand All @@ -32,38 +29,38 @@ import { dashboardFilters } from './mockDashboardFilters';
import { nativeFilters, dataMaskWith2Filters } from './mockNativeFilters';

export const storeWithState = state =>
createStore(rootReducer, state, compose(applyMiddleware(thunk)));
setupStore({
disableDebugger: true,
initialState: state,
});

export const getMockStore = overrideState =>
createStore(
rootReducer,
{ ...mockState, ...overrideState },
compose(applyMiddleware(thunk)),
);
setupStore({
disableDebugger: true,
initialState: { ...mockState, ...overrideState },
});

export const mockStore = getMockStore();

export const getMockStoreWithTabs = () =>
createStore(
rootReducer,
{
setupStore({
disableDebugger: true,
initialState: {
...mockState,
dashboardLayout: dashboardLayoutWithTabs,
dashboardFilters: {},
},
compose(applyMiddleware(thunk)),
);
});

export const getMockStoreWithChartsInTabsAndRoot = () =>
createStore(
rootReducer,
{
setupStore({
disableDebugger: true,
initialState: {
...mockState,
dashboardLayout: dashboardLayoutWithChartsInTabsAndRoot,
dashboardFilters: {},
},
compose(applyMiddleware(thunk)),
);
});

export const mockStoreWithTabs = getMockStoreWithTabs();
export const mockStoreWithChartsInTabsAndRoot =
Expand Down Expand Up @@ -101,7 +98,10 @@ export const stateWithFilters = {
// one chart with a filter that has been rejected,
// and one chart with no filters set.
export const getMockStoreWithFilters = () =>
createStore(rootReducer, stateWithFilters);
setupStore({
disableDebugger: true,
initialState: stateWithFilters,
});

export const stateWithNativeFilters = {
...mockState,
Expand Down Expand Up @@ -132,7 +132,10 @@ export const stateWithNativeFilters = {
};

export const getMockStoreWithNativeFilters = () =>
createStore(rootReducer, stateWithNativeFilters);
setupStore({
disableDebugger: true,
initialState: stateWithNativeFilters,
});

export const stateWithoutNativeFilters = {
...mockState,
Expand Down
Loading

0 comments on commit 75021a1

Please sign in to comment.