Skip to content

Commit

Permalink
Implemented compact mode for the drawing-toolbar
Browse files Browse the repository at this point in the history
  • Loading branch information
dkvovik committed Jul 16, 2024
1 parent 92cbcc4 commit 691d686
Show file tree
Hide file tree
Showing 17 changed files with 500 additions and 195 deletions.
2 changes: 1 addition & 1 deletion package-lock.json

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

2 changes: 1 addition & 1 deletion packages/drawing-toolbar/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@ulms/ui-drawing-toolbar",
"version": "2.5.1",
"version": "2.6.0-dev.0-ULMS-3031",
"license": "MIT",
"main": "index.js",
"module": "es/index.js",
Expand Down
25 changes: 22 additions & 3 deletions packages/drawing-toolbar/src/components/color-settings.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,20 +20,29 @@ const colors = [
{ dataTestId: 'board-panel-popup-color-aquamarine-button', value: '#9DF1F7' },
]

const colorsForCompactMode = [
{ dataTestId: 'board-panel-popup-color-black-button', value: '#000000' },
{ dataTestId: 'board-panel-popup-color-red-button', value: '#F94B28' },
{ dataTestId: 'board-panel-popup-color-blue-button', value: '#1A96F6' },
{ dataTestId: 'board-panel-popup-color-green-button', value: '#7FC92E' },
]

export function ColorItem({
active = false,
color,
compact,
dataTestId,
handleClick,
innerRef,
}) {
return (
<ToolbarButton
active={active}
compact={compact}
dataTestId={dataTestId}
innerRef={innerRef}
onClick={() => handleClick(color)}
style={{ padding: '10px' }}
style={{ padding: compact ? '6px' : '10px' }}
>
<div
className={css.colorCircle}
Expand All @@ -47,8 +56,17 @@ export function ColorItem({
)
}

export function ColorSettings({ currentColor, handleClick, rows = 3 }) {
export function ColorSettings({
compact,
currentColor,
handleClick,
rows = 3,
}) {
const splitColors = useMemo(() => {
if (compact) {
return [colorsForCompactMode]
}

const chunkSize = Math.max(colors.length / rows, 1)
const result = []

Expand All @@ -57,7 +75,7 @@ export function ColorSettings({ currentColor, handleClick, rows = 3 }) {
}

return result
}, [rows])
}, [compact, rows])

return (
<div className={css.wrapper}>
Expand All @@ -68,6 +86,7 @@ export function ColorSettings({ currentColor, handleClick, rows = 3 }) {
<ColorItem
active={currentColor.toLowerCase() === color.value.toLowerCase()}
color={color.value}
compact={compact}
dataTestId={color.dataTestId}
handleClick={handleClick}
key={color.value}
Expand Down
7 changes: 4 additions & 3 deletions packages/drawing-toolbar/src/components/divider.jsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
import cn from 'classnames-es'
import React from 'react'

import css from './divider.module.css'

// eslint-disable-next-line import/prefer-default-export
export function Divider({ horizontal = false }) {
export function Divider({ className, horizontal = false }) {
return horizontal ? (
<div className={css.horizontalDivider} />
<div className={cn(css.horizontalDivider, className)} />
) : (
<div className={css.verticalDivider} />
<div className={cn(css.verticalDivider, className)} />
)
}
4 changes: 3 additions & 1 deletion packages/drawing-toolbar/src/components/font-settings.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ const testAttributes = {
}

// eslint-disable-next-line import/prefer-default-export
export function FontSettings({ currentFontSize, handleClick }) {
export function FontSettings({ compact, currentFontSize, gap, handleClick }) {
const fontIcons = {
[fontSizes[0]]: <IconText32 />,
[fontSizes[1]]: <IconText48 />,
Expand All @@ -30,7 +30,9 @@ export function FontSettings({ currentFontSize, handleClick }) {
return (
<IconGroupSettings
iconsSet={iconsSet}
compact={compact}
currentSelection={currentFontSize}
gap={gap}
handleClick={handleClick}
/>
)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import cn from 'classnames-es'
import React from 'react'

import { ToolbarButton } from './toolbar-button'
Expand All @@ -7,16 +8,19 @@ import css from './settings.module.css'
// eslint-disable-next-line import/prefer-default-export
export function IconGroupSettings({
iconsSet,
compact,
currentSelection,
gap = 4,
handleClick,
fillWidth,
}) {
return (
<div className={css.wrapper}>
<div className={css.row}>
<div className={cn(css.row, css[`gap-${gap}`])}>
{iconsSet.map(({ dataTestId, key, icon, title = '' }) => (
<ToolbarButton
active={currentSelection === key}
compact={compact}
dataTestId={dataTestId}
onClick={() => handleClick(key)}
title={title}
Expand Down
76 changes: 59 additions & 17 deletions packages/drawing-toolbar/src/components/line-group.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,12 @@ import IconDashedLine from '../icons/dashed-line-tool-icon.svg'
import IconArrow from '../icons/arrow-tool-icon.svg'

import { intlID } from '../../lang/constants'

import {
compactSettingsGroupContainerStyles,
settingsGroupContainerStyles,
} from '../constants'
import { HEXtoRGB, RGBtoHEX } from '../utils'
import { settingsGroupContainerStyles } from '../constants'

import { IconGroupSettings } from './icon-group-settings'
import { ToolbarButton } from './toolbar-button'
Expand Down Expand Up @@ -112,39 +116,77 @@ export class LineGroup extends React.Component {
}

render() {
const { opened, tool, handleClose, handleOpen, className } = this.props
const { compact, opened, tool, handleClose, handleOpen, className } =
this.props
const { brushMode, size, color } = this.state

return (
<SettingsGroup
direction="right-start"
containerStyles={settingsGroupContainerStyles}
direction={compact ? 'top' : 'right-start'}
compact={compact}
containerStyles={
compact
? compactSettingsGroupContainerStyles
: settingsGroupContainerStyles
}
isOpen={opened}
handleClose={handleClose}
target={this.buttonRef.current}
offset={compact ? 4 : undefined}
target={compact ? '.drawing-toolbar' : this.buttonRef.current}
content={
<div className={cn(css.column, className)}>
<div
className={cn(
css['settings-group'],
{
[css.column]: !compact,
[css.compact]: compact,
[css.row]: compact,
},
className,
)}
>
<IconGroupSettings
compact={compact}
iconsSet={this.iconsSet}
currentSelection={brushMode}
gap={compact ? 12 : 4}
handleClick={(value) => this.handleClick('brushMode', value)}
/>
<Divider horizontal />
<LineSettings
currentSize={size}
dashed={brushMode === lineToolModeEnum.DASHED_LINE}
handleClick={(value) => this.handleClick('size', value)}
/>
<Divider horizontal />
<ColorSettings
currentColor={color}
handleClick={(value) => this.handleClick('color', value)}
/>

{compact && (
<>
<Divider
className={cn(compact && css['divider-with-margin'])}
/>
<ColorSettings
compact={compact}
currentColor={color}
handleClick={(value) => this.handleClick('color', value)}
/>
</>
)}

{!compact && (
<>
<Divider horizontal />
<LineSettings
currentSize={size}
dashed={brushMode === lineToolModeEnum.DASHED_LINE}
handleClick={(value) => this.handleClick('size', value)}
/>
<Divider horizontal />
<ColorSettings
currentColor={color}
handleClick={(value) => this.handleClick('color', value)}
/>
</>
)}
</div>
}
>
<ToolbarButton
active={tool === toolEnum.LINE}
compact={compact}
dataTestId="board-panel-group-line-button"
group
groupColor={color}
Expand Down
100 changes: 73 additions & 27 deletions packages/drawing-toolbar/src/components/pen-group.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,10 @@ import IconMarker from '../icons/marker-tool-icon.svg'

import { intlID } from '../../lang/constants'

import {
compactSettingsGroupContainerStyles,
settingsGroupContainerStyles,
} from '../constants'
import { HEXtoRGB, RGBtoHEX } from '../utils'

import { IconGroupSettings } from './icon-group-settings'
Expand Down Expand Up @@ -166,62 +170,104 @@ export class PenGroup extends React.Component {

render() {
const {
compact,
opened,
tool,
handleClose,
handleOpen,
className,
containerStyles = { marginTop: '-16px', marginLeft: '-2px' },
containerStyles = settingsGroupContainerStyles,
direction = 'right-start',
orientation = 'vertical',
} = this.props
const { brushMode, markerSize, penSize, markerColor, penColor } = this.state

return (
<SettingsGroup
compact={compact}
direction={direction}
containerStyles={containerStyles}
containerStyles={
compact ? compactSettingsGroupContainerStyles : containerStyles
}
isOpen={opened}
handleClose={handleClose}
target={this.buttonRef.current}
offset={compact ? 4 : undefined}
target={compact ? '.drawing-toolbar' : this.buttonRef.current}
content={
<div className={cn(css.column, css[orientation], className)}>
<div
className={cn(
css['settings-group'],
css.column,
css[orientation],
{ [css.compact]: compact },
className,
)}
>
<div className={css.column__group}>
<IconGroupSettings
iconsSet={this.iconsSet}
compact={compact}
currentSelection={brushMode}
gap={compact ? 12 : 4}
handleClick={(value) => this.handleClick('brushMode', value)}
/>
<Divider horizontal={orientation === 'vertical'} />
<LineSettings
currentSize={
brushMode === penToolModeEnum.MARKER ? markerSize : penSize
}
dashed={brushMode === penToolModeEnum.DASHED_PENCIL}
handleClick={(value) =>
brushMode === penToolModeEnum.MARKER
? this.handleClick('markerSize', value)
: this.handleClick('penSize', value)
}
<Divider
className={cn(compact && css['divider-with-margin'])}
horizontal={orientation === 'vertical'}
/>
{compact ? (
<ColorSettings
compact
currentColor={
brushMode === penToolModeEnum.MARKER
? markerColor
: penColor
}
handleClick={(value) =>
brushMode === penToolModeEnum.MARKER
? this.handleClick('markerColor', value)
: this.handleClick('penColor', value)
}
/>
) : (
<LineSettings
currentSize={
brushMode === penToolModeEnum.MARKER ? markerSize : penSize
}
dashed={brushMode === penToolModeEnum.DASHED_PENCIL}
handleClick={(value) =>
brushMode === penToolModeEnum.MARKER
? this.handleClick('markerSize', value)
: this.handleClick('penSize', value)
}
/>
)}
</div>
<Divider horizontal />
<ColorSettings
currentColor={
brushMode === penToolModeEnum.MARKER ? markerColor : penColor
}
handleClick={(value) =>
brushMode === penToolModeEnum.MARKER
? this.handleClick('markerColor', value)
: this.handleClick('penColor', value)
}
rows={orientation === 'horizontal' ? 2 : 3}
/>
{!compact && (
<>
<Divider horizontal />
<ColorSettings
compact={compact}
currentColor={
brushMode === penToolModeEnum.MARKER
? markerColor
: penColor
}
handleClick={(value) =>
brushMode === penToolModeEnum.MARKER
? this.handleClick('markerColor', value)
: this.handleClick('penColor', value)
}
rows={orientation === 'horizontal' ? 2 : 3}
/>
</>
)}
</div>
}
>
<ToolbarButton
active={tool === toolEnum.PEN}
compact={compact}
dataTestId="board-panel-group-pen-button"
group
groupColor={
Expand Down
Loading

0 comments on commit 691d686

Please sign in to comment.