UNPKG

hrw-certificate-editor

Version:

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

134 lines 6.92 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_1 = __importStar(require("react")); const prop_types_1 = __importDefault(require("prop-types")); const antd_1 = require("antd"); const i18next_1 = __importDefault(require("i18next")); const CommonButton_1 = __importDefault(require("../../components/common/CommonButton")); const constants_1 = require("../../canvas/constants"); class ImageMapFooterToolbar extends react_1.Component { constructor() { super(...arguments); this.state = { interactionMode: 'selection', }; 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); }; /* eslint-disable react/sort-comp, react/prop-types */ this.handlers = { selection: () => { if (this.props.canvasRef.handler.interactionHandler.isDrawingMode()) { return; } this.forceUpdate(); this.props.canvasRef.handler.interactionHandler.selection(); this.setState({ interactionMode: 'selection' }); }, grab: () => { if (this.props.canvasRef.handler.interactionHandler.isDrawingMode()) { return; } this.forceUpdate(); 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) { this.handlers.selection(); } else if (e.code === constants_1.code.KEY_W) { this.handlers.grab(); } }, }; } componentDidMount() { const { canvasRef } = this.props; this.waitForCanvasRender(canvasRef); } componentWillUnmount() { const { canvasRef } = this.props; this.detachEventListener(canvasRef); } render() { const { canvasRef, preview, zoomRatio, onChangePreview } = this.props; const { interactionMode } = this.state; const { selection, grab } = this.handlers; if (!canvasRef) { return null; } const zoomValue = parseInt((zoomRatio * 100).toFixed(2), 10); return (react_1.default.createElement(react_1.default.Fragment, null, react_1.default.createElement("div", { className: "rde-editor-footer-toolbar-interaction" }, react_1.default.createElement(antd_1.Button.Group, null, react_1.default.createElement(CommonButton_1.default, { type: interactionMode === 'selection' ? 'primary' : 'default', style: { borderBottomLeftRadius: '8px', borderTopLeftRadius: '8px' }, onClick: () => { selection(); }, icon: "mouse-pointer", tooltipTitle: i18next_1.default.t('action.selection') }), react_1.default.createElement(CommonButton_1.default, { type: interactionMode === 'grab' ? 'primary' : 'default', style: { borderBottomRightRadius: '8px', borderTopRightRadius: '8px' }, onClick: () => { grab(); }, tooltipTitle: i18next_1.default.t('action.grab'), icon: "hand-rock" }))), react_1.default.createElement("div", { className: "rde-editor-footer-toolbar-zoom" }, react_1.default.createElement(antd_1.Button.Group, null, react_1.default.createElement(CommonButton_1.default, { style: { borderBottomLeftRadius: '8px', borderTopLeftRadius: '8px' }, onClick: () => { canvasRef.handler.zoomHandler.zoomOut(); }, icon: "search-minus", tooltipTitle: i18next_1.default.t('action.zoom-out') }), react_1.default.createElement(CommonButton_1.default, { onClick: () => { canvasRef.handler.zoomHandler.zoomToFit(); }, tooltipTitle: i18next_1.default.t('action.fit'), icon: "expand" }), react_1.default.createElement(CommonButton_1.default, { style: { borderBottomRightRadius: '8px', borderTopRightRadius: '8px' }, onClick: () => { canvasRef.handler.zoomHandler.zoomIn(); }, icon: "search-plus", tooltipTitle: i18next_1.default.t('action.zoom-in') }))), react_1.default.createElement("div", { className: "rde-editor-footer-toolbar-preview" }, react_1.default.createElement(antd_1.Tooltip, { title: 'Xem trước' }, react_1.default.createElement(antd_1.Switch, { checked: preview, onChange: onChangePreview }))))); } } ImageMapFooterToolbar.propTypes = { canvasRef: prop_types_1.default.any, preview: prop_types_1.default.bool, onChangePreview: prop_types_1.default.func, zoomRatio: prop_types_1.default.number, }; exports.default = ImageMapFooterToolbar; //# sourceMappingURL=ImageMapFooterToolbar.js.map