Skip to content

Commit

Permalink
Merge pull request #195 from editor-js/update-tunes
Browse files Browse the repository at this point in the history
Replace block tunes HTML with config and update icons
  • Loading branch information
TatianaFomina authored Nov 29, 2022
2 parents 7edabc5 + eb2d287 commit 5ee4e1e
Show file tree
Hide file tree
Showing 15 changed files with 114 additions and 204 deletions.
6 changes: 3 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -118,15 +118,15 @@ actions: [
name: 'new_button',
icon: '<svg>...</svg>',
title: 'New Button',
toggle: true,
action: (name) => {
alert(`${name} button clicked`);
return false;
}
}
]
```
By adding `return true` or `return false` at the end of your custom actions, you can determine wether the icon in the tool's settings is toggled or not. This is helpfull for actions that do not toggle between states, but execute a different action.
If toggling is enabled, an `image-tool--[button name]` class will be appended and removed from the container.

**_NOTE:_** return value of `action` callback for settings whether action button should be toggled or not is *deprecated*. Consider using `toggle` option instead.

## Output data

Expand Down
5 changes: 4 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@editorjs/image",
"version": "2.6.2",
"version": "2.7.0",
"keywords": [
"codex editor",
"tool",
Expand Down Expand Up @@ -43,5 +43,8 @@
"svg-inline-loader": "^0.8.0",
"webpack": "^4.29.5",
"webpack-cli": "^3.2.3"
},
"dependencies": {
"@codexteam/icons": "^0.0.6"
}
}
11 changes: 11 additions & 0 deletions src/index.css
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,17 @@
}
}
}

.cdx-button {
display: flex;
align-items: center;
justify-content: center;

svg {
height: auto;
margin: 0 6px 0 0;
}
}
}

@keyframes image-preloader-spin {
Expand Down
74 changes: 56 additions & 18 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,13 +41,13 @@
* @property {string} file.url — image URL
*/

// eslint-disable-next-line
import css from './index.css';
import './index.css';

import Ui from './ui';
import Tunes from './tunes';
import ToolboxIcon from './svg/toolbox.svg';
import Uploader from './uploader';

import { IconAddBorder, IconStretch, IconAddBackground, IconPicture } from '@codexteam/icons';

/**
* @typedef {object} ImageConfig
* @description Config supported by Tool
Expand Down Expand Up @@ -93,11 +93,39 @@ export default class ImageTool {
*/
static get toolbox() {
return {
icon: ToolboxIcon,
icon: IconPicture,
title: 'Image',
};
}

/**
* Available image tools
*
* @returns {Array}
*/
static get tunes() {
return [
{
name: 'withBorder',
icon: IconAddBorder,
title: 'With border',
toggle: true,
},
{
name: 'stretched',
icon: IconStretch,
title: 'Stretch image',
toggle: true,
},
{
name: 'withBackground',
icon: IconAddBackground,
title: 'With background',
toggle: true,
},
];
}

/**
* @param {object} tool - tool properties got from editor.js
* @param {ImageToolData} tool.data - previously saved data
Expand Down Expand Up @@ -149,15 +177,6 @@ export default class ImageTool {
readOnly,
});

/**
* Module for working with tunes
*/
this.tunes = new Tunes({
api,
actions: this.config.actions,
onChange: (tuneName) => this.tuneToggled(tuneName),
});

/**
* Set saved state
*/
Expand Down Expand Up @@ -203,14 +222,33 @@ export default class ImageTool {
}

/**
* Makes buttons with tunes: add background, add border, stretch image
* Returns configuration for block tunes: add background, add border, stretch image
*
* @public
*
* @returns {Element}
* @returns {Array}
*/
renderSettings() {
return this.tunes.render(this.data);
// Merge default tunes with the ones that might be added by user
// @see https://github.com/editor-js/image/pull/49
const tunes = ImageTool.tunes.concat(this.config.actions);

return tunes.map(tune => ({
icon: tune.icon,
label: this.api.i18n.t(tune.title),
name: tune.name,
toggle: tune.toggle,
isActive: this.data[tune.name],
onActivate: () => {
/* If it'a user defined tune, execute it's callback stored in action property */
if (typeof tune.action === 'function') {
tune.action(tune.name);

return;
}
this.tuneToggled(tune.name);
},
}));
}

/**
Expand Down Expand Up @@ -311,7 +349,7 @@ export default class ImageTool {
this._data.caption = data.caption || '';
this.ui.fillCaption(this._data.caption);

Tunes.tunes.forEach(({ name: tune }) => {
ImageTool.tunes.forEach(({ name: tune }) => {
const value = typeof data[tune] !== 'undefined' ? data[tune] === true || data[tune] === 'true' : false;

this.setTune(tune, value);
Expand Down
1 change: 0 additions & 1 deletion src/svg/background.svg

This file was deleted.

1 change: 0 additions & 1 deletion src/svg/border.svg

This file was deleted.

3 changes: 0 additions & 3 deletions src/svg/button-icon.svg

This file was deleted.

1 change: 0 additions & 1 deletion src/svg/stretched.svg

This file was deleted.

1 change: 0 additions & 1 deletion src/svg/toolbox.svg

This file was deleted.

120 changes: 0 additions & 120 deletions src/tunes.js

This file was deleted.

28 changes: 3 additions & 25 deletions src/ui.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import buttonIcon from './svg/button-icon.svg';
import { IconPicture } from '@codexteam/icons';
import { make } from './utils/dom';

/**
* Class for working with UI:
Expand Down Expand Up @@ -110,7 +111,7 @@ export default class Ui {
createFileButton() {
const button = make('div', [ this.CSS.button ]);

button.innerHTML = this.config.buttonContent || `${buttonIcon} ${this.api.i18n.t('Select an Image')}`;
button.innerHTML = this.config.buttonContent || `${IconPicture} ${this.api.i18n.t('Select an Image')}`;

button.addEventListener('click', () => {
this.onSelectFile();
Expand Down Expand Up @@ -250,26 +251,3 @@ export default class Ui {
}
}

/**
* Helper for making Elements with attributes
*
* @param {string} tagName - new Element tag name
* @param {Array|string} classNames - list or name of CSS class
* @param {object} attributes - any attributes
* @returns {Element}
*/
export const make = function make(tagName, classNames = null, attributes = {}) {
const el = document.createElement(tagName);

if (Array.isArray(classNames)) {
el.classList.add(...classNames);
} else if (classNames) {
el.classList.add(classNames);
}

for (const attrName in attributes) {
el[attrName] = attributes[attrName];
}

return el;
};
10 changes: 1 addition & 9 deletions src/uploader.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import ajax from '@codexteam/ajax';
import isPromise from './utils/isPromise';

/**
* Module for file uploading. Handle 3 scenarios:
Expand Down Expand Up @@ -176,12 +177,3 @@ export default class Uploader {
}
}

/**
* Check if passed object is a Promise
*
* @param {*} object - object to check
* @returns {boolean}
*/
function isPromise(object) {
return object && typeof object.then === "function";
}
23 changes: 23 additions & 0 deletions src/utils/dom.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
/**
* Helper for making Elements with attributes
*
* @param {string} tagName - new Element tag name
* @param {Array|string} classNames - list or name of CSS class
* @param {object} attributes - any attributes
* @returns {Element}
*/
export function make(tagName, classNames = null, attributes = {}) {
const el = document.createElement(tagName);

if (Array.isArray(classNames)) {
el.classList.add(...classNames);
} else if (classNames) {
el.classList.add(classNames);
}

for (const attrName in attributes) {
el[attrName] = attributes[attrName];
}

return el;
};
Loading

0 comments on commit 5ee4e1e

Please sign in to comment.