hrw-certificate-editor
Version:
Design Editor Tools with React.js + ant.design + fabric.js
134 lines • 6.92 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_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