mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-31 14:55:38 +03:00
9a0b72071d
refs https://github.com/TryGhost/Ghost/issues/8106, https://github.com/TryGhost/Ghost/issues/7429, requires https://github.com/TryGhost/Ghost/pull/8137 -Adds new "card" menus - Navigation with keyboard in both axis. - Search with keyboard in both menus. - Adds a "+" Menu for cards - Adds a "/" Menu for cards - if the block has content and it becomes a markdown or HTML Embed card then the content is included into the card. - Image and HR cards appear below the current section - Adds new toolbar with both inline and block styling. - Adds a new 'divider' card.
100 lines
3.0 KiB
JavaScript
100 lines
3.0 KiB
JavaScript
import Component from 'ember-component';
|
|
import computed from 'ember-computed';
|
|
import $ from 'jquery';
|
|
import layout from '../templates/components/koenig-toolbar-blockitem';
|
|
import Tools from '../options/default-tools';
|
|
|
|
export default Component.extend({
|
|
layout,
|
|
classNames: ['toolbar-block'],
|
|
tools: [],
|
|
isBlank: false,
|
|
|
|
toolbar: computed('tools.@each.selected', function () {
|
|
let postTools = [];
|
|
let selectedPostTools = [];
|
|
|
|
this.tools.forEach((tool) => {
|
|
if (tool.type === 'block' || (tool.type === 'card' && this.isBlank)) {
|
|
if (tool.selected) {
|
|
selectedPostTools.push(tool);
|
|
} else {
|
|
postTools.push(tool);
|
|
}
|
|
}
|
|
|
|
});
|
|
|
|
return selectedPostTools.concat(postTools);
|
|
}),
|
|
|
|
init() {
|
|
this._super(...arguments);
|
|
let editor = this.editor = this.get('editor');
|
|
this.tools = new Tools(editor, this);
|
|
|
|
this.iconURL = `${this.get('assetPath')}/tools/`;
|
|
},
|
|
|
|
didRender() {
|
|
let $this = this.$();
|
|
let {editor} = this;
|
|
let $editor = $(this.get('containerSelector')); // TODO this is part of Ghost-Admin
|
|
|
|
editor.cursorDidChange(() => {
|
|
|
|
// if there is no cursor:
|
|
if (!editor.range || !editor.range.head.section) {
|
|
$this.fadeOut();
|
|
return;
|
|
}
|
|
|
|
let element = editor.range.head.section.renderNode._element;
|
|
|
|
if (this._element === element) {
|
|
return;
|
|
}
|
|
|
|
// if the section is a blank section then we can change it to a card, otherwise we can't.
|
|
if (editor.range.head.section.isBlank) {
|
|
this.set('isBlank', true);
|
|
} else {
|
|
this.set('isBlank', false);
|
|
}
|
|
|
|
this.propertyWillChange('toolbar');
|
|
|
|
this.__state = 'normal';
|
|
|
|
let offset = this.$(element).position();
|
|
let edOffset = $editor.offset();
|
|
|
|
$this.css('top', offset.top + $editor.scrollTop() - edOffset.top - 5);
|
|
if (element.tagName.toLowerCase() === 'li') {
|
|
$this.css('left', this.$(element.parentNode).position().left + $editor.scrollLeft() - 90);
|
|
} else {
|
|
$this.css('left', offset.left + $editor.scrollLeft() - 90);
|
|
}
|
|
|
|
$this.fadeIn();
|
|
|
|
this._element = element;
|
|
|
|
this.tools.forEach((tool) => {
|
|
if (tool.hasOwnProperty('checkElements')) {
|
|
// if its a list we want to know what type
|
|
let sectionTagName = editor.activeSection._tagName === 'li' ? editor.activeSection.parent._tagName : editor.activeSection._tagName;
|
|
tool.checkElements(editor.activeMarkups.concat([{tagName: sectionTagName}]));
|
|
}
|
|
});
|
|
|
|
this.propertyDidChange('toolbar');
|
|
|
|
});
|
|
},
|
|
|
|
willDestroy() {
|
|
this.editor.destroy();
|
|
}
|
|
});
|