mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 12:57:29 -08:00
🐛 fix external links in sidemenu (#1720)
* fix admin link clickability * fix bug when there are unsaved changes
This commit is contained in:
parent
715e41b590
commit
0cb96d6caa
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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: {
|
||||||
|
|
|
@ -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>
|
|
@ -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)',
|
||||||
},
|
},
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue