mirror of
https://github.com/kodjodevf/mangayomi-extensions.git
synced 2026-02-14 02:41:39 +00:00
Merge pull request #269 from xMohnad/fix/teamx-install-error
Fix/teamx install error and displayed chapters
This commit is contained in:
@@ -1,31 +1,19 @@
|
||||
const mangayomiSources = [
|
||||
{
|
||||
// prettier-ignore
|
||||
const mangayomiSources = [{
|
||||
"name": "TeamX",
|
||||
"lang": "ar",
|
||||
"baseUrl": "https://olympustaff.com",
|
||||
"apiUrl": "",
|
||||
"iconUrl":
|
||||
"https://www.google.com/s2/favicons?sz=256&domain=https://olympustaff.com",
|
||||
"iconUrl": "https://www.google.com/s2/favicons?sz=256&domain=https://olympustaff.com",
|
||||
"typeSource": "single",
|
||||
"itemType": 0,
|
||||
"version": "1.0.1",
|
||||
"version": "0.0.3",
|
||||
"isNsfw": false,
|
||||
"pkgPath": "manga/src/ar/teamx.js"
|
||||
}
|
||||
];
|
||||
}];
|
||||
|
||||
class DefaultExtension extends MProvider {
|
||||
constructor() {
|
||||
super();
|
||||
this.client = new Client();
|
||||
this.baseUrl = new SharedPreferences().get("overrideBaseUrl1");
|
||||
}
|
||||
|
||||
// Helper Methods
|
||||
|
||||
getHeaders(url) {
|
||||
return { Referer: this.source.baseUrl };
|
||||
}
|
||||
|
||||
toStatus(status) {
|
||||
return (
|
||||
{
|
||||
@@ -48,59 +36,30 @@ class DefaultExtension extends MProvider {
|
||||
}
|
||||
|
||||
parseChapterDate(date) {
|
||||
return new Date(date).toISOString().split("T")[0];
|
||||
return new Date(date).getTime().toString();
|
||||
}
|
||||
|
||||
async request(slug) {
|
||||
const res = await this.client.get(`${this.baseUrl}${slug}`);
|
||||
getBaseUrl() {
|
||||
const preference = new SharedPreferences();
|
||||
var base_url = preference.get("domain_url");
|
||||
if (base_url.length == 0) {
|
||||
return this.source.baseUrl;
|
||||
}
|
||||
if (base_url.endsWith("/")) {
|
||||
return base_url.slice(0, -1);
|
||||
}
|
||||
return base_url;
|
||||
}
|
||||
|
||||
async request(slug, useBaseUrl = true) {
|
||||
const url = useBaseUrl ? `${this.getBaseUrl()}${slug}` : slug;
|
||||
if (!this.client) {
|
||||
this.client = new Client();
|
||||
}
|
||||
const res = await this.client.get(url);
|
||||
return new Document(res.body);
|
||||
}
|
||||
|
||||
// Chapters
|
||||
chapterFromElement(element) {
|
||||
const chpNum = element.selectFirst("div.epl-num")?.text.trim();
|
||||
const chpTitle = element.selectFirst("div.epl-title")?.text.trim();
|
||||
|
||||
let name;
|
||||
if (chpTitle?.includes(chpNum?.replace(/[^0-9]/g, ""))) {
|
||||
name = chpTitle;
|
||||
} else if (!chpNum) {
|
||||
name = chpTitle;
|
||||
} else if (!chpTitle) {
|
||||
name = chpNum;
|
||||
} else {
|
||||
name = `${chpNum} - ${chpTitle}`;
|
||||
}
|
||||
|
||||
return {
|
||||
name,
|
||||
dateUpload: this.parseChapterDate(
|
||||
element.selectFirst("div.epl-date")?.text.trim(),
|
||||
),
|
||||
url: element.getHref,
|
||||
};
|
||||
}
|
||||
|
||||
async chapterListParse(response) {
|
||||
const allElements = [];
|
||||
let doc = response;
|
||||
|
||||
while (true) {
|
||||
const pageChapters = doc.select("div.eplister ul a");
|
||||
if (pageChapters.length === 0) break;
|
||||
|
||||
allElements.push(...pageChapters);
|
||||
const nextPage = doc.select("a[rel=next]");
|
||||
if (nextPage.length === 0) break;
|
||||
|
||||
const nextUrl = nextPage[0].attr("href");
|
||||
const nextResponse = await this.client.get(nextUrl);
|
||||
doc = new Document(nextResponse.body);
|
||||
}
|
||||
|
||||
return allElements.map((element) => this.chapterFromElement(element));
|
||||
}
|
||||
|
||||
// Manga Listing
|
||||
async getMangaList(slug) {
|
||||
const doc = await this.request(`/${slug}`);
|
||||
@@ -149,10 +108,34 @@ class DefaultExtension extends MProvider {
|
||||
return { list, hasNextPage: false };
|
||||
}
|
||||
|
||||
// Chapters
|
||||
chapterFromElement(element) {
|
||||
const chpNum = element.selectFirst("div.epl-num")?.text.trim();
|
||||
const chpTitle = element.selectFirst("div.epl-title")?.text.trim();
|
||||
|
||||
let name;
|
||||
if (chpTitle?.includes(chpNum?.replace(/[^0-9]/g, ""))) {
|
||||
name = chpTitle;
|
||||
} else if (!chpNum) {
|
||||
name = chpTitle;
|
||||
} else if (!chpTitle) {
|
||||
name = chpNum;
|
||||
} else {
|
||||
name = `${chpNum} - ${chpTitle}`;
|
||||
}
|
||||
|
||||
return {
|
||||
name,
|
||||
dateUpload: this.parseChapterDate(
|
||||
element.selectFirst("div.epl-date")?.text.trim(),
|
||||
),
|
||||
url: element.getHref,
|
||||
};
|
||||
}
|
||||
|
||||
// Detail
|
||||
async getDetail(url) {
|
||||
const res = await this.client.get(url);
|
||||
const doc = new Document(res.body);
|
||||
let doc = await this.request(url, false);
|
||||
|
||||
const title = doc.selectFirst("div.author-info-title h1")?.text.trim();
|
||||
const imageUrl = doc.selectFirst("img.shadow-sm")?.getSrc;
|
||||
@@ -176,7 +159,24 @@ class DefaultExtension extends MProvider {
|
||||
.select("div.review-author-info a")
|
||||
.map((e) => e.text.trim());
|
||||
|
||||
const chapters = await this.chapterListParse(doc);
|
||||
const allElements = [];
|
||||
for (;;) {
|
||||
const pageChapters = doc.select("div.eplister ul a");
|
||||
if (!pageChapters || pageChapters.length === 0) break;
|
||||
allElements.push(...pageChapters);
|
||||
|
||||
const nextPage = doc.select("a[rel=next]");
|
||||
if (!nextPage || nextPage.length === 0) break;
|
||||
|
||||
const nextUrl = nextPage[0].attr("href");
|
||||
if (!nextUrl) break;
|
||||
|
||||
doc = await this.request(nextUrl, false);
|
||||
}
|
||||
|
||||
const chapters = allElements.map((element) =>
|
||||
this.chapterFromElement(element),
|
||||
);
|
||||
|
||||
return {
|
||||
title,
|
||||
@@ -191,8 +191,7 @@ class DefaultExtension extends MProvider {
|
||||
|
||||
// chapter pages
|
||||
async getPageList(url) {
|
||||
const res = await this.client.get(url);
|
||||
const doc = new Document(res.body);
|
||||
const doc = await this.request(url, false);
|
||||
|
||||
return doc.select("div.image_list img[src]").map((x) => ({
|
||||
url: x.attr("src"),
|
||||
@@ -336,33 +335,15 @@ class DefaultExtension extends MProvider {
|
||||
getSourcePreferences() {
|
||||
return [
|
||||
{
|
||||
key: "overrideBaseUrl1",
|
||||
key: "domain_url",
|
||||
editTextPreference: {
|
||||
title: "Override BaseUrl",
|
||||
summary: "https://olympustaff.com",
|
||||
summary: "",
|
||||
value: "https://olympustaff.com",
|
||||
dialogTitle: "Override BaseUrl",
|
||||
dialogTitle: "URL",
|
||||
dialogMessage: "",
|
||||
},
|
||||
},
|
||||
];
|
||||
}
|
||||
|
||||
// Unimplemented Methods
|
||||
get supportsLatest() {
|
||||
throw new Error("Method not implemented: supportsLatest");
|
||||
}
|
||||
|
||||
async getHtmlContent(url) {
|
||||
throw new Error("Method not implemented: getHtmlContent");
|
||||
}
|
||||
|
||||
async cleanHtmlContent(html) {
|
||||
throw new Error("Method not implemented: cleanHtmlContent");
|
||||
}
|
||||
|
||||
// For anime episode video list
|
||||
async getVideoList(url) {
|
||||
throw new Error("Method not implemented: getVideoList");
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user