mirror of
https://github.com/redphx/better-xcloud.git
synced 2025-06-07 16:17:20 +02:00
94 lines
3.8 KiB
TypeScript
Executable File
94 lines
3.8 KiB
TypeScript
Executable File
import { isFullVersion } from "@macros/build" with { type: "macro" };
|
|
|
|
import { SCRIPT_VERSION, STATES } from "@utils/global";
|
|
import { createButton, ButtonStyle, CE } from "@utils/html";
|
|
import { BxIcon } from "@utils/bx-icon";
|
|
import { getPreferredServerRegion } from "@utils/region";
|
|
import { RemotePlayManager } from "@/modules/remote-play-manager";
|
|
import { t } from "@utils/translation";
|
|
import { SettingsDialog } from "./dialog/settings-dialog";
|
|
import { GlobalPref } from "@/enums/pref-keys";
|
|
import { getGlobalPref } from "@/utils/pref-utils";
|
|
import { BxLogger } from "@/utils/bx-logger";
|
|
import { BxEventBus } from "@/utils/bx-event-bus";
|
|
|
|
export class HeaderSection {
|
|
private static instance: HeaderSection;
|
|
public static getInstance = () => HeaderSection.instance ?? (HeaderSection.instance = new HeaderSection());
|
|
private readonly LOG_TAG = 'HeaderSection';
|
|
|
|
private $btnRemotePlay: HTMLElement | null;
|
|
private $btnSettings: HTMLElement;
|
|
private $buttonsWrapper: HTMLElement;
|
|
|
|
constructor() {
|
|
BxLogger.info(this.LOG_TAG, 'constructor()');
|
|
|
|
if (isFullVersion()) {
|
|
this.$btnRemotePlay = createButton({
|
|
classes: ['bx-header-remote-play-button', 'bx-gone'],
|
|
icon: BxIcon.REMOTE_PLAY,
|
|
title: t('remote-play'),
|
|
style: ButtonStyle.GHOST | ButtonStyle.FOCUSABLE | ButtonStyle.CIRCULAR,
|
|
onClick: e => RemotePlayManager.getInstance()?.togglePopup(),
|
|
});
|
|
} else {
|
|
this.$btnRemotePlay = null;
|
|
}
|
|
|
|
let $btnSettings = this.$btnSettings = createButton({
|
|
classes: ['bx-header-settings-button', 'bx-gone'],
|
|
label: t('better-xcloud'),
|
|
style: ButtonStyle.FROSTED | ButtonStyle.DROP_SHADOW | ButtonStyle.FOCUSABLE | ButtonStyle.FULL_HEIGHT,
|
|
onClick: e => SettingsDialog.getInstance().show(),
|
|
});
|
|
|
|
this.$buttonsWrapper = CE('div', false,
|
|
getGlobalPref(GlobalPref.REMOTE_PLAY_ENABLED) ? this.$btnRemotePlay : null,
|
|
this.$btnSettings,
|
|
);
|
|
|
|
BxEventBus.Script.on('xcloud.server', ({status}) => {
|
|
if (status === 'ready') {
|
|
STATES.isSignedIn = true;
|
|
|
|
// Show server name
|
|
$btnSettings.querySelector('span')!.textContent = getPreferredServerRegion(true) || t('better-xcloud');
|
|
const PREF_LATEST_VERSION = getGlobalPref(GlobalPref.VERSION_LATEST);
|
|
// Show new update status
|
|
if (!SCRIPT_VERSION.includes('beta') && PREF_LATEST_VERSION && PREF_LATEST_VERSION !== SCRIPT_VERSION) {
|
|
$btnSettings.setAttribute('data-update-available', 'true');
|
|
}
|
|
} else if (status === 'unavailable') {
|
|
STATES.supportedRegion = false;
|
|
|
|
// Open Settings dialog on Unsupported page
|
|
const $unsupportedPage = document.querySelector<HTMLElement>('div[class^=UnsupportedMarketPage-module__container]');
|
|
if ($unsupportedPage) {
|
|
SettingsDialog.getInstance().show();
|
|
}
|
|
}
|
|
|
|
$btnSettings.classList.remove('bx-gone');
|
|
});
|
|
}
|
|
|
|
checkHeader = () => {
|
|
let $target = document.querySelector('#PageContent div[class*=EdgewaterHeader-module__rightSectionSpacing]');
|
|
if (!$target) {
|
|
$target = document.querySelector('div[class^=UnsupportedMarketPage-module__buttons]');
|
|
}
|
|
|
|
// Add the Settings button to the web page
|
|
$target?.appendChild(this.$buttonsWrapper);
|
|
|
|
if (!STATES.isSignedIn) {
|
|
BxEventBus.Script.emit('xcloud.server', { status: 'signed-out' });
|
|
}
|
|
}
|
|
|
|
showRemotePlayButton() {
|
|
this.$btnRemotePlay?.classList.remove('bx-gone');
|
|
}
|
|
}
|