parent
							
								
									86cac8697b
								
							
						
					
					
						commit
						d37e61728b
					
				| @ -5,7 +5,7 @@ ext { | |||||||
|     appName = 'Tachiyomi: MyReadingManga' |     appName = 'Tachiyomi: MyReadingManga' | ||||||
|     pkgNameSuffix = 'all.myreadingmanga' |     pkgNameSuffix = 'all.myreadingmanga' | ||||||
|     extClass = '.MyReadingMangaFactory' |     extClass = '.MyReadingMangaFactory' | ||||||
|     extVersionCode = 24 |     extVersionCode = 25 | ||||||
|     libVersion = '1.2' |     libVersion = '1.2' | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| package eu.kanade.tachiyomi.extension.all.myreadingmanga | package eu.kanade.tachiyomi.extension.all.myreadingmanga | ||||||
| 
 |  | ||||||
| import android.net.Uri | import android.net.Uri | ||||||
| import eu.kanade.tachiyomi.network.GET | import eu.kanade.tachiyomi.network.GET | ||||||
| import eu.kanade.tachiyomi.source.model.* | import eu.kanade.tachiyomi.source.model.* | ||||||
| @ -69,11 +68,20 @@ open class MyReadingManga(override val lang: String) : ParsedHttpSource() { | |||||||
|     override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request { |     override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request { | ||||||
| 
 | 
 | ||||||
|         val query2 = URLEncoder.encode(query, "UTF-8") |         val query2 = URLEncoder.encode(query, "UTF-8") | ||||||
|         val uri = Uri.parse("$baseUrl/search/").buildUpon() |         val uri = if (query.isNotBlank()) { | ||||||
|  |             Uri.parse("$baseUrl/search/").buildUpon() | ||||||
|                 .appendEncodedPath(query2) |                 .appendEncodedPath(query2) | ||||||
|                 .appendPath("page") |         } else { | ||||||
|                 .appendPath("$page") |             val uri = Uri.parse("$baseUrl/").buildUpon() | ||||||
|         return GET(uri.toString()) |             //Append uri filters | ||||||
|  |             filters.forEach { | ||||||
|  |                 if (it is UriFilter) | ||||||
|  |                     it.addToUri(uri) | ||||||
|  |             } | ||||||
|  |             uri | ||||||
|  |         } | ||||||
|  |         uri.appendPath("page").appendPath("$page") | ||||||
|  |         return GET(uri.toString(), headers) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -182,4 +190,60 @@ open class MyReadingManga(override val lang: String) : ParsedHttpSource() { | |||||||
|     override fun imageUrlRequest(page: Page) = throw Exception("Not used") |     override fun imageUrlRequest(page: Page) = throw Exception("Not used") | ||||||
|     override fun imageUrlParse(document: Document) = throw Exception("Not used") |     override fun imageUrlParse(document: Document) = throw Exception("Not used") | ||||||
| 
 | 
 | ||||||
|  |     //Filter Parsing, grabs home page as document and filters out Genres, Popular Tags, and Catagorys | ||||||
|  |     private val filterdoc = OkHttpClient().newCall(GET("$baseUrl", headers)).execute().asJsoup() | ||||||
|  |     private val genresarray = filterdoc.select(".tagcloud a[href*=/genre/]").map { Pair(it.attr("href").substringBeforeLast("/").substringAfterLast("/"), it.text())}.toTypedArray() | ||||||
|  |     private val poptagarray = filterdoc.select(".tagcloud a[href*=/tag/]").map { Pair(it.attr("href").substringBeforeLast("/").substringAfterLast("/"), it.text())}.toTypedArray() | ||||||
|  |     private val cattagarray = filterdoc.select(".level-0").map { Pair(it.attr("value"), it.text())}.toTypedArray() | ||||||
|  |      | ||||||
|  |     //Generates the filter lists for app | ||||||
|  |     override fun getFilterList(): FilterList { | ||||||
|  |         val filterList = FilterList( | ||||||
|  |             //MRM does not support genre filtering and text search at the same time | ||||||
|  |             Filter.Header("NOTE: Filters are ignored if using text search."), | ||||||
|  |             Filter.Header("Only one filter can be used at a time."), | ||||||
|  |             GenreFilter(genresarray), | ||||||
|  |             TagFilter(poptagarray), | ||||||
|  |             CatFilter(cattagarray) | ||||||
|  |         ) | ||||||
|  |         return filterList | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private class GenreFilter(GENRES: Array<Pair<String, String>>) : UriSelectFilterPath("Genre", "genre", arrayOf(Pair("","Any"),*GENRES)) | ||||||
|  |     private class TagFilter(POPTAG: Array<Pair<String, String>>) : UriSelectFilterPath("Popular Tags", "tag", arrayOf(Pair("","Any"),*POPTAG)) | ||||||
|  |     private class CatFilter(CATID: Array<Pair<String, String>>) : UriSelectFilterQuery("Categories", "cat", arrayOf(Pair("","Any"), *CATID)) | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Class that creates a select filter. Each entry in the dropdown has a name and a display name. | ||||||
|  |      * If an entry is selected it is appended as a query parameter onto the end of the URI. | ||||||
|  |      * If `firstIsUnspecified` is set to true, if the first entry is selected, nothing will be appended on the the URI. | ||||||
|  |      */ | ||||||
|  |     //vals: <name, display> | ||||||
|  |     private open class UriSelectFilterPath(displayName: String, val uriParam: String, val vals: Array<Pair<String, String>>, | ||||||
|  |                                        val firstIsUnspecified: Boolean = true, | ||||||
|  |                                        defaultValue: Int = 0) : | ||||||
|  |         Filter.Select<String>(displayName, vals.map { it.second }.toTypedArray(), defaultValue), UriFilter { | ||||||
|  |         override fun addToUri(uri: Uri.Builder) { | ||||||
|  |             if (state != 0 || !firstIsUnspecified) | ||||||
|  |                 uri.appendPath(uriParam) | ||||||
|  |                     .appendPath(vals[state].first) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     private open class UriSelectFilterQuery(displayName: String, val uriParam: String, val vals: Array<Pair<String, String>>, | ||||||
|  |                                        val firstIsUnspecified: Boolean = true, | ||||||
|  |                                        defaultValue: Int = 0) : | ||||||
|  |         Filter.Select<String>(displayName, vals.map { it.second }.toTypedArray(), defaultValue), UriFilter { | ||||||
|  |         override fun addToUri(uri: Uri.Builder) { | ||||||
|  |             if (state != 0 || !firstIsUnspecified) | ||||||
|  |                 uri.appendQueryParameter(uriParam, vals[state].first) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Represents a filter that is able to modify a URI. | ||||||
|  |      */ | ||||||
|  |     private interface UriFilter { | ||||||
|  |         fun addToUri(uri: Uri.Builder) | ||||||
|  |     } | ||||||
|  |      | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 happywillow0
						happywillow0