This commit is contained in:
kodjomoustapha
2023-10-24 21:28:23 +01:00
parent 9739a8720e
commit 6eac32b58c
39 changed files with 457 additions and 953 deletions

View File

@@ -1,22 +1,19 @@
import 'dart:convert';
import 'package:bridge_lib/bridge_lib.dart';
getPopularAnime(MangaModel anime) async {
getPopularAnime(MManga anime) async {
final data = {"url": "${anime.baseUrl}/popular.html?page=${anime.page}"};
final res = await MBridge.http('GET', json.encode(data));
if (res.isEmpty) {
return anime;
}
anime.urls = MBridge.xpath(res, '//*[@class="img"]/a/@href');
anime.names = MBridge.xpath(res, '//*[@class="img"]/a/@title');
anime.images = MBridge.xpath(res, '//*[@class="img"]/a/img/@src');
return anime;
}
getLatestUpdatesAnime(MangaModel anime) async {
getLatestUpdatesAnime(MManga anime) async {
final url =
"https://ajax.gogo-load.com/ajax/page-recent-release-ongoing.html?page=${anime.page}&type=1";
final data = {"url": url};
@@ -26,7 +23,6 @@ getLatestUpdatesAnime(MangaModel anime) async {
}
anime.urls = MBridge.xpath(
res, '//*[@class="added_series_body popular"]/ul/li/a[1]/@href');
anime.names = MBridge.xpath(
res, '//*[//*[@class="added_series_body popular"]/ul/li/a[1]/@title');
List<String> images = [];
@@ -41,7 +37,7 @@ getLatestUpdatesAnime(MangaModel anime) async {
return anime;
}
getAnimeDetail(MangaModel anime) async {
getAnimeDetail(MManga anime) async {
final statusList = [
{
"Ongoing": 0,
@@ -59,12 +55,10 @@ getAnimeDetail(MangaModel anime) async {
res, '//*[@class="anime_info_body_bg"]/p[@class="type"][5]/text()')
.first
.replaceAll("Status: ", "");
anime.description = MBridge.xpath(
res, '//*[@class="anime_info_body_bg"]/p[@class="type"][2]/text()')
.first
.replaceAll("Plot Summary: ", "");
anime.status = MBridge.parseStatus(status, statusList);
anime.genre = MBridge.xpath(
res, '//*[@class="anime_info_body_bg"]/p[@class="type"][3]/text()')
@@ -91,7 +85,7 @@ getAnimeDetail(MangaModel anime) async {
return anime;
}
getVideoList(MangaModel anime) async {
getVideoList(MManga anime) async {
final datas = {"url": "${anime.baseUrl}${anime.link}"};
final res = await MBridge.http('GET', json.encode(datas));
@@ -104,13 +98,12 @@ getVideoList(MangaModel anime) async {
MBridge.xpath(res, '//*[@class="anime_muti_link"]/ul/li/a/@data-video');
final classNames =
MBridge.xpath(res, '//*[@class="anime_muti_link"]/ul/li/@class');
print(serverUrls);
List<VideoModel> videos = [];
List<MVideo> videos = [];
for (var i = 0; i < classNames.length; i++) {
final name = classNames[i];
final url = serverUrls[i];
print(url);
List<VideoModel> a = [];
List<MVideo> a = [];
if (name.contains("anime")) {
a = await MBridge.gogoCdnExtractor(url);
} else if (name.contains("vidcdn")) {
@@ -131,7 +124,7 @@ getVideoList(MangaModel anime) async {
return videos;
}
searchAnime(MangaModel anime) async {
searchAnime(MManga anime) async {
final url =
"${anime.baseUrl}/search.html?keyword=${anime.query}&page=${anime.page}";
final data = {"url": url};
@@ -140,9 +133,7 @@ searchAnime(MangaModel anime) async {
return anime;
}
anime.urls = MBridge.xpath(res, '//*[@class="img"]/a/@href');
anime.names = MBridge.xpath(res, '//*[@class="img"]/a/@title');
anime.images = MBridge.xpath(res, '//*[@class="img"]/a/img/@src');
return anime;
}

View File

@@ -2,7 +2,7 @@ import '../../../../model/source.dart';
import '../../../../utils/utils.dart';
Source get gogoanimeSource => _gogoanimeSource;
const gogoanimeVersion = "0.0.2";
const gogoanimeVersion = "0.0.3";
const gogoanimeSourceCodeUrl =
"https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/main/anime/src/en/gogoanime/gogoanime-v$gogoanimeVersion.dart";
Source _gogoanimeSource = Source(