hrw-certificate-editor
Version:
Design Editor Tools with React.js + ant.design + fabric.js
119 lines • 5.91 kB
JavaScript
"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