Skip to content

Commit

Permalink
fix: keep menubar in one line - prioritize entries
Browse files Browse the repository at this point in the history
Menubar entries with submenus cannot be moved to the more-button.
Prioritize them when picking the icons for the toolbar.
If they still do not fit - do not add them to the more button either
they do not work there.

This makes sure that the menubar fits in one line and does not overflow.

Still prioritizing `undo` and `bold` over `emoji` and `callout`.
The former ones are need fairly frequently while the latter not so often.
In addition mobile phones have an emoji picker in their text entry.

Signed-off-by: Max <max@nextcloud.com>
  • Loading branch information
max-nextcloud committed Apr 19, 2022
1 parent 3bc0d0b commit 2442970
Show file tree
Hide file tree
Showing 14 changed files with 58 additions and 40 deletions.
4 changes: 2 additions & 2 deletions js/editor-rich.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion js/editor-rich.js.map

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions js/editor.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion js/editor.js.map

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions js/text-files.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion js/text-files.js.map

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions js/text-public.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion js/text-public.js.map

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions js/text-text.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion js/text-text.js.map

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions js/text-viewer.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion js/text-viewer.js.map

Large diffs are not rendered by default.

36 changes: 14 additions & 22 deletions src/components/MenuBar.vue
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,9 @@
:multiple="true"
@change="onImageUploadFilePicked">
<div v-if="isRichEditor" ref="menubar" class="menubar-icons">
<template v-for="(icon, $index) in allIcons">
<template v-for="(icon) in icons">
<EmojiPicker v-if="icon.class === 'icon-emoji'"
v-show="icon.priority <= iconCount"
:key="icon.label"
class="menuitem-emoji"
@selectData="emojiObject => addEmoji(icon, emojiObject)">
Expand Down Expand Up @@ -68,14 +69,14 @@
</ActionButton>
</Actions>
<button v-else-if="icon.class"
v-show="$index < iconCount"
v-show="icon.priority <= iconCount"
:key="icon.label"
v-tooltip="getLabelAndKeys(icon)"
:class="getIconClasses(icon)"
:disabled="disabled(icon)"
@click="clickIcon(icon)" />
<template v-else>
<div v-show="$index < iconCount || !icon.class"
<div v-show="icon.priority <= iconCount"
:key="icon.label"
v-click-outside="() => hideChildMenu(icon)"
class="submenu">
Expand All @@ -90,16 +91,16 @@
</template>
<Actions @open="toggleChildMenu({ label: 'Remaining Actions' })"
@close="toggleChildMenu({ label: 'Remaining Actions' })">
<template v-for="(icon, $index) in allIcons">
<ActionButton v-if="icon.class && isHiddenInMenu($index) && !(icon.class === 'icon-emoji')"
<template v-for="(icon) in icons">
<ActionButton v-if="icon.class && isHiddenInMenu(icon) && !hasSubmenu(icon)"
:key="icon.class"
v-tooltip="getKeys(icon)"
:icon="icon.class"
:close-after-click="true"
@click="clickIcon(icon)">
{{ icon.label }}
</ActionButton>
<!--<template v-else-if="!icon.class && isHiddenInMenu($index)">
<!--<template v-else-if="!icon.class && isHiddenInMenu(icon)">
<ActionButton v-for="childIcon in icon.children"
:key="childIcon.class"
:icon="childIcon.class"
Expand Down Expand Up @@ -193,7 +194,7 @@ export default {
},
computed: {
isHiddenInMenu() {
return ($index) => $index - this.iconCount >= 0
return (icon) => icon.priority > this.iconCount
},
getIconClasses() {
return (icon) => {
Expand Down Expand Up @@ -226,18 +227,6 @@ export default {
return Object.prototype.hasOwnProperty.call(this.submenuVisibility, icon.label) ? this.submenuVisibility[icon.label] : false
}
},
allIcons() {
return [...this.icons, {
label: t('text', 'Insert image'),
class: 'icon-image',
}, {
label: t('text', 'Formatting help'),
class: 'icon-help',
click: () => {
this.$emit('show-help')
},
}]
},
childPopoverMenu() {
return (icons, parent) => {
return icons.map(icon => {
Expand Down Expand Up @@ -267,8 +256,7 @@ export default {
this.forceRecompute // eslint-disable-line
this.windowWidth // eslint-disable-line
const menuBarWidth = this.$refs.menubar && this.$refs.menubar.clientWidth > 200 ? this.$refs.menubar.clientWidth : 200
const iconCount = Math.max((Math.floor(menuBarWidth / 44) - 2), 0)
return iconCount - 1
return Math.max((Math.floor(menuBarWidth / 44) - 1), 0)
},
imagePath() {
return this.lastImagePath
Expand Down Expand Up @@ -303,7 +291,7 @@ export default {
},
clickIcon(icon) {
if (icon.click) {
return icon.click()
return icon.click(this)
}
// Some actions run themselves.
// others still need to have .run() called upon them.
Expand All @@ -319,6 +307,10 @@ export default {
hideChildMenu({ label }) {
this.$set(this.submenuVisibility, label, false)
},
hasSubmenu(icon) {
return icon.class === 'icon-emoji'
|| icon.children
},
toggleChildMenu({ label }) {
const lastValue = Object.prototype.hasOwnProperty.call(this.submenuVisibility, label) ? this.submenuVisibility[label] : false
this.$set(this.submenuVisibility, label, !lastValue)
Expand Down
26 changes: 26 additions & 0 deletions src/mixins/menubar.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,13 +27,15 @@ export default [
keyModifiers: ['ctrl'],
class: 'icon-undo',
action: (command) => command.undo(),
priority: 3,
},
{
label: t('text', 'Redo'),
keyChar: 'y',
keyModifiers: ['ctrl'],
class: 'icon-redo',
action: (command) => command.redo(),
priority: 11,
},
{
label: t('text', 'Bold'),
Expand All @@ -44,6 +46,7 @@ export default [
action: (command) => {
return command.toggleBold()
},
priority: 4,
},
{
label: t('text', 'Italic'),
Expand All @@ -54,6 +57,7 @@ export default [
action: (command) => {
return command.toggleItalic()
},
priority: 7,
},
{
label: t('text', 'Underline'),
Expand All @@ -64,6 +68,7 @@ export default [
action: (command) => {
return command.toggleUnderline()
},
priority: 14,
},
{
label: t('text', 'Strikethrough'),
Expand All @@ -74,6 +79,7 @@ export default [
action: (command) => {
return command.toggleStrike()
},
priority: 15,
},
{
label: t('text', 'Headings'),
Expand Down Expand Up @@ -130,6 +136,7 @@ export default [
},
},
],
priority: 1,
},
{
label: t('text', 'Unordered list'),
Expand All @@ -140,6 +147,7 @@ export default [
action: (command) => {
return command.toggleBulletList()
},
priority: 8,
},
{
label: t('text', 'Ordered list'),
Expand All @@ -150,12 +158,14 @@ export default [
action: (command) => {
return command.toggleOrderedList()
},
priority: 9,
},
{
label: t('text', 'ToDo list'),
class: 'icon-tasklist',
isActive: 'taskList',
action: (command) => command.toggleTaskList(),
priority: 10,
},
{
label: t('text', 'Blockquote'),
Expand All @@ -166,6 +176,7 @@ export default [
action: (command) => {
return command.toggleBlockquote()
},
priority: 12,
},
{
label: t('text', 'Callouts'),
Expand Down Expand Up @@ -204,6 +215,7 @@ export default [
},
},
],
priority: 5,
},
{
label: t('text', 'Code block'),
Expand All @@ -212,6 +224,7 @@ export default [
action: (command) => {
return command.toggleCodeBlock()
},
priority: 13,
},
{
label: t('text', 'Table'),
Expand All @@ -220,12 +233,25 @@ export default [
action: (command) => {
return command.insertTable()
},
priority: 16,
},
{
label: t('text', 'Emoji picker'),
class: 'icon-emoji',
action: (command, emojiObject) => {
return command.emoji(emojiObject)
},
priority: 6,
},
{
label: t('text', 'Insert image'),
class: 'icon-image',
priority: 2,
},
{
label: t('text', 'Formatting help'),
class: 'icon-help',
click: (view) => view.$emit('show-help'),
priority: 17,
},
]

0 comments on commit 2442970

Please sign in to comment.