feat: switch to eslint and bundle with webpack
This commit is contained in:
parent
983207ae48
commit
b691ac19c5
12 changed files with 2325 additions and 1322 deletions
|
@ -1,11 +1,10 @@
|
||||||
.vscode/**
|
.vscode
|
||||||
.vscode-test/**
|
dist/**/*.map
|
||||||
test/**
|
node_modules
|
||||||
|
src
|
||||||
.gitattributes
|
.gitattributes
|
||||||
.gitignore
|
.gitignore
|
||||||
|
package.json
|
||||||
tsconfig.json
|
tsconfig.json
|
||||||
tslint.json
|
webpack.config.js
|
||||||
src/
|
yarn.lock
|
||||||
typings/
|
|
||||||
dist/**/*.map
|
|
||||||
gulpfile.js
|
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
* Stable or Insiders build detection
|
* Stable or Insiders build detection
|
||||||
* Debug mode detection
|
* Debug mode detection
|
||||||
* Easily manually reconnect to Discord
|
* Easily manually reconnect to Discord
|
||||||
* **(NEW)** VSCode Live Share support!
|
* VSCode Live Share support
|
||||||
|
|
||||||
## Troubleshooting
|
## Troubleshooting
|
||||||
|
|
||||||
|
|
27
gulpfile.js
27
gulpfile.js
|
@ -1,27 +0,0 @@
|
||||||
const gulp = require('gulp');
|
|
||||||
const fsn = require('fs-nextra');
|
|
||||||
const ts = require('gulp-typescript');
|
|
||||||
const sourcemaps = require('gulp-sourcemaps');
|
|
||||||
const merge = require('merge2');
|
|
||||||
const path = require('path');
|
|
||||||
const project = ts.createProject('tsconfig.json');
|
|
||||||
|
|
||||||
async function build() {
|
|
||||||
await Promise.all([
|
|
||||||
fsn.emptydir('dist'),
|
|
||||||
fsn.emptydir('typings')
|
|
||||||
]);
|
|
||||||
|
|
||||||
const result = project.src()
|
|
||||||
.pipe(sourcemaps.init())
|
|
||||||
.pipe(project());
|
|
||||||
|
|
||||||
await fsn.copy(path.join(__dirname, 'src', 'data'), path.join(__dirname, 'dist', 'data'))
|
|
||||||
return merge([
|
|
||||||
result.dts.pipe(gulp.dest('typings')),
|
|
||||||
result.js.pipe(sourcemaps.write('.', { sourceRoot: '../src' })).pipe(gulp.dest('dist'))
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
gulp.task('default', build);
|
|
||||||
gulp.task('build', build);
|
|
31
package.json
31
package.json
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"name": "discord-vscode",
|
"name": "discord-vscode",
|
||||||
"displayName": "Discord Presence",
|
"displayName": "Discord Presence",
|
||||||
"version": "3.4.0",
|
"version": "3.5.0",
|
||||||
"description": "Update your discord status with the newly added rich presence.",
|
"description": "Update your discord status with the newly added rich presence.",
|
||||||
"private": true,
|
"private": true,
|
||||||
"author": {
|
"author": {
|
||||||
|
@ -19,8 +19,8 @@
|
||||||
"main": "./dist/extension",
|
"main": "./dist/extension",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"prebuild": "yarn lint",
|
"prebuild": "yarn lint",
|
||||||
"build": "gulp",
|
"build": "webpack --mode production",
|
||||||
"lint": "tslint -p tsconfig.json",
|
"lint": "eslint src --ext .ts",
|
||||||
"postinstall": "node ./node_modules/vscode/bin/install"
|
"postinstall": "node ./node_modules/vscode/bin/install"
|
||||||
},
|
},
|
||||||
"activationEvents": [
|
"activationEvents": [
|
||||||
|
@ -177,23 +177,28 @@
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"clipboardy": "^2.0.0",
|
"clipboardy": "^2.0.0",
|
||||||
"discord-rpc": "iCrawl/rpc#custom",
|
"discord-rpc": "discordjs/RPC",
|
||||||
"register-scheme": "devsnek/node-register-scheme",
|
"register-scheme": "devsnek/node-register-scheme",
|
||||||
"vsls": "^0.3.1291"
|
"vsls": "^0.3.1291"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/node": "^11.13.5",
|
"@types/node": "^11.13.6",
|
||||||
"fs-nextra": "^0.4.5",
|
"@typescript-eslint/eslint-plugin": "^1.7.0",
|
||||||
"gulp": "^3.9.1",
|
"@typescript-eslint/parser": "^1.7.0",
|
||||||
"gulp-sourcemaps": "^2.6.5",
|
"clean-webpack-plugin": "^2.0.1",
|
||||||
"gulp-typescript": "^5.0.1",
|
"eslint": "^5.16.0",
|
||||||
"merge2": "^1.2.3",
|
"eslint-config-marine": "^2.0.0",
|
||||||
"tslint": "^5.16.0",
|
"terser-webpack-plugin": "^1.2.3",
|
||||||
"tslint-config-fire": "^1.0.1",
|
"ts-loader": "^5.3.3",
|
||||||
"typescript": "^3.4.4",
|
"typescript": "^3.4.4",
|
||||||
"vscode": "^1.1.33"
|
"vscode": "^1.1.33",
|
||||||
|
"webpack": "^4.30.0",
|
||||||
|
"webpack-cli": "^3.3.0"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"vscode": "^1.15.0"
|
"vscode": "^1.15.0"
|
||||||
|
},
|
||||||
|
"eslintConfig": {
|
||||||
|
"extends": "marine/node"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
const { Client } = require('discord-rpc'); // tslint:disable-line
|
const { Client } = require('discord-rpc'); // eslint-disable-line
|
||||||
import {
|
import {
|
||||||
Disposable,
|
Disposable,
|
||||||
StatusBarItem,
|
StatusBarItem,
|
||||||
workspace,
|
workspace,
|
||||||
Uri,
|
Uri,
|
||||||
window
|
window
|
||||||
} from 'vscode'; // tslint:disable-line
|
} from 'vscode';
|
||||||
import * as vsls from 'vsls/vscode';
|
import * as vsls from 'vsls';
|
||||||
import Activity from '../structures/Activity';
|
import Activity from '../structures/Activity';
|
||||||
import Logger from '../structures/Logger';
|
import Logger from '../structures/Logger';
|
||||||
const clipboardy = require('clipboardy'); // tslint:disable-line
|
const clipboardy = require('clipboardy'); // eslint-disable-line
|
||||||
|
|
||||||
let activityTimer: NodeJS.Timer;
|
let activityTimer: NodeJS.Timer;
|
||||||
|
|
||||||
|
@ -18,74 +18,75 @@ export default class RPCClient implements Disposable {
|
||||||
|
|
||||||
public config = workspace.getConfiguration('discord');
|
public config = workspace.getConfiguration('discord');
|
||||||
|
|
||||||
private _rpc: any; // tslint:disable-line
|
private _rpc: any;
|
||||||
|
|
||||||
private readonly _activity = new Activity(); // tslint:disable-line
|
private readonly _activity = new Activity();
|
||||||
|
|
||||||
private readonly _clientId: string; // tslint:disable-line
|
private readonly _clientId: string;
|
||||||
|
|
||||||
public constructor(clientId: string, statusBarIcon: StatusBarItem) {
|
public constructor(clientId: string, statusBarIcon: StatusBarItem) {
|
||||||
this._clientId = clientId;
|
this._clientId = clientId;
|
||||||
this.statusBarIcon = statusBarIcon;
|
this.statusBarIcon = statusBarIcon;
|
||||||
}
|
}
|
||||||
|
|
||||||
public get client() {
|
public get client(): any {
|
||||||
return this._rpc;
|
return this._rpc;
|
||||||
}
|
}
|
||||||
|
|
||||||
public setActivity(workspaceElapsedTime: boolean = false) {
|
public setActivity(workspaceElapsedTime: boolean = false): void {
|
||||||
if (!this._rpc) return;
|
if (!this._rpc) return;
|
||||||
const activity = this._activity.generate(workspaceElapsedTime);
|
const activity = this._activity.generate(workspaceElapsedTime);
|
||||||
Logger.log('Sending activity to Discord.');
|
Logger.log('Sending activity to Discord.');
|
||||||
this._rpc.setActivity(activity);
|
this._rpc.setActivity(activity);
|
||||||
}
|
}
|
||||||
|
|
||||||
public async allowSpectate() {
|
public async allowSpectate(): Promise<void> {
|
||||||
if (!this._rpc) return;
|
if (!this._rpc) return;
|
||||||
Logger.log('Allowed spectating.');
|
Logger.log('Allowed spectating.');
|
||||||
Logger.log('Sending spectate activity to Discord.');
|
Logger.log('Sending spectate activity to Discord.');
|
||||||
await this._activity.allowSpectate();
|
await this._activity.allowSpectate();
|
||||||
}
|
}
|
||||||
|
|
||||||
public async disableSpectate() {
|
public async disableSpectate(): Promise<void> {
|
||||||
if (!this._rpc) return;
|
if (!this._rpc) return;
|
||||||
Logger.log('Disabled spectating.');
|
Logger.log('Disabled spectating.');
|
||||||
await this._activity.disableSpectate();
|
await this._activity.disableSpectate();
|
||||||
}
|
}
|
||||||
|
|
||||||
public async allowJoinRequests() {
|
public async allowJoinRequests(): Promise<void> {
|
||||||
if (!this._rpc) return;
|
if (!this._rpc) return;
|
||||||
Logger.log('Allowed join requests.');
|
Logger.log('Allowed join requests.');
|
||||||
Logger.log('Sending join activity to Discord.');
|
Logger.log('Sending join activity to Discord.');
|
||||||
await this._activity.allowJoinRequests();
|
await this._activity.allowJoinRequests();
|
||||||
}
|
}
|
||||||
|
|
||||||
public async disableJoinRequests() {
|
public async disableJoinRequests(): Promise<void> {
|
||||||
if (!this._rpc) return;
|
if (!this._rpc) return;
|
||||||
Logger.log('Disabled join requests.');
|
Logger.log('Disabled join requests.');
|
||||||
await this._activity.disableJoinRequests();
|
await this._activity.disableJoinRequests();
|
||||||
}
|
}
|
||||||
|
|
||||||
public async login() {
|
public async login(): Promise<void> {
|
||||||
if (this._rpc) return;
|
if (this._rpc) return;
|
||||||
this._rpc = new Client({ transport: 'ipc' });
|
this._rpc = new Client({ transport: 'ipc' });
|
||||||
Logger.log('Logging into RPC.');
|
Logger.log('Logging into RPC.');
|
||||||
this._rpc.once('ready', async () => {
|
this._rpc.once('ready', async (): Promise<void> => {
|
||||||
Logger.log('Successfully connected to Discord.');
|
Logger.log('Successfully connected to Discord.');
|
||||||
this.statusBarIcon.text = '$(globe) Connected to Discord';
|
this.statusBarIcon.text = '$(globe) Connected to Discord';
|
||||||
this.statusBarIcon.tooltip = 'Connected to Discord';
|
this.statusBarIcon.tooltip = 'Connected to Discord';
|
||||||
|
|
||||||
setTimeout(() => this.statusBarIcon.text = '$(globe)', 5000);
|
// @ts-ignore
|
||||||
|
setTimeout((): void => this.statusBarIcon.text = '$(globe)', 5000);
|
||||||
|
|
||||||
if (activityTimer) clearInterval(activityTimer);
|
if (activityTimer) clearInterval(activityTimer);
|
||||||
this.setActivity();
|
this.setActivity();
|
||||||
|
|
||||||
activityTimer = setInterval(() => {
|
activityTimer = setInterval((): void => {
|
||||||
this.config = workspace.getConfiguration('discord');
|
this.config = workspace.getConfiguration('discord');
|
||||||
this.setActivity(this.config.get<boolean>('workspaceElapsedTime'));
|
this.setActivity(this.config.get<boolean>('workspaceElapsedTime'));
|
||||||
}, 10000);
|
}, 10000);
|
||||||
|
|
||||||
this._rpc.subscribe('ACTIVITY_SPECTATE', async ({ secret }: { secret: string }) => {
|
this._rpc.subscribe('ACTIVITY_SPECTATE', async ({ secret }: { secret: string }): Promise<void> => {
|
||||||
const liveshare = await vsls.getApi();
|
const liveshare = await vsls.getApi();
|
||||||
if (!liveshare) return;
|
if (!liveshare) return;
|
||||||
try {
|
try {
|
||||||
|
@ -105,17 +106,17 @@ export default class RPCClient implements Disposable {
|
||||||
// You might be asking yourself again: "but why?"
|
// You might be asking yourself again: "but why?"
|
||||||
// Same here, this is a real nasty race condition that happens inside the discord-rpc module currently
|
// Same here, this is a real nasty race condition that happens inside the discord-rpc module currently
|
||||||
// To circumvent this we need to timeout sending the subscribe events to the discord client
|
// To circumvent this we need to timeout sending the subscribe events to the discord client
|
||||||
setTimeout(() => {
|
setTimeout((): void => {
|
||||||
this._rpc.subscribe('ACTIVITY_JOIN_REQUEST', async ({ user }: { user: { username: string, discriminator: string } }) => {
|
this._rpc.subscribe('ACTIVITY_JOIN_REQUEST', async ({ user }: { user: { username: string; discriminator: string } }): Promise<void> =>
|
||||||
window.showInformationMessage(`${user.username}#${user.discriminator} wants to join your session`, { title: 'Accept' }, { title: 'Decline' })
|
window.showInformationMessage(`${user.username}#${user.discriminator} wants to join your session`, { title: 'Accept' }, { title: 'Decline' })
|
||||||
|
// eslint-disable-next-line
|
||||||
.then(async (val: { title: string } | undefined) => {
|
.then(async (val: { title: string } | undefined) => {
|
||||||
if (val && val.title === 'Accept') await this._rpc.sendJoinInvite(user);
|
if (val && val.title === 'Accept') await this._rpc.sendJoinInvite(user); // eslint-disable-line
|
||||||
else await this._rpc.closeJoinRequest(user);
|
else await this._rpc.closeJoinRequest(user);
|
||||||
});
|
}));
|
||||||
});
|
|
||||||
}, 500);
|
}, 500);
|
||||||
setTimeout(() => {
|
setTimeout((): void => {
|
||||||
this._rpc.subscribe('ACTIVITY_JOIN', async ({ secret }: { secret: string }) => {
|
this._rpc.subscribe('ACTIVITY_JOIN', async ({ secret }: { secret: string }): Promise<void> => {
|
||||||
const liveshare = await vsls.getApi();
|
const liveshare = await vsls.getApi();
|
||||||
if (!liveshare) return;
|
if (!liveshare) return;
|
||||||
try {
|
try {
|
||||||
|
@ -133,17 +134,21 @@ export default class RPCClient implements Disposable {
|
||||||
|
|
||||||
const liveshare = await vsls.getApi();
|
const liveshare = await vsls.getApi();
|
||||||
if (!liveshare) return;
|
if (!liveshare) return;
|
||||||
liveshare.onDidChangeSession(({ session }: { session: vsls.Session }) => {
|
liveshare.onDidChangeSession(({ session }: { session: vsls.Session }): void => {
|
||||||
|
// @ts-ignore
|
||||||
if (session.id) return this._activity.changePartyId(session.id);
|
if (session.id) return this._activity.changePartyId(session.id);
|
||||||
else return this._activity.changePartyId();
|
// @ts-ignore
|
||||||
|
return this._activity.changePartyId();
|
||||||
});
|
});
|
||||||
liveshare.onDidChangePeers(({ added, removed }: { added: vsls.Peer[], removed: vsls.Peer[] }) => {
|
liveshare.onDidChangePeers(({ added, removed }: { added: vsls.Peer[]; removed: vsls.Peer[] }): void => {
|
||||||
|
// @ts-ignore
|
||||||
if (added.length) return this._activity.increasePartySize(added.length);
|
if (added.length) return this._activity.increasePartySize(added.length);
|
||||||
|
// @ts-ignore
|
||||||
else if (removed.length) return this._activity.decreasePartySize(removed.length);
|
else if (removed.length) return this._activity.decreasePartySize(removed.length);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
this._rpc.transport.once('close', async () => {
|
this._rpc.transport.once('close', async (): Promise<void> => {
|
||||||
if (!this.config.get<boolean>('enabled')) return;
|
if (!this.config.get<boolean>('enabled')) return;
|
||||||
await this.dispose();
|
await this.dispose();
|
||||||
this.statusBarIcon.text = '$(plug) Reconnect to Discord';
|
this.statusBarIcon.text = '$(plug) Reconnect to Discord';
|
||||||
|
@ -154,11 +159,10 @@ export default class RPCClient implements Disposable {
|
||||||
await this._rpc.login({ clientId: this._clientId });
|
await this._rpc.login({ clientId: this._clientId });
|
||||||
}
|
}
|
||||||
|
|
||||||
public async dispose() {
|
public async dispose(): Promise<void> {
|
||||||
this._activity.dispose();
|
this._activity.dispose();
|
||||||
try {
|
try {
|
||||||
await this._rpc.destroy();
|
await this._rpc.destroy();
|
||||||
// tslint:disable-next-line
|
|
||||||
} catch {}
|
} catch {}
|
||||||
this._rpc = null;
|
this._rpc = null;
|
||||||
this.statusBarIcon.tooltip = '';
|
this.statusBarIcon.tooltip = '';
|
||||||
|
|
|
@ -5,10 +5,10 @@ import {
|
||||||
StatusBarItem,
|
StatusBarItem,
|
||||||
window,
|
window,
|
||||||
workspace
|
workspace
|
||||||
} from 'vscode'; // tslint:disable-line
|
} from 'vscode';
|
||||||
import RPCClient from './client/RPCClient';
|
import RPCClient from './client/RPCClient';
|
||||||
import Logger from './structures/Logger';
|
import Logger from './structures/Logger';
|
||||||
const { register } = require('discord-rpc'); // tslint:disable-line
|
const { register } = require('discord-rpc'); // eslint-disable-line
|
||||||
|
|
||||||
const statusBarIcon: StatusBarItem = window.createStatusBarItem(StatusBarAlignment.Left);
|
const statusBarIcon: StatusBarItem = window.createStatusBarItem(StatusBarAlignment.Left);
|
||||||
statusBarIcon.text = '$(pulse) Connecting to Discord...';
|
statusBarIcon.text = '$(pulse) Connecting to Discord...';
|
||||||
|
@ -17,7 +17,7 @@ const config = workspace.getConfiguration('discord');
|
||||||
register(config.get<string>('clientID'));
|
register(config.get<string>('clientID'));
|
||||||
const rpc = new RPCClient(config.get<string>('clientID')!, statusBarIcon);
|
const rpc = new RPCClient(config.get<string>('clientID')!, statusBarIcon);
|
||||||
|
|
||||||
export async function activate(context: ExtensionContext) {
|
export async function activate(context: ExtensionContext): Promise<void> {
|
||||||
Logger.log('Discord Presence activated!');
|
Logger.log('Discord Presence activated!');
|
||||||
|
|
||||||
let isWorkspaceExcluded = false;
|
let isWorkspaceExcluded = false;
|
||||||
|
@ -27,7 +27,7 @@ export async function activate(context: ExtensionContext) {
|
||||||
const regex = new RegExp(pattern);
|
const regex = new RegExp(pattern);
|
||||||
const folders = workspace.workspaceFolders;
|
const folders = workspace.workspaceFolders;
|
||||||
if (!folders) break;
|
if (!folders) break;
|
||||||
if (folders.some((folder) => regex.test(folder.uri.fsPath))) {
|
if (folders.some((folder): boolean => regex.test(folder.uri.fsPath))) {
|
||||||
isWorkspaceExcluded = true;
|
isWorkspaceExcluded = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -50,7 +50,7 @@ export async function activate(context: ExtensionContext) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const enabler = commands.registerCommand('discord.enable', async () => {
|
const enabler = commands.registerCommand('discord.enable', async (): Promise<void> => {
|
||||||
await rpc.dispose();
|
await rpc.dispose();
|
||||||
config.update('enabled', true);
|
config.update('enabled', true);
|
||||||
rpc.config = workspace.getConfiguration('discord');
|
rpc.config = workspace.getConfiguration('discord');
|
||||||
|
@ -60,7 +60,7 @@ export async function activate(context: ExtensionContext) {
|
||||||
window.showInformationMessage('Enabled Discord Rich Presence for this workspace.');
|
window.showInformationMessage('Enabled Discord Rich Presence for this workspace.');
|
||||||
});
|
});
|
||||||
|
|
||||||
const disabler = commands.registerCommand('discord.disable', async () => {
|
const disabler = commands.registerCommand('discord.disable', async (): Promise<void> => {
|
||||||
config.update('enabled', false);
|
config.update('enabled', false);
|
||||||
rpc.config = workspace.getConfiguration('discord');
|
rpc.config = workspace.getConfiguration('discord');
|
||||||
await rpc.dispose();
|
await rpc.dispose();
|
||||||
|
@ -68,7 +68,7 @@ export async function activate(context: ExtensionContext) {
|
||||||
window.showInformationMessage('Disabled Discord Rich Presence for this workspace.');
|
window.showInformationMessage('Disabled Discord Rich Presence for this workspace.');
|
||||||
});
|
});
|
||||||
|
|
||||||
const reconnecter = commands.registerCommand('discord.reconnect', async () => {
|
const reconnecter = commands.registerCommand('discord.reconnect', async (): Promise<void> => {
|
||||||
await rpc.dispose();
|
await rpc.dispose();
|
||||||
await rpc.login();
|
await rpc.login();
|
||||||
if (!config.get('silent')) window.showInformationMessage('Reconnecting to Discord RPC...');
|
if (!config.get('silent')) window.showInformationMessage('Reconnecting to Discord RPC...');
|
||||||
|
@ -76,27 +76,27 @@ export async function activate(context: ExtensionContext) {
|
||||||
rpc.statusBarIcon.command = undefined;
|
rpc.statusBarIcon.command = undefined;
|
||||||
});
|
});
|
||||||
|
|
||||||
const allowSpectate = commands.registerCommand('discord.allowSpectate', async () => {
|
const allowSpectate = commands.registerCommand('discord.allowSpectate', async (): Promise<void> => {
|
||||||
await rpc.allowSpectate();
|
await rpc.allowSpectate();
|
||||||
});
|
});
|
||||||
|
|
||||||
const disableSpectate = commands.registerCommand('discord.disableSpectate', async () => {
|
const disableSpectate = commands.registerCommand('discord.disableSpectate', async (): Promise<void> => {
|
||||||
await rpc.disableSpectate();
|
await rpc.disableSpectate();
|
||||||
});
|
});
|
||||||
|
|
||||||
const allowJoinRequests = commands.registerCommand('discord.allowJoinRequests', async () => {
|
const allowJoinRequests = commands.registerCommand('discord.allowJoinRequests', async (): Promise<void> => {
|
||||||
await rpc.allowJoinRequests();
|
await rpc.allowJoinRequests();
|
||||||
});
|
});
|
||||||
|
|
||||||
const disableJoinRequests = commands.registerCommand('discord.disableJoinRequests', async () => {
|
const disableJoinRequests = commands.registerCommand('discord.disableJoinRequests', async (): Promise<void> => {
|
||||||
await rpc.disableJoinRequests();
|
await rpc.disableJoinRequests();
|
||||||
});
|
});
|
||||||
|
|
||||||
context.subscriptions.push(enabler, disabler, reconnecter, allowSpectate, disableSpectate, allowJoinRequests, disableJoinRequests);
|
context.subscriptions.push(enabler, disabler, reconnecter, allowSpectate, disableSpectate, allowJoinRequests, disableJoinRequests);
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function deactivate() {
|
export async function deactivate(): Promise<void> {
|
||||||
await rpc.dispose();
|
await rpc.dispose();
|
||||||
}
|
}
|
||||||
|
|
||||||
process.on('unhandledRejection', err => Logger.log(err as string));
|
process.on('unhandledRejection', (err): void => Logger.log(err as string));
|
||||||
|
|
|
@ -6,9 +6,9 @@ import {
|
||||||
env,
|
env,
|
||||||
window,
|
window,
|
||||||
workspace
|
workspace
|
||||||
} from 'vscode'; // tslint:disable-line
|
} from 'vscode';
|
||||||
import * as vsls from 'vsls/vscode';
|
import * as vsls from 'vsls';
|
||||||
const lang = require('../data/languages.json'); // tslint:disable-line
|
const lang = require('../data/languages.json'); // eslint-disable-line
|
||||||
const knownExtentions: { [key: string]: { image: string } } = lang.knownExtentions;
|
const knownExtentions: { [key: string]: { image: string } } = lang.knownExtentions;
|
||||||
const knownLanguages: string[] = lang.knownLanguages;
|
const knownLanguages: string[] = lang.knownLanguages;
|
||||||
|
|
||||||
|
@ -40,17 +40,17 @@ interface FileDetail {
|
||||||
}
|
}
|
||||||
|
|
||||||
export default class Activity implements Disposable {
|
export default class Activity implements Disposable {
|
||||||
private _state: State | null = null; // tslint:disable-line
|
private _state: State | null = null;
|
||||||
|
|
||||||
private readonly _config = workspace.getConfiguration('discord'); // tslint:disable-line
|
private readonly _config = workspace.getConfiguration('discord');
|
||||||
|
|
||||||
private _lastKnownFile: string = ''; // tslint:disable-line
|
private _lastKnownFile: string = '';
|
||||||
|
|
||||||
public get state() {
|
public get state(): State | null {
|
||||||
return this._state;
|
return this._state;
|
||||||
}
|
}
|
||||||
|
|
||||||
public generate(workspaceElapsedTime: boolean = false) {
|
public generate(workspaceElapsedTime: boolean = false): State {
|
||||||
let largeImageKey: any = 'vscode-big';
|
let largeImageKey: any = 'vscode-big';
|
||||||
if (window.activeTextEditor) {
|
if (window.activeTextEditor) {
|
||||||
if (window.activeTextEditor.document.fileName === this._lastKnownFile) {
|
if (window.activeTextEditor.document.fileName === this._lastKnownFile) {
|
||||||
|
@ -63,7 +63,7 @@ export default class Activity implements Disposable {
|
||||||
}
|
}
|
||||||
this._lastKnownFile = window.activeTextEditor.document.fileName;
|
this._lastKnownFile = window.activeTextEditor.document.fileName;
|
||||||
const filename = basename(window.activeTextEditor.document.fileName);
|
const filename = basename(window.activeTextEditor.document.fileName);
|
||||||
largeImageKey = knownExtentions[Object.keys(knownExtentions).find(key => {
|
largeImageKey = knownExtentions[Object.keys(knownExtentions).find((key): boolean => {
|
||||||
if (filename.endsWith(key)) return true;
|
if (filename.endsWith(key)) return true;
|
||||||
const match = key.match(/^\/(.*)\/([mgiy]+)$/);
|
const match = key.match(/^\/(.*)\/([mgiy]+)$/);
|
||||||
if (!match) return false;
|
if (!match) return false;
|
||||||
|
@ -84,9 +84,9 @@ export default class Activity implements Disposable {
|
||||||
largeImageText: window.activeTextEditor
|
largeImageText: window.activeTextEditor
|
||||||
? this._config.get<string>('largeImage')!
|
? this._config.get<string>('largeImage')!
|
||||||
.replace('{lang}', largeImageKey ? largeImageKey.image || largeImageKey : 'txt')
|
.replace('{lang}', largeImageKey ? largeImageKey.image || largeImageKey : 'txt')
|
||||||
.replace('{Lang}', largeImageKey ? (largeImageKey.image || largeImageKey).toLowerCase().replace(/^\w/, (c: string) => c.toUpperCase()) : 'Txt')
|
.replace('{Lang}', largeImageKey ? (largeImageKey.image || largeImageKey).toLowerCase().replace(/^\w/, (c: string): string => c.toUpperCase()) : 'Txt')
|
||||||
.replace('{LANG}', largeImageKey ? (largeImageKey.image || largeImageKey).toUpperCase() : 'TXT')
|
.replace('{LANG}', largeImageKey ? (largeImageKey.image || largeImageKey).toUpperCase() : 'TXT') ||
|
||||||
|| window.activeTextEditor.document.languageId.padEnd(2, '\u200b')
|
window.activeTextEditor.document.languageId.padEnd(2, '\u200b')
|
||||||
: this._config.get<string>('largeImageIdle'),
|
: this._config.get<string>('largeImageIdle'),
|
||||||
smallImageKey: debug.activeDebugSession ? 'debug' : env.appName.includes('Insiders') ? 'vscode-insiders' : 'vscode',
|
smallImageKey: debug.activeDebugSession ? 'debug' : env.appName.includes('Insiders') ? 'vscode-insiders' : 'vscode',
|
||||||
smallImageText: this._config.get<string>('smallImage')!.replace('{appname}', env.appName)
|
smallImageText: this._config.get<string>('smallImage')!.replace('{appname}', env.appName)
|
||||||
|
@ -95,7 +95,7 @@ export default class Activity implements Disposable {
|
||||||
return this._state;
|
return this._state;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async allowSpectate() {
|
public async allowSpectate(): Promise<State | void> {
|
||||||
const liveshare = await vsls.getApi();
|
const liveshare = await vsls.getApi();
|
||||||
if (!liveshare) return;
|
if (!liveshare) return;
|
||||||
const join = await liveshare.share({ suppressNotification: true, access: vsls.Access.ReadOnly });
|
const join = await liveshare.share({ suppressNotification: true, access: vsls.Access.ReadOnly });
|
||||||
|
@ -108,7 +108,7 @@ export default class Activity implements Disposable {
|
||||||
return this._state;
|
return this._state;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async disableSpectate() {
|
public async disableSpectate(): Promise<State | void> {
|
||||||
const liveshare = await vsls.getApi();
|
const liveshare = await vsls.getApi();
|
||||||
if (!liveshare) return;
|
if (!liveshare) return;
|
||||||
await liveshare.end();
|
await liveshare.end();
|
||||||
|
@ -121,7 +121,7 @@ export default class Activity implements Disposable {
|
||||||
return this._state;
|
return this._state;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async allowJoinRequests() {
|
public async allowJoinRequests(): Promise<State | void> {
|
||||||
const liveshare = await vsls.getApi();
|
const liveshare = await vsls.getApi();
|
||||||
if (!liveshare) return;
|
if (!liveshare) return;
|
||||||
const join = await liveshare.share({ suppressNotification: true });
|
const join = await liveshare.share({ suppressNotification: true });
|
||||||
|
@ -137,7 +137,7 @@ export default class Activity implements Disposable {
|
||||||
return this._state;
|
return this._state;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async disableJoinRequests() {
|
public async disableJoinRequests(): Promise<State | void> {
|
||||||
const liveshare = await vsls.getApi();
|
const liveshare = await vsls.getApi();
|
||||||
if (!liveshare) return;
|
if (!liveshare) return;
|
||||||
await liveshare.end();
|
await liveshare.end();
|
||||||
|
@ -153,7 +153,7 @@ export default class Activity implements Disposable {
|
||||||
return this._state;
|
return this._state;
|
||||||
}
|
}
|
||||||
|
|
||||||
public changePartyId(id?: string) {
|
public changePartyId(id?: string): State | void {
|
||||||
if (!this._state) return;
|
if (!this._state) return;
|
||||||
this._state = {
|
this._state = {
|
||||||
...this._state,
|
...this._state,
|
||||||
|
@ -165,7 +165,7 @@ export default class Activity implements Disposable {
|
||||||
return this._state;
|
return this._state;
|
||||||
}
|
}
|
||||||
|
|
||||||
public increasePartySize(size?: number) {
|
public increasePartySize(size?: number): State | void {
|
||||||
if (!this._state) return;
|
if (!this._state) return;
|
||||||
if (this.state && this._state.partySize === 5) return;
|
if (this.state && this._state.partySize === 5) return;
|
||||||
this._state = {
|
this._state = {
|
||||||
|
@ -176,7 +176,7 @@ export default class Activity implements Disposable {
|
||||||
return this._state;
|
return this._state;
|
||||||
}
|
}
|
||||||
|
|
||||||
public decreasePartySize(size?: number) {
|
public decreasePartySize(size?: number): State | void {
|
||||||
if (!this._state) return;
|
if (!this._state) return;
|
||||||
if (this.state && this._state.partySize === 1) return;
|
if (this.state && this._state.partySize === 1) return;
|
||||||
this._state = {
|
this._state = {
|
||||||
|
@ -187,12 +187,12 @@ export default class Activity implements Disposable {
|
||||||
return this._state;
|
return this._state;
|
||||||
}
|
}
|
||||||
|
|
||||||
public dispose() {
|
public dispose(): void {
|
||||||
this._state = null;
|
this._state = null;
|
||||||
this._lastKnownFile = '';
|
this._lastKnownFile = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
private _generateDetails(debugging: string, editing: string, idling: string, largeImageKey: any) {
|
private _generateDetails(debugging: string, editing: string, idling: string, largeImageKey: any): string {
|
||||||
let raw: string = this._config.get<string>(idling)!.replace('{null}', empty);
|
let raw: string = this._config.get<string>(idling)!.replace('{null}', empty);
|
||||||
let filename = null;
|
let filename = null;
|
||||||
let dirname = null;
|
let dirname = null;
|
||||||
|
@ -231,7 +231,7 @@ export default class Activity implements Disposable {
|
||||||
.replace('{fulldirname}', fullDirname!)
|
.replace('{fulldirname}', fullDirname!)
|
||||||
.replace('{workspace}', checkState && workspaceFolder ? workspaceFolder.name : this._config.get<string>('lowerDetailsNotFound')!.replace('{null}', empty))
|
.replace('{workspace}', checkState && workspaceFolder ? workspaceFolder.name : this._config.get<string>('lowerDetailsNotFound')!.replace('{null}', empty))
|
||||||
.replace('{lang}', largeImageKey ? largeImageKey.image || largeImageKey : 'txt')
|
.replace('{lang}', largeImageKey ? largeImageKey.image || largeImageKey : 'txt')
|
||||||
.replace('{Lang}', largeImageKey ? (largeImageKey.image || largeImageKey).toLowerCase().replace(/^\w/, (c: string) => c.toUpperCase()) : 'Txt')
|
.replace('{Lang}', largeImageKey ? (largeImageKey.image || largeImageKey).toLowerCase().replace(/^\w/, (c: string): string => c.toUpperCase()) : 'Txt')
|
||||||
.replace('{LANG}', largeImageKey ? (largeImageKey.image || largeImageKey).toUpperCase() : 'TXT');
|
.replace('{LANG}', largeImageKey ? (largeImageKey.image || largeImageKey).toUpperCase() : 'TXT');
|
||||||
if (totalLines) raw = raw!.replace('{totallines}', totalLines);
|
if (totalLines) raw = raw!.replace('{totallines}', totalLines);
|
||||||
if (size) raw = raw!.replace('{filesize}', size);
|
if (size) raw = raw!.replace('{filesize}', size);
|
||||||
|
@ -242,7 +242,7 @@ export default class Activity implements Disposable {
|
||||||
return raw;
|
return raw;
|
||||||
}
|
}
|
||||||
|
|
||||||
private _generateFileDetails(str?: string) {
|
private _generateFileDetails(str?: string): FileDetail {
|
||||||
const fileDetail: FileDetail = {};
|
const fileDetail: FileDetail = {};
|
||||||
if (!str) return fileDetail;
|
if (!str) return fileDetail;
|
||||||
|
|
||||||
|
@ -252,11 +252,11 @@ export default class Activity implements Disposable {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (str.includes('{currentline}')) {
|
if (str.includes('{currentline}')) {
|
||||||
fileDetail.currentLine = (window.activeTextEditor.selection.active.line + 1).toLocaleString(); // tslint:disable-line
|
fileDetail.currentLine = (window.activeTextEditor.selection.active.line as number + 1).toLocaleString();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (str.includes('{currentcolumn}')) {
|
if (str.includes('{currentcolumn}')) {
|
||||||
fileDetail.currentColumn = (window.activeTextEditor.selection.active.character + 1).toLocaleString(); // tslint:disable-line
|
fileDetail.currentColumn = (window.activeTextEditor.selection.active.character as number + 1).toLocaleString();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (str.includes('{filesize}')) {
|
if (str.includes('{filesize}')) {
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
import { OutputChannel, window } from 'vscode'; // tslint:disable-line
|
import { OutputChannel, window } from 'vscode';
|
||||||
|
|
||||||
// tslint:disable-next-line
|
// eslint-disable-next-line
|
||||||
export default class Logger {
|
export default class Logger {
|
||||||
private static _output: OutputChannel; // tslint:disable-line
|
private static _output: OutputChannel;
|
||||||
|
|
||||||
private static _setup() {
|
private static _setup(): void {
|
||||||
this._output = this._output || window.createOutputChannel('Discord Presence');
|
this._output = this._output || window.createOutputChannel('Discord Presence');
|
||||||
}
|
}
|
||||||
|
|
||||||
public static log(message: string) {
|
public static log(message: string): void {
|
||||||
if (!this._output) this._setup();
|
if (!this._output) this._setup();
|
||||||
this._output.appendLine(message);
|
this._output.appendLine(message);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
"strict": true,
|
"strict": true,
|
||||||
"module": "commonjs",
|
"module": "commonjs",
|
||||||
"target": "es6",
|
"target": "es2017",
|
||||||
"lib": [
|
"lib": [
|
||||||
"esnext",
|
"esnext",
|
||||||
"esnext.array",
|
"esnext.array",
|
||||||
|
@ -10,15 +10,14 @@
|
||||||
"esnext.intl",
|
"esnext.intl",
|
||||||
"esnext.symbol"
|
"esnext.symbol"
|
||||||
],
|
],
|
||||||
"declaration": true,
|
"rootDir": "src",
|
||||||
|
"outDir": "dist",
|
||||||
|
"declaration": false,
|
||||||
"sourceMap": true,
|
"sourceMap": true,
|
||||||
"removeComments": false,
|
"removeComments": false,
|
||||||
"experimentalDecorators": true,
|
"experimentalDecorators": true
|
||||||
"typeRoots": [
|
|
||||||
"node_modules/@types"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"include": [
|
"exclude": [
|
||||||
"./src"
|
"node_modules"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +0,0 @@
|
||||||
{
|
|
||||||
"extends": "tslint-config-fire"
|
|
||||||
}
|
|
43
webpack.config.js
Normal file
43
webpack.config.js
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
const CleanWebpackPlugin = require('clean-webpack-plugin');
|
||||||
|
const TerserPlugin = require('terser-webpack-plugin');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
target: 'node',
|
||||||
|
entry: './src/extension.ts',
|
||||||
|
output: {
|
||||||
|
filename: 'extension.js',
|
||||||
|
libraryTarget: 'commonjs2'
|
||||||
|
},
|
||||||
|
devtool: 'source-map',
|
||||||
|
externals: {
|
||||||
|
vscode: 'commonjs vscode'
|
||||||
|
},
|
||||||
|
resolve: {
|
||||||
|
extensions: ['.ts', '.js', '.json']
|
||||||
|
},
|
||||||
|
plugins: [
|
||||||
|
new CleanWebpackPlugin()
|
||||||
|
],
|
||||||
|
optimization: {
|
||||||
|
minimizer: [
|
||||||
|
new TerserPlugin({
|
||||||
|
cache: false,
|
||||||
|
parallel: true,
|
||||||
|
sourceMap: true,
|
||||||
|
terserOptions: {
|
||||||
|
ecma: 8,
|
||||||
|
keep_classnames: true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
]
|
||||||
|
},
|
||||||
|
module: {
|
||||||
|
rules: [{
|
||||||
|
test: /\.ts$/,
|
||||||
|
use: 'ts-loader',
|
||||||
|
exclude: /node_modules/
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
};
|
Loading…
Reference in a new issue