Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(drawing): add ColorPickerControl for images #1307

Merged
merged 8 commits into from
Dec 9, 2020
2 changes: 2 additions & 0 deletions src/lib/AnnotationModule.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ export const AnnotationColor = {
GRIMACE: bdlGrimace,
};

export const ANNOTATION_COLORS = Object.values(AnnotationColor);

export default class AnnotationModule {
private cache: Cache;

Expand Down
28 changes: 28 additions & 0 deletions src/lib/viewers/controls/annotations/DrawingControls.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import React from 'react';
import ColorPickerControl from '../color-picker/ColorPickerControl';
ChenCodes marked this conversation as resolved.
Show resolved Hide resolved
import { ANNOTATION_COLORS } from '../../../AnnotationModule';
import { AnnotationMode } from './types';

export type Props = {
annotationColor?: string;
annotationMode?: AnnotationMode;
onAnnotationColorChange: (color: string) => void;
};

export default function DrawingControls({
annotationColor,
annotationMode,
onAnnotationColorChange,
}: Props): JSX.Element | null {
if (annotationMode !== AnnotationMode.DRAWING) {
return null;
}

return (
<ColorPickerControl
activeColor={annotationColor}
colors={ANNOTATION_COLORS}
onColorSelect={onAnnotationColorChange}
/>
);
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import React from 'react';
import { shallow, ShallowWrapper } from 'enzyme';
import DrawingControls from '../DrawingControls';
import { AnnotationMode } from '../types';

describe('DrawingControls', () => {
const getWrapper = (props = {}): ShallowWrapper =>
shallow(<DrawingControls onAnnotationColorChange={jest.fn()} {...props} />);

describe('render', () => {
test('should return nothing if annotationMode is not DRAWING', () => {
const wrapper = getWrapper();
expect(wrapper.isEmptyRender()).toBe(true);
});

test('should return ColorPickerControl if annotationMode is DRAWING', () => {
const wrapper = getWrapper({ annotationMode: AnnotationMode.DRAWING });

expect(wrapper.exists('ColorPickerControl')).toBe(true);
});
});
});
8 changes: 6 additions & 2 deletions src/lib/viewers/controls/controls-bar/ControlsBar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,14 @@ import React from 'react';
import './ControlsBar.scss';

export type Props = {
children: React.ReactNode;
children?: React.ReactNode;
};

export default function ControlsBar({ children, ...rest }: Props): JSX.Element {
export default function ControlsBar({ children, ...rest }: Props): JSX.Element | null {
if (!children) {
return null;
}

return (
<div className="bp-ControlsBar" {...rest}>
{children}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,5 +11,12 @@ describe('ControlsBar', () => {
expect(wrapper.contains(children)).toBe(true);
expect(wrapper.hasClass('bp-ControlsBar')).toBe(true);
});

test('should return null if the children property is undefined', () => {
const children = undefined;
const wrapper = shallow(<ControlsBar>{children}</ControlsBar>);

expect(wrapper.isEmptyRender()).toBe(true);
});
});
});
24 changes: 9 additions & 15 deletions src/lib/viewers/doc/DocControls.tsx
Original file line number Diff line number Diff line change
@@ -1,19 +1,15 @@
import React from 'react';
import AnnotationsControls, { Props as AnnotationsControlsProps } from '../controls/annotations';
import ColorPickerControl, { Props as ColorPickerControlProps } from '../controls/color-picker';
import DrawingControls, { Props as DrawingControlsProps } from '../controls/annotations/DrawingControls';
ChenCodes marked this conversation as resolved.
Show resolved Hide resolved
import ControlsBar from '../controls/controls-bar';
import FindBarToggle, { Props as FindBarToggleProps } from '../controls/findbar';
import FullscreenToggle, { Props as FullscreenToggleProps } from '../controls/fullscreen';
import PageControls, { Props as PageControlsProps } from '../controls/page';
import ThumbnailsToggle, { Props as ThumbnailsToggleProps } from '../controls/sidebar';
import ZoomControls, { Props as ZoomControlsProps } from '../controls/zoom';
import { AnnotationColor } from '../../AnnotationModule';
import { AnnotationMode } from '../controls/annotations/types';

const colors = Object.values(AnnotationColor);

export type Props = AnnotationsControlsProps &
ColorPickerControlProps &
DrawingControlsProps &
FindBarToggleProps &
FullscreenToggleProps &
PageControlsProps &
Expand Down Expand Up @@ -73,15 +69,13 @@ export default function DocControls({
onAnnotationModeEscape={onAnnotationModeEscape}
/>
</ControlsBar>
{hasDrawing && annotationMode === AnnotationMode.DRAWING && (
<ControlsBar>
<ColorPickerControl
activeColor={annotationColor}
colors={colors}
onColorSelect={onAnnotationColorChange}
/>
</ControlsBar>
)}
<ControlsBar>
<DrawingControls
annotationColor={annotationColor}
annotationMode={annotationMode}
onAnnotationColorChange={onAnnotationColorChange}
/>
</ControlsBar>
</>
);
}
22 changes: 8 additions & 14 deletions src/lib/viewers/image/ImageControls.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,10 @@
import React from 'react';
import AnnotationsControls, { Props as AnnotationsControlsProps } from '../controls/annotations';
import ColorPickerControl from '../controls/color-picker';
import ControlsBar from '../controls/controls-bar';
import DrawingControls from '../controls/annotations/DrawingControls';
import FullscreenToggle, { Props as FullscreenToggleProps } from '../controls/fullscreen';
import RotateControl, { Props as RotateControlProps } from '../controls/rotate';
import ZoomControls, { Props as ZoomControlsProps } from '../controls/zoom';
import { AnnotationColor } from '../../AnnotationModule';
import { AnnotationMode } from '../controls/annotations/types';

const colors = Object.values(AnnotationColor);

export type Props = AnnotationsControlsProps &
FullscreenToggleProps &
Expand Down Expand Up @@ -48,15 +44,13 @@ export default function ImageControls({
onAnnotationModeEscape={onAnnotationModeEscape}
/>
</ControlsBar>
{hasDrawing && annotationMode === AnnotationMode.DRAWING && (
<ControlsBar>
<ColorPickerControl
activeColor={annotationColor}
colors={colors}
onColorSelect={onAnnotationColorChange}
/>
</ControlsBar>
)}
<ControlsBar>
<DrawingControls
annotationColor={annotationColor}
annotationMode={annotationMode}
onAnnotationColorChange={onAnnotationColorChange}
/>
</ControlsBar>
</>
);
}