Skip to content

Commit

Permalink
changes-made-a/c-review
Browse files Browse the repository at this point in the history
  • Loading branch information
SURAJ-SHARMA27 authored and inodb committed Oct 24, 2024
1 parent e3892ad commit ac65aaf
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 21 deletions.
6 changes: 3 additions & 3 deletions src/pages/groupComparison/MultipleCategoryBarPlot.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ import classnames from 'classnames';
import { toConditionalPrecisionWithMinimum } from 'shared/lib/FormatUtils';
import { IStringAxisData } from 'shared/components/plots/PlotsTabUtils';
import WindowStore from 'shared/components/window/WindowStore';

import { SortByOptions } from 'shared/components/plots/PlotsTab';
export interface IMultipleCategoryBarPlotProps {
svgId?: string;
domainPadding?: number;
Expand Down Expand Up @@ -432,9 +432,9 @@ export default class MultipleCategoryBarPlot extends React.Component<
@computed get labels() {
if (this.data.length > 0) {
if (
this.props.sortByOption === 'SortByTotalSum' ||
this.props.sortByOption === SortByOptions.SortByTotalSum ||
(this.props.sortByOption !== '' &&
this.props.sortByOption !== 'alphabetically')
this.props.sortByOption !== SortByOptions.Alphabetically)
) {
return getSortedMajorCategories(
this.data,
Expand Down
43 changes: 29 additions & 14 deletions src/shared/components/plots/MultipleCategoryBarPlotUtils.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,12 @@
import { IStringAxisData } from './PlotsTabUtils';
import { SortByOptions } from './PlotsTab';
import _ from 'lodash';
import { IMultipleCategoryBarPlotData } from '../../../pages/groupComparison/MultipleCategoryBarPlot';

interface CountItem {
majorCategory: string;
count: number;
percentage: number;
}
export function makePlotData(
horzData: IStringAxisData['data'],
vertData: IStringAxisData['data'],
Expand Down Expand Up @@ -103,7 +108,7 @@ export function getSortedMajorCategories(
sortByOption: string | undefined
): string[] {
if (sortByOption === 'SortByTotalSum') {
const majorCategoryCounts: any = {};
const majorCategoryCounts: { [key: string]: number } = {};

data.forEach(item => {
item.counts.forEach(countItem => {
Expand All @@ -114,11 +119,14 @@ export function getSortedMajorCategories(
majorCategoryCounts[majorCategory] += count;
});
});

console.log(majorCategoryCounts, 'this is major');
return Object.keys(majorCategoryCounts).sort(
(a, b) => majorCategoryCounts[b] - majorCategoryCounts[a]
);
} else if (sortByOption !== '' && sortByOption !== 'alphabetically') {
} else if (
sortByOption !== '' &&
sortByOption !== SortByOptions.Alphabetically
) {
const sortedEntityData = data.find(
item => item.minorCategory === sortByOption
);
Expand All @@ -138,15 +146,19 @@ export function sortDataByOption(
const sortedMajorCategories = getSortedMajorCategories(data, sortByOption);

if (sortByOption === 'SortByTotalSum' || sortedMajorCategories.length > 0) {
const reorderCounts = (counts: any) => {
return sortedMajorCategories.map(category => {
return counts.find(
(countItem: any) => countItem.majorCategory === category
);
});
const reorderCounts = (counts: CountItem[]): CountItem[] => {
console.log('Counts structure:', counts);
return sortedMajorCategories
.map(category =>
counts.find(
(countItem: CountItem) =>
countItem.majorCategory === category
)
)
.filter((item): item is CountItem => item !== undefined); // Filter out undefined values
};

data.forEach(item => {
data.forEach((item: IMultipleCategoryBarPlotData) => {
item.counts = reorderCounts(item.counts);
});

Expand All @@ -157,11 +169,13 @@ export function sortDataByOption(
if (sortedEntityData) {
data = data.filter(item => item.minorCategory !== sortByOption);
data.unshift(sortedEntityData);
} else {
return data; // Early return if no sorted entity found
}
}
}

return data;
return data; // Return the sorted data
}

export function makeBarSpecs(
Expand All @@ -188,7 +202,7 @@ export function makeBarSpecs(
if (
sortByOption &&
sortByOption !== '' &&
sortByOption !== 'alphabetically'
sortByOption !== SortByOptions.Alphabetically
) {
data = sortDataByOption(data, sortByOption);
} else {
Expand All @@ -212,7 +226,8 @@ export function makeBarSpecs(
);
return {
fill,
data: (sortByOption != '' && sortByOption != 'alphabetically'
data: (sortByOption != '' &&
sortByOption != SortByOptions.Alphabetically
? counts
: sortedCounts
).map((obj, index) => ({
Expand Down
13 changes: 9 additions & 4 deletions src/shared/components/plots/PlotsTab.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -210,6 +210,11 @@ export enum DiscreteVsDiscretePlotType {
Table = 'Table',
}

export enum SortByOptions {
Alphabetically = 'alphabetically',
SortByTotalSum = 'SortByTotalSum',
}

export enum MutationCountBy {
MutationType = 'MutationType',
MutatedVsWildType = 'MutatedVsWildType',
Expand Down Expand Up @@ -443,7 +448,7 @@ export default class PlotsTab extends React.Component<IPlotsTabProps, {}> {
private scrollingDummyPane = false;
@observable plotElementWidth = 0;
@observable sortByDropDownOptions: { value: string; label: string }[] = [];
@observable sortByOption: string = 'alphabetically';
@observable sortByOption: string = SortByOptions.Alphabetically;
@observable boxPlotSortByMedian = false;
@observable.ref searchCaseInput: string;
@observable.ref searchMutationInput: string;
Expand All @@ -467,8 +472,8 @@ export default class PlotsTab extends React.Component<IPlotsTabProps, {}> {
@observable _vertGenericAssaySearchText: string = '';

private defaultOptions = [
{ value: 'alphabetically', label: 'Alphabetically' },
{ value: 'SortByTotalSum', label: 'Number of samples' },
{ value: SortByOptions.Alphabetically, label: 'Alphabetically' },
{ value: SortByOptions.SortByTotalSum, label: 'Number of samples' },
];

@action.bound
Expand Down Expand Up @@ -4596,7 +4601,7 @@ export default class PlotsTab extends React.Component<IPlotsTabProps, {}> {
</div>
</div>
)}
{this.stackedBar && (
{this.discreteVsDiscretePlotType == 'StackedBar' && (
<div className="form-group">
<label>Sort By</label>
<div style={{ display: 'flex' }}>
Expand Down

0 comments on commit ac65aaf

Please sign in to comment.