From cc73c3fcf0ddbe67e424b1dcad27cb6840511175 Mon Sep 17 00:00:00 2001 From: Matthias Kestenholz Date: Fri, 31 May 2024 12:27:09 +0200 Subject: [PATCH] Replace the generic drag handle with plugin icons --- CHANGELOG.rst | 1 + .../static/content_editor/content_editor.css | 7 ++----- .../static/content_editor/content_editor.js | 13 +++++++++++++ 3 files changed, 16 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.rst b/CHANGELOG.rst index 4fa71d64..54095313 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -12,6 +12,7 @@ Next version - Completely revamped the plugin buttons control. It now doesn't take up any place on the side anymore but instead appears when clicking the insertion target. +- Added plugin icons to inlines instead of the generic drag handle. 6.5 (2024-05-16) diff --git a/content_editor/static/content_editor/content_editor.css b/content_editor/static/content_editor/content_editor.css index 4abf9a21..ed468633 100644 --- a/content_editor/static/content_editor/content_editor.css +++ b/content_editor/static/content_editor/content_editor.css @@ -107,12 +107,9 @@ h3[draggable] { cursor: move; } -.order-machine .inline-related > h3[draggable]::before { - content: "drag_indicator"; - font-family: "Material Icons"; - font-size: 24px; +.order-machine h3 .material-icons { position: relative; - top: -6px; + top: -4px; left: -2px; } diff --git a/content_editor/static/content_editor/content_editor.js b/content_editor/static/content_editor/content_editor.js index c6340d39..621d6b0f 100644 --- a/content_editor/static/content_editor/content_editor.js +++ b/content_editor/static/content_editor/content_editor.js @@ -117,6 +117,19 @@ django.jQuery(($) => { `, ) + const addPluginIconsToInlines = () => { + for (const plugin of ContentEditor.plugins) { + const fragment = document.createElement("template") + fragment.innerHTML = + plugin.button || 'extension' + const button = fragment.content.firstElementChild + for (const title of qsa(`.dynamic-${plugin.prefix} > h3`)) { + title.insertAdjacentElement("afterbegin", button.cloneNode(true)) + } + } + } + addPluginIconsToInlines() + const orderMachineWrapper = $(".order-machine-wrapper") const orderMachine = $(".order-machine") const machineEmptyMessage = $('