refactor(ui/page-header): make docs url explicit [EE-5966] (#10411)

pull/10459/head
Chaim Lev-Ari 2023-10-11 10:38:57 +03:00 committed by GitHub
parent 9e57530bde
commit 35dfde70de
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
15 changed files with 215 additions and 404 deletions

View File

@ -47,6 +47,9 @@ function config($stateRegistryProvider: StateRegistry) {
component: 'containerInstancesView', component: 'containerInstancesView',
}, },
}, },
data: {
docs: '/user/aci/containers',
},
}; };
const containerInstance = { const containerInstance = {
@ -77,6 +80,9 @@ function config($stateRegistryProvider: StateRegistry) {
component: 'dashboardView', component: 'dashboardView',
}, },
}, },
data: {
docs: '/user/aci/dashboard',
},
}; };
$stateRegistryProvider.register(azure); $stateRegistryProvider.register(azure);

View File

@ -78,6 +78,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controllerAs: 'ctrl', controllerAs: 'ctrl',
}, },
}, },
data: {
docs: '/user/docker/configs',
},
}; };
var config = { var config = {
@ -112,6 +115,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
component: 'customTemplatesView', component: 'customTemplatesView',
}, },
}, },
data: {
docs: '/user/docker/templates/custom',
},
}; };
const customTemplatesNew = { const customTemplatesNew = {
@ -149,6 +155,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'DashboardController', controller: 'DashboardController',
}, },
}, },
data: {
docs: '/user/docker/dashboard',
},
}; };
var host = { var host = {
@ -159,6 +168,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
component: 'hostView', component: 'hostView',
}, },
}, },
data: {
docs: '/user/docker/host',
},
}; };
var hostBrowser = { var hostBrowser = {
@ -180,6 +192,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'EventsController', controller: 'EventsController',
}, },
}, },
data: {
docs: '/user/docker/events',
},
}; };
var images = { var images = {
@ -191,6 +206,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'ImagesController', controller: 'ImagesController',
}, },
}, },
data: {
docs: '/user/docker/images',
},
}; };
var image = { var image = {
@ -235,6 +253,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'NetworksController', controller: 'NetworksController',
}, },
}, },
data: {
docs: '/user/docker/networks',
},
}; };
var network = { var network = {
@ -262,6 +283,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
name: 'docker.nodes', name: 'docker.nodes',
url: '/nodes', url: '/nodes',
abstract: true, abstract: true,
data: {
docs: '/user/docker/swarm',
},
}; };
var node = { var node = {
@ -293,6 +317,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'SecretsController', controller: 'SecretsController',
}, },
}, },
data: {
docs: '/user/docker/secrets',
},
}; };
var secret = { var secret = {
@ -326,6 +353,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'ServicesController', controller: 'ServicesController',
}, },
}, },
data: {
docs: '/user/docker/services',
},
}; };
var service = { var service = {
@ -370,6 +400,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'StacksController', controller: 'StacksController',
}, },
}, },
data: {
docs: '/user/docker/stacks',
},
}; };
var stack = { var stack = {
@ -414,6 +447,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'SwarmController', controller: 'SwarmController',
}, },
}, },
data: {
docs: '/user/docker/swarm',
},
}; };
var swarmVisualizer = { var swarmVisualizer = {
@ -425,6 +461,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'SwarmVisualizerController', controller: 'SwarmVisualizerController',
}, },
}, },
data: {
docs: '/user/docker/swarm/cluster-visualizer',
},
}; };
var tasks = { var tasks = {
@ -464,6 +503,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'TemplatesController', controller: 'TemplatesController',
}, },
}, },
data: {
docs: '/user/docker/templates',
},
}; };
var volumes = { var volumes = {
@ -475,6 +517,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
controller: 'VolumesController', controller: 'VolumesController',
}, },
}, },
data: {
docs: '/user/docker/volumes',
},
}; };
var volume = { var volume = {
@ -518,6 +563,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
component: 'dockerFeaturesConfigurationView', component: 'dockerFeaturesConfigurationView',
}, },
}, },
data: {
docs: '/user/docker/host/setup',
},
}; };
const swarmFeaturesConfiguration = { const swarmFeaturesConfiguration = {
@ -528,6 +576,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
component: 'dockerFeaturesConfigurationView', component: 'dockerFeaturesConfigurationView',
}, },
}, },
data: {
docs: '/user/docker/swarm/setup',
},
}; };
const dockerRegistries = { const dockerRegistries = {
@ -538,6 +589,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
component: 'endpointRegistriesView', component: 'endpointRegistriesView',
}, },
}, },
data: {
docs: '/user/docker/host/registries',
},
}; };
const swarmRegistries = { const swarmRegistries = {
@ -548,6 +602,9 @@ angular.module('portainer.docker', ['portainer.app', reactModule]).config([
component: 'endpointRegistriesView', component: 'endpointRegistriesView',
}, },
}, },
data: {
docs: '/user/docker/swarm/registries',
},
}; };
const dockerRegistryAccess = { const dockerRegistryAccess = {

View File

@ -34,6 +34,9 @@ function config($stateRegistryProvider: StateRegistry) {
component: 'containersView', component: 'containersView',
}, },
}, },
data: {
docs: '/user/docker/containers',
},
}); });
$stateRegistryProvider.register({ $stateRegistryProvider.register({

View File

@ -22,6 +22,9 @@ angular
component: 'edgeGroupsView', component: 'edgeGroupsView',
}, },
}, },
data: {
docs: '/user/edge/groups',
},
}; };
const groupsNew = { const groupsNew = {
@ -52,6 +55,9 @@ angular
component: 'edgeStacksView', component: 'edgeStacksView',
}, },
}, },
data: {
docs: '/user/edge/stacks',
},
}; };
const stacksNew = { const stacksNew = {
@ -87,6 +93,9 @@ angular
component: 'edgeJobsView', component: 'edgeJobsView',
}, },
}, },
data: {
docs: '/user/edge/jobs',
},
}; };
const edgeJob = { const edgeJob = {
@ -127,6 +136,9 @@ angular
component: 'waitingRoomView', component: 'waitingRoomView',
}, },
}, },
data: {
docs: '/user/edge/devices',
},
}); });
} }

View File

@ -77,6 +77,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'kubernetesHelmApplicationView', component: 'kubernetesHelmApplicationView',
}, },
}, },
data: {
docs: '/user/kubernetes/helm',
},
}; };
const helmTemplates = { const helmTemplates = {
@ -97,6 +100,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'kubernetesServicesView', component: 'kubernetesServicesView',
}, },
}, },
data: {
docs: '/user/kubernetes/services',
},
}; };
const ingresses = { const ingresses = {
@ -107,6 +113,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'kubernetesIngressesView', component: 'kubernetesIngressesView',
}, },
}, },
data: {
docs: '/user/kubernetes/ingresses',
},
}; };
const ingressesCreate = { const ingressesCreate = {
@ -137,6 +146,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'kubernetesApplicationsView', component: 'kubernetesApplicationsView',
}, },
}, },
data: {
docs: '/user/kubernetes/applications',
},
}; };
const applicationCreation = { const applicationCreation = {
@ -232,11 +244,17 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
params: { params: {
tab: null, tab: null,
}, },
data: {
docs: '/user/kubernetes/configurations',
},
}; };
const configmaps = { const configmaps = {
name: 'kubernetes.configmaps', name: 'kubernetes.configmaps',
url: '/configmaps', url: '/configmaps',
abstract: true, abstract: true,
data: {
docs: '/user/kubernetes/configurations',
},
}; };
const configMapCreation = { const configMapCreation = {
@ -263,6 +281,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
name: 'kubernetes.secrets', name: 'kubernetes.secrets',
url: '/secrets', url: '/secrets',
abstract: true, abstract: true,
data: {
docs: '/user/kubernetes/configurations',
},
}; };
const secretCreation = { const secretCreation = {
@ -293,6 +314,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'kubernetesClusterView', component: 'kubernetesClusterView',
}, },
}, },
data: {
docs: '/user/kubernetes/cluster',
},
}; };
const node = { const node = {
@ -323,6 +347,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'kubernetesDashboardView', component: 'kubernetesDashboardView',
}, },
}, },
data: {
docs: '/user/kubernetes/dashboard',
},
}; };
const deploy = { const deploy = {
@ -343,6 +370,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'kubernetesResourcePoolsView', component: 'kubernetesResourcePoolsView',
}, },
}, },
data: {
docs: '/user/kubernetes/namespaces',
},
}; };
const resourcePoolCreation = { const resourcePoolCreation = {
@ -383,6 +413,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'kubernetesVolumesView', component: 'kubernetesVolumesView',
}, },
}, },
data: {
docs: '/user/kubernetes/volumes',
},
}; };
const volume = { const volume = {
@ -403,6 +436,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'endpointRegistriesView', component: 'endpointRegistriesView',
}, },
}, },
data: {
docs: '/user/kubernetes/cluster/registries',
},
}; };
const registriesAccess = { const registriesAccess = {
@ -423,6 +459,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
component: 'kubernetesConfigureView', component: 'kubernetesConfigureView',
}, },
}, },
data: {
docs: '/user/kubernetes/cluster/setup',
},
}; };
const endpointKubernetesSecurityConstraint = { const endpointKubernetesSecurityConstraint = {
@ -434,6 +473,9 @@ angular.module('portainer.kubernetes', ['portainer.app', registriesModule, custo
controller: 'KubernetesSecurityConstraintController', controller: 'KubernetesSecurityConstraintController',
}, },
}, },
data: {
docs: '/user/kubernetes/cluster/security',
},
}; };
$stateRegistryProvider.register(kubernetes); $stateRegistryProvider.register(kubernetes);

View File

@ -27,6 +27,9 @@ function config($stateRegistryProvider) {
component: 'kubeCustomTemplatesView', component: 'kubeCustomTemplatesView',
}, },
}, },
data: {
docs: '/user/kubernetes/templates',
},
}; };
const customTemplatesNew = { const customTemplatesNew = {

View File

@ -81,6 +81,9 @@ function config($stateRegistryProvider: StateRegistry) {
component: 'nomadDashboardView', component: 'nomadDashboardView',
}, },
}, },
data: {
docs: '/user/nomad/dashboard',
},
}; };
const jobs = { const jobs = {
@ -91,6 +94,9 @@ function config($stateRegistryProvider: StateRegistry) {
component: 'nomadJobsView', component: 'nomadJobsView',
}, },
}, },
data: {
docs: '/user/nomad/jobs',
},
}; };
const events = { const events = {

View File

@ -121,6 +121,9 @@ angular
controller: 'AccountController', controller: 'AccountController',
}, },
}, },
data: {
docs: '/user/account-settings',
},
}; };
const tokenCreation = { const tokenCreation = {
@ -174,6 +177,9 @@ angular
component: 'environmentsListView', component: 'environmentsListView',
}, },
}, },
data: {
docs: '/admin/environments',
},
}; };
var endpoint = { var endpoint = {
@ -263,6 +269,9 @@ angular
controller: 'GroupsController', controller: 'GroupsController',
}, },
}, },
data: {
docs: '/admin/environments/groups',
},
}; };
var group = { var group = {
@ -306,6 +315,9 @@ angular
component: 'homeView', component: 'homeView',
}, },
}, },
data: {
docs: '/user/home',
},
}; };
var init = { var init = {
@ -337,6 +349,9 @@ angular
controller: 'RegistriesController', controller: 'RegistriesController',
}, },
}, },
data: {
docs: '/admin/registries',
},
}; };
var registry = { var registry = {
@ -367,6 +382,9 @@ angular
component: 'settingsView', component: 'settingsView',
}, },
}, },
data: {
docs: '/admin/settings',
},
}; };
var settingsAuthentication = { var settingsAuthentication = {
@ -378,6 +396,9 @@ angular
controller: 'SettingsAuthenticationController', controller: 'SettingsAuthenticationController',
}, },
}, },
data: {
docs: '/admin/settings/authentication',
},
}; };
var settingsEdgeCompute = { var settingsEdgeCompute = {
@ -388,6 +409,9 @@ angular
component: 'settingsEdgeComputeView', component: 'settingsEdgeComputeView',
}, },
}, },
data: {
docs: '/admin/settings/edge',
},
}; };
var tags = { var tags = {
@ -399,6 +423,9 @@ angular
controller: 'TagsController', controller: 'TagsController',
}, },
}, },
data: {
docs: '/admin/environments/tags',
},
}; };
var users = { var users = {
@ -410,6 +437,9 @@ angular
controller: 'UsersController', controller: 'UsersController',
}, },
}, },
data: {
docs: '/admin/users',
},
}; };
var user = { var user = {

View File

@ -27,6 +27,9 @@ function config($stateRegistryProvider) {
component: 'rolesView', component: 'rolesView',
}, },
}, },
data: {
docs: '/admin/users/roles',
},
}; };
$stateRegistryProvider.register(roles); $stateRegistryProvider.register(roles);

View File

@ -29,6 +29,9 @@ function config($stateRegistryProvider: StateRegistry) {
component: 'teamsView', component: 'teamsView',
}, },
}, },
data: {
docs: '/admin/users/teams',
},
}); });
$stateRegistryProvider.register({ $stateRegistryProvider.register({

View File

@ -55,6 +55,9 @@ function config($stateRegistryProvider: StateRegistry) {
params: { params: {
localEndpointId: 0, localEndpointId: 0,
}, },
data: {
docs: '/admin/environments/add',
},
}); });
$stateRegistryProvider.register({ $stateRegistryProvider.register({

View File

@ -16,6 +16,9 @@ function config($stateRegistryProvider) {
component: 'authLogsView', component: 'authLogsView',
}, },
}, },
data: {
docs: '/admin/logs',
},
}); });
$stateRegistryProvider.register({ $stateRegistryProvider.register({
@ -26,6 +29,9 @@ function config($stateRegistryProvider) {
component: 'activityLogsView', component: 'activityLogsView',
}, },
}, },
data: {
docs: '/admin/logs/activity',
},
}); });
$stateRegistryProvider.register({ $stateRegistryProvider.register({
@ -39,5 +45,8 @@ function config($stateRegistryProvider) {
params: { params: {
id: '', id: '',
}, },
data: {
docs: '/admin/notifications',
},
}); });
} }

View File

@ -1,20 +1,19 @@
import { HelpCircle } from 'lucide-react'; import { HelpCircle } from 'lucide-react';
import clsx from 'clsx'; import clsx from 'clsx';
import { useCurrentStateAndParams } from '@uirouter/react';
import { getDocURL } from '@@/PageHeader/ContextHelp/docURLs';
import headerStyles from '../HeaderTitle.module.css'; import headerStyles from '../HeaderTitle.module.css';
import './ContextHelp.css'; import './ContextHelp.css';
export function ContextHelp() { export function ContextHelp() {
function onHelpClick() { const docsUrl = useDocsUrl();
const docURL = getDocURL();
window.open(docURL, '_blank');
}
return ( return (
<div className={clsx(headerStyles.menuButton)}> <div className={headerStyles.menuButton}>
<div <a
href={`https://docs.portainer.io${docsUrl}`}
target="_blank"
color="none"
className={clsx( className={clsx(
headerStyles.menuIcon, headerStyles.menuIcon,
'menu-icon', 'menu-icon',
@ -23,9 +22,30 @@ export function ContextHelp() {
'th-dark:text-gray-warm-7' 'th-dark:text-gray-warm-7'
)} )}
title="Help" title="Help"
rel="noreferrer"
> >
<HelpCircle className="lucide" onClick={onHelpClick} /> <HelpCircle className="lucide" />
</div> </a>
</div> </div>
); );
} }
function useDocsUrl(): string {
const { state } = useCurrentStateAndParams();
if (!state) {
return '';
}
const { data } = state;
if (
data &&
typeof data === 'object' &&
'docs' in data &&
typeof data.docs === 'string'
) {
return data.docs;
}
return '';
}

View File

@ -1,389 +0,0 @@
const docURLs = [
{
desc: 'Home',
docURL: 'https://docs.portainer.io/user/home',
locationRegex: /#!\/home/,
exmaples: ['#!/home'],
},
{
desc: 'Docker or Swarm / Dashboard',
docURL: 'https://docs.portainer.io/user/docker/dashboard',
locationRegex: /#!\/\d+\/docker\/dashboard/,
exmaples: ['#!/10/docker/dashboard'],
},
{
desc: 'Docker or Swarm / Custom Templates',
docURL: 'https://docs.portainer.io/user/docker/templates/custom',
locationRegex: /#!\/\d+\/docker\/templates\/custom/,
examples: ['#!/10/docker/templates/custom', '#!/10/docker/templates/custom/new?fileContent=&type=', '#!/10/docker/templates/custom/1'],
},
{
desc: 'Docker or Swarm / App Templates',
docURL: 'https://docs.portainer.io/user/docker/templates',
locationRegex: /#!\/\d+\/docker\/templates/,
examples: ['#!/10/docker/templates'],
},
{
desc: 'Docker or Swarm / Stacks',
docURL: 'https://docs.portainer.io/user/docker/stacks',
locationRegex: /#!\/\d+\/docker\/stacks/,
examples: ['#!/10/docker/stacks', '#!/10/docker/stacks/newstack', '#!/10/docker/stacks/s4?id=3&type=1&regular=true&external=false&orphaned=false'],
},
{
desc: 'Swarm / Services',
docURL: 'https://docs.portainer.io/user/docker/services',
locationRegex: /#!\/\d+\/docker\/(services|tasks)/,
examples: [
'#!/10/docker/services',
'#!/10/docker/services/zqp46vzoz5nnf39m6c518nlt8',
'#!/10/docker/services/zqp46vzoz5nnf39m6c518nlt8/logs',
'#!/10/docker/tasks/yyll0peo7ack4uaw2wom3nxso',
'#!/10/docker/tasks/yyll0peo7ack4uaw2wom3nxso/logs',
],
},
{
desc: 'Docker or Swarm / Containers',
docURL: 'https://docs.portainer.io/user/docker/containers',
locationRegex: /#!\/\d+\/docker\/containers/,
examples: [
'#!/10/docker/containers',
'#!/10/docker/containers/new',
'#!/10/docker/containers/new?from=49ff4ae03d10c57fe375f6968c48a6169a9852a6bfbb5137cd30c615d58188c1',
'#!/10/docker/containers/49ff4ae03d10c57fe375f6968c48a6169a9852a6bfbb5137cd30c615d58188c1',
'#!/10/docker/containers/49ff4ae03d10c57fe375f6968c48a6169a9852a6bfbb5137cd30c615d58188c1/logs',
'#!/10/docker/containers/49ff4ae03d10c57fe375f6968c48a6169a9852a6bfbb5137cd30c615d58188c1/inspect',
'#!/10/docker/containers/49ff4ae03d10c57fe375f6968c48a6169a9852a6bfbb5137cd30c615d58188c1/stats',
],
},
{
desc: 'Docker or Swarm / Images',
docURL: 'https://docs.portainer.io/user/docker/images',
locationRegex: /#!\/\d+\/docker\/images/,
examples: ['#!/10/docker/images', '#!/10/docker/images/build', '#!/10/docker/images/sha256:feb5d9fea6a5e9606aa995e879d862b825965ba48de054caab5ef356dc6b3412'],
},
{
desc: 'Docker or Swarm / Networks',
docURL: 'https://docs.portainer.io/user/docker/networks',
locationRegex: /#!\/\d+\/docker\/networks/,
examples: ['#!/10/docker/networks', '#!/10/docker/networks/new', '#!/10/docker/networks/db5732ff4a2c6df70a18530dba6abd8625f8e94c5fc5daabbcbab07377ee1044'],
},
{
desc: 'Docker or Swarm / Volumes',
docURL: 'https://docs.portainer.io/user/docker/volumes',
locationRegex: /#!\/\d+\/docker\/volumes/,
examples: ['#!/10/docker/volumes', '#!/10/docker/volumes/new', '#!/10/docker/volumes/153b46162f5bab9a7c9d2c8e1675115fcedd4c0ccdf5834159400750fa6b794c'],
},
{
desc: 'Swarm / Configs',
docURL: 'https://docs.portainer.io/user/docker/configs',
locationRegex: /#!\/\d+\/docker\/configs/,
examples: ['#!/10/docker/configs', '#!/10/docker/configs/new', '#!/10/docker/configs/azd0xc805l298jrgnadbnnzyv'],
},
{
desc: 'Swarm / Secrets',
docURL: 'https://docs.portainer.io/user/docker/secrets',
locationRegex: /#!\/\d+\/docker\/secrets/,
examples: ['#!/10/docker/secrets', '#!/10/docker/secrets/new', '#!/10/docker/secrets/tsoeeh7ln7g54g5qkk67eg4xe'],
},
{
desc: 'Docker or Swarm / Swarm / Cluster visualizer',
docURL: 'https://docs.portainer.io/user/docker/swarm/cluster-visualizer',
locationRegex: /#!\/\d+\/docker\/swarm\/visualizer/,
examples: ['#!/10/docker/swarm/visualizer'],
},
{
desc: 'Docker or Swarm / Swarm / Set up',
docURL: 'https://docs.portainer.io/user/docker/swarm/setup',
locationRegex: /#!\/\d+\/docker\/swarm\/feat-config/,
examples: ['#!/10/docker/feat-config'],
},
{
desc: 'Swarm / Swarm / Registries',
docURL: 'https://docs.portainer.io/user/docker/swarm/registries',
locationRegex: /#!\/\d+\/docker\/swarm\/registries/,
examples: ['#!/10/docker/registries'],
},
{
desc: 'Swarm / Swarm',
docURL: 'https://docs.portainer.io/user/docker/swarm',
locationRegex: /#!\/\d+\/docker\/(swarm|nodes)/,
examples: ['#!/10/docker/swarm', '#!/10/docker/nodes/nd694yepzgms1j8y7kv3lpcc3'],
},
{
desc: 'Docker / Events',
docURL: 'https://docs.portainer.io/user/docker/events',
locationRegex: /#!\/\d+\/docker\/events/,
examples: ['#!/10/docker/events'],
},
{
desc: 'Docker / Host / Registries',
docURL: 'https://docs.portainer.io/user/docker/host/registries',
locationRegex: /#!\/\d+\/docker\/host\/registries/,
examples: ['#!/10/docker/registries'],
},
{
desc: 'Docker / Host / Setup',
docURL: 'https://docs.portainer.io/user/docker/host/setup',
locationRegex: /#!\/\d+\/docker\/host\/feat-config/,
examples: ['#!/10/docker/feat-config'],
},
{
desc: 'Docker / Host',
docURL: 'https://docs.portainer.io/user/docker/host',
locationRegex: /#!\/\d+\/docker\/host/,
examples: ['#!/10/docker/host'],
},
{
desc: 'Kubernetes / Dashboard',
docURL: 'https://docs.portainer.io/user/kubernetes/dashboard',
locationRegex: /#!\/\d+\/kubernetes\/dashboard/,
examples: ['#!/1/kubernetes/dashboard'],
},
{
desc: 'Kubernetes / Custom Templates',
docURL: 'https://docs.portainer.io/user/kubernetes/templates',
locationRegex: /#!\/\d+\/kubernetes\/templates\/custom/,
examples: ['#!/1/kubernetes/templates/custom', '#!/1/kubernetes/templates/custom/new?fileContent='],
},
{
desc: 'Kubernetes / Namespaces',
docURL: 'https://docs.portainer.io/user/kubernetes/namespaces',
locationRegex: /#!\/\d+\/kubernetes\/pools/,
examples: ['#!/1/kubernetes/pools', '#!/1/kubernetes/pools/new', '#!/1/kubernetes/deploy?templateId=', '#!/1/kubernetes/pools/default'],
},
{
desc: 'Kubernetes / Helm',
docURL: 'https://docs.portainer.io/user/kubernetes/helm',
locationRegex: /#!\/\d+\/kubernetes\/templates\/helm/,
examples: ['#!/1/kubernetes/templates/helm'],
},
{
desc: 'Kubernetes / Applications',
docURL: 'https://docs.portainer.io/user/kubernetes/applications',
locationRegex: /#!\/\d+\/kubernetes\/applications/,
examples: ['#!/1/kubernetes/applications', '#!/1/kubernetes/applications/new', '#!/1/kubernetes/deploy?templateId=', '#!/1/kubernetes/applications/metallb-system/controller'],
},
{
desc: 'Kubernetes / Services',
docURL: 'https://docs.portainer.io/user/kubernetes/services',
locationRegex: /#!\/\d+\/kubernetes\/services/,
examples: ['#!/1/kubernetes/services'],
},
{
desc: 'Kubernetes / Ingresses',
docURL: 'https://docs.portainer.io/user/kubernetes/ingresses',
locationRegex: /#!\/\d+\/kubernetes\/ingresses/,
examples: ['#!/1/kubernetes/ingresses'],
},
{
desc: 'Kubernetes / ConfigMaps & Secrets',
docURL: 'https://docs.portainer.io/user/kubernetes/configurations',
locationRegex: /#!\/\d+\/kubernetes\/configurations/,
examples: ['#!/1/kubernetes/configurations', '#!/1/kubernetes/configurations/new', '#!/1/kubernetes/configurations/metallb-system/config'],
},
{
desc: 'Kubernetes / Volumes',
docURL: 'https://docs.portainer.io/user/kubernetes/volumes',
locationRegex: /#!\/\d+\/kubernetes\/volumes/,
examples: ['#!/1/kubernetes/volumes'],
},
{
desc: 'Kubernetes / Cluster / Set up',
docURL: 'https://docs.portainer.io/user/kubernetes/cluster/setup',
locationRegex: /#!\/\d+\/kubernetes\/cluster\/configure/,
examples: ['#!/1/kubernetes/cluster/configure'],
},
{
desc: 'Kubernetes / Cluster / Security constraints',
docURL: 'https://docs.portainer.io/user/kubernetes/cluster/security',
locationRegex: /#!\/\d+\/kubernetes\/cluster\/securityConstraint/,
examples: ['#!/1/kubernetes/cluster/securityConstraint'],
},
{
desc: 'Kubernetes / Cluster',
docURL: 'https://docs.portainer.io/user/kubernetes/cluster',
locationRegex: /#!\/\d+\/kubernetes\/cluster/,
examples: ['#!/1/kubernetes/cluster', '#!/1/kubernetes/cluster/ip-10-138-11-102', '#!/1/kubernetes/cluster/ip-10-138-11-102/stats'],
},
{
desc: 'Kubernetes / Cluster / Registries',
docURL: 'https://docs.portainer.io/user/kubernetes/cluster/registries',
locationRegex: /#!\/\d+\/kubernetes\/registries/,
examples: ['#!/1/kubernetes/registries'],
},
{
desc: 'Azure ACI / Dashboard',
docURL: 'https://docs.portainer.io/user/aci/dashboard',
locationRegex: /#!\/\d+\/azure\/dashboard/,
examples: ['#!/26/azure/dashboard'],
},
{
desc: 'Azure ACI / Container instances',
docURL: 'https://docs.portainer.io/user/aci/containers',
locationRegex: /#!\/\d+\/azure\/containerinstances/,
examples: ['#!/26/azure/containerinstances'],
},
{
desc: 'Edge Compute / Edge Devices',
docURL: 'https://docs.portainer.io/user/edge/devices',
locationRegex: /#!\/edge\/devices/,
examples: ['#!/edge/devices', '#!/edge/devices/waiting-room'],
},
{
desc: 'Edge Compute / Edge Groups',
docURL: 'https://docs.portainer.io/user/edge/groups',
locationRegex: /#!\/edge\/groups/,
examples: ['#!/edge/groups', '#!/edge/groups/new'],
},
{
desc: 'Edge Compute / Edge Stacks ',
docURL: 'https://docs.portainer.io/user/edge/stacks',
locationRegex: /#!\/edge\/stacks/,
examples: ['#!/edge/stacks', '#!/edge/stacks/new'],
},
{
desc: 'Edge Compute / Edge Jobs',
docURL: 'https://docs.portainer.io/user/edge/jobs',
locationRegex: /#!\/edge\/jobs/,
examples: ['#!/edge/jobs', '#!/edge/jobs/new'],
},
{
desc: 'Edge Compute / Edge Configurations',
docURL: 'https://docs.portainer.io/user/edge/configurations',
locationRegex: /#!\/edge\/configurations/,
examples: ['#!/edge/configurations', '#!/edge/configurations/new'],
},
{
desc: 'Nomad / Dashboard',
docURL: 'https://docs.portainer.io/user/nomad/dashboard',
locationRegex: /#!\/\d+\/nomad\/dashboard/,
examples: ['#!/2/nomad/dashboard'],
},
{
desc: 'Nomad / Nomad Jobs',
docURL: 'https://docs.portainer.io/user/nomad/jobs',
locationRegex: /#!\/\d+\/nomad\/jobs/,
examples: [
'#!/2/nomad/jobs',
'#!/2/nomad/jobs/portainer-agent/tasks/portainer-agent/allocations/acdbf08e-34af-9b8a-cc84-7dc202bf1fcf/events?namespace=default',
'#!/2/nomad/jobs/portainer-agent/tasks/portainer-agent/allocations/acdbf08e-34af-9b8a-cc84-7dc202bf1fcf/logs?namespace=default',
],
},
{
desc: 'Account Settings',
docURL: 'https://docs.portainer.io/user/account-settings',
locationRegex: /#!\/account/,
examples: ['#!/account', '#!/account/tokens/new'],
},
{
desc: 'Settings / Users',
docURL: 'https://docs.portainer.io/admin/users',
locationRegex: /#!\/users/,
examples: ['#!/users', '#!/users/1'],
},
{
desc: 'Settings / Users / Teams',
docURL: 'https://docs.portainer.io/admin/users/teams',
locationRegex: /#!\/teams/,
examples: ['#!/teams', '#!/teams/1'],
},
{
desc: 'Settings / Users / Roles',
docURL: 'https://docs.portainer.io/admin/users/roles',
locationRegex: /#!\/roles/,
examples: ['#!/roles'],
},
{
desc: 'Settings / Environments',
docURL: 'https://docs.portainer.io/admin/environments',
locationRegex: /#!\/endpoints/,
examples: ['#!/endpoints', '#!/endpoints/10', '#!/endpoints/10/access'],
},
{
desc: 'Settings / Environments / Groups',
docURL: 'https://docs.portainer.io/admin/environments/groups',
locationRegex: /#!\/groups/,
examples: ['#!/groups', '#!/groups/new', '#!/groups/3', '#!/groups/3/access'],
},
{
desc: 'Settings / Environments / Tags',
docURL: 'https://docs.portainer.io/admin/environments/tags',
locationRegex: /#!\/tags/,
examples: ['#!/tags'],
},
{
desc: 'Settings / Registries',
docURL: 'https://docs.portainer.io/admin/registries',
locationRegex: /#!\/registries/,
examples: [
'#!/registries',
'#!/registries/new',
'#!/registries/1',
'#!/registries/1/repositories',
'#!/registries/1/configure',
'#!/registries/5/portainer.demo~2Fportainerregistrytesting~2Falpine',
'#!/registries/5/portainer.demo~2Fportainerregistrytesting~2Falpine/jfadelhaye',
],
},
{
desc: 'Settings / Licenses',
docURL: 'https://docs.portainer.io/admin/licenses',
locationRegex: /#!\/licenses/,
examples: ['#!/licenses', '#!/licenses/licenses/new'],
},
{
desc: 'Settings / Authentication logs',
docURL: 'https://docs.portainer.io/admin/logs',
locationRegex: /#!\/auth-logs/,
examples: ['#!/auth-logs'],
},
{
desc: 'Settings / Authentication logs / Activity logs',
docURL: 'https://docs.portainer.io/admin/logs/activity',
locationRegex: /#!\/activity-logs/,
examples: ['#!/activity-logs'],
},
{
desc: 'Settings / Settings / Authentication',
docURL: 'https://docs.portainer.io/admin/settings/authentication',
locationRegex: /#!\/settings\/auth/,
examples: ['#!/settings/auth'],
},
{
desc: 'Settings / Settings / Notifications',
docURL: 'https://docs.portainer.io/admin/notifications',
locationRegex: /#!\/notifications/,
examples: ['#!/notifications'],
},
{
desc: 'Settings / Settings / Cloud settings',
docURL: 'https://docs.portainer.io/admin/settings/cloud',
locationRegex: /#!\/settings\/cloud/,
examples: ['#!/settings/cloud', '#!/settings/cloud/credentials/new', '#!/settings/cloud/credentials/1'],
},
{
desc: 'Settings / Settings / Edge Compute',
docURL: 'https://docs.portainer.io/admin/settings/edge',
locationRegex: /#!\/settings\/edge/,
examples: ['#!/settings/edge'],
},
{
desc: 'Settings / Settings',
docURL: 'https://docs.portainer.io/admin/settings',
locationRegex: /#!\/settings/,
examples: ['#!/settings'],
},
];
const DEFAULT_DOC_URL = 'https://docs.portainer.io';
export function getDocURL() {
const hash = window.location.hash;
for (let i = 0; i < docURLs.length; i += 1) {
const docURL = docURLs[i];
if (hash.match(docURL.locationRegex)) {
return docURL.docURL;
}
}
return DEFAULT_DOC_URL;
}

View File

@ -1,5 +1,6 @@
import { useRouter } from '@uirouter/react'; import { useRouter } from '@uirouter/react';
import { RefreshCw } from 'lucide-react'; import { RefreshCw } from 'lucide-react';
import { PropsWithChildren } from 'react';
import { Button } from '../buttons'; import { Button } from '../buttons';
@ -24,13 +25,10 @@ export function PageHeader({
reload, reload,
loading, loading,
onReload, onReload,
}: Props) { children,
}: PropsWithChildren<Props>) {
const router = useRouter(); const router = useRouter();
function onClickedRefresh() {
return onReload ? onReload() : router.stateService.reload();
}
return ( return (
<HeaderContainer id={id}> <HeaderContainer id={id}>
<Breadcrumbs breadcrumbs={breadcrumbs} /> <Breadcrumbs breadcrumbs={breadcrumbs} />
@ -47,7 +45,12 @@ export function PageHeader({
<RefreshCw className="icon" /> <RefreshCw className="icon" />
</Button> </Button>
)} )}
{children}
</HeaderTitle> </HeaderTitle>
</HeaderContainer> </HeaderContainer>
); );
function onClickedRefresh() {
return onReload ? onReload() : router.stateService.reload();
}
} }