mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-26 14:19:11 +02:00
Clean Anilist HTML
This commit is contained in:
@@ -2,7 +2,7 @@ const Command = require('../../structures/Command');
|
|||||||
const { MessageEmbed } = require('discord.js');
|
const { MessageEmbed } = require('discord.js');
|
||||||
const request = require('node-superfetch');
|
const request = require('node-superfetch');
|
||||||
const { stripIndents } = require('common-tags');
|
const { stripIndents } = require('common-tags');
|
||||||
const { shorten } = require('../../util/Util');
|
const { shorten, cleanAnilistHTML } = require('../../util/Util');
|
||||||
const searchGraphQL = stripIndents`
|
const searchGraphQL = stripIndents`
|
||||||
query ($search: String, $type: MediaType, $isAdult: Boolean) {
|
query ($search: String, $type: MediaType, $isAdult: Boolean) {
|
||||||
anime: Page (perPage: 1) {
|
anime: Page (perPage: 1) {
|
||||||
@@ -77,7 +77,7 @@ module.exports = class AnimeCommand extends Command {
|
|||||||
.setURL(anime.siteUrl)
|
.setURL(anime.siteUrl)
|
||||||
.setThumbnail(anime.coverImage.large || anime.coverImage.medium || null)
|
.setThumbnail(anime.coverImage.large || anime.coverImage.medium || null)
|
||||||
.setTitle(anime.title.english || anime.title.userPreferred)
|
.setTitle(anime.title.english || anime.title.userPreferred)
|
||||||
.setDescription(anime.description ? shorten(anime.description.replace(/(<br>)+/g, '\n')) : 'No description.')
|
.setDescription(anime.description ? shorten(cleanAnilistHTML(anime.description)) : 'No description.')
|
||||||
.addField('❯ Status', statuses[anime.status], true)
|
.addField('❯ Status', statuses[anime.status], true)
|
||||||
.addField('❯ Episodes', anime.episodes || '???', true)
|
.addField('❯ Episodes', anime.episodes || '???', true)
|
||||||
.addField('❯ Season', anime.season ? `${seasons[anime.season]} ${anime.startDate.year}` : '???', true)
|
.addField('❯ Season', anime.season ? `${seasons[anime.season]} ${anime.startDate.year}` : '???', true)
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ const Command = require('../../structures/Command');
|
|||||||
const { MessageEmbed } = require('discord.js');
|
const { MessageEmbed } = require('discord.js');
|
||||||
const request = require('node-superfetch');
|
const request = require('node-superfetch');
|
||||||
const { stripIndents } = require('common-tags');
|
const { stripIndents } = require('common-tags');
|
||||||
const { shorten } = require('../../util/Util');
|
const { shorten, cleanAnilistHTML } = require('../../util/Util');
|
||||||
const searchGraphQL = stripIndents`
|
const searchGraphQL = stripIndents`
|
||||||
query ($search: String) {
|
query ($search: String) {
|
||||||
characters: Page (perPage: 1) {
|
characters: Page (perPage: 1) {
|
||||||
@@ -74,9 +74,7 @@ module.exports = class CharacterCommand extends Command {
|
|||||||
.setURL(character.siteUrl)
|
.setURL(character.siteUrl)
|
||||||
.setThumbnail(character.image.large || character.image.medium || null)
|
.setThumbnail(character.image.large || character.image.medium || null)
|
||||||
.setTitle(`${character.name.first || ''}${character.name.last ? ` ${character.name.last}` : ''}`)
|
.setTitle(`${character.name.first || ''}${character.name.last ? ` ${character.name.last}` : ''}`)
|
||||||
.setDescription(character.description
|
.setDescription(character.description ? shorten(cleanAnilistHTML(character.description)) : 'No description.')
|
||||||
? shorten(character.description.replace(/(<br>)+/g, '\n'))
|
|
||||||
: 'No description.')
|
|
||||||
.addField('❯ Appearances', character.media.edges.map(edge => {
|
.addField('❯ Appearances', character.media.edges.map(edge => {
|
||||||
const title = edge.node.title.english || edge.node.title.userPreferred;
|
const title = edge.node.title.english || edge.node.title.userPreferred;
|
||||||
return `[${title} (${types[edge.node.type]})](${edge.node.siteUrl})`;
|
return `[${title} (${types[edge.node.type]})](${edge.node.siteUrl})`;
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ const Command = require('../../structures/Command');
|
|||||||
const { MessageEmbed } = require('discord.js');
|
const { MessageEmbed } = require('discord.js');
|
||||||
const request = require('node-superfetch');
|
const request = require('node-superfetch');
|
||||||
const { stripIndents } = require('common-tags');
|
const { stripIndents } = require('common-tags');
|
||||||
const { shorten } = require('../../util/Util');
|
const { shorten, cleanAnilistHTML } = require('../../util/Util');
|
||||||
const searchGraphQL = stripIndents`
|
const searchGraphQL = stripIndents`
|
||||||
query ($search: String, $type: MediaType, $isAdult: Boolean) {
|
query ($search: String, $type: MediaType, $isAdult: Boolean) {
|
||||||
anime: Page (perPage: 1) {
|
anime: Page (perPage: 1) {
|
||||||
@@ -68,7 +68,7 @@ module.exports = class MangaCommand extends Command {
|
|||||||
.setURL(manga.siteUrl)
|
.setURL(manga.siteUrl)
|
||||||
.setThumbnail(manga.coverImage.large || manga.coverImage.medium || null)
|
.setThumbnail(manga.coverImage.large || manga.coverImage.medium || null)
|
||||||
.setTitle(manga.title.english || manga.title.userPreferred)
|
.setTitle(manga.title.english || manga.title.userPreferred)
|
||||||
.setDescription(manga.description ? shorten(manga.description.replace(/(<br>)+/g, '\n')) : 'No description.')
|
.setDescription(manga.description ? shorten(cleanAnilistHTML(manga.description)) : 'No description.')
|
||||||
.addField('❯ Status', statuses[manga.status], true)
|
.addField('❯ Status', statuses[manga.status], true)
|
||||||
.addField('❯ Chapters / Volumes', `${manga.chapters || '???'}/${manga.volumes || '???'}`, true)
|
.addField('❯ Chapters / Volumes', `${manga.chapters || '???'}/${manga.volumes || '???'}`, true)
|
||||||
.addField('❯ Year', manga.startDate.year || '???', true)
|
.addField('❯ Year', manga.startDate.year || '???', true)
|
||||||
|
|||||||
@@ -116,4 +116,16 @@ module.exports = class Util {
|
|||||||
if (no.includes(choice)) return false;
|
if (no.includes(choice)) return false;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static cleanAnilistHTML(html) {
|
||||||
|
let clean = html
|
||||||
|
.replace(/(<br>)+/g, '\n')
|
||||||
|
.replace(/'/g, '\'')
|
||||||
|
.replace(/"/g, '"')
|
||||||
|
.replace(/<\/?i>/g, '*')
|
||||||
|
.replace(/~!|!~/g, '||');
|
||||||
|
const spoilers = (clean.substr(0, 1997).match(/\|\|/g) || []).length;
|
||||||
|
if (spoilers !== 0 && (spoilers && (spoilers % 2))) clean += '||';
|
||||||
|
return clean;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user