UNPKG

hrw-certificate-editor

Version:

Design Editor Tools with React.js + ant.design + fabric.js

119 lines 5.91 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const React = __importStar(require("react")); const antd_1 = require("antd"); const PropTypes = __importStar(require("prop-types")); const i18next_1 = __importDefault(require("i18next")); const constants_1 = require("../../canvas/constants"); // import { Canvas } from '../../canvas'; const common_1 = require("../../components/common"); class WorkflowToolbar extends React.Component { constructor() { super(...arguments); this.state = { interactionMode: 'selection', }; this.handlers = { selection: () => { this.props.canvasRef.handler.interactionHandler.selection(); this.setState({ interactionMode: 'selection' }); }, grab: () => { this.props.canvasRef.handler.interactionHandler.grab(); this.setState({ interactionMode: 'grab' }); }, }; this.events = { keydown: (e) => { if (this.props.canvasRef.canvas.wrapperEl !== document.activeElement) { return false; } if (e.code === constants_1.code.KEY_Q) { return this.handlers.selection(); } else if (e.code === constants_1.code.KEY_W) { return this.handlers.grab(); } }, }; this.waitForCanvasRender = (canvas) => { setTimeout(() => { if (canvas) { this.attachEventListener(canvas); return; } const { canvasRef } = this.props; this.waitForCanvasRender(canvasRef); }, 5); }; this.attachEventListener = (canvasRef) => { canvasRef.canvas.wrapperEl.addEventListener('keydown', this.events.keydown, false); }; this.detachEventListener = (canvasRef) => { canvasRef.canvas.wrapperEl.removeEventListener('keydown', this.events.keydown); }; } componentDidMount() { const { canvasRef } = this.props; this.waitForCanvasRender(canvasRef); } componentWillUnmount() { const { canvasRef } = this.props; this.detachEventListener(canvasRef); } render() { const { canvasRef, zoomRatio } = this.props; const { interactionMode } = this.state; const { selection, grab } = this.handlers; const zoomValue = parseInt((zoomRatio * 100).toFixed(2), 10); return (React.createElement(React.Fragment, null, React.createElement("div", { className: "rde-editor-toolbar-interaction" }, React.createElement(antd_1.Button.Group, null, React.createElement(common_1.CommonButton, { type: interactionMode === 'selection' ? 'primary' : 'default', style: { borderBottomLeftRadius: '8px', borderTopLeftRadius: '8px' }, onClick: () => { selection(); }, icon: "mouse-pointer", tooltipTitle: i18next_1.default.t('action.selection') }), React.createElement(common_1.CommonButton, { type: interactionMode === 'grab' ? 'primary' : 'default', style: { borderBottomRightRadius: '8px', borderTopRightRadius: '8px' }, onClick: () => { grab(); }, tooltipTitle: i18next_1.default.t('action.grab'), icon: "hand-rock" }))), React.createElement("div", { className: "rde-editor-toolbar-zoom" }, React.createElement(antd_1.Button.Group, null, React.createElement(common_1.CommonButton, { style: { borderBottomLeftRadius: '8px', borderTopLeftRadius: '8px' }, onClick: () => { canvasRef.handler.zoomHandler.zoomIn(); }, icon: "search-plus", tooltipTitle: i18next_1.default.t('action.zoom-in') }), React.createElement(common_1.CommonButton, { onClick: () => { canvasRef.handler.zoomHandler.zoomOneToOne(); }, tooltipTitle: i18next_1.default.t('action.one-to-one') }, `${zoomValue}%`), React.createElement(common_1.CommonButton, { style: { borderBottomRightRadius: '8px', borderTopRightRadius: '8px' }, onClick: () => { canvasRef.handler.zoomHandler.zoomOut(); }, icon: "search-minus", tooltipTitle: i18next_1.default.t('action.zoom-out') }))))); } } WorkflowToolbar.propTypes = { canvasRef: PropTypes.any, selectedItem: PropTypes.object, zoomRatio: PropTypes.number, }; exports.default = WorkflowToolbar; //# sourceMappingURL=WorkflowToolbar.js.map