import forEachOwnProperties from 'tui-code-snippet/collection/forEachOwnProperties'; import commandFactory from '@/factory/command'; import { componentNames, rejectMessages, commandNames } from '@/consts'; const { TEXT } = componentNames; /** * Cached data for undo * @type {Object} */ let cachedUndoDataForSilent = null; /** * Make undoData * @param {object} styles - text styles * @param {Component} targetObj - text component * @returns {object} - undo data */ function makeUndoData(styles, targetObj) { const undoData = { object: targetObj, styles: {}, }; forEachOwnProperties(styles, (value, key) => { const undoValue = targetObj[key]; undoData.styles[key] = undoValue; }); return undoData; } const command = { name: commandNames.CHANGE_TEXT_STYLE, /** * Change text styles * @param {Graphics} graphics - Graphics instance * @param {number} id - object id * @param {Object} styles - text styles * @param {string} [styles.fill] Color * @param {string} [styles.fontFamily] Font type for text * @param {number} [styles.fontSize] Size * @param {string} [styles.fontStyle] Type of inclination (normal / italic) * @param {string} [styles.fontWeight] Type of thicker or thinner looking (normal / bold) * @param {string} [styles.textAlign] Type of text align (left / center / right) * @param {string} [styles.textDecoration] Type of line (underline / line-through / overline) * @param {boolean} isSilent - is silent execution or not * @returns {Promise} */ execute(graphics, id, styles, isSilent) { const textComp = graphics.getComponent(TEXT); const targetObj = graphics.getObject(id); if (!targetObj) { return Promise.reject(rejectMessages.noObject); } if (!this.isRedo) { const undoData = makeUndoData(styles, targetObj); cachedUndoDataForSilent = this.setUndoData(undoData, cachedUndoDataForSilent, isSilent); } return textComp.setStyle(targetObj, styles); }, /** * @param {Graphics} graphics - Graphics instance * @returns {Promise} */ undo(graphics) { const textComp = graphics.getComponent(TEXT); const { object: textObj, styles } = this.undoData; return textComp.setStyle(textObj, styles); }, }; commandFactory.register(command); export default command;