Add extension: Real Life Comics (#8653)

* add icon for reallifecomics source

* add required manifest and gradle file

* add reallifecomics source

original webcomic link - https://reallifecomics.com

* page index starts at 0

* initialise Page correctly

imageUrl was what I was trying to set

* parse date_upload for chapterList differently

posts before 2014 don't have the date in the link. However, they are
still arranged in a Calendar. Use this calendar to find a date.

* skip years with no archive pages

* cleanup and edits

* now able to parse all years without link issues

* add an extra space to chapter names

for aesthetics! also follows what is shown on the website

* have a simple Search feature

since a search just throwing an error seemed weird
This commit is contained in:
nicki 2021-08-20 15:53:56 +05:30 committed by GitHub
parent 4746ab375b
commit 8bf86ecba3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 175 additions and 0 deletions

View File

@ -0,0 +1,2 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest package="eu.kanade.tachiyomi.extension" />

View File

@ -0,0 +1,16 @@
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
ext {
extName = 'Real Life Comics'
pkgNameSuffix = 'en.reallifecomics'
extClass = '.RealLifeComics'
extVersionCode = 1
libVersion = '1.2'
}
dependencies {
// implementation project(':lib-ratelimit')
}
apply from: "$rootDir/common.gradle"

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@color/ic_launcher_background"/>
<foreground android:drawable="@mipmap/ic_launcher_foreground"/>
</adaptive-icon>

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@color/ic_launcher_background"/>
<foreground android:drawable="@mipmap/ic_launcher_foreground"/>
</adaptive-icon>

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 37 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 61 KiB

View File

@ -0,0 +1,4 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="ic_launcher_background">#FFFFFF</color>
</resources>

Binary file not shown.

After

Width:  |  Height:  |  Size: 155 KiB

View File

@ -0,0 +1,143 @@
package eu.kanade.tachiyomi.extension.en.reallifecomics
import eu.kanade.tachiyomi.source.model.FilterList
import eu.kanade.tachiyomi.source.model.MangasPage
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.online.ParsedHttpSource
import okhttp3.Response
import org.jsoup.nodes.Document
import org.jsoup.nodes.Element
import rx.Observable
import java.text.SimpleDateFormat
import java.util.Calendar
import java.util.Locale
class RealLifeComics : ParsedHttpSource() {
override val name = "Real Life Comics"
override val baseUrl = "https://reallifecomics.com"
override val lang = "en"
override val supportsLatest = false
// Helper
private fun createManga(year: Int): SManga = SManga.create().apply {
setUrlWithoutDomain("/archivepage.php?year=$year")
title = "$name ($year)"
thumbnail_url = "$baseUrl$LOGO"
author = AUTHOR
status = if (year != currentYear) SManga.COMPLETED else SManga.ONGOING
description = "$SUMMARY $year"
}
// Popular
override fun fetchPopularManga(page: Int): Observable<MangasPage> {
// create one manga entry for each yearly archive
// skip 2016 and 2017 as they don't have any archive
return (currentYear downTo 1999).filter { it !in 2016..2017 }
.map { createManga(it) }
.let { Observable.just(MangasPage(it, false))!! }
}
// Search
override fun fetchSearchManga(page: Int, query: String, filters: FilterList): Observable<MangasPage> =
fetchPopularManga(1).map { mangaList ->
mangaList.copy(mangaList.mangas.filter { it.title.contains(query) })
}
// Details
override fun fetchMangaDetails(manga: SManga) = Observable.just(
manga.apply {
initialized = true
}
)!!
// Chapters
override fun chapterListParse(response: Response): List<SChapter> {
return super.chapterListParse(response).distinct().mapIndexed { index, chapter ->
chapter.apply { chapter_number = index.toFloat() }
}
}
override fun chapterListSelector() = ".calendar tbody tr td a"
override fun chapterFromElement(element: Element) = SChapter.create().apply {
url = element.attr("href")
// entries between 1999-2014 do not have dates in the link
// but all entries are placed in a calendar class which has the month & year as heading
// figure out a date using the calendar
// perhaps there might be a better way to get this but for now this works
val monthYear = element
.parent()
.parent()
.parent()
.parent()
.firstElementSibling()
.text()
val date = "$monthYear ${element.text()}"
val parsedDate = SimpleDateFormat("MMMM yyyy dd", Locale.US).parse(date)
date_upload = parsedDate?.time ?: 0L
// chapter names are kept the same as what the site has
name = SimpleDateFormat("EEEE, MMM dd, yyyy", Locale.US).format(parsedDate ?: 0L)
}
// Page
override fun pageListParse(document: Document): List<Page> {
val image = document.select(".comic img").attr("src")
return listOf(Page(0, "", image))
}
// Unsupported
override fun imageUrlParse(document: Document) = throw Exception("Not used")
override fun popularMangaSelector() = throw Exception("Not used")
override fun searchMangaFromElement(element: Element) = throw Exception("Not used")
override fun searchMangaNextPageSelector() = throw Exception("Not used")
override fun searchMangaSelector() = throw Exception("Not used")
override fun popularMangaRequest(page: Int) = throw Exception("Not used")
override fun searchMangaRequest(page: Int, query: String, filters: FilterList) = throw Exception("Not used")
override fun popularMangaNextPageSelector() = throw Exception("Not used")
override fun popularMangaFromElement(element: Element) = throw Exception("Not used")
override fun mangaDetailsParse(document: Document) = throw Exception("Not used")
override fun latestUpdatesNextPageSelector() = throw Exception("Not used")
override fun latestUpdatesFromElement(element: Element) = throw Exception("Not used")
override fun latestUpdatesRequest(page: Int) = throw Exception("Not used")
override fun latestUpdatesSelector() = throw Exception("Not used")
companion object {
private const val LOGO = "/images/logo.png"
private const val AUTHOR = "Maelyn Dean"
private const val SUMMARY = "The normal daily lives of some abnormal people. This entry includes all the chapters published in"
private val currentYear by lazy {
Calendar.getInstance()[Calendar.YEAR]
}
}
}