@cuemath/leap 2.8.49 → 2.8.50-as1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/line-icons/icons/clear-all.js +53 -0
- package/dist/assets/line-icons/icons/clear-all.js.map +1 -0
- package/dist/assets/line-icons/icons/download.js +48 -0
- package/dist/assets/line-icons/icons/download.js.map +1 -0
- package/dist/assets/line-icons/icons/equation.js +48 -0
- package/dist/assets/line-icons/icons/equation.js.map +1 -0
- package/dist/assets/line-icons/icons/grid-icon.js +42 -0
- package/dist/assets/line-icons/icons/grid-icon.js.map +1 -0
- package/dist/assets/line-icons/icons/pan.js +98 -0
- package/dist/assets/line-icons/icons/pan.js.map +1 -0
- package/dist/assets/line-icons/icons/square-checked-grid.js +25 -0
- package/dist/assets/line-icons/icons/square-checked-grid.js.map +1 -0
- package/dist/assets/line-icons/icons/square-dots.js +32 -0
- package/dist/assets/line-icons/icons/square-dots.js.map +1 -0
- package/dist/assets/line-icons/icons/square-grid.js +17 -0
- package/dist/assets/line-icons/icons/square-grid.js.map +1 -0
- package/dist/assets/line-icons/icons/square2-grid.js +13 -0
- package/dist/assets/line-icons/icons/square2-grid.js.map +1 -0
- package/dist/assets/line-icons/icons/text-icon.js +48 -0
- package/dist/assets/line-icons/icons/text-icon.js.map +1 -0
- package/dist/assets/line-icons/icons/tri-dots.js +27 -0
- package/dist/assets/line-icons/icons/tri-dots.js.map +1 -0
- package/dist/assets/line-icons/icons/tri-grid.js +27 -0
- package/dist/assets/line-icons/icons/tri-grid.js.map +1 -0
- package/dist/assets/line-icons/icons/tri2-dots.js +27 -0
- package/dist/assets/line-icons/icons/tri2-dots.js.map +1 -0
- package/dist/assets/line-icons/icons/tri2-grid.js +27 -0
- package/dist/assets/line-icons/icons/tri2-grid.js.map +1 -0
- package/dist/assets/line-icons/icons/upload.js +48 -0
- package/dist/assets/line-icons/icons/upload.js.map +1 -0
- package/dist/assets/line-icons/icons/zoom-in.js +58 -0
- package/dist/assets/line-icons/icons/zoom-in.js.map +1 -0
- package/dist/assets/line-icons/icons/zoom-out.js +48 -0
- package/dist/assets/line-icons/icons/zoom-out.js.map +1 -0
- package/dist/features/cue-canvas/cue-canvas-core.js +169 -59
- package/dist/features/cue-canvas/cue-canvas-core.js.map +1 -1
- package/dist/features/cue-canvas/cue-canvas-helpers.js +91 -29
- package/dist/features/cue-canvas/cue-canvas-helpers.js.map +1 -1
- package/dist/features/cue-canvas/cue-canvas.js +57 -49
- package/dist/features/cue-canvas/cue-canvas.js.map +1 -1
- package/dist/features/cue-canvas/cue-cavas-styled.js +96 -59
- package/dist/features/cue-canvas/cue-cavas-styled.js.map +1 -1
- package/dist/features/cue-canvas/hooks/use-tool-state.js +34 -0
- package/dist/features/cue-canvas/hooks/use-tool-state.js.map +1 -0
- package/dist/features/cue-canvas/toolbar/color-pallete.js +21 -21
- package/dist/features/cue-canvas/toolbar/color-pallete.js.map +1 -1
- package/dist/features/cue-canvas/toolbar/color-picker-button.js +62 -0
- package/dist/features/cue-canvas/toolbar/color-picker-button.js.map +1 -0
- package/dist/features/cue-canvas/toolbar/grid-menu.js +57 -0
- package/dist/features/cue-canvas/toolbar/grid-menu.js.map +1 -0
- package/dist/features/cue-canvas/toolbar/icon-map.js +58 -0
- package/dist/features/cue-canvas/toolbar/icon-map.js.map +1 -0
- package/dist/features/cue-canvas/toolbar/pen-tool-menu.js +65 -0
- package/dist/features/cue-canvas/toolbar/pen-tool-menu.js.map +1 -0
- package/dist/features/cue-canvas/toolbar/tool-buttons.js +21 -0
- package/dist/features/cue-canvas/toolbar/tool-buttons.js.map +1 -0
- package/dist/features/cue-canvas/toolbar/toolbar.js +28 -85
- package/dist/features/cue-canvas/toolbar/toolbar.js.map +1 -1
- package/dist/features/cue-canvas/toolbar/whiteboard-toolbar.js +25 -0
- package/dist/features/cue-canvas/toolbar/whiteboard-toolbar.js.map +1 -0
- package/dist/features/trial-session/comps/session-report/session-report.js +41 -41
- package/dist/features/trial-session/comps/session-report/session-report.js.map +1 -1
- package/dist/features/worksheet/worksheet/worksheet-action-bar/worksheet-action-bar.js +7 -7
- package/dist/features/worksheet/worksheet/worksheet-action-bar/worksheet-action-bar.js.map +1 -1
- package/dist/index.d.ts +13 -1
- package/dist/static/fonts/Athletics-Black.woff +0 -0
- package/dist/static/fonts/Athletics-Bold.woff +0 -0
- package/dist/static/fonts/Athletics-Light.woff +0 -0
- package/dist/static/fonts/Athletics-Medium.woff +0 -0
- package/dist/static/fonts/Athletics-Regular.woff +0 -0
- package/dist/static/fonts/untitled-sans-medium.woff +0 -0
- package/dist/static/fonts/untitled-sans-medium.woff2 +0 -0
- package/dist/static/fonts/untitled-sans-regular.woff +0 -0
- package/dist/static/fonts/untitled-sans-regular.woff2 +0 -0
- package/package.json +2 -2
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"cue-cavas-styled.js","sources":["../../../src/features/cue-canvas/cue-cavas-styled.tsx"],"sourcesContent":["import type { ICueCanvasWrappper, TCueCanvasColors } from './types/cue-canvas';\n\nimport styled, { css } from 'styled-components';\n\nimport TickIcon from '../../assets/line-icons/icons/check';\nimport HighlighterIcon from '../../assets/line-icons/icons/highlighter';\nimport PencilIcon from '../../assets/line-icons/icons/pencil';\nimport RulerIcon from '../../assets/line-icons/icons/ruler';\nimport SketchIcon from '../../assets/line-icons/icons/sketch';\nimport FlexView from '../ui/layout/flex-view';\nimport { CANVAS_COLORS } from './constants/constants';\n\ninterface IToolProps {\n $active: boolean;\n $activeColor: TCueCanvasColors;\n}\n\nexport const StyledPencilIcon = styled(PencilIcon)<IToolProps>(({\n theme,\n $active,\n $activeColor,\n}) => {\n const { colors } = theme;\n const color = $active ? CANVAS_COLORS[$activeColor] : colors.REAL_BLACK_50;\n\n return css`\n position: relative;\n transition: top 0.3s ease-in-out;\n top: ${$active ? '0px' : '8px'};\n cursor: ${$active ? 'auto' : 'pointer'};\n .pencil-dark-shade {\n fill: ${$active ? color : colors.GREY_3};\n }\n\n .pencil-light-shade {\n fill: ${$active ? color : colors.GREY_2};\n opacity: ${$active ? 0.3 : 1};\n }\n\n ${!$active &&\n css`\n &:hover {\n .pencil-dark-shade {\n fill: ${colors.GREY_4};\n }\n .pencil-light-shade {\n fill: ${colors.GREY_2};\n }\n }\n `}\n `;\n});\n\nexport const StyledRulerIcon = styled(RulerIcon)<IToolProps>(({ theme, $active, $activeColor }) => {\n const { colors } = theme;\n const color = $active ? CANVAS_COLORS[$activeColor] : colors.REAL_BLACK_50;\n\n return css`\n cursor: ${$active ? 'auto' : 'pointer'};\n position: relative;\n transition: top 0.3s ease-in-out;\n top: ${$active ? '0px' : '8px'};\n\n .ruler-rect-color {\n fill: ${$active ? color : colors.GREY_3};\n }\n\n .ruler-stripe-base {\n fill: ${$active ? color : colors.GREY_2};\n opacity: ${$active ? 0.2 : 1};\n }\n\n .ruler-small-stripe {\n fill: ${colors.REAL_BLACK};\n }\n\n ${!$active &&\n css`\n &:hover {\n .ruler-rect-color {\n fill: ${colors.GREY_4};\n }\n .ruler-stripe-base {\n fill: ${colors.GREY_3};\n }\n }\n `}\n `;\n});\n\nexport const StyledHighlighterWrapper = styled(HighlighterIcon)<IToolProps>(({\n $active,\n theme,\n $activeColor,\n}) => {\n const { colors } = theme;\n const color = $active ? CANVAS_COLORS[$activeColor] : colors.REAL_BLACK_50;\n\n return css`\n cursor: ${$active ? 'auto' : 'pointer'};\n position: relative;\n transition: top 0.3s ease-in-out;\n top: ${$active ? '0px' : '8px'};\n ${!$active &&\n css`\n &:hover {\n .highlighter-tip {\n fill: ${theme.colors.BLACK};\n }\n\n .highlighter-stripe {\n fill: ${theme.colors.BLACK_50};\n }\n\n .highlighter-light-body {\n fill: ${theme.colors.BLACK_10};\n }\n }\n `}\n\n ${$active &&\n css`\n .highlighter-tip {\n fill: ${color};\n }\n\n .highlighter-stripe {\n fill: ${color};\n opacity: 0.6;\n }\n\n .highlighter-light-body {\n fill: ${color};\n opacity: 0.2;\n }\n `}\n `;\n});\n\nexport const StyledSketchWrapper = styled(SketchIcon)<IToolProps>(({\n $active,\n theme,\n $activeColor,\n}) => {\n const { colors } = theme;\n const color = $active ? CANVAS_COLORS[$activeColor] : colors.REAL_BLACK_50;\n\n return css`\n cursor: ${$active ? 'auto' : 'pointer'};\n position: relative;\n transition: top 0.3s ease-in-out;\n top: ${$active ? '0px' : '8px'};\n\n ${!$active &&\n css`\n &:hover {\n .pen-tip {\n fill: ${theme.colors.BLACK};\n }\n\n .pen-dark-shade {\n fill: ${theme.colors.BLACK_50};\n }\n\n .pen-light-shade {\n fill: ${theme.colors.BLACK_10};\n }\n }\n `}\n\n ${$active &&\n css`\n cursor: ${$active ? 'auto' : 'pointer'};\n .pen-tip {\n fill: ${color};\n }\n\n .pen-dark-shade {\n fill: ${color};\n opacity: 0.6;\n }\n\n .pen-light-shade {\n fill: ${color};\n opacity: 0.4;\n }\n `}\n `;\n});\n\nexport const StyledWrapper = styled(FlexView)<Omit<IToolProps, '$activeColor'>>(({\n theme,\n $active,\n}) => {\n const { colors } = theme;\n\n return css`\n cursor: ${$active ? 'auto' : 'pointer'};\n width: 32px;\n height: 32px;\n justify-content: center;\n align-items: center;\n\n border: 1px solid ${colors.WHITE};\n border-radius: 50%;\n transition: all 100ms ease-in-out;\n\n &:hover {\n border: 1px solid ${colors.REAL_BLACK};\n }\n ${!$active &&\n css`\n &:hover {\n border: 1px solid ${colors.REAL_BLACK};\n }\n `}\n\n ${$active &&\n css`\n cursor: auto;\n background: ${colors.BLACK};\n svg {\n path,\n circle {\n stroke: ${colors.WHITE};\n }\n .hover-tiles {\n stroke: ${colors.WHITE};\n }\n .hover-eraser {\n stroke: none;\n fill: ${colors.WHITE};\n }\n }\n `}\n `;\n});\n\nexport const StyledCheckIcon = styled(TickIcon)`\n path {\n stroke: ${'white'};\n }\n`;\n\nexport const PalleteWrapper = styled(FlexView)`\n position: absolute;\n display: flex;\n justify-content: center;\n top: -24px; //-16 for icon, -8 for gap\n transition:\n opacity 0.5s ease,\n transform 0.5s ease;\n`;\n\nexport const CueCanvasWrapper = styled(FlexView)<ICueCanvasWrappper>(\n ({ $canScribble, $canRender, $renderAs }) => `\n display: ${$canRender ? 'block' : 'none'};\n opacity: ${$canScribble ? 1 : 0.5};\n pointer-events: ${$canScribble ? 'auto' : 'none'};\n\n ${\n $renderAs === 'canvas' &&\n $canScribble &&\n `\n background-image: radial-gradient(rgb(43 43 43 / 8%) 2px, transparent 10%);\n background-position:0 0,32px 32px;\n background-size: 30px 32px;\n `\n }\n \n`,\n);\n\nexport const ColorPicker = styled(FlexView)<{ $color: TCueCanvasColors }>(\n ({ $color }) => `\nbackground: ${CANVAS_COLORS[$color]};\n`,\n);\n"],"names":["StyledPencilIcon","styled","PencilIcon","theme","$active","$activeColor","colors","color","CANVAS_COLORS","css","StyledRulerIcon","RulerIcon","StyledHighlighterWrapper","HighlighterIcon","StyledSketchWrapper","SketchIcon","StyledWrapper","FlexView","StyledCheckIcon","TickIcon","PalleteWrapper","CueCanvasWrapper","$canScribble","$canRender","$renderAs","ColorPicker","$color"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"cue-cavas-styled.js","sources":["../../../src/features/cue-canvas/cue-cavas-styled.tsx"],"sourcesContent":["import type { ICueCanvasWrappper, TCueCanvasColors } from './types/cue-canvas';\n\nimport styled, { css } from 'styled-components';\n\nimport TickIcon from '../../assets/line-icons/icons/check';\nimport DownIcon from '../../assets/line-icons/icons/down';\nimport HighlighterIcon from '../../assets/line-icons/icons/highlighter';\nimport PencilIcon from '../../assets/line-icons/icons/pencil';\nimport RulerIcon from '../../assets/line-icons/icons/ruler';\nimport SketchIcon from '../../assets/line-icons/icons/sketch';\nimport UndoIcon from '../../assets/line-icons/icons/undo';\nimport FlexView from '../ui/layout/flex-view';\nimport { CANVAS_COLORS } from './constants/constants';\n\ninterface IToolProps {\n $active: boolean;\n $activeColor: TCueCanvasColors;\n $isWhiteBoard: boolean;\n}\n\nexport const StyledPencilIcon = styled(PencilIcon)<IToolProps>(({\n theme,\n $active,\n $activeColor,\n $isWhiteBoard,\n}) => {\n const { colors } = theme;\n const color = $active ? CANVAS_COLORS[$activeColor] : colors.REAL_BLACK_50;\n\n return css`\n position: relative;\n transition: top 0.3s ease-in-out;\n top: ${$active && !$isWhiteBoard ? '0px' : '8px'};\n cursor: ${$active ? 'auto' : 'pointer'};\n .pencil-dark-shade {\n fill: ${$active ? color : colors.GREY_3};\n }\n\n .pencil-light-shade {\n fill: ${$active ? color : colors.GREY_2};\n opacity: ${$active ? 0.3 : 1};\n }\n\n ${!$active &&\n css`\n &:hover {\n .pencil-dark-shade {\n fill: ${colors.GREY_4};\n }\n .pencil-light-shade {\n fill: ${colors.GREY_2};\n }\n }\n `}\n `;\n});\n\nexport const StyledRulerIcon = styled(RulerIcon)<IToolProps>(({\n theme,\n $active,\n $activeColor,\n $isWhiteBoard,\n}) => {\n const { colors } = theme;\n const color = $active ? CANVAS_COLORS[$activeColor] : colors.REAL_BLACK_50;\n\n return css`\n cursor: ${$active ? 'auto' : 'pointer'};\n position: relative;\n transition: top 0.3s ease-in-out;\n top: ${$active && !$isWhiteBoard ? '0px' : '8px'};\n\n .ruler-rect-color {\n fill: ${$active ? color : colors.GREY_3};\n }\n\n .ruler-stripe-base {\n fill: ${$active ? color : colors.GREY_2};\n opacity: ${$active ? 0.2 : 1};\n }\n\n .ruler-small-stripe {\n fill: ${colors.REAL_BLACK};\n }\n\n ${!$active &&\n css`\n &:hover {\n .ruler-rect-color {\n fill: ${colors.GREY_4};\n }\n .ruler-stripe-base {\n fill: ${colors.GREY_3};\n }\n }\n `}\n `;\n});\n\nexport const StyledHighlighterWrapper = styled(HighlighterIcon)<IToolProps>(({\n $active,\n theme,\n $activeColor,\n $isWhiteBoard,\n}) => {\n const { colors } = theme;\n const color = $active ? CANVAS_COLORS[$activeColor] : colors.REAL_BLACK_50;\n\n return css`\n cursor: ${$active ? 'auto' : 'pointer'};\n position: relative;\n transition: top 0.3s ease-in-out;\n top: ${$active && !$isWhiteBoard ? '0px' : '8px'};\n ${!$active &&\n css`\n &:hover {\n .highlighter-tip {\n fill: ${theme.colors.BLACK};\n }\n\n .highlighter-stripe {\n fill: ${theme.colors.BLACK_50};\n }\n\n .highlighter-light-body {\n fill: ${theme.colors.BLACK_10};\n }\n }\n `}\n\n ${$active &&\n css`\n .highlighter-tip {\n fill: ${color};\n }\n\n .highlighter-stripe {\n fill: ${color};\n opacity: 0.6;\n }\n\n .highlighter-light-body {\n fill: ${color};\n opacity: 0.2;\n }\n `}\n `;\n});\n\nexport const StyledSketchWrapper = styled(SketchIcon)<IToolProps>(({\n $active,\n theme,\n $activeColor,\n $isWhiteBoard,\n}) => {\n const { colors } = theme;\n const color = $active ? CANVAS_COLORS[$activeColor] : colors.REAL_BLACK_50;\n\n return css`\n cursor: ${$active ? 'auto' : 'pointer'};\n position: relative;\n transition: top 0.3s ease-in-out;\n top: ${$active && !$isWhiteBoard ? '0px' : '8px'};\n\n ${!$active &&\n css`\n &:hover {\n .pen-tip {\n fill: ${theme.colors.BLACK};\n }\n\n .pen-dark-shade {\n fill: ${theme.colors.BLACK_50};\n }\n\n .pen-light-shade {\n fill: ${theme.colors.BLACK_10};\n }\n }\n `}\n\n ${$active &&\n css`\n cursor: ${$active ? 'auto' : 'pointer'};\n .pen-tip {\n fill: ${color};\n }\n\n .pen-dark-shade {\n fill: ${color};\n opacity: 0.6;\n }\n\n .pen-light-shade {\n fill: ${color};\n opacity: 0.4;\n }\n `}\n `;\n});\n\nexport const StyledWrapper = styled(FlexView)<Omit<IToolProps, '$activeColor' | '$isWhiteBoard'>>(({\n theme,\n $active,\n}) => {\n const { colors } = theme;\n\n return css`\n cursor: ${$active ? 'auto' : 'pointer'};\n width: 32px;\n height: 32px;\n justify-content: center;\n align-items: center;\n\n border: 1px solid ${colors.WHITE};\n border-radius: 50%;\n transition: all 100ms ease-in-out;\n\n &:hover {\n border: 1px solid ${colors.REAL_BLACK};\n }\n ${!$active &&\n css`\n &:hover {\n border: 1px solid ${colors.REAL_BLACK};\n }\n `}\n\n ${$active &&\n css`\n cursor: auto;\n background: ${colors.BLACK};\n svg {\n path,\n circle {\n stroke: ${colors.WHITE};\n }\n .hover-tiles {\n stroke: ${colors.WHITE};\n }\n .hover-eraser {\n stroke: none;\n fill: ${colors.WHITE};\n }\n }\n `}\n `;\n});\n\nexport const StyledCheckIcon = styled(TickIcon)`\n path {\n stroke: ${'white'};\n }\n`;\n\nexport const RedoIcon = styled(UndoIcon)`\n transform: scaleX(-1);\n`;\n\nexport const PalleteWrapper = styled(FlexView)`\n position: absolute;\n display: flex;\n justify-content: center;\n top: -24px; //-16 for icon, -8 for gap\n transition:\n opacity 0.5s ease,\n transform 0.5s ease;\n`;\n\nexport const CueCanvasWrapper = styled(FlexView)<ICueCanvasWrappper>(\n ({ $canScribble, $canRender, $renderAs }) => `\n display: ${$canRender ? 'block' : 'none'};\n opacity: ${$canScribble ? 1 : 0.5};\n pointer-events: ${$canScribble ? 'auto' : 'none'};\n\n ${\n $renderAs === 'canvas' &&\n $canScribble &&\n `\n background-image: radial-gradient(rgb(43 43 43 / 8%) 2px, transparent 10%);\n background-position:0 0,32px 32px;\n background-size: 30px 32px;\n `\n }\n \n`,\n);\n\nexport const ColorPicker = styled(FlexView)<{ $color: TCueCanvasColors }>(\n ({ $color }) => `\nbackground: ${CANVAS_COLORS[$color]};\n`,\n);\n\nexport const StyledDownIcon = styled(DownIcon)<{ $isAnimating: boolean }>`\n pointer-events: none;\n transition: transform 0.5s ease;\n transform: ${({ $isAnimating }) => ($isAnimating ? 'rotate(180deg)' : 'rotate(0deg)')};\n`;\n\nexport const PenIconWrapper = styled(FlexView)`\n overflow: hidden;\n border-right: 1px solid ${({ theme }) => theme.colors.GREY_1};\n`;\n\nexport const MenuWrapper = styled(FlexView)`\n position: absolute;\n padding: 8px 8px 0 8px;\n overflow: hidden;\n bottom: 58px;\n border-top-left-radius: 8px;\n border-top-right-radius: 8px;\n transition:\n opacity 0.5s ease,\n transform 0.5s ease;\n\n :hover {\n cursor: pointer;\n }\n`;\n"],"names":["StyledPencilIcon","styled","PencilIcon","theme","$active","$activeColor","$isWhiteBoard","colors","color","CANVAS_COLORS","css","StyledRulerIcon","RulerIcon","StyledHighlighterWrapper","HighlighterIcon","StyledSketchWrapper","SketchIcon","StyledWrapper","FlexView","StyledCheckIcon","TickIcon","RedoIcon","UndoIcon","PalleteWrapper","CueCanvasWrapper","$canScribble","$canRender","$renderAs","ColorPicker","$color","StyledDownIcon","DownIcon","$isAnimating","PenIconWrapper","MenuWrapper"],"mappings":";;;;;;;;;;AAoBO,MAAMA,IAAmBC,EAAOC,CAAU,EAAc,CAAC;AAAA,EAC9D,OAAAC;AAAA,EACA,SAAAC;AAAA,EACA,cAAAC;AAAA,EACA,eAAAC;AACF,MAAM;AACE,QAAA,EAAE,QAAAC,EAAW,IAAAJ,GACbK,IAAQJ,IAAUK,EAAcJ,CAAY,IAAIE,EAAO;AAEtD,SAAAG;AAAA;AAAA;AAAA,WAGEN,KAAW,CAACE,IAAgB,QAAQ,KAAK;AAAA,cACtCF,IAAU,SAAS,SAAS;AAAA;AAAA,cAE5BA,IAAUI,IAAQD,EAAO,MAAM;AAAA;AAAA;AAAA;AAAA,cAI/BH,IAAUI,IAAQD,EAAO,MAAM;AAAA,iBAC5BH,IAAU,MAAM,CAAC;AAAA;AAAA;AAAA,MAG5B,CAACA,KACHM;AAAA;AAAA;AAAA,kBAGcH,EAAO,MAAM;AAAA;AAAA;AAAA,kBAGbA,EAAO,MAAM;AAAA;AAAA;AAAA,KAG1B;AAAA;AAEL,CAAC,GAEYI,IAAkBV,EAAOW,CAAS,EAAc,CAAC;AAAA,EAC5D,OAAAT;AAAA,EACA,SAAAC;AAAA,EACA,cAAAC;AAAA,EACA,eAAAC;AACF,MAAM;AACE,QAAA,EAAE,QAAAC,EAAW,IAAAJ,GACbK,IAAQJ,IAAUK,EAAcJ,CAAY,IAAIE,EAAO;AAEtD,SAAAG;AAAA,cACKN,IAAU,SAAS,SAAS;AAAA;AAAA;AAAA,WAG/BA,KAAW,CAACE,IAAgB,QAAQ,KAAK;AAAA;AAAA;AAAA,cAGtCF,IAAUI,IAAQD,EAAO,MAAM;AAAA;AAAA;AAAA;AAAA,cAI/BH,IAAUI,IAAQD,EAAO,MAAM;AAAA,iBAC5BH,IAAU,MAAM,CAAC;AAAA;AAAA;AAAA;AAAA,cAIpBG,EAAO,UAAU;AAAA;AAAA;AAAA,MAGzB,CAACH,KACHM;AAAA;AAAA;AAAA,kBAGcH,EAAO,MAAM;AAAA;AAAA;AAAA,kBAGbA,EAAO,MAAM;AAAA;AAAA;AAAA,KAG1B;AAAA;AAEL,CAAC,GAEYM,IAA2BZ,EAAOa,CAAe,EAAc,CAAC;AAAA,EAC3E,SAAAV;AAAA,EACA,OAAAD;AAAA,EACA,cAAAE;AAAA,EACA,eAAAC;AACF,MAAM;AACE,QAAA,EAAE,QAAAC,EAAW,IAAAJ,GACbK,IAAQJ,IAAUK,EAAcJ,CAAY,IAAIE,EAAO;AAEtD,SAAAG;AAAA,cACKN,IAAU,SAAS,SAAS;AAAA;AAAA;AAAA,WAG/BA,KAAW,CAACE,IAAgB,QAAQ,KAAK;AAAA,MAC9C,CAACF,KACHM;AAAA;AAAA;AAAA,kBAGcP,EAAM,OAAO,KAAK;AAAA;AAAA;AAAA;AAAA,kBAIlBA,EAAM,OAAO,QAAQ;AAAA;AAAA;AAAA;AAAA,kBAIrBA,EAAM,OAAO,QAAQ;AAAA;AAAA;AAAA,KAGlC;AAAA;AAAA,MAECC,KACFM;AAAA;AAAA,gBAEYF,CAAK;AAAA;AAAA;AAAA;AAAA,gBAILA,CAAK;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKLA,CAAK;AAAA;AAAA;AAAA,KAGhB;AAAA;AAEL,CAAC,GAEYO,IAAsBd,EAAOe,CAAU,EAAc,CAAC;AAAA,EACjE,SAAAZ;AAAA,EACA,OAAAD;AAAA,EACA,cAAAE;AAAA,EACA,eAAAC;AACF,MAAM;AACE,QAAA,EAAE,QAAAC,EAAW,IAAAJ,GACbK,IAAQJ,IAAUK,EAAcJ,CAAY,IAAIE,EAAO;AAEtD,SAAAG;AAAA,cACKN,IAAU,SAAS,SAAS;AAAA;AAAA;AAAA,WAG/BA,KAAW,CAACE,IAAgB,QAAQ,KAAK;AAAA;AAAA,MAE9C,CAACF,KACHM;AAAA;AAAA;AAAA,kBAGcP,EAAM,OAAO,KAAK;AAAA;AAAA;AAAA;AAAA,kBAIlBA,EAAM,OAAO,QAAQ;AAAA;AAAA;AAAA;AAAA,kBAIrBA,EAAM,OAAO,QAAQ;AAAA;AAAA;AAAA,KAGlC;AAAA;AAAA,MAECC,KACFM;AAAA,gBACYN,IAAU,SAAS,SAAS;AAAA;AAAA,gBAE5BI,CAAK;AAAA;AAAA;AAAA;AAAA,gBAILA,CAAK;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKLA,CAAK;AAAA;AAAA;AAAA,KAGhB;AAAA;AAEL,CAAC,GAEYS,IAAgBhB,EAAOiB,CAAQ,EAAsD,CAAC;AAAA,EACjG,OAAAf;AAAA,EACA,SAAAC;AACF,MAAM;AACE,QAAA,EAAE,QAAAG,EAAW,IAAAJ;AAEZ,SAAAO;AAAA,cACKN,IAAU,SAAS,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAMlBG,EAAO,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA,0BAKVA,EAAO,UAAU;AAAA;AAAA,MAErC,CAACH,KACHM;AAAA;AAAA,4BAEwBH,EAAO,UAAU;AAAA;AAAA,KAExC;AAAA;AAAA,MAECH,KACFM;AAAA;AAAA,oBAEgBH,EAAO,KAAK;AAAA;AAAA;AAAA;AAAA,oBAIZA,EAAO,KAAK;AAAA;AAAA;AAAA,oBAGZA,EAAO,KAAK;AAAA;AAAA;AAAA;AAAA,kBAIdA,EAAO,KAAK;AAAA;AAAA;AAAA,KAGzB;AAAA;AAEL,CAAC,GAEYY,IAAkBlB,EAAOmB,CAAQ;AAAA;AAAA,cAEhC,OAAO;AAAA;AAAA,GAIRC,IAAWpB,EAAOqB,CAAQ;AAAA;AAAA,GAI1BC,IAAiBtB,EAAOiB,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAUhCM,IAAmBvB,EAAOiB,CAAQ;AAAA,EAC7C,CAAC,EAAE,cAAAO,GAAc,YAAAC,GAAY,WAAAC,EAAgB,MAAA;AAAA,aAClCD,IAAa,UAAU,MAAM;AAAA,aAC7BD,IAAe,IAAI,GAAG;AAAA,oBACfA,IAAe,SAAS,MAAM;AAAA;AAAA,IAG9CE,MAAc,YACdF,KACA;AAAA;AAAA;AAAA;AAAA,KAKF;AAAA;AAAA;AAGF,GAEaG,IAAc3B,EAAOiB,CAAQ;AAAA,EACxC,CAAC,EAAE,QAAAW,EAAA,MAAa;AAAA,cACJpB,EAAcoB,CAAM,CAAC;AAAA;AAEnC,GAEaC,IAAiB7B,EAAO8B,CAAQ;AAAA;AAAA;AAAA,eAG9B,CAAC,EAAE,cAAAC,EAAA,MAAoBA,IAAe,mBAAmB,cAAe;AAAA,GAG1EC,IAAiBhC,EAAOiB,CAAQ;AAAA;AAAA,4BAEjB,CAAC,EAAE,OAAAf,EAAA,MAAYA,EAAM,OAAO,MAAM;AAAA,GAGjD+B,IAAcjC,EAAOiB,CAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
import { useEffect as l, useCallback as s } from "react";
|
2
|
+
import { CANVAS_COLORS as m } from "../constants/constants.js";
|
3
|
+
import { SINGLE_CLICK_TOOLS as n } from "../cue-canvas-helpers.js";
|
4
|
+
import { useCueCanvasActions as T } from "./use-cue-canvas-actions.js";
|
5
|
+
const A = () => {
|
6
|
+
const {
|
7
|
+
activeInstance: o,
|
8
|
+
activeTool: i,
|
9
|
+
setActiveTool: e,
|
10
|
+
activeColor: r
|
11
|
+
} = T();
|
12
|
+
l(() => {
|
13
|
+
o && (r && o.setColor(m[r]), i && (o == null || o.setTool(i)));
|
14
|
+
}, [r, i, o]);
|
15
|
+
const c = s(
|
16
|
+
(t) => {
|
17
|
+
o == null || o.setTool(t), n.has(t) || e(t);
|
18
|
+
},
|
19
|
+
[o, e]
|
20
|
+
), f = s(
|
21
|
+
(t) => {
|
22
|
+
o == null || o.changeGrid(t);
|
23
|
+
},
|
24
|
+
[o]
|
25
|
+
);
|
26
|
+
return {
|
27
|
+
onToolClick: c,
|
28
|
+
onGridOptionClick: f
|
29
|
+
};
|
30
|
+
};
|
31
|
+
export {
|
32
|
+
A as useToolState
|
33
|
+
};
|
34
|
+
//# sourceMappingURL=use-tool-state.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"use-tool-state.js","sources":["../../../../src/features/cue-canvas/hooks/use-tool-state.ts"],"sourcesContent":["import type { TCueCanvasGridName, TCueCanvasTool } from '../types/cue-canvas';\n\nimport { useCallback, useEffect } from 'react';\n\nimport { CANVAS_COLORS } from '../constants/constants';\nimport { SINGLE_CLICK_TOOLS } from '../cue-canvas-helpers';\nimport { useCueCanvasActions } from './use-cue-canvas-actions';\n\nexport const useToolState = () => {\n const {\n activeInstance: cueCanvas,\n activeTool,\n setActiveTool,\n activeColor,\n } = useCueCanvasActions();\n\n useEffect(() => {\n if (cueCanvas) {\n if (activeColor) {\n cueCanvas.setColor(CANVAS_COLORS[activeColor]);\n }\n\n if (activeTool) {\n cueCanvas?.setTool(activeTool);\n }\n }\n }, [activeColor, activeTool, cueCanvas]);\n\n const onToolClick = useCallback(\n (tool: TCueCanvasTool) => {\n cueCanvas?.setTool(tool);\n\n if (!SINGLE_CLICK_TOOLS.has(tool)) {\n setActiveTool(tool);\n }\n },\n [cueCanvas, setActiveTool],\n );\n\n const onGridOptionClick = useCallback(\n (gridOption: TCueCanvasGridName) => {\n cueCanvas?.changeGrid(gridOption);\n },\n [cueCanvas],\n );\n\n return {\n onToolClick,\n onGridOptionClick,\n };\n};\n"],"names":["useToolState","cueCanvas","activeTool","setActiveTool","activeColor","useCueCanvasActions","useEffect","CANVAS_COLORS","onToolClick","useCallback","tool","SINGLE_CLICK_TOOLS","onGridOptionClick","gridOption"],"mappings":";;;;AAQO,MAAMA,IAAe,MAAM;AAC1B,QAAA;AAAA,IACJ,gBAAgBC;AAAA,IAChB,YAAAC;AAAA,IACA,eAAAC;AAAA,IACA,aAAAC;AAAA,MACEC,EAAoB;AAExB,EAAAC,EAAU,MAAM;AACd,IAAIL,MACEG,KACQH,EAAA,SAASM,EAAcH,CAAW,CAAC,GAG3CF,MACFD,KAAA,QAAAA,EAAW,QAAQC;AAAA,EAGtB,GAAA,CAACE,GAAaF,GAAYD,CAAS,CAAC;AAEvC,QAAMO,IAAcC;AAAA,IAClB,CAACC,MAAyB;AACxB,MAAAT,KAAA,QAAAA,EAAW,QAAQS,IAEdC,EAAmB,IAAID,CAAI,KAC9BP,EAAcO,CAAI;AAAA,IAEtB;AAAA,IACA,CAACT,GAAWE,CAAa;AAAA,EAAA,GAGrBS,IAAoBH;AAAA,IACxB,CAACI,MAAmC;AAClC,MAAAZ,KAAA,QAAAA,EAAW,WAAWY;AAAA,IACxB;AAAA,IACA,CAACZ,CAAS;AAAA,EAAA;AAGL,SAAA;AAAA,IACL,aAAAO;AAAA,IACA,mBAAAI;AAAA,EAAA;AAEJ;"}
|
@@ -1,32 +1,32 @@
|
|
1
|
-
import { jsx as r } from "react/jsx-runtime";
|
2
|
-
import { memo as
|
3
|
-
import
|
4
|
-
import
|
5
|
-
import { getColorsForUser as
|
6
|
-
import {
|
7
|
-
const
|
8
|
-
const
|
1
|
+
import { jsx as r, Fragment as a } from "react/jsx-runtime";
|
2
|
+
import { memo as c, useCallback as d, useMemo as s } from "react";
|
3
|
+
import h from "../../ui/buttons/clickable/clickable.js";
|
4
|
+
import $ from "../../ui/layout/flex-view.js";
|
5
|
+
import { getColorsForUser as C } from "../cue-canvas-helpers.js";
|
6
|
+
import { ColorPicker as f, StyledCheckIcon as g } from "../cue-cavas-styled.js";
|
7
|
+
const w = c(({ setActiveColor: t, activeColor: o, userType: n }) => {
|
8
|
+
const i = d(
|
9
9
|
(e) => {
|
10
|
-
|
10
|
+
t(e);
|
11
11
|
},
|
12
|
-
[
|
13
|
-
),
|
14
|
-
return /* @__PURE__ */ r(
|
15
|
-
|
12
|
+
[t]
|
13
|
+
), l = s(() => C(n), [n]);
|
14
|
+
return /* @__PURE__ */ r(a, { children: l.map((e, m) => /* @__PURE__ */ r(
|
15
|
+
h,
|
16
16
|
{
|
17
|
-
onClick: () =>
|
17
|
+
onClick: () => i(e),
|
18
18
|
label: `Color Picker - ${e}`,
|
19
19
|
children: /* @__PURE__ */ r(
|
20
|
-
|
20
|
+
$,
|
21
21
|
{
|
22
22
|
$width: 22,
|
23
23
|
$height: 22,
|
24
24
|
$borderRadius: 11,
|
25
25
|
$justifyContent: "center",
|
26
|
-
$background:
|
26
|
+
$background: o === e ? "BLACK" : "WHITE",
|
27
27
|
$alignItems: "center",
|
28
28
|
children: /* @__PURE__ */ r(
|
29
|
-
|
29
|
+
f,
|
30
30
|
{
|
31
31
|
$width: 20,
|
32
32
|
$height: 20,
|
@@ -34,16 +34,16 @@ const x = d(({ setActiveColor: o, activeColor: t, userType: i }) => {
|
|
34
34
|
$color: e,
|
35
35
|
$alignItems: "center",
|
36
36
|
$justifyContent: "center",
|
37
|
-
children:
|
37
|
+
children: o === e && /* @__PURE__ */ r(g, {})
|
38
38
|
}
|
39
39
|
)
|
40
40
|
}
|
41
41
|
)
|
42
42
|
},
|
43
|
-
|
44
|
-
)) })
|
43
|
+
m
|
44
|
+
)) });
|
45
45
|
});
|
46
46
|
export {
|
47
|
-
|
47
|
+
w as default
|
48
48
|
};
|
49
49
|
//# sourceMappingURL=color-pallete.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"color-pallete.js","sources":["../../../../src/features/cue-canvas/toolbar/color-pallete.tsx"],"sourcesContent":["import type { TUserTypes } from '../../ui/types';\nimport type { TCueCanvasColors } from '../types/cue-canvas';\n\nimport { memo, useCallback, useMemo } from 'react';\n\nimport Clickable from '../../ui/buttons/clickable/clickable';\nimport FlexView from '../../ui/layout/flex-view';\nimport { getColorsForUser } from '../cue-canvas-helpers';\nimport { StyledCheckIcon } from '../cue-cavas-styled';\nimport {
|
1
|
+
{"version":3,"file":"color-pallete.js","sources":["../../../../src/features/cue-canvas/toolbar/color-pallete.tsx"],"sourcesContent":["import type { TUserTypes } from '../../ui/types';\nimport type { TCueCanvasColors } from '../types/cue-canvas';\n\nimport { memo, useCallback, useMemo } from 'react';\n\nimport Clickable from '../../ui/buttons/clickable/clickable';\nimport FlexView from '../../ui/layout/flex-view';\nimport { getColorsForUser } from '../cue-canvas-helpers';\nimport { StyledCheckIcon } from '../cue-cavas-styled';\nimport { ColorPicker } from '../cue-cavas-styled';\n\ninterface IColorPallete {\n setActiveColor: (color: TCueCanvasColors) => void;\n activeColor: TCueCanvasColors;\n userType: TUserTypes;\n}\n\nconst ColorPallete: React.FC<IColorPallete> = memo(({ setActiveColor, activeColor, userType }) => {\n const handleColorChange = useCallback(\n (color: TCueCanvasColors) => {\n setActiveColor(color);\n },\n [setActiveColor],\n );\n const colors = useMemo(() => getColorsForUser(userType), [userType]);\n\n return (\n <>\n {colors.map((color, index) => (\n <Clickable\n key={index}\n onClick={() => handleColorChange(color)}\n label={`Color Picker - ${color}`}\n >\n <FlexView\n $width={22}\n $height={22}\n $borderRadius={11}\n $justifyContent=\"center\"\n $background={activeColor === color ? 'BLACK' : 'WHITE'}\n $alignItems=\"center\"\n >\n <ColorPicker\n $width={20}\n $height={20}\n $borderRadius={10}\n $color={color}\n $alignItems=\"center\"\n $justifyContent=\"center\"\n >\n {activeColor === color && <StyledCheckIcon />}\n </ColorPicker>\n </FlexView>\n </Clickable>\n ))}\n </>\n );\n});\n\nexport default ColorPallete;\n"],"names":["ColorPallete","memo","setActiveColor","activeColor","userType","handleColorChange","useCallback","color","colors","useMemo","getColorsForUser","jsx","Fragment","index","Clickable","FlexView","ColorPicker","StyledCheckIcon"],"mappings":";;;;;;AAiBA,MAAMA,IAAwCC,EAAK,CAAC,EAAE,gBAAAC,GAAgB,aAAAC,GAAa,UAAAC,QAAe;AAChG,QAAMC,IAAoBC;AAAA,IACxB,CAACC,MAA4B;AAC3B,MAAAL,EAAeK,CAAK;AAAA,IACtB;AAAA,IACA,CAACL,CAAc;AAAA,EAAA,GAEXM,IAASC,EAAQ,MAAMC,EAAiBN,CAAQ,GAAG,CAACA,CAAQ,CAAC;AAEnE,SAEK,gBAAAO,EAAAC,GAAA,EAAA,UAAAJ,EAAO,IAAI,CAACD,GAAOM,MAClB,gBAAAF;AAAA,IAACG;AAAA,IAAA;AAAA,MAEC,SAAS,MAAMT,EAAkBE,CAAK;AAAA,MACtC,OAAO,kBAAkBA,CAAK;AAAA,MAE9B,UAAA,gBAAAI;AAAA,QAACI;AAAA,QAAA;AAAA,UACC,QAAQ;AAAA,UACR,SAAS;AAAA,UACT,eAAe;AAAA,UACf,iBAAgB;AAAA,UAChB,aAAaZ,MAAgBI,IAAQ,UAAU;AAAA,UAC/C,aAAY;AAAA,UAEZ,UAAA,gBAAAI;AAAA,YAACK;AAAA,YAAA;AAAA,cACC,QAAQ;AAAA,cACR,SAAS;AAAA,cACT,eAAe;AAAA,cACf,QAAQT;AAAA,cACR,aAAY;AAAA,cACZ,iBAAgB;AAAA,cAEf,UAAAJ,MAAgBI,KAAS,gBAAAI,EAACM,GAAgB,CAAA,CAAA;AAAA,YAAA;AAAA,UAC7C;AAAA,QAAA;AAAA,MACF;AAAA,IAAA;AAAA,IAtBKJ;AAAA,EAwBR,CAAA,EACH,CAAA;AAEJ,CAAC;"}
|
@@ -0,0 +1,62 @@
|
|
1
|
+
import { jsxs as s, jsx as o } from "react/jsx-runtime";
|
2
|
+
import { memo as a, useRef as m } from "react";
|
3
|
+
import d from "../../ui/buttons/clickable/clickable.js";
|
4
|
+
import u from "../../ui/hooks/use-context-menu-click-handler.js";
|
5
|
+
import $ from "../../ui/layout/flex-view.js";
|
6
|
+
import { ColorPicker as f, PalleteWrapper as C } from "../cue-cavas-styled.js";
|
7
|
+
import { useCueCanvasActions as p } from "../hooks/use-cue-canvas-actions.js";
|
8
|
+
import b from "./color-pallete.js";
|
9
|
+
const W = a(({ userType: t }) => {
|
10
|
+
const e = m(null), { activeColor: r, setActiveColor: l, isWritingToolActive: i } = p(), { menuVisible: n, onMenuClick: c } = u(
|
11
|
+
e,
|
12
|
+
void 0,
|
13
|
+
!0,
|
14
|
+
void 0
|
15
|
+
);
|
16
|
+
return /* @__PURE__ */ s(
|
17
|
+
$,
|
18
|
+
{
|
19
|
+
$width: 32,
|
20
|
+
$height: 32,
|
21
|
+
$alignItems: "center",
|
22
|
+
$justifyContent: "center",
|
23
|
+
$borderRadius: 16,
|
24
|
+
$background: "WHITE",
|
25
|
+
children: [
|
26
|
+
/* @__PURE__ */ o(d, { onClick: c, label: "Color Picker", disabled: !i, children: /* @__PURE__ */ o(
|
27
|
+
f,
|
28
|
+
{
|
29
|
+
$width: 22,
|
30
|
+
$height: 22,
|
31
|
+
$borderRadius: 11,
|
32
|
+
$color: r,
|
33
|
+
$opacity: i ? 1 : 0.5,
|
34
|
+
ref: e
|
35
|
+
}
|
36
|
+
) }),
|
37
|
+
n && /* @__PURE__ */ o(
|
38
|
+
C,
|
39
|
+
{
|
40
|
+
$background: "WHITE",
|
41
|
+
$gutterX: 0.5,
|
42
|
+
$gapX: 0.5,
|
43
|
+
$borderRadius: 10,
|
44
|
+
$flexDirection: "row",
|
45
|
+
children: /* @__PURE__ */ o(
|
46
|
+
b,
|
47
|
+
{
|
48
|
+
setActiveColor: l,
|
49
|
+
activeColor: r,
|
50
|
+
userType: t
|
51
|
+
}
|
52
|
+
)
|
53
|
+
}
|
54
|
+
)
|
55
|
+
]
|
56
|
+
}
|
57
|
+
);
|
58
|
+
});
|
59
|
+
export {
|
60
|
+
W as default
|
61
|
+
};
|
62
|
+
//# sourceMappingURL=color-picker-button.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"color-picker-button.js","sources":["../../../../src/features/cue-canvas/toolbar/color-picker-button.tsx"],"sourcesContent":["import type { TUserTypes } from '../../ui/types';\nimport type { FC } from 'react';\n\nimport { memo, useRef } from 'react';\n\nimport Clickable from '../../ui/buttons/clickable/clickable';\nimport useContextMenuClickHandler from '../../ui/hooks/use-context-menu-click-handler';\nimport FlexView from '../../ui/layout/flex-view';\nimport { ColorPicker, PalleteWrapper } from '../cue-cavas-styled';\nimport { useCueCanvasActions } from '../hooks/use-cue-canvas-actions';\nimport ColorPallete from './color-pallete';\n\ninterface ColorPickerButtonProps {\n userType: TUserTypes;\n}\n\nconst ColorPickerButton: FC<ColorPickerButtonProps> = memo(({ userType }) => {\n const colorPalleteRef = useRef(null);\n const { activeColor, setActiveColor, isWritingToolActive } = useCueCanvasActions();\n\n const { menuVisible, onMenuClick } = useContextMenuClickHandler(\n colorPalleteRef,\n undefined,\n true,\n undefined,\n );\n\n return (\n <FlexView\n $width={32}\n $height={32}\n $alignItems=\"center\"\n $justifyContent=\"center\"\n $borderRadius={16}\n $background=\"WHITE\"\n >\n <Clickable onClick={onMenuClick} label=\"Color Picker\" disabled={!isWritingToolActive}>\n <ColorPicker\n $width={22}\n $height={22}\n $borderRadius={11}\n $color={activeColor}\n $opacity={isWritingToolActive ? 1 : 0.5}\n ref={colorPalleteRef}\n />\n </Clickable>\n {menuVisible && (\n <PalleteWrapper\n $background=\"WHITE\"\n $gutterX={0.5}\n $gapX={0.5}\n $borderRadius={10}\n $flexDirection=\"row\"\n >\n <ColorPallete\n setActiveColor={setActiveColor}\n activeColor={activeColor}\n userType={userType}\n />\n </PalleteWrapper>\n )}\n </FlexView>\n );\n});\n\nexport default ColorPickerButton;\n"],"names":["ColorPickerButton","memo","userType","colorPalleteRef","useRef","activeColor","setActiveColor","isWritingToolActive","useCueCanvasActions","menuVisible","onMenuClick","useContextMenuClickHandler","jsxs","FlexView","jsx","Clickable","ColorPicker","PalleteWrapper","ColorPallete"],"mappings":";;;;;;;;AAgBA,MAAMA,IAAgDC,EAAK,CAAC,EAAE,UAAAC,QAAe;AACrE,QAAAC,IAAkBC,EAAO,IAAI,GAC7B,EAAE,aAAAC,GAAa,gBAAAC,GAAgB,qBAAAC,MAAwBC,EAAoB,GAE3E,EAAE,aAAAC,GAAa,aAAAC,EAAA,IAAgBC;AAAA,IACnCR;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA;AAIA,SAAA,gBAAAS;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,QAAQ;AAAA,MACR,SAAS;AAAA,MACT,aAAY;AAAA,MACZ,iBAAgB;AAAA,MAChB,eAAe;AAAA,MACf,aAAY;AAAA,MAEZ,UAAA;AAAA,QAAA,gBAAAC,EAACC,KAAU,SAASL,GAAa,OAAM,gBAAe,UAAU,CAACH,GAC/D,UAAA,gBAAAO;AAAA,UAACE;AAAA,UAAA;AAAA,YACC,QAAQ;AAAA,YACR,SAAS;AAAA,YACT,eAAe;AAAA,YACf,QAAQX;AAAA,YACR,UAAUE,IAAsB,IAAI;AAAA,YACpC,KAAKJ;AAAA,UAAA;AAAA,QAAA,GAET;AAAA,QACCM,KACC,gBAAAK;AAAA,UAACG;AAAA,UAAA;AAAA,YACC,aAAY;AAAA,YACZ,UAAU;AAAA,YACV,OAAO;AAAA,YACP,eAAe;AAAA,YACf,gBAAe;AAAA,YAEf,UAAA,gBAAAH;AAAA,cAACI;AAAA,cAAA;AAAA,gBACC,gBAAAZ;AAAA,gBACA,aAAAD;AAAA,gBACA,UAAAH;AAAA,cAAA;AAAA,YACF;AAAA,UAAA;AAAA,QACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAIR,CAAC;"}
|
@@ -0,0 +1,57 @@
|
|
1
|
+
import { jsxs as p, jsx as r } from "react/jsx-runtime";
|
2
|
+
import { memo as f, useRef as s } from "react";
|
3
|
+
import i from "../../ui/buttons/clickable/clickable.js";
|
4
|
+
import a from "../../ui/hooks/use-context-menu-click-handler.js";
|
5
|
+
import t from "../../ui/layout/flex-view.js";
|
6
|
+
import { GRID_NAMES as C } from "../cue-canvas-helpers.js";
|
7
|
+
import { StyledWrapper as $, MenuWrapper as h } from "../cue-cavas-styled.js";
|
8
|
+
import { useCueCanvasActions as b } from "../hooks/use-cue-canvas-actions.js";
|
9
|
+
import { GRID_TO_COMP as x } from "./icon-map.js";
|
10
|
+
const W = f(({ onGridOptionClick: n, GridIcon: l }) => {
|
11
|
+
const e = s(null), { activeTool: c } = b(), { menuVisible: d, onMenuClick: m } = a(
|
12
|
+
e,
|
13
|
+
void 0,
|
14
|
+
!0,
|
15
|
+
void 0
|
16
|
+
);
|
17
|
+
return /* @__PURE__ */ p(t, { $gutterX: 0.25, ref: e, children: [
|
18
|
+
/* @__PURE__ */ r(i, { onClick: m, label: "grid", children: /* @__PURE__ */ r($, { $active: c === "grid", children: /* @__PURE__ */ r(l, {}) }) }),
|
19
|
+
d && /* @__PURE__ */ r(
|
20
|
+
h,
|
21
|
+
{
|
22
|
+
$borderColor: "GREY_1",
|
23
|
+
$background: "GREY_1",
|
24
|
+
$flexDirection: "row",
|
25
|
+
$widthX: 11.15,
|
26
|
+
$flexWrap: !0,
|
27
|
+
$flexGapX: 0.5,
|
28
|
+
children: C.map((o) => {
|
29
|
+
const u = x[o];
|
30
|
+
return /* @__PURE__ */ r(
|
31
|
+
i,
|
32
|
+
{
|
33
|
+
onClick: () => n(o),
|
34
|
+
label: o,
|
35
|
+
children: /* @__PURE__ */ r(
|
36
|
+
t,
|
37
|
+
{
|
38
|
+
$width: 48,
|
39
|
+
$height: 48,
|
40
|
+
$borderColor: "BLACK",
|
41
|
+
$borderRadius: 4,
|
42
|
+
$background: "WHITE",
|
43
|
+
children: /* @__PURE__ */ r(u, {})
|
44
|
+
}
|
45
|
+
)
|
46
|
+
},
|
47
|
+
o
|
48
|
+
);
|
49
|
+
})
|
50
|
+
}
|
51
|
+
)
|
52
|
+
] });
|
53
|
+
});
|
54
|
+
export {
|
55
|
+
W as default
|
56
|
+
};
|
57
|
+
//# sourceMappingURL=grid-menu.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"grid-menu.js","sources":["../../../../src/features/cue-canvas/toolbar/grid-menu.tsx"],"sourcesContent":["import type { IGridMenu, TToolComponentType } from '../types/toolbar';\n\nimport React, { memo, useRef } from 'react';\n\nimport Clickable from '../../ui/buttons/clickable/clickable';\nimport useContextMenuClickHandler from '../../ui/hooks/use-context-menu-click-handler';\nimport FlexView from '../../ui/layout/flex-view';\nimport { GRID_NAMES } from '../cue-canvas-helpers';\nimport { MenuWrapper, StyledWrapper } from '../cue-cavas-styled';\nimport { useCueCanvasActions } from '../hooks/use-cue-canvas-actions';\nimport { GRID_TO_COMP } from './icon-map';\n\nconst GridMenu: React.FC<IGridMenu> = memo(({ onGridOptionClick, GridIcon }) => {\n const gridMenuRef = useRef(null);\n const { activeTool } = useCueCanvasActions();\n const { menuVisible, onMenuClick } = useContextMenuClickHandler(\n gridMenuRef,\n undefined,\n true,\n undefined,\n );\n\n return (\n <FlexView $gutterX={0.25} ref={gridMenuRef}>\n <Clickable onClick={onMenuClick} label=\"grid\">\n <StyledWrapper $active={activeTool === 'grid'}>\n <GridIcon />\n </StyledWrapper>\n </Clickable>\n {menuVisible && (\n <MenuWrapper\n $borderColor=\"GREY_1\"\n $background=\"GREY_1\"\n $flexDirection=\"row\"\n $widthX={11.15}\n $flexWrap={true}\n $flexGapX={0.5}\n >\n {GRID_NAMES.map(gridName => {\n const GridComponent = GRID_TO_COMP[gridName] as TToolComponentType;\n\n return (\n <Clickable\n key={gridName}\n onClick={() => onGridOptionClick(gridName)}\n label={gridName}\n >\n <FlexView\n $width={48}\n $height={48}\n $borderColor=\"BLACK\"\n $borderRadius={4}\n $background=\"WHITE\"\n >\n <GridComponent />\n </FlexView>\n </Clickable>\n );\n })}\n </MenuWrapper>\n )}\n </FlexView>\n );\n});\n\nexport default GridMenu;\n"],"names":["GridMenu","memo","onGridOptionClick","GridIcon","gridMenuRef","useRef","activeTool","useCueCanvasActions","menuVisible","onMenuClick","useContextMenuClickHandler","jsxs","FlexView","jsx","Clickable","StyledWrapper","MenuWrapper","GRID_NAMES","gridName","GridComponent","GRID_TO_COMP"],"mappings":";;;;;;;;;AAYA,MAAMA,IAAgCC,EAAK,CAAC,EAAE,mBAAAC,GAAmB,UAAAC,QAAe;AACxE,QAAAC,IAAcC,EAAO,IAAI,GACzB,EAAE,YAAAC,MAAeC,KACjB,EAAE,aAAAC,GAAa,aAAAC,EAAA,IAAgBC;AAAA,IACnCN;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA;AAGF,SACG,gBAAAO,EAAAC,GAAA,EAAS,UAAU,MAAM,KAAKR,GAC7B,UAAA;AAAA,IAAA,gBAAAS,EAACC,GAAU,EAAA,SAASL,GAAa,OAAM,QACrC,UAAA,gBAAAI,EAACE,GAAc,EAAA,SAAST,MAAe,QACrC,UAAC,gBAAAO,EAAAV,GAAA,CAAA,CAAS,EACZ,CAAA,GACF;AAAA,IACCK,KACC,gBAAAK;AAAA,MAACG;AAAA,MAAA;AAAA,QACC,cAAa;AAAA,QACb,aAAY;AAAA,QACZ,gBAAe;AAAA,QACf,SAAS;AAAA,QACT,WAAW;AAAA,QACX,WAAW;AAAA,QAEV,UAAAC,EAAW,IAAI,CAAYC,MAAA;AACpB,gBAAAC,IAAgBC,EAAaF,CAAQ;AAGzC,iBAAA,gBAAAL;AAAA,YAACC;AAAA,YAAA;AAAA,cAEC,SAAS,MAAMZ,EAAkBgB,CAAQ;AAAA,cACzC,OAAOA;AAAA,cAEP,UAAA,gBAAAL;AAAA,gBAACD;AAAA,gBAAA;AAAA,kBACC,QAAQ;AAAA,kBACR,SAAS;AAAA,kBACT,cAAa;AAAA,kBACb,eAAe;AAAA,kBACf,aAAY;AAAA,kBAEZ,4BAACO,GAAc,EAAA;AAAA,gBAAA;AAAA,cACjB;AAAA,YAAA;AAAA,YAZKD;AAAA,UAAA;AAAA,QAaP,CAEH;AAAA,MAAA;AAAA,IACH;AAAA,EAEJ,EAAA,CAAA;AAEJ,CAAC;"}
|
@@ -0,0 +1,58 @@
|
|
1
|
+
import o from "../../../assets/line-icons/icons/clear-all.js";
|
2
|
+
import r from "../../../assets/line-icons/icons/cursor.js";
|
3
|
+
import m from "../../../assets/line-icons/icons/download.js";
|
4
|
+
import i from "../../../assets/line-icons/icons/equation.js";
|
5
|
+
import t from "../../../assets/line-icons/icons/eraser.js";
|
6
|
+
import e from "../../../assets/line-icons/icons/grid-icon.js";
|
7
|
+
import p from "../../../assets/line-icons/icons/home.js";
|
8
|
+
import n from "../../../assets/line-icons/icons/pan.js";
|
9
|
+
import d from "../../../assets/line-icons/icons/square-checked-grid.js";
|
10
|
+
import a from "../../../assets/line-icons/icons/square-dots.js";
|
11
|
+
import c from "../../../assets/line-icons/icons/square-grid.js";
|
12
|
+
import f from "../../../assets/line-icons/icons/square2-grid.js";
|
13
|
+
import l from "../../../assets/line-icons/icons/text-icon.js";
|
14
|
+
import I from "../../../assets/line-icons/icons/tri-dots.js";
|
15
|
+
import S from "../../../assets/line-icons/icons/tri-grid.js";
|
16
|
+
import g from "../../../assets/line-icons/icons/tri2-dots.js";
|
17
|
+
import u from "../../../assets/line-icons/icons/tri2-grid.js";
|
18
|
+
import s from "../../../assets/line-icons/icons/undo.js";
|
19
|
+
import q from "../../../assets/line-icons/icons/upload.js";
|
20
|
+
import h from "../../../assets/line-icons/icons/zoom-in.js";
|
21
|
+
import v from "../../../assets/line-icons/icons/zoom-out.js";
|
22
|
+
import O from "../../ui/layout/flex-view.js";
|
23
|
+
import { StyledPencilIcon as T, StyledRulerIcon as G, StyledSketchWrapper as C, StyledHighlighterWrapper as D, RedoIcon as k } from "../cue-cavas-styled.js";
|
24
|
+
const Q = {
|
25
|
+
pen: T,
|
26
|
+
ruler: G,
|
27
|
+
marker: C,
|
28
|
+
highlighter: D,
|
29
|
+
eraser: t,
|
30
|
+
move: r,
|
31
|
+
undo: s,
|
32
|
+
redo: k,
|
33
|
+
pan: n,
|
34
|
+
clearAll: o,
|
35
|
+
text: l,
|
36
|
+
equation: i,
|
37
|
+
grid: e,
|
38
|
+
home: p,
|
39
|
+
zoomIn: h,
|
40
|
+
zoomOut: v,
|
41
|
+
upload: q,
|
42
|
+
download: m
|
43
|
+
}, X = {
|
44
|
+
none: O,
|
45
|
+
"square2-grid": f,
|
46
|
+
"square-checked": d,
|
47
|
+
"square-dots": a,
|
48
|
+
"tri-dots": I,
|
49
|
+
"tri2-dots": g,
|
50
|
+
"square-grid": c,
|
51
|
+
"tri-grid": S,
|
52
|
+
"tri2-grid": u
|
53
|
+
};
|
54
|
+
export {
|
55
|
+
X as GRID_TO_COMP,
|
56
|
+
Q as TOOLS_TO_COMP
|
57
|
+
};
|
58
|
+
//# sourceMappingURL=icon-map.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"icon-map.js","sources":["../../../../src/features/cue-canvas/toolbar/icon-map.ts"],"sourcesContent":["import type { IToolsToCompMap, IGridToCompMap, TToolComponentType } from '../types/toolbar';\n\nimport ClearAllIcon from '../../../assets/line-icons/icons/clear-all';\nimport CursorIcon from '../../../assets/line-icons/icons/cursor';\nimport DownloadIcon from '../../../assets/line-icons/icons/download';\nimport EquationIcon from '../../../assets/line-icons/icons/equation';\nimport EraserIcon from '../../../assets/line-icons/icons/eraser';\nimport GridIcon from '../../../assets/line-icons/icons/grid-icon';\nimport HomeIcon from '../../../assets/line-icons/icons/home';\nimport PanIcon from '../../../assets/line-icons/icons/pan';\nimport SquareCheckedGridSvg from '../../../assets/line-icons/icons/square-checked-grid';\nimport SquareDotSvg from '../../../assets/line-icons/icons/square-dots';\nimport SquareGridSvg from '../../../assets/line-icons/icons/square-grid';\nimport Square2GridSvg from '../../../assets/line-icons/icons/square2-grid';\nimport TextIcon from '../../../assets/line-icons/icons/text-icon';\nimport TriDotSvg from '../../../assets/line-icons/icons/tri-dots';\nimport TriGridSvg from '../../../assets/line-icons/icons/tri-grid';\nimport Tri2DotSvg from '../../../assets/line-icons/icons/tri2-dots';\nimport Tri2GridSvg from '../../../assets/line-icons/icons/tri2-grid';\nimport UndoIcon from '../../../assets/line-icons/icons/undo';\nimport UploadIcon from '../../../assets/line-icons/icons/upload';\nimport ZoomInIcon from '../../../assets/line-icons/icons/zoom-in';\nimport ZoomOutIcon from '../../../assets/line-icons/icons/zoom-out';\nimport FlexView from '../../ui/layout/flex-view';\nimport {\n RedoIcon,\n StyledHighlighterWrapper,\n StyledPencilIcon,\n StyledRulerIcon,\n StyledSketchWrapper,\n} from '../cue-cavas-styled';\n\nexport const TOOLS_TO_COMP: IToolsToCompMap = {\n pen: StyledPencilIcon,\n ruler: StyledRulerIcon,\n marker: StyledSketchWrapper,\n highlighter: StyledHighlighterWrapper,\n eraser: EraserIcon,\n move: CursorIcon,\n undo: UndoIcon,\n redo: RedoIcon,\n pan: PanIcon,\n clearAll: ClearAllIcon,\n text: TextIcon,\n equation: EquationIcon,\n grid: GridIcon,\n home: HomeIcon,\n zoomIn: ZoomInIcon,\n zoomOut: ZoomOutIcon,\n upload: UploadIcon,\n download: DownloadIcon,\n};\n\nexport const GRID_TO_COMP: IGridToCompMap = {\n 'none': FlexView as unknown as TToolComponentType,\n 'square2-grid': Square2GridSvg,\n 'square-checked': SquareCheckedGridSvg,\n 'square-dots': SquareDotSvg,\n 'tri-dots': TriDotSvg,\n 'tri2-dots': Tri2DotSvg,\n 'square-grid': SquareGridSvg,\n 'tri-grid': TriGridSvg,\n 'tri2-grid': Tri2GridSvg,\n};\n"],"names":["TOOLS_TO_COMP","StyledPencilIcon","StyledRulerIcon","StyledSketchWrapper","StyledHighlighterWrapper","EraserIcon","CursorIcon","UndoIcon","RedoIcon","PanIcon","ClearAllIcon","TextIcon","EquationIcon","GridIcon","HomeIcon","ZoomInIcon","ZoomOutIcon","UploadIcon","DownloadIcon","GRID_TO_COMP","FlexView","Square2GridSvg","SquareCheckedGridSvg","SquareDotSvg","TriDotSvg","Tri2DotSvg","SquareGridSvg","TriGridSvg","Tri2GridSvg"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAgCO,MAAMA,IAAiC;AAAA,EAC5C,KAAKC;AAAA,EACL,OAAOC;AAAA,EACP,QAAQC;AAAA,EACR,aAAaC;AAAA,EACb,QAAQC;AAAA,EACR,MAAMC;AAAA,EACN,MAAMC;AAAA,EACN,MAAMC;AAAA,EACN,KAAKC;AAAA,EACL,UAAUC;AAAA,EACV,MAAMC;AAAA,EACN,UAAUC;AAAAA,EACV,MAAMC;AAAA,EACN,MAAMC;AAAA,EACN,QAAQC;AAAA,EACR,SAASC;AAAA,EACT,QAAQC;AAAA,EACR,UAAUC;AACZ,GAEaC,IAA+B;AAAA,EAC1C,MAAQC;AAAA,EACR,gBAAgBC;AAAA,EAChB,kBAAkBC;AAAA,EAClB,eAAeC;AAAA,EACf,YAAYC;AAAA,EACZ,aAAaC;AAAA,EACb,eAAeC;AAAA,EACf,YAAYC;AAAA,EACZ,aAAaC;AACf;"}
|
@@ -0,0 +1,65 @@
|
|
1
|
+
import { jsxs as n, jsx as e } from "react/jsx-runtime";
|
2
|
+
import { memo as h, useRef as T } from "react";
|
3
|
+
import s from "../../ui/buttons/clickable/clickable.js";
|
4
|
+
import b from "../../ui/hooks/use-context-menu-click-handler.js";
|
5
|
+
import t from "../../ui/layout/flex-view.js";
|
6
|
+
import { getIsWritingTool as c } from "../cue-canvas-helpers.js";
|
7
|
+
import { PenIconWrapper as g, StyledDownIcon as W, MenuWrapper as k, StyledWrapper as x } from "../cue-cavas-styled.js";
|
8
|
+
import { useCueCanvasActions as I } from "../hooks/use-cue-canvas-actions.js";
|
9
|
+
import M from "./color-pallete.js";
|
10
|
+
import { TOOLS_TO_COMP as p } from "./icon-map.js";
|
11
|
+
const S = h(({ writingTools: u, onToolClick: d, userType: C }) => {
|
12
|
+
const { activeTool: o, activeColor: i, setActiveColor: $ } = I(), l = T(null), { menuVisible: m, onMenuClick: f } = b(
|
13
|
+
l,
|
14
|
+
void 0,
|
15
|
+
!0,
|
16
|
+
void 0
|
17
|
+
), v = p[c(o) ? o : "pen"];
|
18
|
+
return /* @__PURE__ */ n(t, { $borderRadius: 16, $background: "WHITE", ref: l, children: [
|
19
|
+
/* @__PURE__ */ e(g, { children: /* @__PURE__ */ e(s, { onClick: f, label: "Active Tool", children: /* @__PURE__ */ n(t, { $flexDirection: "row", $justifyContent: "center", $alignItems: "center", children: [
|
20
|
+
/* @__PURE__ */ e(
|
21
|
+
v,
|
22
|
+
{
|
23
|
+
$active: c(o),
|
24
|
+
$activeColor: i,
|
25
|
+
$isWhiteBoard: !0
|
26
|
+
}
|
27
|
+
),
|
28
|
+
/* @__PURE__ */ e(W, { $isAnimating: m })
|
29
|
+
] }) }) }),
|
30
|
+
m && /* @__PURE__ */ n(
|
31
|
+
k,
|
32
|
+
{
|
33
|
+
$flexDirection: "row",
|
34
|
+
$alignItems: "center",
|
35
|
+
$borderColor: "GREY_1",
|
36
|
+
$background: "WHITE",
|
37
|
+
children: [
|
38
|
+
u.map((r) => {
|
39
|
+
const a = p[r];
|
40
|
+
return /* @__PURE__ */ e(t, { $gutterX: 0.25, children: /* @__PURE__ */ e(s, { onClick: () => d(r), label: r, children: c(r) ? /* @__PURE__ */ e(
|
41
|
+
a,
|
42
|
+
{
|
43
|
+
$active: o === r,
|
44
|
+
$activeColor: i,
|
45
|
+
$isWhiteBoard: !0
|
46
|
+
}
|
47
|
+
) : /* @__PURE__ */ e(x, { $active: o === r, children: /* @__PURE__ */ e(a, {}) }) }) }, r);
|
48
|
+
}),
|
49
|
+
/* @__PURE__ */ e(
|
50
|
+
M,
|
51
|
+
{
|
52
|
+
setActiveColor: $,
|
53
|
+
activeColor: i,
|
54
|
+
userType: C
|
55
|
+
}
|
56
|
+
)
|
57
|
+
]
|
58
|
+
}
|
59
|
+
)
|
60
|
+
] });
|
61
|
+
});
|
62
|
+
export {
|
63
|
+
S as default
|
64
|
+
};
|
65
|
+
//# sourceMappingURL=pen-tool-menu.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"pen-tool-menu.js","sources":["../../../../src/features/cue-canvas/toolbar/pen-tool-menu.tsx"],"sourcesContent":["import type { IPenToolMenu, TToolComponentType } from '../types/toolbar';\nimport type { FC } from 'react';\n\nimport { memo, useRef } from 'react';\n\nimport Clickable from '../../ui/buttons/clickable/clickable';\nimport useContextMenuClickHandler from '../../ui/hooks/use-context-menu-click-handler';\nimport FlexView from '../../ui/layout/flex-view';\nimport { getIsWritingTool } from '../cue-canvas-helpers';\nimport { MenuWrapper, PenIconWrapper, StyledDownIcon } from '../cue-cavas-styled';\nimport { StyledWrapper } from '../cue-cavas-styled';\nimport { useCueCanvasActions } from '../hooks/use-cue-canvas-actions';\nimport ColorPallete from './color-pallete';\nimport { TOOLS_TO_COMP } from './icon-map';\n\nconst PenToolMenu: FC<IPenToolMenu> = memo(({ writingTools, onToolClick, userType }) => {\n const { activeTool, activeColor, setActiveColor } = useCueCanvasActions();\n const penMenuRef = useRef(null);\n const { menuVisible, onMenuClick } = useContextMenuClickHandler(\n penMenuRef,\n undefined,\n true,\n undefined,\n );\n\n const ActiveToolComponent = TOOLS_TO_COMP[\n getIsWritingTool(activeTool) ? activeTool : 'pen'\n ] as TToolComponentType;\n\n return (\n <FlexView $borderRadius={16} $background=\"WHITE\" ref={penMenuRef}>\n <PenIconWrapper>\n <Clickable onClick={onMenuClick} label=\"Active Tool\">\n <FlexView $flexDirection=\"row\" $justifyContent=\"center\" $alignItems=\"center\">\n <ActiveToolComponent\n $active={getIsWritingTool(activeTool)}\n $activeColor={activeColor}\n $isWhiteBoard\n />\n <StyledDownIcon $isAnimating={menuVisible} />\n </FlexView>\n </Clickable>\n </PenIconWrapper>\n {menuVisible && (\n <MenuWrapper\n $flexDirection=\"row\"\n $alignItems=\"center\"\n $borderColor=\"GREY_1\"\n $background=\"WHITE\"\n >\n {writingTools.map(tool => {\n const ToolComponent = TOOLS_TO_COMP[tool] as TToolComponentType;\n\n return (\n <FlexView $gutterX={0.25} key={tool}>\n <Clickable onClick={() => onToolClick(tool)} label={tool}>\n {getIsWritingTool(tool) ? (\n <ToolComponent\n $active={activeTool === tool}\n $activeColor={activeColor}\n $isWhiteBoard\n />\n ) : (\n <StyledWrapper $active={activeTool === tool}>\n <ToolComponent />\n </StyledWrapper>\n )}\n </Clickable>\n </FlexView>\n );\n })}\n <ColorPallete\n setActiveColor={setActiveColor}\n activeColor={activeColor}\n userType={userType}\n />\n </MenuWrapper>\n )}\n </FlexView>\n );\n});\n\nexport default PenToolMenu;\n"],"names":["PenToolMenu","memo","writingTools","onToolClick","userType","activeTool","activeColor","setActiveColor","useCueCanvasActions","penMenuRef","useRef","menuVisible","onMenuClick","useContextMenuClickHandler","ActiveToolComponent","TOOLS_TO_COMP","getIsWritingTool","FlexView","jsx","PenIconWrapper","Clickable","jsxs","StyledDownIcon","MenuWrapper","tool","ToolComponent","StyledWrapper","ColorPallete"],"mappings":";;;;;;;;;;AAeA,MAAMA,IAAgCC,EAAK,CAAC,EAAE,cAAAC,GAAc,aAAAC,GAAa,UAAAC,QAAe;AACtF,QAAM,EAAE,YAAAC,GAAY,aAAAC,GAAa,gBAAAC,MAAmBC,EAAoB,GAClEC,IAAaC,EAAO,IAAI,GACxB,EAAE,aAAAC,GAAa,aAAAC,EAAA,IAAgBC;AAAA,IACnCJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA,GAGIK,IAAsBC,EAC1BC,EAAiBX,CAAU,IAAIA,IAAa,KAC9C;AAEA,2BACGY,GAAS,EAAA,eAAe,IAAI,aAAY,SAAQ,KAAKR,GACpD,UAAA;AAAA,IAAA,gBAAAS,EAACC,GACC,EAAA,UAAA,gBAAAD,EAACE,GAAU,EAAA,SAASR,GAAa,OAAM,eACrC,UAAC,gBAAAS,EAAAJ,GAAA,EAAS,gBAAe,OAAM,iBAAgB,UAAS,aAAY,UAClE,UAAA;AAAA,MAAA,gBAAAC;AAAA,QAACJ;AAAA,QAAA;AAAA,UACC,SAASE,EAAiBX,CAAU;AAAA,UACpC,cAAcC;AAAA,UACd,eAAa;AAAA,QAAA;AAAA,MACf;AAAA,MACA,gBAAAY,EAACI,GAAe,EAAA,cAAcX,EAAa,CAAA;AAAA,IAAA,EAC7C,CAAA,EACF,CAAA,GACF;AAAA,IACCA,KACC,gBAAAU;AAAA,MAACE;AAAA,MAAA;AAAA,QACC,gBAAe;AAAA,QACf,aAAY;AAAA,QACZ,cAAa;AAAA,QACb,aAAY;AAAA,QAEX,UAAA;AAAA,UAAArB,EAAa,IAAI,CAAQsB,MAAA;AAClB,kBAAAC,IAAgBV,EAAcS,CAAI;AAExC,mBACG,gBAAAN,EAAAD,GAAA,EAAS,UAAU,MAClB,4BAACG,GAAU,EAAA,SAAS,MAAMjB,EAAYqB,CAAI,GAAG,OAAOA,GACjD,UAAAR,EAAiBQ,CAAI,IACpB,gBAAAN;AAAA,cAACO;AAAA,cAAA;AAAA,gBACC,SAASpB,MAAemB;AAAA,gBACxB,cAAclB;AAAA,gBACd,eAAa;AAAA,cAAA;AAAA,YAAA,IAGd,gBAAAY,EAAAQ,GAAA,EAAc,SAASrB,MAAemB,GACrC,UAAA,gBAAAN,EAACO,GAAc,CAAA,CAAA,EACjB,CAAA,EAEJ,CAAA,EAAA,GAb6BD,CAc/B;AAAA,UAAA,CAEH;AAAA,UACD,gBAAAN;AAAA,YAACS;AAAA,YAAA;AAAA,cACC,gBAAApB;AAAA,cACA,aAAAD;AAAA,cACA,UAAAF;AAAA,YAAA;AAAA,UACF;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,EAEJ,EAAA,CAAA;AAEJ,CAAC;"}
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import { jsx as i } from "react/jsx-runtime";
|
2
|
+
import { memo as a } from "react";
|
3
|
+
import p from "../../ui/buttons/clickable/clickable.js";
|
4
|
+
import { getIsWritingTool as f } from "../cue-canvas-helpers.js";
|
5
|
+
import { StyledWrapper as s } from "../cue-cavas-styled.js";
|
6
|
+
import { useCueCanvasActions as u } from "../hooks/use-cue-canvas-actions.js";
|
7
|
+
import C from "./grid-menu.js";
|
8
|
+
import { TOOLS_TO_COMP as d } from "./icon-map.js";
|
9
|
+
const k = a(
|
10
|
+
({ tools: t, onToolClick: m, onGridOptionClick: n }) => {
|
11
|
+
const { activeColor: c, activeTool: e } = u();
|
12
|
+
return t.map((r) => {
|
13
|
+
const o = d[r];
|
14
|
+
return r === "grid" ? /* @__PURE__ */ i(C, { onGridOptionClick: n, GridIcon: o }, r) : /* @__PURE__ */ i(p, { onClick: () => m(r), label: r, children: f(r) ? /* @__PURE__ */ i(o, { $active: e === r, $activeColor: c }) : /* @__PURE__ */ i(s, { $active: e === r, children: /* @__PURE__ */ i(o, {}) }) }, r);
|
15
|
+
});
|
16
|
+
}
|
17
|
+
);
|
18
|
+
export {
|
19
|
+
k as default
|
20
|
+
};
|
21
|
+
//# sourceMappingURL=tool-buttons.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"tool-buttons.js","sources":["../../../../src/features/cue-canvas/toolbar/tool-buttons.tsx"],"sourcesContent":["import type { IToolButtonList, TToolComponentType } from '../types/toolbar';\n\nimport React, { memo } from 'react';\n\nimport Clickable from '../../ui/buttons/clickable/clickable';\nimport { getIsWritingTool } from '../cue-canvas-helpers';\nimport { StyledWrapper } from '../cue-cavas-styled';\nimport { useCueCanvasActions } from '../hooks/use-cue-canvas-actions';\nimport GridMenu from './grid-menu';\nimport { TOOLS_TO_COMP } from './icon-map';\n\nconst ToolButtonList: React.FC<IToolButtonList> = memo(\n ({ tools, onToolClick, onGridOptionClick }) => {\n const { activeColor, activeTool } = useCueCanvasActions();\n\n return tools.map(tool => {\n const ToolComponent = TOOLS_TO_COMP[tool] as TToolComponentType;\n\n if (tool === 'grid') {\n return (\n <GridMenu key={tool} onGridOptionClick={onGridOptionClick} GridIcon={ToolComponent} />\n );\n }\n\n return (\n <Clickable onClick={() => onToolClick(tool)} label={tool} key={tool}>\n {getIsWritingTool(tool) ? (\n <ToolComponent $active={activeTool === tool} $activeColor={activeColor} />\n ) : (\n <StyledWrapper $active={activeTool === tool}>\n <ToolComponent />\n </StyledWrapper>\n )}\n </Clickable>\n );\n });\n },\n);\n\nexport default ToolButtonList;\n"],"names":["ToolButtonList","memo","tools","onToolClick","onGridOptionClick","activeColor","activeTool","useCueCanvasActions","tool","ToolComponent","TOOLS_TO_COMP","jsx","GridMenu","Clickable","getIsWritingTool","StyledWrapper"],"mappings":";;;;;;;;AAWA,MAAMA,IAA4CC;AAAA,EAChD,CAAC,EAAE,OAAAC,GAAO,aAAAC,GAAa,mBAAAC,QAAwB;AAC7C,UAAM,EAAE,aAAAC,GAAa,YAAAC,EAAW,IAAIC,EAAoB;AAEjD,WAAAL,EAAM,IAAI,CAAQM,MAAA;AACjB,YAAAC,IAAgBC,EAAcF,CAAI;AAExC,aAAIA,MAAS,SAER,gBAAAG,EAAAC,GAAA,EAAoB,mBAAAR,GAAsC,UAAUK,KAAtDD,CAAqE,IAKrF,gBAAAG,EAAAE,GAAA,EAAU,SAAS,MAAMV,EAAYK,CAAI,GAAG,OAAOA,GACjD,UAAAM,EAAiBN,CAAI,IACnB,gBAAAG,EAAAF,GAAA,EAAc,SAASH,MAAeE,GAAM,cAAcH,GAAa,IAEvE,gBAAAM,EAAAI,GAAA,EAAc,SAAST,MAAeE,GACrC,UAAA,gBAAAG,EAACF,GAAc,CAAA,CAAA,EAAA,CACjB,KAN2DD,CAQ/D;AAAA,IAAA,CAEH;AAAA,EACH;AACF;"}
|