diff options
Diffstat (limited to 'src/client/views/InkingControl.tsx')
| -rw-r--r-- | src/client/views/InkingControl.tsx | 66 | 
1 files changed, 48 insertions, 18 deletions
diff --git a/src/client/views/InkingControl.tsx b/src/client/views/InkingControl.tsx index 955831fb6..fb75ef2a5 100644 --- a/src/client/views/InkingControl.tsx +++ b/src/client/views/InkingControl.tsx @@ -1,16 +1,25 @@  import { observable, action, computed } from "mobx"; -import { CirclePicker, ColorResult } from 'react-color'; + +import { CirclePicker, ColorResult } from 'react-color'  import React = require("react");  import "./InkingCanvas.scss"  import { InkTool } from "../../fields/InkField";  import { observer } from "mobx-react"; +import "./InkingCanvas.scss" +import { library } from '@fortawesome/fontawesome-svg-core'; +import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; +import { faPen, faHighlighter, faEraser, faBan } from '@fortawesome/free-solid-svg-icons'; + +library.add(faPen, faHighlighter, faEraser, faBan);  @observer  export class InkingControl extends React.Component {      static Instance: InkingControl = new InkingControl({});      @observable private _selectedTool: InkTool = InkTool.None; -    @observable private _selectedColor: string = "#f44336"; +    @observable private _selectedColor: string = "rgb(244, 67, 54)";      @observable private _selectedWidth: string = "25"; +    @observable private _open: boolean = false; +    @observable private _colorPickerDisplay: boolean = false;      constructor(props: Readonly<{}>) {          super(props); @@ -49,29 +58,50 @@ export class InkingControl extends React.Component {      selected = (tool: InkTool) => {          if (this._selectedTool === tool) { -            return { backgroundColor: "black", color: "white" } +            return { color: "#61aaa3" }          }          return {}      } +    @action +    toggleDisplay = () => { +        this._open = !this._open; +    } + +    @action +    toggleColorPicker = () => { +        this._colorPickerDisplay = !this._colorPickerDisplay; +    } +      render() {          return ( -            <div className="inking-control"> -                <div className="ink-tools ink-panel"> -                    <button onClick={() => this.switchTool(InkTool.Pen)} style={this.selected(InkTool.Pen)}>Pen</button> -                    <button onClick={() => this.switchTool(InkTool.Highlighter)} style={this.selected(InkTool.Highlighter)}>Highlighter</button> -                    <button onClick={() => this.switchTool(InkTool.Eraser)} style={this.selected(InkTool.Eraser)}>Eraser</button> -                    <button onClick={() => this.switchTool(InkTool.None)} style={this.selected(InkTool.None)}> None</button> -                </div> -                <div className="ink-size ink-panel"> -                    <label htmlFor="stroke-width">Size</label> -                    <input type="range" min="1" max="100" defaultValue="25" name="stroke-width" +            <ul className="inking-control" style={this._open ? { display: "flex" } : { display: "none" }}> +                <li className="ink-tools ink-panel"> +                    <div className="ink-tool-buttons"> +                        <button onClick={() => this.switchTool(InkTool.Pen)} style={this.selected(InkTool.Pen)}><FontAwesomeIcon icon="pen" size="lg" title="Pen" /></button> +                        <button onClick={() => this.switchTool(InkTool.Highlighter)} style={this.selected(InkTool.Highlighter)}><FontAwesomeIcon icon="highlighter" size="lg" title="Highlighter" /></button> +                        <button onClick={() => this.switchTool(InkTool.Eraser)} style={this.selected(InkTool.Eraser)}><FontAwesomeIcon icon="eraser" size="lg" title="Eraser" /></button> +                        <button onClick={() => this.switchTool(InkTool.None)} style={this.selected(InkTool.None)}><FontAwesomeIcon icon="ban" size="lg" title="Pointer" /></button> +                    </div> +                </li> +                <li className="ink-color ink-panel"> +                    <label>COLOR: </label> +                    <div className="ink-color-display" style={{ backgroundColor: this._selectedColor }} +                        onClick={() => this.toggleColorPicker()}> +                        {/* {this._colorPickerDisplay ? <span>▼</span> : <span>▲</span>} */} +                    </div> +                    <div className="ink-color-picker" style={this._colorPickerDisplay ? { display: "block" } : { display: "none" }}> +                        <CirclePicker onChange={this.switchColor} circleSize={22} width={"220"} /> +                    </div> +                </li> +                <li className="ink-size ink-panel"> +                    <label htmlFor="stroke-width">SIZE: </label> +                    <input type="text" min="1" max="100" value={this._selectedWidth} name="stroke-width" +                        onChange={(e: React.ChangeEvent<HTMLInputElement>) => this.switchWidth(e.target.value)} /> +                    <input type="range" min="1" max="100" value={this._selectedWidth} name="stroke-width"                          onChange={(e: React.ChangeEvent<HTMLInputElement>) => this.switchWidth(e.target.value)} /> -                </div> -                <div className="ink-color ink-panel"> -                    <CirclePicker onChange={this.switchColor} /> -                </div> -            </div> +                </li> +            </ul >          )      }  }
\ No newline at end of file  | 
