diff --git a/src/apps/backoffice/components/backoffice-header-logo.element.ts b/src/apps/backoffice/components/backoffice-header-logo.element.ts
index 3dd588cc84..e23427254c 100644
--- a/src/apps/backoffice/components/backoffice-header-logo.element.ts
+++ b/src/apps/backoffice/components/backoffice-header-logo.element.ts
@@ -73,12 +73,7 @@ export class UmbBackofficeHeaderLogoElement extends UmbLitElement {
Umbraco.com
- ${this._isUserAdmin
- ? html``
- : ''}
+
diff --git a/src/packages/sysinfo/components/sysinfo.element.ts b/src/packages/sysinfo/components/sysinfo.element.ts
index 63dfb31984..1cd7ccc38b 100644
--- a/src/packages/sysinfo/components/sysinfo.element.ts
+++ b/src/packages/sysinfo/components/sysinfo.element.ts
@@ -4,6 +4,7 @@ import { UmbTextStyles } from '@umbraco-cms/backoffice/style';
import { UmbModalBaseElement } from '@umbraco-cms/backoffice/modal';
import { UMB_NOTIFICATION_CONTEXT } from '@umbraco-cms/backoffice/notification';
import type { UUIButtonState } from '@umbraco-cms/backoffice/external/uui';
+import { UmbCurrentUserRepository } from '@umbraco-cms/backoffice/current-user';
type ServerKeyValue = {
name: string;
@@ -21,23 +22,18 @@ export class UmbSysinfoElement extends UmbModalBaseElement {
@state()
private _buttonState?: UUIButtonState;
- #serverKeyValues: Array = [];
- #sysinfoRepository = new UmbSysinfoRepository(this);
- #notificationContext?: typeof UMB_NOTIFICATION_CONTEXT.TYPE;
-
- constructor() {
- super();
-
- this.consumeContext(UMB_NOTIFICATION_CONTEXT, (context) => {
- this.#notificationContext = context;
- });
+ readonly #serverKeyValues: Array = [];
+ readonly #sysinfoRepository = new UmbSysinfoRepository(this);
+ readonly #currentUserRepository = new UmbCurrentUserRepository(this);
+ override connectedCallback(): void {
+ super.connectedCallback();
this.#populate();
}
async #populate() {
this._loading = true;
- this.#serverKeyValues = [];
+ this.#serverKeyValues.length = 0;
const [serverTroubleshooting, serverInformation] = await Promise.all([
this.#sysinfoRepository.requestTroubleShooting(),
@@ -45,7 +41,7 @@ export class UmbSysinfoElement extends UmbModalBaseElement {
]);
if (serverTroubleshooting) {
- this.#serverKeyValues = serverTroubleshooting.items;
+ this.#serverKeyValues.push(...serverTroubleshooting.items);
}
if (serverInformation) {
@@ -59,6 +55,22 @@ export class UmbSysinfoElement extends UmbModalBaseElement {
this.#serverKeyValues.push({ name: 'Browser language', data: navigator.language });
this.#serverKeyValues.push({ name: 'Browser location', data: location.href });
+ // User information
+ const { data: currentUser } = await this.#currentUserRepository.requestCurrentUser();
+ if (currentUser) {
+ this.#serverKeyValues.push({ name: 'User is admin', data: currentUser.isAdmin ? 'Yes' : 'No' });
+ this.#serverKeyValues.push({ name: 'User sections', data: currentUser.allowedSections.join(', ') });
+ this.#serverKeyValues.push({ name: 'User culture', data: currentUser.languageIsoCode });
+ this.#serverKeyValues.push({
+ name: 'User languages',
+ data: currentUser.hasAccessToAllLanguages ? 'All' : currentUser.languages.join(', '),
+ });
+ this.#serverKeyValues.push({
+ name: 'User document start nodes',
+ data: currentUser.documentStartNodeUniques.length ? currentUser.documentStartNodeUniques.join(', ') : 'None',
+ });
+ }
+
this._systemInformation = this.#renderServerKeyValues();
this._loading = false;
}
@@ -100,6 +112,8 @@ export class UmbSysinfoElement extends UmbModalBaseElement {
}
async #copyToClipboard() {
+ const notificationContext = await this.getContext(UMB_NOTIFICATION_CONTEXT);
+
try {
this._buttonState = 'waiting';
const text = `Umbraco system information
@@ -109,7 +123,7 @@ ${this._systemInformation}`;
await navigator.clipboard.writeText(textAsCode);
setTimeout(() => {
- this.#notificationContext?.peek('positive', {
+ notificationContext?.peek('positive', {
data: {
headline: 'System information',
message: this.localize.term('speechBubbles_copySuccessMessage'),
@@ -119,7 +133,7 @@ ${this._systemInformation}`;
}, 250);
} catch {
this._buttonState = 'failed';
- this.#notificationContext?.peek('danger', {
+ notificationContext?.peek('danger', {
data: {
headline: 'System information',
message: this.localize.term('speechBubbles_cannotCopyInformation'),