UNPKG

plot-plan-designer

Version:

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

151 lines (150 loc) 8.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 (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 Icon_1 = __importDefault(require("../icon/Icon")); const flex_1 = require("../flex"); const i18next_1 = __importDefault(require("i18next")); let ImageMapList = /** @class */ (() => { class ImageMapList extends react_1.Component { constructor() { super(...arguments); this.renderActions = () => { var _a; const { canvasRef } = this.props; const idCropping = canvasRef ? ((_a = canvasRef.handler) === null || _a === void 0 ? void 0 : _a.interactionMode) === 'crop' : false; return (react_1.default.createElement(flex_1.Flex.Item, { className: "rde-canvas-list-actions", flex: "0 1 auto" }, react_1.default.createElement(flex_1.Flex, null, react_1.default.createElement(antd_1.Input.Search, { placeholder: i18next_1.default.t('placeholder.search-node') })), react_1.default.createElement(flex_1.Flex, { justifyContent: "space-between", alignItems: "center" }, react_1.default.createElement(flex_1.Flex, { flex: "1", justifyContent: "center" }, react_1.default.createElement(antd_1.Button, { className: "rde-action-btn", style: { width: '100%', height: 30 }, disabled: idCropping, onClick: (e) => canvasRef.handler.sendBackwards() }, react_1.default.createElement(Icon_1.default, { name: "arrow-up" }))), react_1.default.createElement(flex_1.Flex, { flex: "1", justifyContent: "center" }, react_1.default.createElement(antd_1.Button, { className: "rde-action-btn", style: { width: '100%', height: 30 }, disabled: idCropping, onClick: (e) => canvasRef.handler.bringForward() }, react_1.default.createElement(Icon_1.default, { name: "arrow-down" })))))); }; this.renderItem = () => { var _a; const { canvasRef, selectedItem } = this.props; const idCropping = canvasRef ? ((_a = canvasRef.handler) === null || _a === void 0 ? void 0 : _a.interactionMode) === 'crop' : false; return canvasRef ? canvasRef.canvas .getObjects() .filter((obj) => { if (obj.id === 'workarea') { return false; } return !!obj.id; }) .map((obj) => { let icon; let title = obj.trans ? i18next_1.default.t(`imagemap.descriptors.${obj.trans}`) : obj.name || obj.type; let prefix = 'fas'; if (obj.type === 'i-text') { icon = 'map-marker-alt'; } else if (obj.type === 'textbox') { icon = 'font'; } else if (obj.type === 'image') { icon = 'image'; } else if (obj.type === 'triangle') { icon = 'image'; } else if (obj.type === 'rect') { icon = 'image'; } else if (obj.type === 'circle') { icon = 'circle'; } else if (obj.type === 'polygon') { icon = 'draw-polygon'; } else if (obj.type === 'line') { icon = 'image'; } else if (obj.type === 'element') { icon = 'html5'; prefix = 'fab'; } else if (obj.type === 'iframe') { icon = 'window-maximize'; } else if (obj.type === 'video') { icon = 'video'; } else if (obj.type === 'svg') { icon = 'bezier-curve'; } else { icon = 'image'; // title = title ? title : 'Default'; } let className = 'rde-canvas-list-item'; if (selectedItem && selectedItem.id === obj.id) { className += ' selected-item'; } return (react_1.default.createElement(flex_1.Flex.Item, { key: obj.id, className: className, flex: "1", style: { cursor: 'pointer' }, onClick: () => canvasRef.handler.select(obj), onMouseDown: (e) => e.preventDefault(), onDoubleClick: (e) => { canvasRef.handler.zoomHandler.zoomToCenter(); } }, react_1.default.createElement(flex_1.Flex, { alignItems: "center" }, react_1.default.createElement(Icon_1.default, { className: "rde-canvas-list-item-icon", name: icon, size: 1.5, style: { width: 32 }, prefix: prefix }), react_1.default.createElement("div", { className: "rde-canvas-list-item-text" }, title), react_1.default.createElement(flex_1.Flex, { className: "rde-canvas-list-item-actions", flex: "1", justifyContent: "flex-end" }, react_1.default.createElement(antd_1.Button, { className: "rde-action-btn", shape: "circle", disabled: idCropping, onClick: (e) => { e.stopPropagation(); canvasRef.handler.inverseVisibleById(obj.id); } }, react_1.default.createElement(Icon_1.default, { name: "eye" })), react_1.default.createElement(antd_1.Button, { className: "rde-action-btn", shape: "circle", disabled: idCropping, onClick: (e) => { e.stopPropagation(); canvasRef.handler.duplicateById(obj.id); } }, react_1.default.createElement(Icon_1.default, { name: "clone" })), react_1.default.createElement(antd_1.Button, { className: "rde-action-btn", shape: "circle", disabled: idCropping, onClick: (e) => { e.stopPropagation(); canvasRef.handler.removeById(obj.id); } }, react_1.default.createElement(Icon_1.default, { name: "trash" })))))); }) : null; }; } render() { return (react_1.default.createElement(flex_1.Flex, { style: { height: '100%', backgroundColor: 'white' }, flexDirection: "column" }, this.renderActions(), react_1.default.createElement("div", { className: "rde-canvas-list-items" }, this.renderItem()))); } } ImageMapList.propTypes = { canvasRef: prop_types_1.default.any, selectedItem: prop_types_1.default.object, }; return ImageMapList; })(); exports.default = ImageMapList;