123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211 |
- const presence = new Presence({
- clientId: "883446187099840562",
- });
- async function getStrings() {
- return presence.getStrings(
- {
- play: "general.playing",
- pause: "general.paused",
- live: "general.live",
- },
- await presence.getSetting<string>("lang").catch(() => "en")
- );
- }
- let channel: string,
- channelTimestamp: number,
- strings: Awaited<ReturnType<typeof getStrings>>,
- oldLang: string = null;
- presence.on("UpdateData", async () => {
- let presenceData: PresenceData = {
- largeImageKey:
- "https://cdn.rcd.gg/PreMiD/websites/C/Cosmote%20TV/assets/logo.png",
- };
- const pages: Record<string, PresenceData> = {
- "#!": {
- details: "Browsing",
- },
- search: {
- details: "Searching",
- state:
- document.querySelector<HTMLInputElement>("#searchFieldInput")?.value,
- smallImageKey: Assets.Search,
- smallImageText: "Searching",
- },
- loginSplash: {
- details: "Logging In",
- },
- channels: {
- details: "Browsing Channels",
- },
- watchlist: {
- details: "Viewing Watchlist",
- },
- settings: {
- details: "Viewing Settings",
- },
- privacy: {
- details: "Viewing Privacy Policy",
- },
- livetv: {
- details: "Browsing Live TV",
- },
- inbox: {
- details: "Viewing Inbox",
- },
- "livetv/replaytv": {
- details: "Browsing Replay TV",
- },
- "livetv/guide": {
- details: "Browsing Live TV Guide",
- },
- "onDemand/FILMS": {
- details: "Browsing Films",
- },
- "onDemand/SERIES": {
- details: "Browsing Series",
- },
- "onDemand/MOVIES_CLUB": {
- details: "Browsing Movies Club",
- },
- "onDemand/SPORTS": {
- details: "Browsing Sports",
- },
- "onDemand/DOCUMENTARIES": {
- details: "Browsing Documentaries",
- },
- "onDemand/KIDS": {
- details: "Browsing Kids Content",
- },
- },
- [newLang, logo, timestamps] = await Promise.all([
- presence.getSetting<string>("lang").catch(() => "en"),
- presence.getSetting<boolean>("logo"),
- presence.getSetting<boolean>("timestamps"),
- ]);
- for (const [path, data] of Object.entries(pages)) {
- if (document.location.hash.includes(path))
- presenceData = { ...presenceData, ...data };
- }
- if (oldLang !== newLang || !strings) {
- oldLang = newLang;
- strings = await getStrings();
- }
- if (document.querySelector<HTMLDivElement>("div[ng-if='showPlayer']")) {
- const { paused, currentTime, duration } =
- document.querySelector<HTMLVideoElement>("video#arxPlayer");
- // TV
- if (
- document.querySelector<HTMLImageElement>(
- "div[ng-if='details.channelLogoWide'] > .wide-logo"
- )
- ) {
- presenceData.details = document.querySelector<HTMLSpanElement>(
- ".meta-title[ng-bind~='details.title']"
- )?.textContent;
- presenceData.state = document.querySelector<HTMLSpanElement>(
- ".meta-title[ng-bind='details.channel.title']"
- )?.textContent;
- if (logo) {
- presenceData.largeImageKey = document
- .querySelector<HTMLImageElement>(
- "div[ng-if='details.channelLogoWide'] > .wide-logo"
- )
- ?.src.replace("-wide", "-normal");
- }
- // Live
- if (document.querySelector<HTMLSpanElement>(".meta-remain")) {
- if (channel !== presenceData.state || !channelTimestamp)
- channelTimestamp = Math.floor(Date.now() / 1000);
- presenceData.startTimestamp = channelTimestamp;
- presenceData.smallImageKey = paused ? Assets.Pause : Assets.Live;
- presenceData.smallImageText = paused ? strings.pause : strings.live;
- } else {
- // Replay / Timeshift
- [presenceData.startTimestamp, presenceData.endTimestamp] =
- presence.getTimestamps(
- presence.timestampFromFormat(
- document.querySelector<HTMLSpanElement>("#VcurrentTime")
- .textContent
- ),
- presence.timestampFromFormat(
- document.querySelector<HTMLSpanElement>("#Vduration").textContent
- )
- );
- presenceData.smallImageKey = paused ? Assets.Pause : Assets.Play;
- presenceData.smallImageText = paused ? strings.pause : strings.play;
- }
- channel = presenceData.state;
- } else {
- // On Demand
- presenceData.details = document.querySelector<HTMLSpanElement>(
- ".meta-title[ng-bind~='details.title']"
- ).textContent;
- // Series
- if (
- document.querySelector<HTMLSpanElement>(
- "span[ng-bind='details.seriesSubs']"
- )?.textContent.length > 0
- ) {
- const episode = document
- .querySelector<HTMLSpanElement>("span[ng-bind='details.seriesSubs']")
- .textContent.split(" / ", 3)
- .map(str => str.trim());
- switch (episode.length) {
- case 3:
- if (
- presenceData.details !== episode[2] &&
- !episode[2].endsWith(` ${episode[1]}`) &&
- !episode[2].endsWith(` ${episode[1].replace("Ε", "E")}`)
- )
- presenceData.state = `${episode[0]}:${episode[1]} ${episode[2]}`;
- else {
- presenceData.state = `${episode[0]
- .replace("S", "Season ")
- .replace("Κ", "Κύκλος ")} ${episode[1]
- .replace("E", "Episode ")
- .replace("Ε", "Επεισόδιο ")}`;
- }
- break;
- case 2:
- presenceData.state = episode[0]
- .replace("E", "Episode ")
- .replace("Ε", "Επεισόδιο ");
- if (
- presenceData.details !== episode[1] &&
- !episode[1].endsWith(` ${episode[0]}`)
- )
- presenceData.state += `: ${episode[1]}`;
- break;
- case 1:
- presenceData.state = episode[0];
- }
- }
- [presenceData.startTimestamp, presenceData.endTimestamp] =
- presence.getTimestamps(Math.floor(currentTime), Math.floor(duration));
- presenceData.smallImageKey = paused ? Assets.Pause : Assets.Play;
- presenceData.smallImageText = paused ? strings.pause : strings.play;
- }
- if (paused || !timestamps) {
- delete presenceData.startTimestamp;
- delete presenceData.endTimestamp;
- channelTimestamp = null;
- }
- }
- presence.setActivity(presenceData);
- });
|