From 717af15488b3ba3fabc8801581adedcb5370521b Mon Sep 17 00:00:00 2001 From: paronos Date: Thu, 26 Apr 2018 20:52:48 +0200 Subject: [PATCH] remove duplicates in latest --- src/all/foolslide/build.gradle | 4 ++-- .../extension/en/foolslide/FoolSlide.kt | 18 ++++++++++++++---- 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/src/all/foolslide/build.gradle b/src/all/foolslide/build.gradle index ff811f56c..5821f444b 100644 --- a/src/all/foolslide/build.gradle +++ b/src/all/foolslide/build.gradle @@ -5,8 +5,8 @@ ext { appName = 'Tachiyomi: FoolSlide' pkgNameSuffix = "all.foolslide" extClass = '.FoolSlideFactory' - extVersionCode = 3 - extVersionSuffix = 3 + extVersionCode = 4 + extVersionSuffix = 4 libVersion = '1.2' } dependencies { diff --git a/src/all/foolslide/src/eu/kanade/tachiyomi/extension/en/foolslide/FoolSlide.kt b/src/all/foolslide/src/eu/kanade/tachiyomi/extension/en/foolslide/FoolSlide.kt index 66098f255..a20a704b1 100644 --- a/src/all/foolslide/src/eu/kanade/tachiyomi/extension/en/foolslide/FoolSlide.kt +++ b/src/all/foolslide/src/eu/kanade/tachiyomi/extension/en/foolslide/FoolSlide.kt @@ -4,13 +4,11 @@ import com.github.salomonbrys.kotson.get import com.google.gson.JsonParser import eu.kanade.tachiyomi.network.GET import eu.kanade.tachiyomi.network.POST -import eu.kanade.tachiyomi.source.model.FilterList -import eu.kanade.tachiyomi.source.model.Page -import eu.kanade.tachiyomi.source.model.SChapter -import eu.kanade.tachiyomi.source.model.SManga +import eu.kanade.tachiyomi.source.model.* import eu.kanade.tachiyomi.source.online.ParsedHttpSource import okhttp3.FormBody import okhttp3.Request +import okhttp3.Response import org.jsoup.nodes.Document import org.jsoup.nodes.Element import java.text.ParseException @@ -28,9 +26,21 @@ open class FoolSlide(override val name: String, override val baseUrl: String, ov return GET("$baseUrl$urlModifier/directory/$page/", headers) } + private val latestUpdatesUrls = HashSet() + + override fun latestUpdatesParse(response: Response): MangasPage { + val mp = super.latestUpdatesParse(response) + val mangas = mp.mangas.distinctBy { it.url }.filterNot { latestUpdatesUrls.contains(it.url) } + latestUpdatesUrls.addAll(mangas.map { it.url }) + return MangasPage(mangas, mp.hasNextPage) + } + override fun latestUpdatesSelector() = "div.group" override fun latestUpdatesRequest(page: Int): Request { + if (page == 1) { + latestUpdatesUrls.clear() + } return GET("$baseUrl$urlModifier/latest/$page/") }