Skip to content

Commit

Permalink
chore(circle-packing): fixes after rebase to master
Browse files Browse the repository at this point in the history
  • Loading branch information
wyze committed Apr 26, 2021
1 parent ca07b9e commit 89109d9
Show file tree
Hide file tree
Showing 8 changed files with 25 additions and 34 deletions.
4 changes: 1 addition & 3 deletions packages/circle-packing/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -33,9 +33,7 @@
"@nivo/tooltip": "0.68.0",
"d3-hierarchy": "^1.1.8",
"lodash": "^4.17.11",
"react-motion": "^0.5.2",
"react-spring": "9.0.0-rc.3",
"recompose": "^0.30.0"
"react-spring": "9.1.2"
},
"devDependencies": {
"@nivo/core": "0.68.0",
Expand Down
6 changes: 3 additions & 3 deletions packages/circle-packing/src/CirclePacking.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -139,8 +139,8 @@ const InnerCirclePacking = <RawDatum,>({
role={role}
>
{layers.map((layer, i) => {
if (layerById[layer as CirclePackLayerId] !== undefined) {
return layerById[layer as CirclePackLayerId]
if (layerById[layer as CirclePackingLayerId] !== undefined) {
return layerById[layer as CirclePackingLayerId]
}

if (typeof layer === 'function') {
Expand All @@ -154,10 +154,10 @@ const InnerCirclePacking = <RawDatum,>({
}

export const CirclePacking = <RawDatum,>({
theme,
isInteractive = defaultProps.isInteractive,
animate = defaultProps.animate,
motionConfig = defaultProps.motionConfig,
theme,
...otherProps
}: Partial<Omit<CirclePackingSvgProps<RawDatum>, 'data' | 'width' | 'height'>> &
Pick<CirclePackingSvgProps<RawDatum>, 'data' | 'width' | 'height'>) => (
Expand Down
4 changes: 2 additions & 2 deletions packages/circle-packing/src/Circles.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,7 @@ export const Circles = <RawDatum,>({
opacity: number
}
>(nodes, {
key: node => node.id,
keys: node => node.id,
initial: transitionPhases.update,
from: transitionPhases.enter,
enter: transitionPhases.update,
Expand All @@ -147,6 +147,6 @@ export const Circles = <RawDatum,>({
onClick: handleClick,
})
})}
</g>
</>
)
}
2 changes: 1 addition & 1 deletion packages/circle-packing/src/Labels.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ export const Labels = <RawDatum,>({
opacity: number
}
>(labels, {
key: label => label.node.id,
keys: label => label.node.id,
initial: transitionPhases.update,
from: transitionPhases.enter,
enter: transitionPhases.update,
Expand Down
11 changes: 0 additions & 11 deletions packages/circle-packing/src/ResponsiveBubbleHtml.js

This file was deleted.

2 changes: 1 addition & 1 deletion packages/circle-packing/src/ResponsiveCirclePacking.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import React from 'react'
import { ResponsiveWrapper } from '@nivo/core'
import { CirclePackingSvgProps } from './types'
import { CirclePacking } from './CirclePacking'
import { CirclePackSvgProps } from './types'

type ResponsiveCirclePackingProps<RawDatum> = Partial<
Omit<CirclePackingSvgProps<RawDatum>, 'data' | 'width' | 'height'>
Expand Down
20 changes: 11 additions & 9 deletions packages/circle-packing/src/hooks.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,11 @@ import {
MouseHandlers,
} from './types'

export const useCirclePacking = <RawDatum extends DatumWithChildren<RawDatum>>({
export const useCirclePacking = <RawDatum>({
data,
id,
value,
valueFormat,
width,
height,
padding,
Expand All @@ -30,9 +31,10 @@ export const useCirclePacking = <RawDatum extends DatumWithChildren<RawDatum>>({
inheritColorFromParent,
childColor,
}: {
data: RawDatum
id: CirclePackSvgProps<RawDatum>['id']
value: CirclePackSvgProps<RawDatum>['value']
data: CirclePackingCommonProps<RawDatum>['data']
id: CirclePackingCommonProps<RawDatum>['id']
value: CirclePackingCommonProps<RawDatum>['value']
valueFormat?: CirclePackingCommonProps<RawDatum>['valueFormat']
width: number
height: number
padding: CirclePackingCommonProps<RawDatum>['padding']
Expand All @@ -44,6 +46,7 @@ export const useCirclePacking = <RawDatum extends DatumWithChildren<RawDatum>>({
}): ComputedDatum<RawDatum>[] => {
const getId = usePropertyAccessor<RawDatum, string>(id)
const getValue = usePropertyAccessor<RawDatum, number>(value)
const formatValue = useValueFormatter(valueFormat)

const getColor = useOrdinalColorScale<Omit<ComputedDatum<RawDatum>, 'color' | 'fill'>>(
colors,
Expand All @@ -57,10 +60,9 @@ export const useCirclePacking = <RawDatum extends DatumWithChildren<RawDatum>>({
// this ensures that we don't mutate the input data
const clonedData = cloneDeep(data)

const hierarchy = d3Hierarchy(clonedData).sum(getValue)

const pack = d3Pack().size([width, height]).padding(padding)
const hierarchy = d3Hierarchy<RawDatum>(clonedData).sum(getValue)

const pack = d3Pack<RawDatum>().size([width, height]).padding(padding)
const packedData = pack(hierarchy)

const nodes = leavesOnly ? packedData.leaves() : packedData.descendants()
Expand All @@ -73,7 +75,7 @@ export const useCirclePacking = <RawDatum extends DatumWithChildren<RawDatum>>({

const total = hierarchy.value ?? 0

const computedNodes = sortedNodes.reduce<ComputedDatum<RawDatum>>((acc, descendant) => {
const computedNodes = sortedNodes.reduce<ComputedDatum<RawDatum>[]>((acc, descendant) => {
const id = getId(descendant.data)
const value = descendant.value!
const percentage = (100 * value) / total
Expand All @@ -89,7 +91,7 @@ export const useCirclePacking = <RawDatum extends DatumWithChildren<RawDatum>>({
path,
value,
percentage,
//formattedValue: valueFormat ? formatValue(value) : `${percentage.toFixed(2)}%`,
formattedValue: valueFormat ? formatValue(value) : `${percentage.toFixed(2)}%`,
x: descendant.x,
y: descendant.y,
radius: descendant.r,
Expand Down
10 changes: 6 additions & 4 deletions packages/circle-packing/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,15 @@ export interface ComputedDatum<RawDatum> {
parent?: ComputedDatum<RawDatum>
}

export type CirclePackLayerId = 'circles' | 'labels'
export type CirclePackingLayerId = 'circles' | 'labels'

export interface CirclePackCustomLayerProps<RawDatum extends DatumWithChildren<RawDatum>> {}
export interface CirclePackingCustomLayerProps<RawDatum> {
nodes: ComputedDatum<RawDatum>[]
}

export type CirclePackCustomLayer<RawDatum> = React.FC<CirclePackCustomLayerProps<RawDatum>>
export type CirclePackingCustomLayer<RawDatum> = React.FC<CirclePackingCustomLayerProps<RawDatum>>

export type CirclePackLayer<RawDatum> = CirclePackLayerId | CirclePackCustomLayer<RawDatum>
export type CirclePackingLayer<RawDatum> = CirclePackingLayerId | CirclePackingCustomLayer<RawDatum>

export type MouseHandler<RawDatum> = (
datum: ComputedDatum<RawDatum>,
Expand Down

0 comments on commit 89109d9

Please sign in to comment.