diff --git a/src/common/components/mock-components/front-components/shape.const.ts b/src/common/components/mock-components/front-components/shape.const.ts index 458d4178..63656560 100644 --- a/src/common/components/mock-components/front-components/shape.const.ts +++ b/src/common/components/mock-components/front-components/shape.const.ts @@ -15,6 +15,7 @@ const DEFAULT_TEXT_HEIGHT = 38; const DEFAULT_FONT_VARIANT = 'normal'; const DEFAULT_FONT_STYLE = 'normal'; const DEFAULT_TEXT_DECORATION = 'none'; +const DEFAULT_TEXT_ALIGNMENT = 'left'; export interface DefaultStyleShape { DEFAULT_CORNER_RADIUS: number; @@ -32,6 +33,7 @@ export interface DefaultStyleShape { DEFAULT_FONT_VARIANT: string; DEFAULT_FONT_STYLE: string; DEFAULT_TEXT_DECORATION: string; + DEFAULT_TEXT_ALIGNMENT: 'left' | 'center' | 'right'; } export const BASIC_SHAPE: DefaultStyleShape = { @@ -50,6 +52,7 @@ export const BASIC_SHAPE: DefaultStyleShape = { DEFAULT_FONT_VARIANT, DEFAULT_FONT_STYLE, DEFAULT_TEXT_DECORATION, + DEFAULT_TEXT_ALIGNMENT, }; export const INPUT_SHAPE: DefaultStyleShape = { @@ -68,6 +71,7 @@ export const INPUT_SHAPE: DefaultStyleShape = { DEFAULT_FONT_VARIANT, DEFAULT_FONT_STYLE, DEFAULT_TEXT_DECORATION, + DEFAULT_TEXT_ALIGNMENT, }; //! maybe a function to calc max height base on the text @@ -87,6 +91,7 @@ export const POSTIT_SHAPE: DefaultStyleShape = { DEFAULT_FONT_VARIANT, DEFAULT_FONT_STYLE, DEFAULT_TEXT_DECORATION, + DEFAULT_TEXT_ALIGNMENT, }; interface FontValues { diff --git a/src/common/components/mock-components/front-text-components/heading1-text-shape.tsx b/src/common/components/mock-components/front-text-components/heading1-text-shape.tsx index 4e80efd4..1e76ba40 100644 --- a/src/common/components/mock-components/front-text-components/heading1-text-shape.tsx +++ b/src/common/components/mock-components/front-text-components/heading1-text-shape.tsx @@ -41,8 +41,14 @@ export const Heading1Shape = forwardRef((props, ref) => { ); const { width: restrictedWidth, height: restrictedHeight } = restrictedSize; - const { textColor, textDecoration, fontStyle, fontVariant, fontSize } = - useShapeProps(otherProps, BASIC_SHAPE); + const { + textColor, + textDecoration, + fontStyle, + fontVariant, + fontSize, + textAlignment, + } = useShapeProps(otherProps, BASIC_SHAPE); const commonGroupProps = useGroupShapeProps( props, @@ -64,7 +70,7 @@ export const Heading1Shape = forwardRef((props, ref) => { fontFamily={BASIC_SHAPE.DEFAULT_FONT_FAMILY} fontSize={fontSize} fill={textColor} - align="center" + align={textAlignment} verticalAlign="middle" ellipsis={true} wrap="none" diff --git a/src/common/components/mock-components/front-text-components/heading2-text-shape.tsx b/src/common/components/mock-components/front-text-components/heading2-text-shape.tsx index f3720664..050bf45f 100644 --- a/src/common/components/mock-components/front-text-components/heading2-text-shape.tsx +++ b/src/common/components/mock-components/front-text-components/heading2-text-shape.tsx @@ -41,8 +41,14 @@ export const Heading2Shape = forwardRef((props, ref) => { ); const { width: restrictedWidth, height: restrictedHeight } = restrictedSize; - const { textColor, fontVariant, fontStyle, textDecoration, fontSize } = - useShapeProps(otherProps, BASIC_SHAPE); + const { + textColor, + fontVariant, + fontStyle, + textDecoration, + fontSize, + textAlignment, + } = useShapeProps(otherProps, BASIC_SHAPE); const commonGroupProps = useGroupShapeProps( props, @@ -64,7 +70,7 @@ export const Heading2Shape = forwardRef((props, ref) => { fontFamily={BASIC_SHAPE.DEFAULT_FONT_FAMILY} fontSize={fontSize} fill={textColor} - align="center" + align={textAlignment} verticalAlign="middle" ellipsis={true} wrap="none" diff --git a/src/common/components/mock-components/front-text-components/heading3-text-shape.tsx b/src/common/components/mock-components/front-text-components/heading3-text-shape.tsx index 9beec114..b02200e8 100644 --- a/src/common/components/mock-components/front-text-components/heading3-text-shape.tsx +++ b/src/common/components/mock-components/front-text-components/heading3-text-shape.tsx @@ -42,8 +42,14 @@ export const Heading3Shape = forwardRef((props, ref) => { const { width: restrictedWidth, height: restrictedHeight } = restrictedSize; - const { textColor, fontVariant, fontStyle, textDecoration, fontSize } = - useShapeProps(otherProps, BASIC_SHAPE); + const { + textColor, + fontVariant, + fontStyle, + textDecoration, + fontSize, + textAlignment, + } = useShapeProps(otherProps, BASIC_SHAPE); const commonGroupProps = useGroupShapeProps( props, @@ -65,7 +71,7 @@ export const Heading3Shape = forwardRef((props, ref) => { fontFamily={BASIC_SHAPE.DEFAULT_FONT_FAMILY} fontSize={fontSize} fill={textColor} - align="center" + align={textAlignment} verticalAlign="middle" ellipsis={true} wrap="none" diff --git a/src/common/components/mock-components/front-text-components/link-text-shape.tsx b/src/common/components/mock-components/front-text-components/link-text-shape.tsx index faa249c1..2f012e88 100644 --- a/src/common/components/mock-components/front-text-components/link-text-shape.tsx +++ b/src/common/components/mock-components/front-text-components/link-text-shape.tsx @@ -42,10 +42,8 @@ export const LinkShape = forwardRef((props, ref) => { const { width: restrictedWidth, height: restrictedHeight } = restrictedSize; - const { textColor, textDecoration, fontSize, fontVariant } = useShapeProps( - otherProps, - BASIC_SHAPE - ); + const { textColor, textDecoration, fontSize, textAlignment, fontVariant } = + useShapeProps(otherProps, BASIC_SHAPE); const commonGroupProps = useGroupShapeProps( props, @@ -67,7 +65,7 @@ export const LinkShape = forwardRef((props, ref) => { fontFamily={BASIC_SHAPE.DEFAULT_FONT_FAMILY} fontSize={fontSize} fill={textColor} - align="center" + align={textAlignment} verticalAlign="middle" ellipsis={true} wrap="none" diff --git a/src/common/components/mock-components/front-text-components/normaltext-shape.tsx b/src/common/components/mock-components/front-text-components/normaltext-shape.tsx index 82569da2..0a37b9df 100644 --- a/src/common/components/mock-components/front-text-components/normaltext-shape.tsx +++ b/src/common/components/mock-components/front-text-components/normaltext-shape.tsx @@ -41,8 +41,14 @@ export const NormaltextShape = forwardRef((props, ref) => { ); const { width: restrictedWidth, height: restrictedHeight } = restrictedSize; - const { textColor, fontVariant, fontStyle, textDecoration, fontSize } = - useShapeProps(otherProps, BASIC_SHAPE); + const { + textColor, + fontVariant, + fontStyle, + textDecoration, + fontSize, + textAlignment, + } = useShapeProps(otherProps, BASIC_SHAPE); const commonGroupProps = useGroupShapeProps( props, @@ -64,7 +70,7 @@ export const NormaltextShape = forwardRef((props, ref) => { fontFamily={BASIC_SHAPE.DEFAULT_FONT_FAMILY} fontSize={fontSize} fill={textColor} - align="center" + align={textAlignment} verticalAlign="middle" ellipsis={true} wrap="none" diff --git a/src/common/components/mock-components/front-text-components/paragraph-text-shape.tsx b/src/common/components/mock-components/front-text-components/paragraph-text-shape.tsx index dccf7fcd..a987e4f4 100644 --- a/src/common/components/mock-components/front-text-components/paragraph-text-shape.tsx +++ b/src/common/components/mock-components/front-text-components/paragraph-text-shape.tsx @@ -41,7 +41,7 @@ export const ParagraphShape = forwardRef((props, ref) => { ); const { width: restrictedWidth, height: restrictedHeight } = restrictedSize; - const { textColor, fontSize, fontVariant } = useShapeProps( + const { textColor, fontSize, textAlignment, fontVariant } = useShapeProps( otherProps, BASIC_SHAPE ); @@ -66,7 +66,7 @@ export const ParagraphShape = forwardRef((props, ref) => { fontFamily={BASIC_SHAPE.DEFAULT_FONT_FAMILY} fontSize={fontSize} fill={textColor} - align="left" + align={textAlignment} ellipsis={true} /> diff --git a/src/common/components/mock-components/front-text-components/smalltext-shape.tsx b/src/common/components/mock-components/front-text-components/smalltext-shape.tsx index 965122cd..421b8728 100644 --- a/src/common/components/mock-components/front-text-components/smalltext-shape.tsx +++ b/src/common/components/mock-components/front-text-components/smalltext-shape.tsx @@ -41,8 +41,14 @@ export const SmalltextShape = forwardRef((props, ref) => { ); const { width: restrictedWidth, height: restrictedHeight } = restrictedSize; - const { textColor, fontVariant, fontStyle, textDecoration, fontSize } = - useShapeProps(otherProps, BASIC_SHAPE); + const { + textColor, + fontVariant, + fontStyle, + textDecoration, + fontSize, + textAlignment, + } = useShapeProps(otherProps, BASIC_SHAPE); const commonGroupProps = useGroupShapeProps( props, @@ -64,7 +70,7 @@ export const SmalltextShape = forwardRef((props, ref) => { fontFamily={BASIC_SHAPE.DEFAULT_FONT_FAMILY} fontSize={fontSize} fill={textColor} - align="center" + align={textAlignment} verticalAlign="middle" ellipsis={true} wrap="none" diff --git a/src/common/components/modal-dialog/modal-dialog.component.module.css b/src/common/components/modal-dialog/modal-dialog.component.module.css index 20f334c4..c64721df 100644 --- a/src/common/components/modal-dialog/modal-dialog.component.module.css +++ b/src/common/components/modal-dialog/modal-dialog.component.module.css @@ -1,26 +1,43 @@ .container { z-index: 2; - position: absolute; + position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; display: flex; + flex-direction: column; align-items: center; justify-content: center; - flex-direction: column; background-color: var(--primary-900-50-opacity); } +.dialog { + position: relative; + z-index: 3; + width: 90%; + max-width: 1280px; + height: 80%; + overflow: auto; + border-radius: var(--border-radius-l); +} + +.dialogContent { + overflow: auto; + flex: 1; +} + .dialogHeader { + position: sticky; + top: 0; + z-index: 4; background-color: var(--primary-500); - width: 70vw; display: flex; justify-content: space-between; align-items: center; padding: var(--space-s) var(--space-md); - border-top-left-radius: var(--border-radius-m); - border-top-right-radius: var(--border-radius-m); + border-top-left-radius: var(--border-radius-l); + border-top-right-radius: var(--border-radius-l); } .dialogTitle { @@ -41,3 +58,10 @@ .dialogButton:hover { cursor: pointer; } + +@media screen and (max-device-width: 780px) { + .dialog { + width: 92%; + height: 82%; + } +} diff --git a/src/common/components/modal-dialog/modal-dialog.component.tsx b/src/common/components/modal-dialog/modal-dialog.component.tsx index ccee8ee4..52ec230a 100644 --- a/src/common/components/modal-dialog/modal-dialog.component.tsx +++ b/src/common/components/modal-dialog/modal-dialog.component.tsx @@ -16,17 +16,19 @@ export const ModalDialogComponent: React.FC = () => { return ( isOpen && (
-
-

{title}

- +
+
+

{title}

+ +
+
{selectedComponent}
-
{selectedComponent}
) ); diff --git a/src/common/components/shapes/use-shape-props.hook.ts b/src/common/components/shapes/use-shape-props.hook.ts index 1a68f6d9..f3d79f85 100644 --- a/src/common/components/shapes/use-shape-props.hook.ts +++ b/src/common/components/shapes/use-shape-props.hook.ts @@ -43,6 +43,11 @@ export const useShapeProps = ( [otherProps?.textDecoration] ); + const textAlignment = useMemo( + () => otherProps?.textAlignment ?? defaultStyleShape.DEFAULT_TEXT_ALIGNMENT, + [otherProps?.textAlignment] + ); + const strokeStyle = useMemo( () => otherProps?.strokeStyle ?? [], [otherProps?.strokeStyle] @@ -81,5 +86,6 @@ export const useShapeProps = ( fontStyle, fontSize, textDecoration, + textAlignment, }; }; diff --git a/src/core/local-disk/shapes-to-document.mapper.ts b/src/core/local-disk/shapes-to-document.mapper.ts index d34a23c0..1efb0be6 100644 --- a/src/core/local-disk/shapes-to-document.mapper.ts +++ b/src/core/local-disk/shapes-to-document.mapper.ts @@ -30,6 +30,7 @@ const mapTextElementFromV0_1ToV0_2 = (shape: ShapeModel): ShapeModel => { otherProps: { ...shape, fontSize: FONT_SIZE_VALUES.HEADING1, + textAlignment: 'center', }, }; case 'heading2': @@ -38,6 +39,7 @@ const mapTextElementFromV0_1ToV0_2 = (shape: ShapeModel): ShapeModel => { otherProps: { ...shape, fontSize: FONT_SIZE_VALUES.HEADING2, + textAlignment: 'center', }, }; case 'heading3': @@ -46,6 +48,7 @@ const mapTextElementFromV0_1ToV0_2 = (shape: ShapeModel): ShapeModel => { otherProps: { ...shape, fontSize: FONT_SIZE_VALUES.HEADING3, + textAlignment: 'center', }, }; case 'link': @@ -54,6 +57,7 @@ const mapTextElementFromV0_1ToV0_2 = (shape: ShapeModel): ShapeModel => { otherProps: { ...shape, fontSize: FONT_SIZE_VALUES.LINK, + textAlignment: 'center', }, }; case 'normaltext': @@ -62,6 +66,7 @@ const mapTextElementFromV0_1ToV0_2 = (shape: ShapeModel): ShapeModel => { otherProps: { ...shape, fontSize: FONT_SIZE_VALUES.NORMALTEXT, + textAlignment: 'center', }, }; case 'smalltext': @@ -70,6 +75,7 @@ const mapTextElementFromV0_1ToV0_2 = (shape: ShapeModel): ShapeModel => { otherProps: { ...shape, fontSize: FONT_SIZE_VALUES.SMALLTEXT, + textAlignment: 'center', }, }; case 'paragraph': @@ -78,6 +84,7 @@ const mapTextElementFromV0_1ToV0_2 = (shape: ShapeModel): ShapeModel => { otherProps: { ...shape, fontSize: FONT_SIZE_VALUES.PARAGRAPH, + textAlignment: 'center', }, }; default: diff --git a/src/core/model/index.ts b/src/core/model/index.ts index 843d0979..c4580e2c 100644 --- a/src/core/model/index.ts +++ b/src/core/model/index.ts @@ -174,6 +174,7 @@ export interface OtherProps { borderRadius?: string; activeElement?: number; selectedBackgroundColor?: string; + textAlignment?: 'left' | 'center' | 'right'; } export const BASE_ICONS_URL = '/icons/'; diff --git a/src/pods/about/about.pod.module.css b/src/pods/about/about.pod.module.css index 6fa22325..dc41a9f8 100644 --- a/src/pods/about/about.pod.module.css +++ b/src/pods/about/about.pod.module.css @@ -1,6 +1,5 @@ .container { background-color: var(--primary-700); - width: 70vw; height: auto; display: flex; flex-direction: column; diff --git a/src/pods/about/components/developmentTeam.component.module.css b/src/pods/about/components/developmentTeam.component.module.css index 85a17ad3..7aea40b4 100644 --- a/src/pods/about/components/developmentTeam.component.module.css +++ b/src/pods/about/components/developmentTeam.component.module.css @@ -13,4 +13,6 @@ display: flex; flex-wrap: wrap; gap: var(--space-md) var(--space-xxl); + align-items: start; + justify-content: center; } diff --git a/src/pods/canvas/model/shape-other-props.utils.ts b/src/pods/canvas/model/shape-other-props.utils.ts index afff3625..62f09261 100644 --- a/src/pods/canvas/model/shape-other-props.utils.ts +++ b/src/pods/canvas/model/shape-other-props.utils.ts @@ -126,6 +126,7 @@ export const generateDefaultOtherProps = ( fontStyle: `${INPUT_SHAPE.DEFAULT_FONT_STYLE}`, textDecoration: `${INPUT_SHAPE.DEFAULT_TEXT_DECORATION}`, fontSize: FONT_SIZE_VALUES.HEADING1, + textAlignment: `${BASIC_SHAPE.DEFAULT_TEXT_ALIGNMENT}`, }; case 'heading2': @@ -135,6 +136,7 @@ export const generateDefaultOtherProps = ( fontStyle: `${INPUT_SHAPE.DEFAULT_FONT_STYLE}`, textDecoration: `${INPUT_SHAPE.DEFAULT_TEXT_DECORATION}`, fontSize: FONT_SIZE_VALUES.HEADING2, + textAlignment: `${BASIC_SHAPE.DEFAULT_TEXT_ALIGNMENT}`, }; case 'heading3': return { @@ -143,12 +145,14 @@ export const generateDefaultOtherProps = ( fontStyle: `${INPUT_SHAPE.DEFAULT_FONT_STYLE}`, textDecoration: `${INPUT_SHAPE.DEFAULT_TEXT_DECORATION}`, fontSize: FONT_SIZE_VALUES.HEADING3, + textAlignment: `${BASIC_SHAPE.DEFAULT_TEXT_ALIGNMENT}`, }; case 'link': return { textColor: `${LINK_SHAPE.DEFAULT_FILL_TEXT}`, textDecoration: 'underline', fontSize: FONT_SIZE_VALUES.LINK, + textAlignment: `${BASIC_SHAPE.DEFAULT_TEXT_ALIGNMENT}`, }; case 'normaltext': return { @@ -157,6 +161,7 @@ export const generateDefaultOtherProps = ( fontStyle: `${INPUT_SHAPE.DEFAULT_FONT_STYLE}`, textDecoration: `${INPUT_SHAPE.DEFAULT_TEXT_DECORATION}`, fontSize: FONT_SIZE_VALUES.NORMALTEXT, + textAlignment: `${BASIC_SHAPE.DEFAULT_TEXT_ALIGNMENT}`, }; case 'smalltext': return { @@ -165,10 +170,12 @@ export const generateDefaultOtherProps = ( fontStyle: `${INPUT_SHAPE.DEFAULT_FONT_STYLE}`, textDecoration: `${INPUT_SHAPE.DEFAULT_TEXT_DECORATION}`, fontSize: FONT_SIZE_VALUES.SMALLTEXT, + textAlignment: `${BASIC_SHAPE.DEFAULT_TEXT_ALIGNMENT}`, }; case 'paragraph': return { fontSize: FONT_SIZE_VALUES.PARAGRAPH, + textAlignment: `${BASIC_SHAPE.DEFAULT_TEXT_ALIGNMENT}`, }; case 'label': return { diff --git a/src/pods/properties/components/icon-selector/modal/icon-modal.module.css b/src/pods/properties/components/icon-selector/modal/icon-modal.module.css index fca99e9c..620d0236 100644 --- a/src/pods/properties/components/icon-selector/modal/icon-modal.module.css +++ b/src/pods/properties/components/icon-selector/modal/icon-modal.module.css @@ -1,6 +1,5 @@ .container { background-color: var(--primary-700); - width: 70vw; height: auto; display: flex; flex-direction: column; diff --git a/src/pods/properties/components/text-alignment/index.ts b/src/pods/properties/components/text-alignment/index.ts new file mode 100644 index 00000000..e292c99a --- /dev/null +++ b/src/pods/properties/components/text-alignment/index.ts @@ -0,0 +1 @@ +export * from './text-alignment'; diff --git a/src/pods/properties/components/text-alignment/text-alignment.module.css b/src/pods/properties/components/text-alignment/text-alignment.module.css new file mode 100644 index 00000000..4e0a8ade --- /dev/null +++ b/src/pods/properties/components/text-alignment/text-alignment.module.css @@ -0,0 +1,39 @@ +.container { + display: flex; + align-items: center; + gap: 1.5em; + padding: var(--space-xs) var(--space-md); + border-bottom: 1px solid var(--primary-300); +} + +.buttonsContainer { + display: flex; + gap: 1em; + align-items: center; + margin-left: auto; +} + +.button { + border: none; + color: var(--text-color); + background-color: inherit; + width: auto; + min-width: 30px; + border-radius: 10px; + font-size: var(--fs-xs); + display: flex; + align-items: center; + justify-content: center; + transition: all 0.3s ease-in-out; + cursor: pointer; + box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); +} + +.button:hover { + background-color: var(--primary-100); +} + +.active { + background-color: var(--primary-200); + box-shadow: inset 0 2px 5px rgba(0, 0, 0, 0.2); +} diff --git a/src/pods/properties/components/text-alignment/text-alignment.tsx b/src/pods/properties/components/text-alignment/text-alignment.tsx new file mode 100644 index 00000000..a18860be --- /dev/null +++ b/src/pods/properties/components/text-alignment/text-alignment.tsx @@ -0,0 +1,70 @@ +import classes from './text-alignment.module.css'; + +interface Props { + textAlignment: 'left' | 'center' | 'right' | undefined; + label: string; + onChange: (textAlignment: 'left' | 'center' | 'right') => void; +} + +export const TextAlignment: React.FC = props => { + const { label, textAlignment, onChange } = props; + + return ( +
+

{label}

+
+ + + +
+
+ ); +}; diff --git a/src/pods/properties/properties.pod.tsx b/src/pods/properties/properties.pod.tsx index 452577cd..65402ae7 100644 --- a/src/pods/properties/properties.pod.tsx +++ b/src/pods/properties/properties.pod.tsx @@ -13,6 +13,7 @@ import { FontStyle } from './components/font-style'; import { FontVariant } from './components/font-variant/font-variant'; import { TextDecoration } from './components/text-decoration/text-decoration'; import { FontSize } from './components/font-size'; +import { TextAlignment } from './components/text-alignment'; export const PropertiesPod = () => { const { selectionInfo } = useCanvasContext(); @@ -139,6 +140,15 @@ export const PropertiesPod = () => { } /> )} + {selectedShapeData?.otherProps?.textAlignment && ( + + updateOtherPropsOnSelected('textAlignment', textAlignment) + } + /> + )} {selectedShapeData?.otherProps?.fontStyle && (