Skip to content

Commit 7fb3dbc

Browse files
committed
Prettified code.
1 parent 0b7974b commit 7fb3dbc

File tree

3 files changed

+92
-94
lines changed

3 files changed

+92
-94
lines changed

README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,3 @@
11
# Better-Embed
2+
23
A npm package that helps you create better Discord Embeds using discord.js.

src/BetterEmbed.ts

Lines changed: 21 additions & 24 deletions
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,11 @@
11
import {MessageEmbed, MessageEmbedOptions} from 'discord.js';
22

3-
type AnyObject = { [k: string]: any };
3+
type AnyObject = {[k: string]: any};
44

5-
const templates: { [k: string]: MessageEmbedOptions } = {
5+
const templates: {[k: string]: MessageEmbedOptions} = {
66
basic: {
7-
footer: {
8-
text: '${client.user.username}',
7+
footer: {
8+
text: '${client.user.username}',
99
iconURL: '${client.user.displayAvatarURL()}',
1010
},
1111
timestamp: new Date(),
@@ -17,7 +17,7 @@ const templates: { [k: string]: MessageEmbedOptions } = {
1717
return {
1818
...this.basic,
1919
...this.color,
20-
title: '${title}',
20+
title: '${title}',
2121
description: '${description}',
2222
};
2323
},
@@ -32,35 +32,34 @@ const templates: { [k: string]: MessageEmbedOptions } = {
3232
};
3333

3434
const limits = {
35-
author: {
35+
author: {
3636
name: 256,
3737
},
38-
title: 256,
38+
title: 256,
3939
description: 2048,
40-
footer: {
40+
footer: {
4141
text: 2048,
4242
},
43-
fields: {
44-
size: 25,
45-
name: 256,
43+
fields: {
44+
size: 25,
45+
name: 256,
4646
value: 1024,
4747
},
4848
};
4949

5050
class BetterEmbed extends MessageEmbed {
51-
5251
public constructor(data?: MessageEmbed | MessageEmbedOptions) {
5352
super(data);
5453
this.checkSize();
5554
}
56-
55+
5756
static fromTemplate(template: keyof typeof templates | typeof templates | MessageEmbedOptions, values: AnyObject) {
5857
if (typeof template === 'string')
5958
if (templates[template]) template = templates[template];
6059
else throw new Error(`Template '${template}' not found.`);
61-
60+
6261
template = JSON.parse(JSON.stringify(template));
63-
62+
6463
function setValues(object: AnyObject, values: AnyObject): MessageEmbedOptions {
6564
for (const [name, value] of Object.entries(object)) {
6665
if (!object.hasOwnProperty(name)) continue;
@@ -69,19 +68,17 @@ class BetterEmbed extends MessageEmbed {
6968
object[name] = setValues(value, values);
7069
continue;
7170
}
72-
73-
const code = value.replace(/\$\{([^}]+)\}/gu, (_: any, value: string) => (values.hasOwnProperty(value.split('.')[0])
74-
? `\${values.${value}}`
75-
: value));
71+
72+
const code = value.replace(/\$\{([^}]+)\}/gu, (_: any, value: string) => (values.hasOwnProperty(value.split('.')[0]) ? `\${values.${value}}` : value));
7673
object[name] = eval(`\`${code}\``);
7774
}
78-
75+
7976
return object;
8077
}
81-
78+
8279
return new BetterEmbed(setValues(template as AnyObject, values));
8380
}
84-
81+
8582
checkSize() {
8683
if (this.title && this.title.length > limits.title) throw new RangeError(`embed.title is too long (${limits.title}).`);
8784
if (this.author?.name && this.author.name.length > limits.author.name) throw new RangeError(`embed.author.name is too long (${limits.author.name}).`);
@@ -93,12 +90,12 @@ class BetterEmbed extends MessageEmbed {
9390
if (field.value?.length > limits.fields.value) throw new RangeError(`embed.fields[${this.fields.indexOf(field)}].value is too long (${limits.fields.value}).`);
9491
});
9592
}
96-
93+
9794
cutIfTooLong() {
9895
function cutWithLength(text: string, maxLength: number) {
9996
return text.length > maxLength ? `${text.substring(0, maxLength - 3)}...` : text;
10097
}
101-
98+
10299
if (this.author?.name) this.author.name = cutWithLength(this.author.name, limits.author.name);
103100
if (this.description) this.description = cutWithLength(this.description, limits.description);
104101
if (this.title) this.title = cutWithLength(this.title, limits.title);

tsconfig.json

Lines changed: 70 additions & 70 deletions
Original file line numberDiff line numberDiff line change
@@ -1,70 +1,70 @@
1-
{
2-
"compilerOptions": {
3-
/* Visit https://aka.ms/tsconfig.json to read more about this file */
4-
5-
/* Basic Options */
6-
// "incremental": true, /* Enable incremental compilation */
7-
"target": "ES2020", /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */
8-
"module": "commonjs", /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */
9-
"lib": ["ES2020"], /* Specify library files to be included in the compilation. */
10-
// "allowJs": true, /* Allow javascript files to be compiled. */
11-
// "checkJs": true, /* Report errors in .js files. */
12-
// "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */
13-
"declaration": true, /* Generates corresponding '.d.ts' file. */
14-
// "declarationMap": true, /* Generates a sourcemap for each corresponding '.d.ts' file. */
15-
// "sourceMap": true, /* Generates corresponding '.map' file. */
16-
// "outFile": "./", /* Concatenate and emit output to single file. */
17-
"outDir": "dist", /* Redirect output structure to the directory. */
18-
"rootDir": "src", /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */
19-
// "composite": true, /* Enable project compilation */
20-
// "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */
21-
// "removeComments": true, /* Do not emit comments to output. */
22-
// "noEmit": true, /* Do not emit outputs. */
23-
// "importHelpers": true, /* Import emit helpers from 'tslib'. */
24-
// "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */
25-
// "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */
26-
27-
/* Strict Type-Checking Options */
28-
"strict": true, /* Enable all strict type-checking options. */
29-
// "noImplicitAny": true, /* Raise error on expressions and declarations with an implied 'any' type. */
30-
// "strictNullChecks": true, /* Enable strict null checks. */
31-
// "strictFunctionTypes": true, /* Enable strict checking of function types. */
32-
// "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */
33-
// "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */
34-
// "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */
35-
// "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */
36-
37-
/* Additional Checks */
38-
"noUnusedLocals": true, /* Report errors on unused locals. */
39-
"noUnusedParameters": true, /* Report errors on unused parameters. */
40-
// "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */
41-
// "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */
42-
// "noUncheckedIndexedAccess": true, /* Include 'undefined' in index signature results */
43-
44-
/* Module Resolution Options */
45-
"moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */
46-
// "baseUrl": "./", /* Base directory to resolve non-absolute module names. */
47-
// "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */
48-
// "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */
49-
// "typeRoots": [], /* List of folders to include type definitions from. */
50-
// "types": [], /* Type declaration files to be included in compilation. */
51-
// "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */
52-
"esModuleInterop": true, /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */
53-
// "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */
54-
// "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */
55-
56-
/* Source Map Options */
57-
// "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */
58-
// "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */
59-
// "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */
60-
// "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */
61-
62-
/* Experimental Options */
63-
// "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */
64-
// "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */
65-
66-
/* Advanced Options */
67-
"skipLibCheck": true, /* Skip type checking of declaration files. */
68-
"forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */
69-
}
70-
}
1+
{
2+
"compilerOptions": {
3+
/* Visit https://aka.ms/tsconfig.json to read more about this file */
4+
5+
/* Basic Options */
6+
// "incremental": true, /* Enable incremental compilation */
7+
"target": "ES2020" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */,
8+
"module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */,
9+
"lib": ["ES2020"] /* Specify library files to be included in the compilation. */,
10+
// "allowJs": true, /* Allow javascript files to be compiled. */
11+
// "checkJs": true, /* Report errors in .js files. */
12+
// "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */
13+
"declaration": true /* Generates corresponding '.d.ts' file. */,
14+
// "declarationMap": true, /* Generates a sourcemap for each corresponding '.d.ts' file. */
15+
// "sourceMap": true, /* Generates corresponding '.map' file. */
16+
// "outFile": "./", /* Concatenate and emit output to single file. */
17+
"outDir": "dist" /* Redirect output structure to the directory. */,
18+
"rootDir": "src" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */,
19+
// "composite": true, /* Enable project compilation */
20+
// "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */
21+
// "removeComments": true, /* Do not emit comments to output. */
22+
// "noEmit": true, /* Do not emit outputs. */
23+
// "importHelpers": true, /* Import emit helpers from 'tslib'. */
24+
// "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */
25+
// "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */
26+
27+
/* Strict Type-Checking Options */
28+
"strict": true /* Enable all strict type-checking options. */,
29+
// "noImplicitAny": true, /* Raise error on expressions and declarations with an implied 'any' type. */
30+
// "strictNullChecks": true, /* Enable strict null checks. */
31+
// "strictFunctionTypes": true, /* Enable strict checking of function types. */
32+
// "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */
33+
// "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */
34+
// "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */
35+
// "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */
36+
37+
/* Additional Checks */
38+
"noUnusedLocals": true /* Report errors on unused locals. */,
39+
"noUnusedParameters": true /* Report errors on unused parameters. */,
40+
// "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */
41+
// "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */
42+
// "noUncheckedIndexedAccess": true, /* Include 'undefined' in index signature results */
43+
44+
/* Module Resolution Options */
45+
"moduleResolution": "node" /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */,
46+
// "baseUrl": "./", /* Base directory to resolve non-absolute module names. */
47+
// "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */
48+
// "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */
49+
// "typeRoots": [], /* List of folders to include type definitions from. */
50+
// "types": [], /* Type declaration files to be included in compilation. */
51+
// "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */
52+
"esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */,
53+
// "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */
54+
// "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */
55+
56+
/* Source Map Options */
57+
// "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */
58+
// "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */
59+
// "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */
60+
// "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */
61+
62+
/* Experimental Options */
63+
// "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */
64+
// "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */
65+
66+
/* Advanced Options */
67+
"skipLibCheck": true /* Skip type checking of declaration files. */,
68+
"forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */
69+
}
70+
}

0 commit comments

Comments
 (0)