mirror of
https://github.com/portainer/portainer.git
synced 2025-07-24 15:59:41 +02:00
* refactor(sidebar): migrate sidebar to react [EE-2907] fixes [EE-2907] feat(sidebar): show label for help fix(sidebar): apply changes from ddExtension fix(sidebar): resolve conflicts style(ts): add explanation for ddExtension fix(sidebar): use enum for status refactor(sidebar): rename to EdgeComputeSidebar refactor(sidebar): removed the need of `ident` prop style(sidebar): add ref for mobile breakpoint refactor(app): document testing props refactor(sidebar): use single sidebar item refactor(sidebar): use section for nav refactor(sidebar): rename sidebarlink to link refactor(sidebar): memoize menu paths fix(kubectl-shell): infinite loop on hooks dependencies refactor(sidebar): use authorized element feat(k8s/shell): track open shell refactor(k8s/shell): remove memoization refactor(settings): move settings queries to queries fix(sidebar): close sidebar on mobile refactor(settings): use mutation helpers refactor(sidebar): remove memo refactor(sidebar): rename sidebar item for storybook refactor(sidebar): move to react gprefactor(sidebar): remove dependence on EndProvider feat(environments): rename settings type feat(kube): move kubeconfig button fix(sidebar): open submenus fix(sidebar): open on expand fix(sibebar): show kube shell correctly * fix(sidebar): import from react component * chore(tests): fix missing prop
56 lines
1.9 KiB
JavaScript
56 lines
1.9 KiB
JavaScript
import $ from 'jquery';
|
|
import feather from 'feather-icons';
|
|
import { PortainerEndpointTypes } from 'Portainer/models/endpoint/models';
|
|
|
|
/* @ngInject */
|
|
export function onStartupAngular($rootScope, $state, $interval, LocalStorage, EndpointProvider, SystemService, cfpLoadingBar, $transitions, HttpRequestHelper) {
|
|
EndpointProvider.initialize();
|
|
|
|
$rootScope.$state = $state;
|
|
const defaultTitle = document.title;
|
|
|
|
$transitions.onEnter({}, () => {
|
|
const endpoint = EndpointProvider.currentEndpoint();
|
|
if (endpoint) {
|
|
document.title = `${defaultTitle} | ${endpoint.Name}`;
|
|
}
|
|
});
|
|
|
|
// Workaround to prevent the loading bar from going backward
|
|
// https://github.com/chieffancypants/angular-loading-bar/issues/273
|
|
const originalSet = cfpLoadingBar.set;
|
|
cfpLoadingBar.set = function overrideSet(n) {
|
|
if (n > cfpLoadingBar.status()) {
|
|
originalSet.apply(cfpLoadingBar, arguments);
|
|
}
|
|
};
|
|
|
|
$transitions.onBefore({}, () => {
|
|
HttpRequestHelper.resetAgentHeaders();
|
|
});
|
|
|
|
$transitions.onSuccess({}, () => {
|
|
feather.replace();
|
|
});
|
|
|
|
// Keep-alive Edge endpoints by sending a ping request every minute
|
|
$interval(() => {
|
|
ping(EndpointProvider, SystemService);
|
|
}, 60 * 1000);
|
|
|
|
$(document).ajaxSend((event, jqXhr, jqOpts) => {
|
|
const type = jqOpts.type === 'POST' || jqOpts.type === 'PUT' || jqOpts.type === 'PATCH';
|
|
const hasNoContentType = jqOpts.contentType !== 'application/json' && jqOpts.headers && !jqOpts.headers['Content-Type'];
|
|
if (type && hasNoContentType) {
|
|
jqXhr.setRequestHeader('Content-Type', 'application/json');
|
|
}
|
|
jqXhr.setRequestHeader('Authorization', 'Bearer ' + LocalStorage.getJWT());
|
|
});
|
|
}
|
|
|
|
function ping(EndpointProvider, SystemService) {
|
|
const endpoint = EndpointProvider.currentEndpoint();
|
|
if (endpoint && endpoint.Type == PortainerEndpointTypes.EdgeAgentOnDockerEnvironment) {
|
|
SystemService.ping(endpoint.Id);
|
|
}
|
|
}
|