n8n-editor-ui
Version:
Workflow Editor UI for n8n
214 lines (213 loc) • 9.59 kB
JavaScript
import { C as computed, Cn as toDisplayString, D as createElementBlock, Gt as unref, It as ref, M as createVNode, P as defineComponent, T as createBlock, W as mergeProps, Z as onMounted, _ as Fragment, bt as withCtx, et as openBlock, it as renderList, j as createTextVNode, ot as resolveComponent, vn as normalizeClass, w as createBaseVNode } from "./vue.runtime.esm-bundler-tP5dCd7J.js";
import { gt as useI18n } from "./_MapCache-B159LOu5.js";
import { Vn as N8nText_default, Wn as N8nIcon_default, j as N8nMenuItem_default, ut as N8nLink_default } from "./src-BW7zuOU1.js";
import "./en-b3uD8cvU.js";
import "./preload-helper-CR0ecmWK.js";
import { t as __plugin_vue_export_helper_default } from "./_plugin-vue_export-helper-BwBpWJRZ.js";
import { y as useRouter } from "./truncate-Dc5upPom.js";
import "./icon-MZ_3fB_h.js";
import "./empty-4-N75rxI.js";
import { Fi as useUIStore, Ho as useSettingsStore, fr as isRouteLocationRaw, qn as hasPermission } from "./useTelemetry-C797TaYa.js";
import "./sanitize-html-CgpOSgtK.js";
import "./CalendarDate-DxkU3CHY.js";
import "./path-browserify-B5h_dP_u.js";
import { Io as VIEWS, Lo as ABOUT_MODAL_KEY } from "./constants-CX1ozgFz.js";
import "./merge-BArJwbQo.js";
import { r as useRootStore } from "./_baseOrderBy-DL6Sy5xK.js";
import "./dateformat-CMLc6OKJ.js";
import "./useDebounce-RgPaX171.js";
function useUserHelpers(router) {
const canUserAccessRouteByName = (name) => {
return canUserAccessRoute(router.resolve({ name }));
};
const canUserAccessRoute = (route) => {
const middleware = route.meta?.middleware;
const middlewareOptions = route.meta?.middlewareOptions;
if (!middleware) return true;
return hasPermission(middleware, middlewareOptions);
};
return { canUserAccessRouteByName };
}
var SettingsSidebar_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
__name: "SettingsSidebar",
emits: ["return"],
setup(__props, { emit: __emit }) {
const emit = __emit;
const router = useRouter();
const i18n = useI18n();
const { canUserAccessRouteByName } = useUserHelpers(router);
const rootStore = useRootStore();
const settingsStore = useSettingsStore();
const uiStore = useUIStore();
const sidebarMenuItems = computed(() => {
const menuItems = [
{
id: "settings-usage-and-plan",
icon: "chart-column-decreasing",
label: i18n.baseText("settings.usageAndPlan.title"),
position: "top",
available: canUserAccessRouteByName(VIEWS.USAGE),
route: { to: { name: VIEWS.USAGE } }
},
{
id: "settings-personal",
icon: "circle-user-round",
label: i18n.baseText("settings.personal"),
position: "top",
available: canUserAccessRouteByName(VIEWS.PERSONAL_SETTINGS),
route: { to: { name: VIEWS.PERSONAL_SETTINGS } }
},
{
id: "settings-users",
icon: "user-round",
label: i18n.baseText("settings.users"),
position: "top",
available: canUserAccessRouteByName(VIEWS.USERS_SETTINGS),
route: { to: { name: VIEWS.USERS_SETTINGS } }
},
{
id: "settings-project-roles",
icon: "user-round",
label: i18n.baseText("settings.projectRoles"),
position: "top",
available: canUserAccessRouteByName(VIEWS.PROJECT_ROLES_SETTINGS),
route: { to: { name: VIEWS.PROJECT_ROLES_SETTINGS } }
},
{
id: "settings-api",
icon: "plug",
label: i18n.baseText("settings.n8napi"),
position: "top",
available: settingsStore.isPublicApiEnabled && canUserAccessRouteByName(VIEWS.API_SETTINGS),
route: { to: { name: VIEWS.API_SETTINGS } }
},
{
id: "settings-external-secrets",
icon: "vault",
label: i18n.baseText("settings.externalSecrets.title"),
position: "top",
available: canUserAccessRouteByName(VIEWS.EXTERNAL_SECRETS_SETTINGS),
route: { to: { name: VIEWS.EXTERNAL_SECRETS_SETTINGS } }
},
{
id: "settings-source-control",
icon: "git-branch",
label: i18n.baseText("settings.sourceControl.title"),
position: "top",
available: canUserAccessRouteByName(VIEWS.SOURCE_CONTROL),
route: { to: { name: VIEWS.SOURCE_CONTROL } }
},
{
id: "settings-sso",
icon: "user-lock",
label: i18n.baseText("settings.sso"),
position: "top",
available: canUserAccessRouteByName(VIEWS.SSO_SETTINGS),
route: { to: { name: VIEWS.SSO_SETTINGS } }
},
{
id: "settings-ldap",
icon: "network",
label: i18n.baseText("settings.ldap"),
position: "top",
available: canUserAccessRouteByName(VIEWS.LDAP_SETTINGS),
route: { to: { name: VIEWS.LDAP_SETTINGS } }
},
{
id: "settings-workersview",
icon: "waypoints",
label: i18n.baseText("mainSidebar.workersView"),
position: "top",
available: settingsStore.isQueueModeEnabled && hasPermission(["rbac"], { rbac: { scope: "workersView:manage" } }),
route: { to: { name: VIEWS.WORKER_VIEW } }
}
];
menuItems.push({
id: "settings-log-streaming",
icon: "log-in",
label: i18n.baseText("settings.log-streaming"),
position: "top",
available: canUserAccessRouteByName(VIEWS.LOG_STREAMING_SETTINGS),
route: { to: { name: VIEWS.LOG_STREAMING_SETTINGS } }
});
menuItems.push({
id: "settings-community-nodes",
icon: "box",
label: i18n.baseText("settings.communityNodes"),
position: "top",
available: canUserAccessRouteByName(VIEWS.COMMUNITY_NODES),
route: { to: { name: VIEWS.COMMUNITY_NODES } }
});
menuItems.push({
id: "settings-migration-report",
icon: "list-checks",
label: i18n.baseText("settings.migrationReport"),
position: "top",
available: canUserAccessRouteByName(VIEWS.MIGRATION_REPORT),
route: { to: { name: VIEWS.MIGRATION_REPORT } }
});
const moduleItems = uiStore.settingsSidebarItems;
return menuItems.concat(moduleItems.filter((item) => !menuItems.some((m) => m.id === item.id)));
});
const visibleItems = computed(() => sidebarMenuItems.value.filter((item) => item.available));
return (_ctx, _cache) => {
return openBlock(), createElementBlock("div", { class: normalizeClass(_ctx.$style.container) }, [
createBaseVNode("div", {
class: normalizeClass(_ctx.$style.returnButton),
"data-test-id": "settings-back",
onClick: _cache[0] || (_cache[0] = ($event) => emit("return"))
}, [createBaseVNode("i", null, [createVNode(unref(N8nIcon_default), { icon: "arrow-left" })]), createVNode(unref(N8nText_default), { bold: "" }, {
default: withCtx(() => [createTextVNode(toDisplayString(unref(i18n).baseText("settings")), 1)]),
_: 1
})], 2),
createBaseVNode("div", { class: normalizeClass(_ctx.$style.items) }, [(openBlock(true), createElementBlock(Fragment, null, renderList(visibleItems.value, (item) => {
return openBlock(), createBlock(unref(N8nMenuItem_default), {
key: item.id,
item
}, null, 8, ["item"]);
}), 128))], 2),
createBaseVNode("div", { class: normalizeClass(_ctx.$style.versionContainer) }, [createVNode(unref(N8nLink_default), {
size: "small",
onClick: _cache[1] || (_cache[1] = ($event) => unref(uiStore).openModal(unref("about")))
}, {
default: withCtx(() => [createTextVNode(toDisplayString(unref(i18n).baseText("settings.version")) + " " + toDisplayString(unref(rootStore).versionCli), 1)]),
_: 1
})], 2)
], 2);
};
}
});
var SettingsSidebar_vue_vue_type_style_index_0_lang_module_default = {
container: "_container_189g8_123",
returnButton: "_returnButton_189g8_132",
items: "_items_189g8_143",
versionContainer: "_versionContainer_189g8_149"
};
var SettingsSidebar_default = /* @__PURE__ */ __plugin_vue_export_helper_default(SettingsSidebar_vue_vue_type_script_setup_true_lang_default, [["__cssModules", { "$style": SettingsSidebar_vue_vue_type_style_index_0_lang_module_default }]]);
var SettingsView_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
__name: "SettingsView",
setup(__props) {
const router = useRouter();
const previousRoute = ref();
function onReturn() {
const resolvedSettingsRoute = router.resolve({ name: VIEWS.SETTINGS });
const resolvedPreviousRoute = isRouteLocationRaw(previousRoute.value) ? router.resolve(previousRoute.value) : null;
const backRoute = !resolvedPreviousRoute || resolvedPreviousRoute.path.startsWith(resolvedSettingsRoute.path) ? { name: VIEWS.HOMEPAGE } : resolvedPreviousRoute;
router.push(backRoute);
}
onMounted(() => {
previousRoute.value = router.options.history.state.back;
});
return (_ctx, _cache) => {
const _component_RouterView = resolveComponent("RouterView");
return openBlock(), createElementBlock("div", { class: normalizeClass(_ctx.$style.container) }, [createVNode(SettingsSidebar_default, { onReturn }), createBaseVNode("div", { class: normalizeClass(_ctx.$style.contentContainer) }, [createBaseVNode("div", { class: normalizeClass(_ctx.$style.content) }, [createVNode(_component_RouterView, mergeProps({ name: "settingsView" }, _ctx.$attrs), null, 16)], 2)], 2)], 2);
};
}
});
var SettingsView_vue_vue_type_style_index_0_lang_module_default = {
container: "_container_93ml1_123",
contentContainer: "_contentContainer_93ml1_130 _container_93ml1_123",
content: "_content_93ml1_130"
};
var SettingsView_default = /* @__PURE__ */ __plugin_vue_export_helper_default(SettingsView_vue_vue_type_script_setup_true_lang_default, [["__cssModules", { "$style": SettingsView_vue_vue_type_style_index_0_lang_module_default }]]);
export { SettingsView_default as default };