🐛 fix external links in sidemenu (#1720)

* fix admin link clickability

* fix bug when there are unsaved changes
This commit is contained in:
Mutasem Aldmour 2021-05-04 18:55:39 +03:00 committed by GitHub
parent 715e41b590
commit 0cb96d6caa
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 90 additions and 57 deletions

View file

@ -435,7 +435,7 @@ export type MenuItemPosition = 'top' | 'bottom';
export interface IMenuItem { export interface IMenuItem {
id: string; id: string;
type: MenuItemType; type: MenuItemType;
position: MenuItemPosition; position?: MenuItemPosition;
properties: ILinkMenuItemProperties; properties: ILinkMenuItemProperties;
} }

View file

@ -21,21 +21,7 @@
</a> </a>
</el-menu-item> </el-menu-item>
<el-menu-item <MenuItemsIterator :items="sidebarMenuTopItems" :root="true"/>
v-for="item in sidebarMenuTopItems"
:key="item.id"
:index="item.id"
>
<a
v-if="item.type === 'link'"
:href="item.properties.href"
:target="item.properties.newWindow ? '_blank' : '_self'"
class="primary-item"
>
<font-awesome-icon :icon="item.properties.icon" />
<span slot="title" class="item-title-root">{{ item.properties.title }}</span>
</a>
</el-menu-item>
<el-submenu index="workflow" title="Workflow"> <el-submenu index="workflow" title="Workflow">
<template slot="title"> <template slot="title">
@ -136,30 +122,8 @@
<span slot="title" class="item-title-root">Help</span> <span slot="title" class="item-title-root">Help</span>
</template> </template>
<el-menu-item index="help-documentation"> <MenuItemsIterator :items="helpMenuItems" />
<template slot="title">
<a href="https://docs.n8n.io" target="_blank">
<font-awesome-icon icon="book"/>
<span slot="title" class="item-title">Documentation</span>
</a>
</template>
</el-menu-item>
<el-menu-item index="help-forum">
<template slot="title">
<a href="https://community.n8n.io" target="_blank">
<font-awesome-icon icon="users"/>
<span slot="title" class="item-title">Forum</span>
</a>
</template>
</el-menu-item>
<el-menu-item index="help-examples">
<template slot="title">
<a href="https://n8n.io/workflows" target="_blank">
<font-awesome-icon icon="network-wired"/>
<span slot="title" class="item-title">Workflows</span>
</a>
</template>
</el-menu-item>
<el-menu-item index="help-about"> <el-menu-item index="help-about">
<template slot="title"> <template slot="title">
<font-awesome-icon class="about-icon" icon="info"/> <font-awesome-icon class="about-icon" icon="info"/>
@ -168,21 +132,7 @@
</el-menu-item> </el-menu-item>
</el-submenu> </el-submenu>
<el-menu-item <MenuItemsIterator :items="sidebarMenuBottomItems" :root="true"/>
v-for="item in sidebarMenuBottomItems"
:key="item.id"
:index="item.id"
>
<a
v-if="item.type === 'link'"
:href="item.properties.href"
:target="item.properties.newWindow ? '_blank' : '_self'"
class="primary-item"
>
<font-awesome-icon :icon="item.properties.icon" />
<span slot="title" class="item-title-root">{{ item.properties.title }}</span>
</a>
</el-menu-item>
</el-menu> </el-menu>
@ -192,6 +142,7 @@
</template> </template>
<script lang="ts"> <script lang="ts">
import Vue from 'vue'; import Vue from 'vue';
import { MessageBoxInputData } from 'element-ui/types/message-box'; import { MessageBoxInputData } from 'element-ui/types/message-box';
@ -219,6 +170,40 @@ import { workflowRun } from '@/components/mixins/workflowRun';
import { saveAs } from 'file-saver'; import { saveAs } from 'file-saver';
import mixins from 'vue-typed-mixins'; import mixins from 'vue-typed-mixins';
import MenuItemsIterator from './MainSidebarMenuItemsIterator.vue';
const helpMenuItems: IMenuItem[] = [
{
id: 'docs',
type: 'link',
properties: {
href: 'https://docs.n8n.io',
title: 'Documentation',
icon: 'book',
newWindow: true,
},
},
{
id: 'forum',
type: 'link',
properties: {
href: 'https://community.n8n.io',
title: 'Forum',
icon: 'users',
newWindow: true,
},
},
{
id: 'examples',
type: 'link',
properties: {
href: 'https://n8n.io/workflows',
title: 'Workflows',
icon: 'network-wired',
newWindow: true,
},
},
];
export default mixins( export default mixins(
genericHelpers, genericHelpers,
@ -237,6 +222,7 @@ export default mixins(
ExecutionsList, ExecutionsList,
WorkflowOpen, WorkflowOpen,
WorkflowSettings, WorkflowSettings,
MenuItemsIterator,
}, },
data () { data () {
return { return {
@ -250,6 +236,7 @@ export default mixins(
stopExecutionInProgress: false, stopExecutionInProgress: false,
workflowOpenDialogVisible: false, workflowOpenDialogVisible: false,
workflowSettingsDialogVisible: false, workflowSettingsDialogVisible: false,
helpMenuItems,
}; };
}, },
computed: { computed: {

View file

@ -0,0 +1,44 @@
<template>
<div>
<el-menu-item
v-for="item in items"
:key="item.id"
:index="item.id"
@click="onClick(item)"
>
<font-awesome-icon :icon="item.properties.icon" />
<span slot="title" :class="{'item-title-root': root, 'item-title': !root}">{{ item.properties.title }}</span>
</el-menu-item>
</div>
</template>
<script lang="ts">
import { IMenuItem } from '../Interface';
import Vue from 'vue';
export default Vue.extend({
name: 'MenuItemsIterator',
props: [
'items',
'root',
],
methods: {
onClick(item: IMenuItem) {
if (item && item.type === 'link' && item.properties) {
const href = item.properties.href;
if (!href) {
return;
}
if (item.properties.newWindow) {
window.open(href);
}
else {
window.location.assign(item.properties.href);
}
}
},
},
});
</script>

View file

@ -52,7 +52,7 @@ export const genericHelpers = mixins(showMessage).extend({
return true; return true;
}, },
startLoading () { startLoading (text?: string) {
if (this.loadingService !== null) { if (this.loadingService !== null) {
return; return;
} }
@ -60,7 +60,7 @@ export const genericHelpers = mixins(showMessage).extend({
this.loadingService = this.$loading( this.loadingService = this.$loading(
{ {
lock: true, lock: true,
text: 'Loading', text: text || 'Loading',
spinner: 'el-icon-loading', spinner: 'el-icon-loading',
background: 'rgba(255, 255, 255, 0.8)', background: 'rgba(255, 255, 255, 0.8)',
}, },

View file

@ -1453,6 +1453,8 @@ export default mixins(
(e || window.event).returnValue = confirmationMessage; //Gecko + IE (e || window.event).returnValue = confirmationMessage; //Gecko + IE
return confirmationMessage; //Gecko + Webkit, Safari, Chrome etc. return confirmationMessage; //Gecko + Webkit, Safari, Chrome etc.
} else { } else {
this.startLoading('Redirecting');
return; return;
} }
}); });