Compare commits
	
		
			78 Commits
		
	
	
		
			v1.6
			...
			v161810286
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 598149d4cd | ||
|  | 5569a47674 | ||
|  | 0dc6981913 | ||
|  | 4984f2f7ad | ||
|  | 3b6891c84a | ||
|  | 4901e7174c | ||
|  | 8d70e68fe2 | ||
|  | d3e1527b70 | ||
|  | 0c201301f2 | ||
|  | 6090590f24 | ||
|  | 06b88c783d | ||
|  | bb75ebf635 | ||
|  | 7d7d0014be | ||
|  | b3f8d44794 | ||
|  | 29d1e38340 | ||
|  | 2be872e61e | ||
|  | 377c5518f7 | ||
|  | 21be7357b5 | ||
|  | d47ba2c820 | ||
|  | a64b14614a | ||
|  | 6a88192e77 | ||
|  | aa7c630818 | ||
|  | 7fb54f14c7 | ||
|  | 3d709c02b7 | ||
|  | 339d384561 | ||
|  | 50338d51af | ||
|  | 92dbabf899 | ||
|  | 0043021390 | ||
|  | 70ba9b20da | ||
|  | 7fda0a04a1 | ||
|  | 3db3157dc9 | ||
|  | 2089fe60ca | ||
|  | 9606d36670 | ||
|  | 869cf64c54 | ||
|  | f57ec1f6c0 | ||
|  | 361eea9a06 | ||
|  | 838b4056ac | ||
|  | 0c0a98510b | ||
|  | be642ed06f | ||
|  | fd77f38e95 | ||
|  | c9baab7267 | ||
|  | 86985cfd5b | ||
|  | 1327a4e069 | ||
|  | c46acbc579 | ||
|  | 4c6a403fae | ||
|  | 78920022bd | ||
|  | 7b16c41e82 | ||
|  | 3389f8bd09 | ||
|  | 8dc25c527d | ||
|  | 46d6bd57c1 | ||
|  | db014fe13d | ||
|  | 6c293f4cac | ||
|  | 91e5d3736f | ||
|  | e11dee220f | ||
|  | fcebf916d2 | ||
|  | 73cc1a7297 | ||
|  | 798f112498 | ||
|  | 38b5e7dc65 | ||
|  | 2799a48f2b | ||
|  | ad5edae6cd | ||
|  | 9cb02f0272 | ||
|  | 6d24fd9336 | ||
|  | a3a7b78c96 | ||
|  | e995286068 | ||
|  | 65fb6d9b7e | ||
|  | eb02d1efad | ||
|  | f8d3e1eefb | ||
|  | 218b8fa843 | ||
|  | 9f94af6239 | ||
|  | d3584ac40e | ||
|  | 90bdb289d0 | ||
|  | 78a08750a2 | ||
|  | baba851e97 | ||
|  | 2a03783623 | ||
|  | 9f2a4438b1 | ||
|  | 5ee5287ffa | ||
|  | 29547c2c94 | ||
|  | 4846c870fa | 
							
								
								
									
										14
									
								
								.github/CONTRIBUTING.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/CONTRIBUTING.md
									
									
									
									
										vendored
									
									
								
							| @@ -47,15 +47,8 @@ You can directly import this project into IntellIJ/Android Studio. | |||||||
|  |  | ||||||
| You'll have to: | You'll have to: | ||||||
|  |  | ||||||
| - Configure fabric and add your `apiKey` and `apiSecret` in the `fabric.properties` file. |  | ||||||
| - Create a firebase project and add the `google-services.json` to the `app/` folder. |  | ||||||
| - Define some parameters either in `~/.gradle/gradle.properties` or as gradle parameters (see the examples) | - Define some parameters either in `~/.gradle/gradle.properties` or as gradle parameters (see the examples) | ||||||
|  |  | ||||||
|     - mercuryApiKey: A [Mercury](https://mercury.postlight.com/web-parser/) web parser api key for the internal browser |  | ||||||
|     - feedbackEmail: An email to receive users  feedback. |  | ||||||
|     - sourceUrl: an url to the source code, used in the settings. **It can be empty.** |  | ||||||
|     - trackerUrl: an url to the tracker, used in the settings. **It can be empty.** |  | ||||||
|     - githubToken: a github token used to report issues from within the app. [Details  here](https://github.com/heinrichreimer/android-issue-reporter#how-to-create-a-bot-key). **It can be empty.**  |  | ||||||
|     - appLoginUrl, appLoginUsername and appLoginPassword: url, username and password of a selfoss instance. **These are only used for tests. They can be empty if you don't test API calls.** |     - appLoginUrl, appLoginUsername and appLoginPassword: url, username and password of a selfoss instance. **These are only used for tests. They can be empty if you don't test API calls.** | ||||||
|  |  | ||||||
| ### Examples: | ### Examples: | ||||||
| @@ -65,15 +58,10 @@ You'll have to: | |||||||
| appLoginUrl="URL" # It can be empty. | appLoginUrl="URL" # It can be empty. | ||||||
| appLoginUsername="LOGIN" # It can be empty. | appLoginUsername="LOGIN" # It can be empty. | ||||||
| appLoginPassword="PASS" # It can be empty. | appLoginPassword="PASS" # It can be empty. | ||||||
| mercuryApiKey="LONGAPIKEY" |  | ||||||
| feedbackEmail="EMAIL" |  | ||||||
| sourceUrl="URLSOURCE" # It can be empty. |  | ||||||
| trackerUrl="URLTRACKER" # It can be empty. |  | ||||||
| githubToken="GITHUBTOKEN" # It can be empty or use https://github.com/heinrichreimer/android-issue-reporter#how-to-create-a-bot-key to generate one |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| #### As gradle parameters | #### As gradle parameters | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| ./gradlew .... -P appLoginUrl="URL" -P appLoginUsername="LOGIN" -P appLoginPassword="PASS" -P mercuryApiKey="LONGAPIKEY" -P feedbackEmail="EMAIL" -P sourceUrl="URLSOURCE" -P trackerUrl="URLTRACKER" -P githubToken="GITHUBTOKEN" | ./gradlew .... -P appLoginUrl="URL" -P appLoginUsername="LOGIN" -P appLoginPassword="PASS" | ||||||
| ``` | ``` | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,3 +1,23 @@ | |||||||
|  | **1.6.x** | ||||||
|  |  | ||||||
|  | - Handling hidden tags. | ||||||
|  |  | ||||||
|  | - Fixed pre-lolipop issue with automatic theme changes. | ||||||
|  |  | ||||||
|  | - Removed all Build config things. | ||||||
|  |  | ||||||
|  | - Removed firebase and fabric. | ||||||
|  |  | ||||||
|  | - Added Acra for optional crash reporting and error logging. | ||||||
|  |  | ||||||
|  | - Dynamic themes ! | ||||||
|  |  | ||||||
|  | - Strings cleaning. | ||||||
|  |  | ||||||
|  | - Versions updates. | ||||||
|  |  | ||||||
|  | - Fixes #215, #208. | ||||||
|  |  | ||||||
| **1.5.7.x** | **1.5.7.x** | ||||||
|  |  | ||||||
| - Added confirmation to the mark as read and update menues. | - Added confirmation to the mark as read and update menues. | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,19 +1,20 @@ | |||||||
| # ReaderForSelfoss | # ReaderForSelfoss | ||||||
|  |  | ||||||
| [](https://join.slack.com/t/readerforselfoss/shared_invite/enQtMjkyNzc3NjM2Mjc1LTUzZTZhOGM5YjQ1MTI5MWZiODRjMjE1ZDBmMzQxZmQ3NWZhYTNhMTBjNGEwNmE2ZGFjODU5NjUxZjBkMWJmMDQ) | [](https://join.slack.com/t/readerforselfoss/shared_invite/enQtMjkyNzc3NjM2Mjc1LTUzZTZhOGM5YjQ1MTI5MWZiODRjMjE1ZDBmMzQxZmQ3NWZhYTNhMTBjNGEwNmE2ZGFjODU5NjUxZjBkMWJmMDQ) [](https://jenkins.amine-bou.fr/job/ReaderForSelfoss/) [](https://www.codetriage.com/aminecmi/readerforselfoss) [](https://crowdin.com/project/readerforselfoss) | ||||||
|  |  | ||||||
| [](http://jenkins.amine-bou.fr/job/ReaderForSelfoss/) |  | ||||||
|  |  | ||||||
| [](https://www.codetriage.com/aminecmi/readerforselfoss) |  | ||||||
|  |  | ||||||
| [](https://crowdin.com/project/readerforselfoss) |  | ||||||
|  |  | ||||||
| This is the repo of [Reader For Selfoss](https://play.google.com/store/apps/details?id=apps.amine.bou.readerforselfoss&hl=en). |  | ||||||
|  |  | ||||||
| It's an RSS Reader for Android, that **only** works with [Selfoss](https://selfoss.aditu.de/) | It's an RSS Reader for Android, that **only** works with [Selfoss](https://selfoss.aditu.de/) | ||||||
|  |  | ||||||
| The last APK built from source is available [here](https://jenkins.amine-bou.fr/job/ReaderForSelfoss/lastSuccessfulBuild/artifact/SignApksBuilder-out/selfoss-key/selfoss/app-githubConfig-release-unsigned.apk/app-githubConfig-release.apk). | <a href='https://play.google.com/store/apps/details?id=apps.amine.bou.readerforselfoss'><img alt='Get it on Google Play' src='https://play.google.com/intl/en_us/badges/images/generic/en_badge_web_generic.png' height="100"/></a> <a href="https://f-droid.org/packages/apps.amine.bou.readerforselfoss"><img src="https://f-droid.org/badge/get-it-on.png" alt="Get it on F-Droid" height="100"></a> | ||||||
|  |  | ||||||
|  | Also, the last APK built from source is available [here](https://jenkins.amine-bou.fr/job/ReaderForSelfoss/lastSuccessfulBuild/artifact/SignApksBuilder-out/selfoss-key/selfoss/app-githubConfig-release-unsigned.apk/app-githubConfig-release.apk). | ||||||
|  |  | ||||||
|  | ## Join the alpha channel | ||||||
|  |  | ||||||
|  | **Keep in mind, it could be instable, but you'll have the new updates faster** | ||||||
|  |  | ||||||
|  | - First, join the google [group](https://groups.google.com/d/forum/reader-for-selfoss-alpha-testing). | ||||||
|  | - Then, join the [alpha channel](https://play.google.com/apps/testing/apps.amine.bou.readerforselfoss) of the app. | ||||||
|  | - You'll be able to update the app for the current alpha version. | ||||||
|  |  | ||||||
| ## Want to help ? | ## Want to help ? | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										153
									
								
								app/build.gradle
									
									
									
									
									
								
							
							
						
						
									
										153
									
								
								app/build.gradle
									
									
									
									
									
								
							| @@ -1,11 +1,4 @@ | |||||||
| buildscript { | buildscript { | ||||||
|     repositories { |  | ||||||
|         maven { url 'https://maven.fabric.io/public' } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     dependencies { |  | ||||||
|         classpath 'io.fabric.tools:gradle:1.+' |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| ext { | ext { | ||||||
| @@ -22,40 +15,34 @@ def gitVersion() { | |||||||
| } | } | ||||||
|  |  | ||||||
| def versionCodeFromGit() { | def versionCodeFromGit() { | ||||||
|     def dayInYear = ext.configuration.buildDate.format("D").padLeft(3, '0') |     println "version code " + gitVersion() | ||||||
|     def versionCode = gitVersion() + (ext.configuration.buildDate.format("yyMM") + dayInYear + ext.todaysBuilds).toInteger() |     return gitVersion().toInteger() | ||||||
|     println "version code " + versionCode |  | ||||||
|     return versionCode.toInteger() |  | ||||||
| } | } | ||||||
|  |  | ||||||
| def versionNameFromGit() { | def versionNameFromGit() { | ||||||
|     def dayInYear = ext.configuration.buildDate.format("D").padLeft(3, '0') |     println "version name " + gitVersion() | ||||||
|     def versionName = gitVersion() + ext.configuration.buildDate.format('yyMM') + dayInYear + ext.todaysBuilds |     return gitVersion() | ||||||
|     println "version name " + versionName |  | ||||||
|     return versionName |  | ||||||
| } | } | ||||||
|  |  | ||||||
| apply plugin: 'com.android.application' | apply plugin: 'kotlin-kapt' | ||||||
|  |  | ||||||
| apply plugin: 'io.fabric' | apply plugin: 'com.android.application' | ||||||
|  |  | ||||||
| apply plugin: 'kotlin-android' | apply plugin: 'kotlin-android' | ||||||
|  |  | ||||||
| apply plugin: 'kotlin-android-extensions' | apply plugin: 'kotlin-android-extensions' | ||||||
|  |  | ||||||
| repositories { |  | ||||||
|     maven { |  | ||||||
|         url 'https://maven.fabric.io/public' |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| android { | android { | ||||||
|     compileSdkVersion 27 |     compileOptions { | ||||||
|     buildToolsVersion '27.0.3' |         sourceCompatibility JavaVersion.VERSION_1_8 | ||||||
|  |         targetCompatibility JavaVersion.VERSION_1_8 | ||||||
|  |     } | ||||||
|  |     compileSdkVersion 28 | ||||||
|  |     buildToolsVersion '28.0.3' | ||||||
|     defaultConfig { |     defaultConfig { | ||||||
|         applicationId "apps.amine.bou.readerforselfoss" |         applicationId "apps.amine.bou.readerforselfoss" | ||||||
|         minSdkVersion 16 |         minSdkVersion 16 | ||||||
|         targetSdkVersion 27 |         targetSdkVersion 28 | ||||||
|         versionCode versionCodeFromGit() |         versionCode versionCodeFromGit() | ||||||
|         versionName versionNameFromGit() |         versionName versionNameFromGit() | ||||||
|  |  | ||||||
| @@ -68,14 +55,7 @@ android { | |||||||
|         vectorDrawables.useSupportLibrary = true |         vectorDrawables.useSupportLibrary = true | ||||||
|  |  | ||||||
|         // tests |         // tests | ||||||
|         testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" |         testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" | ||||||
|  |  | ||||||
|         buildConfigField "String", "MERCURY_KEY", mercuryApiKey |  | ||||||
|         buildConfigField "String", "FEEDBACK_EMAIL", feedbackEmail |  | ||||||
|         buildConfigField "String", "SOURCE_URL", sourceUrl |  | ||||||
|         buildConfigField "String", "TRACKER_URL", trackerUrl |  | ||||||
|         buildConfigField "String", "TRANSLATION_URL", translationUrl |  | ||||||
|         buildConfigField "String", "GITHUB_TOKEN", githubToken |  | ||||||
|     } |     } | ||||||
|     buildTypes { |     buildTypes { | ||||||
|         release { |         release { | ||||||
| @@ -88,6 +68,7 @@ android { | |||||||
|             buildConfigField "String", "LOGIN_URL", appLoginUrl |             buildConfigField "String", "LOGIN_URL", appLoginUrl | ||||||
|             buildConfigField "String", "LOGIN_USERNAME", appLoginUsername |             buildConfigField "String", "LOGIN_USERNAME", appLoginUsername | ||||||
|             buildConfigField "String", "LOGIN_PASSWORD", appLoginPassword |             buildConfigField "String", "LOGIN_PASSWORD", appLoginPassword | ||||||
|  |             applicationIdSuffix ".dev" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     flavorDimensions "build" |     flavorDimensions "build" | ||||||
| @@ -95,56 +76,40 @@ android { | |||||||
|         githubConfig { |         githubConfig { | ||||||
|             versionNameSuffix '-github' |             versionNameSuffix '-github' | ||||||
|             dimension "build" |             dimension "build" | ||||||
|             buildConfigField "boolean", "GITHUB_VERSION", "true" |  | ||||||
|         } |         } | ||||||
|         storeConfig { |         storeConfig { | ||||||
|             // As jenkins publishes to alpha first, this is the default suffix now. |             // As jenkins publishes to alpha first, this is the default suffix now. | ||||||
|             versionNameSuffix '-store' |             versionNameSuffix '-store' | ||||||
|             dimension "build" |             dimension "build" | ||||||
|             buildConfigField "boolean", "GITHUB_VERSION", "false" |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     // Testing |     // Testing | ||||||
|     androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1' |     androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.0-beta02' | ||||||
|     androidTestImplementation 'com.android.support.test:runner:1.0.1' |     androidTestImplementation 'androidx.test:runner:1.1.0-beta02' | ||||||
|     // Espresso-contrib for DatePicker, RecyclerView, Drawer actions, Accessibility checks, CountingIdlingResource |     // Espresso-contrib for DatePicker, RecyclerView, Drawer actions, Accessibility checks, CountingIdlingResource | ||||||
|     androidTestImplementation 'com.android.support.test.espresso:espresso-contrib:3.0.1' |     androidTestImplementation 'androidx.test.espresso:espresso-contrib:3.1.0-beta02' | ||||||
|     // Espresso-intents for validation and stubbing of Intents |     // Espresso-intents for validation and stubbing of Intents | ||||||
|     androidTestImplementation 'com.android.support.test.espresso:espresso-intents:3.0.1' |     androidTestImplementation 'androidx.test.espresso:espresso-intents:3.1.0-beta02' | ||||||
|  |     implementation fileTree(include: ['*.jar'], dir: 'libs') | ||||||
|  |  | ||||||
|     implementation fileTree(dir: 'libs', include: ['*.jar']) |  | ||||||
|     implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version" |     implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version" | ||||||
|  |  | ||||||
|     // Android Support |     // Android Support | ||||||
|     implementation 'com.android.support:appcompat-v7:27.1.1' |     implementation "androidx.appcompat:appcompat:$android_version" | ||||||
|     implementation 'com.android.support:design:27.1.1' |     implementation "com.google.android.material:material:$android_version" | ||||||
|     implementation 'com.android.support:recyclerview-v7:27.1.1' |     implementation "androidx.recyclerview:recyclerview:$android_version" | ||||||
|     implementation 'com.android.support:support-v4:27.1.1' |     implementation "androidx.legacy:legacy-support-v4:$android_version" | ||||||
|     implementation 'com.android.support:support-vector-drawable:27.1.1' |     implementation "androidx.vectordrawable:vectordrawable:$android_version" | ||||||
|     implementation 'com.android.support:customtabs:27.1.1' |     implementation "androidx.browser:browser:$android_version" | ||||||
|     implementation 'com.android.support:cardview-v7:27.1.1' |     implementation "androidx.cardview:cardview:$android_version" | ||||||
|     implementation 'com.android.support.constraint:constraint-layout:1.0.2' |     implementation 'androidx.constraintlayout:constraintlayout:2.0.0-alpha2' | ||||||
|  |  | ||||||
|     // Firebase + crashlytics |  | ||||||
|     implementation 'com.google.firebase:firebase-core:12.0.1' |  | ||||||
|     implementation 'com.google.firebase:firebase-config:12.0.1' |  | ||||||
|     implementation 'com.google.firebase:firebase-invites:12.0.1' |  | ||||||
|     implementation('com.crashlytics.sdk.android:crashlytics:2.9.1@aar') { |  | ||||||
|         transitive = true |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     //multidex |     //multidex | ||||||
|     implementation 'com.android.support:multidex:1.0.3' |     implementation 'androidx.multidex:multidex:2.0.0' | ||||||
|  |  | ||||||
|     // Intro |  | ||||||
|     implementation 'agency.tango.android:material-intro-screen:0.0.5' |  | ||||||
|  |  | ||||||
|     // About |     // About | ||||||
|     implementation('com.mikepenz:aboutlibraries:6.0.0@aar') { |     implementation('com.mikepenz:aboutlibraries:6.2.0@aar') { | ||||||
|         transitive = true |         transitive = true | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -155,8 +120,8 @@ dependencies { | |||||||
|     implementation 'com.burgstaller:okhttp-digest:1.12' |     implementation 'com.burgstaller:okhttp-digest:1.12' | ||||||
|  |  | ||||||
|     // Material-ish things |     // Material-ish things | ||||||
|     implementation 'com.ashokvarma.android:bottom-navigation-bar:2.0.3' |     implementation 'com.ashokvarma.android:bottom-navigation-bar:2.0.5' | ||||||
|     implementation 'com.github.jd-alexander:LikeButton:0.2.1' |     implementation 'com.github.jd-alexander:LikeButton:0.2.3' | ||||||
|     implementation 'com.amulyakhare:com.amulyakhare.textdrawable:1.0.1' |     implementation 'com.amulyakhare:com.amulyakhare.textdrawable:1.0.1' | ||||||
|  |  | ||||||
|     // glide |     // glide | ||||||
| @@ -164,46 +129,35 @@ dependencies { | |||||||
|     implementation 'com.github.bumptech.glide:okhttp3-integration:4.1.1' |     implementation 'com.github.bumptech.glide:okhttp3-integration:4.1.1' | ||||||
|  |  | ||||||
|     // Asking politely users to rate the app |     // Asking politely users to rate the app | ||||||
|     implementation 'com.github.stkent:amplify:2.1.0' |     implementation 'com.github.stkent:amplify:2.2.0' | ||||||
|  |  | ||||||
|     // Drawer |     // Drawer | ||||||
|     implementation 'co.zsmb:materialdrawer-kt:1.2.1' |     implementation 'co.zsmb:materialdrawer-kt:2.0.1' | ||||||
|     implementation 'com.anupcowkur:reservoir:3.1.0' |  | ||||||
|  |  | ||||||
|     // Themes |     // Themes | ||||||
|     implementation 'com.52inc:scoops:1.0.0' |     implementation 'com.52inc:scoops:1.0.0' | ||||||
|     implementation'com.jrummyapps:colorpicker:2.1.7' |     implementation 'com.jaredrummler:colorpicker:1.0.2' | ||||||
|  |  | ||||||
|     // Github issues reporter |  | ||||||
|     implementation 'com.heinrichreimersoftware:android-issue-reporter:1.3.1' |  | ||||||
|  |  | ||||||
|     implementation 'com.github.rubensousa:floatingtoolbar:1.5.1' |     implementation 'com.github.rubensousa:floatingtoolbar:1.5.1' | ||||||
|  |  | ||||||
|     // Pager |     // Pager | ||||||
|     implementation 'me.relex:circleindicator:1.2.2@aar' |     implementation 'me.relex:circleindicator:2.0.0@aar' | ||||||
|  |  | ||||||
|     implementation 'androidx.core:core-ktx:0.3' |     implementation 'androidx.core:core-ktx:1.0.0' | ||||||
|  |  | ||||||
|  |     // Crash | ||||||
|  |     implementation 'ch.acra:acra-http:5.1.3' | ||||||
|  |     implementation 'ch.acra:acra-dialog:5.1.3' | ||||||
|  |  | ||||||
|  |     implementation "androidx.lifecycle:lifecycle-livedata:$lifecycle_version" | ||||||
|  |     implementation "androidx.lifecycle:lifecycle-common-java8:$lifecycle_version" | ||||||
|  |  | ||||||
|  |     implementation "androidx.room:room-runtime:$room_version" | ||||||
|  |     kapt "androidx.room:room-compiler:$room_version" | ||||||
| } | } | ||||||
|  |  | ||||||
| apply plugin: 'com.google.gms.google-services' |  | ||||||
|  |  | ||||||
|  |  | ||||||
| afterEvaluate { | afterEvaluate { | ||||||
|     initFabricPropertiesIfNeeded() |  | ||||||
|     initAppLoginPropertiesIfNeeded() |     initAppLoginPropertiesIfNeeded() | ||||||
|     initAppForSecretPropertiesIfNeeded() |  | ||||||
| } |  | ||||||
|  |  | ||||||
| def initFabricPropertiesIfNeeded() { |  | ||||||
|     def propertiesFile = file('fabric.properties') |  | ||||||
|     if (!propertiesFile.exists()) { |  | ||||||
|         def commentMessage = "This is autogenerated fabric property from system environment to prevent key to be committed to source control." |  | ||||||
|         ant.propertyfile(file: "fabric.properties", comment: commentMessage) { |  | ||||||
|             entry(key: "apiSecret", value: crashlyticsdemoApisecret) |  | ||||||
|             entry(key: "apiKey", value: crashlyticsdemoApikey) |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| def initAppLoginPropertiesIfNeeded() { | def initAppLoginPropertiesIfNeeded() { | ||||||
| @@ -217,18 +171,3 @@ def initAppLoginPropertiesIfNeeded() { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| def initAppForSecretPropertiesIfNeeded() { |  | ||||||
|     def propertiesFile = file(System.getProperty("user.home") + '/.gradle/gradle.properties') |  | ||||||
|     if (!propertiesFile.exists()) { |  | ||||||
|         def commentMessage = "This is autogenerated local property from system environment to prevent key to be committed to source control." |  | ||||||
|         ant.propertyfile(file: System.getProperty("user.home") + "/.gradle/gradle.properties", comment: commentMessage) { |  | ||||||
|             entry(key: "mercuryApiKey", value: System.getProperty("mercuryApiKey")) |  | ||||||
|             entry(key: "feedbackEmail", value: System.getProperty("feedbackEmail")) |  | ||||||
|             entry(key: "sourceUrl", value: System.getProperty("sourceUrl")) |  | ||||||
|             entry(key: "trackerUrl", value: System.getProperty("trackerUrl")) |  | ||||||
|             entry(key: "translationUrl", value: System.getProperty("translationUrl")) |  | ||||||
|             entry(key: "githubToken", value: System.getProperty("githubToken")) |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -2,30 +2,29 @@ package apps.amine.bou.readerforselfoss | |||||||
|  |  | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.support.test.InstrumentationRegistry | import androidx.test.InstrumentationRegistry | ||||||
| import android.support.test.espresso.Espresso.onView | import androidx.test.espresso.Espresso.onView | ||||||
| import android.support.test.espresso.Espresso.openActionBarOverflowOrOptionsMenu | import androidx.test.espresso.Espresso.openActionBarOverflowOrOptionsMenu | ||||||
| import android.support.test.espresso.action.ViewActions.click | import androidx.test.espresso.action.ViewActions.click | ||||||
| import android.support.test.espresso.action.ViewActions.closeSoftKeyboard | import androidx.test.espresso.action.ViewActions.closeSoftKeyboard | ||||||
| import android.support.test.espresso.action.ViewActions.pressBack | import androidx.test.espresso.action.ViewActions.pressBack | ||||||
| import android.support.test.espresso.action.ViewActions.pressKey | import androidx.test.espresso.action.ViewActions.pressKey | ||||||
| import android.support.test.espresso.action.ViewActions.typeText | import androidx.test.espresso.action.ViewActions.typeText | ||||||
| import android.support.test.espresso.assertion.ViewAssertions.matches | import androidx.test.espresso.assertion.ViewAssertions.matches | ||||||
| import android.support.test.espresso.contrib.DrawerActions | import androidx.test.espresso.contrib.DrawerActions | ||||||
| import android.support.test.espresso.intent.Intents | import androidx.test.espresso.intent.Intents | ||||||
| import android.support.test.espresso.intent.Intents.intended | import androidx.test.espresso.intent.Intents.intended | ||||||
| import android.support.test.espresso.intent.Intents.times | import androidx.test.espresso.intent.Intents.times | ||||||
| import android.support.test.espresso.intent.matcher.IntentMatchers.hasComponent | import androidx.test.espresso.intent.matcher.IntentMatchers.hasComponent | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.isDisplayed | import androidx.test.espresso.matcher.ViewMatchers.isDisplayed | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.isRoot | import androidx.test.espresso.matcher.ViewMatchers.isRoot | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.withContentDescription | import androidx.test.espresso.matcher.ViewMatchers.withContentDescription | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.withId | import androidx.test.espresso.matcher.ViewMatchers.withId | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.withText | import androidx.test.espresso.matcher.ViewMatchers.withText | ||||||
| import android.support.test.rule.ActivityTestRule | import androidx.test.rule.ActivityTestRule | ||||||
| import android.support.test.runner.AndroidJUnit4 | import androidx.test.runner.AndroidJUnit4 | ||||||
| import android.view.KeyEvent | import android.view.KeyEvent | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
| import com.heinrichreimersoftware.androidissuereporter.IssueReporterLauncher |  | ||||||
| import org.junit.After | import org.junit.After | ||||||
| import org.junit.Before | import org.junit.Before | ||||||
| import org.junit.Rule | import org.junit.Rule | ||||||
| @@ -92,25 +91,6 @@ class HomeActivityEspressoTest { | |||||||
|         intended(hasComponent(LoginActivity::class.java.name), times(1)) |         intended(hasComponent(LoginActivity::class.java.name), times(1)) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Test |  | ||||||
|     fun drawerTesting() { |  | ||||||
|  |  | ||||||
|         rule.launchActivity(Intent()) |  | ||||||
|  |  | ||||||
|         onView(withId(R.id.material_drawer_layout)).perform(DrawerActions.open()) |  | ||||||
|  |  | ||||||
|         onView(withText(R.string.drawer_report_bug)).perform(click()) |  | ||||||
|         intended(hasComponent(IssueReporterLauncher.Activity::class.java.name)) |  | ||||||
|         onView(isRoot()).perform(pressBack()) |  | ||||||
|         onView(isRoot()).perform(pressBack()) |  | ||||||
|         intended(hasComponent(HomeActivity::class.java.name)) |  | ||||||
|  |  | ||||||
|         onView(withId(R.id.material_drawer_layout)).perform(DrawerActions.open()) |  | ||||||
|  |  | ||||||
|         onView(withId(R.id.material_drawer_layout)).perform(DrawerActions.open()) |  | ||||||
|         onView(withText(R.string.drawer_action_clear)).perform(click()) |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     // TODO: test articles opening and actions for cards and lists |     // TODO: test articles opening and actions for cards and lists | ||||||
|  |  | ||||||
|     @After |     @After | ||||||
|   | |||||||
| @@ -1,91 +0,0 @@ | |||||||
| package apps.amine.bou.readerforselfoss |  | ||||||
|  |  | ||||||
| import android.content.Context |  | ||||||
| import android.content.Intent |  | ||||||
| import android.support.test.InstrumentationRegistry.getInstrumentation |  | ||||||
| import android.support.test.espresso.Espresso.onView |  | ||||||
| import android.support.test.espresso.action.ViewActions.click |  | ||||||
| import android.support.test.espresso.assertion.ViewAssertions.matches |  | ||||||
| import android.support.test.espresso.intent.Intents |  | ||||||
| import android.support.test.espresso.intent.Intents.intended |  | ||||||
| import android.support.test.espresso.intent.Intents.times |  | ||||||
| import android.support.test.espresso.intent.matcher.IntentMatchers.hasComponent |  | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.isDisplayed |  | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.withId |  | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.withText |  | ||||||
| import android.support.test.rule.ActivityTestRule |  | ||||||
| import android.support.test.runner.AndroidJUnit4 |  | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config |  | ||||||
| import org.junit.After |  | ||||||
| import org.junit.Before |  | ||||||
| import org.junit.Rule |  | ||||||
| import org.junit.Test |  | ||||||
| import org.junit.runner.RunWith |  | ||||||
| import java.util.* |  | ||||||
|  |  | ||||||
| @RunWith(AndroidJUnit4::class) |  | ||||||
| class IntroActivityEspressoTest { |  | ||||||
|  |  | ||||||
|     @Rule @JvmField |  | ||||||
|     val rule = ActivityTestRule(IntroActivity::class.java, true, false) |  | ||||||
|  |  | ||||||
|     @Before |  | ||||||
|     fun clearData() { |  | ||||||
|         val editor = |  | ||||||
|                 getInstrumentation().targetContext |  | ||||||
|                         .getSharedPreferences(Config.settingsName, Context.MODE_PRIVATE) |  | ||||||
|                         .edit() |  | ||||||
|         editor.clear() |  | ||||||
|         editor.commit() |  | ||||||
|  |  | ||||||
|         Intents.init() |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Test |  | ||||||
|     fun nextEachTimes() { |  | ||||||
|  |  | ||||||
|         rule.launchActivity(Intent()) |  | ||||||
|  |  | ||||||
|         onView(withText(R.string.intro_hello_title)).check(matches(isDisplayed())) |  | ||||||
|         onView(withId(R.id.button_next)).perform(click()) |  | ||||||
|         onView(withText(R.string.intro_needs_selfoss_message)).check(matches(isDisplayed())) |  | ||||||
|         onView(withId(R.id.button_next)).perform(click()) |  | ||||||
|         onView(withText(R.string.intro_all_set_message)).check(matches(isDisplayed())) |  | ||||||
|         onView(withId(R.id.button_next)).perform(click()) |  | ||||||
|  |  | ||||||
|         intended(hasComponent(IntroActivity::class.java.name), times(1)) |  | ||||||
|         intended(hasComponent(LoginActivity::class.java.name), times(1)) |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Test |  | ||||||
|     fun nextBackRandomTimes() { |  | ||||||
|         val max = 5 |  | ||||||
|         val min = 1 |  | ||||||
|  |  | ||||||
|         val random = (Random().nextInt(max + 1 - min)) + min |  | ||||||
|  |  | ||||||
|         rule.launchActivity(Intent()) |  | ||||||
|  |  | ||||||
|         onView(withText(R.string.intro_hello_title)).check(matches(isDisplayed())) |  | ||||||
|         onView(withId(R.id.button_next)).perform(click()) |  | ||||||
|  |  | ||||||
|         repeat(random) { _ -> |  | ||||||
|             onView(withText(R.string.intro_needs_selfoss_message)).check(matches(isDisplayed())) |  | ||||||
|             onView(withId(R.id.button_next)).perform(click()) |  | ||||||
|             onView(withText(R.string.intro_all_set_message)).check(matches(isDisplayed())) |  | ||||||
|             onView(withId(R.id.button_back)).perform(click()) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         onView(withId(R.id.button_next)).perform(click()) |  | ||||||
|         onView(withText(R.string.intro_all_set_message)).check(matches(isDisplayed())) |  | ||||||
|         onView(withId(R.id.button_next)).perform(click()) |  | ||||||
|  |  | ||||||
|         intended(hasComponent(IntroActivity::class.java.name), times(1)) |  | ||||||
|         intended(hasComponent(LoginActivity::class.java.name), times(1)) |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @After |  | ||||||
|     fun releaseIntents() { |  | ||||||
|         Intents.release() |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -2,25 +2,25 @@ package apps.amine.bou.readerforselfoss | |||||||
|  |  | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.support.test.InstrumentationRegistry | import androidx.test.InstrumentationRegistry | ||||||
| import android.support.test.espresso.Espresso.onView | import androidx.test.espresso.Espresso.onView | ||||||
| import android.support.test.espresso.Espresso.openActionBarOverflowOrOptionsMenu | import androidx.test.espresso.Espresso.openActionBarOverflowOrOptionsMenu | ||||||
| import android.support.test.espresso.action.ViewActions.click | import androidx.test.espresso.action.ViewActions.click | ||||||
| import android.support.test.espresso.action.ViewActions.closeSoftKeyboard | import androidx.test.espresso.action.ViewActions.closeSoftKeyboard | ||||||
| import android.support.test.espresso.action.ViewActions.pressBack | import androidx.test.espresso.action.ViewActions.pressBack | ||||||
| import android.support.test.espresso.action.ViewActions.typeText | import androidx.test.espresso.action.ViewActions.typeText | ||||||
| import android.support.test.espresso.assertion.ViewAssertions.matches | import androidx.test.espresso.assertion.ViewAssertions.matches | ||||||
| import android.support.test.espresso.intent.Intents | import androidx.test.espresso.intent.Intents | ||||||
| import android.support.test.espresso.intent.Intents.intended | import androidx.test.espresso.intent.Intents.intended | ||||||
| import android.support.test.espresso.intent.Intents.times | import androidx.test.espresso.intent.Intents.times | ||||||
| import android.support.test.espresso.intent.matcher.IntentMatchers.hasComponent | import androidx.test.espresso.intent.matcher.IntentMatchers.hasComponent | ||||||
| import android.support.test.espresso.matcher.ViewMatchers | import androidx.test.espresso.matcher.ViewMatchers | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.isRoot | import androidx.test.espresso.matcher.ViewMatchers.isRoot | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.withEffectiveVisibility | import androidx.test.espresso.matcher.ViewMatchers.withEffectiveVisibility | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.withId | import androidx.test.espresso.matcher.ViewMatchers.withId | ||||||
| import android.support.test.espresso.matcher.ViewMatchers.withText | import androidx.test.espresso.matcher.ViewMatchers.withText | ||||||
| import android.support.test.rule.ActivityTestRule | import androidx.test.rule.ActivityTestRule | ||||||
| import android.support.test.runner.AndroidJUnit4 | import androidx.test.runner.AndroidJUnit4 | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
| import com.mikepenz.aboutlibraries.ui.LibsActivity | import com.mikepenz.aboutlibraries.ui.LibsActivity | ||||||
| import org.junit.After | import org.junit.After | ||||||
|   | |||||||
| @@ -3,13 +3,13 @@ package apps.amine.bou.readerforselfoss | |||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.content.SharedPreferences | import android.content.SharedPreferences | ||||||
| import android.preference.PreferenceManager | import android.preference.PreferenceManager | ||||||
| import android.support.test.InstrumentationRegistry.getInstrumentation | import androidx.test.InstrumentationRegistry.getInstrumentation | ||||||
| import android.support.test.espresso.intent.Intents | import androidx.test.espresso.intent.Intents | ||||||
| import android.support.test.espresso.intent.Intents.intended | import androidx.test.espresso.intent.Intents.intended | ||||||
| import android.support.test.espresso.intent.Intents.times | import androidx.test.espresso.intent.Intents.times | ||||||
| import android.support.test.espresso.intent.matcher.IntentMatchers.hasComponent | import androidx.test.espresso.intent.matcher.IntentMatchers.hasComponent | ||||||
| import android.support.test.rule.ActivityTestRule | import androidx.test.rule.ActivityTestRule | ||||||
| import android.support.test.runner.AndroidJUnit4 | import androidx.test.runner.AndroidJUnit4 | ||||||
| import org.junit.After | import org.junit.After | ||||||
|  |  | ||||||
| import org.junit.Before | import org.junit.Before | ||||||
| @@ -45,7 +45,6 @@ class MainActivityEspressoTest { | |||||||
|         rule.launchActivity(intent) |         rule.launchActivity(intent) | ||||||
|  |  | ||||||
|         intended(hasComponent(MainActivity::class.java.name)) |         intended(hasComponent(MainActivity::class.java.name)) | ||||||
|         intended(hasComponent(IntroActivity::class.java.name)) |  | ||||||
|         intended(hasComponent(LoginActivity::class.java.name), times(0)) |         intended(hasComponent(LoginActivity::class.java.name), times(0)) | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -58,7 +57,6 @@ class MainActivityEspressoTest { | |||||||
|  |  | ||||||
|         intended(hasComponent(MainActivity::class.java.name)) |         intended(hasComponent(MainActivity::class.java.name)) | ||||||
|         intended(hasComponent(LoginActivity::class.java.name)) |         intended(hasComponent(LoginActivity::class.java.name)) | ||||||
|         intended(hasComponent(IntroActivity::class.java.name), times(0)) |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @After |     @After | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| package apps.amine.bou.readerforselfoss | package apps.amine.bou.readerforselfoss | ||||||
|  |  | ||||||
| import android.support.design.widget.TextInputLayout | import com.google.android.material.textfield.TextInputLayout | ||||||
| import android.support.test.espresso.matcher.ViewMatchers | import androidx.test.espresso.matcher.ViewMatchers | ||||||
| import android.view.View | import android.view.View | ||||||
| import org.hamcrest.Description | import org.hamcrest.Description | ||||||
| import org.hamcrest.Matcher | import org.hamcrest.Matcher | ||||||
|   | |||||||
| @@ -5,15 +5,6 @@ | |||||||
|  |  | ||||||
|     <uses-permission android:name="android.permission.INTERNET" /> |     <uses-permission android:name="android.permission.INTERNET" /> | ||||||
|  |  | ||||||
|      <!-- Remove unwanted permissions from Crashlytics.. see https://www.reddit.com/r/androiddev/comments/86c02l/google_play_services_1200_released/dw4ehln/?context=0 --> |  | ||||||
|     <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" tools:node="remove" /> |  | ||||||
|     <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" tools:node="remove" /> |  | ||||||
|     <uses-permission android:name="android.permission.READ_PHONE_STATE" tools:node="remove" /> |  | ||||||
|  |  | ||||||
|     <!-- For firebase only --> |  | ||||||
|     <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> |  | ||||||
|     <uses-permission android:name="android.permission.WAKE_LOCK" /> |  | ||||||
|  |  | ||||||
|     <application |     <application | ||||||
|         android:name=".MyApp" |         android:name=".MyApp" | ||||||
|         android:allowBackup="true" |         android:allowBackup="true" | ||||||
| @@ -30,10 +21,6 @@ | |||||||
|                 <category android:name="android.intent.category.LAUNCHER" /> |                 <category android:name="android.intent.category.LAUNCHER" /> | ||||||
|             </intent-filter> |             </intent-filter> | ||||||
|         </activity> |         </activity> | ||||||
|         <activity |  | ||||||
|             android:name=".IntroActivity" |  | ||||||
|             android:theme="@style/Theme.Intro"> |  | ||||||
|         </activity> |  | ||||||
|         <activity |         <activity | ||||||
|             android:name=".LoginActivity" |             android:name=".LoginActivity" | ||||||
|             android:label="@string/title_activity_login"> |             android:label="@string/title_activity_login"> | ||||||
|   | |||||||
| @@ -4,8 +4,8 @@ import android.content.Intent | |||||||
| import android.os.Build | import android.os.Build | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import android.preference.PreferenceManager | ||||||
| import android.support.constraint.ConstraintLayout | import androidx.constraintlayout.widget.ConstraintLayout | ||||||
| import android.support.v7.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
| import android.view.View | import android.view.View | ||||||
| import android.widget.AdapterView | import android.widget.AdapterView | ||||||
| import android.widget.ArrayAdapter | import android.widget.ArrayAdapter | ||||||
| @@ -44,10 +44,11 @@ class AddSourceActivity : AppCompatActivity() { | |||||||
|  |  | ||||||
|         setContentView(R.layout.activity_add_source) |         setContentView(R.layout.activity_add_source) | ||||||
|  |  | ||||||
|         // TODO: input bubble cursor |         val scoop = Scoop.getInstance() | ||||||
|         Scoop.getInstance() |         scoop.bind(this, Toppings.PRIMARY.value, toolbar) | ||||||
|             .bind(this, Toppings.PRIMARY.value, toolbar) |         if  (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { | ||||||
|             .bindStatusBar(this, Toppings.PRIMARY_DARK.value) |             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) | ||||||
|  |         } | ||||||
|  |  | ||||||
|         val drawable = nameInput.background |         val drawable = nameInput.background | ||||||
|         drawable.setColorFilter(appColors.colorAccent, PorterDuff.Mode.SRC_ATOP) |         drawable.setColorFilter(appColors.colorAccent, PorterDuff.Mode.SRC_ATOP) | ||||||
|   | |||||||
| @@ -1,69 +1,63 @@ | |||||||
| package apps.amine.bou.readerforselfoss | package apps.amine.bou.readerforselfoss | ||||||
|  |  | ||||||
| import android.app.Activity |  | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.content.SharedPreferences | import android.content.SharedPreferences | ||||||
| import android.graphics.Color | import android.graphics.Color | ||||||
| import android.graphics.drawable.GradientDrawable | import android.graphics.drawable.GradientDrawable | ||||||
| import android.net.Uri | import android.net.Uri | ||||||
|  | import android.os.Build | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import android.preference.PreferenceManager | ||||||
| import android.support.v4.view.MenuItemCompat | import androidx.core.view.MenuItemCompat | ||||||
| import android.support.v7.app.AlertDialog | import androidx.appcompat.app.AlertDialog | ||||||
| import android.support.v7.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
| import android.support.v7.widget.DividerItemDecoration | import androidx.recyclerview.widget.DividerItemDecoration | ||||||
| import android.support.v7.widget.GridLayoutManager | import androidx.recyclerview.widget.GridLayoutManager | ||||||
| import android.support.v7.widget.RecyclerView | import androidx.recyclerview.widget.RecyclerView | ||||||
| import android.support.v7.widget.SearchView | import androidx.appcompat.widget.SearchView | ||||||
| import android.support.v7.widget.StaggeredGridLayoutManager | import androidx.recyclerview.widget.StaggeredGridLayoutManager | ||||||
| import android.support.v7.widget.helper.ItemTouchHelper | import androidx.recyclerview.widget.ItemTouchHelper | ||||||
|  | import android.util.Log | ||||||
| import android.view.Menu | import android.view.Menu | ||||||
| import android.view.MenuItem | import android.view.MenuItem | ||||||
| import android.view.View | import android.view.View | ||||||
| import android.widget.Toast | import android.widget.Toast | ||||||
|  | import androidx.room.Room | ||||||
|  | import androidx.room.RoomDatabase | ||||||
| import apps.amine.bou.readerforselfoss.adapters.ItemCardAdapter | import apps.amine.bou.readerforselfoss.adapters.ItemCardAdapter | ||||||
| import apps.amine.bou.readerforselfoss.adapters.ItemListAdapter | import apps.amine.bou.readerforselfoss.adapters.ItemListAdapter | ||||||
| import apps.amine.bou.readerforselfoss.adapters.ItemsAdapter | import apps.amine.bou.readerforselfoss.adapters.ItemsAdapter | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Item | import apps.amine.bou.readerforselfoss.api.selfoss.Item | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Sources | import apps.amine.bou.readerforselfoss.api.selfoss.Source | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Stats | import apps.amine.bou.readerforselfoss.api.selfoss.Stats | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Tag | import apps.amine.bou.readerforselfoss.api.selfoss.Tag | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.database.AppDatabase | ||||||
| import apps.amine.bou.readerforselfoss.settings.SettingsActivity | import apps.amine.bou.readerforselfoss.settings.SettingsActivity | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors | import apps.amine.bou.readerforselfoss.themes.AppColors | ||||||
| import apps.amine.bou.readerforselfoss.themes.Toppings | import apps.amine.bou.readerforselfoss.themes.Toppings | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
| import apps.amine.bou.readerforselfoss.utils.bottombar.maybeShow | import apps.amine.bou.readerforselfoss.utils.bottombar.maybeShow | ||||||
| import apps.amine.bou.readerforselfoss.utils.bottombar.removeBadge | import apps.amine.bou.readerforselfoss.utils.bottombar.removeBadge | ||||||
| import apps.amine.bou.readerforselfoss.utils.checkApkVersion |  | ||||||
| import apps.amine.bou.readerforselfoss.utils.customtabs.CustomTabActivityHelper | import apps.amine.bou.readerforselfoss.utils.customtabs.CustomTabActivityHelper | ||||||
| import apps.amine.bou.readerforselfoss.utils.drawer.CustomUrlPrimaryDrawerItem | import apps.amine.bou.readerforselfoss.utils.drawer.CustomUrlPrimaryDrawerItem | ||||||
| import apps.amine.bou.readerforselfoss.utils.flattenTags | import apps.amine.bou.readerforselfoss.utils.flattenTags | ||||||
| import apps.amine.bou.readerforselfoss.utils.longHash | import apps.amine.bou.readerforselfoss.utils.longHash | ||||||
|  | import apps.amine.bou.readerforselfoss.utils.persistence.toEntity | ||||||
|  | import apps.amine.bou.readerforselfoss.utils.persistence.toView | ||||||
| import co.zsmb.materialdrawerkt.builders.accountHeader | import co.zsmb.materialdrawerkt.builders.accountHeader | ||||||
| import co.zsmb.materialdrawerkt.builders.drawer | import co.zsmb.materialdrawerkt.builders.drawer | ||||||
| import co.zsmb.materialdrawerkt.builders.footer | import co.zsmb.materialdrawerkt.builders.footer | ||||||
| import co.zsmb.materialdrawerkt.draweritems.badgeable.primaryItem | import co.zsmb.materialdrawerkt.draweritems.badgeable.primaryItem | ||||||
| import co.zsmb.materialdrawerkt.draweritems.profile.profile | import co.zsmb.materialdrawerkt.draweritems.profile.profile | ||||||
| import com.anupcowkur.reservoir.Reservoir |  | ||||||
| import com.anupcowkur.reservoir.ReservoirGetCallback |  | ||||||
| import com.anupcowkur.reservoir.ReservoirPutCallback |  | ||||||
| import com.ashokvarma.bottomnavigation.BottomNavigationBar | import com.ashokvarma.bottomnavigation.BottomNavigationBar | ||||||
| import com.ashokvarma.bottomnavigation.BottomNavigationItem | import com.ashokvarma.bottomnavigation.BottomNavigationItem | ||||||
| import com.ashokvarma.bottomnavigation.TextBadgeItem | import com.ashokvarma.bottomnavigation.TextBadgeItem | ||||||
| import com.crashlytics.android.Crashlytics |  | ||||||
| import com.crashlytics.android.answers.Answers |  | ||||||
| import com.crashlytics.android.answers.InviteEvent |  | ||||||
| import com.ftinc.scoop.Scoop | import com.ftinc.scoop.Scoop | ||||||
| import com.github.stkent.amplify.tracking.Amplify | import com.github.stkent.amplify.tracking.Amplify | ||||||
| import com.google.android.gms.appinvite.AppInviteInvitation |  | ||||||
| import com.google.android.gms.common.ConnectionResult |  | ||||||
| import com.google.android.gms.common.GoogleApiAvailability |  | ||||||
| import com.google.firebase.remoteconfig.FirebaseRemoteConfig |  | ||||||
| import com.google.gson.reflect.TypeToken | import com.google.gson.reflect.TypeToken | ||||||
| import com.heinrichreimersoftware.androidissuereporter.IssueReporterLauncher |  | ||||||
| import com.mikepenz.aboutlibraries.Libs | import com.mikepenz.aboutlibraries.Libs | ||||||
| import com.mikepenz.aboutlibraries.LibsBuilder | import com.mikepenz.aboutlibraries.LibsBuilder | ||||||
| import com.mikepenz.materialdrawer.Drawer | import com.mikepenz.materialdrawer.Drawer | ||||||
| @@ -73,16 +67,17 @@ import com.mikepenz.materialdrawer.model.DividerDrawerItem | |||||||
| import com.mikepenz.materialdrawer.model.PrimaryDrawerItem | import com.mikepenz.materialdrawer.model.PrimaryDrawerItem | ||||||
| import com.mikepenz.materialdrawer.model.SecondaryDrawerItem | import com.mikepenz.materialdrawer.model.SecondaryDrawerItem | ||||||
| import kotlinx.android.synthetic.main.activity_home.* | import kotlinx.android.synthetic.main.activity_home.* | ||||||
|  | import kotlinx.android.synthetic.main.fragment_article.* | ||||||
| import retrofit2.Call | import retrofit2.Call | ||||||
| import retrofit2.Callback | import retrofit2.Callback | ||||||
| import retrofit2.Response | import retrofit2.Response | ||||||
|  | import kotlin.concurrent.thread | ||||||
|  |  | ||||||
| class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | ||||||
|  |  | ||||||
|     private val MENU_PREFERENCES = 12302 |     private val MENU_PREFERENCES = 12302 | ||||||
|     private val REQUEST_INVITE = 13231 |  | ||||||
|     private val REQUEST_INVITE_BYMAIL = 13232 |  | ||||||
|     private val DRAWER_ID_TAGS = 100101L |     private val DRAWER_ID_TAGS = 100101L | ||||||
|  |     private val DRAWER_ID_HIDDEN_TAGS = 101100L | ||||||
|     private val DRAWER_ID_SOURCES = 100110L |     private val DRAWER_ID_SOURCES = 100110L | ||||||
|     private val DRAWER_ID_FILTERS = 100111L |     private val DRAWER_ID_FILTERS = 100111L | ||||||
|     private val UNREAD_SHOWN = 1 |     private val UNREAD_SHOWN = 1 | ||||||
| @@ -92,7 +87,6 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     private var items: ArrayList<Item> = ArrayList() |     private var items: ArrayList<Item> = ArrayList() | ||||||
|     private var allItems: ArrayList<Item> = ArrayList() |     private var allItems: ArrayList<Item> = ArrayList() | ||||||
|  |  | ||||||
|     private var clickBehavior = false |  | ||||||
|     private var debugReadingItems = false |     private var debugReadingItems = false | ||||||
|     private var shouldLogEverything = false |     private var shouldLogEverything = false | ||||||
|     private var internalBrowser = false |     private var internalBrowser = false | ||||||
| @@ -104,13 +98,13 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     private var itemsNumber: Int = 200 |     private var itemsNumber: Int = 200 | ||||||
|     private var elementsShown: Int = 0 |     private var elementsShown: Int = 0 | ||||||
|     private var maybeTagFilter: Tag? = null |     private var maybeTagFilter: Tag? = null | ||||||
|     private var maybeSourceFilter: Sources? = null |     private var maybeSourceFilter: Source? = null | ||||||
|     private var maybeSearchFilter: String? = null |     private var maybeSearchFilter: String? = null | ||||||
|     private var userIdentifier: String = "" |     private var userIdentifier: String = "" | ||||||
|     private var displayAccountHeader: Boolean = false |     private var displayAccountHeader: Boolean = false | ||||||
|     private var infiniteScroll: Boolean = false |     private var infiniteScroll: Boolean = false | ||||||
|     private var lastFetchDone: Boolean = false |     private var lastFetchDone: Boolean = false | ||||||
|  |     private var hiddenTags: List<String> = emptyList() | ||||||
|  |  | ||||||
|     private lateinit var tabNewBadge: TextBadgeItem |     private lateinit var tabNewBadge: TextBadgeItem | ||||||
|     private lateinit var tabArchiveBadge: TextBadgeItem |     private lateinit var tabArchiveBadge: TextBadgeItem | ||||||
| @@ -120,11 +114,10 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     private lateinit var customTabActivityHelper: CustomTabActivityHelper |     private lateinit var customTabActivityHelper: CustomTabActivityHelper | ||||||
|     private lateinit var editor: SharedPreferences.Editor |     private lateinit var editor: SharedPreferences.Editor | ||||||
|     private lateinit var sharedPref: SharedPreferences |     private lateinit var sharedPref: SharedPreferences | ||||||
|     private lateinit var firebaseRemoteConfig: FirebaseRemoteConfig |  | ||||||
|     private lateinit var appColors: AppColors |     private lateinit var appColors: AppColors | ||||||
|     private var offset: Int = 0 |     private var offset: Int = 0 | ||||||
|     private var firstVisible: Int = 0 |     private var firstVisible: Int = 0 | ||||||
|     private var recyclerViewScrollListener: RecyclerView.OnScrollListener? = null |     private lateinit var recyclerViewScrollListener: RecyclerView.OnScrollListener | ||||||
|     private lateinit var settings: SharedPreferences |     private lateinit var settings: SharedPreferences | ||||||
|  |  | ||||||
|     private var recyclerAdapter: RecyclerView.Adapter<*>? = null |     private var recyclerAdapter: RecyclerView.Adapter<*>? = null | ||||||
| @@ -133,10 +126,11 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     private var badgeAll: Int = -1 |     private var badgeAll: Int = -1 | ||||||
|     private var badgeFavs: Int = -1 |     private var badgeFavs: Int = -1 | ||||||
|  |  | ||||||
|  |  | ||||||
|     private lateinit var tagsBadge: Map<Long, Int> |     private lateinit var tagsBadge: Map<Long, Int> | ||||||
|  |  | ||||||
|     data class DrawerData(val tags: List<Tag>?, val sources: List<Sources>?) |     private lateinit var db: AppDatabase | ||||||
|  |  | ||||||
|  |     data class DrawerData(val tags: List<Tag>?, val sources: List<Source>?) | ||||||
|  |  | ||||||
|     override fun onStart() { |     override fun onStart() { | ||||||
|         super.onStart() |         super.onStart() | ||||||
| @@ -157,8 +151,11 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|             Amplify.getSharedInstance().promptIfReady(promptView) |             Amplify.getSharedInstance().promptIfReady(promptView) | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         firebaseRemoteConfig = FirebaseRemoteConfig.getInstance() |         db = Room.databaseBuilder( | ||||||
|         firebaseRemoteConfig.setDefaults(R.xml.default_remote_config) |             applicationContext, | ||||||
|  |             AppDatabase::class.java!!, "selfoss-database" | ||||||
|  |         ).build() | ||||||
|  |  | ||||||
|  |  | ||||||
|         customTabActivityHelper = CustomTabActivityHelper() |         customTabActivityHelper = CustomTabActivityHelper() | ||||||
|  |  | ||||||
| @@ -180,6 +177,24 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|         handleSwipeRefreshLayout() |         handleSwipeRefreshLayout() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private fun handleGDPRDialog(GDPRShown: Boolean) { | ||||||
|  |         val sharedEditor = sharedPref.edit() | ||||||
|  |         if (!GDPRShown) { | ||||||
|  |             val alertDialog = AlertDialog.Builder(this).create() | ||||||
|  |             alertDialog.setTitle(getString(R.string.gdpr_dialog_title)) | ||||||
|  |             alertDialog.setMessage(getString(R.string.gdpr_dialog_message)) | ||||||
|  |             alertDialog.setButton( | ||||||
|  |                 AlertDialog.BUTTON_NEUTRAL, | ||||||
|  |                 "OK" | ||||||
|  |             ) { dialog, _ -> | ||||||
|  |                 sharedEditor.putBoolean("GDPR_shown", true) | ||||||
|  |                 sharedEditor.commit() | ||||||
|  |                 dialog.dismiss() | ||||||
|  |             } | ||||||
|  |             alertDialog.show() | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private fun handleSwipeRefreshLayout() { |     private fun handleSwipeRefreshLayout() { | ||||||
|         swipeRefreshLayout.setColorSchemeResources( |         swipeRefreshLayout.setColorSchemeResources( | ||||||
|             R.color.refresh_progress_1, |             R.color.refresh_progress_1, | ||||||
| @@ -187,6 +202,8 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|             R.color.refresh_progress_3 |             R.color.refresh_progress_3 | ||||||
|         ) |         ) | ||||||
|         swipeRefreshLayout.setOnRefreshListener { |         swipeRefreshLayout.setOnRefreshListener { | ||||||
|  |             allItems = ArrayList() | ||||||
|  |             lastFetchDone = false | ||||||
|             handleDrawerItems() |             handleDrawerItems() | ||||||
|             getElementsAccordingToTab() |             getElementsAccordingToTab() | ||||||
|         } |         } | ||||||
| @@ -197,8 +214,8 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                 ItemTouchHelper.LEFT or ItemTouchHelper.RIGHT |                 ItemTouchHelper.LEFT or ItemTouchHelper.RIGHT | ||||||
|             ) { |             ) { | ||||||
|                 override fun getSwipeDirs( |                 override fun getSwipeDirs( | ||||||
|                     recyclerView: RecyclerView?, |                     recyclerView: RecyclerView, | ||||||
|                     viewHolder: RecyclerView.ViewHolder? |                     viewHolder: RecyclerView.ViewHolder | ||||||
|                 ): Int = |                 ): Int = | ||||||
|                     if (elementsShown != UNREAD_SHOWN) { |                     if (elementsShown != UNREAD_SHOWN) { | ||||||
|                         0 |                         0 | ||||||
| @@ -227,44 +244,29 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                             is ItemListAdapter -> adapter.removeItemAtIndex(position) |                             is ItemListAdapter -> adapter.removeItemAtIndex(position) | ||||||
|                         } |                         } | ||||||
|  |  | ||||||
|                         if (items.size > 0) { |                         badgeNew-- | ||||||
|                             badgeNew-- |                         reloadBadgeContent() | ||||||
|                             reloadBadgeContent() |  | ||||||
|  |  | ||||||
|                             val tagHashes = i.tags.split(",").map { it.longHash() } |                         val tagHashes = i.tags.split(",").map { it.longHash() } | ||||||
|                             tagsBadge = tagsBadge.map { |                         tagsBadge = tagsBadge.map { | ||||||
|                                 if (tagHashes.contains(it.key)) { |                             if (tagHashes.contains(it.key)) { | ||||||
|                                     (it.key to (it.value - 1)) |                                 (it.key to (it.value - 1)) | ||||||
|                                 } else { |                             } else { | ||||||
|                                     (it.key to it.value) |                                 (it.key to it.value) | ||||||
|                                 } |  | ||||||
|                             }.toMap() |  | ||||||
|                             reloadTagsBadges() |  | ||||||
|                         } else { |  | ||||||
|                             tabNewBadge.hide() |  | ||||||
|                         } |  | ||||||
|  |  | ||||||
|                         val manager = recyclerView.layoutManager |  | ||||||
|                         val lastVisibleItem: Int = when (manager) { |  | ||||||
|                             is StaggeredGridLayoutManager -> manager.findLastCompletelyVisibleItemPositions( |  | ||||||
|                                 null |  | ||||||
|                             ).last() |  | ||||||
|                             is GridLayoutManager -> manager.findLastCompletelyVisibleItemPosition() |  | ||||||
|                             else -> 0 |  | ||||||
|                         } |  | ||||||
|  |  | ||||||
|                         if (lastVisibleItem === items.size && |  | ||||||
|                             items.size <= maxItemNumber() && |  | ||||||
|                             (maxItemNumber() >= itemsNumber || !lastFetchDone) |  | ||||||
|                         ) { |  | ||||||
|                             if (maxItemNumber() < itemsNumber) { |  | ||||||
|                                 lastFetchDone = true |  | ||||||
|                             } |                             } | ||||||
|                             getElementsAccordingToTab( |                         }.toMap() | ||||||
|                                 appendResults = true, |                         reloadTagsBadges() | ||||||
|                                 offsetOverride = lastVisibleItem |  | ||||||
|                             ) |                         // Just load everythin | ||||||
|  |                         if (items.size <= 0) { | ||||||
|  |                             getElementsAccordingToTab() | ||||||
|                         } |                         } | ||||||
|  |                     } else { | ||||||
|  |                         Toast.makeText( | ||||||
|  |                             this@HomeActivity, | ||||||
|  |                             "Found null when swiping at positon $position.", | ||||||
|  |                             Toast.LENGTH_LONG | ||||||
|  |                         ).show() | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -323,18 +325,14 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|         // TODO: Make this the only appcolors init |         // TODO: Make this the only appcolors init | ||||||
|         appColors = AppColors(this@HomeActivity) |         appColors = AppColors(this@HomeActivity) | ||||||
|  |  | ||||||
|         handleDrawerItems() |  | ||||||
|  |  | ||||||
|         sharedPref = PreferenceManager.getDefaultSharedPreferences(this) |         sharedPref = PreferenceManager.getDefaultSharedPreferences(this) | ||||||
|  |  | ||||||
|         editor = settings.edit() |         editor = settings.edit() | ||||||
|  |  | ||||||
|         if (BuildConfig.GITHUB_VERSION) { |  | ||||||
|             this@HomeActivity.checkApkVersion(settings, editor, firebaseRemoteConfig) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         handleSharedPrefs() |         handleSharedPrefs() | ||||||
|  |  | ||||||
|  |         handleDrawerItems() | ||||||
|  |  | ||||||
|         handleThemeUpdate() |         handleThemeUpdate() | ||||||
|  |  | ||||||
|         reloadLayoutManager() |         reloadLayoutManager() | ||||||
| @@ -348,6 +346,8 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|         handleBottomBarActions() |         handleBottomBarActions() | ||||||
|  |  | ||||||
|         getElementsAccordingToTab() |         getElementsAccordingToTab() | ||||||
|  |  | ||||||
|  |         handleGDPRDialog(sharedPref.getBoolean("GDPR_shown", false)) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     override fun onStop() { |     override fun onStop() { | ||||||
| @@ -358,7 +358,6 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     private fun handleSharedPrefs() { |     private fun handleSharedPrefs() { | ||||||
|         debugReadingItems = sharedPref.getBoolean("read_debug", false) |         debugReadingItems = sharedPref.getBoolean("read_debug", false) | ||||||
|         shouldLogEverything = sharedPref.getBoolean("should_log_everything", false) |         shouldLogEverything = sharedPref.getBoolean("should_log_everything", false) | ||||||
|         clickBehavior = sharedPref.getBoolean("tab_on_tap", false) |  | ||||||
|         internalBrowser = sharedPref.getBoolean("prefer_internal_browser", true) |         internalBrowser = sharedPref.getBoolean("prefer_internal_browser", true) | ||||||
|         articleViewer = sharedPref.getBoolean("prefer_article_viewer", true) |         articleViewer = sharedPref.getBoolean("prefer_article_viewer", true) | ||||||
|         shouldBeCardView = sharedPref.getBoolean("card_view_active", false) |         shouldBeCardView = sharedPref.getBoolean("card_view_active", false) | ||||||
| @@ -369,19 +368,29 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|         userIdentifier = sharedPref.getString("unique_id", "") |         userIdentifier = sharedPref.getString("unique_id", "") | ||||||
|         displayAccountHeader = sharedPref.getBoolean("account_header_displaying", false) |         displayAccountHeader = sharedPref.getBoolean("account_header_displaying", false) | ||||||
|         infiniteScroll = sharedPref.getBoolean("infinite_loading", false) |         infiniteScroll = sharedPref.getBoolean("infinite_loading", false) | ||||||
|  |         hiddenTags = if (sharedPref.getString("hidden_tags", "").isNotEmpty()) { | ||||||
|  |             sharedPref.getString("hidden_tags", "").replace("\\s".toRegex(), "").split(",") | ||||||
|  |         } else { | ||||||
|  |             emptyList() | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun handleThemeBinding() { |     private fun handleThemeBinding() { | ||||||
|         Scoop.getInstance() |         val scoop = Scoop.getInstance() | ||||||
|             .bind(this, Toppings.PRIMARY.value, toolBar) |         scoop.bind(this, Toppings.PRIMARY.value, toolBar) | ||||||
|             .bindStatusBar(this, Toppings.PRIMARY_DARK.value) |         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { | ||||||
|  |             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun handleThemeUpdate() { |     private fun handleThemeUpdate() { | ||||||
|  |  | ||||||
|         Scoop.getInstance() |         val scoop = Scoop.getInstance() | ||||||
|             .update(Toppings.PRIMARY.value, appColors.colorPrimary) |         scoop.update(Toppings.PRIMARY.value, appColors.colorPrimary) | ||||||
|             .update(Toppings.PRIMARY_DARK.value, appColors.colorPrimaryDark) |  | ||||||
|  |         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { | ||||||
|  |             scoop.update(Toppings.PRIMARY_DARK.value, appColors.colorPrimaryDark) | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun handleDrawer() { |     private fun handleDrawer() { | ||||||
| @@ -420,18 +429,8 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                     icon = R.drawable.ic_bug_report |                     icon = R.drawable.ic_bug_report | ||||||
|                     iconTintingEnabled = true |                     iconTintingEnabled = true | ||||||
|                     onClick { _ -> |                     onClick { _ -> | ||||||
|                         IssueReporterLauncher.forTarget( |                         val browserIntent = Intent(Intent.ACTION_VIEW, Uri.parse(Config.trackerUrl)) | ||||||
|                             getString(R.string.report_github_user), |                         startActivity(browserIntent) | ||||||
|                             getString(R.string.report_github_repo) |  | ||||||
|                         ) |  | ||||||
|                             .theme(R.style.Theme_App_Light) |  | ||||||
|                             .guestToken(BuildConfig.GITHUB_TOKEN) |  | ||||||
|                             .guestEmailRequired(true) |  | ||||||
|                             .minDescriptionLength(20) |  | ||||||
|                             .putExtraInfo("Unique ID", settings.getString("unique_id", "")) |  | ||||||
|                             .putExtraInfo("From github", BuildConfig.GITHUB_VERSION) |  | ||||||
|                             .homeAsUpEnabled(true) |  | ||||||
|                             .launch(this@HomeActivity) |  | ||||||
|                         false |                         false | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -467,7 +466,8 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                         ) |                         ) | ||||||
|                     } |                     } | ||||||
|                 } else { |                 } else { | ||||||
|                     tagsBadge = maybeTags.map { |                     val filteredTags = maybeTags.filterNot { hiddenTags.contains(it.tag) } | ||||||
|  |                     tagsBadge = filteredTags.map { | ||||||
|                         val gd = GradientDrawable() |                         val gd = GradientDrawable() | ||||||
|                         val color = try { |                         val color = try { | ||||||
|                             Color.parseColor(it.color) |                             Color.parseColor(it.color) | ||||||
| @@ -502,7 +502,54 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             fun handleSources(maybeSources: List<Sources>?) { |             fun handleHiddenTags(maybeTags: List<Tag>?) { | ||||||
|  |                 if (maybeTags == null) { | ||||||
|  |                     if (loadedFromCache) { | ||||||
|  |                         drawer.addItem( | ||||||
|  |                             SecondaryDrawerItem() | ||||||
|  |                                 .withName(getString(R.string.drawer_error_loading_tags)) | ||||||
|  |                                 .withSelectable(false) | ||||||
|  |                         ) | ||||||
|  |                     } | ||||||
|  |                 } else { | ||||||
|  |                     val filteredHiddenTags: List<Tag> = | ||||||
|  |                         maybeTags.filter { hiddenTags.contains(it.tag) } | ||||||
|  |                     tagsBadge = filteredHiddenTags.map { | ||||||
|  |                         val gd = GradientDrawable() | ||||||
|  |                         val color = try { | ||||||
|  |                             Color.parseColor(it.color) | ||||||
|  |                         } catch (e: IllegalArgumentException) { | ||||||
|  |                             appColors.colorPrimary | ||||||
|  |                         } | ||||||
|  |  | ||||||
|  |                         gd.setColor(color) | ||||||
|  |                         gd.shape = GradientDrawable.RECTANGLE | ||||||
|  |                         gd.setSize(30, 30) | ||||||
|  |                         gd.cornerRadius = 30F | ||||||
|  |                         drawer.addItem( | ||||||
|  |                             PrimaryDrawerItem() | ||||||
|  |                                 .withName(it.tag) | ||||||
|  |                                 .withIdentifier(it.tag.longHash()) | ||||||
|  |                                 .withIcon(gd) | ||||||
|  |                                 .withBadge("${it.unread}") | ||||||
|  |                                 .withBadgeStyle( | ||||||
|  |                                     BadgeStyle().withTextColor(Color.WHITE) | ||||||
|  |                                         .withColor(appColors.colorAccent) | ||||||
|  |                                 ) | ||||||
|  |                                 .withOnDrawerItemClickListener { _, _, _ -> | ||||||
|  |                                     allItems = ArrayList() | ||||||
|  |                                     maybeTagFilter = it | ||||||
|  |                                     getElementsAccordingToTab() | ||||||
|  |                                     false | ||||||
|  |                                 } | ||||||
|  |                         ) | ||||||
|  |  | ||||||
|  |                         (it.tag.longHash() to it.unread) | ||||||
|  |                     }.toMap() | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             fun handleSources(maybeSources: List<Source>?) { | ||||||
|                 if (maybeSources == null) { |                 if (maybeSources == null) { | ||||||
|                     if (loadedFromCache) { |                     if (loadedFromCache) { | ||||||
|                         drawer.addItem( |                         drawer.addItem( | ||||||
| @@ -553,6 +600,16 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                         .withSelectable(false) |                         .withSelectable(false) | ||||||
|                 ) |                 ) | ||||||
|                 handleTags(maybeDrawerData.tags) |                 handleTags(maybeDrawerData.tags) | ||||||
|  |                 if (hiddenTags.isNotEmpty()) { | ||||||
|  |                     drawer.addItem(DividerDrawerItem()) | ||||||
|  |                     drawer.addItem( | ||||||
|  |                         SecondaryDrawerItem() | ||||||
|  |                             .withName(getString(R.string.drawer_item_hidden_tags)) | ||||||
|  |                             .withIdentifier(DRAWER_ID_HIDDEN_TAGS) | ||||||
|  |                             .withSelectable(false) | ||||||
|  |                     ) | ||||||
|  |                     handleHiddenTags(maybeDrawerData.tags) | ||||||
|  |                 } | ||||||
|                 drawer.addItem(DividerDrawerItem()) |                 drawer.addItem(DividerDrawerItem()) | ||||||
|                 drawer.addItem( |                 drawer.addItem( | ||||||
|                     SecondaryDrawerItem() |                     SecondaryDrawerItem() | ||||||
| @@ -577,9 +634,9 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                             LibsBuilder() |                             LibsBuilder() | ||||||
|                                 .withActivityStyle( |                                 .withActivityStyle( | ||||||
|                                     if (appColors.isDarkTheme) { |                                     if (appColors.isDarkTheme) { | ||||||
|                                         Libs.ActivityStyle.LIGHT_DARK_TOOLBAR |  | ||||||
|                                     } else { |  | ||||||
|                                         Libs.ActivityStyle.DARK |                                         Libs.ActivityStyle.DARK | ||||||
|  |                                     } else { | ||||||
|  |                                         Libs.ActivityStyle.LIGHT_DARK_TOOLBAR | ||||||
|                                     } |                                     } | ||||||
|                                 ) |                                 ) | ||||||
|                                 .withAboutIconShown(true) |                                 .withAboutIconShown(true) | ||||||
| @@ -591,14 +648,19 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|  |  | ||||||
|  |  | ||||||
|                 if (!loadedFromCache) { |                 if (!loadedFromCache) { | ||||||
|                     Reservoir.putAsync( |                     if (maybeDrawerData.tags != null) { | ||||||
|                         "drawerData", maybeDrawerData, object : ReservoirPutCallback { |                         thread { | ||||||
|                             override fun onSuccess() { |                             val tagEntities = maybeDrawerData.tags.map { it.toEntity() } | ||||||
|                             } |                             db.drawerDataDao().insertAllTags(*tagEntities.toTypedArray()) | ||||||
|  |                         } | ||||||
|                             override fun onFailure(p0: Exception?) { |                     } | ||||||
|                             } |                     if (maybeDrawerData.sources != null) { | ||||||
|                         }) |                         thread { | ||||||
|  |                             val sourceEntities = | ||||||
|  |                                 maybeDrawerData.sources.map { it.toEntity() } | ||||||
|  |                             db.drawerDataDao().insertAllSources(*sourceEntities.toTypedArray()) | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|                 } |                 } | ||||||
|             } else { |             } else { | ||||||
|                 if (!loadedFromCache) { |                 if (!loadedFromCache) { | ||||||
| @@ -620,13 +682,13 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|  |  | ||||||
|         fun drawerApiCalls(maybeDrawerData: DrawerData?) { |         fun drawerApiCalls(maybeDrawerData: DrawerData?) { | ||||||
|             var tags: List<Tag>? = null |             var tags: List<Tag>? = null | ||||||
|             var sources: List<Sources>? |             var sources: List<Source>? | ||||||
|  |  | ||||||
|             fun sourcesApiCall() { |             fun sourcesApiCall() { | ||||||
|                 api.sources.enqueue(object : Callback<List<Sources>> { |                 api.sources.enqueue(object : Callback<List<Source>> { | ||||||
|                     override fun onResponse( |                     override fun onResponse( | ||||||
|                         call: Call<List<Sources>>?, |                         call: Call<List<Source>>?, | ||||||
|                         response: Response<List<Sources>> |                         response: Response<List<Source>> | ||||||
|                     ) { |                     ) { | ||||||
|                         sources = response.body() |                         sources = response.body() | ||||||
|                         val apiDrawerData = DrawerData(tags, sources) |                         val apiDrawerData = DrawerData(tags, sources) | ||||||
| @@ -635,7 +697,7 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                     override fun onFailure(call: Call<List<Sources>>?, t: Throwable?) { |                     override fun onFailure(call: Call<List<Source>>?, t: Throwable?) { | ||||||
|                     } |                     } | ||||||
|                 }) |                 }) | ||||||
|             } |             } | ||||||
| @@ -661,18 +723,12 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|             ) |             ) | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|         val resultType = object : TypeToken<DrawerData>() {}.type |         thread { | ||||||
|         Reservoir.getAsync( |             var drawerData = DrawerData(db.drawerDataDao().tags().map { it.toView() }, | ||||||
|             "drawerData", resultType, object : ReservoirGetCallback<DrawerData> { |                                         db.drawerDataDao().sources().map { it.toView() }) | ||||||
|                 override fun onSuccess(maybeDrawerData: DrawerData?) { |             handleDrawerData(drawerData, loadedFromCache = true) | ||||||
|                     handleDrawerData(maybeDrawerData, loadedFromCache = true) |             drawerApiCalls(drawerData) | ||||||
|                     drawerApiCalls(maybeDrawerData) |         } | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 override fun onFailure(p0: Exception?) { |  | ||||||
|                     drawerApiCalls(null) |  | ||||||
|                 } |  | ||||||
|             }) |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun reloadLayoutManager() { |     private fun reloadLayoutManager() { | ||||||
| @@ -683,7 +739,10 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|         when (currentManager) { |         when (currentManager) { | ||||||
|             is StaggeredGridLayoutManager -> |             is StaggeredGridLayoutManager -> | ||||||
|                 if (!shouldBeCardView) { |                 if (!shouldBeCardView) { | ||||||
|                     layoutManager = GridLayoutManager(this, calculateNoOfColumns()) |                     layoutManager = GridLayoutManager( | ||||||
|  |                         this, | ||||||
|  |                         calculateNoOfColumns() | ||||||
|  |                     ) | ||||||
|                     recyclerView.layoutManager = layoutManager |                     recyclerView.layoutManager = layoutManager | ||||||
|                 } |                 } | ||||||
|             is GridLayoutManager -> |             is GridLayoutManager -> | ||||||
| @@ -699,7 +758,10 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|             else -> |             else -> | ||||||
|                 if (currentManager == null) { |                 if (currentManager == null) { | ||||||
|                     if (!shouldBeCardView) { |                     if (!shouldBeCardView) { | ||||||
|                         layoutManager = GridLayoutManager(this, calculateNoOfColumns()) |                         layoutManager = GridLayoutManager( | ||||||
|  |                             this, | ||||||
|  |                             calculateNoOfColumns() | ||||||
|  |                         ) | ||||||
|                         recyclerView.layoutManager = layoutManager |                         recyclerView.layoutManager = layoutManager | ||||||
|                     } else { |                     } else { | ||||||
|                         layoutManager = StaggeredGridLayoutManager( |                         layoutManager = StaggeredGridLayoutManager( | ||||||
| @@ -753,22 +815,20 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun handleInfiniteScroll() { |     private fun handleInfiniteScroll() { | ||||||
|         if (recyclerViewScrollListener == null) { |         recyclerViewScrollListener = object : RecyclerView.OnScrollListener() { | ||||||
|             recyclerViewScrollListener = object : RecyclerView.OnScrollListener() { |             override fun onScrolled(localRecycler: RecyclerView, dx: Int, dy: Int) { | ||||||
|                 override fun onScrolled(localRecycler: RecyclerView?, dx: Int, dy: Int) { |                 if (localRecycler != null && dy > 0) { | ||||||
|                     if (localRecycler != null && dy > 0) { |                     val manager = recyclerView.layoutManager | ||||||
|                         val manager = recyclerView.layoutManager |                     val lastVisibleItem: Int = when (manager) { | ||||||
|                         val lastVisibleItem: Int = when (manager) { |                         is StaggeredGridLayoutManager -> manager.findLastCompletelyVisibleItemPositions( | ||||||
|                             is StaggeredGridLayoutManager -> manager.findLastCompletelyVisibleItemPositions( |                             null | ||||||
|                                 null |                         ).last() | ||||||
|                             ).last() |                         is GridLayoutManager -> manager.findLastCompletelyVisibleItemPosition() | ||||||
|                             is GridLayoutManager -> manager.findLastCompletelyVisibleItemPosition() |                         else -> 0 | ||||||
|                             else -> 0 |                     } | ||||||
|                         } |  | ||||||
|  |  | ||||||
|                         if (lastVisibleItem == (items.size - 1) && items.size < maxItemNumber()) { |                     if (lastVisibleItem == (items.size - 1) && items.size < maxItemNumber()) { | ||||||
|                             getElementsAccordingToTab(appendResults = true) |                         getElementsAccordingToTab(appendResults = true) | ||||||
|                         } |  | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -806,6 +866,11 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private fun filter(tags: String): Boolean { | ||||||
|  |         val tagsList = tags.replace("\\s".toRegex(), "").split(",") | ||||||
|  |         return tagsList.intersect(hiddenTags).isEmpty() | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private fun doCallTo( |     private fun doCallTo( | ||||||
|         appendResults: Boolean, |         appendResults: Boolean, | ||||||
|         toastMessage: Int, |         toastMessage: Int, | ||||||
| @@ -816,9 +881,16 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|             if (response.body() != null) { |             if (response.body() != null) { | ||||||
|                 if (shouldUpdate) { |                 if (shouldUpdate) { | ||||||
|                     items = response.body() as ArrayList<Item> |                     items = response.body() as ArrayList<Item> | ||||||
|  |                     items = items.filter { | ||||||
|  |                         maybeTagFilter != null || filter(it.tags) | ||||||
|  |                     } as ArrayList<Item> | ||||||
|  |  | ||||||
|                     items.forEach { |                     if (allItems.isEmpty()) { | ||||||
|                         if (!allItems.contains(it)) allItems.add(it) |                         allItems = items | ||||||
|  |                     } else { | ||||||
|  |                         items.forEach { | ||||||
|  |                             if (!allItems.contains(it)) allItems.add(it) | ||||||
|  |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } else { |             } else { | ||||||
| @@ -924,7 +996,9 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                             appColors, |                             appColors, | ||||||
|                             debugReadingItems, |                             debugReadingItems, | ||||||
|                             userIdentifier |                             userIdentifier | ||||||
|                         ) |                         ) { | ||||||
|  |                             updateItems(it) | ||||||
|  |                         } | ||||||
|             } else { |             } else { | ||||||
|                 recyclerAdapter = |                 recyclerAdapter = | ||||||
|                         ItemListAdapter( |                         ItemListAdapter( | ||||||
| @@ -932,13 +1006,14 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                             items, |                             items, | ||||||
|                             api, |                             api, | ||||||
|                             customTabActivityHelper, |                             customTabActivityHelper, | ||||||
|                             clickBehavior, |  | ||||||
|                             internalBrowser, |                             internalBrowser, | ||||||
|                             articleViewer, |                             articleViewer, | ||||||
|                             debugReadingItems, |                             debugReadingItems, | ||||||
|                             userIdentifier, |                             userIdentifier, | ||||||
|                             appColors |                             appColors | ||||||
|                         ) |                         ) { | ||||||
|  |                             updateItems(it) | ||||||
|  |                         } | ||||||
|  |  | ||||||
|                 recyclerView.addItemDecoration( |                 recyclerView.addItemDecoration( | ||||||
|                     DividerItemDecoration( |                     DividerItemDecoration( | ||||||
| @@ -1038,13 +1113,6 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                 drawer.closeDrawer() |                 drawer.closeDrawer() | ||||||
|                 recreate() |                 recreate() | ||||||
|             } |             } | ||||||
|             REQUEST_INVITE -> if (result == Activity.RESULT_OK) { |  | ||||||
|                 Answers.getInstance().logInvite(InviteEvent()) |  | ||||||
|             } |  | ||||||
|             REQUEST_INVITE_BYMAIL -> { |  | ||||||
|                 Answers.getInstance().logInvite(InviteEvent()) |  | ||||||
|                 super.onActivityResult(req, result, data) |  | ||||||
|             } |  | ||||||
|             else -> super.onActivityResult(req, result, data) |             else -> super.onActivityResult(req, result, data) | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -1073,7 +1141,7 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|     override fun onOptionsItemSelected(item: MenuItem): Boolean { |     override fun onOptionsItemSelected(item: MenuItem): Boolean { | ||||||
|         when (item.itemId) { |         when (item.itemId) { | ||||||
|             R.id.refresh -> { |             R.id.refresh -> { | ||||||
|                 needsConfirmation(R.string.menu_home_refresh, R.string.refresh_dialog_message, { |                 needsConfirmation(R.string.menu_home_refresh, R.string.refresh_dialog_message) { | ||||||
|                     api.update().enqueue(object : Callback<String> { |                     api.update().enqueue(object : Callback<String> { | ||||||
|                         override fun onResponse( |                         override fun onResponse( | ||||||
|                             call: Call<String>, |                             call: Call<String>, | ||||||
| @@ -1095,12 +1163,12 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                         } |                         } | ||||||
|                     }) |                     }) | ||||||
|                     Toast.makeText(this, R.string.refresh_in_progress, Toast.LENGTH_SHORT).show() |                     Toast.makeText(this, R.string.refresh_in_progress, Toast.LENGTH_SHORT).show() | ||||||
|                 }) |                 } | ||||||
|                 return true |                 return true | ||||||
|             } |             } | ||||||
|             R.id.readAll -> { |             R.id.readAll -> { | ||||||
|                 if (elementsShown == UNREAD_SHOWN) { |                 if (elementsShown == UNREAD_SHOWN) { | ||||||
|                     needsConfirmation(R.string.readAll, R.string.markall_dialog_message, { |                     needsConfirmation(R.string.readAll, R.string.markall_dialog_message) { | ||||||
|                         swipeRefreshLayout.isRefreshing = false |                         swipeRefreshLayout.isRefreshing = false | ||||||
|                         val ids = allItems.map { it.id } |                         val ids = allItems.map { it.id } | ||||||
|                         val itemsByTag: Map<Long, Int> = |                         val itemsByTag: Map<Long, Int> = | ||||||
| @@ -1110,9 +1178,7 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                                 .toMap() |                                 .toMap() | ||||||
|  |  | ||||||
|                         fun readAllDebug(e: Throwable) { |                         fun readAllDebug(e: Throwable) { | ||||||
|                             Crashlytics.setUserIdentifier(userIdentifier) |                             // TODO: debug | ||||||
|                             Crashlytics.log(100, "READ_ALL_ERROR", e.message) |  | ||||||
|                             Crashlytics.logException(e) |  | ||||||
|                         } |                         } | ||||||
|  |  | ||||||
|                         if (ids.isNotEmpty()) { |                         if (ids.isNotEmpty()) { | ||||||
| @@ -1152,7 +1218,6 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                                                 ) |                                                 ) | ||||||
|                                             ) |                                             ) | ||||||
|                                         } |                                         } | ||||||
|  |  | ||||||
|                                     } |                                     } | ||||||
|  |  | ||||||
|                                     swipeRefreshLayout.isRefreshing = false |                                     swipeRefreshLayout.isRefreshing = false | ||||||
| @@ -1182,34 +1247,13 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|                             ).show() |                             ).show() | ||||||
|                         } |                         } | ||||||
|                         handleListResult() |                         handleListResult() | ||||||
|                     }) |                     } | ||||||
|                 } |                 } | ||||||
|                 return true |                 return true | ||||||
|             } |             } | ||||||
|             R.id.action_disconnect -> { |             R.id.action_disconnect -> { | ||||||
|                 return Config.logoutAndRedirect(this, this@HomeActivity, editor) |                 return Config.logoutAndRedirect(this, this@HomeActivity, editor) | ||||||
|             } |             } | ||||||
|             R.id.action_share_the_app -> { |  | ||||||
|                 if (GoogleApiAvailability.getInstance().isGooglePlayServicesAvailable(this) == ConnectionResult.SUCCESS) { |  | ||||||
|                     val share = |  | ||||||
|                         AppInviteInvitation.IntentBuilder(getString(R.string.invitation_title)) |  | ||||||
|                             .setMessage(getString(R.string.invitation_message)) |  | ||||||
|                             .setDeepLink(Uri.parse("https://ymbh5.app.goo.gl/qbvQ")) |  | ||||||
|                             .setCallToActionText(getString(R.string.invitation_cta)) |  | ||||||
|                             .build() |  | ||||||
|                     startActivityForResult(share, REQUEST_INVITE) |  | ||||||
|                 } else { |  | ||||||
|                     val sendIntent = Intent() |  | ||||||
|                     sendIntent.action = Intent.ACTION_SEND |  | ||||||
|                     sendIntent.putExtra( |  | ||||||
|                         Intent.EXTRA_TEXT, |  | ||||||
|                         getString(R.string.invitation_message) + " https://ymbh5.app.goo.gl/qbvQ" |  | ||||||
|                     ) |  | ||||||
|                     sendIntent.type = "text/plain" |  | ||||||
|                     startActivityForResult(sendIntent, REQUEST_INVITE_BYMAIL) |  | ||||||
|                 } |  | ||||||
|                 return super.onOptionsItemSelected(item) |  | ||||||
|             } |  | ||||||
|             else -> return super.onOptionsItemSelected(item) |             else -> return super.onOptionsItemSelected(item) | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -1221,4 +1265,9 @@ class HomeActivity : AppCompatActivity(), SearchView.OnQueryTextListener { | |||||||
|             FAV_SHOWN -> badgeFavs |             FAV_SHOWN -> badgeFavs | ||||||
|             else -> badgeNew // if !elementsShown then unread are fetched. |             else -> badgeNew // if !elementsShown then unread are fetched. | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |     fun updateItems(adapterItems: ArrayList<Item>) { | ||||||
|  |         items = adapterItems | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,70 +0,0 @@ | |||||||
| package apps.amine.bou.readerforselfoss |  | ||||||
|  |  | ||||||
| import agency.tango.materialintroscreen.MaterialIntroActivity |  | ||||||
| import agency.tango.materialintroscreen.MessageButtonBehaviour |  | ||||||
| import agency.tango.materialintroscreen.SlideFragmentBuilder |  | ||||||
| import android.content.Intent |  | ||||||
| import android.net.Uri |  | ||||||
| import android.os.Bundle |  | ||||||
| import android.preference.PreferenceManager |  | ||||||
| import android.support.v7.app.AppCompatDelegate |  | ||||||
| import android.view.View |  | ||||||
|  |  | ||||||
| class IntroActivity : MaterialIntroActivity() { |  | ||||||
|  |  | ||||||
|     override fun onCreate(savedInstanceState: Bundle?) { |  | ||||||
|         super.onCreate(savedInstanceState) |  | ||||||
|  |  | ||||||
|         AppCompatDelegate.setCompatVectorFromResourcesEnabled(true) |  | ||||||
|  |  | ||||||
|         addSlide( |  | ||||||
|             SlideFragmentBuilder() |  | ||||||
|                 .backgroundColor(R.color.colorPrimary) |  | ||||||
|                 .buttonsColor(R.color.colorAccent) |  | ||||||
|                 .image(R.drawable.web_hi_res_512) |  | ||||||
|                 .title(getString(R.string.intro_hello_title)) |  | ||||||
|                 .description(getString(R.string.intro_hello_message)) |  | ||||||
|                 .build() |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|         addSlide( |  | ||||||
|             SlideFragmentBuilder() |  | ||||||
|                 .backgroundColor(R.color.colorAccent) |  | ||||||
|                 .buttonsColor(R.color.colorPrimary) |  | ||||||
|                 .image(R.drawable.ic_info_outline_white_48px) |  | ||||||
|                 .title(getString(R.string.intro_needs_selfoss_title)) |  | ||||||
|                 .description(getString(R.string.intro_needs_selfoss_message)) |  | ||||||
|                 .build(), |  | ||||||
|             MessageButtonBehaviour( |  | ||||||
|                 View.OnClickListener { |  | ||||||
|                     val browserIntent = Intent( |  | ||||||
|                         Intent.ACTION_VIEW, |  | ||||||
|                         Uri.parse("https://selfoss.aditu.de") |  | ||||||
|                     ) |  | ||||||
|                     startActivity(browserIntent) |  | ||||||
|                 }, getString(R.string.intro_needs_selfoss_link) |  | ||||||
|             ) |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|         addSlide( |  | ||||||
|             SlideFragmentBuilder() |  | ||||||
|                 .backgroundColor(R.color.colorPrimaryDark) |  | ||||||
|                 .buttonsColor(R.color.colorAccentDark) |  | ||||||
|                 .image(R.drawable.ic_thumb_up_white_48px) |  | ||||||
|                 .title(getString(R.string.intro_all_set_title)) |  | ||||||
|                 .description(getString(R.string.intro_all_set_message)) |  | ||||||
|                 .build() |  | ||||||
|         ) |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     override fun onFinish() { |  | ||||||
|         super.onFinish() |  | ||||||
|         val getPrefs = PreferenceManager.getDefaultSharedPreferences(baseContext) |  | ||||||
|         val e = getPrefs.edit() |  | ||||||
|         e.putBoolean("firstStart", false) |  | ||||||
|         e.apply() |  | ||||||
|         val intent = Intent(this, LoginActivity::class.java) |  | ||||||
|         startActivity(intent) |  | ||||||
|         finish() |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -6,8 +6,8 @@ import android.content.Context | |||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.content.SharedPreferences | import android.content.SharedPreferences | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.support.v7.app.AlertDialog | import androidx.appcompat.app.AlertDialog | ||||||
| import android.support.v7.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
| import android.text.TextUtils | import android.text.TextUtils | ||||||
| import android.view.Menu | import android.view.Menu | ||||||
| import android.view.MenuItem | import android.view.MenuItem | ||||||
| @@ -20,11 +20,11 @@ import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | |||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors | import apps.amine.bou.readerforselfoss.themes.AppColors | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
| import apps.amine.bou.readerforselfoss.utils.isBaseUrlValid | import apps.amine.bou.readerforselfoss.utils.isBaseUrlValid | ||||||
| import com.crashlytics.android.Crashlytics | import apps.amine.bou.readerforselfoss.utils.maybeHandleSilentException | ||||||
| import com.google.firebase.analytics.FirebaseAnalytics |  | ||||||
| import com.mikepenz.aboutlibraries.Libs | import com.mikepenz.aboutlibraries.Libs | ||||||
| import com.mikepenz.aboutlibraries.LibsBuilder | import com.mikepenz.aboutlibraries.LibsBuilder | ||||||
| import kotlinx.android.synthetic.main.activity_login.* | import kotlinx.android.synthetic.main.activity_login.* | ||||||
|  | import org.acra.ACRA | ||||||
| import retrofit2.Call | import retrofit2.Call | ||||||
| import retrofit2.Callback | import retrofit2.Callback | ||||||
| import retrofit2.Response | import retrofit2.Response | ||||||
| @@ -38,7 +38,6 @@ class LoginActivity : AppCompatActivity() { | |||||||
|  |  | ||||||
|     private lateinit var settings: SharedPreferences |     private lateinit var settings: SharedPreferences | ||||||
|     private lateinit var editor: SharedPreferences.Editor |     private lateinit var editor: SharedPreferences.Editor | ||||||
|     private lateinit var firebaseAnalytics: FirebaseAnalytics |  | ||||||
|     private lateinit var userIdentifier: String |     private lateinit var userIdentifier: String | ||||||
|     private var logErrors: Boolean = false |     private var logErrors: Boolean = false | ||||||
|     private lateinit var appColors: AppColors |     private lateinit var appColors: AppColors | ||||||
| @@ -65,8 +64,6 @@ class LoginActivity : AppCompatActivity() { | |||||||
|             goToMain() |             goToMain() | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         firebaseAnalytics = FirebaseAnalytics.getInstance(this) |  | ||||||
|  |  | ||||||
|         handleActions() |         handleActions() | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -213,9 +210,7 @@ class LoginActivity : AppCompatActivity() { | |||||||
|                     httpLoginView.error = getString(R.string.wrong_infos) |                     httpLoginView.error = getString(R.string.wrong_infos) | ||||||
|                     httpPasswordView.error = getString(R.string.wrong_infos) |                     httpPasswordView.error = getString(R.string.wrong_infos) | ||||||
|                     if (logErrors) { |                     if (logErrors) { | ||||||
|                         Crashlytics.setUserIdentifier(userIdentifier) |                         ACRA.getErrorReporter().maybeHandleSilentException(t, this@LoginActivity) | ||||||
|                         Crashlytics.log(100, "LOGIN_DEBUG_ERRROR", t.message) |  | ||||||
|                         Crashlytics.logException(t) |  | ||||||
|                         Toast.makeText( |                         Toast.makeText( | ||||||
|                             this@LoginActivity, |                             this@LoginActivity, | ||||||
|                             t.message, |                             t.message, | ||||||
| @@ -230,7 +225,6 @@ class LoginActivity : AppCompatActivity() { | |||||||
|                     response: Response<SuccessResponse> |                     response: Response<SuccessResponse> | ||||||
|                 ) { |                 ) { | ||||||
|                     if (response.body() != null && response.body()!!.isSuccess) { |                     if (response.body() != null && response.body()!!.isSuccess) { | ||||||
|                         firebaseAnalytics.logEvent(FirebaseAnalytics.Event.LOGIN, Bundle()) |  | ||||||
|                         goToMain() |                         goToMain() | ||||||
|                     } else { |                     } else { | ||||||
|                         preferenceError(Exception("No response body...")) |                         preferenceError(Exception("No response body...")) | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ package apps.amine.bou.readerforselfoss | |||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import android.preference.PreferenceManager | ||||||
| import android.support.v7.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
|  |  | ||||||
| class MainActivity : AppCompatActivity() { | class MainActivity : AppCompatActivity() { | ||||||
|  |  | ||||||
| @@ -11,17 +11,9 @@ class MainActivity : AppCompatActivity() { | |||||||
|         super.onCreate(savedInstanceState) |         super.onCreate(savedInstanceState) | ||||||
|         setContentView(R.layout.activity_main) |         setContentView(R.layout.activity_main) | ||||||
|  |  | ||||||
|         if (PreferenceManager.getDefaultSharedPreferences(baseContext).getBoolean( |         val intent = Intent(this, LoginActivity::class.java) | ||||||
|                 "firstStart", |  | ||||||
|                 true |  | ||||||
|             )) { |  | ||||||
|             val i = Intent(this@MainActivity, IntroActivity::class.java) |  | ||||||
|             startActivity(i) |  | ||||||
|         } else { |  | ||||||
|             val intent = Intent(this, LoginActivity::class.java) |  | ||||||
|             startActivity(intent) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|  |         startActivity(intent) | ||||||
|         finish() |         finish() | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -4,33 +4,49 @@ import android.content.Context | |||||||
| import android.graphics.drawable.Drawable | import android.graphics.drawable.Drawable | ||||||
| import android.net.Uri | import android.net.Uri | ||||||
| import android.preference.PreferenceManager | import android.preference.PreferenceManager | ||||||
| import android.support.multidex.MultiDexApplication | import androidx.multidex.MultiDexApplication | ||||||
| import android.widget.ImageView | import android.widget.ImageView | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
| import com.anupcowkur.reservoir.Reservoir |  | ||||||
| import com.bumptech.glide.Glide | import com.bumptech.glide.Glide | ||||||
| import com.bumptech.glide.request.RequestOptions | import com.bumptech.glide.request.RequestOptions | ||||||
| import com.crashlytics.android.Crashlytics |  | ||||||
| import com.ftinc.scoop.Scoop | import com.ftinc.scoop.Scoop | ||||||
| import com.github.stkent.amplify.feedback.DefaultEmailFeedbackCollector | import com.github.stkent.amplify.feedback.DefaultEmailFeedbackCollector | ||||||
| import com.github.stkent.amplify.feedback.GooglePlayStoreFeedbackCollector | import com.github.stkent.amplify.feedback.GooglePlayStoreFeedbackCollector | ||||||
| import com.github.stkent.amplify.tracking.Amplify | import com.github.stkent.amplify.tracking.Amplify | ||||||
| import com.mikepenz.materialdrawer.util.AbstractDrawerImageLoader | import com.mikepenz.materialdrawer.util.AbstractDrawerImageLoader | ||||||
| import com.mikepenz.materialdrawer.util.DrawerImageLoader | import com.mikepenz.materialdrawer.util.DrawerImageLoader | ||||||
| import io.fabric.sdk.android.Fabric | import org.acra.ACRA | ||||||
|  | import org.acra.ReportField | ||||||
|  | import org.acra.annotation.AcraCore | ||||||
|  | import org.acra.annotation.AcraDialog | ||||||
|  | import org.acra.annotation.AcraHttpSender | ||||||
|  | import org.acra.sender.HttpSender | ||||||
| import java.io.IOException | import java.io.IOException | ||||||
| import java.util.UUID.randomUUID | import java.util.UUID.randomUUID | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @AcraHttpSender(uri = "http://amine-bou.fr:5984/acra-selfoss/_design/acra-storage/_update/report", | ||||||
|  |                 basicAuthLogin = "selfoss", | ||||||
|  |                 basicAuthPassword = "selfoss", | ||||||
|  |                 httpMethod = HttpSender.Method.PUT) | ||||||
|  | @AcraDialog(resText = R.string.crash_dialog_text, | ||||||
|  |             resCommentPrompt = R.string.crash_dialog_comment, | ||||||
|  |             resTheme = android.R.style.Theme_DeviceDefault_Dialog) | ||||||
|  | @AcraCore(reportContent = [ReportField.REPORT_ID, ReportField.INSTALLATION_ID, | ||||||
|  |     ReportField.APP_VERSION_CODE, ReportField.APP_VERSION_NAME, | ||||||
|  |     ReportField.BUILD, ReportField.ANDROID_VERSION, ReportField.BRAND, ReportField.PHONE_MODEL, | ||||||
|  |     ReportField.AVAILABLE_MEM_SIZE, ReportField.TOTAL_MEM_SIZE, | ||||||
|  |     ReportField.STACK_TRACE, ReportField.APPLICATION_LOG, ReportField.LOGCAT, | ||||||
|  |     ReportField.INITIAL_CONFIGURATION, ReportField.CRASH_CONFIGURATION, ReportField.IS_SILENT, | ||||||
|  |     ReportField.USER_APP_START_DATE, ReportField.USER_COMMENT, ReportField.USER_CRASH_DATE, ReportField.USER_EMAIL, ReportField.CUSTOM_DATA], | ||||||
|  |           buildConfigClass = BuildConfig::class) | ||||||
| class MyApp : MultiDexApplication() { | class MyApp : MultiDexApplication() { | ||||||
|  |  | ||||||
|     override fun onCreate() { |     override fun onCreate() { | ||||||
|         super.onCreate() |         super.onCreate() | ||||||
|         Fabric.with(this, Crashlytics()) |  | ||||||
|  |  | ||||||
|         initAmplify() |         initAmplify() | ||||||
|  |  | ||||||
|         initCache() |  | ||||||
|  |  | ||||||
|         val prefs = getSharedPreferences(Config.settingsName, Context.MODE_PRIVATE) |         val prefs = getSharedPreferences(Config.settingsName, Context.MODE_PRIVATE) | ||||||
|         if (prefs.getString("unique_id", "").isEmpty()) { |         if (prefs.getString("unique_id", "").isEmpty()) { | ||||||
|             val editor = prefs.edit() |             val editor = prefs.edit() | ||||||
| @@ -45,21 +61,21 @@ class MyApp : MultiDexApplication() { | |||||||
|         tryToHandleBug() |         tryToHandleBug() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     override fun attachBaseContext(base: Context?) { | ||||||
|  |         super.attachBaseContext(base) | ||||||
|  |         val prefs = getSharedPreferences(Config.settingsName, Context.MODE_PRIVATE) | ||||||
|  |         ACRA.init(this) | ||||||
|  |         ACRA.getErrorReporter().putCustomData("unique_id", prefs.getString("unique_id", "")) | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private fun initAmplify() { |     private fun initAmplify() { | ||||||
|         Amplify.initSharedInstance(this) |         Amplify.initSharedInstance(this) | ||||||
|             .setPositiveFeedbackCollectors(GooglePlayStoreFeedbackCollector()) |             .setPositiveFeedbackCollectors(GooglePlayStoreFeedbackCollector()) | ||||||
|             .setCriticalFeedbackCollectors(DefaultEmailFeedbackCollector(BuildConfig.FEEDBACK_EMAIL)) |             .setCriticalFeedbackCollectors(DefaultEmailFeedbackCollector(Config.feedbackEmail)) | ||||||
|             .applyAllDefaultRules() |             .applyAllDefaultRules() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun initCache() { |  | ||||||
|         try { |  | ||||||
|             Reservoir.init(this, 8192) //in bytes |  | ||||||
|         } catch (e: IOException) { |  | ||||||
|             //failure |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private fun initDrawerImageLoader() { |     private fun initDrawerImageLoader() { | ||||||
|         DrawerImageLoader.init(object : AbstractDrawerImageLoader() { |         DrawerImageLoader.init(object : AbstractDrawerImageLoader() { | ||||||
|             override fun set( |             override fun set( | ||||||
|   | |||||||
| @@ -1,15 +1,17 @@ | |||||||
| package apps.amine.bou.readerforselfoss | package apps.amine.bou.readerforselfoss | ||||||
|  |  | ||||||
| import android.content.Context | import android.graphics.drawable.ColorDrawable | ||||||
| import android.content.res.Resources | import android.os.Build | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import android.preference.PreferenceManager | ||||||
| import android.support.v4.app.FragmentManager | import androidx.fragment.app.FragmentManager | ||||||
| import android.support.v4.app.FragmentStatePagerAdapter | import androidx.fragment.app.FragmentStatePagerAdapter | ||||||
| import android.support.v4.view.ViewPager | import androidx.core.content.ContextCompat | ||||||
| import android.support.v7.app.AppCompatActivity | import androidx.viewpager.widget.ViewPager | ||||||
|  | import androidx.appcompat.app.AppCompatActivity | ||||||
| import android.view.Menu | import android.view.Menu | ||||||
| import android.view.MenuItem | import android.view.MenuItem | ||||||
|  | import android.view.ViewGroup | ||||||
| import android.widget.Toast | import android.widget.Toast | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Item | import apps.amine.bou.readerforselfoss.api.selfoss.Item | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| @@ -18,13 +20,13 @@ import apps.amine.bou.readerforselfoss.fragments.ArticleFragment | |||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors | import apps.amine.bou.readerforselfoss.themes.AppColors | ||||||
| import apps.amine.bou.readerforselfoss.themes.Toppings | import apps.amine.bou.readerforselfoss.themes.Toppings | ||||||
| import apps.amine.bou.readerforselfoss.transformers.DepthPageTransformer | import apps.amine.bou.readerforselfoss.transformers.DepthPageTransformer | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config | import apps.amine.bou.readerforselfoss.utils.maybeHandleSilentException | ||||||
| import apps.amine.bou.readerforselfoss.utils.succeeded | import apps.amine.bou.readerforselfoss.utils.succeeded | ||||||
| import apps.amine.bou.readerforselfoss.utils.toggleStar | import apps.amine.bou.readerforselfoss.utils.toggleStar | ||||||
| import com.crashlytics.android.Crashlytics |  | ||||||
| import com.ftinc.scoop.Scoop | import com.ftinc.scoop.Scoop | ||||||
| import kotlinx.android.synthetic.main.activity_reader.* | import kotlinx.android.synthetic.main.activity_reader.* | ||||||
| import me.relex.circleindicator.CircleIndicator | import me.relex.circleindicator.CircleIndicator | ||||||
|  | import org.acra.ACRA | ||||||
| import retrofit2.Call | import retrofit2.Call | ||||||
| import retrofit2.Callback | import retrofit2.Callback | ||||||
| import retrofit2.Response | import retrofit2.Response | ||||||
| @@ -54,115 +56,108 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     override fun onCreate(savedInstanceState: Bundle?) { |     override fun onCreate(savedInstanceState: Bundle?) { | ||||||
|         val appColors = AppColors(this@ReaderActivity) |  | ||||||
|  |  | ||||||
|         super.onCreate(savedInstanceState) |         super.onCreate(savedInstanceState) | ||||||
|  |  | ||||||
|         setContentView(R.layout.activity_reader) |         setContentView(R.layout.activity_reader) | ||||||
|  |  | ||||||
|         Scoop.getInstance() |         val scoop = Scoop.getInstance() | ||||||
|             .bind(this, Toppings.PRIMARY.value, toolBar) |         scoop.bind(this, Toppings.PRIMARY.value, toolBar) | ||||||
|             .bindStatusBar(this, Toppings.PRIMARY_DARK.value) |         if  (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { | ||||||
|  |             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) | ||||||
|  |         } | ||||||
|  |  | ||||||
|         setSupportActionBar(toolBar) |         setSupportActionBar(toolBar) | ||||||
|         supportActionBar?.setDisplayHomeAsUpEnabled(true) |         supportActionBar?.setDisplayHomeAsUpEnabled(true) | ||||||
|         supportActionBar?.setDisplayShowHomeEnabled(true) |         supportActionBar?.setDisplayShowHomeEnabled(true) | ||||||
|  |  | ||||||
|         val settings = getSharedPreferences(Config.settingsName, Context.MODE_PRIVATE) |         val prefs = PreferenceManager.getDefaultSharedPreferences(this) | ||||||
|         val sharedPref = PreferenceManager.getDefaultSharedPreferences(this) |  | ||||||
|  |  | ||||||
|         debugReadingItems = sharedPref.getBoolean("read_debug", false) |         debugReadingItems = prefs.getBoolean("read_debug", false) | ||||||
|         userIdentifier = sharedPref.getString("unique_id", "") |         userIdentifier = prefs.getString("unique_id", "") | ||||||
|         markOnScroll = sharedPref.getBoolean("mark_on_scroll", false) |         markOnScroll = prefs.getBoolean("mark_on_scroll", false) | ||||||
|  |  | ||||||
|  |         api = SelfossApi( | ||||||
|  |             this, | ||||||
|  |             this@ReaderActivity, | ||||||
|  |             prefs.getBoolean("isSelfSignedCert", false), | ||||||
|  |             prefs.getBoolean("should_log_everything", false) | ||||||
|  |         ) | ||||||
|  |  | ||||||
|         if (allItems.isEmpty()) { |         if (allItems.isEmpty()) { | ||||||
|             finish() |             finish() | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         api = SelfossApi( |  | ||||||
|             this, |  | ||||||
|             this@ReaderActivity, |  | ||||||
|             settings.getBoolean("isSelfSignedCert", false), |  | ||||||
|             sharedPref.getBoolean("should_log_everything", false) |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|         currentItem = intent.getIntExtra("currentItem", 0) |         currentItem = intent.getIntExtra("currentItem", 0) | ||||||
|  |  | ||||||
|         pager.adapter = ScreenSlidePagerAdapter(supportFragmentManager) |         readItem(allItems[currentItem].id) | ||||||
|  |  | ||||||
|  |         pager.adapter = ScreenSlidePagerAdapter(supportFragmentManager, AppColors(this@ReaderActivity)) | ||||||
|         pager.currentItem = currentItem |         pager.currentItem = currentItem | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     override fun onResume() { |     override fun onResume() { | ||||||
|         super.onResume() |         super.onResume() | ||||||
|  |  | ||||||
|         (pager.adapter as ScreenSlidePagerAdapter).notifyDataSetChanged() |         notifyAdapter() | ||||||
|  |  | ||||||
|         pager.setPageTransformer(true, DepthPageTransformer()) |         pager.setPageTransformer(true, DepthPageTransformer()) | ||||||
|         (indicator as CircleIndicator).setViewPager(pager) |         (indicator as CircleIndicator).setViewPager(pager) | ||||||
|  |  | ||||||
|         pager.addOnPageChangeListener( |         pager.addOnPageChangeListener( | ||||||
|             object : ViewPager.SimpleOnPageChangeListener() { |             object : ViewPager.SimpleOnPageChangeListener() { | ||||||
|                 var isLastItem = false |  | ||||||
|  |  | ||||||
|                 override fun onPageSelected(position: Int) { |                 override fun onPageSelected(position: Int) { | ||||||
|                     isLastItem = (position === (allItems.size - 1)) |  | ||||||
|  |  | ||||||
|                     if (allItems[position].starred) { |                     if (allItems[position].starred) { | ||||||
|                         canRemoveFromFavorite() |                         canRemoveFromFavorite() | ||||||
|                     } else { |                     } else { | ||||||
|                         canFavorite() |                         canFavorite() | ||||||
|                     } |                     } | ||||||
|                 } |                     readItem(allItems[pager.currentItem].id) | ||||||
|  |  | ||||||
|                 override fun onPageScrollStateChanged(state: Int) { |  | ||||||
|                     if (markOnScroll && (state === ViewPager.SCROLL_STATE_DRAGGING || (state === ViewPager.SCROLL_STATE_IDLE && isLastItem))) { |  | ||||||
|                         api.markItem(allItems[pager.currentItem].id).enqueue( |  | ||||||
|                             object : Callback<SuccessResponse> { |  | ||||||
|                                 override fun onResponse( |  | ||||||
|                                     call: Call<SuccessResponse>, |  | ||||||
|                                     response: Response<SuccessResponse> |  | ||||||
|                                 ) { |  | ||||||
|                                     if (!response.succeeded() && debugReadingItems) { |  | ||||||
|                                         val message = |  | ||||||
|                                             "message: ${response.message()} " + |  | ||||||
|                                                     "response isSuccess: ${response.isSuccessful} " + |  | ||||||
|                                                     "response code: ${response.code()} " + |  | ||||||
|                                                     "response message: ${response.message()} " + |  | ||||||
|                                                     "response errorBody: ${response.errorBody()?.string()} " + |  | ||||||
|                                                     "body success: ${response.body()?.success} " + |  | ||||||
|                                                     "body isSuccess: ${response.body()?.isSuccess}" |  | ||||||
|                                         Crashlytics.setUserIdentifier(userIdentifier) |  | ||||||
|                                         Crashlytics.log( |  | ||||||
|                                             100, |  | ||||||
|                                             "READ_DEBUG_SUCCESS", |  | ||||||
|                                             message |  | ||||||
|                                         ) |  | ||||||
|                                         Crashlytics.logException(Exception("Was success, but did it work ?")) |  | ||||||
|                                     } |  | ||||||
|                                 } |  | ||||||
|  |  | ||||||
|                                 override fun onFailure( |  | ||||||
|                                     call: Call<SuccessResponse>, |  | ||||||
|                                     t: Throwable |  | ||||||
|                                 ) { |  | ||||||
|                                     if (debugReadingItems) { |  | ||||||
|                                         Crashlytics.setUserIdentifier(userIdentifier) |  | ||||||
|                                         Crashlytics.log( |  | ||||||
|                                             100, |  | ||||||
|                                             "READ_DEBUG_ERROR", |  | ||||||
|                                             t.message |  | ||||||
|                                         ) |  | ||||||
|                                         Crashlytics.logException(t) |  | ||||||
|                                     } |  | ||||||
|                                 } |  | ||||||
|                             } |  | ||||||
|                         ) |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     fun readItem(id: String) { | ||||||
|  |         if (markOnScroll) { | ||||||
|  |             api.markItem(id).enqueue( | ||||||
|  |                 object : Callback<SuccessResponse> { | ||||||
|  |                     override fun onResponse( | ||||||
|  |                         call: Call<SuccessResponse>, | ||||||
|  |                         response: Response<SuccessResponse> | ||||||
|  |                     ) { | ||||||
|  |                         if (!response.succeeded() && debugReadingItems) { | ||||||
|  |                             val message = | ||||||
|  |                                 "message: ${response.message()} " + | ||||||
|  |                                         "response isSuccess: ${response.isSuccessful} " + | ||||||
|  |                                         "response code: ${response.code()} " + | ||||||
|  |                                         "response message: ${response.message()} " + | ||||||
|  |                                         "response errorBody: ${response.errorBody()?.string()} " + | ||||||
|  |                                         "body success: ${response.body()?.success} " + | ||||||
|  |                                         "body isSuccess: ${response.body()?.isSuccess}" | ||||||
|  |                             ACRA.getErrorReporter() | ||||||
|  |                                 .maybeHandleSilentException(Exception(message), this@ReaderActivity) | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |  | ||||||
|  |                     override fun onFailure( | ||||||
|  |                         call: Call<SuccessResponse>, | ||||||
|  |                         t: Throwable | ||||||
|  |                     ) { | ||||||
|  |                         if (debugReadingItems) { | ||||||
|  |                             ACRA.getErrorReporter().maybeHandleSilentException(t, this@ReaderActivity) | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             ) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private fun notifyAdapter() { | ||||||
|  |         (pager.adapter as ScreenSlidePagerAdapter).notifyDataSetChanged() | ||||||
|  |     } | ||||||
|  |  | ||||||
|     override fun onPause() { |     override fun onPause() { | ||||||
|         super.onPause() |         super.onPause() | ||||||
|         if (markOnScroll) { |         if (markOnScroll) { | ||||||
| @@ -175,8 +170,10 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|         oldInstanceState!!.clear() |         oldInstanceState!!.clear() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private inner class ScreenSlidePagerAdapter(fm: FragmentManager) : |     private inner class ScreenSlidePagerAdapter(fm: FragmentManager, val appColors: AppColors) : | ||||||
|         FragmentStatePagerAdapter(fm) { |         FragmentStatePagerAdapter(fm) { | ||||||
|  |  | ||||||
|  |  | ||||||
|         override fun getCount(): Int { |         override fun getCount(): Int { | ||||||
|             return allItems.size |             return allItems.size | ||||||
|         } |         } | ||||||
| @@ -184,6 +181,12 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|         override fun getItem(position: Int): ArticleFragment { |         override fun getItem(position: Int): ArticleFragment { | ||||||
|             return ArticleFragment.newInstance(position, allItems) |             return ArticleFragment.newInstance(position, allItems) | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         override fun startUpdate(container: ViewGroup) { | ||||||
|  |             super.startUpdate(container) | ||||||
|  |  | ||||||
|  |             container.background = ColorDrawable(ContextCompat.getColor(this@ReaderActivity, appColors.colorBackground)) | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     override fun onCreateOptionsMenu(menu: Menu): Boolean { |     override fun onCreateOptionsMenu(menu: Menu): Boolean { | ||||||
| @@ -214,6 +217,7 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|                             response: Response<SuccessResponse> |                             response: Response<SuccessResponse> | ||||||
|                         ) { |                         ) { | ||||||
|                             allItems[pager.currentItem] = allItems[pager.currentItem].toggleStar() |                             allItems[pager.currentItem] = allItems[pager.currentItem].toggleStar() | ||||||
|  |                             notifyAdapter() | ||||||
|                             canRemoveFromFavorite() |                             canRemoveFromFavorite() | ||||||
|                         } |                         } | ||||||
|  |  | ||||||
| @@ -237,6 +241,7 @@ class ReaderActivity : AppCompatActivity() { | |||||||
|                             response: Response<SuccessResponse> |                             response: Response<SuccessResponse> | ||||||
|                         ) { |                         ) { | ||||||
|                             allItems[pager.currentItem] = allItems[pager.currentItem].toggleStar() |                             allItems[pager.currentItem] = allItems[pager.currentItem].toggleStar() | ||||||
|  |                             notifyAdapter() | ||||||
|                             canFavorite() |                             canFavorite() | ||||||
|                         } |                         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,14 +2,15 @@ package apps.amine.bou.readerforselfoss | |||||||
|  |  | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.content.res.ColorStateList | import android.content.res.ColorStateList | ||||||
|  | import android.os.Build | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import android.preference.PreferenceManager | ||||||
| import android.support.v7.app.AppCompatActivity | import androidx.appcompat.app.AppCompatActivity | ||||||
| import android.support.v7.widget.LinearLayoutManager | import androidx.recyclerview.widget.LinearLayoutManager | ||||||
| import android.widget.Toast | import android.widget.Toast | ||||||
| import apps.amine.bou.readerforselfoss.adapters.SourcesListAdapter | import apps.amine.bou.readerforselfoss.adapters.SourcesListAdapter | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Sources | import apps.amine.bou.readerforselfoss.api.selfoss.Source | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors | import apps.amine.bou.readerforselfoss.themes.AppColors | ||||||
| import apps.amine.bou.readerforselfoss.themes.Toppings | import apps.amine.bou.readerforselfoss.themes.Toppings | ||||||
| import com.ftinc.scoop.Scoop | import com.ftinc.scoop.Scoop | ||||||
| @@ -29,9 +30,11 @@ class SourcesActivity : AppCompatActivity() { | |||||||
|  |  | ||||||
|         setContentView(R.layout.activity_sources) |         setContentView(R.layout.activity_sources) | ||||||
|  |  | ||||||
|         Scoop.getInstance() |         val scoop = Scoop.getInstance() | ||||||
|             .bind(this, Toppings.PRIMARY.value, toolbar) |         scoop.bind(this, Toppings.PRIMARY.value, toolbar) | ||||||
|             .bindStatusBar(this, Toppings.PRIMARY_DARK.value) |         if  (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { | ||||||
|  |             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.value) | ||||||
|  |         } | ||||||
|  |  | ||||||
|         setSupportActionBar(toolbar) |         setSupportActionBar(toolbar) | ||||||
|         supportActionBar?.setDisplayHomeAsUpEnabled(true) |         supportActionBar?.setDisplayHomeAsUpEnabled(true) | ||||||
| @@ -58,18 +61,18 @@ class SourcesActivity : AppCompatActivity() { | |||||||
|             prefs.getBoolean("isSelfSignedCert", false), |             prefs.getBoolean("isSelfSignedCert", false), | ||||||
|             prefs.getBoolean("should_log_everything", false) |             prefs.getBoolean("should_log_everything", false) | ||||||
|         ) |         ) | ||||||
|         var items: ArrayList<Sources> = ArrayList() |         var items: ArrayList<Source> = ArrayList() | ||||||
|  |  | ||||||
|         recyclerView.setHasFixedSize(true) |         recyclerView.setHasFixedSize(true) | ||||||
|         recyclerView.layoutManager = mLayoutManager |         recyclerView.layoutManager = mLayoutManager | ||||||
|  |  | ||||||
|         api.sources.enqueue(object : Callback<List<Sources>> { |         api.sources.enqueue(object : Callback<List<Source>> { | ||||||
|             override fun onResponse( |             override fun onResponse( | ||||||
|                 call: Call<List<Sources>>, |                 call: Call<List<Source>>, | ||||||
|                 response: Response<List<Sources>> |                 response: Response<List<Source>> | ||||||
|             ) { |             ) { | ||||||
|                 if (response.body() != null && response.body()!!.isNotEmpty()) { |                 if (response.body() != null && response.body()!!.isNotEmpty()) { | ||||||
|                     items = response.body() as ArrayList<Sources> |                     items = response.body() as ArrayList<Source> | ||||||
|                 } |                 } | ||||||
|                 val mAdapter = SourcesListAdapter(this@SourcesActivity, items, api) |                 val mAdapter = SourcesListAdapter(this@SourcesActivity, items, api) | ||||||
|                 recyclerView.adapter = mAdapter |                 recyclerView.adapter = mAdapter | ||||||
| @@ -83,7 +86,7 @@ class SourcesActivity : AppCompatActivity() { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             override fun onFailure(call: Call<List<Sources>>, t: Throwable) { |             override fun onFailure(call: Call<List<Source>>, t: Throwable) { | ||||||
|                 Toast.makeText( |                 Toast.makeText( | ||||||
|                     this@SourcesActivity, |                     this@SourcesActivity, | ||||||
|                     R.string.cant_get_sources, |                     R.string.cant_get_sources, | ||||||
|   | |||||||
| @@ -2,8 +2,8 @@ package apps.amine.bou.readerforselfoss.adapters | |||||||
|  |  | ||||||
| import android.app.Activity | import android.app.Activity | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.support.v7.widget.CardView | import androidx.cardview.widget.CardView | ||||||
| import android.support.v7.widget.RecyclerView | import androidx.recyclerview.widget.RecyclerView | ||||||
| import android.text.Html | import android.text.Html | ||||||
| import android.view.LayoutInflater | import android.view.LayoutInflater | ||||||
| import android.view.View | import android.view.View | ||||||
| @@ -44,7 +44,8 @@ class ItemCardAdapter( | |||||||
|     private val fullHeightCards: Boolean, |     private val fullHeightCards: Boolean, | ||||||
|     override val appColors: AppColors, |     override val appColors: AppColors, | ||||||
|     override val debugReadingItems: Boolean, |     override val debugReadingItems: Boolean, | ||||||
|     override val userIdentifier: String |     override val userIdentifier: String, | ||||||
|  |     override val updateItems: (ArrayList<Item>) -> Unit | ||||||
| ) : ItemsAdapter<ItemCardAdapter.ViewHolder>() { | ) : ItemsAdapter<ItemCardAdapter.ViewHolder>() { | ||||||
|     private val c: Context = app.baseContext |     private val c: Context = app.baseContext | ||||||
|     private val generator: ColorGenerator = ColorGenerator.MATERIAL |     private val generator: ColorGenerator = ColorGenerator.MATERIAL | ||||||
| @@ -88,7 +89,7 @@ class ItemCardAdapter( | |||||||
|                 TextDrawable |                 TextDrawable | ||||||
|                     .builder() |                     .builder() | ||||||
|                     .round() |                     .round() | ||||||
|                     .build(itm.sourcetitle.toTextDrawableString(), color) |                     .build(itm.sourcetitle.toTextDrawableString(c), color) | ||||||
|             holder.mView.sourceImage.setImageDrawable(drawable) |             holder.mView.sourceImage.setImageDrawable(drawable) | ||||||
|         } else { |         } else { | ||||||
|             c.circularBitmapDrawable(itm.getIcon(c), holder.mView.sourceImage) |             c.circularBitmapDrawable(itm.getIcon(c), holder.mView.sourceImage) | ||||||
|   | |||||||
| @@ -2,8 +2,8 @@ package apps.amine.bou.readerforselfoss.adapters | |||||||
|  |  | ||||||
| import android.app.Activity | import android.app.Activity | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.support.constraint.ConstraintLayout | import androidx.constraintlayout.widget.ConstraintLayout | ||||||
| import android.support.v7.widget.RecyclerView | import androidx.recyclerview.widget.RecyclerView | ||||||
| import android.text.Html | import android.text.Html | ||||||
| import android.util.TypedValue | import android.util.TypedValue | ||||||
| import android.view.LayoutInflater | import android.view.LayoutInflater | ||||||
| @@ -40,12 +40,12 @@ class ItemListAdapter( | |||||||
|     override var items: ArrayList<Item>, |     override var items: ArrayList<Item>, | ||||||
|     override val api: SelfossApi, |     override val api: SelfossApi, | ||||||
|     private val helper: CustomTabActivityHelper, |     private val helper: CustomTabActivityHelper, | ||||||
|     private val clickBehavior: Boolean, |  | ||||||
|     private val internalBrowser: Boolean, |     private val internalBrowser: Boolean, | ||||||
|     private val articleViewer: Boolean, |     private val articleViewer: Boolean, | ||||||
|     override val debugReadingItems: Boolean, |     override val debugReadingItems: Boolean, | ||||||
|     override val userIdentifier: String, |     override val userIdentifier: String, | ||||||
|     override val appColors: AppColors |     override val appColors: AppColors, | ||||||
|  |     override val updateItems: (ArrayList<Item>) -> Unit | ||||||
| ) : ItemsAdapter<ItemListAdapter.ViewHolder>() { | ) : ItemsAdapter<ItemListAdapter.ViewHolder>() { | ||||||
|     private val generator: ColorGenerator = ColorGenerator.MATERIAL |     private val generator: ColorGenerator = ColorGenerator.MATERIAL | ||||||
|     private val c: Context = app.baseContext |     private val c: Context = app.baseContext | ||||||
| @@ -96,7 +96,7 @@ class ItemListAdapter( | |||||||
|                     TextDrawable |                     TextDrawable | ||||||
|                         .builder() |                         .builder() | ||||||
|                         .round() |                         .round() | ||||||
|                         .build(itm.sourcetitle.toTextDrawableString(), color) |                         .build(itm.sourcetitle.toTextDrawableString(c), color) | ||||||
|  |  | ||||||
|                 holder.mView.itemImage.setImageDrawable(drawable) |                 holder.mView.itemImage.setImageDrawable(drawable) | ||||||
|             } else { |             } else { | ||||||
| @@ -193,37 +193,18 @@ class ItemListAdapter( | |||||||
|             val customTabsIntent = c.buildCustomTabsIntent() |             val customTabsIntent = c.buildCustomTabsIntent() | ||||||
|             helper.bindCustomTabsService(app) |             helper.bindCustomTabsService(app) | ||||||
|  |  | ||||||
|  |             mView.setOnClickListener { actionBarShowHide() } | ||||||
|             if (!clickBehavior) { |             mView.setOnLongClickListener { | ||||||
|                 mView.setOnClickListener { |                 c.openItemUrl( | ||||||
|                     c.openItemUrl( |                     items, | ||||||
|                         items, |                     adapterPosition, | ||||||
|                         adapterPosition, |                     items[adapterPosition].getLinkDecoded(), | ||||||
|                         items[adapterPosition].getLinkDecoded(), |                     customTabsIntent, | ||||||
|                         customTabsIntent, |                     internalBrowser, | ||||||
|                         internalBrowser, |                     articleViewer, | ||||||
|                         articleViewer, |                     app | ||||||
|                         app |                 ) | ||||||
|                     ) |                 true | ||||||
|                 } |  | ||||||
|                 mView.setOnLongClickListener { |  | ||||||
|                     actionBarShowHide() |  | ||||||
|                     true |  | ||||||
|                 } |  | ||||||
|             } else { |  | ||||||
|                 mView.setOnClickListener { actionBarShowHide() } |  | ||||||
|                 mView.setOnLongClickListener { |  | ||||||
|                     c.openItemUrl( |  | ||||||
|                         items, |  | ||||||
|                         adapterPosition, |  | ||||||
|                         items[adapterPosition].getLinkDecoded(), |  | ||||||
|                         customTabsIntent, |  | ||||||
|                         internalBrowser, |  | ||||||
|                         articleViewer, |  | ||||||
|                         app |  | ||||||
|                     ) |  | ||||||
|                     true |  | ||||||
|                 } |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,8 +2,8 @@ package apps.amine.bou.readerforselfoss.adapters | |||||||
|  |  | ||||||
| import android.app.Activity | import android.app.Activity | ||||||
| import android.graphics.Color | import android.graphics.Color | ||||||
| import android.support.design.widget.Snackbar | import com.google.android.material.snackbar.Snackbar | ||||||
| import android.support.v7.widget.RecyclerView | import androidx.recyclerview.widget.RecyclerView | ||||||
| import android.widget.TextView | import android.widget.TextView | ||||||
| import android.widget.Toast | import android.widget.Toast | ||||||
| import apps.amine.bou.readerforselfoss.R | import apps.amine.bou.readerforselfoss.R | ||||||
| @@ -11,8 +11,9 @@ import apps.amine.bou.readerforselfoss.api.selfoss.Item | |||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors | import apps.amine.bou.readerforselfoss.themes.AppColors | ||||||
|  | import apps.amine.bou.readerforselfoss.utils.maybeHandleSilentException | ||||||
| import apps.amine.bou.readerforselfoss.utils.succeeded | import apps.amine.bou.readerforselfoss.utils.succeeded | ||||||
| import com.crashlytics.android.Crashlytics | import org.acra.ACRA | ||||||
| import retrofit2.Call | import retrofit2.Call | ||||||
| import retrofit2.Callback | import retrofit2.Callback | ||||||
| import retrofit2.Response | import retrofit2.Response | ||||||
| @@ -24,10 +25,12 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> : RecyclerView.Adapte | |||||||
|     abstract val userIdentifier: String |     abstract val userIdentifier: String | ||||||
|     abstract val app: Activity |     abstract val app: Activity | ||||||
|     abstract val appColors: AppColors |     abstract val appColors: AppColors | ||||||
|  |     abstract val updateItems: (ArrayList<Item>) -> Unit | ||||||
|  |  | ||||||
|     fun updateAllItems(newItems: ArrayList<Item>) { |     fun updateAllItems(newItems: ArrayList<Item>) { | ||||||
|         items = newItems |         items = newItems | ||||||
|         notifyDataSetChanged() |         notifyDataSetChanged() | ||||||
|  |         updateItems(items) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun doUnmark(i: Item, position: Int) { |     private fun doUnmark(i: Item, position: Int) { | ||||||
| @@ -40,6 +43,7 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> : RecyclerView.Adapte | |||||||
|             .setAction(R.string.undo_string) { |             .setAction(R.string.undo_string) { | ||||||
|                 items.add(position, i) |                 items.add(position, i) | ||||||
|                 notifyItemInserted(position) |                 notifyItemInserted(position) | ||||||
|  |                 updateItems(items) | ||||||
|  |  | ||||||
|                 api.unmarkItem(i.id).enqueue(object : Callback<SuccessResponse> { |                 api.unmarkItem(i.id).enqueue(object : Callback<SuccessResponse> { | ||||||
|                     override fun onResponse( |                     override fun onResponse( | ||||||
| @@ -51,13 +55,14 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> : RecyclerView.Adapte | |||||||
|                     override fun onFailure(call: Call<SuccessResponse>, t: Throwable) { |                     override fun onFailure(call: Call<SuccessResponse>, t: Throwable) { | ||||||
|                         items.remove(i) |                         items.remove(i) | ||||||
|                         notifyItemRemoved(position) |                         notifyItemRemoved(position) | ||||||
|  |                         updateItems(items) | ||||||
|                         doUnmark(i, position) |                         doUnmark(i, position) | ||||||
|                     } |                     } | ||||||
|                 }) |                 }) | ||||||
|             } |             } | ||||||
|  |  | ||||||
|         val view = s.view |         val view = s.view | ||||||
|         val tv: TextView = view.findViewById(android.support.design.R.id.snackbar_text) |         val tv: TextView = view.findViewById(com.google.android.material.R.id.snackbar_text) | ||||||
|         tv.setTextColor(Color.WHITE) |         tv.setTextColor(Color.WHITE) | ||||||
|         s.show() |         s.show() | ||||||
|     } |     } | ||||||
| @@ -68,6 +73,8 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> : RecyclerView.Adapte | |||||||
|  |  | ||||||
|         items.remove(i) |         items.remove(i) | ||||||
|         notifyItemRemoved(position) |         notifyItemRemoved(position) | ||||||
|  |         updateItems(items) | ||||||
|  |  | ||||||
|  |  | ||||||
|         api.markItem(i.id).enqueue(object : Callback<SuccessResponse> { |         api.markItem(i.id).enqueue(object : Callback<SuccessResponse> { | ||||||
|             override fun onResponse( |             override fun onResponse( | ||||||
| @@ -83,10 +90,7 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> : RecyclerView.Adapte | |||||||
|                                 "response errorBody: ${response.errorBody()?.string()} " + |                                 "response errorBody: ${response.errorBody()?.string()} " + | ||||||
|                                 "body success: ${response.body()?.success} " + |                                 "body success: ${response.body()?.success} " + | ||||||
|                                 "body isSuccess: ${response.body()?.isSuccess}" |                                 "body isSuccess: ${response.body()?.isSuccess}" | ||||||
|                     Crashlytics.setUserIdentifier(userIdentifier) |                     ACRA.getErrorReporter().maybeHandleSilentException(Exception(message), app) | ||||||
|                     Crashlytics.log(100, "READ_DEBUG_SUCCESS", message) |  | ||||||
|                     Crashlytics.logException(Exception("Was success, but did it work ?")) |  | ||||||
|  |  | ||||||
|                     Toast.makeText(app.baseContext, message, Toast.LENGTH_LONG).show() |                     Toast.makeText(app.baseContext, message, Toast.LENGTH_LONG).show() | ||||||
|                 } |                 } | ||||||
|                 doUnmark(i, position) |                 doUnmark(i, position) | ||||||
| @@ -94,9 +98,7 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> : RecyclerView.Adapte | |||||||
|  |  | ||||||
|             override fun onFailure(call: Call<SuccessResponse>, t: Throwable) { |             override fun onFailure(call: Call<SuccessResponse>, t: Throwable) { | ||||||
|                 if (debugReadingItems) { |                 if (debugReadingItems) { | ||||||
|                     Crashlytics.setUserIdentifier(userIdentifier) |                     ACRA.getErrorReporter().maybeHandleSilentException(t, app) | ||||||
|                     Crashlytics.log(100, "READ_DEBUG_ERROR", t.message) |  | ||||||
|                     Crashlytics.logException(t) |  | ||||||
|                     Toast.makeText(app.baseContext, t.message, Toast.LENGTH_LONG).show() |                     Toast.makeText(app.baseContext, t.message, Toast.LENGTH_LONG).show() | ||||||
|                 } |                 } | ||||||
|                 Toast.makeText( |                 Toast.makeText( | ||||||
| @@ -106,6 +108,8 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> : RecyclerView.Adapte | |||||||
|                 ).show() |                 ).show() | ||||||
|                 items.add(i) |                 items.add(i) | ||||||
|                 notifyItemInserted(position) |                 notifyItemInserted(position) | ||||||
|  |                 updateItems(items) | ||||||
|  |  | ||||||
|             } |             } | ||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
| @@ -113,11 +117,15 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> : RecyclerView.Adapte | |||||||
|     fun addItemAtIndex(item: Item, position: Int) { |     fun addItemAtIndex(item: Item, position: Int) { | ||||||
|         items.add(position, item) |         items.add(position, item) | ||||||
|         notifyItemInserted(position) |         notifyItemInserted(position) | ||||||
|  |         updateItems(items) | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     fun addItemsAtEnd(newItems: List<Item>) { |     fun addItemsAtEnd(newItems: List<Item>) { | ||||||
|         val oldSize = items.size |         val oldSize = items.size | ||||||
|         items.addAll(newItems) |         items.addAll(newItems) | ||||||
|         notifyItemRangeInserted(oldSize, newItems.size) |         notifyItemRangeInserted(oldSize, newItems.size) | ||||||
|  |         updateItems(items) | ||||||
|  |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -2,15 +2,15 @@ package apps.amine.bou.readerforselfoss.adapters | |||||||
|  |  | ||||||
| import android.app.Activity | import android.app.Activity | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.support.constraint.ConstraintLayout | import androidx.constraintlayout.widget.ConstraintLayout | ||||||
| import android.support.v7.widget.RecyclerView | import androidx.recyclerview.widget.RecyclerView | ||||||
| import android.view.LayoutInflater | import android.view.LayoutInflater | ||||||
| import android.view.ViewGroup | import android.view.ViewGroup | ||||||
| import android.widget.Button | import android.widget.Button | ||||||
| import android.widget.Toast | import android.widget.Toast | ||||||
| import apps.amine.bou.readerforselfoss.R | import apps.amine.bou.readerforselfoss.R | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Sources | import apps.amine.bou.readerforselfoss.api.selfoss.Source | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | ||||||
| import apps.amine.bou.readerforselfoss.utils.glide.circularBitmapDrawable | import apps.amine.bou.readerforselfoss.utils.glide.circularBitmapDrawable | ||||||
| import apps.amine.bou.readerforselfoss.utils.toTextDrawableString | import apps.amine.bou.readerforselfoss.utils.toTextDrawableString | ||||||
| @@ -23,7 +23,7 @@ import retrofit2.Response | |||||||
|  |  | ||||||
| class SourcesListAdapter( | class SourcesListAdapter( | ||||||
|     private val app: Activity, |     private val app: Activity, | ||||||
|     private val items: ArrayList<Sources>, |     private val items: ArrayList<Source>, | ||||||
|     private val api: SelfossApi |     private val api: SelfossApi | ||||||
| ) : RecyclerView.Adapter<SourcesListAdapter.ViewHolder>() { | ) : RecyclerView.Adapter<SourcesListAdapter.ViewHolder>() { | ||||||
|     private val c: Context = app.baseContext |     private val c: Context = app.baseContext | ||||||
| @@ -48,7 +48,7 @@ class SourcesListAdapter( | |||||||
|                 TextDrawable |                 TextDrawable | ||||||
|                     .builder() |                     .builder() | ||||||
|                     .round() |                     .round() | ||||||
|                     .build(itm.title.toTextDrawableString(), color) |                     .build(itm.title.toTextDrawableString(c), color) | ||||||
|             holder.mView.itemImage.setImageDrawable(drawable) |             holder.mView.itemImage.setImageDrawable(drawable) | ||||||
|         } else { |         } else { | ||||||
|             c.circularBitmapDrawable(itm.getIcon(c), holder.mView.itemImage) |             c.circularBitmapDrawable(itm.getIcon(c), holder.mView.itemImage) | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ import retrofit2.Call | |||||||
| import retrofit2.Retrofit | import retrofit2.Retrofit | ||||||
| import retrofit2.converter.gson.GsonConverterFactory | import retrofit2.converter.gson.GsonConverterFactory | ||||||
|  |  | ||||||
| class MercuryApi(private val key: String, shouldLog: Boolean) { | class MercuryApi(shouldLog: Boolean) { | ||||||
|     private val service: MercuryService |     private val service: MercuryService | ||||||
|  |  | ||||||
|     init { |     init { | ||||||
| @@ -26,7 +26,7 @@ class MercuryApi(private val key: String, shouldLog: Boolean) { | |||||||
|         val retrofit = |         val retrofit = | ||||||
|             Retrofit |             Retrofit | ||||||
|                 .Builder() |                 .Builder() | ||||||
|                 .baseUrl("https://mercury.postlight.com") |                 .baseUrl("https://www.amine-bou.fr") | ||||||
|                 .client(client) |                 .client(client) | ||||||
|                 .addConverterFactory(GsonConverterFactory.create(gson)) |                 .addConverterFactory(GsonConverterFactory.create(gson)) | ||||||
|                 .build() |                 .build() | ||||||
| @@ -34,6 +34,6 @@ class MercuryApi(private val key: String, shouldLog: Boolean) { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     fun parseUrl(url: String): Call<ParsedContent> { |     fun parseUrl(url: String): Call<ParsedContent> { | ||||||
|         return service.parseUrl(url, this.key) |         return service.parseUrl(url) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -6,6 +6,6 @@ import retrofit2.http.Header | |||||||
| import retrofit2.http.Query | import retrofit2.http.Query | ||||||
|  |  | ||||||
| interface MercuryService { | interface MercuryService { | ||||||
|     @GET("parser") |     @GET("parser.php") | ||||||
|     fun parseUrl(@Query("url") url: String, @Header("x-api-key") key: String): Call<ParsedContent> |     fun parseUrl(@Query("link") link: String): Call<ParsedContent> | ||||||
| } | } | ||||||
|   | |||||||
| @@ -125,6 +125,9 @@ class SelfossApi( | |||||||
|     ): Call<List<Item>> = |     ): Call<List<Item>> = | ||||||
|         getItems("starred", tag, sourceId, search, itemsNumber, offset) |         getItems("starred", tag, sourceId, search, itemsNumber, offset) | ||||||
|  |  | ||||||
|  |     fun allItems(): Call<List<Item>> = | ||||||
|  |         service.allItems(userName, password) | ||||||
|  |  | ||||||
|     private fun getItems( |     private fun getItems( | ||||||
|         type: String, |         type: String, | ||||||
|         tag: String?, |         tag: String?, | ||||||
| @@ -159,7 +162,7 @@ class SelfossApi( | |||||||
|     fun update(): Call<String> = |     fun update(): Call<String> = | ||||||
|         service.update(userName, password) |         service.update(userName, password) | ||||||
|  |  | ||||||
|     val sources: Call<List<Sources>> |     val sources: Call<List<Source>> | ||||||
|         get() = service.sources(userName, password) |         get() = service.sources(userName, password) | ||||||
|  |  | ||||||
|     fun deleteSource(id: String): Call<SuccessResponse> = |     fun deleteSource(id: String): Call<SuccessResponse> = | ||||||
|   | |||||||
| @@ -42,7 +42,7 @@ data class Spout( | |||||||
|     @SerializedName("description") val description: String |     @SerializedName("description") val description: String | ||||||
| ) | ) | ||||||
|  |  | ||||||
| data class Sources( | data class Source( | ||||||
|     @SerializedName("id") val id: String, |     @SerializedName("id") val id: String, | ||||||
|     @SerializedName("title") val title: String, |     @SerializedName("title") val title: String, | ||||||
|     @SerializedName("tags") val tags: String, |     @SerializedName("tags") val tags: String, | ||||||
|   | |||||||
| @@ -27,6 +27,12 @@ internal interface SelfossService { | |||||||
|         @Query("offset") offset: Int |         @Query("offset") offset: Int | ||||||
|     ): Call<List<Item>> |     ): Call<List<Item>> | ||||||
|  |  | ||||||
|  |     @GET("items") | ||||||
|  |     fun allItems( | ||||||
|  |         @Query("username") username: String, | ||||||
|  |         @Query("password") password: String | ||||||
|  |     ): Call<List<Item>> | ||||||
|  |  | ||||||
|     @Headers("Content-Type: application/x-www-form-urlencoded") |     @Headers("Content-Type: application/x-www-form-urlencoded") | ||||||
|     @POST("mark/{id}") |     @POST("mark/{id}") | ||||||
|     fun markAsRead( |     fun markAsRead( | ||||||
| @@ -95,7 +101,7 @@ internal interface SelfossService { | |||||||
|     fun sources( |     fun sources( | ||||||
|         @Query("username") username: String, |         @Query("username") username: String, | ||||||
|         @Query("password") password: String |         @Query("password") password: String | ||||||
|     ): Call<List<Sources>> |     ): Call<List<Source>> | ||||||
|  |  | ||||||
|     @DELETE("source/{id}") |     @DELETE("source/{id}") | ||||||
|     fun deleteSource( |     fun deleteSource( | ||||||
|   | |||||||
| @@ -1,44 +1,44 @@ | |||||||
| package apps.amine.bou.readerforselfoss.fragments | package apps.amine.bou.readerforselfoss.fragments | ||||||
|  |  | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent |  | ||||||
| import android.content.SharedPreferences | import android.content.SharedPreferences | ||||||
| import android.content.res.ColorStateList | import android.content.res.ColorStateList | ||||||
| import android.graphics.drawable.ColorDrawable | import android.graphics.drawable.ColorDrawable | ||||||
| import android.net.Uri |  | ||||||
| import android.os.Build | import android.os.Build | ||||||
| import android.os.Bundle | import android.os.Bundle | ||||||
| import android.preference.PreferenceManager | import android.preference.PreferenceManager | ||||||
| import android.support.customtabs.CustomTabsIntent | import androidx.browser.customtabs.CustomTabsIntent | ||||||
| import android.support.design.widget.FloatingActionButton | import com.google.android.material.floatingactionbutton.FloatingActionButton | ||||||
| import android.support.v4.app.Fragment | import androidx.fragment.app.Fragment | ||||||
| import android.support.v4.content.ContextCompat | import androidx.core.content.ContextCompat | ||||||
| import android.support.v4.widget.NestedScrollView | import androidx.core.widget.NestedScrollView | ||||||
| import android.support.v7.app.AlertDialog |  | ||||||
| import android.view.LayoutInflater | import android.view.LayoutInflater | ||||||
| import android.view.MenuItem | import android.view.MenuItem | ||||||
| import android.view.View | import android.view.View | ||||||
| import android.view.ViewGroup | import android.view.ViewGroup | ||||||
| import android.webkit.WebSettings | import android.webkit.WebSettings | ||||||
| import apps.amine.bou.readerforselfoss.BuildConfig |  | ||||||
| import apps.amine.bou.readerforselfoss.R | import apps.amine.bou.readerforselfoss.R | ||||||
| import apps.amine.bou.readerforselfoss.api.mercury.MercuryApi | import apps.amine.bou.readerforselfoss.api.mercury.MercuryApi | ||||||
| import apps.amine.bou.readerforselfoss.api.mercury.ParsedContent | import apps.amine.bou.readerforselfoss.api.mercury.ParsedContent | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Item | import apps.amine.bou.readerforselfoss.api.selfoss.Item | ||||||
|  | import apps.amine.bou.readerforselfoss.api.selfoss.SelfossApi | ||||||
|  | import apps.amine.bou.readerforselfoss.api.selfoss.SuccessResponse | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors | import apps.amine.bou.readerforselfoss.themes.AppColors | ||||||
|  | import apps.amine.bou.readerforselfoss.utils.Config | ||||||
| import apps.amine.bou.readerforselfoss.utils.buildCustomTabsIntent | import apps.amine.bou.readerforselfoss.utils.buildCustomTabsIntent | ||||||
| import apps.amine.bou.readerforselfoss.utils.customtabs.CustomTabActivityHelper | import apps.amine.bou.readerforselfoss.utils.customtabs.CustomTabActivityHelper | ||||||
| import apps.amine.bou.readerforselfoss.utils.isEmptyOrNullOrNullString | import apps.amine.bou.readerforselfoss.utils.isEmptyOrNullOrNullString | ||||||
|  | import apps.amine.bou.readerforselfoss.utils.maybeHandleSilentException | ||||||
| import apps.amine.bou.readerforselfoss.utils.openItemUrl | import apps.amine.bou.readerforselfoss.utils.openItemUrl | ||||||
| import apps.amine.bou.readerforselfoss.utils.shareLink | import apps.amine.bou.readerforselfoss.utils.shareLink | ||||||
| import apps.amine.bou.readerforselfoss.utils.sourceAndDateText | import apps.amine.bou.readerforselfoss.utils.sourceAndDateText | ||||||
|  | import apps.amine.bou.readerforselfoss.utils.succeeded | ||||||
| import apps.amine.bou.readerforselfoss.utils.toPx | import apps.amine.bou.readerforselfoss.utils.toPx | ||||||
| import com.bumptech.glide.Glide | import com.bumptech.glide.Glide | ||||||
| import com.bumptech.glide.request.RequestOptions | import com.bumptech.glide.request.RequestOptions | ||||||
| import com.crashlytics.android.Crashlytics |  | ||||||
| import com.ftinc.scoop.Scoop |  | ||||||
| import com.github.rubensousa.floatingtoolbar.FloatingToolbar | import com.github.rubensousa.floatingtoolbar.FloatingToolbar | ||||||
| import kotlinx.android.synthetic.main.fragment_article.view.* | import kotlinx.android.synthetic.main.fragment_article.view.* | ||||||
|  | import org.acra.ACRA | ||||||
| import retrofit2.Call | import retrofit2.Call | ||||||
| import retrofit2.Callback | import retrofit2.Callback | ||||||
| import retrofit2.Response | import retrofit2.Response | ||||||
| @@ -55,7 +55,6 @@ class ArticleFragment : Fragment() { | |||||||
|     private lateinit var contentSource: String |     private lateinit var contentSource: String | ||||||
|     private lateinit var contentImage: String |     private lateinit var contentImage: String | ||||||
|     private lateinit var contentTitle: String |     private lateinit var contentTitle: String | ||||||
|     private var showMalformedUrl: Boolean = false |  | ||||||
|     private lateinit var editor: SharedPreferences.Editor |     private lateinit var editor: SharedPreferences.Editor | ||||||
|     private lateinit var fab: FloatingActionButton |     private lateinit var fab: FloatingActionButton | ||||||
|     private lateinit var appColors: AppColors |     private lateinit var appColors: AppColors | ||||||
| @@ -85,14 +84,26 @@ class ArticleFragment : Fragment() { | |||||||
|         rootView = inflater |         rootView = inflater | ||||||
|             .inflate(R.layout.fragment_article, container, false) as ViewGroup |             .inflate(R.layout.fragment_article, container, false) as ViewGroup | ||||||
|  |  | ||||||
|         val context: Context = activity!! |  | ||||||
|  |  | ||||||
|         url = allItems[pageNumber.toInt()].getLinkDecoded() |         url = allItems[pageNumber.toInt()].getLinkDecoded() | ||||||
|         contentText = allItems[pageNumber.toInt()].content |         contentText = allItems[pageNumber.toInt()].content | ||||||
|         contentTitle = allItems[pageNumber.toInt()].title |         contentTitle = allItems[pageNumber.toInt()].title | ||||||
|         contentImage = allItems[pageNumber.toInt()].getThumbnail(activity!!) |         contentImage = allItems[pageNumber.toInt()].getThumbnail(activity!!) | ||||||
|         contentSource = allItems[pageNumber.toInt()].sourceAndDateText() |         contentSource = allItems[pageNumber.toInt()].sourceAndDateText() | ||||||
|  |  | ||||||
|  |         val prefs = PreferenceManager.getDefaultSharedPreferences(activity) | ||||||
|  |         editor = prefs.edit() | ||||||
|  |         fontSize = prefs.getString("reader_font_size", "14").toInt() | ||||||
|  |  | ||||||
|  |         val settings = activity!!.getSharedPreferences(Config.settingsName, Context.MODE_PRIVATE) | ||||||
|  |         val debugReadingItems = prefs.getBoolean("read_debug", false) | ||||||
|  |  | ||||||
|  |         val api = SelfossApi( | ||||||
|  |             context!!, | ||||||
|  |             activity!!, | ||||||
|  |             settings.getBoolean("isSelfSignedCert", false), | ||||||
|  |             prefs.getBoolean("should_log_everything", false) | ||||||
|  |         ) | ||||||
|  |  | ||||||
|         fab = rootView.fab |         fab = rootView.fab | ||||||
|  |  | ||||||
|         fab.backgroundTintList = ColorStateList.valueOf(appColors.colorAccent) |         fab.backgroundTintList = ColorStateList.valueOf(appColors.colorAccent) | ||||||
| @@ -108,17 +119,12 @@ class ArticleFragment : Fragment() { | |||||||
|         mCustomTabActivityHelper = CustomTabActivityHelper() |         mCustomTabActivityHelper = CustomTabActivityHelper() | ||||||
|         mCustomTabActivityHelper.bindCustomTabsService(activity) |         mCustomTabActivityHelper.bindCustomTabsService(activity) | ||||||
|  |  | ||||||
|         val prefs = PreferenceManager.getDefaultSharedPreferences(activity) |  | ||||||
|         editor = prefs.edit() |  | ||||||
|         fontSize = prefs.getString("reader_font_size", "14").toInt() |  | ||||||
|         showMalformedUrl = prefs.getBoolean("show_error_malformed_url", true) |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         floatingToolbar.setClickListener( |         floatingToolbar.setClickListener( | ||||||
|             object : FloatingToolbar.ItemClickListener { |             object : FloatingToolbar.ItemClickListener { | ||||||
|                 override fun onItemClick(item: MenuItem) { |                 override fun onItemClick(item: MenuItem) { | ||||||
|                     when (item.itemId) { |                     when (item.itemId) { | ||||||
|                         R.id.more_action -> getContentFromMercury(customTabsIntent, prefs, context) |                         R.id.more_action -> getContentFromMercury(customTabsIntent, prefs) | ||||||
|                         R.id.share_action -> activity!!.shareLink(url) |                         R.id.share_action -> activity!!.shareLink(url) | ||||||
|                         R.id.open_action -> activity!!.openItemUrl( |                         R.id.open_action -> activity!!.openItemUrl( | ||||||
|                             allItems, |                             allItems, | ||||||
| @@ -129,6 +135,35 @@ class ArticleFragment : Fragment() { | |||||||
|                             false, |                             false, | ||||||
|                             activity!! |                             activity!! | ||||||
|                         ) |                         ) | ||||||
|  |                         R.id.unread_action -> api.unmarkItem(allItems[pageNumber.toInt()].id).enqueue( | ||||||
|  |                             object : Callback<SuccessResponse> { | ||||||
|  |                                 override fun onResponse( | ||||||
|  |                                     call: Call<SuccessResponse>, | ||||||
|  |                                     response: Response<SuccessResponse> | ||||||
|  |                                 ) { | ||||||
|  |                                     if (!response.succeeded() && debugReadingItems) { | ||||||
|  |                                         val message = | ||||||
|  |                                             "message: ${response.message()} " + | ||||||
|  |                                                     "response isSuccess: ${response.isSuccessful} " + | ||||||
|  |                                                     "response code: ${response.code()} " + | ||||||
|  |                                                     "response message: ${response.message()} " + | ||||||
|  |                                                     "response errorBody: ${response.errorBody()?.string()} " + | ||||||
|  |                                                     "body success: ${response.body()?.success} " + | ||||||
|  |                                                     "body isSuccess: ${response.body()?.isSuccess}" | ||||||
|  |                                         ACRA.getErrorReporter().maybeHandleSilentException(Exception(message), activity!!) | ||||||
|  |                                     } | ||||||
|  |                                 } | ||||||
|  |  | ||||||
|  |                                 override fun onFailure( | ||||||
|  |                                     call: Call<SuccessResponse>, | ||||||
|  |                                     t: Throwable | ||||||
|  |                                 ) { | ||||||
|  |                                     if (debugReadingItems) { | ||||||
|  |                                         ACRA.getErrorReporter().maybeHandleSilentException(t, activity!!) | ||||||
|  |                                     } | ||||||
|  |                                 } | ||||||
|  |                             } | ||||||
|  |                         ) | ||||||
|                         else -> Unit |                         else -> Unit | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -141,16 +176,16 @@ class ArticleFragment : Fragment() { | |||||||
|         rootView.source.text = contentSource |         rootView.source.text = contentSource | ||||||
|  |  | ||||||
|         if (contentText.isEmptyOrNullOrNullString()) { |         if (contentText.isEmptyOrNullOrNullString()) { | ||||||
|             getContentFromMercury(customTabsIntent, prefs, context) |             getContentFromMercury(customTabsIntent, prefs) | ||||||
|         } else { |         } else { | ||||||
|             rootView.titleView.text = contentTitle |             rootView.titleView.text = contentTitle | ||||||
|  |  | ||||||
|             htmlToWebview(contentText, prefs, context) |             htmlToWebview(contentText, prefs) | ||||||
|  |  | ||||||
|             if (!contentImage.isEmptyOrNullOrNullString()) { |             if (!contentImage.isEmptyOrNullOrNullString() && context != null) { | ||||||
|                 rootView.imageView.visibility = View.VISIBLE |                 rootView.imageView.visibility = View.VISIBLE | ||||||
|                 Glide |                 Glide | ||||||
|                     .with(context) |                     .with(context!!) | ||||||
|                     .asBitmap() |                     .asBitmap() | ||||||
|                     .load(contentImage) |                     .load(contentImage) | ||||||
|                     .apply(RequestOptions.fitCenterTransform()) |                     .apply(RequestOptions.fitCenterTransform()) | ||||||
| @@ -175,12 +210,10 @@ class ArticleFragment : Fragment() { | |||||||
|  |  | ||||||
|     private fun getContentFromMercury( |     private fun getContentFromMercury( | ||||||
|         customTabsIntent: CustomTabsIntent, |         customTabsIntent: CustomTabsIntent, | ||||||
|         prefs: SharedPreferences, |         prefs: SharedPreferences | ||||||
|         context: Context |  | ||||||
|     ) { |     ) { | ||||||
|         rootView.progressBar.visibility = View.VISIBLE |         rootView.progressBar.visibility = View.VISIBLE | ||||||
|         val parser = MercuryApi( |         val parser = MercuryApi( | ||||||
|             BuildConfig.MERCURY_KEY, |  | ||||||
|             prefs.getBoolean("should_log_everything", false) |             prefs.getBoolean("should_log_everything", false) | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
| @@ -195,64 +228,47 @@ class ArticleFragment : Fragment() { | |||||||
|                         if (response.body() != null && response.body()!!.content != null && !response.body()!!.content.isNullOrEmpty()) { |                         if (response.body() != null && response.body()!!.content != null && !response.body()!!.content.isNullOrEmpty()) { | ||||||
|                             try { |                             try { | ||||||
|                                 rootView.titleView.text = response.body()!!.title |                                 rootView.titleView.text = response.body()!!.title | ||||||
|                                 url = response.body()!!.url |                                 try { | ||||||
|  |                                     // Note: Mercury may return relative urls... If it does the url val will not be changed. | ||||||
|  |                                     URL(response.body()!!.url) | ||||||
|  |                                     url = response.body()!!.url | ||||||
|  |                                 } catch (e: MalformedURLException) { | ||||||
|  |                                     ACRA.getErrorReporter().maybeHandleSilentException(e, activity!!) | ||||||
|  |                                 } | ||||||
|                             } catch (e: Exception) { |                             } catch (e: Exception) { | ||||||
|                                 Crashlytics.setUserIdentifier(prefs.getString("unique_id", "")) |                                 if (context != null) { | ||||||
|                                 Crashlytics.log( |                                     ACRA.getErrorReporter().maybeHandleSilentException(e, context!!) | ||||||
|                                     100, |                                 } | ||||||
|                                     "MERCURY_CONTENT_EXCEPTION", |  | ||||||
|                                     "source titleView or url issues" |  | ||||||
|                                 ) |  | ||||||
|                                 Crashlytics.logException(e) |  | ||||||
|                             } |                             } | ||||||
|  |  | ||||||
|                             try { |                             try { | ||||||
|                                 htmlToWebview(response.body()!!.content.orEmpty(), prefs, context) |                                 htmlToWebview(response.body()!!.content.orEmpty(), prefs) | ||||||
|                             } catch (e: Exception) { |                             } catch (e: Exception) { | ||||||
|                                 Crashlytics.setUserIdentifier(prefs.getString("unique_id", "")) |                                 if (context != null) { | ||||||
|                                 Crashlytics.log( |                                     ACRA.getErrorReporter().maybeHandleSilentException(e, context!!) | ||||||
|                                     100, |                                 } | ||||||
|                                     "MERCURY_CONTENT_EXCEPTION", |  | ||||||
|                                     "Webview issue ${e.message}" |  | ||||||
|                                 ) |  | ||||||
|                                 Crashlytics.logException(e) |  | ||||||
|                             } |                             } | ||||||
|  |  | ||||||
|                             try { |                             try { | ||||||
|                                 if (response.body()!!.lead_image_url != null && !response.body()!!.lead_image_url.isNullOrEmpty()) { |                                 if (response.body()!!.lead_image_url != null && !response.body()!!.lead_image_url.isNullOrEmpty() && context != null) { | ||||||
|                                     rootView.imageView.visibility = View.VISIBLE |                                     rootView.imageView.visibility = View.VISIBLE | ||||||
|                                     try { |                                     try { | ||||||
|                                         Glide |                                         Glide | ||||||
|                                             .with(context) |                                             .with(context!!) | ||||||
|                                             .asBitmap() |                                             .asBitmap() | ||||||
|                                             .load(response.body()!!.lead_image_url) |                                             .load(response.body()!!.lead_image_url) | ||||||
|                                             .apply(RequestOptions.fitCenterTransform()) |                                             .apply(RequestOptions.fitCenterTransform()) | ||||||
|                                             .into(rootView.imageView) |                                             .into(rootView.imageView) | ||||||
|                                     } catch (e: Exception) { |                                     } catch (e: Exception) { | ||||||
|                                         Crashlytics.setUserIdentifier( |                                         ACRA.getErrorReporter().maybeHandleSilentException(e, context!!) | ||||||
|                                             prefs.getString( |  | ||||||
|                                                 "unique_id", |  | ||||||
|                                                 "" |  | ||||||
|                                             ) |  | ||||||
|                                         ) |  | ||||||
|                                         Crashlytics.log( |  | ||||||
|                                             100, |  | ||||||
|                                             "MERCURY_CONTENT_EXCEPTION", |  | ||||||
|                                             "Glide issue with image ${response.body()!!.lead_image_url}" |  | ||||||
|                                         ) |  | ||||||
|                                         Crashlytics.logException(e) |  | ||||||
|                                     } |                                     } | ||||||
|                                 } else { |                                 } else { | ||||||
|                                     rootView.imageView.visibility = View.GONE |                                     rootView.imageView.visibility = View.GONE | ||||||
|                                 } |                                 } | ||||||
|                             } catch (e: Exception) { |                             } catch (e: Exception) { | ||||||
|                                 Crashlytics.setUserIdentifier(prefs.getString("unique_id", "")) |                                 if (context != null) { | ||||||
|                                 Crashlytics.log( |                                     ACRA.getErrorReporter().maybeHandleSilentException(e, context!!) | ||||||
|                                     100, |                                 } | ||||||
|                                     "MERCURY_CONTENT_EXCEPTION", |  | ||||||
|                                     "Glide or image issue" |  | ||||||
|                                 ) |  | ||||||
|                                 Crashlytics.logException(e) |  | ||||||
|                             } |                             } | ||||||
|  |  | ||||||
|                             try { |                             try { | ||||||
| @@ -260,35 +276,23 @@ class ArticleFragment : Fragment() { | |||||||
|  |  | ||||||
|                                 rootView.progressBar.visibility = View.GONE |                                 rootView.progressBar.visibility = View.GONE | ||||||
|                             } catch (e: Exception) { |                             } catch (e: Exception) { | ||||||
|                                 Crashlytics.setUserIdentifier(prefs.getString("unique_id", "")) |                                 if (context != null) { | ||||||
|                                 Crashlytics.log( |                                     ACRA.getErrorReporter().maybeHandleSilentException(e, context!!) | ||||||
|                                     100, |                                 } | ||||||
|                                     "MERCURY_CONTENT_EXCEPTION", |  | ||||||
|                                     "Scroll or visibility issues" |  | ||||||
|                                 ) |  | ||||||
|                                 Crashlytics.logException(e) |  | ||||||
|                             } |                             } | ||||||
|                         } else { |                         } else { | ||||||
|                             try { |                             try { | ||||||
|                                 openInBrowserAfterFailing(customTabsIntent) |                                 openInBrowserAfterFailing(customTabsIntent) | ||||||
|                             } catch (e: Exception) { |                             } catch (e: Exception) { | ||||||
|                                 Crashlytics.setUserIdentifier(prefs.getString("unique_id", "")) |                                 if (context != null) { | ||||||
|                                 Crashlytics.log( |                                     ACRA.getErrorReporter().maybeHandleSilentException(e, context!!) | ||||||
|                                     100, |                                 } | ||||||
|                                     "MERCURY_CONTENT_EXCEPTION", |  | ||||||
|                                     "Browser after failing issue" |  | ||||||
|                                 ) |  | ||||||
|                                 Crashlytics.logException(e) |  | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                     } catch (e: Exception) { |                     } catch (e: Exception) { | ||||||
|                         Crashlytics.setUserIdentifier(prefs.getString("unique_id", "")) |                         if (context != null) { | ||||||
|                         Crashlytics.log( |                             ACRA.getErrorReporter().maybeHandleSilentException(e, context!!) | ||||||
|                             100, |                         } | ||||||
|                             "MERCURY_CONTENT_EXCEPTION", |  | ||||||
|                             "UNCAUGHT (?) Fatal Exception on mercury response" |  | ||||||
|                         ) |  | ||||||
|                         Crashlytics.logException(e) |  | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
| @@ -300,31 +304,47 @@ class ArticleFragment : Fragment() { | |||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private fun htmlToWebview(c: String, prefs: SharedPreferences, context: Context) { |     private fun htmlToWebview(c: String, prefs: SharedPreferences) { | ||||||
|  |  | ||||||
|         val stringColor = String.format("#%06X", 0xFFFFFF and appColors.colorAccent) |         val stringColor = String.format("#%06X", 0xFFFFFF and appColors.colorAccent) | ||||||
|  |  | ||||||
|         rootView.webcontent.visibility = View.VISIBLE |         rootView.webcontent.visibility = View.VISIBLE | ||||||
|         val (textColor, backgroundColor) = if (appColors.isDarkTheme) { |         val (textColor, backgroundColor) = if (appColors.isDarkTheme) { | ||||||
|             rootView.webcontent.setBackgroundColor( |             if (context != null) { | ||||||
|                 ContextCompat.getColor( |                 rootView.webcontent.setBackgroundColor( | ||||||
|                     context, |                     ContextCompat.getColor( | ||||||
|                     R.color.dark_webview |                         context!!, | ||||||
|  |                         R.color.dark_webview | ||||||
|  |                     ) | ||||||
|                 ) |                 ) | ||||||
|             ) |                 Pair(ContextCompat.getColor(context!!, R.color.dark_webview_text), ContextCompat.getColor(context!!, R.color.light_webview_text)) | ||||||
|             Pair(ContextCompat.getColor(context, R.color.dark_webview_text), ContextCompat.getColor(context, R.color.light_webview_text)) |             } else { | ||||||
|  |                 Pair(null, null) | ||||||
|  |             } | ||||||
|         } else { |         } else { | ||||||
|             rootView.webcontent.setBackgroundColor( |             if (context != null) { | ||||||
|                 ContextCompat.getColor( |                 rootView.webcontent.setBackgroundColor( | ||||||
|                     context, |                     ContextCompat.getColor( | ||||||
|                     R.color.light_webview |                         context!!, | ||||||
|  |                         R.color.light_webview | ||||||
|  |                     ) | ||||||
|                 ) |                 ) | ||||||
|             ) |                 Pair(ContextCompat.getColor(context!!, R.color.light_webview_text), ContextCompat.getColor(context!!, R.color.dark_webview_text)) | ||||||
|             Pair(ContextCompat.getColor(context, R.color.light_webview_text), ContextCompat.getColor(context, R.color.dark_webview_text)) |             } else { | ||||||
|  |                 Pair(null, null) | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         val stringTextColor = String.format("#%06X", 0xFFFFFF and textColor) |         val stringTextColor: String = if (textColor != null) { | ||||||
|         val stringBackgroundColor = String.format("#%06X", 0xFFFFFF and backgroundColor) |             String.format("#%06X", 0xFFFFFF and textColor) | ||||||
|  |         } else { | ||||||
|  |             "#000000" | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         val stringBackgroundColor = if (backgroundColor != null) { | ||||||
|  |             String.format("#%06X", 0xFFFFFF and backgroundColor) | ||||||
|  |         } else { | ||||||
|  |             "#FFFFFF" | ||||||
|  |         } | ||||||
|  |  | ||||||
|         rootView.webcontent.settings.useWideViewPort = true |         rootView.webcontent.settings.useWideViewPort = true | ||||||
|         rootView.webcontent.settings.loadWithOverviewMode = true |         rootView.webcontent.settings.loadWithOverviewMode = true | ||||||
| @@ -343,76 +363,46 @@ class ArticleFragment : Fragment() { | |||||||
|             val itemUrl = URL(url) |             val itemUrl = URL(url) | ||||||
|             baseUrl = itemUrl.protocol + "://" + itemUrl.host |             baseUrl = itemUrl.protocol + "://" + itemUrl.host | ||||||
|         } catch (e: MalformedURLException) { |         } catch (e: MalformedURLException) { | ||||||
|             if (showMalformedUrl) { |             ACRA.getErrorReporter().maybeHandleSilentException(e, activity!!) | ||||||
|                 val alertDialog = AlertDialog.Builder(context).create() |  | ||||||
|                 alertDialog.setTitle("Error") |  | ||||||
|                 alertDialog.setMessage("You are encountering a bug that I can't solve. Can you please contact me to solve the issue, please ?") |  | ||||||
|                 alertDialog.setButton( |  | ||||||
|                     AlertDialog.BUTTON_POSITIVE, |  | ||||||
|                     "Send mail", |  | ||||||
|                     { dialog, _ -> |  | ||||||
|  |  | ||||||
|                         // This won't be translated because it should only be temporary. |  | ||||||
|                         val to = BuildConfig.FEEDBACK_EMAIL |  | ||||||
|                         val subject= "[MalformedURLException]" |  | ||||||
|                         val body= "Please specify the source, item and spout you are using for the url below : \n ${e.message}" |  | ||||||
|                         val mailTo = "mailto:" + to + "?&subject=" + Uri.encode(subject) + "&body=" + Uri.encode(body) |  | ||||||
|  |  | ||||||
|                         val emailIntent = Intent(Intent.ACTION_VIEW) |  | ||||||
|                         emailIntent.data = Uri.parse(mailTo) |  | ||||||
|                         startActivity(emailIntent) |  | ||||||
|  |  | ||||||
|                         dialog.dismiss() |  | ||||||
|                     } |  | ||||||
|                 ) |  | ||||||
|                 alertDialog.setButton( |  | ||||||
|                     AlertDialog.BUTTON_NEUTRAL, |  | ||||||
|                     "Not now", |  | ||||||
|                     { dialog, _ -> dialog.dismiss() } |  | ||||||
|                 ) |  | ||||||
|                 alertDialog.setButton( |  | ||||||
|                     AlertDialog.BUTTON_NEGATIVE, |  | ||||||
|                     "Don't show anymore.", |  | ||||||
|                     { dialog, _ -> |  | ||||||
|                         editor.putBoolean("show_error_malformed_url", false) |  | ||||||
|                         editor.apply() |  | ||||||
|                         dialog.dismiss() |  | ||||||
|                     } |  | ||||||
|                 ) |  | ||||||
|                 alertDialog.show() |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         rootView.webcontent.loadDataWithBaseURL( |         rootView.webcontent.loadDataWithBaseURL( | ||||||
|             baseUrl, |             baseUrl, | ||||||
|             """<style> |             """<html> | ||||||
|                 |img { |                 |<head> | ||||||
|                 |  display: inline-block; |                 |   <style> | ||||||
|                 |  height: auto; |                 |      img { | ||||||
|                 |  width: 100%; |                 |        display: inline-block; | ||||||
|                 |  max-width: 100%; |                 |        height: auto; | ||||||
|                 |} |                 |        width: 100%; | ||||||
|                 |a { |                 |        max-width: 100%; | ||||||
|                 |  color: $stringColor !important; |                 |      } | ||||||
|                 |} |                 |      a { | ||||||
|                 |*:not(a) { |                 |        color: $stringColor !important; | ||||||
|                 |  color: $stringTextColor; |                 |      } | ||||||
|                 |} |                 |      *:not(a) { | ||||||
|                 |* { |                 |        color: $stringTextColor; | ||||||
|                 |  font-size: ${fontSize.toPx}px; |                 |      } | ||||||
|                 |  text-align: justify; |                 |      * { | ||||||
|                 |  word-break: break-word; |                 |        font-size: ${fontSize.toPx}px; | ||||||
|                 |  overflow:hidden; |                 |        text-align: justify; | ||||||
|                 |} |                 |        word-break: break-word; | ||||||
|                 |a, pre, code { |                 |        overflow:hidden; | ||||||
|                 |  text-align: left; |                 |      } | ||||||
|                 |} |                 |      a, pre, code { | ||||||
|                 |pre, code { |                 |        text-align: left; | ||||||
|                 |  white-space: pre-wrap; |                 |      } | ||||||
|                 |  width:100%; |                 |      pre, code { | ||||||
|                 |  background-color: $stringBackgroundColor; |                 |        white-space: pre-wrap; | ||||||
|                 |}</style>$c""".trimMargin(), |                 |        width:100%; | ||||||
|             "text/html; charset=utf-8", |                 |        background-color: $stringBackgroundColor; | ||||||
|  |                 |      } | ||||||
|  |                 |   </style> | ||||||
|  |                 |</head> | ||||||
|  |                 |<body> | ||||||
|  |                 |   $c | ||||||
|  |                 |</body>""".trimMargin(), | ||||||
|  |             "text/html", | ||||||
|             "utf-8", |             "utf-8", | ||||||
|             null |             null | ||||||
|         ) |         ) | ||||||
|   | |||||||
| @@ -0,0 +1,36 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss.persistence.dao | ||||||
|  |  | ||||||
|  | import androidx.room.Delete | ||||||
|  | import androidx.room.Dao | ||||||
|  | import androidx.room.Insert | ||||||
|  | import androidx.room.OnConflictStrategy | ||||||
|  | import androidx.room.Query | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.entities.SourceEntity | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.entities.TagEntity | ||||||
|  |  | ||||||
|  | @Dao | ||||||
|  | interface DrawerDataDao { | ||||||
|  |     @Query("SELECT * FROM tags") | ||||||
|  |     fun tags(): List<TagEntity> | ||||||
|  |  | ||||||
|  |     @Query("SELECT * FROM sources") | ||||||
|  |     fun sources(): List<SourceEntity> | ||||||
|  |  | ||||||
|  |     @Insert(onConflict = OnConflictStrategy.REPLACE) | ||||||
|  |     fun insertAllTags(vararg tags: TagEntity) | ||||||
|  |  | ||||||
|  |     @Insert(onConflict = OnConflictStrategy.REPLACE) | ||||||
|  |     fun insertAllSources(vararg sources: SourceEntity) | ||||||
|  |  | ||||||
|  |     @Query("DELETE FROM tags") | ||||||
|  |     fun deleteAllTags() | ||||||
|  |  | ||||||
|  |     @Query("DELETE FROM sources") | ||||||
|  |     fun deleteAllSources() | ||||||
|  |  | ||||||
|  |     @Delete | ||||||
|  |     fun deleteTag(tag: TagEntity) | ||||||
|  |  | ||||||
|  |     @Delete | ||||||
|  |     fun deleteSource(source: SourceEntity) | ||||||
|  | } | ||||||
| @@ -0,0 +1,25 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss.persistence.dao | ||||||
|  |  | ||||||
|  | import androidx.room.Dao | ||||||
|  | import androidx.room.Insert | ||||||
|  | import androidx.room.OnConflictStrategy | ||||||
|  | import androidx.room.Query | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.entities.ItemEntity | ||||||
|  | import androidx.room.Update | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @Dao | ||||||
|  | interface ItemsDao { | ||||||
|  |     @Query("SELECT * FROM items") | ||||||
|  |     fun items(): List<ItemEntity> | ||||||
|  |  | ||||||
|  |     @Insert(onConflict = OnConflictStrategy.REPLACE) | ||||||
|  |     fun insertAllItems(vararg tags: ItemEntity) | ||||||
|  |  | ||||||
|  |     @Query("DELETE FROM items") | ||||||
|  |     fun deleteAllItems() | ||||||
|  |  | ||||||
|  |     @Update | ||||||
|  |     fun updateItem(item: ItemEntity) | ||||||
|  | } | ||||||
| @@ -0,0 +1,14 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss.persistence.database | ||||||
|  |  | ||||||
|  | import androidx.room.RoomDatabase | ||||||
|  | import androidx.room.Database | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.dao.DrawerDataDao | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.dao.ItemsDao | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.entities.ItemEntity | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.entities.SourceEntity | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.entities.TagEntity | ||||||
|  |  | ||||||
|  | @Database(entities = [TagEntity::class, SourceEntity::class], version = 1) | ||||||
|  | abstract class AppDatabase : RoomDatabase() { | ||||||
|  |     abstract fun drawerDataDao(): DrawerDataDao | ||||||
|  | } | ||||||
| @@ -0,0 +1,33 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss.persistence.entities | ||||||
|  |  | ||||||
|  | import androidx.room.ColumnInfo | ||||||
|  | import androidx.room.Entity | ||||||
|  | import androidx.room.PrimaryKey | ||||||
|  |  | ||||||
|  | @Entity(tableName = "tags") | ||||||
|  | data class TagEntity( | ||||||
|  |     @PrimaryKey | ||||||
|  |     @ColumnInfo(name = "tag") | ||||||
|  |     val tag: String, | ||||||
|  |     @ColumnInfo(name = "color") | ||||||
|  |     val color: String, | ||||||
|  |     @ColumnInfo(name = "unread") | ||||||
|  |     val unread: Int | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | @Entity(tableName = "sources") | ||||||
|  | data class SourceEntity( | ||||||
|  |     @PrimaryKey | ||||||
|  |     @ColumnInfo(name = "id") | ||||||
|  |     val id: String, | ||||||
|  |     @ColumnInfo(name = "title") | ||||||
|  |     val title: String, | ||||||
|  |     @ColumnInfo(name = "tags") | ||||||
|  |     val tags: String, | ||||||
|  |     @ColumnInfo(name = "spout") | ||||||
|  |     val spout: String, | ||||||
|  |     @ColumnInfo(name = "error") | ||||||
|  |     val error: String, | ||||||
|  |     @ColumnInfo(name = "icon") | ||||||
|  |     val icon: String | ||||||
|  | ) | ||||||
| @@ -0,0 +1,32 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss.persistence.entities | ||||||
|  |  | ||||||
|  | import androidx.room.ColumnInfo | ||||||
|  | import androidx.room.Entity | ||||||
|  | import androidx.room.PrimaryKey | ||||||
|  |  | ||||||
|  | @Entity(tableName = "items") | ||||||
|  | data class ItemEntity( | ||||||
|  |     @PrimaryKey | ||||||
|  |     @ColumnInfo(name = "id") | ||||||
|  |     val id: String, | ||||||
|  |     @ColumnInfo(name = "datetime") | ||||||
|  |     val datetime: String, | ||||||
|  |     @ColumnInfo(name = "title") | ||||||
|  |     val title: String, | ||||||
|  |     @ColumnInfo(name = "content") | ||||||
|  |     val content: String, | ||||||
|  |     @ColumnInfo(name = "unread") | ||||||
|  |     val unread: Boolean, | ||||||
|  |     @ColumnInfo(name = "starred") | ||||||
|  |     var starred: Boolean, | ||||||
|  |     @ColumnInfo(name = "thumbnail") | ||||||
|  |     val thumbnail: String, | ||||||
|  |     @ColumnInfo(name = "icon") | ||||||
|  |     val icon: String, | ||||||
|  |     @ColumnInfo(name = "link") | ||||||
|  |     val link: String, | ||||||
|  |     @ColumnInfo(name = "sourcetitle") | ||||||
|  |     val sourcetitle: String, | ||||||
|  |     @ColumnInfo(name = "tags") | ||||||
|  |     val tags: String | ||||||
|  | ) | ||||||
| @@ -1,15 +1,16 @@ | |||||||
| package apps.amine.bou.readerforselfoss.settings; | package apps.amine.bou.readerforselfoss.settings; | ||||||
|  |  | ||||||
| import android.content.res.Configuration; | import android.content.res.Configuration; | ||||||
|  | import android.os.Build; | ||||||
| import android.os.Bundle; | import android.os.Bundle; | ||||||
| import android.preference.PreferenceActivity; | import android.preference.PreferenceActivity; | ||||||
| import android.support.annotation.LayoutRes; | import androidx.annotation.LayoutRes; | ||||||
| import android.support.annotation.NonNull; | import androidx.annotation.NonNull; | ||||||
| import android.support.annotation.Nullable; | import androidx.annotation.Nullable; | ||||||
| import android.support.design.widget.AppBarLayout; | import com.google.android.material.appbar.AppBarLayout; | ||||||
| import android.support.v7.app.ActionBar; | import androidx.appcompat.app.ActionBar; | ||||||
| import android.support.v7.app.AppCompatDelegate; | import androidx.appcompat.app.AppCompatDelegate; | ||||||
| import android.support.v7.widget.Toolbar; | import androidx.appcompat.widget.Toolbar; | ||||||
| import android.view.LayoutInflater; | import android.view.LayoutInflater; | ||||||
| import android.view.MenuInflater; | import android.view.MenuInflater; | ||||||
| import android.view.View; | import android.view.View; | ||||||
| @@ -48,10 +49,11 @@ public abstract class AppCompatPreferenceActivity extends PreferenceActivity { | |||||||
|         AppBarLayout bar = (AppBarLayout) LayoutInflater.from(this).inflate(R.layout.settings_toolbar, root, false); |         AppBarLayout bar = (AppBarLayout) LayoutInflater.from(this).inflate(R.layout.settings_toolbar, root, false); | ||||||
|         Toolbar toolbar = bar.findViewById(R.id.toolbar); |         Toolbar toolbar = bar.findViewById(R.id.toolbar); | ||||||
|  |  | ||||||
|         // TODO: all switches |         Scoop scoop = Scoop.getInstance(); | ||||||
|         Scoop.getInstance() |         scoop.bind(this, Toppings.PRIMARY.getValue(), toolbar); | ||||||
|                 .bind(this, Toppings.PRIMARY.getValue(), toolbar) |         if  (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { | ||||||
|                 .bindStatusBar(this, Toppings.PRIMARY_DARK.getValue()); |             scoop.bindStatusBar(this, Toppings.PRIMARY_DARK.getValue()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         setSupportActionBar(toolbar); |         setSupportActionBar(toolbar); | ||||||
|         getSupportActionBar().setDisplayHomeAsUpEnabled(true); |         getSupportActionBar().setDisplayHomeAsUpEnabled(true); | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ import android.preference.PreferenceActivity; | |||||||
| import android.preference.PreferenceFragment; | import android.preference.PreferenceFragment; | ||||||
| import android.preference.PreferenceManager; | import android.preference.PreferenceManager; | ||||||
| import android.preference.SwitchPreference; | import android.preference.SwitchPreference; | ||||||
| import android.support.v7.app.ActionBar; | import androidx.appcompat.app.ActionBar; | ||||||
| import android.text.Editable; | import android.text.Editable; | ||||||
| import android.text.InputFilter; | import android.text.InputFilter; | ||||||
| import android.text.Spanned; | import android.text.Spanned; | ||||||
| @@ -29,11 +29,8 @@ import android.view.MenuInflater; | |||||||
| import android.view.MenuItem; | import android.view.MenuItem; | ||||||
| import android.widget.Toast; | import android.widget.Toast; | ||||||
|  |  | ||||||
| import com.ftinc.scoop.ui.ScoopSettingsActivity; |  | ||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import apps.amine.bou.readerforselfoss.BuildConfig; |  | ||||||
| import apps.amine.bou.readerforselfoss.R; | import apps.amine.bou.readerforselfoss.R; | ||||||
| import apps.amine.bou.readerforselfoss.themes.AppColors; | import apps.amine.bou.readerforselfoss.themes.AppColors; | ||||||
| import apps.amine.bou.readerforselfoss.utils.Config; | import apps.amine.bou.readerforselfoss.utils.Config; | ||||||
| @@ -155,17 +152,6 @@ public class SettingsActivity extends AppCompatPreferenceActivity { | |||||||
|             addPreferencesFromResource(R.xml.pref_general); |             addPreferencesFromResource(R.xml.pref_general); | ||||||
|             setHasOptionsMenu(true); |             setHasOptionsMenu(true); | ||||||
|  |  | ||||||
|             SwitchPreference cardViewActive = (SwitchPreference) findPreference("card_view_active"); |  | ||||||
|             final SwitchPreference tabOnTap = (SwitchPreference) findPreference("tab_on_tap"); |  | ||||||
|             tabOnTap.setEnabled(!cardViewActive.isChecked()); |  | ||||||
|             cardViewActive.setOnPreferenceChangeListener(new OnPreferenceChangeListener() { |  | ||||||
|                 public boolean onPreferenceChange(Preference preference, Object newValue) { |  | ||||||
|                     boolean isEnabled = (Boolean) newValue; |  | ||||||
|                     tabOnTap.setEnabled(!isEnabled); |  | ||||||
|                     return true; |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|  |  | ||||||
|             EditTextPreference itemsNumber = (EditTextPreference) findPreference("prefer_api_items_number"); |             EditTextPreference itemsNumber = (EditTextPreference) findPreference("prefer_api_items_number"); | ||||||
|             itemsNumber.getEditText().setFilters(new InputFilter[]{ |             itemsNumber.getEditText().setFilters(new InputFilter[]{ | ||||||
|                     new InputFilter() { |                     new InputFilter() { | ||||||
| @@ -183,6 +169,7 @@ public class SettingsActivity extends AppCompatPreferenceActivity { | |||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|             }); |             }); | ||||||
|  |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
| @@ -308,7 +295,7 @@ public class SettingsActivity extends AppCompatPreferenceActivity { | |||||||
|             findPreference("trackerLink").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() { |             findPreference("trackerLink").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() { | ||||||
|                 @Override |                 @Override | ||||||
|                 public boolean onPreferenceClick(Preference preference) { |                 public boolean onPreferenceClick(Preference preference) { | ||||||
|                     openUrl(Uri.parse(BuildConfig.TRACKER_URL)); |                     openUrl(Uri.parse(Config.trackerUrl)); | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
| @@ -316,7 +303,7 @@ public class SettingsActivity extends AppCompatPreferenceActivity { | |||||||
|             findPreference("sourceLink").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() { |             findPreference("sourceLink").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() { | ||||||
|                 @Override |                 @Override | ||||||
|                 public boolean onPreferenceClick(Preference preference) { |                 public boolean onPreferenceClick(Preference preference) { | ||||||
|                     openUrl(Uri.parse(BuildConfig.SOURCE_URL)); |                     openUrl(Uri.parse(Config.sourceUrl)); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
| @@ -324,7 +311,7 @@ public class SettingsActivity extends AppCompatPreferenceActivity { | |||||||
|             findPreference("translation").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() { |             findPreference("translation").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() { | ||||||
|                 @Override |                 @Override | ||||||
|                 public boolean onPreferenceClick(Preference preference) { |                 public boolean onPreferenceClick(Preference preference) { | ||||||
|                     openUrl(Uri.parse(BuildConfig.TRANSLATION_URL)); |                     openUrl(Uri.parse(Config.translationUrl)); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
|   | |||||||
| @@ -3,8 +3,8 @@ package apps.amine.bou.readerforselfoss.themes | |||||||
| import android.app.Activity | import android.app.Activity | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.preference.PreferenceManager | import android.preference.PreferenceManager | ||||||
| import android.support.annotation.ColorInt | import androidx.annotation.ColorInt | ||||||
| import android.support.v7.view.ContextThemeWrapper | import androidx.appcompat.view.ContextThemeWrapper | ||||||
| import android.util.TypedValue | import android.util.TypedValue | ||||||
| import apps.amine.bou.readerforselfoss.R | import apps.amine.bou.readerforselfoss.R | ||||||
| import android.view.LayoutInflater | import android.view.LayoutInflater | ||||||
| @@ -17,6 +17,7 @@ class AppColors(a: Activity) { | |||||||
|     @ColorInt val colorAccent: Int |     @ColorInt val colorAccent: Int | ||||||
|     @ColorInt val colorAccentDark: Int |     @ColorInt val colorAccentDark: Int | ||||||
|     @ColorInt val cardBackgroundColor: Int |     @ColorInt val cardBackgroundColor: Int | ||||||
|  |     @ColorInt val colorBackground: Int | ||||||
|     val isDarkTheme: Boolean |     val isDarkTheme: Boolean | ||||||
|  |  | ||||||
|     init { |     init { | ||||||
| @@ -48,10 +49,12 @@ class AppColors(a: Activity) { | |||||||
|                     false |                     false | ||||||
|                 ) |                 ) | ||||||
|  |  | ||||||
|         if (isDarkTheme) { |         colorBackground = if (isDarkTheme) { | ||||||
|             a.setTheme(R.style.NoBarDark) |             a.setTheme(R.style.NoBarDark) | ||||||
|  |             R.color.darkBackground | ||||||
|         } else { |         } else { | ||||||
|             a.setTheme(R.style.NoBar) |             a.setTheme(R.style.NoBar) | ||||||
|  |             android.R.color.background_light | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         val wrapper = Context::class.java |         val wrapper = Context::class.java | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| package apps.amine.bou.readerforselfoss.transformers | package apps.amine.bou.readerforselfoss.transformers | ||||||
|  |  | ||||||
| import android.support.v4.view.ViewPager | import androidx.viewpager.widget.ViewPager | ||||||
| import android.view.View | import android.view.View | ||||||
|  |  | ||||||
| class DepthPageTransformer : ViewPager.PageTransformer { | class DepthPageTransformer : ViewPager.PageTransformer { | ||||||
|   | |||||||
| @@ -0,0 +1,12 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss.utils | ||||||
|  |  | ||||||
|  | import android.content.Context | ||||||
|  | import android.preference.PreferenceManager | ||||||
|  | import org.acra.ErrorReporter | ||||||
|  |  | ||||||
|  | fun ErrorReporter.maybeHandleSilentException(throwable: Throwable, ctx: Context) { | ||||||
|  |     val sharedPref = PreferenceManager.getDefaultSharedPreferences(ctx) | ||||||
|  |     if (sharedPref.getBoolean("acra_should_log", false)) { | ||||||
|  |         this.handleSilentException(throwable) | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -2,60 +2,11 @@ package apps.amine.bou.readerforselfoss.utils | |||||||
|  |  | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.content.SharedPreferences |  | ||||||
| import android.net.Uri |  | ||||||
| import android.support.v7.app.AlertDialog |  | ||||||
| import apps.amine.bou.readerforselfoss.R | import apps.amine.bou.readerforselfoss.R | ||||||
| import com.google.firebase.remoteconfig.FirebaseRemoteConfig |  | ||||||
|  |  | ||||||
| fun String?.isEmptyOrNullOrNullString(): Boolean = | fun String?.isEmptyOrNullOrNullString(): Boolean = | ||||||
|     this == null || this == "null" || this.isEmpty() |     this == null || this == "null" || this.isEmpty() | ||||||
|  |  | ||||||
| fun Context.checkApkVersion( |  | ||||||
|     settings: SharedPreferences, |  | ||||||
|     editor: SharedPreferences.Editor, |  | ||||||
|     mFirebaseRemoteConfig: FirebaseRemoteConfig |  | ||||||
| ) = { |  | ||||||
|     fun isThereAnUpdate() { |  | ||||||
|         val APK_LINK = "github_apk" |  | ||||||
|  |  | ||||||
|         val apkLink = mFirebaseRemoteConfig.getString(APK_LINK) |  | ||||||
|         val storedLink = settings.getString(APK_LINK, "") |  | ||||||
|         if (apkLink != storedLink && !apkLink.isEmpty()) { |  | ||||||
|             val alertDialog = AlertDialog.Builder(this).create() |  | ||||||
|             alertDialog.setTitle(getString(R.string.new_apk_available_title)) |  | ||||||
|             alertDialog.setMessage(getString(R.string.new_apk_available_message)) |  | ||||||
|             alertDialog.setButton( |  | ||||||
|                 AlertDialog.BUTTON_POSITIVE, |  | ||||||
|                 getString(R.string.new_apk_available_get) |  | ||||||
|             ) { _, _ -> |  | ||||||
|                 editor.putString(APK_LINK, apkLink) |  | ||||||
|                 editor.apply() |  | ||||||
|                 val browserIntent = Intent(Intent.ACTION_VIEW, Uri.parse(apkLink)) |  | ||||||
|                 startActivity(browserIntent) |  | ||||||
|             } |  | ||||||
|             alertDialog.setButton( |  | ||||||
|                 AlertDialog.BUTTON_NEUTRAL, getString(R.string.new_apk_available_no), |  | ||||||
|                 { dialog, _ -> |  | ||||||
|                     editor.putString(APK_LINK, apkLink) |  | ||||||
|                     editor.apply() |  | ||||||
|                     dialog.dismiss() |  | ||||||
|                 } |  | ||||||
|             ) |  | ||||||
|             alertDialog.show() |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     mFirebaseRemoteConfig.fetch(43200) |  | ||||||
|         .addOnCompleteListener { task -> |  | ||||||
|             if (task.isSuccessful) { |  | ||||||
|                 mFirebaseRemoteConfig.activateFetched() |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             isThereAnUpdate() |  | ||||||
|         } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fun String.longHash(): Long { | fun String.longHash(): Long { | ||||||
|     var h = 98764321261L |     var h = 98764321261L | ||||||
|     val l = this.length |     val l = this.length | ||||||
|   | |||||||
| @@ -28,6 +28,14 @@ class Config(c: Context) { | |||||||
|     companion object { |     companion object { | ||||||
|         const val settingsName = "paramsselfoss" |         const val settingsName = "paramsselfoss" | ||||||
|  |  | ||||||
|  |         const val feedbackEmail = "aminecmi@gmail.com" | ||||||
|  |  | ||||||
|  |         const val translationUrl = "https://crwd.in/readerforselfoss" | ||||||
|  |  | ||||||
|  |         const val sourceUrl = "https://github.com/aminecmi/ReaderforSelfoss" | ||||||
|  |  | ||||||
|  |         const val trackerUrl = "https://github.com/aminecmi/ReaderforSelfoss/issues" | ||||||
|  |  | ||||||
|         fun logoutAndRedirect( |         fun logoutAndRedirect( | ||||||
|             c: Context, |             c: Context, | ||||||
|             callingActivity: Activity, |             callingActivity: Activity, | ||||||
|   | |||||||
| @@ -1,24 +1,20 @@ | |||||||
| package apps.amine.bou.readerforselfoss.utils | package apps.amine.bou.readerforselfoss.utils | ||||||
|  |  | ||||||
|  | import android.content.Context | ||||||
| import android.text.format.DateUtils | import android.text.format.DateUtils | ||||||
| import apps.amine.bou.readerforselfoss.api.selfoss.Item | import apps.amine.bou.readerforselfoss.api.selfoss.Item | ||||||
| import com.crashlytics.android.Crashlytics | import org.acra.ACRA | ||||||
| import java.text.ParseException | import java.text.ParseException | ||||||
| import java.text.SimpleDateFormat | import java.text.SimpleDateFormat | ||||||
| import java.util.* | import java.util.* | ||||||
|  |  | ||||||
| fun String.toTextDrawableString(): String { | fun String.toTextDrawableString(c: Context): String { | ||||||
|     val textDrawable = StringBuilder() |     val textDrawable = StringBuilder() | ||||||
|     for (s in this.split(" ".toRegex()).filter { !it.isEmpty() }.toTypedArray()) { |     for (s in this.split(" ".toRegex()).filter { !it.isEmpty() }.toTypedArray()) { | ||||||
|         try { |         try { | ||||||
|             textDrawable.append(s[0]) |             textDrawable.append(s[0]) | ||||||
|         } catch (e: StringIndexOutOfBoundsException) { |         } catch (e: StringIndexOutOfBoundsException) { | ||||||
|             Crashlytics.log( |             ACRA.getErrorReporter().maybeHandleSilentException(e, c) | ||||||
|                 100, |  | ||||||
|                 "TEXT_DRAWABLE_INDEX_OUT_OF_BOUND", |  | ||||||
|                 this + " produces ${e.message}" |  | ||||||
|             ) |  | ||||||
|             Crashlytics.logException(e) |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     return textDrawable.toString() |     return textDrawable.toString() | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import android.content.Context | |||||||
| import android.content.Intent | import android.content.Intent | ||||||
| import android.graphics.BitmapFactory | import android.graphics.BitmapFactory | ||||||
| import android.net.Uri | import android.net.Uri | ||||||
| import android.support.customtabs.CustomTabsIntent | import androidx.browser.customtabs.CustomTabsIntent | ||||||
| import android.util.Patterns | import android.util.Patterns | ||||||
| import android.widget.Toast | import android.widget.Toast | ||||||
| import apps.amine.bou.readerforselfoss.R | import apps.amine.bou.readerforselfoss.R | ||||||
|   | |||||||
| @@ -1,54 +0,0 @@ | |||||||
| package apps.amine.bou.readerforselfoss.utils |  | ||||||
|  |  | ||||||
| import android.content.Context |  | ||||||
| import android.support.design.widget.CoordinatorLayout |  | ||||||
| import android.support.design.widget.FloatingActionButton |  | ||||||
| import android.util.AttributeSet |  | ||||||
| import android.view.View |  | ||||||
|  |  | ||||||
| class ScrollAwareFABBehavior( |  | ||||||
|     context: Context, |  | ||||||
|     attrs: AttributeSet |  | ||||||
| ) : CoordinatorLayout.Behavior<FloatingActionButton>() { |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     override fun onStartNestedScroll( |  | ||||||
|         coordinatorLayout: CoordinatorLayout, |  | ||||||
|         child: FloatingActionButton, |  | ||||||
|         directTargetChild: View, |  | ||||||
|         target: View, |  | ||||||
|         nestedScrollAxes: Int |  | ||||||
|     ): Boolean { |  | ||||||
|         return true |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     override fun onNestedScroll( |  | ||||||
|         coordinatorLayout: CoordinatorLayout, |  | ||||||
|         child: FloatingActionButton, |  | ||||||
|         target: View, |  | ||||||
|         dxConsumed: Int, |  | ||||||
|         dyConsumed: Int, |  | ||||||
|         dxUnconsumed: Int, |  | ||||||
|         dyUnconsumed: Int |  | ||||||
|     ) { |  | ||||||
|         super.onNestedScroll( |  | ||||||
|             coordinatorLayout, |  | ||||||
|             child, |  | ||||||
|             target, |  | ||||||
|             dxConsumed, |  | ||||||
|             dyConsumed, |  | ||||||
|             dxUnconsumed, |  | ||||||
|             dyUnconsumed |  | ||||||
|         ) |  | ||||||
|         if (dyConsumed > 0 && child.visibility == View.VISIBLE) { |  | ||||||
|             child.hide(object : FloatingActionButton.OnVisibilityChangedListener() { |  | ||||||
|                 override fun onHidden(fab: FloatingActionButton?) { |  | ||||||
|                     super.onHidden(fab) |  | ||||||
|                     fab!!.visibility = View.INVISIBLE |  | ||||||
|                 } |  | ||||||
|             }) |  | ||||||
|         } else if (dyConsumed < 0 && child.visibility != View.VISIBLE) { |  | ||||||
|             child.show() |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -4,10 +4,10 @@ package apps.amine.bou.readerforselfoss.utils.customtabs; | |||||||
| import android.app.Activity; | import android.app.Activity; | ||||||
| import android.net.Uri; | import android.net.Uri; | ||||||
| import android.os.Bundle; | import android.os.Bundle; | ||||||
| import android.support.customtabs.CustomTabsClient; | import androidx.browser.customtabs.CustomTabsClient; | ||||||
| import android.support.customtabs.CustomTabsIntent; | import androidx.browser.customtabs.CustomTabsIntent; | ||||||
| import android.support.customtabs.CustomTabsServiceConnection; | import androidx.browser.customtabs.CustomTabsServiceConnection; | ||||||
| import android.support.customtabs.CustomTabsSession; | import androidx.browser.customtabs.CustomTabsSession; | ||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ import android.content.IntentFilter; | |||||||
| import android.content.pm.PackageManager; | import android.content.pm.PackageManager; | ||||||
| import android.content.pm.ResolveInfo; | import android.content.pm.ResolveInfo; | ||||||
| import android.net.Uri; | import android.net.Uri; | ||||||
| import android.support.customtabs.CustomTabsService; | import androidx.browser.customtabs.CustomTabsService; | ||||||
| import android.text.TextUtils; | import android.text.TextUtils; | ||||||
| import android.util.Log; | import android.util.Log; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,8 +2,8 @@ package apps.amine.bou.readerforselfoss.utils.customtabs; | |||||||
|  |  | ||||||
|  |  | ||||||
| import android.content.ComponentName; | import android.content.ComponentName; | ||||||
| import android.support.customtabs.CustomTabsClient; | import androidx.browser.customtabs.CustomTabsClient; | ||||||
| import android.support.customtabs.CustomTabsServiceConnection; | import androidx.browser.customtabs.CustomTabsServiceConnection; | ||||||
|  |  | ||||||
| import java.lang.ref.WeakReference; | import java.lang.ref.WeakReference; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| package apps.amine.bou.readerforselfoss.utils.customtabs; | package apps.amine.bou.readerforselfoss.utils.customtabs; | ||||||
|  |  | ||||||
|  |  | ||||||
| import android.support.customtabs.CustomTabsClient; | import androidx.browser.customtabs.CustomTabsClient; | ||||||
|  |  | ||||||
|  |  | ||||||
| public interface ServiceConnectionCallback { | public interface ServiceConnectionCallback { | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| /* From https://github.com/mikepenz/MaterialDrawer/blob/develop/app/src/main/java/com/mikepenz/materialdrawer/app/drawerItems/CustomBaseViewHolder.java */ | /* From https://github.com/mikepenz/MaterialDrawer/blob/develop/app/src/main/java/com/mikepenz/materialdrawer/app/drawerItems/CustomBaseViewHolder.java */ | ||||||
| package apps.amine.bou.readerforselfoss.utils.drawer | package apps.amine.bou.readerforselfoss.utils.drawer | ||||||
|  |  | ||||||
| import android.support.v7.widget.RecyclerView | import androidx.recyclerview.widget.RecyclerView | ||||||
| import android.view.View | import android.view.View | ||||||
| import android.widget.ImageView | import android.widget.ImageView | ||||||
| import android.widget.TextView | import android.widget.TextView | ||||||
|   | |||||||
| @@ -2,10 +2,10 @@ | |||||||
| package apps.amine.bou.readerforselfoss.utils.drawer | package apps.amine.bou.readerforselfoss.utils.drawer | ||||||
|  |  | ||||||
| import android.net.Uri | import android.net.Uri | ||||||
| import android.support.annotation.ColorInt | import androidx.annotation.ColorInt | ||||||
| import android.support.annotation.ColorRes | import androidx.annotation.ColorRes | ||||||
| import android.support.annotation.StringRes | import androidx.annotation.StringRes | ||||||
| import android.support.v7.widget.RecyclerView | import androidx.recyclerview.widget.RecyclerView | ||||||
|  |  | ||||||
| import com.mikepenz.materialdrawer.holder.ColorHolder | import com.mikepenz.materialdrawer.holder.ColorHolder | ||||||
| import com.mikepenz.materialdrawer.holder.ImageHolder | import com.mikepenz.materialdrawer.holder.ImageHolder | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| /* From https://github.com/mikepenz/MaterialDrawer/blob/develop/app/src/main/java/com/mikepenz/materialdrawer/app/drawerItems/CustomUrlPrimaryDrawerItem.java */ | /* From https://github.com/mikepenz/MaterialDrawer/blob/develop/app/src/main/java/com/mikepenz/materialdrawer/app/drawerItems/CustomUrlPrimaryDrawerItem.java */ | ||||||
| package apps.amine.bou.readerforselfoss.utils.drawer | package apps.amine.bou.readerforselfoss.utils.drawer | ||||||
|  |  | ||||||
| import android.support.annotation.LayoutRes | import androidx.annotation.LayoutRes | ||||||
| import android.support.annotation.StringRes | import androidx.annotation.StringRes | ||||||
| import android.view.View | import android.view.View | ||||||
| import android.widget.TextView | import android.widget.TextView | ||||||
| import apps.amine.bou.readerforselfoss.R | import apps.amine.bou.readerforselfoss.R | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ package apps.amine.bou.readerforselfoss.utils.glide | |||||||
|  |  | ||||||
| import android.content.Context | import android.content.Context | ||||||
| import android.graphics.Bitmap | import android.graphics.Bitmap | ||||||
| import android.support.v4.graphics.drawable.RoundedBitmapDrawableFactory | import androidx.core.graphics.drawable.RoundedBitmapDrawableFactory | ||||||
| import android.widget.ImageView | import android.widget.ImageView | ||||||
| import com.bumptech.glide.Glide | import com.bumptech.glide.Glide | ||||||
| import com.bumptech.glide.request.RequestOptions | import com.bumptech.glide.request.RequestOptions | ||||||
|   | |||||||
| @@ -0,0 +1,72 @@ | |||||||
|  | package apps.amine.bou.readerforselfoss.utils.persistence | ||||||
|  |  | ||||||
|  | import apps.amine.bou.readerforselfoss.api.selfoss.Item | ||||||
|  | import apps.amine.bou.readerforselfoss.api.selfoss.Source | ||||||
|  | import apps.amine.bou.readerforselfoss.api.selfoss.Tag | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.entities.ItemEntity | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.entities.SourceEntity | ||||||
|  | import apps.amine.bou.readerforselfoss.persistence.entities.TagEntity | ||||||
|  |  | ||||||
|  | fun TagEntity.toView(): Tag = | ||||||
|  |         Tag( | ||||||
|  |             this.tag, | ||||||
|  |             this.color, | ||||||
|  |             this.unread | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  | fun SourceEntity.toView(): Source = | ||||||
|  |         Source( | ||||||
|  |             this.id, | ||||||
|  |             this.title, | ||||||
|  |             this.tags, | ||||||
|  |             this.spout, | ||||||
|  |             this.error, | ||||||
|  |             this.icon | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  | fun Source.toEntity(): SourceEntity = | ||||||
|  |         SourceEntity( | ||||||
|  |             this.id, | ||||||
|  |             this.title, | ||||||
|  |             this.tags, | ||||||
|  |             this.spout, | ||||||
|  |             this.error, | ||||||
|  |             this.icon.orEmpty() | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  | fun Tag.toEntity(): TagEntity = | ||||||
|  |         TagEntity( | ||||||
|  |             this.tag, | ||||||
|  |             this.color, | ||||||
|  |             this.unread | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  | fun ItemEntity.toView(): Item = | ||||||
|  |         Item( | ||||||
|  |             this.id, | ||||||
|  |             this.datetime, | ||||||
|  |             this.title, | ||||||
|  |             this.content, | ||||||
|  |             this.unread, | ||||||
|  |             this.starred, | ||||||
|  |             this.thumbnail, | ||||||
|  |             this.icon, | ||||||
|  |             this.link, | ||||||
|  |             this.sourcetitle, | ||||||
|  |             this.tags | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  | fun Item.toEntity(): ItemEntity = | ||||||
|  |     ItemEntity( | ||||||
|  |         this.id, | ||||||
|  |         this.datetime, | ||||||
|  |         this.title, | ||||||
|  |         this.content, | ||||||
|  |         this.unread, | ||||||
|  |         this.starred, | ||||||
|  |         this.thumbnail, | ||||||
|  |         this.icon, | ||||||
|  |         this.link, | ||||||
|  |         this.sourcetitle, | ||||||
|  |         this.tags | ||||||
|  |     ) | ||||||
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/drawable-hdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/src/main/res/drawable-hdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 324 B | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/drawable-mdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/src/main/res/drawable-mdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 215 B | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/drawable-xhdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/src/main/res/drawable-xhdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 327 B | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/drawable-xxhdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/src/main/res/drawable-xxhdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 490 B | 
							
								
								
									
										
											BIN
										
									
								
								app/src/main/res/drawable-xxxhdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/src/main/res/drawable-xxxhdpi/ic_fiber_new.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 567 B | 
| @@ -1,4 +0,0 @@ | |||||||
| <vector android:height="24dp" android:viewportHeight="24.0" |  | ||||||
|     android:viewportWidth="24.0" android:width="24dp" xmlns:android="http://schemas.android.com/apk/res/android"> |  | ||||||
|     <path android:fillColor="#FFFFFF" android:pathData="M11,17h2v-6h-2v6zM12,2C6.48,2 2,6.48 2,12s4.48,10 10,10 10,-4.48 10,-10S17.52,2 12,2zM12,20c-4.41,0 -8,-3.59 -8,-8s3.59,-8 8,-8 8,3.59 8,8 -3.59,8 -8,8zM11,9h2L13,7h-2v2z"/> |  | ||||||
| </vector> |  | ||||||
| @@ -1,4 +0,0 @@ | |||||||
| <vector android:height="24dp" android:viewportHeight="24.0" |  | ||||||
|     android:viewportWidth="24.0" android:width="24dp" xmlns:android="http://schemas.android.com/apk/res/android"> |  | ||||||
|     <path android:fillColor="#FFFFFF" android:pathData="M1,21h4L5,9L1,9v12zM23,10c0,-1.1 -0.9,-2 -2,-2h-6.31l0.95,-4.57 0.03,-0.32c0,-0.41 -0.17,-0.79 -0.44,-1.06L14.17,1 7.59,7.59C7.22,7.95 7,8.45 7,9v10c0,1.1 0.9,2 2,2h9c0.83,0 1.54,-0.5 1.84,-1.22l3.02,-7.05c0.09,-0.23 0.14,-0.47 0.14,-0.73v-1.91l-0.01,-0.01L23,10z"/> |  | ||||||
| </vector> |  | ||||||
| @@ -10,22 +10,22 @@ | |||||||
|         android:layout_height="match_parent" |         android:layout_height="match_parent" | ||||||
|         android:orientation="vertical"> |         android:orientation="vertical"> | ||||||
|  |  | ||||||
|         <android.support.design.widget.AppBarLayout |         <com.google.android.material.appbar.AppBarLayout | ||||||
|             android:layout_width="match_parent" |             android:layout_width="match_parent" | ||||||
|             android:layout_height="wrap_content"> |             android:layout_height="wrap_content"> | ||||||
|  |  | ||||||
|             <android.support.v7.widget.Toolbar |             <androidx.appcompat.widget.Toolbar | ||||||
|                 android:id="@+id/toolbar" |                 android:id="@+id/toolbar" | ||||||
|                 android:layout_width="match_parent" |                 android:layout_width="match_parent" | ||||||
|                 android:layout_height="?attr/actionBarSize" |                 android:layout_height="?attr/actionBarSize" | ||||||
|                 app:theme="@style/ToolBarStyle" |                 app:theme="@style/ToolBarStyle" | ||||||
|                 app:popupTheme="?attr/toolbarPopupTheme" /> |                 app:popupTheme="?attr/toolbarPopupTheme" /> | ||||||
|  |  | ||||||
|         </android.support.design.widget.AppBarLayout> |         </com.google.android.material.appbar.AppBarLayout> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         <android.support.constraint.ConstraintLayout |         <androidx.constraintlayout.widget.ConstraintLayout | ||||||
|             android:paddingBottom="@dimen/activity_vertical_margin" |             android:paddingBottom="@dimen/activity_vertical_margin" | ||||||
|             android:paddingLeft="@dimen/activity_horizontal_margin" |             android:paddingLeft="@dimen/activity_horizontal_margin" | ||||||
|             android:paddingRight="@dimen/activity_horizontal_margin" |             android:paddingRight="@dimen/activity_horizontal_margin" | ||||||
| @@ -121,7 +121,7 @@ | |||||||
|                 android:layout_marginBottom="16dp" |                 android:layout_marginBottom="16dp" | ||||||
|                 app:layout_constraintVertical_bias="0.0"/> |                 app:layout_constraintVertical_bias="0.0"/> | ||||||
|  |  | ||||||
|         </android.support.constraint.ConstraintLayout> |         </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
|  |  | ||||||
|         <ProgressBar |         <ProgressBar | ||||||
|             android:id="@+id/progress" |             android:id="@+id/progress" | ||||||
|   | |||||||
| @@ -30,13 +30,13 @@ | |||||||
|         app:prompt_view_background_color="?attr/colorAccent" |         app:prompt_view_background_color="?attr/colorAccent" | ||||||
|         app:prompt_view_thanks_display_time_ms="2000"/> |         app:prompt_view_thanks_display_time_ms="2000"/> | ||||||
|  |  | ||||||
|     <android.support.design.widget.CoordinatorLayout |     <androidx.coordinatorlayout.widget.CoordinatorLayout | ||||||
|         android:id="@+id/coordLayout" |         android:id="@+id/coordLayout" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="match_parent" |         android:layout_height="match_parent" | ||||||
|         android:layout_below="@id/promptView"> |         android:layout_below="@id/promptView"> | ||||||
|  |  | ||||||
|         <android.support.design.widget.CoordinatorLayout |         <androidx.coordinatorlayout.widget.CoordinatorLayout | ||||||
|             android:id="@+id/intern_coordLayout" |             android:id="@+id/intern_coordLayout" | ||||||
|             android:layout_width="match_parent" |             android:layout_width="match_parent" | ||||||
|             android:layout_height="match_parent"> |             android:layout_height="match_parent"> | ||||||
| @@ -46,18 +46,18 @@ | |||||||
|                 android:layout_height="match_parent" |                 android:layout_height="match_parent" | ||||||
|                 android:orientation="vertical"> |                 android:orientation="vertical"> | ||||||
|  |  | ||||||
|                 <android.support.design.widget.AppBarLayout |                 <com.google.android.material.appbar.AppBarLayout | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content"> |                     android:layout_height="wrap_content"> | ||||||
|  |  | ||||||
|                     <android.support.v7.widget.Toolbar |                     <androidx.appcompat.widget.Toolbar | ||||||
|                         android:id="@+id/toolBar" |                         android:id="@+id/toolBar" | ||||||
|                         android:layout_width="match_parent" |                         android:layout_width="match_parent" | ||||||
|                         android:layout_height="?attr/actionBarSize" |                         android:layout_height="?attr/actionBarSize" | ||||||
|                         app:theme="@style/ToolBarStyle" |                         app:theme="@style/ToolBarStyle" | ||||||
|                         app:popupTheme="?attr/toolbarPopupTheme" /> |                         app:popupTheme="?attr/toolbarPopupTheme" /> | ||||||
|  |  | ||||||
|                 </android.support.design.widget.AppBarLayout> |                 </com.google.android.material.appbar.AppBarLayout> | ||||||
|  |  | ||||||
|                 <FrameLayout |                 <FrameLayout | ||||||
|                     android:id="@+id/drawer_layout" |                     android:id="@+id/drawer_layout" | ||||||
| @@ -66,7 +66,7 @@ | |||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="match_parent"> |                     android:layout_height="match_parent"> | ||||||
|  |  | ||||||
|                     <android.support.v4.widget.SwipeRefreshLayout |                     <androidx.swiperefreshlayout.widget.SwipeRefreshLayout | ||||||
|                         android:id="@+id/swipeRefreshLayout" |                         android:id="@+id/swipeRefreshLayout" | ||||||
|                         android:layout_width="match_parent" |                         android:layout_width="match_parent" | ||||||
|                         android:layout_height="match_parent"> |                         android:layout_height="match_parent"> | ||||||
| @@ -86,30 +86,30 @@ | |||||||
|                                 android:text="@string/nothing_here" |                                 android:text="@string/nothing_here" | ||||||
|                                 android:textAlignment="center" |                                 android:textAlignment="center" | ||||||
|                                 android:textAppearance="@style/TextAppearance.AppCompat.Headline" |                                 android:textAppearance="@style/TextAppearance.AppCompat.Headline" | ||||||
|                                 android:background="@color/transparent" |                                 android:background="@android:color/transparent" | ||||||
|                                 android:visibility="gone" /> |                                 android:visibility="gone" /> | ||||||
|  |  | ||||||
|                             <android.support.v7.widget.RecyclerView |                             <androidx.recyclerview.widget.RecyclerView | ||||||
|                                 android:id="@+id/recyclerView" |                                 android:id="@+id/recyclerView" | ||||||
|                                 android:layout_width="match_parent" |                                 android:layout_width="match_parent" | ||||||
|                                 android:layout_height="wrap_content" |                                 android:layout_height="wrap_content" | ||||||
|                                 android:background="@color/transparent" |                                 android:background="@android:color/transparent" | ||||||
|                                 android:clipToPadding="false" |                                 android:clipToPadding="false" | ||||||
|                                 android:paddingBottom="60dp" |                                 android:paddingBottom="60dp" | ||||||
|                                 android:scrollbars="vertical" |                                 android:scrollbars="vertical" | ||||||
|                                 app:layout_behavior="@string/appbar_scrolling_view_behavior" /> |                                 app:layout_behavior="@string/appbar_scrolling_view_behavior" /> | ||||||
|                         </LinearLayout> |                         </LinearLayout> | ||||||
|  |  | ||||||
|                     </android.support.v4.widget.SwipeRefreshLayout> |                     </androidx.swiperefreshlayout.widget.SwipeRefreshLayout> | ||||||
|  |  | ||||||
|                 </FrameLayout> |                 </FrameLayout> | ||||||
|             </LinearLayout> |             </LinearLayout> | ||||||
|  |  | ||||||
|         </android.support.design.widget.CoordinatorLayout> |         </androidx.coordinatorlayout.widget.CoordinatorLayout> | ||||||
|         <com.ashokvarma.bottomnavigation.BottomNavigationBar |         <com.ashokvarma.bottomnavigation.BottomNavigationBar | ||||||
|             android:layout_gravity="bottom" |             android:layout_gravity="bottom" | ||||||
|             android:id="@+id/bottomBar" |             android:id="@+id/bottomBar" | ||||||
|             android:layout_width="match_parent" |             android:layout_width="match_parent" | ||||||
|             android:layout_height="60dp"/> |             android:layout_height="60dp"/> | ||||||
|     </android.support.design.widget.CoordinatorLayout> |     </androidx.coordinatorlayout.widget.CoordinatorLayout> | ||||||
| </RelativeLayout> | </RelativeLayout> | ||||||
| @@ -6,18 +6,18 @@ | |||||||
|     android:gravity="center_horizontal" |     android:gravity="center_horizontal" | ||||||
|     android:orientation="vertical" |     android:orientation="vertical" | ||||||
|     tools:context="apps.amine.bou.readerforselfoss.LoginActivity"> |     tools:context="apps.amine.bou.readerforselfoss.LoginActivity"> | ||||||
|     <android.support.design.widget.AppBarLayout |     <com.google.android.material.appbar.AppBarLayout | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="wrap_content"> |         android:layout_height="wrap_content"> | ||||||
|  |  | ||||||
|         <android.support.v7.widget.Toolbar |         <androidx.appcompat.widget.Toolbar | ||||||
|             android:id="@+id/toolbar" |             android:id="@+id/toolbar" | ||||||
|             android:layout_width="match_parent" |             android:layout_width="match_parent" | ||||||
|             android:layout_height="?attr/actionBarSize" |             android:layout_height="?attr/actionBarSize" | ||||||
|             app:theme="@style/ToolBarStyle" |             app:theme="@style/ToolBarStyle" | ||||||
|             app:popupTheme="?attr/toolbarPopupTheme" /> |             app:popupTheme="?attr/toolbarPopupTheme" /> | ||||||
|  |  | ||||||
|     </android.support.design.widget.AppBarLayout> |     </com.google.android.material.appbar.AppBarLayout> | ||||||
|     <LinearLayout |     <LinearLayout | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="match_parent" |         android:layout_height="match_parent" | ||||||
| @@ -45,7 +45,7 @@ | |||||||
|                 android:layout_height="wrap_content" |                 android:layout_height="wrap_content" | ||||||
|                 android:orientation="vertical"> |                 android:orientation="vertical"> | ||||||
|  |  | ||||||
|                 <android.support.design.widget.TextInputLayout |                 <com.google.android.material.textfield.TextInputLayout | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
|                     android:id="@+id/urlLayout" |                     android:id="@+id/urlLayout" | ||||||
| @@ -60,7 +60,7 @@ | |||||||
|                         android:inputType="textUri" |                         android:inputType="textUri" | ||||||
|                         android:maxLines="1" /> |                         android:maxLines="1" /> | ||||||
|  |  | ||||||
|                 </android.support.design.widget.TextInputLayout> |                 </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|                 <Switch |                 <Switch | ||||||
|                     android:text="@string/withLoginSwitch" |                     android:text="@string/withLoginSwitch" | ||||||
| @@ -69,7 +69,7 @@ | |||||||
|                     android:id="@+id/withLogin" |                     android:id="@+id/withLogin" | ||||||
|                     android:layout_weight="1"/> |                     android:layout_weight="1"/> | ||||||
|  |  | ||||||
|                 <android.support.design.widget.TextInputLayout |                 <com.google.android.material.textfield.TextInputLayout | ||||||
|                     android:id="@+id/loginLayout" |                     android:id="@+id/loginLayout" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
| @@ -83,9 +83,9 @@ | |||||||
|                         android:inputType="text" |                         android:inputType="text" | ||||||
|                         android:maxLines="1" /> |                         android:maxLines="1" /> | ||||||
|  |  | ||||||
|                 </android.support.design.widget.TextInputLayout> |                 </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|                 <android.support.design.widget.TextInputLayout |                 <com.google.android.material.textfield.TextInputLayout | ||||||
|                     android:id="@+id/passwordLayout" |                     android:id="@+id/passwordLayout" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="wrap_content" |                     android:layout_height="wrap_content" | ||||||
| @@ -99,7 +99,7 @@ | |||||||
|                         android:inputType="textPassword" |                         android:inputType="textPassword" | ||||||
|                         android:maxLines="1" /> |                         android:maxLines="1" /> | ||||||
|  |  | ||||||
|                 </android.support.design.widget.TextInputLayout> |                 </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|                 <Switch |                 <Switch | ||||||
|                     android:id="@+id/withHttpLogin" |                     android:id="@+id/withHttpLogin" | ||||||
| @@ -108,7 +108,7 @@ | |||||||
|                     android:layout_weight="1" |                     android:layout_weight="1" | ||||||
|                     android:text="@string/withHttpLoginSwitch" /> |                     android:text="@string/withHttpLoginSwitch" /> | ||||||
|  |  | ||||||
|                 <android.support.design.widget.TextInputLayout |                 <com.google.android.material.textfield.TextInputLayout | ||||||
|                     android:id="@+id/httpLoginInput" |                     android:id="@+id/httpLoginInput" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="match_parent" |                     android:layout_height="match_parent" | ||||||
| @@ -120,9 +120,9 @@ | |||||||
|                         android:layout_width="match_parent" |                         android:layout_width="match_parent" | ||||||
|                         android:layout_height="wrap_content" |                         android:layout_height="wrap_content" | ||||||
|                         android:hint="@string/prompt_http_login" /> |                         android:hint="@string/prompt_http_login" /> | ||||||
|                 </android.support.design.widget.TextInputLayout> |                 </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|                 <android.support.design.widget.TextInputLayout |                 <com.google.android.material.textfield.TextInputLayout | ||||||
|                     android:id="@+id/httpPasswordInput" |                     android:id="@+id/httpPasswordInput" | ||||||
|                     android:layout_width="match_parent" |                     android:layout_width="match_parent" | ||||||
|                     android:layout_height="match_parent" |                     android:layout_height="match_parent" | ||||||
| @@ -134,7 +134,7 @@ | |||||||
|                         android:layout_height="wrap_content" |                         android:layout_height="wrap_content" | ||||||
|                         android:hint="@string/prompt_http_password" |                         android:hint="@string/prompt_http_password" | ||||||
|                         android:inputType="textPassword" /> |                         android:inputType="textPassword" /> | ||||||
|                 </android.support.design.widget.TextInputLayout> |                 </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|                 <Switch |                 <Switch | ||||||
|                     android:id="@+id/withSelfhostedCert" |                     android:id="@+id/withSelfhostedCert" | ||||||
|   | |||||||
| @@ -1,9 +1,9 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <android.support.constraint.ConstraintLayout | <androidx.constraintlayout.widget.ConstraintLayout | ||||||
|     xmlns:android="http://schemas.android.com/apk/res/android" |     xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:tools="http://schemas.android.com/tools" |     xmlns:tools="http://schemas.android.com/tools" | ||||||
|     android:layout_width="match_parent" |     android:layout_width="match_parent" | ||||||
|     android:layout_height="match_parent" |     android:layout_height="match_parent" | ||||||
|     tools:context="apps.amine.bou.readerforselfoss.MainActivity"> |     tools:context="apps.amine.bou.readerforselfoss.MainActivity"> | ||||||
|  |  | ||||||
| </android.support.constraint.ConstraintLayout> | </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
|   | |||||||
| @@ -1,10 +1,10 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" | <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" |     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||||
|     android:layout_width="match_parent" |     android:layout_width="match_parent" | ||||||
|     android:layout_height="match_parent"> |     android:layout_height="match_parent"> | ||||||
|  |  | ||||||
|     <android.support.design.widget.AppBarLayout |     <com.google.android.material.appbar.AppBarLayout | ||||||
|         android:id="@+id/appBarLayout" |         android:id="@+id/appBarLayout" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="wrap_content" |         android:layout_height="wrap_content" | ||||||
| @@ -12,16 +12,16 @@ | |||||||
|         app:layout_constraintStart_toStartOf="parent" |         app:layout_constraintStart_toStartOf="parent" | ||||||
|         app:layout_constraintTop_toTopOf="parent"> |         app:layout_constraintTop_toTopOf="parent"> | ||||||
|  |  | ||||||
|         <android.support.v7.widget.Toolbar |         <androidx.appcompat.widget.Toolbar | ||||||
|             android:id="@+id/toolBar" |             android:id="@+id/toolBar" | ||||||
|             android:layout_width="match_parent" |             android:layout_width="match_parent" | ||||||
|             android:layout_height="?attr/actionBarSize" |             android:layout_height="?attr/actionBarSize" | ||||||
|             app:popupTheme="?attr/toolbarPopupTheme" |             app:popupTheme="?attr/toolbarPopupTheme" | ||||||
|             app:theme="@style/ToolBarStyle" /> |             app:theme="@style/ToolBarStyle" /> | ||||||
|  |  | ||||||
|     </android.support.design.widget.AppBarLayout> |     </com.google.android.material.appbar.AppBarLayout> | ||||||
|  |  | ||||||
|     <android.support.v4.view.ViewPager |     <androidx.viewpager.widget.ViewPager | ||||||
|         android:id="@+id/pager" |         android:id="@+id/pager" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="0dp" |         android:layout_height="0dp" | ||||||
| @@ -41,4 +41,4 @@ | |||||||
|         app:layout_constraintLeft_toLeftOf="parent" |         app:layout_constraintLeft_toLeftOf="parent" | ||||||
|         app:layout_constraintRight_toRightOf="parent" |         app:layout_constraintRight_toRightOf="parent" | ||||||
|         app:layout_constraintTop_toTopOf="@+id/pager" /> |         app:layout_constraintTop_toTopOf="@+id/pager" /> | ||||||
| </android.support.constraint.ConstraintLayout> | </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
|   | |||||||
| @@ -1,33 +1,33 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  |  | ||||||
| <android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" | <androidx.coordinatorlayout.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:tools="http://schemas.android.com/tools" |     xmlns:tools="http://schemas.android.com/tools" | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" |     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||||
|     android:layout_width="match_parent" |     android:layout_width="match_parent" | ||||||
|     android:layout_height="match_parent" |     android:layout_height="match_parent" | ||||||
|     tools:context="apps.amine.bou.readerforselfoss.SourcesActivity"> |     tools:context="apps.amine.bou.readerforselfoss.SourcesActivity"> | ||||||
|     <android.support.design.widget.AppBarLayout |     <com.google.android.material.appbar.AppBarLayout | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="wrap_content"> |         android:layout_height="wrap_content"> | ||||||
|  |  | ||||||
|         <android.support.v7.widget.Toolbar |         <androidx.appcompat.widget.Toolbar | ||||||
|             android:id="@+id/toolbar" |             android:id="@+id/toolbar" | ||||||
|             android:layout_width="match_parent" |             android:layout_width="match_parent" | ||||||
|             android:layout_height="?attr/actionBarSize" |             android:layout_height="?attr/actionBarSize" | ||||||
|             app:theme="@style/ToolBarStyle" |             app:theme="@style/ToolBarStyle" | ||||||
|             app:popupTheme="?attr/toolbarPopupTheme" /> |             app:popupTheme="?attr/toolbarPopupTheme" /> | ||||||
|  |  | ||||||
|     </android.support.design.widget.AppBarLayout> |     </com.google.android.material.appbar.AppBarLayout> | ||||||
|  |  | ||||||
|     <android.support.v7.widget.RecyclerView |     <androidx.recyclerview.widget.RecyclerView | ||||||
|         android:id="@+id/recyclerView" |         android:id="@+id/recyclerView" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="match_parent" |         android:layout_height="match_parent" | ||||||
|         android:scrollbars="vertical" |         android:scrollbars="vertical" | ||||||
|         app:layout_behavior="@string/appbar_scrolling_view_behavior"> |         app:layout_behavior="@string/appbar_scrolling_view_behavior"> | ||||||
|     </android.support.v7.widget.RecyclerView> |     </androidx.recyclerview.widget.RecyclerView> | ||||||
|  |  | ||||||
|     <android.support.design.widget.FloatingActionButton |     <com.google.android.material.floatingactionbutton.FloatingActionButton | ||||||
|         android:id="@+id/fab" |         android:id="@+id/fab" | ||||||
|         android:layout_width="wrap_content" |         android:layout_width="wrap_content" | ||||||
|         android:layout_height="wrap_content" |         android:layout_height="wrap_content" | ||||||
| @@ -42,4 +42,4 @@ | |||||||
|         android:layout_marginEnd="16dp" |         android:layout_marginEnd="16dp" | ||||||
|         android:layout_marginRight="16dp" |         android:layout_marginRight="16dp" | ||||||
|         app:layout_behavior="apps.amine.bou.readerforselfoss.utils.ScrollAwareFABBehavior" /> |         app:layout_behavior="apps.amine.bou.readerforselfoss.utils.ScrollAwareFABBehavior" /> | ||||||
| </android.support.design.widget.CoordinatorLayout> | </androidx.coordinatorlayout.widget.CoordinatorLayout> | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <android.support.v7.widget.CardView | <androidx.cardview.widget.CardView | ||||||
|     xmlns:android="http://schemas.android.com/apk/res/android" |     xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" |     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||||
|     xmlns:card_view="http://schemas.android.com/apk/res-auto" |     xmlns:card_view="http://schemas.android.com/apk/res-auto" | ||||||
| @@ -18,7 +18,7 @@ | |||||||
|     card_view:cardUseCompatPadding="true" |     card_view:cardUseCompatPadding="true" | ||||||
|     card_view:layout_constraintBottom_toBottomOf="parent"> |     card_view:layout_constraintBottom_toBottomOf="parent"> | ||||||
|  |  | ||||||
|     <android.support.constraint.ConstraintLayout |     <androidx.constraintlayout.widget.ConstraintLayout | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="wrap_content"> |         android:layout_height="wrap_content"> | ||||||
|  |  | ||||||
| @@ -34,7 +34,7 @@ | |||||||
|             app:srcCompat="@drawable/background_splash" |             app:srcCompat="@drawable/background_splash" | ||||||
|             card_view:layout_constraintBottom_toTopOf="@+id/constraintLayout" /> |             card_view:layout_constraintBottom_toTopOf="@+id/constraintLayout" /> | ||||||
|  |  | ||||||
|         <android.support.constraint.ConstraintLayout |         <androidx.constraintlayout.widget.ConstraintLayout | ||||||
|             android:id="@+id/constraintLayout" |             android:id="@+id/constraintLayout" | ||||||
|             android:layout_width="0dp" |             android:layout_width="0dp" | ||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
| @@ -143,7 +143,7 @@ | |||||||
|  |  | ||||||
|             </RelativeLayout> |             </RelativeLayout> | ||||||
|  |  | ||||||
|         </android.support.constraint.ConstraintLayout> |         </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
|     </android.support.constraint.ConstraintLayout> |     </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
|  |  | ||||||
| </android.support.v7.widget.CardView> | </androidx.cardview.widget.CardView> | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| <android.support.design.widget.CoordinatorLayout | <androidx.coordinatorlayout.widget.CoordinatorLayout | ||||||
|     xmlns:android="http://schemas.android.com/apk/res/android" |     xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" |     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||||
|     xmlns:tools="http://schemas.android.com/tools" |     xmlns:tools="http://schemas.android.com/tools" | ||||||
| @@ -6,12 +6,12 @@ | |||||||
|     android:layout_height="match_parent" |     android:layout_height="match_parent" | ||||||
|     android:descendantFocusability="blocksDescendants"> |     android:descendantFocusability="blocksDescendants"> | ||||||
|  |  | ||||||
|     <android.support.v4.widget.NestedScrollView |     <androidx.core.widget.NestedScrollView | ||||||
|         android:id="@+id/nestedScrollView" |         android:id="@+id/nestedScrollView" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="match_parent"> |         android:layout_height="match_parent"> | ||||||
|  |  | ||||||
|         <android.support.constraint.ConstraintLayout |         <androidx.constraintlayout.widget.ConstraintLayout | ||||||
|             android:layout_width="match_parent" |             android:layout_width="match_parent" | ||||||
|             android:layout_height="match_parent"> |             android:layout_height="match_parent"> | ||||||
|  |  | ||||||
| @@ -70,9 +70,9 @@ | |||||||
|                 app:layout_constraintTop_toBottomOf="@+id/source" |                 app:layout_constraintTop_toBottomOf="@+id/source" | ||||||
|                 tools:visibility="visible" /> |                 tools:visibility="visible" /> | ||||||
|  |  | ||||||
|         </android.support.constraint.ConstraintLayout> |         </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
|  |  | ||||||
|     </android.support.v4.widget.NestedScrollView> |     </androidx.core.widget.NestedScrollView> | ||||||
|  |  | ||||||
|     <FrameLayout |     <FrameLayout | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
| @@ -89,7 +89,7 @@ | |||||||
|             android:layout_gravity="bottom" |             android:layout_gravity="bottom" | ||||||
|             app:floatingMenu="@menu/reader_toolbar" /> |             app:floatingMenu="@menu/reader_toolbar" /> | ||||||
|  |  | ||||||
|         <android.support.design.widget.FloatingActionButton |         <com.google.android.material.floatingactionbutton.FloatingActionButton | ||||||
|             android:id="@+id/fab" |             android:id="@+id/fab" | ||||||
|             android:layout_width="wrap_content" |             android:layout_width="wrap_content" | ||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
| @@ -123,4 +123,4 @@ | |||||||
|             android:progressTint="?attr/colorAccent" /> |             android:progressTint="?attr/colorAccent" /> | ||||||
|     </FrameLayout> |     </FrameLayout> | ||||||
|  |  | ||||||
| </android.support.design.widget.CoordinatorLayout> | </androidx.coordinatorlayout.widget.CoordinatorLayout> | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" | <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" |     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||||
|     xmlns:tools="http://schemas.android.com/tools" |     xmlns:tools="http://schemas.android.com/tools" | ||||||
|     android:layout_width="match_parent" |     android:layout_width="match_parent" | ||||||
| @@ -115,4 +115,4 @@ | |||||||
|  |  | ||||||
|     </RelativeLayout> |     </RelativeLayout> | ||||||
|  |  | ||||||
| </android.support.constraint.ConstraintLayout> | </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
| @@ -1,15 +1,15 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <android.support.design.widget.AppBarLayout | <com.google.android.material.appbar.AppBarLayout | ||||||
|     xmlns:android="http://schemas.android.com/apk/res/android" |     xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     android:layout_width="match_parent" |     android:layout_width="match_parent" | ||||||
|     android:layout_height="wrap_content" |     android:layout_height="wrap_content" | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto"> |     xmlns:app="http://schemas.android.com/apk/res-auto"> | ||||||
|  |  | ||||||
|     <android.support.v7.widget.Toolbar |     <androidx.appcompat.widget.Toolbar | ||||||
|         android:id="@+id/toolbar" |         android:id="@+id/toolbar" | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="?attr/actionBarSize" |         android:layout_height="?attr/actionBarSize" | ||||||
|         app:theme="@style/ToolBarStyle" |         app:theme="@style/ToolBarStyle" | ||||||
|         app:popupTheme="?attr/toolbarPopupTheme" /> |         app:popupTheme="?attr/toolbarPopupTheme" /> | ||||||
|  |  | ||||||
| </android.support.design.widget.AppBarLayout> | </com.google.android.material.appbar.AppBarLayout> | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <android.support.constraint.ConstraintLayout | <androidx.constraintlayout.widget.ConstraintLayout | ||||||
|     xmlns:android="http://schemas.android.com/apk/res/android" |     xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" |     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||||
|     xmlns:tools="http://schemas.android.com/tools" |     xmlns:tools="http://schemas.android.com/tools" | ||||||
| @@ -52,4 +52,4 @@ | |||||||
|         android:layout_width="34dp" |         android:layout_width="34dp" | ||||||
|         android:layout_height="34dp"/> |         android:layout_height="34dp"/> | ||||||
|  |  | ||||||
| </android.support.constraint.ConstraintLayout> | </androidx.constraintlayout.widget.ConstraintLayout> | ||||||
| @@ -6,13 +6,13 @@ | |||||||
|         android:title="@string/menu_home_search" |         android:title="@string/menu_home_search" | ||||||
|         android:icon="@drawable/ic_action_search" |         android:icon="@drawable/ic_action_search" | ||||||
|         app:showAsAction="ifRoom|collapseActionView" |         app:showAsAction="ifRoom|collapseActionView" | ||||||
|         app:actionViewClass="android.support.v7.widget.SearchView" /> |         app:actionViewClass="androidx.appcompat.widget.SearchView" /> | ||||||
|  |  | ||||||
|     <item android:id="@+id/readAll" |     <item android:id="@+id/readAll" | ||||||
|           android:icon="@drawable/ic_done_all_white_24dp" |           android:icon="@drawable/ic_done_all_white_24dp" | ||||||
|           android:title="@string/readAll" |           android:title="@string/readAll" | ||||||
|           android:orderInCategory="1" |           android:orderInCategory="1" | ||||||
|           app:showAsAction="ifRoom"/> |           app:showAsAction="always"/> | ||||||
|  |  | ||||||
|     <item |     <item | ||||||
|         android:id="@+id/refresh" |         android:id="@+id/refresh" | ||||||
| @@ -20,11 +20,6 @@ | |||||||
|         android:orderInCategory="99" |         android:orderInCategory="99" | ||||||
|         android:title="@string/menu_home_refresh" /> |         android:title="@string/menu_home_refresh" /> | ||||||
|  |  | ||||||
|     <item |  | ||||||
|         android:id="@+id/action_share_the_app" |  | ||||||
|         android:orderInCategory="102" |  | ||||||
|         android:title="@string/menu_share_the_app" /> |  | ||||||
|  |  | ||||||
|     <item android:id="@+id/action_disconnect" |     <item android:id="@+id/action_disconnect" | ||||||
|           android:title="@string/action_disconnect" |           android:title="@string/action_disconnect" | ||||||
|           android:orderInCategory="104" |           android:orderInCategory="104" | ||||||
|   | |||||||
| @@ -2,6 +2,12 @@ | |||||||
| <menu xmlns:android="http://schemas.android.com/apk/res/android" | <menu xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|     xmlns:app="http://schemas.android.com/apk/res-auto"> |     xmlns:app="http://schemas.android.com/apk/res-auto"> | ||||||
|  |  | ||||||
|  |     <item | ||||||
|  |         android:id="@+id/unread_action" | ||||||
|  |         android:icon="@drawable/ic_fiber_new" | ||||||
|  |         android:title="@string/unmark" | ||||||
|  |         app:showAsAction="ifRoom" /> | ||||||
|  |  | ||||||
|     <item |     <item | ||||||
|         android:id="@+id/more_action" |         android:id="@+id/more_action" | ||||||
|         android:icon="@drawable/ic_chrome_reader_mode" |         android:icon="@drawable/ic_chrome_reader_mode" | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -1,170 +1,156 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <!--Generated by crowdin.com--> | <!--Generated by crowdin.com--> | ||||||
| <resources xmlns:tools="http://schemas.android.com/tools"> | <resources xmlns:tools="http://schemas.android.com/tools"> | ||||||
|   <string name="app_name">"Reader for Selfoss"</string> |   <string name="app_name">"Lector per a Selfoss"</string> | ||||||
|   <string name="title_activity_login">"Log in"</string> |   <string name="title_activity_login">"Inicia la sessió"</string> | ||||||
|   <string name="prompt_password">"Password"</string> |   <string name="prompt_password">"Contrasenya"</string> | ||||||
|   <string name="prompt_http_password">"HTTP Password"</string> |   <string name="prompt_http_password">"Contrasenya HTTP"</string> | ||||||
|   <string name="action_sign_in">"Go"</string> |   <string name="action_sign_in">"Vés-hi"</string> | ||||||
|   <string name="error_invalid_password">"Password not long enough"</string> |   <string name="error_invalid_password">"La contrasenya és massa curta"</string> | ||||||
|   <string name="error_field_required">"Field required"</string> |   <string name="error_field_required">"Camp necessari"</string> | ||||||
|   <string name="prompt_url">"Url"</string> |   <string name="prompt_url">"URL"</string> | ||||||
|   <string name="withLoginSwitch">"Login required ?"</string> |   <string name="withLoginSwitch">"Autenticació (si és necessària)"</string> | ||||||
|   <string name="withHttpLoginSwitch">"HTTP Login required ?"</string> |   <string name="withHttpLoginSwitch">"Autenticació HTTP (si és necessària)"</string> | ||||||
|   <string name="login_url_problem">"Oops. You may need to add a \"/\" at the end of the url."</string> |   <string name="login_url_problem">"Pot ser que falti una \"/\" al final de l'url."</string> | ||||||
|   <string name="prompt_login">"Username"</string> |   <string name="prompt_login">"Nom d'usuari"</string> | ||||||
|   <string name="prompt_http_login">"HTTP Username"</string> |   <string name="prompt_http_login">"Nom d'usuari HTTP"</string> | ||||||
|   <string name="label_share">"Share"</string> |   <string name="label_share">"Comparteix"</string> | ||||||
|   <string name="readAll">"Read all"</string> |   <string name="readAll">"Llegeix-ho tot"</string> | ||||||
|   <string name="action_disconnect">"Disconnect"</string> |   <string name="action_disconnect">"Desconnecta't"</string> | ||||||
|   <string name="title_activity_settings">"Settings"</string> |   <string name="title_activity_settings">"Configuració"</string> | ||||||
|   <string name="pref_header_general">"General"</string> |   <string name="pref_header_general">"General"</string> | ||||||
|   <string name="pref_switch_actions_tap_title">"Tap action on the articles"</string> |   <string name="pref_switch_actions_tap_title">"Fer un toc als articles"</string> | ||||||
|   <string name="add_source_hint_tags">"Tag1, Tag2, Tag3"</string> |   <string name="add_source_hint_tags">"Etiqueta1, Etiqueta2, Etiqueta3"</string> | ||||||
|   <string name="add_source_hint_url">"Link"</string> |   <string name="add_source_hint_url">"Enllaç"</string> | ||||||
|   <string name="add_source_hint_name">"Name"</string> |   <string name="add_source_hint_name">"Nom"</string> | ||||||
|   <string name="add_source">"Add a source"</string> |   <string name="add_source">"Afegeix una font"</string> | ||||||
|   <string name="add_source_save">"Save"</string> |   <string name="add_source_save">"Desa"</string> | ||||||
|   <string name="wrong_infos">"Check your details again."</string> |   <string name="wrong_infos">"Torneu a comprovar la informació."</string> | ||||||
|   <string name="all_posts_not_read">"All posts weren't read"</string> |   <string name="all_posts_not_read">"No s'han llegit totes les publicacions"</string> | ||||||
|   <string name="all_posts_read">"All posts were read"</string> |   <string name="all_posts_read">"S'han llegit totes les publicacions"</string> | ||||||
|   <string name="cant_get_favs">"Can't get favorites"</string> |   <string name="cant_get_favs">"No es poden obtenir preferits"</string> | ||||||
|   <string name="cant_get_new_elements">"Can't get new articles"</string> |   <string name="cant_get_new_elements">"No es pot accedir als articles nous"</string> | ||||||
|   <string name="cant_get_read">"Can't get read articles"</string> |   <string name="cant_get_read">"No es poden llegir els articles"</string> | ||||||
|   <string name="nothing_here">"Nothing here"</string> |   <string name="nothing_here">"No hi ha res"</string> | ||||||
|   <string name="tab_new">"New"</string> |   <string name="tab_new">"Nou"</string> | ||||||
|   <string name="tab_read">"All"</string> |   <string name="tab_read">"Tot"</string> | ||||||
|   <string name="tab_favs">"Favorites"</string> |   <string name="tab_favs">"Preferits"</string> | ||||||
|   <string name="action_about">"About"</string> |   <string name="action_about">"Quant a"</string> | ||||||
|   <string name="marked_as_read">"Item read"</string> |   <string name="marked_as_read">"Element llegit"</string> | ||||||
|   <string name="undo_string">"Undo"</string> |   <string name="undo_string">"Desfés"</string> | ||||||
|   <string name="addStringNoUrl">"Log in to add sources."</string> |   <string name="addStringNoUrl">"Inicieu la sessió per afegir fonts."</string> | ||||||
|   <string name="cant_get_sources">"Can't get sources list."</string> |   <string name="cant_get_sources">"No es pot obtenir la llista de fonts."</string> | ||||||
|   <string name="cant_create_source">"Can't create source."</string> |   <string name="cant_create_source">"No es pot crear la font."</string> | ||||||
|   <string name="cant_get_spouts">"Can't get spouts list."</string> |   <string name="cant_get_spouts">"No es pot obtenir la llista de canals."</string> | ||||||
|   <string name="form_not_complete">"The form is not complete"</string> |   <string name="form_not_complete">"El formulari no està complet"</string> | ||||||
|   <string name="pref_header_links">"Links"</string> |   <string name="pref_header_links">"Enllaços"</string> | ||||||
|   <string name="issue_tracker_link">"Issue Tracker"</string> |   <string name="issue_tracker_link">"Detector de problemes"</string> | ||||||
|   <string name="issue_tracker_summary">"Report a bug or ask for a new feature"</string> |   <string name="issue_tracker_summary">"Informa d'un error o pregunta sobre funcions noves"</string> | ||||||
|   <string name="warning_wrong_url">"WARNING"</string> |   <string name="warning_wrong_url">"ADVERTÈNCIA"</string> | ||||||
|   <string name="pref_switch_card_view_title">"Card View"</string> |   <string name="pref_switch_card_view_title">"Visualització de targeta"</string> | ||||||
|   <string name="cant_mark_favortie">"Can't mark article as favorite"</string> |   <string name="cant_mark_favortie">"No es pot marcar l'article com a preferit"</string> | ||||||
|   <string name="cant_unmark_favortie">"Can't remove item from favorite"</string> |   <string name="cant_unmark_favortie">"No es pot treure l'element de preferits"</string> | ||||||
|   <string name="share">"Share"</string> |   <string name="share">"Comparteix"</string> | ||||||
|   <string name="rating_prompt_title">"Enjoying the app ?"</string> |   <string name="rating_prompt_title">"Us agrada l'aplicació?"</string> | ||||||
|   <string name="rating_prompt_yes">"Yes !"</string> |   <string name="rating_prompt_yes">"Sí."</string> | ||||||
|   <string name="rating_prompt_no">"Not really …"</string> |   <string name="rating_prompt_no">"No gaire…"</string> | ||||||
|   <string name="rating_prompt_feedback_title">"Can you tell us why ?"</string> |   <string name="rating_prompt_feedback_title">"Ens podeu dir per què?"</string> | ||||||
|   <string name="rating_prompt_feedback_yes">"OK !"</string> |   <string name="rating_prompt_feedback_yes">"D'acord."</string> | ||||||
|   <string name="rating_prompt_feedback_no">"Not now."</string> |   <string name="rating_prompt_feedback_no">"Ara no."</string> | ||||||
|   <string name="rating_prompt_rating_title">"Great ! Can you rate us on the Store ?"</string> |   <string name="rating_prompt_rating_title">"Perfecte! Ens podeu puntuar a la Botiga?"</string> | ||||||
|   <string name="rating_prompt_rating_yes">"Sure !"</string> |   <string name="rating_prompt_rating_yes">"Sí."</string> | ||||||
|   <string name="rating_prompt_rating_no">"Not right now."</string> |   <string name="rating_prompt_rating_no">"Ara no."</string> | ||||||
|   <string name="rating_prompt_thanks">"Thanks, your feedback help enhance the app !"</string> |   <string name="rating_prompt_thanks">"Gràcies. La vostra opinió ens ajuda a millorar l'aplicació."</string> | ||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Mostra el recompte d'articles no llegits amb un distintiu a la barra inferior."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Recompte d'articles no llegits"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Recompte d'articles llegits i preferits"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"Sembla que esteu utilitzant un URL no vàlid. Assegureu-vos que és correcte, i si el problema persisteix, poseu-vos en contacte amb mi (a través de l'enllaç de contacte que hi ha a la Botiga). Tingueu en compte que per utilitzar aquesta aplicació cal que també utilitzeu Selfoss. Si no, no podreu accedir a canals RSS."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |   <string name="pref_general_internal_browser_title">"Obre els enllaços dins de l'aplicació"</string> | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |   <string name="pref_general_internal_browser_on">"Els articles s'obriran dins de l'aplicació"</string> | ||||||
|   <string name="invitation_cta">"Try the app"</string> |   <string name="pref_general_internal_browser_off">"Els articles s'obriran amb el navegador predeterminat"</string> | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |   <string name="prefer_article_viewer_title">"Obre el visualitzador d'articles"</string> | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="prefer_article_viewer_on">"S'obrirà el visualitzador d'articles en lloc del navegador intern"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="prefer_article_viewer_off">"S'obrirà el navegador intern en lloc del visualitzador d'articles"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_category_links">"Gestió d'enllaços"</string> | ||||||
|   <string name="prefer_article_viewer_title">"Use the article viewer"</string> |   <string name="pref_general_category_displaying">"Visualització"</string> | ||||||
|   <string name="prefer_article_viewer_on">"Will use the article viewer instead of the internal browser"</string> |   <string name="pref_general_category_actions">"Accions"</string> | ||||||
|   <string name="prefer_article_viewer_off">"Will use the internal browser instead of the article viewer"</string> |   <string name="pref_switch_card_view_on">"Els articles es mostraran com a targetes"</string> | ||||||
|   <string name="pref_general_category_links">"Link handling"</string> |   <string name="pref_switch_card_view_off">"Els articles es mostraran en forma de llista"</string> | ||||||
|   <string name="pref_general_category_displaying">"Displaying"</string> |   <string name="pref_switch_actions_tap_on">"Mostra la barra d'acció sota l'article"</string> | ||||||
|   <string name="pref_general_category_actions">"Actions"</string> |   <string name="pref_switch_actions_tap_off">"En seleccionar un article, s'obrirà al navegador seleccionat"</string> | ||||||
|   <string name="pref_switch_card_view_on">"The articles will be displayed as cards"</string> |   <string name="menu_home_refresh">"Actualitza l'accés remot"</string> | ||||||
|   <string name="pref_switch_card_view_off">"The articles will be displayed as a list"</string> |   <string name="refresh_success_response">"S'ha actualitzat el remot. Torneu a carregar la llista d'articles"</string> | ||||||
|   <string name="pref_switch_actions_tap_on">"Displays the action bar under the article"</string> |   <string name="refresh_failer_message">"L'actualització no ha funcionat. Torneu a provar-ho més tard o consulteu els registres de Selfoss."</string> | ||||||
|   <string name="pref_switch_actions_tap_off">"When selecting an article it will open in your selected browser"</string> |   <string name="refresh_in_progress">"S'està actualitzant"</string> | ||||||
|   <string name="menu_home_refresh">"Update remote"</string> |     <string name="card_height_title">Alçada completa de les targetes</string> | ||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="card_height_on">L\'alçada de les targetes s\'ajustarà al seu contingut</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="card_height_off">L\'alçada de les targetes serà fixa</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="source_code">Codi font</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |   <string name="cant_mark_read">No es pot marcar l\'article com a llegit</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |   <string name="drawer_error_loading_tags">S\'ha produït un error en carregar les etiquetes</string> | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |   <string name="drawer_error_loading_sources">S\'ha produït un error en carregar les fonts</string> | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |   <string name="drawer_item_filters">Filtres</string> | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |   <string name="drawer_action_clear">Esborra</string> | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |   <string name="drawer_item_tags">Etiquetes</string> | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |   <string name="drawer_item_sources">Fonts</string> | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |   <string name="drawer_action_edit">Edita</string> | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |   <string name="cache_drawer_error" tools:keep="@string/cache_drawer_error">La informació del calaix no s\'ha pogut emmagatzemar a la memòria cau</string> | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |   <string name="no_tags_loaded">No s\'ha carregat cap etiqueta</string> | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |   <string name="no_sources_loaded">No s\'ha carregat cap font</string> | ||||||
|   <string name="card_height_title">Full height cards</string> |   <string name="drawer_loading">S\'està carregant…</string> | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="menu_home_search">Cerca</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="can_delete_source">No es pot suprimir la font</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="base_url_error">S\'ha produït un error en comunicar-se amb la instància de Selfoss. Si el problema persisteix, posa\'t en contacte amb mi.</string> | ||||||
|   <string name="cant_mark_read">Can\'t mark article as read</string> |   <string name="pref_header_theme">Temes</string> | ||||||
|   <string name="drawer_error_loading_tags">Error loading tags…</string> |   <string name="default_theme">Predeterminat</string> | ||||||
|   <string name="drawer_error_loading_sources">Error loading sources…</string> |   <string name="default_dark_theme">Predeterminat/Fosc</string> | ||||||
|   <string name="drawer_item_filters">Filters</string> |   <string name="pref_header_debug">Depuració</string> | ||||||
|   <string name="drawer_action_clear">clear</string> |   <string name="login_debug_title">Registra els errors d\'inici de sessió</string> | ||||||
|   <string name="drawer_item_tags">Tags</string> |   <string name="login_debug_on">Es registraran tots els errors que es produeixin a la pàgina d\'inici de sessió</string> | ||||||
|   <string name="drawer_item_sources">Sources</string> |   <string name="login_debug_off">No es registrarà cap error que es produeixi a la pàgina d\'inici de sessió</string> | ||||||
|   <string name="drawer_action_edit">edit</string> |   <string name="login_menu_debug">Depuració</string> | ||||||
|   <string name="cache_drawer_error" tools:keep="@string/cache_drawer_error">Couldn\'t cache your drawer data</string> |   <string name="self_hosted_cert_switch">Utilitzeu un certificat autoallotjat?</string> | ||||||
|   <string name="no_tags_loaded">No tags loaded</string> |   <string name="self_signed_cert_warning">Per raons de seguretat, els certificats autosignats no seran compatibles per defecte. En activar aquesta opció, sereu responsable de qualsevol problema de seguretat que es pugui produir.</string> | ||||||
|   <string name="no_sources_loaded">No sources loaded</string> |   <string name="pref_selfoss_category">API de Selfoss</string> | ||||||
|   <string name="drawer_loading">Loading …</string> |   <string name="pref_api_items_number_title">Nombre d\'elements carregats</string> | ||||||
|   <string name="menu_home_search">Search</string> |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="can_delete_source">Can\'t delete the source…</string> |   <string name="read_debug_title">Voleu llegir els articles que apareixen com a no llegits?</string> | ||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="read_debug_off">No es registraran quan es marquen elements com a llegits</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="read_debug_on">Les crides de l\'API es registraran en marcar un article com a llegit</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="summary_debug_identifier">Identificador de depuració</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |   <string name="unique_id_to_clipboard">S\'ha copiat l\'identificador al porta-retalls</string> | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |   <string name="display_header_drawer_summary">Mostra una capçalera amb la instància URL de Selfoss al panell lateral.</string> | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |   <string name="display_header_drawer_title">Capçalera de menú</string> | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |   <string name="login_everything_title">Registra totes les crides de l\'API</string> | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |   <string name="login_everything_on">Aquesta acció registrarà totes les crides de l\'API per als programadors.</string> | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |   <string name="login_everything_off">No es registrarà cap crida de l\'API</string> | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |   <string name="pref_general_infinite_loading_title">Carrega articles en desplaçar</string> | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |   <string name="translation">Traducció</string> | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="cant_open_invalid_url">L\'element URL no és vàlid. Estic intentant solucionar aquest problema perquè l\'aplicació no falli.</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |   <string name="drawer_report_bug">Informa d\'un error</string> | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |   <string name="items_number_should_be_number">El nombre d\'elements ha de ser enter.</string> | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |   <string name="reader_action_more">Més informació</string> | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |   <string name="reader_action_open">Obre al navegador</string> | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="reader_action_share">Comparteix</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="pref_switch_actions_pager_scroll_on">Es marcaran els articles com a llegits en lliscar el dit d\'un article a l\'altre.</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="add_to_favs_reader">Afegeix als preferits</string> | ||||||
|   <string name="login_debug_off">No log on the login page</string> |   <string name="remove_to_favs_reader">Suprimeix dels preferits</string> | ||||||
|   <string name="login_menu_debug">Debug</string> |   <string name="pref_content_reader_font_size">Mida de la lletra del lector d’articles</string> | ||||||
|   <string name="self_hosted_cert_switch">Using a self hosted certificate ?</string> |   <string name="pref_header_viewer">Visualitzador d\'articles</string> | ||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="refresh_dialog_message">Aquesta acció actualitzarà la vostra instància de Selfoss.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="markall_dialog_message">Aquesta acció marcarà els elements com a llegits.</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_switch_actions_pager_scroll">Marca com a llegit en lliscar el dit</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="pref_switch_actions_pager_scroll_off">No es marcaran els articles com a llegits en lliscar el dit d\'un article a l\'altre.</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="gdpr_dialog_message">Aquesta aplicació no recull cap dada personal. S\'han suprimit totes les eines d\'anàlisi. A partir d\'ara, l\'enviament d\'informes és opcional, així com el registre de depuració d\'errors. Recordeu que la depuració i els informes d\'error són essencials per al desenvolupament de l\'aplicació (Ho podeu configurar tot a Configuració > Depura).</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="gdpr_dialog_title">Aquesta aplicació no comparteix cap dada personal vostra.</string> | ||||||
|   <string name="summary_debug_identifier">Debug identifier</string> |   <string name="crash_dialog_text">Alguna cosa ha anat malament. Envieu l\'informe al desenvolupador.</string> | ||||||
|   <string name="unique_id_to_clipboard">Identifier copied to your clipboard</string> |   <string name="crash_dialog_comment">Podeu afegir informació útil en la secció de comentaris. No incloeu cap dada personal en el vostre comentari. També em podeu enviar un correu electrònic amb l\'identificador de depuració i us ho faré saber quan el problema s\'hagi resolt.</string> | ||||||
|   <string name="display_header_drawer_summary">Display a header with the selfoss instance url on the lateral drawer.</string> |     <string name="pref_acra_alwaysaccept">Envia informes d\'error automàtics</string> | ||||||
|   <string name="display_header_drawer_title">Account header</string> |   <string name="pref_acra_alwaysaccept_enabled">S\'enviaran informes d\'error automàticament</string> | ||||||
|   <string name="login_everything_title">Logging every api calls</string> |   <string name="pref_acra_alwaysaccept_disabled">Us preguntarem abans d\'enviar un informe d\'error.</string> | ||||||
|   <string name="login_everything_on">This will log every api call for debug purpose.</string> |   <string name="pref_debug_crash_reports">Informes d\'error</string> | ||||||
|   <string name="login_everything_off">No api call will be logged</string> |   <string name="pref_debug_debug_logs">Registre de depuració (s\'enviarà automàticament)</string> | ||||||
|   <string name="pref_general_infinite_loading_title">Load more articles on scroll</string> |   <string name="acra_login">Habilita el registre</string> | ||||||
|   <string name="translation">Translation</string> |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="cant_open_invalid_url">The item url is invalid. I\'m looking into solving this issue so the app won\'t crash.</string> |   <string name="unmark">Mark item as unread</string> | ||||||
|   <string name="drawer_report_bug">Report a bug</string> |  | ||||||
|   <string name="items_number_should_be_number">The items number should be an integer.</string> |  | ||||||
|   <string name="reader_action_more">Read more</string> |  | ||||||
|   <string name="reader_action_open">Open in browser</string> |  | ||||||
|   <string name="reader_action_share">Share</string> |  | ||||||
|   <string name="pref_switch_actions_pager_scroll_on">Mark articles as read when swiping between articles.</string> |  | ||||||
|   <string name="add_to_favs_reader">Add to favorites</string> |  | ||||||
|   <string name="remove_to_favs_reader">Remove from favorites</string> |  | ||||||
|   <string name="pref_content_reader_font_size">Article reader content font size</string> |  | ||||||
|   <string name="pref_header_viewer">Article viewer</string> |  | ||||||
|   <string name="refresh_dialog_message">This will refresh your Selfoss instance.</string> |  | ||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |  | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |  | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |  | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Zeige die Zahl ungelesener Artikel in der unteren Leiste."</string> |   <string name="switch_unread_count">"Zeige die Zahl ungelesener Artikel in der unteren Leiste."</string> | ||||||
|   <string name="switch_unread_count_title">"Zeige Anzahl ungelesener Artikel"</string> |   <string name="switch_unread_count_title">"Zeige Anzahl ungelesener Artikel"</string> | ||||||
|   <string name="display_all_counts_title">"Zeige Anzahl der Favoriten und gelesenen Artikel"</string> |   <string name="display_all_counts_title">"Zeige Anzahl der Favoriten und gelesenen Artikel"</string> | ||||||
|   <string name="menu_share_the_app">"Freunde einladen"</string> |     <string name="text_wrong_url">"Sie scheinen eine ungültige URL verwenden. Stellen Sie sicher, dass die URL richtig ist. Sollte das Problem weiterhin bestehen kontaktieren Sie mich (über den Playstore-Kontakt-Link). Bitte beachten Sie, dass Sie Selfoss benötigen um RSS-Feeds zu lesen."</string> | ||||||
|   <string name="invitation_title">"Probiere diese App für deine Selfoss RSS-Feeds!"</string> |  | ||||||
|   <string name="invitation_message">"Ich benutze diese App für meine Selfoss RSS-Feeds. Vielleicht magst du sie auch!"</string> |  | ||||||
|   <string name="invitation_cta">"Probier die App"</string> |  | ||||||
|   <string name="text_wrong_url">"Sie scheinen eine ungültige URL verwenden. Stellen Sie sicher, dass die URL richtig ist. Sollte das Problem weiterhin bestehen kontaktieren Sie mich (über den Playstore-Kontakt-Link). Bitte beachten Sie, dass Sie Selfoss benötigen um RSS-Feeds zu lesen."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Öffne Links innerhalb der App"</string> |   <string name="pref_general_internal_browser_title">"Öffne Links innerhalb der App"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Artikel werden innerhalb der App geöffnet"</string> |   <string name="pref_general_internal_browser_on">"Artikel werden innerhalb der App geöffnet"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Artikel werden mit deinem Standard-Browser geöffnet"</string> |   <string name="pref_general_internal_browser_off">"Artikel werden mit deinem Standard-Browser geöffnet"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"Selfoss wird aktualisiert, du kannst jetzt die Artikel laden"</string> |   <string name="refresh_success_response">"Selfoss wird aktualisiert, du kannst jetzt die Artikel laden"</string> | ||||||
|   <string name="refresh_failer_message">"Das Update hat nicht funktioniert, versuche es erneut oder überprüfe die Protokolle von Selfoss."</string> |   <string name="refresh_failer_message">"Das Update hat nicht funktioniert, versuche es erneut oder überprüfe die Protokolle von Selfoss."</string> | ||||||
|   <string name="refresh_in_progress">"Aktualisierung läuft"</string> |   <string name="refresh_in_progress">"Aktualisierung läuft"</string> | ||||||
|   <string name="new_apk_available_title">"Eine neue Version ist verfügbar."</string> |     <string name="card_height_title">Maximale Kartenhöhe</string> | ||||||
|   <string name="new_apk_available_message">"Eine neue APK steht im offiziellen Repository zur Verfügung."</string> |  | ||||||
|   <string name="new_apk_available_get">"Jetzt herunterladen"</string> |  | ||||||
|   <string name="new_apk_available_no">"Version ignorieren"</string> |  | ||||||
|   <string name="intro_hello_title">"Hallo!"</string> |  | ||||||
|   <string name="intro_hello_message">"Danke fürs Herunterladen der App!"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Bevor du beginnst…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"Die App kann nicht ohne Selfoss-Instanz benutzt werden."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"Was ist Selfoss?"</string> |  | ||||||
|   <string name="intro_all_set_title">"Fertig!"</string> |  | ||||||
|   <string name="intro_all_set_message">"Sie können die App jetzt verwenden. Vergiss nicht deine App unter \"Einstellungen\" zu konfigurieren. Dort findest du auch einige nützliche Links."</string> |  | ||||||
|   <string name="card_height_title">Maximale Kartenhöhe</string> |  | ||||||
|   <string name="card_height_on">Kartenhöhe passt sich Inhalt an</string> |   <string name="card_height_on">Kartenhöhe passt sich Inhalt an</string> | ||||||
|   <string name="card_height_off">Kartenhöhe ist fix</string> |   <string name="card_height_off">Kartenhöhe ist fix</string> | ||||||
|   <string name="source_code">Quellcode</string> |   <string name="source_code">Quellcode</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">Beim Versuch deine Selfoss-Instanz zu erreichen ist ein Fehler aufgetreten. Solltet dieser Fehler bestehen bleiben, trete bitte mit mir in Kontakt.</string> |   <string name="base_url_error">Beim Versuch deine Selfoss-Instanz zu erreichen ist ein Fehler aufgetreten. Solltet dieser Fehler bestehen bleiben, trete bitte mit mir in Kontakt.</string> | ||||||
|   <string name="pref_header_theme">Designs</string> |   <string name="pref_header_theme">Designs</string> | ||||||
|   <string name="default_theme">Standard</string> |   <string name="default_theme">Standard</string> | ||||||
|   <string name="teal_orange_theme">Türkis/Orange/Hell</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Hell</string> |  | ||||||
|   <string name="grey_orange_theme">Türkis/Orange/Hell</string> |  | ||||||
|   <string name="blue_amber_theme">Blau/Amber/Hell</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Hell</string> |  | ||||||
|   <string name="red_teal_theme">Rot/Türkis/Hell</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Türkis/Orange/Dunkel</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dunkel</string> |  | ||||||
|   <string name="default_dark_theme">Standard (Dunkel)</string> |   <string name="default_dark_theme">Standard (Dunkel)</string> | ||||||
|   <string name="grey_orange_dark_theme">Grau/Orange/Dunkel</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blau/Gelb/Dunkel</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dunkel</string> |  | ||||||
|   <string name="red_teal_dark_theme">Rot/Türkis/Dunkel</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Aktivieren, um Login-Fehler zu protokollieren</string> |   <string name="login_debug_title">Aktivieren, um Login-Fehler zu protokollieren</string> | ||||||
|   <string name="login_debug_on">Fehler auf der Login-Seite werden protokolliert</string> |   <string name="login_debug_on">Fehler auf der Login-Seite werden protokolliert</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">selfoss API</string> |   <string name="pref_selfoss_category">selfoss API</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Mostrar el recuento no leído como una insignia de la barra inferior."</string> |   <string name="switch_unread_count">"Mostrar el recuento no leído como una insignia de la barra inferior."</string> | ||||||
|   <string name="switch_unread_count_title">"Mostrar recuento no leído"</string> |   <string name="switch_unread_count_title">"Mostrar recuento no leído"</string> | ||||||
|   <string name="display_all_counts_title">"Mostrar recuento de favoritos y leídos"</string> |   <string name="display_all_counts_title">"Mostrar recuento de favoritos y leídos"</string> | ||||||
|   <string name="menu_share_the_app">"Invitar amigos"</string> |     <string name="text_wrong_url">"Parece estar tratando de utilizar una dirección URL inválida. Asegúrese de que sea correcta y si el problema persiste, póngase en contacto conmigo (mediante el enlace de contacto de la tienda). Tenga en cuenta que la aplicación necesita utilizar Selfoss. No se puede acceder al contenido RSS sin él."</string> | ||||||
|   <string name="invitation_title">"¡Prueba esta aplicación para tu contenido RSS de Selfoss!"</string> |  | ||||||
|   <string name="invitation_message">"Yo uso esta aplicación para mi contenido RSS de Selfoss. ¡Te puede gusta también!"</string> |  | ||||||
|   <string name="invitation_cta">"Probar la aplicación"</string> |  | ||||||
|   <string name="text_wrong_url">"Parece estar tratando de utilizar una dirección URL inválida. Asegúrese de que sea correcta y si el problema persiste, póngase en contacto conmigo (mediante el enlace de contacto de la tienda). Tenga en cuenta que la aplicación necesita utilizar Selfoss. No se puede acceder al contenido RSS sin él."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Abrir enlaces dentro de la aplicación"</string> |   <string name="pref_general_internal_browser_title">"Abrir enlaces dentro de la aplicación"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Los artículos se abrirán dentro de la aplicación"</string> |   <string name="pref_general_internal_browser_on">"Los artículos se abrirán dentro de la aplicación"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Los artículos se abrirán con tu navegador predeterminado"</string> |   <string name="pref_general_internal_browser_off">"Los artículos se abrirán con tu navegador predeterminado"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"Se actualizó el remoto, ahora puede recargar la lista de artículos"</string> |   <string name="refresh_success_response">"Se actualizó el remoto, ahora puede recargar la lista de artículos"</string> | ||||||
|   <string name="refresh_failer_message">"La actualización no funcionó, inténtalo más tarde o compruebe los registros de selfoss."</string> |   <string name="refresh_failer_message">"La actualización no funcionó, inténtalo más tarde o compruebe los registros de selfoss."</string> | ||||||
|   <string name="refresh_in_progress">"Actualización en progreso"</string> |   <string name="refresh_in_progress">"Actualización en progreso"</string> | ||||||
|   <string name="new_apk_available_title">"Una nueva versión está disponible."</string> |     <string name="card_height_title">Tarjetas de altura completas</string> | ||||||
|   <string name="new_apk_available_message">"Un APK nuevo está disponible para descarga en el repositorio oficial."</string> |  | ||||||
|   <string name="new_apk_available_get">"Descargar ahora"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignorar versión"</string> |  | ||||||
|   <string name="intro_hello_title">"¡Hola!"</string> |  | ||||||
|   <string name="intro_hello_message">"¡Gracias por descargar la aplicación!"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Antes de empezar…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"No se puede utilizar la aplicación sin una instancia de Selfoss."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"¿Qué es Selfoss?"</string> |  | ||||||
|   <string name="intro_all_set_title">"¡Todo listo!"</string> |  | ||||||
|   <string name="intro_all_set_message">"Estás listo para utilizar la aplicación. No olvides ir a la página de configuración para configurar su aplicación, y donde usted encontrará algunos enlaces útiles."</string> |  | ||||||
|   <string name="card_height_title">Tarjetas de altura completas</string> |  | ||||||
|   <string name="card_height_on">Altura de tarjetas se ajustará a su contenido</string> |   <string name="card_height_on">Altura de tarjetas se ajustará a su contenido</string> | ||||||
|   <string name="card_height_off">Se fijará la altura de la tarjeta</string> |   <string name="card_height_off">Se fijará la altura de la tarjeta</string> | ||||||
|   <string name="source_code">Código fuente</string> |   <string name="source_code">Código fuente</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">Hubo un problema al intentar comunicarse con su instancia de Selfoss. Si el problema persiste, póngase en contacto conmigo.</string> |   <string name="base_url_error">Hubo un problema al intentar comunicarse con su instancia de Selfoss. Si el problema persiste, póngase en contacto conmigo.</string> | ||||||
|   <string name="pref_header_theme">Temas</string> |   <string name="pref_header_theme">Temas</string> | ||||||
|   <string name="default_theme">Predeterminado</string> |   <string name="default_theme">Predeterminado</string> | ||||||
|   <string name="teal_orange_theme">Turquesa/Naranja/Claro</string> |  | ||||||
|   <string name="cyan_pink_theme">Cian/Rosa/Claro</string> |  | ||||||
|   <string name="grey_orange_theme">Gris/Naranja/Claro</string> |  | ||||||
|   <string name="blue_amber_theme">Azul/Ámbar/Claro</string> |  | ||||||
|   <string name="indigo_pink_theme">Índigo/Rosa/Claro</string> |  | ||||||
|   <string name="red_teal_theme">Rojo/Turquesa/Claro</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Turquesa/Naranja/Oscuro</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cian/Rosa/Oscuro</string> |  | ||||||
|   <string name="default_dark_theme">Predeterminado/Oscuro</string> |   <string name="default_dark_theme">Predeterminado/Oscuro</string> | ||||||
|   <string name="grey_orange_dark_theme">Gris/Naranja/Oscuro</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Azul/Ámbar/Oscuro</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Índigo/Rosa/Oscuro</string> |  | ||||||
|   <string name="red_teal_dark_theme">Rojo/Turquesa/Oscuro</string> |  | ||||||
|   <string name="pref_header_debug">Depurar</string> |   <string name="pref_header_debug">Depurar</string> | ||||||
|   <string name="login_debug_title">Activar para registrar errores de inicio de sesión</string> |   <string name="login_debug_title">Activar para registrar errores de inicio de sesión</string> | ||||||
|   <string name="login_debug_on">Cualquier error en la página de inicio de sesión se registrará</string> |   <string name="login_debug_on">Cualquier error en la página de inicio de sesión se registrará</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Por razones de seguridad, los certificados propios no son compatibles por defecto. Activando esto, no seré responsable de cualquier problema de seguridad que encuentre.</string> |   <string name="self_signed_cert_warning">Por razones de seguridad, los certificados propios no son compatibles por defecto. Activando esto, no seré responsable de cualquier problema de seguridad que encuentre.</string> | ||||||
|   <string name="pref_selfoss_category">Api de Selfoss</string> |   <string name="pref_selfoss_category">Api de Selfoss</string> | ||||||
|   <string name="pref_api_items_number_title">Número de artículos cargados</string> |   <string name="pref_api_items_number_title">Número de artículos cargados</string> | ||||||
|  |   <string name="pref_hidden_tags">Etiquetas ocultas</string> | ||||||
|   <string name="read_debug_title">¿Leer los artículos que aparecen como no leídos?</string> |   <string name="read_debug_title">¿Leer los artículos que aparecen como no leídos?</string> | ||||||
|   <string name="read_debug_off">Sin registro al marcar un elemento como leído</string> |   <string name="read_debug_off">Sin registro al marcar un elemento como leído</string> | ||||||
|   <string name="read_debug_on">Llamadas a la Api se registrarán al marcar un artículo como leído</string> |   <string name="read_debug_on">Llamadas a la Api se registrarán al marcar un artículo como leído</string> | ||||||
| @@ -161,10 +135,22 @@ | |||||||
|   <string name="pref_switch_actions_pager_scroll_on">Marcar artículos como leidos al desplazarse entre ellos.</string> |   <string name="pref_switch_actions_pager_scroll_on">Marcar artículos como leidos al desplazarse entre ellos.</string> | ||||||
|   <string name="add_to_favs_reader">Añadir a Favoritos</string> |   <string name="add_to_favs_reader">Añadir a Favoritos</string> | ||||||
|   <string name="remove_to_favs_reader">Eliminar de favoritos</string> |   <string name="remove_to_favs_reader">Eliminar de favoritos</string> | ||||||
|   <string name="pref_content_reader_font_size">Tamaño de la fuente</string> |   <string name="pref_content_reader_font_size">Tamaño de la fuente del lector</string> | ||||||
|   <string name="pref_header_viewer">Visor de artículos</string> |   <string name="pref_header_viewer">Visor de artículos</string> | ||||||
|   <string name="refresh_dialog_message">Esto actualizará su instancia de Selfoss.</string> |   <string name="refresh_dialog_message">Esto actualizará su instancia de Selfoss.</string> | ||||||
|   <string name="markall_dialog_message">Esto marcará todos los artículos como leídos.</string> |   <string name="markall_dialog_message">Esto marcará todos los artículos como leídos.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Marcar como leído al arrastrar</string> |   <string name="pref_switch_actions_pager_scroll">Marcar artículos como leídos al deslizar con el dedo hacia los lados</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">No marca artículos como leídos al arrastrar.</string> |   <string name="pref_switch_actions_pager_scroll_off">No marcar artículos como leídos al deslizar con el dedo hacia los lados.</string> | ||||||
|  |   <string name="gdpr_dialog_message">La aplicación no recopila ningún dato personal. Todas las herramientas de analítica fueron eliminadas. El envío de informes de errores es opcional, así como los registros de depuración. Ten en cuenta que tanto los registros como los informes de errores son esenciales para el desarrollo de la aplicación (Puedes configurar todo en \"Configuración > Depurar\").</string> | ||||||
|  |   <string name="gdpr_dialog_title">La aplicación no comparte ningún dato personal sobre usted.</string> | ||||||
|  |   <string name="crash_dialog_text">Algo salió mal. Envié el informe al desarrollador.</string> | ||||||
|  |   <string name="crash_dialog_comment">Puede agregar cualquier información útil en el siguiente comentario. No incluya ningún dato personal en el comentario. Podría enviarme un correo electrónico con el id de depuración para ser notificado cuando el problema se resuelva.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Enviar automáticamente informe de fallos</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Se enviaran automáticamente los informes de fallos</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Le preguntará al enviar informes de fallos.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Informe de fallos</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Registro de depuración (éstos se enviarán sin diálogo)</string> | ||||||
|  |   <string name="acra_login">Habilitar el registro</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Etiquetas ocultas</string> | ||||||
|  |   <string name="unmark">Marcar artículo como no leído</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Afficher le nombre d'articles non lus sur la barre en bas de l'écran"</string> |   <string name="switch_unread_count">"Afficher le nombre d'articles non lus sur la barre en bas de l'écran"</string> | ||||||
|   <string name="switch_unread_count_title">"Afficher le nombre de non lus"</string> |   <string name="switch_unread_count_title">"Afficher le nombre de non lus"</string> | ||||||
|   <string name="display_all_counts_title">"Afficher le nombre de favoris et d'articles lus"</string> |   <string name="display_all_counts_title">"Afficher le nombre de favoris et d'articles lus"</string> | ||||||
|   <string name="menu_share_the_app">"Inviter des amis"</string> |     <string name="text_wrong_url">"Vous semblez essayer de vous connecter avec une URL invalide. Assurez-vous que c'est la bonne, et si le problème persiste, contactez-moi via le lien du play store. Notez aussi que l'application ne peut fonctionner sans l'application web Selfoss. Vous ne pouvez pas utiliser l'application pour accéder directement aux flux RSS."</string> | ||||||
|   <string name="invitation_title">"Essaye cette application pour les flux RSS Selfoss !"</string> |  | ||||||
|   <string name="invitation_message">"J'utilise cette applications pour mon flux RSS Selfoss. Tu aimeras peut être !"</string> |  | ||||||
|   <string name="invitation_cta">"Essayer maintenant"</string> |  | ||||||
|   <string name="text_wrong_url">"Vous semblez essayer de vous connecter avec une URL invalide. Assurez-vous que c'est la bonne, et si le problème persiste, contactez-moi via le lien du play store. Notez aussi que l'application ne peut fonctionner sans l'application web Selfoss. Vous ne pouvez pas utiliser l'application pour accéder directement aux flux RSS."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Ouvrir les liens dans l'application"</string> |   <string name="pref_general_internal_browser_title">"Ouvrir les liens dans l'application"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Les articles s'ouvriront dans l'application"</string> |   <string name="pref_general_internal_browser_on">"Les articles s'ouvriront dans l'application"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Les articles s'ouvriront dans votre naviguateur par défaut"</string> |   <string name="pref_general_internal_browser_off">"Les articles s'ouvriront dans votre naviguateur par défaut"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"Mise à jour effectuée."</string> |   <string name="refresh_success_response">"Mise à jour effectuée."</string> | ||||||
|   <string name="refresh_failer_message">"La mise à jour n'a pas fonctionné. Vérifiez vos logs selfoss."</string> |   <string name="refresh_failer_message">"La mise à jour n'a pas fonctionné. Vérifiez vos logs selfoss."</string> | ||||||
|   <string name="refresh_in_progress">"Mise à jour en cours"</string> |   <string name="refresh_in_progress">"Mise à jour en cours"</string> | ||||||
|   <string name="new_apk_available_title">"Nouvelle version disponible"</string> |     <string name="card_height_title">Taille dynamique des cartes</string> | ||||||
|   <string name="new_apk_available_message">"Une nouvelle version officielle de l'application est disponible."</string> |  | ||||||
|   <string name="new_apk_available_get">"Télécharger maintenant"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignorer cette version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hey !"</string> |  | ||||||
|   <string name="intro_hello_message">"Merci d'avoir installé mon application !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Avant de commencer…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"Cette application ne peut fonctionner sans une instance de Selfoss"</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"Où trouver Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"Tout semble bon !"</string> |  | ||||||
|   <string name="intro_all_set_message">"Vous êtes prêt à utiliser l'application. N'oubliez pas de consulter l'écran de configuration pour paramétrer l'application à votre goût, et trouver toutes sortes de liens utiles."</string> |  | ||||||
|   <string name="card_height_title">Taille dynamique des cartes</string> |  | ||||||
|   <string name="card_height_on">La taille de la carte s\'adaptera au contenu</string> |   <string name="card_height_on">La taille de la carte s\'adaptera au contenu</string> | ||||||
|   <string name="card_height_off">La taille de la carte sera fixe</string> |   <string name="card_height_off">La taille de la carte sera fixe</string> | ||||||
|   <string name="source_code">Code source</string> |   <string name="source_code">Code source</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">Il y a eu un souci lors de la communication avec votre instance Selfoss. Si le problèmes persiste, contactez-moi pour trouver une solution.</string> |   <string name="base_url_error">Il y a eu un souci lors de la communication avec votre instance Selfoss. Si le problèmes persiste, contactez-moi pour trouver une solution.</string> | ||||||
|   <string name="pref_header_theme">Thèmes</string> |   <string name="pref_header_theme">Thèmes</string> | ||||||
|   <string name="default_theme">Par défaut</string> |   <string name="default_theme">Par défaut</string> | ||||||
|   <string name="teal_orange_theme">Sarcelle/Orange/Clair</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Rose/Clair</string> |  | ||||||
|   <string name="grey_orange_theme">Gris/Orange/Clair</string> |  | ||||||
|   <string name="blue_amber_theme">Bleu/Ambre/Clair</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Rose/Clair</string> |  | ||||||
|   <string name="red_teal_theme">Rouge/Sarcelle/Clair</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Sarcelle/Orange/Foncé</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Rose/Foncé</string> |  | ||||||
|   <string name="default_dark_theme">Par défaut/Foncé</string> |   <string name="default_dark_theme">Par défaut/Foncé</string> | ||||||
|   <string name="grey_orange_dark_theme">Gris/Orange/Foncé</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Bleu/Ambre/Foncé</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Rose/Foncé</string> |  | ||||||
|   <string name="red_teal_dark_theme">Rouge/Sarcelle/Foncé</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activez pour loguer toutes les erreurs de connexion</string> |   <string name="login_debug_title">Activez pour loguer toutes les erreurs de connexion</string> | ||||||
|   <string name="login_debug_on">Toutes les erreurs de connexion vont être loguées</string> |   <string name="login_debug_on">Toutes les erreurs de connexion vont être loguées</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Pour des raisons de sécurité, les certificats auto-signés sont désactivés par défaut. En les activant, je ne serais pas responsable de quelconques problèmes de sécurité rencontrés.</string> |   <string name="self_signed_cert_warning">Pour des raisons de sécurité, les certificats auto-signés sont désactivés par défaut. En les activant, je ne serais pas responsable de quelconques problèmes de sécurité rencontrés.</string> | ||||||
|   <string name="pref_selfoss_category">Api Selfoss</string> |   <string name="pref_selfoss_category">Api Selfoss</string> | ||||||
|   <string name="pref_api_items_number_title">Nombre d\'articles chargés</string> |   <string name="pref_api_items_number_title">Nombre d\'articles chargés</string> | ||||||
|  |   <string name="pref_hidden_tags">Tags Cachés</string> | ||||||
|   <string name="read_debug_title">Des articles lus marqués comme non lus ?</string> |   <string name="read_debug_title">Des articles lus marqués comme non lus ?</string> | ||||||
|   <string name="read_debug_off">Aucun log quand un article est marqué comme lu</string> |   <string name="read_debug_off">Aucun log quand un article est marqué comme lu</string> | ||||||
|   <string name="read_debug_on">Les appels API vont être logués lorsqu\'un article est marqué comme lu</string> |   <string name="read_debug_on">Les appels API vont être logués lorsqu\'un article est marqué comme lu</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">Marquer tous les éléments comme lus ?</string> |   <string name="markall_dialog_message">Marquer tous les éléments comme lus ?</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Marquer comme lu à la navigation.</string> |   <string name="pref_switch_actions_pager_scroll">Marquer comme lu à la navigation.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Ne pas marquer les articles comme lus à la navigation.</string> |   <string name="pref_switch_actions_pager_scroll_off">Ne pas marquer les articles comme lus à la navigation.</string> | ||||||
|  |   <string name="gdpr_dialog_message">L\'application ne collecte aucune donnée personnelle. Tous les outils d\'analytics ont été supprimés. Les rapports d\'erreurs sont maintenant optionnels, ainsi que les logs. N\'oubliez pas que les rapports d\'erreurs sont essentiels pour la résolution des bugs (vous pouvez configurer tout cela dans Paramètres > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">L\'application ne partage aucune de vos données.</string> | ||||||
|  |   <string name="crash_dialog_text">Quelque chose s\'est mal passé, S\'il vous plaît, envoyez le rapport au développeur.</string> | ||||||
|  |   <string name="crash_dialog_comment">Vous pouvez ajouter tous les détails utiles dans le champ de commentaire plus bas. N\'ajoutez aucune information personnelle. Vous pouvez m\'envoyer un email avec votre identifiant de debug, et je vous informerai à la correction du problème.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Envoyer automatiquement les rapports d\'erreur</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Enverra automatiquement les rapports d\'erreur</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Demandera une confirmation à chaque incident.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Rapport d\'erreur</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Log de debug (seront envoyés automatiquement)</string> | ||||||
|  |   <string name="acra_login">Activer les logs</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Tags Cachés</string> | ||||||
|  |   <string name="unmark">Marquer l\'article comme non lu</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
							
								
								
									
										156
									
								
								app/src/main/res/values-gl-rES/strings.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										156
									
								
								app/src/main/res/values-gl-rES/strings.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,156 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <!--Generated by crowdin.com--> | ||||||
|  | <resources xmlns:tools="http://schemas.android.com/tools"> | ||||||
|  |   <string name="app_name">"Lector para Selfoss"</string> | ||||||
|  |   <string name="title_activity_login">"Acceder"</string> | ||||||
|  |   <string name="prompt_password">"Contrasinal"</string> | ||||||
|  |   <string name="prompt_http_password">"Contrasinal HTTP"</string> | ||||||
|  |   <string name="action_sign_in">"Ir"</string> | ||||||
|  |   <string name="error_invalid_password">"O contrasinal non é suficientemente longo"</string> | ||||||
|  |   <string name="error_field_required">"Campo requirido"</string> | ||||||
|  |   <string name="prompt_url">"URL"</string> | ||||||
|  |   <string name="withLoginSwitch">"É preciso iniciar sesión?"</string> | ||||||
|  |   <string name="withHttpLoginSwitch">"É preciso iniciar sesión HTTP?"</string> | ||||||
|  |   <string name="login_url_problem">"Ups! Pode que precises engadir un \"/\" o final da URL."</string> | ||||||
|  |   <string name="prompt_login">"Nome de usuario"</string> | ||||||
|  |   <string name="prompt_http_login">"Nome de usuario HTTP"</string> | ||||||
|  |   <string name="label_share">"Compartir"</string> | ||||||
|  |   <string name="readAll">"Ler todos"</string> | ||||||
|  |   <string name="action_disconnect">"Desconectar"</string> | ||||||
|  |   <string name="title_activity_settings">"Axustes"</string> | ||||||
|  |   <string name="pref_header_general">"Xeral"</string> | ||||||
|  |   <string name="pref_switch_actions_tap_title">"Dar un toque nos artigos"</string> | ||||||
|  |   <string name="add_source_hint_tags">"Etiqueta1, Etiqueta2, Etiqueta3"</string> | ||||||
|  |   <string name="add_source_hint_url">"Ligazón"</string> | ||||||
|  |   <string name="add_source_hint_name">"Nome"</string> | ||||||
|  |   <string name="add_source">"Engadir unha fonte"</string> | ||||||
|  |   <string name="add_source_save">"Gardar"</string> | ||||||
|  |   <string name="wrong_infos">"Comprobar os teus detalles de novo."</string> | ||||||
|  |   <string name="all_posts_not_read">"Non se leron todas as publicacións"</string> | ||||||
|  |   <string name="all_posts_read">"Leronse todas as publicacións"</string> | ||||||
|  |   <string name="cant_get_favs">"Non se poden obter os favoritos"</string> | ||||||
|  |   <string name="cant_get_new_elements">"Non se poden recibir os novos artigos"</string> | ||||||
|  |   <string name="cant_get_read">"Non se poden recibir os artigos lidos"</string> | ||||||
|  |   <string name="nothing_here">"Non hai nada aquí"</string> | ||||||
|  |   <string name="tab_new">"Novo"</string> | ||||||
|  |   <string name="tab_read">"Todos"</string> | ||||||
|  |   <string name="tab_favs">"Favoritos"</string> | ||||||
|  |   <string name="action_about">"Acerca de"</string> | ||||||
|  |   <string name="marked_as_read">"Elemento lido"</string> | ||||||
|  |   <string name="undo_string">"Desfacer"</string> | ||||||
|  |   <string name="addStringNoUrl">"Accede pra engadir fontes."</string> | ||||||
|  |   <string name="cant_get_sources">"Non se pode obter a lista de fontes."</string> | ||||||
|  |   <string name="cant_create_source">"Non se pode crear unha fonte."</string> | ||||||
|  |   <string name="cant_get_spouts">"Non se pode obter a lista de fontes."</string> | ||||||
|  |   <string name="form_not_complete">"O formulario non está completo"</string> | ||||||
|  |   <string name="pref_header_links">"Ligazóns"</string> | ||||||
|  |   <string name="issue_tracker_link">"Rastrexador de Incidencias"</string> | ||||||
|  |   <string name="issue_tracker_summary">"Informar dun erro ou pedir unha nova característica"</string> | ||||||
|  |   <string name="warning_wrong_url">"AVISO"</string> | ||||||
|  |   <string name="pref_switch_card_view_title">"Vista de tarxeta"</string> | ||||||
|  |   <string name="cant_mark_favortie">"Non se pode marcar o artigo como favorito"</string> | ||||||
|  |   <string name="cant_unmark_favortie">"Non se pode eliminar o elemento dos favoritos"</string> | ||||||
|  |   <string name="share">"Compartir"</string> | ||||||
|  |   <string name="rating_prompt_title">"Estás gozando coa aplicación?"</string> | ||||||
|  |   <string name="rating_prompt_yes">"Si !"</string> | ||||||
|  |   <string name="rating_prompt_no">"Non moito …"</string> | ||||||
|  |   <string name="rating_prompt_feedback_title">"Podes dicirnos por qué?"</string> | ||||||
|  |   <string name="rating_prompt_feedback_yes">"Dacordo!"</string> | ||||||
|  |   <string name="rating_prompt_feedback_no">"Agora non."</string> | ||||||
|  |   <string name="rating_prompt_rating_title">"Xenial! Podes puntuarnos na tenda?"</string> | ||||||
|  |   <string name="rating_prompt_rating_yes">"Claro!"</string> | ||||||
|  |   <string name="rating_prompt_rating_no">"Agora mesmo non."</string> | ||||||
|  |   <string name="rating_prompt_thanks">"Grazas, a túa opinión axudanos a mellorar a aplicación!"</string> | ||||||
|  |   <string name="switch_unread_count">"Mostrar o reconto de artigos non lidos cunha insignia na barra inferior."</string> | ||||||
|  |   <string name="switch_unread_count_title">"Mostrar reconto de artigos non lidos"</string> | ||||||
|  |   <string name="display_all_counts_title">"Mostrar reconto de artigos lidos e favoritos"</string> | ||||||
|  |     <string name="text_wrong_url">"Semella que intentas usar unha URL non válida. Asegúrate de que é correcta, e se o problema persiste, ponte en contacto conmigo (a través da ligazón de contacto na tenda). Por favor ten en conta que a aplicación precisa que uses Selfoss. Non podes acceder a canles RSS se non o tes."</string> | ||||||
|  |   <string name="pref_general_internal_browser_title">"Abrir ligazóns dentro da aplicación"</string> | ||||||
|  |   <string name="pref_general_internal_browser_on">"Os artigos abriranse dentro da aplicación"</string> | ||||||
|  |   <string name="pref_general_internal_browser_off">"Os artigos abriranse co teu navegador prederminado"</string> | ||||||
|  |   <string name="prefer_article_viewer_title">"Usar o visor de artigos"</string> | ||||||
|  |   <string name="prefer_article_viewer_on">"Usarase o visor de artigos en lugar do navegador interno"</string> | ||||||
|  |   <string name="prefer_article_viewer_off">"Usarase o navegador interno en lugar do visor de artigos"</string> | ||||||
|  |   <string name="pref_general_category_links">"Xestión de ligazóns"</string> | ||||||
|  |   <string name="pref_general_category_displaying">"Visualización"</string> | ||||||
|  |   <string name="pref_general_category_actions">"Accións"</string> | ||||||
|  |   <string name="pref_switch_card_view_on">"Os artigos amosaranse coma tarxetas"</string> | ||||||
|  |   <string name="pref_switch_card_view_off">"Os artigos amosaranse coma unha lista"</string> | ||||||
|  |   <string name="pref_switch_actions_tap_on">"Amosar a barra de acción debaixo do artigo"</string> | ||||||
|  |   <string name="pref_switch_actions_tap_off">"Ao seleccionar un artigo, abrirase no navegador escollido"</string> | ||||||
|  |   <string name="menu_home_refresh">"Actualizar o remoto"</string> | ||||||
|  |   <string name="refresh_success_response">"O remoto foi actualizado, xa podes refrescar a lista de artigos"</string> | ||||||
|  |   <string name="refresh_failer_message">"A actualización non funcionou, proba de novo máis tarde ou comproba os teus rexistros de Selfoss."</string> | ||||||
|  |   <string name="refresh_in_progress">"Actualizazación en progreso"</string> | ||||||
|  |     <string name="card_height_title">Tarxetas de altura completa</string> | ||||||
|  |   <string name="card_height_on">A altura das tarxetas axustarase ao seu contido</string> | ||||||
|  |   <string name="card_height_off">A altura das tarxetas será fixa</string> | ||||||
|  |   <string name="source_code">Código fonte</string> | ||||||
|  |   <string name="cant_mark_read">Non se pode marcar o artigo como lido</string> | ||||||
|  |   <string name="drawer_error_loading_tags">Produciuse un erro ao cargar as etiquetas…</string> | ||||||
|  |   <string name="drawer_error_loading_sources">Produciuse un erro ao cargar as fontes…</string> | ||||||
|  |   <string name="drawer_item_filters">Filtros</string> | ||||||
|  |   <string name="drawer_action_clear">limpar</string> | ||||||
|  |   <string name="drawer_item_tags">Etiquetas</string> | ||||||
|  |   <string name="drawer_item_sources">Fontes</string> | ||||||
|  |   <string name="drawer_action_edit">editar</string> | ||||||
|  |   <string name="cache_drawer_error" tools:keep="@string/cache_drawer_error">Non se puideron gardar na memoria os datos do seu panel</string> | ||||||
|  |   <string name="no_tags_loaded">Non se cargou ningunha etiqueta</string> | ||||||
|  |   <string name="no_sources_loaded">Non se cargou ningunha fonte</string> | ||||||
|  |   <string name="drawer_loading">Cargando…</string> | ||||||
|  |   <string name="menu_home_search">Procurar</string> | ||||||
|  |   <string name="can_delete_source">Non se puido eliminar a fonte…</string> | ||||||
|  |   <string name="base_url_error">Houno unha incidencia ao tratar de comunicarse coa túa instancia de Selfoss. Se o problema persiste, prégolle que se poña en contacto conmigo.</string> | ||||||
|  |   <string name="pref_header_theme">Temas</string> | ||||||
|  |   <string name="default_theme">Predeterminado</string> | ||||||
|  |   <string name="default_dark_theme">Predeterminado/Escuro</string> | ||||||
|  |   <string name="pref_header_debug">Depuración</string> | ||||||
|  |   <string name="login_debug_title">Activar pra rexistrar os erros de acceso</string> | ||||||
|  |   <string name="login_debug_on">Rexistrarse todos os erros na páxina de acceso</string> | ||||||
|  |   <string name="login_debug_off">Non se rexistrará ningún erro na páxina de acceso</string> | ||||||
|  |   <string name="login_menu_debug">Depuración</string> | ||||||
|  |   <string name="self_hosted_cert_switch">Utilizas un certificado autoaloxado?</string> | ||||||
|  |   <string name="self_signed_cert_warning">Por razóns de seguridade, por defecto non se permiten os certificados autoasinados. Activando isto, non serei responsable de calquera problema de seguridade que atopes.</string> | ||||||
|  |   <string name="pref_selfoss_category">API de Selfoss</string> | ||||||
|  |   <string name="pref_api_items_number_title">Número de elementos cargados</string> | ||||||
|  |   <string name="pref_hidden_tags">Etiquetas ocultas</string> | ||||||
|  |   <string name="read_debug_title">Ler os artigos que aparecen coma non lidos?</string> | ||||||
|  |   <string name="read_debug_off">Non rexistrar cando se marca un elemento coma lido</string> | ||||||
|  |   <string name="read_debug_on">As chamadas á API serán rexistradas cando se marque un artigo coma lido</string> | ||||||
|  |   <string name="summary_debug_identifier">Identificador de depuración</string> | ||||||
|  |   <string name="unique_id_to_clipboard">Copiouse o identificador ao portapapeis</string> | ||||||
|  |   <string name="display_header_drawer_summary">Amosar unha cabeceira coa URL da instancia de Selfoss no panel lateral.</string> | ||||||
|  |   <string name="display_header_drawer_title">Cabeceira da conta</string> | ||||||
|  |   <string name="login_everything_title">Rexistrando todas as chamadas á API</string> | ||||||
|  |   <string name="login_everything_on">Isto rexistrará todas as chamadas á API con fins de depuración.</string> | ||||||
|  |   <string name="login_everything_off">Non se rexistrará ningunha chamada á API</string> | ||||||
|  |   <string name="pref_general_infinite_loading_title">Cargar máis artigos ao desprazarse</string> | ||||||
|  |   <string name="translation">Traducción</string> | ||||||
|  |   <string name="cant_open_invalid_url">A URL do elemento non é válida. Estou tratando de solucionar isto pra que a aplicación non falle.</string> | ||||||
|  |   <string name="drawer_report_bug">Informar dun erro</string> | ||||||
|  |   <string name="items_number_should_be_number">O número de elementos debería ser un enteiro.</string> | ||||||
|  |   <string name="reader_action_more">Ler máis</string> | ||||||
|  |   <string name="reader_action_open">Abrir no navegador</string> | ||||||
|  |   <string name="reader_action_share">Compartir</string> | ||||||
|  |   <string name="pref_switch_actions_pager_scroll_on">Marcar artigos como lidos cando se desliza o dedo dun a outro.</string> | ||||||
|  |   <string name="add_to_favs_reader">Engadir a favoritos</string> | ||||||
|  |   <string name="remove_to_favs_reader">Eliminar dos favoritos</string> | ||||||
|  |   <string name="pref_content_reader_font_size">Tamaño da fonte do lector</string> | ||||||
|  |   <string name="pref_header_viewer">Visor de artigos</string> | ||||||
|  |   <string name="refresh_dialog_message">Isto actualizará a súa instancia de Selfoss.</string> | ||||||
|  |   <string name="markall_dialog_message">Isto marcara todos os elementos como lidos.</string> | ||||||
|  |   <string name="pref_switch_actions_pager_scroll">Marcar artigos como lidos ao deslizar co dedo cara os lados</string> | ||||||
|  |   <string name="pref_switch_actions_pager_scroll_off">Non marcar artigos como lidos ao deslizar co dedo cara os lados.</string> | ||||||
|  |   <string name="gdpr_dialog_message">A aplicación non recolle ningún dato persoal. Todas as ferramentas de analítica foron eliminadas. O envío de informes de erros agora é opcional, así coma os rexistros de depuración. Ten en conta que tanto os rexistros coma os informes de erros son esenciais prao desenvolvemento da aplicación (Podes configurar todo en \"Axustes > Depurar\").</string> | ||||||
|  |   <string name="gdpr_dialog_title">A aplicación non comparte ningún dato persoal seu.</string> | ||||||
|  |   <string name="crash_dialog_text">Algo foi mal. Pregámoslle que envíe o informe de erro ao desarrollador.</string> | ||||||
|  |   <string name="crash_dialog_comment">Podes engadir calquera información útil nos comentarios. Non inclúas datos persoais. Podes enviarme un correo coa Id de depuración pra que me poña en contacto contigo cando a incidencia se resolva.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Enviar automáticamente informes de erros</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Enviaranse automáticamente os informes de erros</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Preguntarase cada vez pra enviar os informes de erros.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Informes de erros</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Rexistro de depuración (Estes enviaranse automáticamente)</string> | ||||||
|  |   <string name="acra_login">Habilitar o rexistro</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Etiquetas ocultas</string> | ||||||
|  |   <string name="unmark">Marcar artículo como non lido</string> | ||||||
|  | </resources> | ||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Tampilkan jumlah item yang belum dibaca di bilah bawah."</string> |   <string name="switch_unread_count">"Tampilkan jumlah item yang belum dibaca di bilah bawah."</string> | ||||||
|   <string name="switch_unread_count_title">"Tampilkan jumlah item yang belum dibaca"</string> |   <string name="switch_unread_count_title">"Tampilkan jumlah item yang belum dibaca"</string> | ||||||
|   <string name="display_all_counts_title">"Tampilkan jumlah item untuk favorit dan sudah dibaca"</string> |   <string name="display_all_counts_title">"Tampilkan jumlah item untuk favorit dan sudah dibaca"</string> | ||||||
|   <string name="menu_share_the_app">"Undang teman"</string> |     <string name="text_wrong_url">"Sepertinya Anda mencoba menggunakan URL yang tidak valid. Pastikan itu benar, jika masalah terus berlanjut, hubungi saya (melalui link kontak toko). Harap dicatat bahwa aplikasi ini mengharuskan Anda menggunakan Selfoss. Tanpa itu, Anda tidak bisa mengakses umpan RSS."</string> | ||||||
|   <string name="invitation_title">"Coba mengggunakan aplikasi ini untuk umpan RSS Selfoss Anda !"</string> |  | ||||||
|   <string name="invitation_message">"Saya menggunakan aplikasi ini untuk umpan RSS Selfoss saya. Anda akan menyukainya juga!"</string> |  | ||||||
|   <string name="invitation_cta">"Coba aplikasi"</string> |  | ||||||
|   <string name="text_wrong_url">"Sepertinya Anda mencoba menggunakan URL yang tidak valid. Pastikan itu benar, jika masalah terus berlanjut, hubungi saya (melalui link kontak toko). Harap dicatat bahwa aplikasi ini mengharuskan Anda menggunakan Selfoss. Tanpa itu, Anda tidak bisa mengakses umpan RSS."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Buka tautan dalam aplikasi"</string> |   <string name="pref_general_internal_browser_title">"Buka tautan dalam aplikasi"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Artikel akan dibuka di dalam aplikasi"</string> |   <string name="pref_general_internal_browser_on">"Artikel akan dibuka di dalam aplikasi"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Artikel akan dibuka dalam peramban bawaan Anda"</string> |   <string name="pref_general_internal_browser_off">"Artikel akan dibuka dalam peramban bawaan Anda"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"Selfoss sedang diperbarui, kini Anda bisa menyegarkan daftar artikel"</string> |   <string name="refresh_success_response">"Selfoss sedang diperbarui, kini Anda bisa menyegarkan daftar artikel"</string> | ||||||
|   <string name="refresh_failer_message">"Pembaruan tidak berhasil, coba lagi atau periksa log Selfoss."</string> |   <string name="refresh_failer_message">"Pembaruan tidak berhasil, coba lagi atau periksa log Selfoss."</string> | ||||||
|   <string name="refresh_in_progress">"Dlam proses menyegarkan"</string> |   <string name="refresh_in_progress">"Dlam proses menyegarkan"</string> | ||||||
|   <string name="new_apk_available_title">"APK baru sudah tersedia."</string> |     <string name="card_height_title">Peta tinggi penuh</string> | ||||||
|   <string name="new_apk_available_message">"APK baru sudah tersedia untuk diunduh di gerai resmi."</string> |  | ||||||
|   <string name="new_apk_available_get">"Unduh sekarang"</string> |  | ||||||
|   <string name="new_apk_available_no">"Abaikan versi"</string> |  | ||||||
|   <string name="intro_hello_title">"Hai !"</string> |  | ||||||
|   <string name="intro_hello_message">"Terima kasih telah mengunduh aplikasi ini !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Sebelum Anda mulai…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"Anda tidak dapat menggunakan aplikasi ini tanpa menjalankan Selfoss."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"Apa itu Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"Selesai !"</string> |  | ||||||
|   <string name="intro_all_set_message">"Kamu sudah siap Jangan lupa atur aplikasi konfigurasi halaman, Anda juga bisa menemukan beberapa tautan yang berguna disana."</string> |  | ||||||
|   <string name="card_height_title">Peta tinggi penuh</string> |  | ||||||
|   <string name="card_height_on">Tinggi kartu akan disesuaikan dengan konten</string> |   <string name="card_height_on">Tinggi kartu akan disesuaikan dengan konten</string> | ||||||
|   <string name="card_height_off">Ukuran kartu akan tetap</string> |   <string name="card_height_off">Ukuran kartu akan tetap</string> | ||||||
|   <string name="source_code">Kode sumber</string> |   <string name="source_code">Kode sumber</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">Ada masalah saat berkomunikasi dengan Selfoss Anda. Jika masalah berlanjut, tolong hubungi saya.</string> |   <string name="base_url_error">Ada masalah saat berkomunikasi dengan Selfoss Anda. Jika masalah berlanjut, tolong hubungi saya.</string> | ||||||
|   <string name="pref_header_theme">Tema</string> |   <string name="pref_header_theme">Tema</string> | ||||||
|   <string name="default_theme">Bawaan</string> |   <string name="default_theme">Bawaan</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Gelap</string> |  | ||||||
|   <string name="default_dark_theme">Bawaan/Gelap</string> |   <string name="default_dark_theme">Bawaan/Gelap</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Gelap</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Gelap</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Gelap</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Gelap</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Aktifkan untuk mencatat semua kesalahan koneksi</string> |   <string name="login_debug_title">Aktifkan untuk mencatat semua kesalahan koneksi</string> | ||||||
|   <string name="login_debug_on">Semua kesalahan koneksi akan dicatat</string> |   <string name="login_debug_on">Semua kesalahan koneksi akan dicatat</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Untuk alasan keamanan, sertifikat yang ditandatangani sendiri tidak didukung secara bawaan. Jika Anda mengaktifkan item ini, saya tidak akan bertanggung jawab atas masalah keamanan yang Anda hadapi.</string> |   <string name="self_signed_cert_warning">Untuk alasan keamanan, sertifikat yang ditandatangani sendiri tidak didukung secara bawaan. Jika Anda mengaktifkan item ini, saya tidak akan bertanggung jawab atas masalah keamanan yang Anda hadapi.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Item nomor dimuat</string> |   <string name="pref_api_items_number_title">Item nomor dimuat</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Baca artikel yang ini sebagai belum dibaca ?</string> |   <string name="read_debug_title">Baca artikel yang ini sebagai belum dibaca ?</string> | ||||||
|   <string name="read_debug_off">Tidak ada catatan saat item ditandai sebagai telah dibaca</string> |   <string name="read_debug_off">Tidak ada catatan saat item ditandai sebagai telah dibaca</string> | ||||||
|   <string name="read_debug_on">Panggilan api dicatat saat item ditandai sebagai telah dibaca</string> |   <string name="read_debug_on">Panggilan api dicatat saat item ditandai sebagai telah dibaca</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -1,53 +1,53 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <!--Generated by crowdin.com--> | <!--Generated by crowdin.com--> | ||||||
| <resources xmlns:tools="http://schemas.android.com/tools"> | <resources xmlns:tools="http://schemas.android.com/tools"> | ||||||
|   <string name="app_name">"Reader for Selfoss"</string> |   <string name="app_name">"Lettore RSS per Selfoss"</string> | ||||||
|   <string name="title_activity_login">"Log in"</string> |   <string name="title_activity_login">"Accedi"</string> | ||||||
|   <string name="prompt_password">"Password"</string> |   <string name="prompt_password">"Password"</string> | ||||||
|   <string name="prompt_http_password">"HTTP Password"</string> |   <string name="prompt_http_password">"Password HTTP"</string> | ||||||
|   <string name="action_sign_in">"Go"</string> |   <string name="action_sign_in">"Vai"</string> | ||||||
|   <string name="error_invalid_password">"Password not long enough"</string> |   <string name="error_invalid_password">"La password non è sufficientemente lunga"</string> | ||||||
|   <string name="error_field_required">"Field required"</string> |   <string name="error_field_required">"Campo obbligatorio"</string> | ||||||
|   <string name="prompt_url">"Url"</string> |   <string name="prompt_url">"URL"</string> | ||||||
|   <string name="withLoginSwitch">"Login required ?"</string> |   <string name="withLoginSwitch">"È richiesto l'accesso?"</string> | ||||||
|   <string name="withHttpLoginSwitch">"HTTP Login required ?"</string> |   <string name="withHttpLoginSwitch">"Accesso HTTP necessario?"</string> | ||||||
|   <string name="login_url_problem">"Oops. You may need to add a \"/\" at the end of the url."</string> |   <string name="login_url_problem">"Oops. Potrebbe essere necessario aggiungere un \"/\" alla fine dell'url."</string> | ||||||
|   <string name="prompt_login">"Username"</string> |   <string name="prompt_login">"Nome utente"</string> | ||||||
|   <string name="prompt_http_login">"HTTP Username"</string> |   <string name="prompt_http_login">"Nome utente HTTP"</string> | ||||||
|   <string name="label_share">"Share"</string> |   <string name="label_share">"Condividi"</string> | ||||||
|   <string name="readAll">"Read all"</string> |   <string name="readAll">"Segna tutte come lette"</string> | ||||||
|   <string name="action_disconnect">"Disconnect"</string> |   <string name="action_disconnect">"Scollegati"</string> | ||||||
|   <string name="title_activity_settings">"Settings"</string> |   <string name="title_activity_settings">"Impostazioni"</string> | ||||||
|   <string name="pref_header_general">"General"</string> |   <string name="pref_header_general">"Generali"</string> | ||||||
|   <string name="pref_switch_actions_tap_title">"Tap action on the articles"</string> |   <string name="pref_switch_actions_tap_title">"Tap sugli articoli"</string> | ||||||
|   <string name="add_source_hint_tags">"Tag1, Tag2, Tag3"</string> |   <string name="add_source_hint_tags">"Tag1, Tag2, Tag3"</string> | ||||||
|   <string name="add_source_hint_url">"Link"</string> |   <string name="add_source_hint_url">"Link"</string> | ||||||
|   <string name="add_source_hint_name">"Name"</string> |   <string name="add_source_hint_name">"Nome"</string> | ||||||
|   <string name="add_source">"Add a source"</string> |   <string name="add_source">"Aggiungi una fonte"</string> | ||||||
|   <string name="add_source_save">"Save"</string> |   <string name="add_source_save">"Salva"</string> | ||||||
|   <string name="wrong_infos">"Check your details again."</string> |   <string name="wrong_infos">"Controlla nuovamente i dati."</string> | ||||||
|   <string name="all_posts_not_read">"All posts weren't read"</string> |   <string name="all_posts_not_read">"All posts weren't read"</string> | ||||||
|   <string name="all_posts_read">"All posts were read"</string> |   <string name="all_posts_read">"Tutti i messaggi sono stati letti"</string> | ||||||
|   <string name="cant_get_favs">"Can't get favorites"</string> |   <string name="cant_get_favs">"Non è possibile ottenere i preferiti"</string> | ||||||
|   <string name="cant_get_new_elements">"Can't get new articles"</string> |   <string name="cant_get_new_elements">"Non è possibile ottenere nuovi articoli"</string> | ||||||
|   <string name="cant_get_read">"Can't get read articles"</string> |   <string name="cant_get_read">"Can't get read articles"</string> | ||||||
|   <string name="nothing_here">"Nothing here"</string> |   <string name="nothing_here">"Non c'è niente qui"</string> | ||||||
|   <string name="tab_new">"New"</string> |   <string name="tab_new">"Nuovi"</string> | ||||||
|   <string name="tab_read">"All"</string> |   <string name="tab_read">"Tutti"</string> | ||||||
|   <string name="tab_favs">"Favorites"</string> |   <string name="tab_favs">"Preferiti"</string> | ||||||
|   <string name="action_about">"About"</string> |   <string name="action_about">"Informazioni"</string> | ||||||
|   <string name="marked_as_read">"Item read"</string> |   <string name="marked_as_read">"Articolo letto"</string> | ||||||
|   <string name="undo_string">"Undo"</string> |   <string name="undo_string">"Annulla"</string> | ||||||
|   <string name="addStringNoUrl">"Log in to add sources."</string> |   <string name="addStringNoUrl">"Autenticati per aggiungere fonti."</string> | ||||||
|   <string name="cant_get_sources">"Can't get sources list."</string> |   <string name="cant_get_sources">"Can't get sources list."</string> | ||||||
|   <string name="cant_create_source">"Can't create source."</string> |   <string name="cant_create_source">"Can't create source."</string> | ||||||
|   <string name="cant_get_spouts">"Can't get spouts list."</string> |   <string name="cant_get_spouts">"Can't get spouts list."</string> | ||||||
|   <string name="form_not_complete">"The form is not complete"</string> |   <string name="form_not_complete">"Il modulo non è completo"</string> | ||||||
|   <string name="pref_header_links">"Links"</string> |   <string name="pref_header_links">"Links"</string> | ||||||
|   <string name="issue_tracker_link">"Issue Tracker"</string> |   <string name="issue_tracker_link">"Traccia problemi"</string> | ||||||
|   <string name="issue_tracker_summary">"Report a bug or ask for a new feature"</string> |   <string name="issue_tracker_summary">"Segnalare un bug o richiedere una nuova funzionalità"</string> | ||||||
|   <string name="warning_wrong_url">"WARNING"</string> |   <string name="warning_wrong_url">"ATTENZIONE"</string> | ||||||
|   <string name="pref_switch_card_view_title">"Card View"</string> |   <string name="pref_switch_card_view_title">"Visualizzazione a schede"</string> | ||||||
|   <string name="cant_mark_favortie">"Can't mark article as favorite"</string> |   <string name="cant_mark_favortie">"Can't mark article as favorite"</string> | ||||||
|   <string name="cant_unmark_favortie">"Can't remove item from favorite"</string> |   <string name="cant_unmark_favortie">"Can't remove item from favorite"</string> | ||||||
|   <string name="share">"Share"</string> |   <string name="share">"Share"</string> | ||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,51 +82,28 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Schede a piena altezza</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Codice sorgente</string> | ||||||
|   <string name="cant_mark_read">Can\'t mark article as read</string> |   <string name="cant_mark_read">Impossibile contrassegnare l\'articolo come già letto</string> | ||||||
|   <string name="drawer_error_loading_tags">Error loading tags…</string> |   <string name="drawer_error_loading_tags">Errore nel caricamento dei tag…</string> | ||||||
|   <string name="drawer_error_loading_sources">Error loading sources…</string> |   <string name="drawer_error_loading_sources">Errore nel caricamento delle fonti…</string> | ||||||
|   <string name="drawer_item_filters">Filters</string> |   <string name="drawer_item_filters">Filtri</string> | ||||||
|   <string name="drawer_action_clear">clear</string> |   <string name="drawer_action_clear">cancella</string> | ||||||
|   <string name="drawer_item_tags">Tags</string> |   <string name="drawer_item_tags">Tags</string> | ||||||
|   <string name="drawer_item_sources">Sources</string> |   <string name="drawer_item_sources">Fonti</string> | ||||||
|   <string name="drawer_action_edit">edit</string> |   <string name="drawer_action_edit">modifica</string> | ||||||
|   <string name="cache_drawer_error" tools:keep="@string/cache_drawer_error">Couldn\'t cache your drawer data</string> |   <string name="cache_drawer_error" tools:keep="@string/cache_drawer_error">Couldn\'t cache your drawer data</string> | ||||||
|   <string name="no_tags_loaded">No tags loaded</string> |   <string name="no_tags_loaded">Nessun tag caricato</string> | ||||||
|   <string name="no_sources_loaded">No sources loaded</string> |   <string name="no_sources_loaded">No sources loaded</string> | ||||||
|   <string name="drawer_loading">Loading …</string> |   <string name="drawer_loading">Caricamento…</string> | ||||||
|   <string name="menu_home_search">Search</string> |   <string name="menu_home_search">Cerca</string> | ||||||
|   <string name="can_delete_source">Can\'t delete the source…</string> |   <string name="can_delete_source">Non è possibile eliminare la fonte…</string> | ||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Temi</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Predefinito</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |   <string name="default_dark_theme">Predefinito (Scuro)</string> | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |  | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -138,8 +111,9 @@ | |||||||
|   <string name="login_menu_debug">Debug</string> |   <string name="login_menu_debug">Debug</string> | ||||||
|   <string name="self_hosted_cert_switch">Using a self hosted certificate ?</string> |   <string name="self_hosted_cert_switch">Using a self hosted certificate ?</string> | ||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Api di Selfoss</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Numero di elementi caricati</string> | ||||||
|  |   <string name="pref_hidden_tags">Tag nascosti</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -151,9 +125,9 @@ | |||||||
|   <string name="login_everything_on">This will log every api call for debug purpose.</string> |   <string name="login_everything_on">This will log every api call for debug purpose.</string> | ||||||
|   <string name="login_everything_off">No api call will be logged</string> |   <string name="login_everything_off">No api call will be logged</string> | ||||||
|   <string name="pref_general_infinite_loading_title">Load more articles on scroll</string> |   <string name="pref_general_infinite_loading_title">Load more articles on scroll</string> | ||||||
|   <string name="translation">Translation</string> |   <string name="translation">Traduzioni</string> | ||||||
|   <string name="cant_open_invalid_url">The item url is invalid. I\'m looking into solving this issue so the app won\'t crash.</string> |   <string name="cant_open_invalid_url">The item url is invalid. I\'m looking into solving this issue so the app won\'t crash.</string> | ||||||
|   <string name="drawer_report_bug">Report a bug</string> |   <string name="drawer_report_bug">Segnala un bug</string> | ||||||
|   <string name="items_number_should_be_number">The items number should be an integer.</string> |   <string name="items_number_should_be_number">The items number should be an integer.</string> | ||||||
|   <string name="reader_action_more">Read more</string> |   <string name="reader_action_more">Read more</string> | ||||||
|   <string name="reader_action_open">Open in browser</string> |   <string name="reader_action_open">Open in browser</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Segna come non letto</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -2,61 +2,61 @@ | |||||||
| <!--Generated by crowdin.com--> | <!--Generated by crowdin.com--> | ||||||
| <resources xmlns:tools="http://schemas.android.com/tools"> | <resources xmlns:tools="http://schemas.android.com/tools"> | ||||||
|   <string name="app_name">"Reader for Selfoss"</string> |   <string name="app_name">"Reader for Selfoss"</string> | ||||||
|   <string name="title_activity_login">"Log in"</string> |   <string name="title_activity_login">"로그인"</string> | ||||||
|   <string name="prompt_password">"Password"</string> |   <string name="prompt_password">"비밀번호"</string> | ||||||
|   <string name="prompt_http_password">"HTTP Password"</string> |   <string name="prompt_http_password">"HTTP 암호"</string> | ||||||
|   <string name="action_sign_in">"Go"</string> |   <string name="action_sign_in">"Go"</string> | ||||||
|   <string name="error_invalid_password">"Password not long enough"</string> |   <string name="error_invalid_password">"패스워드가 짧습니다."</string> | ||||||
|   <string name="error_field_required">"Field required"</string> |   <string name="error_field_required">"필수 항목"</string> | ||||||
|   <string name="prompt_url">"Url"</string> |   <string name="prompt_url">"Url"</string> | ||||||
|   <string name="withLoginSwitch">"Login required ?"</string> |   <string name="withLoginSwitch">"로그인이 필요합니까?"</string> | ||||||
|   <string name="withHttpLoginSwitch">"HTTP Login required ?"</string> |   <string name="withHttpLoginSwitch">"HTTP 로그인이 필요 합니까?"</string> | ||||||
|   <string name="login_url_problem">"Oops. You may need to add a \"/\" at the end of the url."</string> |   <string name="login_url_problem">"죄송합니다. Url의 끝에 \"/\"를 추가할 필요가 있습니다."</string> | ||||||
|   <string name="prompt_login">"Username"</string> |   <string name="prompt_login">"사용자 이름"</string> | ||||||
|   <string name="prompt_http_login">"HTTP Username"</string> |   <string name="prompt_http_login">"HTTP 사용자 이름"</string> | ||||||
|   <string name="label_share">"Share"</string> |   <string name="label_share">"공유"</string> | ||||||
|   <string name="readAll">"Read all"</string> |   <string name="readAll">"모두 읽기"</string> | ||||||
|   <string name="action_disconnect">"Disconnect"</string> |   <string name="action_disconnect">"연결 해제"</string> | ||||||
|   <string name="title_activity_settings">"Settings"</string> |   <string name="title_activity_settings">"설정"</string> | ||||||
|   <string name="pref_header_general">"General"</string> |   <string name="pref_header_general">"일반"</string> | ||||||
|   <string name="pref_switch_actions_tap_title">"Tap action on the articles"</string> |   <string name="pref_switch_actions_tap_title">"기사에 탭 액션"</string> | ||||||
|   <string name="add_source_hint_tags">"Tag1, Tag2, Tag3"</string> |   <string name="add_source_hint_tags">"태그1, 태그2, 태그3"</string> | ||||||
|   <string name="add_source_hint_url">"Link"</string> |   <string name="add_source_hint_url">"링크"</string> | ||||||
|   <string name="add_source_hint_name">"Name"</string> |   <string name="add_source_hint_name">"이름"</string> | ||||||
|   <string name="add_source">"Add a source"</string> |   <string name="add_source">"소스 추가"</string> | ||||||
|   <string name="add_source_save">"Save"</string> |   <string name="add_source_save">"저장"</string> | ||||||
|   <string name="wrong_infos">"Check your details again."</string> |   <string name="wrong_infos">"세부 정보를 다시 확인하세요."</string> | ||||||
|   <string name="all_posts_not_read">"All posts weren't read"</string> |   <string name="all_posts_not_read">"모든 게시물을 읽지 않았습니다."</string> | ||||||
|   <string name="all_posts_read">"All posts were read"</string> |   <string name="all_posts_read">"모든 게시물을 읽었습니다."</string> | ||||||
|   <string name="cant_get_favs">"Can't get favorites"</string> |   <string name="cant_get_favs">"즐겨찾기를 가져올 수 없습니다."</string> | ||||||
|   <string name="cant_get_new_elements">"Can't get new articles"</string> |   <string name="cant_get_new_elements">"새로운 기사를 가져올 수 없습니다."</string> | ||||||
|   <string name="cant_get_read">"Can't get read articles"</string> |   <string name="cant_get_read">"읽은 기사를 가져올 수 없습니다."</string> | ||||||
|   <string name="nothing_here">"Nothing here"</string> |   <string name="nothing_here">"비어있음"</string> | ||||||
|   <string name="tab_new">"New"</string> |   <string name="tab_new">"새로운"</string> | ||||||
|   <string name="tab_read">"All"</string> |   <string name="tab_read">"전체"</string> | ||||||
|   <string name="tab_favs">"Favorites"</string> |   <string name="tab_favs">"즐겨찾기"</string> | ||||||
|   <string name="action_about">"About"</string> |   <string name="action_about">"정보"</string> | ||||||
|   <string name="marked_as_read">"Item read"</string> |   <string name="marked_as_read">"항목 읽기"</string> | ||||||
|   <string name="undo_string">"Undo"</string> |   <string name="undo_string">"실행 취소"</string> | ||||||
|   <string name="addStringNoUrl">"Log in to add sources."</string> |   <string name="addStringNoUrl">"로그인 소스를 추가 해야 합니다."</string> | ||||||
|   <string name="cant_get_sources">"Can't get sources list."</string> |   <string name="cant_get_sources">"소스 리스트를 얻을 수 없습니다."</string> | ||||||
|   <string name="cant_create_source">"Can't create source."</string> |   <string name="cant_create_source">"소스를 만들 수 없습니다."</string> | ||||||
|   <string name="cant_get_spouts">"Can't get spouts list."</string> |   <string name="cant_get_spouts">"Spouts 목록을 가져올 수 없습니다."</string> | ||||||
|   <string name="form_not_complete">"The form is not complete"</string> |   <string name="form_not_complete">"양식이 완료되지 않았습니다."</string> | ||||||
|   <string name="pref_header_links">"Links"</string> |   <string name="pref_header_links">"링크"</string> | ||||||
|   <string name="issue_tracker_link">"Issue Tracker"</string> |   <string name="issue_tracker_link">"이슈 트래커"</string> | ||||||
|   <string name="issue_tracker_summary">"Report a bug or ask for a new feature"</string> |   <string name="issue_tracker_summary">"버그를 보고 하거나 새기능에 대해 요청하세요."</string> | ||||||
|   <string name="warning_wrong_url">"WARNING"</string> |   <string name="warning_wrong_url">"경고"</string> | ||||||
|   <string name="pref_switch_card_view_title">"Card View"</string> |   <string name="pref_switch_card_view_title">"카드 형식 보기"</string> | ||||||
|   <string name="cant_mark_favortie">"Can't mark article as favorite"</string> |   <string name="cant_mark_favortie">"좋아하는 문서를 마크할 수 없습니다."</string> | ||||||
|   <string name="cant_unmark_favortie">"Can't remove item from favorite"</string> |   <string name="cant_unmark_favortie">"좋아하는 항목에서 제거할 수 없습니다."</string> | ||||||
|   <string name="share">"Share"</string> |   <string name="share">"공유"</string> | ||||||
|   <string name="rating_prompt_title">"Enjoying the app ?"</string> |   <string name="rating_prompt_title">"이 앱에 만족하십니까?"</string> | ||||||
|   <string name="rating_prompt_yes">"Yes !"</string> |   <string name="rating_prompt_yes">"예!"</string> | ||||||
|   <string name="rating_prompt_no">"Not really …"</string> |   <string name="rating_prompt_no">"설마..."</string> | ||||||
|   <string name="rating_prompt_feedback_title">"Can you tell us why ?"</string> |   <string name="rating_prompt_feedback_title">"이유를 우리에게 말해줄 수 있습니까?"</string> | ||||||
|   <string name="rating_prompt_feedback_yes">"OK !"</string> |   <string name="rating_prompt_feedback_yes">"OK!"</string> | ||||||
|   <string name="rating_prompt_feedback_no">"Not now."</string> |   <string name="rating_prompt_feedback_no">"나중에"</string> | ||||||
|   <string name="rating_prompt_rating_title">"Great ! Can you rate us on the Store ?"</string> |   <string name="rating_prompt_rating_title">"Great ! Can you rate us on the Store ?"</string> | ||||||
|   <string name="rating_prompt_rating_yes">"Sure !"</string> |   <string name="rating_prompt_rating_yes">"Sure !"</string> | ||||||
|   <string name="rating_prompt_rating_no">"Not right now."</string> |   <string name="rating_prompt_rating_no">"Not right now."</string> | ||||||
| @@ -64,10 +64,6 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |  | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
| @@ -86,17 +82,6 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |  | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |   <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Geef het aantal ongelezen artikelen weer in de balk onderaan"</string> |   <string name="switch_unread_count">"Geef het aantal ongelezen artikelen weer in de balk onderaan"</string> | ||||||
|   <string name="switch_unread_count_title">"Geef aantal ongelezen weer"</string> |   <string name="switch_unread_count_title">"Geef aantal ongelezen weer"</string> | ||||||
|   <string name="display_all_counts_title">"Geef aantal weer bij favorieten en gelezen"</string> |   <string name="display_all_counts_title">"Geef aantal weer bij favorieten en gelezen"</string> | ||||||
|   <string name="menu_share_the_app">"Vrienden uitnodigen"</string> |     <string name="text_wrong_url">"De gebruikte link lijkt onjuist. Controleer deze. Mocht het probleem blijven, neem dan contact met me op (via de contact link in de store). Om deze app te kunnen gebruiken heb je Selfoss nodig."</string> | ||||||
|   <string name="invitation_title">"Probeer deze app voor je Selfoss RSS feeds!"</string> |  | ||||||
|   <string name="invitation_message">"Ik gebruik deze app voor mijn Selfoss RSS feeds. Misschien is het ook wat voor jou!"</string> |  | ||||||
|   <string name="invitation_cta">"App proberen"</string> |  | ||||||
|   <string name="text_wrong_url">"De gebruikte link lijkt onjuist. Controleer deze. Mocht het probleem blijven, neem dan contact met me op (via de contact link in de store). Om deze app te kunnen gebruiken heb je Selfoss nodig."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Links opnemen in interne browser"</string> |   <string name="pref_general_internal_browser_title">"Links opnemen in interne browser"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Artikelen worden in de interne browser geopend"</string> |   <string name="pref_general_internal_browser_on">"Artikelen worden in de interne browser geopend"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Artikelen worden geopend in de standaard browser"</string> |   <string name="pref_general_internal_browser_off">"Artikelen worden geopend in de standaard browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"Selfoss update uitgevoerd. Je kunt nu de artikellijst verversen"</string> |   <string name="refresh_success_response">"Selfoss update uitgevoerd. Je kunt nu de artikellijst verversen"</string> | ||||||
|   <string name="refresh_failer_message">"Selfoss update mislukt. Probeer het later nog eens of controleer de logbestanden."</string> |   <string name="refresh_failer_message">"Selfoss update mislukt. Probeer het later nog eens of controleer de logbestanden."</string> | ||||||
|   <string name="refresh_in_progress">"Bezig met verversen"</string> |   <string name="refresh_in_progress">"Bezig met verversen"</string> | ||||||
|   <string name="new_apk_available_title">"Er is een nieuwe versie (APK) beschikbaar."</string> |     <string name="card_height_title">Volledige hoogte kaarten</string> | ||||||
|   <string name="new_apk_available_message">"Een nieuwe versie (APK) is te downloaden vanaf de officiële repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Downloaden"</string> |  | ||||||
|   <string name="new_apk_available_no">"Negeren"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi!"</string> |  | ||||||
|   <string name="intro_hello_message">"Bedankt voor het downloaden van de app!"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Voordat je begint…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"Een werkende Selfoss website is verplicht."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"Wat is Selfoss?"</string> |  | ||||||
|   <string name="intro_all_set_title">"Voltooid"</string> |  | ||||||
|   <string name="intro_all_set_message">"Je kunt nu de app gebruiken.Ga naar instellingen om de app te configureren. Daarnaast kun je daar handige links vinden."</string> |  | ||||||
|   <string name="card_height_title">Volledige hoogte kaarten</string> |  | ||||||
|   <string name="card_height_on">Hoogte aanpassen aan de hand van kaartinhoud</string> |   <string name="card_height_on">Hoogte aanpassen aan de hand van kaartinhoud</string> | ||||||
|   <string name="card_height_off">Vaste hoogte</string> |   <string name="card_height_off">Vaste hoogte</string> | ||||||
|   <string name="source_code">Broncode</string> |   <string name="source_code">Broncode</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">Er was een probleem bij het communiceren met uw Selfoss Instance. Als het probleem blijft, neem dan contact met mij op.</string> |   <string name="base_url_error">Er was een probleem bij het communiceren met uw Selfoss Instance. Als het probleem blijft, neem dan contact met mij op.</string> | ||||||
|   <string name="pref_header_theme">Thema \'s</string> |   <string name="pref_header_theme">Thema \'s</string> | ||||||
|   <string name="default_theme">Standaard</string> |   <string name="default_theme">Standaard</string> | ||||||
|   <string name="teal_orange_theme">Groenblauw/Oranje/Licht</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyaan/Roze/Licht</string> |  | ||||||
|   <string name="grey_orange_theme">Grijs/Oranje/Licht</string> |  | ||||||
|   <string name="blue_amber_theme">Blauw/Amber/Licht</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Roze/Licht</string> |  | ||||||
|   <string name="red_teal_theme">Rood/Groenblauwl/Licht</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Groenblauw/Oranje/Donker</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyaan/Roze/Donker</string> |  | ||||||
|   <string name="default_dark_theme">Standaard/Donker</string> |   <string name="default_dark_theme">Standaard/Donker</string> | ||||||
|   <string name="grey_orange_dark_theme">Grijs/Oranje/Donker</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blauw/Amber/Donker</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Roze/Donker</string> |  | ||||||
|   <string name="red_teal_dark_theme">Rood/Groenbauw/Donker</string> |  | ||||||
|   <string name="pref_header_debug">Fout opsporen</string> |   <string name="pref_header_debug">Fout opsporen</string> | ||||||
|   <string name="login_debug_title">Activeer om login-fouten te loggen</string> |   <string name="login_debug_title">Activeer om login-fouten te loggen</string> | ||||||
|   <string name="login_debug_on">Elke fout op de inlogpagina wordt gelogd</string> |   <string name="login_debug_on">Elke fout op de inlogpagina wordt gelogd</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Vanwege veiligheidsredenen worden zelfondertekende certificaten niet standaard ondersteund. Door dit te activeren, ben ik niet verantwoordelijk voor beveiligingsproblemen die u tegenkomt.</string> |   <string name="self_signed_cert_warning">Vanwege veiligheidsredenen worden zelfondertekende certificaten niet standaard ondersteund. Door dit te activeren, ben ik niet verantwoordelijk voor beveiligingsproblemen die u tegenkomt.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Geladen items nummer</string> |   <string name="pref_api_items_number_title">Geladen items nummer</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Gelezen artikelen verschijnen als ongelezen?</string> |   <string name="read_debug_title">Gelezen artikelen verschijnen als ongelezen?</string> | ||||||
|   <string name="read_debug_off">Geen logboek bij het markeren van een artikel als gelezen</string> |   <string name="read_debug_off">Geen logboek bij het markeren van een artikel als gelezen</string> | ||||||
|   <string name="read_debug_on">Api-oproepen zullen gelogd worden wanneer een artikel als gelezen wordt gemarkeerd</string> |   <string name="read_debug_on">Api-oproepen zullen gelogd worden wanneer een artikel als gelezen wordt gemarkeerd</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Exibir a contagem de artigos não lidos como um badge na barra inferior."</string> |   <string name="switch_unread_count">"Exibir a contagem de artigos não lidos como um badge na barra inferior."</string> | ||||||
|   <string name="switch_unread_count_title">"Exibir contagem de artigos não lidos"</string> |   <string name="switch_unread_count_title">"Exibir contagem de artigos não lidos"</string> | ||||||
|   <string name="display_all_counts_title">"Exibir contagem de lidos e favoritos"</string> |   <string name="display_all_counts_title">"Exibir contagem de lidos e favoritos"</string> | ||||||
|   <string name="menu_share_the_app">"Convidar amigos"</string> |     <string name="text_wrong_url">"Parece que você está tentando utilizar uma URL inválida. Certifique-se de que está correto, e se o problema persistir, entre em contato comigo (através do link de contato da loja). Por favor, note que o aplicativo precisa que você esteja usando o Selfoss. Você não pode acessar feeds RSS sem ele."</string> | ||||||
|   <string name="invitation_title">"Experimente este aplicativo para seus feeds RSS do Selfoss !"</string> |  | ||||||
|   <string name="invitation_message">"Eu uso o app para o visualizar meu feed RSS do Selfoss. Você vai gostar também !"</string> |  | ||||||
|   <string name="invitation_cta">"Experimente o aplicativo"</string> |  | ||||||
|   <string name="text_wrong_url">"Parece que você está tentando utilizar uma URL inválida. Certifique-se de que está correto, e se o problema persistir, entre em contato comigo (através do link de contato da loja). Por favor, note que o aplicativo precisa que você esteja usando o Selfoss. Você não pode acessar feeds RSS sem ele."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Abrir links dentro do aplicativo"</string> |   <string name="pref_general_internal_browser_title">"Abrir links dentro do aplicativo"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Os artigos serão abertos dentro do aplicativo"</string> |   <string name="pref_general_internal_browser_on">"Os artigos serão abertos dentro do aplicativo"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Os artigos serão abertos com seu navegador padrão"</string> |   <string name="pref_general_internal_browser_off">"Os artigos serão abertos com seu navegador padrão"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"O controle remoto foi atualizado, agora você pode recarregar a lista de artigos"</string> |   <string name="refresh_success_response">"O controle remoto foi atualizado, agora você pode recarregar a lista de artigos"</string> | ||||||
|   <string name="refresh_failer_message">"A atualização não funcionou, tente novamente mais tarde ou verifique seus logs do Selfoss."</string> |   <string name="refresh_failer_message">"A atualização não funcionou, tente novamente mais tarde ou verifique seus logs do Selfoss."</string> | ||||||
|   <string name="refresh_in_progress">"Atualização em progresso"</string> |   <string name="refresh_in_progress">"Atualização em progresso"</string> | ||||||
|   <string name="new_apk_available_title">"Um novo APK está disponível."</string> |     <string name="card_height_title">Cards com altura total</string> | ||||||
|   <string name="new_apk_available_message">"Um novo APK está disponível para download no repositório oficial."</string> |  | ||||||
|   <string name="new_apk_available_get">"Baixar agora"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignorar"</string> |  | ||||||
|   <string name="intro_hello_title">"Olá !"</string> |  | ||||||
|   <string name="intro_hello_message">"Obrigado por baixar o app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Antes que você comece…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"Você não pode usar o aplicativo sem uma instância do Selfoss."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"O que é Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"Tudo pronto !"</string> |  | ||||||
|   <string name="intro_all_set_message">"Você está pronto para usar o aplicativo. Não se esqueça de acessar a página de configurações para configurar seu aplicativo e onde você encontrará alguns links úteis."</string> |  | ||||||
|   <string name="card_height_title">Cards com altura total</string> |  | ||||||
|   <string name="card_height_on">Cards com altura ajustáveis de acordo com o conteúdo</string> |   <string name="card_height_on">Cards com altura ajustáveis de acordo com o conteúdo</string> | ||||||
|   <string name="card_height_off">Cards com altura de tamanho fixo</string> |   <string name="card_height_off">Cards com altura de tamanho fixo</string> | ||||||
|   <string name="source_code">Código fonte</string> |   <string name="source_code">Código fonte</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">Houve um problema ao tentar se comunicar com o seu Selfoss. Se o problema persistir, entre em contato comigo.</string> |   <string name="base_url_error">Houve um problema ao tentar se comunicar com o seu Selfoss. Se o problema persistir, entre em contato comigo.</string> | ||||||
|   <string name="pref_header_theme">Temas</string> |   <string name="pref_header_theme">Temas</string> | ||||||
|   <string name="default_theme">Padrão</string> |   <string name="default_theme">Padrão</string> | ||||||
|   <string name="teal_orange_theme">Cerceta/Laranja/Claro</string> |  | ||||||
|   <string name="cyan_pink_theme">Ciano/Rosa/Claro</string> |  | ||||||
|   <string name="grey_orange_theme">Cinza/Laranja/Claro</string> |  | ||||||
|   <string name="blue_amber_theme">Azul/Âmbar/Claro</string> |  | ||||||
|   <string name="indigo_pink_theme">Índigo/Rosa/Claro</string> |  | ||||||
|   <string name="red_teal_theme">Vermelho/Cerceta/Claro</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Cerceta/Laranja/Escuro</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Ciano/Rosa/Escuro</string> |  | ||||||
|   <string name="default_dark_theme">Padrão/Escuro</string> |   <string name="default_dark_theme">Padrão/Escuro</string> | ||||||
|   <string name="grey_orange_dark_theme">Cinza/Laranja/Escuro</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Azul/Âmbar/Escuro</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Índigo/Rosa/Escuro</string> |  | ||||||
|   <string name="red_teal_dark_theme">Vermelho/Âmbar/Escuro</string> |  | ||||||
|   <string name="pref_header_debug">Depurar</string> |   <string name="pref_header_debug">Depurar</string> | ||||||
|   <string name="login_debug_title">Ativar para registrar erros de login</string> |   <string name="login_debug_title">Ativar para registrar erros de login</string> | ||||||
|   <string name="login_debug_on">Qualquer erro na página de login será registrado</string> |   <string name="login_debug_on">Qualquer erro na página de login será registrado</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Por motivos de segurança, certificados autônomos não são suportados por padrão. Ao ativar, não serei responsável por qualquer problema de segurança que você encontre.</string> |   <string name="self_signed_cert_warning">Por motivos de segurança, certificados autônomos não são suportados por padrão. Ao ativar, não serei responsável por qualquer problema de segurança que você encontre.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Quantidade de itens carregados</string> |   <string name="pref_api_items_number_title">Quantidade de itens carregados</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Ler os artigos que aparecem como não lidos ?</string> |   <string name="read_debug_title">Ler os artigos que aparecem como não lidos ?</string> | ||||||
|   <string name="read_debug_off">Nenhum registro ao marcar um item como lido</string> |   <string name="read_debug_off">Nenhum registro ao marcar um item como lido</string> | ||||||
|   <string name="read_debug_on">As chamadas Api serão registradas ao marcar um artigo como lido</string> |   <string name="read_debug_on">As chamadas Api serão registradas ao marcar um artigo como lido</string> | ||||||
| @@ -165,6 +139,18 @@ | |||||||
|   <string name="pref_header_viewer">Visualizador de artigos</string> |   <string name="pref_header_viewer">Visualizador de artigos</string> | ||||||
|   <string name="refresh_dialog_message">Isso atualizará sua instância do Selfoss.</string> |   <string name="refresh_dialog_message">Isso atualizará sua instância do Selfoss.</string> | ||||||
|   <string name="markall_dialog_message">Isso marcará todos os itens como lidos.</string> |   <string name="markall_dialog_message">Isso marcará todos os itens como lidos.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Marcar Como Lida ao Abrir</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Não marca artigos como lido quando abrir.</string> | ||||||
|  |   <string name="gdpr_dialog_message">O app não recolhe quaisquer dados pessoais. Todas as ferramentas de análise foram removidas. Envio de relatórios de erro agora é opcional, como é o log de depuração. Tenha em mente que a depuração e relatórios de erro são essenciais para o desenvolvimento do app (você pode configurar tudo em configurações > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">O app não compartilha dados pessoais sobre você.</string> | ||||||
|  |   <string name="crash_dialog_text">Algo deu errado. Por favor envie o relatório para o desenvolvedor.</string> | ||||||
|  |   <string name="crash_dialog_comment">Você pode adicionar informação útil no comentário abaixo. Não inclua quaisquer dados pessoais no seu comentário. Você pode enviar um e-mail com sua id de depuração, e eu vou mantê-lo informado quando o problema for resolvido.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Envia relatórios de erros automaticamente</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Enviar relatórios de erro automaticamente</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Perguntar sempre, ao enviar relatórios de erro.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Relatório de erro</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Log de depuração (Serão enviados sem uma caixa de diálogo)</string> | ||||||
|  |   <string name="acra_login">Ativar registro de erros</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Exibir a contagem não lida como um emblema para a barra inferior."</string> |   <string name="switch_unread_count">"Exibir a contagem não lida como um emblema para a barra inferior."</string> | ||||||
|   <string name="switch_unread_count_title">"Exibir a contagem não lida"</string> |   <string name="switch_unread_count_title">"Exibir a contagem não lida"</string> | ||||||
|   <string name="display_all_counts_title">"Exibir a contagem para o favorito e leitura"</string> |   <string name="display_all_counts_title">"Exibir a contagem para o favorito e leitura"</string> | ||||||
|   <string name="menu_share_the_app">"Convidar amigos"</string> |     <string name="text_wrong_url">"Você parece estar tentando usar um URL inválido. Certifique-se de que está correto, e se o problema persistir, entre em contato comigo (através do link de contato da loja). Por favor, note que o aplicativo precisa que você esteja usando o Selfoss. Você não pode acessar feeds RSS sem ele."</string> | ||||||
|   <string name="invitation_title">"Tente este aplicativo para seus Selfoss RSS feeds!"</string> |  | ||||||
|   <string name="invitation_message">"Eu uso este app para meus Selfoss RSS feeds. Você pode gostar também!"</string> |  | ||||||
|   <string name="invitation_cta">"Tente o aplicativo"</string> |  | ||||||
|   <string name="text_wrong_url">"Você parece estar tentando usar um URL inválido. Certifique-se de que está correto, e se o problema persistir, entre em contato comigo (através do link de contato da loja). Por favor, note que o aplicativo precisa que você esteja usando o Selfoss. Você não pode acessar feeds RSS sem ele."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Abrir links dentro do app"</string> |   <string name="pref_general_internal_browser_title">"Abrir links dentro do app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Artigos serão aberto dentro do aplicativo"</string> |   <string name="pref_general_internal_browser_on">"Artigos serão aberto dentro do aplicativo"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Artigos serão aberto com o seu navegador padrão"</string> |   <string name="pref_general_internal_browser_off">"Artigos serão aberto com o seu navegador padrão"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"O remoto é atualizado, você agora pode recarregar a lista de artigos"</string> |   <string name="refresh_success_response">"O remoto é atualizado, você agora pode recarregar a lista de artigos"</string> | ||||||
|   <string name="refresh_failer_message">"A atualização não funcionar, tente novamente mais tarde ou verifique seus logs de selfoss."</string> |   <string name="refresh_failer_message">"A atualização não funcionar, tente novamente mais tarde ou verifique seus logs de selfoss."</string> | ||||||
|   <string name="refresh_in_progress">"Atualização em curso"</string> |   <string name="refresh_in_progress">"Atualização em curso"</string> | ||||||
|   <string name="new_apk_available_title">"Está disponível um novo APK."</string> |     <string name="card_height_title">Cartões de altura total</string> | ||||||
|   <string name="new_apk_available_message">"Um APK novo está disponível para download no repositório oficial."</string> |  | ||||||
|   <string name="new_apk_available_get">"Fazer download agora"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignorar esta versão"</string> |  | ||||||
|   <string name="intro_hello_title">"Olá ai!"</string> |  | ||||||
|   <string name="intro_hello_message">"Obrigado por baixar o aplicativo!"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Antes de começar…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"Você não pode usar o app sem uma instância de Selfoss."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"O que é Selfoss?"</string> |  | ||||||
|   <string name="intro_all_set_title">"Tudo configurado!"</string> |  | ||||||
|   <string name="intro_all_set_message">"Você está pronto para usar o app. não se esqueça de ir para a página de configurações para configurar o seu aplicativo, e onde você encontrará alguns links úteis."</string> |  | ||||||
|   <string name="card_height_title">Cartões de altura total</string> |  | ||||||
|   <string name="card_height_on">Altura de cartas irá ajustar ao seu conteúdo</string> |   <string name="card_height_on">Altura de cartas irá ajustar ao seu conteúdo</string> | ||||||
|   <string name="card_height_off">Altura do cartão será corrigida</string> |   <string name="card_height_off">Altura do cartão será corrigida</string> | ||||||
|   <string name="source_code">Código fonte</string> |   <string name="source_code">Código fonte</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">Houve um problema ao tentar se comunicar com sua instância de Selfoss. Se o problema persistir, por favor entre em contato comigo.</string> |   <string name="base_url_error">Houve um problema ao tentar se comunicar com sua instância de Selfoss. Se o problema persistir, por favor entre em contato comigo.</string> | ||||||
|   <string name="pref_header_theme">Temas</string> |   <string name="pref_header_theme">Temas</string> | ||||||
|   <string name="default_theme">Predefinição</string> |   <string name="default_theme">Predefinição</string> | ||||||
|   <string name="teal_orange_theme">Verde-azulado/laranja/Luz</string> |  | ||||||
|   <string name="cyan_pink_theme">Ciano/rosa/luz</string> |  | ||||||
|   <string name="grey_orange_theme">Cinza/laranja/luz</string> |  | ||||||
|   <string name="blue_amber_theme">Azul/âmbar/luz</string> |  | ||||||
|   <string name="indigo_pink_theme">Índigo/rosa/luz</string> |  | ||||||
|   <string name="red_teal_theme">Vermelha/verde-azulado/Luz</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Verde-azulado/laranja/escuro</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Ciano/rosa/escura</string> |  | ||||||
|   <string name="default_dark_theme">Padrão/escuro</string> |   <string name="default_dark_theme">Padrão/escuro</string> | ||||||
|   <string name="grey_orange_dark_theme">Cinza/laranja/Escuro</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Azul/âmbar/escuro</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Índigo/rosa/escura</string> |  | ||||||
|   <string name="red_teal_dark_theme">Verde-azulado/vermelho/escuro</string> |  | ||||||
|   <string name="pref_header_debug">Depurar</string> |   <string name="pref_header_debug">Depurar</string> | ||||||
|   <string name="login_debug_title">Ativar para registrar erros de logon</string> |   <string name="login_debug_title">Ativar para registrar erros de logon</string> | ||||||
|   <string name="login_debug_on">Qualquer erro na página de login será registrado</string> |   <string name="login_debug_on">Qualquer erro na página de login será registrado</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Devido a razões de segurança, auto certificados auto-assinados não são suportados por padrão. Ao activar isto, eu não vou ser responsável de qualquer problema de segurança que você encontrar.</string> |   <string name="self_signed_cert_warning">Devido a razões de segurança, auto certificados auto-assinados não são suportados por padrão. Ao activar isto, eu não vou ser responsável de qualquer problema de segurança que você encontrar.</string> | ||||||
|   <string name="pref_selfoss_category">Api de Selfoss</string> |   <string name="pref_selfoss_category">Api de Selfoss</string> | ||||||
|   <string name="pref_api_items_number_title">Número de itens carregados</string> |   <string name="pref_api_items_number_title">Número de itens carregados</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Leia artigos aparecem como não lidas?</string> |   <string name="read_debug_title">Leia artigos aparecem como não lidas?</string> | ||||||
|   <string name="read_debug_off">Sem log quando marcar um item como lido</string> |   <string name="read_debug_off">Sem log quando marcar um item como lido</string> | ||||||
|   <string name="read_debug_on">Chamadas de Api serão registradas quando marcar um artigo como lido</string> |   <string name="read_debug_on">Chamadas de Api serão registradas quando marcar um artigo como lido</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,10 +64,6 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |  | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
| @@ -86,17 +82,6 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |  | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |   <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |     <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> |   <string name="pref_general_internal_browser_off">"Articles will open with your default browser"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |     <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |  | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
|   <string name="source_code">Source code</string> |   <string name="source_code">Source code</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,11 +64,7 @@ | |||||||
|   <string name="switch_unread_count">"Okunmamış sayıyı, alt çubuk için bir rozet olarak görüntüleyin."</string> |   <string name="switch_unread_count">"Okunmamış sayıyı, alt çubuk için bir rozet olarak görüntüleyin."</string> | ||||||
|   <string name="switch_unread_count_title">"Okunmamış sayıyı görüntüle"</string> |   <string name="switch_unread_count_title">"Okunmamış sayıyı görüntüle"</string> | ||||||
|   <string name="display_all_counts_title">"Favori ve okunan sayıları göster"</string> |   <string name="display_all_counts_title">"Favori ve okunan sayıları göster"</string> | ||||||
|   <string name="menu_share_the_app">"Arkadaşları davet et"</string> |     <string name="text_wrong_url">"Geçersiz bir URL kullanmaya çalışıyormuş gibi görünüyorsunuz. Doğru olduğundan emin olun ve sorun devam ederse, bana ulaşın (mağaza iletişim bağlantısıyla). Uygulamanın, Selfoss'u kullanmanız gerektiğini lütfen unutmayın. RSS özet akışlarına olmadan erişemezsiniz."</string> | ||||||
|   <string name="invitation_title">"Selfoss RSS yayınlarınız için bu uygulamayı deneyin!"</string> |  | ||||||
|   <string name="invitation_message">"Bu uygulamayı Selfoss RSS özet akışlarım için kullanıyorum. Sizin de hoşunuza gidebilir !"</string> |  | ||||||
|   <string name="invitation_cta">"Uygulamayı dene"</string> |  | ||||||
|   <string name="text_wrong_url">"Geçersiz bir URL kullanmaya çalışıyormuş gibi görünüyorsunuz. Doğru olduğundan emin olun ve sorun devam ederse, bana ulaşın (mağaza iletişim bağlantısıyla). Uygulamanın, Selfoss'u kullanmanız gerektiğini lütfen unutmayın. RSS özet akışlarına olmadan erişemezsiniz."</string> |  | ||||||
|   <string name="pref_general_internal_browser_title">"Uygulamadaki bağlantıları açın"</string> |   <string name="pref_general_internal_browser_title">"Uygulamadaki bağlantıları açın"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Makale, uygulama içinde açılacaktır"</string> |   <string name="pref_general_internal_browser_on">"Makale, uygulama içinde açılacaktır"</string> | ||||||
|   <string name="pref_general_internal_browser_off">"Makaleler varsayılan tarayıcınızla açılır"</string> |   <string name="pref_general_internal_browser_off">"Makaleler varsayılan tarayıcınızla açılır"</string> | ||||||
| @@ -86,18 +82,7 @@ | |||||||
|   <string name="refresh_success_response">"Uzaktan güncelleştirilir, şimdi makaleler listesi yeniden yükleyebilirsiniz"</string> |   <string name="refresh_success_response">"Uzaktan güncelleştirilir, şimdi makaleler listesi yeniden yükleyebilirsiniz"</string> | ||||||
|   <string name="refresh_failer_message">"Güncelleme çalışmadı, daha sonra tekrar deneyin veya selfoss günlüklerinizi kontrol edin."</string> |   <string name="refresh_failer_message">"Güncelleme çalışmadı, daha sonra tekrar deneyin veya selfoss günlüklerinizi kontrol edin."</string> | ||||||
|   <string name="refresh_in_progress">"Yenileme devam ediyor"</string> |   <string name="refresh_in_progress">"Yenileme devam ediyor"</string> | ||||||
|   <string name="new_apk_available_title">"Yeni bir güncelleme var."</string> |     <string name="card_height_title">Tam boy kartlar</string> | ||||||
|   <string name="new_apk_available_message">"Yeni bir APK deposu resmi indirmek kullanılabilir."</string> |  | ||||||
|   <string name="new_apk_available_get">"Şimdi indir"</string> |  | ||||||
|   <string name="new_apk_available_no">"Bu sürümü yoksay"</string> |  | ||||||
|   <string name="intro_hello_title">"Selam!"</string> |  | ||||||
|   <string name="intro_hello_message">"Uygulamayı indirdiğiniz için teşekkür ederiz!"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Başlamadan önce…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"Uygulamayı bir Selfoss örneği olmadan kullanamazsınız."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"Selfoss nedir?"</string> |  | ||||||
|   <string name="intro_all_set_title">"Her şey tamam!"</string> |  | ||||||
|   <string name="intro_all_set_message">"Uygulamayı kullanmaya hazırsınız. Uygulamanızı yapılandırmak için ayarlar sayfasına gitmeyi ve bazı yararlı bağlantıları nereden bulacağınızı unutma."</string> |  | ||||||
|   <string name="card_height_title">Tam boy kartlar</string> |  | ||||||
|   <string name="card_height_on">Kartların yüksekliği içeriğine göre ayarlanır</string> |   <string name="card_height_on">Kartların yüksekliği içeriğine göre ayarlanır</string> | ||||||
|   <string name="card_height_off">Kart yüksekliği sabit olacak</string> |   <string name="card_height_off">Kart yüksekliği sabit olacak</string> | ||||||
|   <string name="source_code">Kaynak kodu</string> |   <string name="source_code">Kaynak kodu</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">Selfoss Örneğinizle iletişim kurmaya çalışırken bir sorun oluştu. Sorun devam ederse, lütfen benimle iletişime geçin.</string> |   <string name="base_url_error">Selfoss Örneğinizle iletişim kurmaya çalışırken bir sorun oluştu. Sorun devam ederse, lütfen benimle iletişime geçin.</string> | ||||||
|   <string name="pref_header_theme">Temalar</string> |   <string name="pref_header_theme">Temalar</string> | ||||||
|   <string name="default_theme">Varsayılan</string> |   <string name="default_theme">Varsayılan</string> | ||||||
|   <string name="teal_orange_theme">Deniz mavisi/turuncu/ışık</string> |  | ||||||
|   <string name="cyan_pink_theme">Camgöbeği/pembe/ışık</string> |  | ||||||
|   <string name="grey_orange_theme">Gri/turuncu/ışık</string> |  | ||||||
|   <string name="blue_amber_theme">Mavi/Amber/ışık</string> |  | ||||||
|   <string name="indigo_pink_theme">Çivit/Pembe/Işık</string> |  | ||||||
|   <string name="red_teal_theme">Kırmızı/deniz mavisi/ışık</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Deniz mavisi/turuncu/koyu</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Camgöbeği/pembe/koyu</string> |  | ||||||
|   <string name="default_dark_theme">Varsayılan/koyu</string> |   <string name="default_dark_theme">Varsayılan/koyu</string> | ||||||
|   <string name="grey_orange_dark_theme">Gri/turuncu/koyu</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Mavi/Kehribar/koyu</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Çivit/Pembe/Işık</string> |  | ||||||
|   <string name="red_teal_dark_theme">Kırmızı/deniz mavisi/koyu</string> |  | ||||||
|   <string name="pref_header_debug">Hata ayıklama</string> |   <string name="pref_header_debug">Hata ayıklama</string> | ||||||
|   <string name="login_debug_title">Giriş hatalarını kaydetmek için etkinleştir</string> |   <string name="login_debug_title">Giriş hatalarını kaydetmek için etkinleştir</string> | ||||||
|   <string name="login_debug_on">Oturum açma sayfasındaki herhangi bir hata günlüğe kaydedilecek</string> |   <string name="login_debug_on">Oturum açma sayfasındaki herhangi bir hata günlüğe kaydedilecek</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Güvenlik nedeniyle, kendinden imzalı sertifikalar varsayılan olarak desteklenmez. Bunu etkinleştirerek karşılaştığınız herhangi bir güvenlik sorununun sorumluluğunu almayacağım.</string> |   <string name="self_signed_cert_warning">Güvenlik nedeniyle, kendinden imzalı sertifikalar varsayılan olarak desteklenmez. Bunu etkinleştirerek karşılaştığınız herhangi bir güvenlik sorununun sorumluluğunu almayacağım.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Uygulaması</string> |   <string name="pref_selfoss_category">Selfoss Uygulaması</string> | ||||||
|   <string name="pref_api_items_number_title">Yüklenen öğe numarası</string> |   <string name="pref_api_items_number_title">Yüklenen öğe numarası</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Okunmamış makaleleri görüntüle?</string> |   <string name="read_debug_title">Okunmamış makaleleri görüntüle?</string> | ||||||
|   <string name="read_debug_off">Bir öğeyi işaretlediğinde günlük yok</string> |   <string name="read_debug_off">Bir öğeyi işaretlediğinde günlük yok</string> | ||||||
|   <string name="read_debug_on">Bir makaleyi okundu olarak işaretlerken Api çağrıları günlüğe kaydedilir</string> |   <string name="read_debug_on">Bir makaleyi okundu olarak işaretlerken Api çağrıları günlüğe kaydedilir</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |     <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
| @@ -64,10 +64,6 @@ | |||||||
|   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> |   <string name="switch_unread_count">"Display the unread count as a badge for the bottom bar."</string> | ||||||
|   <string name="switch_unread_count_title">"Display unread count"</string> |   <string name="switch_unread_count_title">"Display unread count"</string> | ||||||
|   <string name="display_all_counts_title">"Display count for favorite and read"</string> |   <string name="display_all_counts_title">"Display count for favorite and read"</string> | ||||||
|   <string name="menu_share_the_app">"Invite friends"</string> |  | ||||||
|   <string name="invitation_title">"Try this app for your Selfoss RSS feeds !"</string> |  | ||||||
|   <string name="invitation_message">"I use this app for my Selfoss RSS feeds. You may like it too !"</string> |  | ||||||
|   <string name="invitation_cta">"Try the app"</string> |  | ||||||
|   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> |   <string name="text_wrong_url">"You seem to be trying to use an invalid URL. Make sure it is correct, and if the problem persists, contact me (via the store contact link). Please note that the app needs you to be using Selfoss. You can't access RSS feeds without it."</string> | ||||||
|   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> |   <string name="pref_general_internal_browser_title">"Open links inside the app"</string> | ||||||
|   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> |   <string name="pref_general_internal_browser_on">"Articles will open inside the app"</string> | ||||||
| @@ -86,17 +82,6 @@ | |||||||
|   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> |   <string name="refresh_success_response">"The remote is updated, you can now reload the articles list"</string> | ||||||
|   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> |   <string name="refresh_failer_message">"The update didn't work, try again later, or check your selfoss logs."</string> | ||||||
|   <string name="refresh_in_progress">"Refresh in progress"</string> |   <string name="refresh_in_progress">"Refresh in progress"</string> | ||||||
|   <string name="new_apk_available_title">"A new APK is available."</string> |  | ||||||
|   <string name="new_apk_available_message">"A new APK is available to download on the official repository."</string> |  | ||||||
|   <string name="new_apk_available_get">"Download now"</string> |  | ||||||
|   <string name="new_apk_available_no">"Ignore version"</string> |  | ||||||
|   <string name="intro_hello_title">"Hi there !"</string> |  | ||||||
|   <string name="intro_hello_message">"Thanks for downloading the app !"</string> |  | ||||||
|   <string name="intro_needs_selfoss_title">"Before you start…"</string> |  | ||||||
|   <string name="intro_needs_selfoss_message">"You can't use the app without a Selfoss instance."</string> |  | ||||||
|   <string name="intro_needs_selfoss_link">"What is Selfoss ?"</string> |  | ||||||
|   <string name="intro_all_set_title">"All set !"</string> |  | ||||||
|   <string name="intro_all_set_message">"You are ready to use the app. Don't forget to go to the settings page to configure your app, and where you'll find some useful links."</string> |  | ||||||
|   <string name="card_height_title">Full height cards</string> |   <string name="card_height_title">Full height cards</string> | ||||||
|   <string name="card_height_on">Cards height will adjust to its content</string> |   <string name="card_height_on">Cards height will adjust to its content</string> | ||||||
|   <string name="card_height_off">Card height will be fixed</string> |   <string name="card_height_off">Card height will be fixed</string> | ||||||
| @@ -118,19 +103,7 @@ | |||||||
|   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> |   <string name="base_url_error">There was an issue when trying to communicate with your Selfoss Instance. If the issue persists, please get in touch with me.</string> | ||||||
|   <string name="pref_header_theme">Themes</string> |   <string name="pref_header_theme">Themes</string> | ||||||
|   <string name="default_theme">Default</string> |   <string name="default_theme">Default</string> | ||||||
|   <string name="teal_orange_theme">Teal/Orange/Light</string> |  | ||||||
|   <string name="cyan_pink_theme">Cyan/Pink/Light</string> |  | ||||||
|   <string name="grey_orange_theme">Grey/Orange/Light</string> |  | ||||||
|   <string name="blue_amber_theme">Blue/Amber/Light</string> |  | ||||||
|   <string name="indigo_pink_theme">Indigo/Pink/Light</string> |  | ||||||
|   <string name="red_teal_theme">Red/Teal/Light</string> |  | ||||||
|   <string name="teal_orange_dark_theme">Teal/Orange/Dark</string> |  | ||||||
|   <string name="cyan_pink_dark_theme">Cyan/Pink/Dark</string> |  | ||||||
|   <string name="default_dark_theme">Default/Dark</string> |   <string name="default_dark_theme">Default/Dark</string> | ||||||
|   <string name="grey_orange_dark_theme">Grey/Orange/Dark</string> |  | ||||||
|   <string name="blue_amber_dark_theme">Blue/Amber/Dark</string> |  | ||||||
|   <string name="indigo_pink_dark_theme">Indigo/Pink/Dark</string> |  | ||||||
|   <string name="red_teal_dark_theme">Red/Teal/Dark</string> |  | ||||||
|   <string name="pref_header_debug">Debug</string> |   <string name="pref_header_debug">Debug</string> | ||||||
|   <string name="login_debug_title">Activate to log login errors</string> |   <string name="login_debug_title">Activate to log login errors</string> | ||||||
|   <string name="login_debug_on">Any error on the login page will be logged</string> |   <string name="login_debug_on">Any error on the login page will be logged</string> | ||||||
| @@ -140,6 +113,7 @@ | |||||||
|   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> |   <string name="self_signed_cert_warning">Due to security reasons, self signed certificates are not supported by default. By activating this, I\'ll not be responsible of any security problem you encounter.</string> | ||||||
|   <string name="pref_selfoss_category">Selfoss Api</string> |   <string name="pref_selfoss_category">Selfoss Api</string> | ||||||
|   <string name="pref_api_items_number_title">Loaded items number</string> |   <string name="pref_api_items_number_title">Loaded items number</string> | ||||||
|  |   <string name="pref_hidden_tags">Hidden Tags</string> | ||||||
|   <string name="read_debug_title">Read articles appearing as unread ?</string> |   <string name="read_debug_title">Read articles appearing as unread ?</string> | ||||||
|   <string name="read_debug_off">No log when marking an item as read</string> |   <string name="read_debug_off">No log when marking an item as read</string> | ||||||
|   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> |   <string name="read_debug_on">Api calls will be logged when marking an article as read</string> | ||||||
| @@ -167,4 +141,16 @@ | |||||||
|   <string name="markall_dialog_message">This will mark all the items as read.</string> |   <string name="markall_dialog_message">This will mark all the items as read.</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> |   <string name="pref_switch_actions_pager_scroll">Mark as read on swipe</string> | ||||||
|   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> |   <string name="pref_switch_actions_pager_scroll_off">Don\'t mark articles as read when swiping.</string> | ||||||
|  |   <string name="gdpr_dialog_message">The app does not collect any personal data. Every analytics tools were removed. Crash reports sending is now optional, as is the debug logging. Keep in mind that debugging and crash reports are essential for the app development (You can configure everything in Settings > Debug).</string> | ||||||
|  |   <string name="gdpr_dialog_title">The app does not share any personal data about you.</string> | ||||||
|  |   <string name="crash_dialog_text">Something went wrong. Please send the report to the developer.</string> | ||||||
|  |   <string name="crash_dialog_comment">You can add any helpful details in the comment bellow. Don\'t include any personal data in your comment. You could send me and email with your debug id, and I\'ll keep you posted when the issue is resolved.</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept">Automatically send crash reports</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_enabled">Will send crash reports automatically</string> | ||||||
|  |   <string name="pref_acra_alwaysaccept_disabled">Will ask everytime when sending crash reports.</string> | ||||||
|  |   <string name="pref_debug_crash_reports">Crash reports</string> | ||||||
|  |   <string name="pref_debug_debug_logs">Debug logging (these will be sent without a dialog)</string> | ||||||
|  |   <string name="acra_login">Enable logging</string> | ||||||
|  |   <string name="drawer_item_hidden_tags">Hidden Tags</string> | ||||||
|  |   <string name="unmark">Mark item as unread</string> | ||||||
| </resources> | </resources> | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user