diff --git a/build.gradle b/build.gradle index d64f093fe..6c752a48d 100644 --- a/build.gradle +++ b/build.gradle @@ -56,4 +56,4 @@ sonarqube { property 'sonar.exclusions', '**/src/main/assets/**/*.*' property 'sonar.test.exclusions', '**/src/test/**/*.*,**/src/androidTest/**/*.*' } -} +} \ No newline at end of file diff --git a/omniNotes/build.gradle b/omniNotes/build.gradle index dfa7ac3c7..010c86dd5 100644 --- a/omniNotes/build.gradle +++ b/omniNotes/build.gradle @@ -157,6 +157,7 @@ dependencies { implementation 'com.google.android.apps.dashclock:dashclock-api:2.0.0' implementation 'ch.acra:acra-http:5.11.2' implementation 'ch.acra:acra-toast:5.11.2' + implementation 'commons-io:commons-io:2.16.1' implementation 'com.github.gabrielemariotti.changeloglib:changelog:2.1.0' implementation 'com.github.vikramkakkar:SublimePicker:8f573b1cfd' implementation 'androidx.preference:preference-ktx:1.2.1' @@ -202,11 +203,10 @@ dependencies { implementation 'com.github.federicoiosue:pixlui:3.0.1' // Flavors specific dependencies - playImplementation 'io.nlopez.smartlocation:library:3.2.4' - betaImplementation 'io.nlopez.smartlocation:library:3.2.4' - alphaImplementation 'io.nlopez.smartlocation:library:3.2.4' - fossImplementation 'com.github.federicoiosue:smart-location-lib:3.2.6' - fossImplementation 'com.jakewharton.timber:timber:5.0.1' + playImplementation 'com.google.android.gms:play-services-location:21.3.0' + betaImplementation 'com.google.android.gms:play-services-location:21.3.0' + alphaImplementation 'com.google.android.gms:play-services-location:21.3.0' +// fossImplementation 'com.jakewharton.timber:timber:5.0.1' } def jacocoVersion = "0.8.7" @@ -266,6 +266,8 @@ tasks.withType(Test).configureEach { exceptionFormat "full" } } -repositories { - mavenCentral() + +tasks.register('wrapper', Wrapper) { + gradleVersion = '8.7' + validateDistributionUrl = false } diff --git a/omniNotes/gradle/wrapper/gradle-wrapper.jar b/omniNotes/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 000000000..e6441136f Binary files /dev/null and b/omniNotes/gradle/wrapper/gradle-wrapper.jar differ diff --git a/omniNotes/gradle/wrapper/gradle-wrapper.properties b/omniNotes/gradle/wrapper/gradle-wrapper.properties new file mode 100644 index 000000000..a0777a32c --- /dev/null +++ b/omniNotes/gradle/wrapper/gradle-wrapper.properties @@ -0,0 +1,6 @@ +distributionBase=GRADLE_USER_HOME +distributionPath=wrapper/dists +distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip +validateDistributionUrl=false +zipStoreBase=GRADLE_USER_HOME +zipStorePath=wrapper/dists diff --git a/omniNotes/gradlew b/omniNotes/gradlew new file mode 100755 index 000000000..1aa94a426 --- /dev/null +++ b/omniNotes/gradlew @@ -0,0 +1,249 @@ +#!/bin/sh + +# +# Copyright © 2015-2021 the original authors. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# https://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +############################################################################## +# +# Gradle start up script for POSIX generated by Gradle. +# +# Important for running: +# +# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is +# noncompliant, but you have some other compliant shell such as ksh or +# bash, then to run this script, type that shell name before the whole +# command line, like: +# +# ksh Gradle +# +# Busybox and similar reduced shells will NOT work, because this script +# requires all of these POSIX shell features: +# * functions; +# * expansions «$var», «${var}», «${var:-default}», «${var+SET}», +# «${var#prefix}», «${var%suffix}», and «$( cmd )»; +# * compound commands having a testable exit status, especially «case»; +# * various built-in commands including «command», «set», and «ulimit». +# +# Important for patching: +# +# (2) This script targets any POSIX shell, so it avoids extensions provided +# by Bash, Ksh, etc; in particular arrays are avoided. +# +# The "traditional" practice of packing multiple parameters into a +# space-separated string is a well documented source of bugs and security +# problems, so this is (mostly) avoided, by progressively accumulating +# options in "$@", and eventually passing that to Java. +# +# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, +# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; +# see the in-line comments for details. +# +# There are tweaks for specific operating systems such as AIX, CygWin, +# Darwin, MinGW, and NonStop. +# +# (3) This script is generated from the Groovy template +# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt +# within the Gradle project. +# +# You can find Gradle at https://github.com/gradle/gradle/. +# +############################################################################## + +# Attempt to set APP_HOME + +# Resolve links: $0 may be a link +app_path=$0 + +# Need this for daisy-chained symlinks. +while + APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path + [ -h "$app_path" ] +do + ls=$( ls -ld "$app_path" ) + link=${ls#*' -> '} + case $link in #( + /*) app_path=$link ;; #( + *) app_path=$APP_HOME$link ;; + esac +done + +# This is normally unused +# shellcheck disable=SC2034 +APP_BASE_NAME=${0##*/} +# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036) +APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit + +# Use the maximum available, or set MAX_FD != -1 to use that value. +MAX_FD=maximum + +warn () { + echo "$*" +} >&2 + +die () { + echo + echo "$*" + echo + exit 1 +} >&2 + +# OS specific support (must be 'true' or 'false'). +cygwin=false +msys=false +darwin=false +nonstop=false +case "$( uname )" in #( + CYGWIN* ) cygwin=true ;; #( + Darwin* ) darwin=true ;; #( + MSYS* | MINGW* ) msys=true ;; #( + NONSTOP* ) nonstop=true ;; +esac + +CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar + + +# Determine the Java command to use to start the JVM. +if [ -n "$JAVA_HOME" ] ; then + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then + # IBM's JDK on AIX uses strange locations for the executables + JAVACMD=$JAVA_HOME/jre/sh/java + else + JAVACMD=$JAVA_HOME/bin/java + fi + if [ ! -x "$JAVACMD" ] ; then + die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." + fi +else + JAVACMD=java + if ! command -v java >/dev/null 2>&1 + then + die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." + fi +fi + +# Increase the maximum file descriptors if we can. +if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then + case $MAX_FD in #( + max*) + # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked. + # shellcheck disable=SC2039,SC3045 + MAX_FD=$( ulimit -H -n ) || + warn "Could not query maximum file descriptor limit" + esac + case $MAX_FD in #( + '' | soft) :;; #( + *) + # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked. + # shellcheck disable=SC2039,SC3045 + ulimit -n "$MAX_FD" || + warn "Could not set maximum file descriptor limit to $MAX_FD" + esac +fi + +# Collect all arguments for the java command, stacking in reverse order: +# * args from the command line +# * the main class name +# * -classpath +# * -D...appname settings +# * --module-path (only if needed) +# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. + +# For Cygwin or MSYS, switch paths to Windows format before running java +if "$cygwin" || "$msys" ; then + APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) + CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) + + JAVACMD=$( cygpath --unix "$JAVACMD" ) + + # Now convert the arguments - kludge to limit ourselves to /bin/sh + for arg do + if + case $arg in #( + -*) false ;; # don't mess with options #( + /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath + [ -e "$t" ] ;; #( + *) false ;; + esac + then + arg=$( cygpath --path --ignore --mixed "$arg" ) + fi + # Roll the args list around exactly as many times as the number of + # args, so each arg winds up back in the position where it started, but + # possibly modified. + # + # NB: a `for` loop captures its iteration list before it begins, so + # changing the positional parameters here affects neither the number of + # iterations, nor the values presented in `arg`. + shift # remove old arg + set -- "$@" "$arg" # push replacement arg + done +fi + + +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' + +# Collect all arguments for the java command: +# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments, +# and any embedded shellness will be escaped. +# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be +# treated as '${Hostname}' itself on the command line. + +set -- \ + "-Dorg.gradle.appname=$APP_BASE_NAME" \ + -classpath "$CLASSPATH" \ + org.gradle.wrapper.GradleWrapperMain \ + "$@" + +# Stop when "xargs" is not available. +if ! command -v xargs >/dev/null 2>&1 +then + die "xargs is not available" +fi + +# Use "xargs" to parse quoted args. +# +# With -n1 it outputs one arg per line, with the quotes and backslashes removed. +# +# In Bash we could simply go: +# +# readarray ARGS < <( xargs -n1 <<<"$var" ) && +# set -- "${ARGS[@]}" "$@" +# +# but POSIX shell has neither arrays nor command substitution, so instead we +# post-process each arg (as a line of input to sed) to backslash-escape any +# character that might be a shell metacharacter, then use eval to reverse +# that process (while maintaining the separation between arguments), and wrap +# the whole thing up as a single "set" statement. +# +# This will of course break if any of these variables contains a newline or +# an unmatched quote. +# + +eval "set -- $( + printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | + xargs -n1 | + sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | + tr '\n' ' ' + )" '"$@"' + +exec "$JAVACMD" "$@" diff --git a/omniNotes/gradlew.bat b/omniNotes/gradlew.bat new file mode 100644 index 000000000..25da30dbd --- /dev/null +++ b/omniNotes/gradlew.bat @@ -0,0 +1,92 @@ +@rem +@rem Copyright 2015 the original author or authors. +@rem +@rem Licensed under the Apache License, Version 2.0 (the "License"); +@rem you may not use this file except in compliance with the License. +@rem You may obtain a copy of the License at +@rem +@rem https://www.apache.org/licenses/LICENSE-2.0 +@rem +@rem Unless required by applicable law or agreed to in writing, software +@rem distributed under the License is distributed on an "AS IS" BASIS, +@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +@rem See the License for the specific language governing permissions and +@rem limitations under the License. +@rem + +@if "%DEBUG%"=="" @echo off +@rem ########################################################################## +@rem +@rem Gradle startup script for Windows +@rem +@rem ########################################################################## + +@rem Set local scope for the variables with windows NT shell +if "%OS%"=="Windows_NT" setlocal + +set DIRNAME=%~dp0 +if "%DIRNAME%"=="" set DIRNAME=. +@rem This is normally unused +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@rem Resolve any "." and ".." in APP_HOME to make it shorter. +for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi + +@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" + +@rem Find java.exe +if defined JAVA_HOME goto findJavaFromJavaHome + +set JAVA_EXE=java.exe +%JAVA_EXE% -version >NUL 2>&1 +if %ERRORLEVEL% equ 0 goto execute + +echo. 1>&2 +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2 +echo. 1>&2 +echo Please set the JAVA_HOME variable in your environment to match the 1>&2 +echo location of your Java installation. 1>&2 + +goto fail + +:findJavaFromJavaHome +set JAVA_HOME=%JAVA_HOME:"=% +set JAVA_EXE=%JAVA_HOME%/bin/java.exe + +if exist "%JAVA_EXE%" goto execute + +echo. 1>&2 +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2 +echo. 1>&2 +echo Please set the JAVA_HOME variable in your environment to match the 1>&2 +echo location of your Java installation. 1>&2 + +goto fail + +:execute +@rem Setup the command line + +set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar + + +@rem Execute Gradle +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* + +:end +@rem End local scope for the variables with windows NT shell +if %ERRORLEVEL% equ 0 goto mainEnd + +:fail +rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of +rem the _cmd.exe /c_ return code! +set EXIT_CODE=%ERRORLEVEL% +if %EXIT_CODE% equ 0 set EXIT_CODE=1 +if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% +exit /b %EXIT_CODE% + +:mainEnd +if "%OS%"=="Windows_NT" endlocal + +:omega diff --git a/omniNotes/src/alpha/java/it/feio/android/omninotes/helpers/location/FuseLocationProvider.kt b/omniNotes/src/alpha/java/it/feio/android/omninotes/helpers/location/FuseLocationProvider.kt new file mode 100644 index 000000000..b252ed4f9 --- /dev/null +++ b/omniNotes/src/alpha/java/it/feio/android/omninotes/helpers/location/FuseLocationProvider.kt @@ -0,0 +1,37 @@ +/* + * Copyright (C) 2013-2024 Federico Iosue (federico@iosue.it) + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +package it.feio.android.omninotes.helpers.location + +import com.google.android.gms.location.LocationServices +import it.feio.android.omninotes.OmniNotes +import it.feio.android.omninotes.models.listeners.OnGeoUtilResultListener + +class FuseLocationProvider : LocationProvider { + + @kotlin.Throws(SecurityException::class) + override fun getLocation(onGeoUtilResultListener: OnGeoUtilResultListener?) { + LocationServices.getFusedLocationProviderClient(OmniNotes.getAppContext()).getLastLocation() + .addOnSuccessListener { location -> + if (location == null) { + onGeoUtilResultListener?.onLocationUnavailable(null) + } + onGeoUtilResultListener?.onLocationRetrieved(location) + } + .addOnFailureListener { e -> onGeoUtilResultListener?.onLocationUnavailable(e) } + } + +} diff --git a/omniNotes/src/main/java/it/feio/android/omninotes/models/listeners/OnGeoUtilResultListener.java b/omniNotes/src/alpha/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt similarity index 67% rename from omniNotes/src/main/java/it/feio/android/omninotes/models/listeners/OnGeoUtilResultListener.java rename to omniNotes/src/alpha/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt index be97ea346..1b59e41e9 100644 --- a/omniNotes/src/main/java/it/feio/android/omninotes/models/listeners/OnGeoUtilResultListener.java +++ b/omniNotes/src/alpha/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt @@ -14,21 +14,15 @@ * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ +package it.feio.android.omninotes.helpers.location -package it.feio.android.omninotes.models.listeners; +import lombok.experimental.UtilityClass +@UtilityClass +object LocationProviderFactory { -import android.location.Location; - - -public interface OnGeoUtilResultListener { - - void onAddressResolved(String address); - - void onCoordinatesResolved(Location location, String address); - - void onLocationRetrieved(Location location); - - void onLocationUnavailable(); - void onLocationNotEnabled(); + @Override + fun getProvider(): LocationProvider { + return FuseLocationProvider() + } } diff --git a/omniNotes/src/androidTest/java/it/feio/android/omninotes/async/upgrade/UpgradeProcessorTest.kt b/omniNotes/src/androidTest/java/it/feio/android/omninotes/async/upgrade/UpgradeProcessorTest.kt index 3f9c4054a..ab2a685bf 100644 --- a/omniNotes/src/androidTest/java/it/feio/android/omninotes/async/upgrade/UpgradeProcessorTest.kt +++ b/omniNotes/src/androidTest/java/it/feio/android/omninotes/async/upgrade/UpgradeProcessorTest.kt @@ -23,7 +23,6 @@ import it.feio.android.omninotes.utils.FileProviderHelper.getShareableUri import it.feio.android.omninotes.utils.StorageHelper.createAttachmentFromUri import org.junit.Assert.* import org.junit.Test -import java.util.stream.Stream class UpgradeProcessorTest : BaseAndroidTestCase() { @@ -32,7 +31,7 @@ class UpgradeProcessorTest : BaseAndroidTestCase() { // Preparation of database state existent pre-612 version. // Attachment used to be stored with "content://" scheme that allowed sharing but broke backups. val note = createTestNote("t", "c", 1) - var attachment = createAttachmentFromUri(testContext, note.attachmentsList[0].uri) + val attachment = createAttachmentFromUri(testContext, note.attachmentsList[0].uri) attachment?.uri = getShareableUri(attachment) note.attachmentsList[0] = attachment dbHelper.updateNote(note, false) diff --git a/omniNotes/src/androidTest/java/it/feio/android/omninotes/helpers/GeocodeProviderBaseFactoryTest.kt b/omniNotes/src/androidTest/java/it/feio/android/omninotes/helpers/GeocodeProviderBaseFactoryTest.kt index f53f4c630..b97c05fb8 100644 --- a/omniNotes/src/androidTest/java/it/feio/android/omninotes/helpers/GeocodeProviderBaseFactoryTest.kt +++ b/omniNotes/src/androidTest/java/it/feio/android/omninotes/helpers/GeocodeProviderBaseFactoryTest.kt @@ -16,26 +16,22 @@ */ package it.feio.android.omninotes.helpers +import it.feio.android.omninotes.helpers.location.LocationProviderFactory import it.feio.android.omninotes.testutils.BaseAndroidTestCase import org.junit.Assert.assertNotNull -import org.junit.Assert.assertTrue import org.junit.Test -class GeocodeProviderBaseFactoryTest : BaseAndroidTestCase() { - +class LocationProviderFactoryTest : BaseAndroidTestCase() { + @Test @Throws(Exception::class) fun checkUtilityClassWellDefined() { - assertUtilityClassWellDefined(GeocodeProviderBaseFactory::class.java, true, true) + assertUtilityClassWellDefined(LocationProviderFactory::class.java, true, true) } @Test fun provider() { - assertNotNull(GeocodeProviderBaseFactory.getProvider(testContext)) + assertNotNull(LocationProviderFactory.provider) } - @Test - fun checkHighAccuracyLocationProvider() { - assertTrue(GeocodeProviderBaseFactory.checkHighAccuracyLocationProvider(testContext)) - } } \ No newline at end of file diff --git a/omniNotes/src/androidTest/java/it/feio/android/omninotes/testutils/BaseAndroidTestCase.java b/omniNotes/src/androidTest/java/it/feio/android/omninotes/testutils/BaseAndroidTestCase.java index c9b6fff4a..26d0f765a 100644 --- a/omniNotes/src/androidTest/java/it/feio/android/omninotes/testutils/BaseAndroidTestCase.java +++ b/omniNotes/src/androidTest/java/it/feio/android/omninotes/testutils/BaseAndroidTestCase.java @@ -18,7 +18,6 @@ package it.feio.android.omninotes.testutils; import static android.Manifest.permission.ACCESS_COARSE_LOCATION; -import static android.Manifest.permission.ACCESS_FINE_LOCATION; import static android.Manifest.permission.POST_NOTIFICATIONS; import static android.Manifest.permission.READ_EXTERNAL_STORAGE; import static android.Manifest.permission.RECORD_AUDIO; @@ -102,7 +101,7 @@ public void tearDown() { .grant(android.Manifest.permission.CAMERA); private static void grantPermissions() { - GrantPermissionRule.grant(ACCESS_COARSE_LOCATION, ACCESS_FINE_LOCATION, READ_EXTERNAL_STORAGE, RECORD_AUDIO); + GrantPermissionRule.grant(ACCESS_COARSE_LOCATION, READ_EXTERNAL_STORAGE, RECORD_AUDIO); if (BuildHelper.isBelowOrEqual(VERSION_CODES.Q)) { GrantPermissionRule.grant(WRITE_EXTERNAL_STORAGE); } diff --git a/omniNotes/src/androidTest/java/it/feio/android/omninotes/utils/GeocodeHelperTest.java b/omniNotes/src/androidTest/java/it/feio/android/omninotes/utils/GeocodeHelperTest.java index d3d18d8af..6411f4133 100644 --- a/omniNotes/src/androidTest/java/it/feio/android/omninotes/utils/GeocodeHelperTest.java +++ b/omniNotes/src/androidTest/java/it/feio/android/omninotes/utils/GeocodeHelperTest.java @@ -21,6 +21,8 @@ import androidx.test.filters.FlakyTest; import it.feio.android.omninotes.testutils.BaseAndroidTestCase; import it.feio.android.omninotes.OmniNotes; +import it.feio.android.omninotes.helpers.location.GeocodeHelper; + import java.io.IOException; import org.junit.Assert; import org.junit.Test; diff --git a/omniNotes/src/beta/java/it/feio/android/omninotes/helpers/location/FuseLocationProvider.kt b/omniNotes/src/beta/java/it/feio/android/omninotes/helpers/location/FuseLocationProvider.kt new file mode 100644 index 000000000..b252ed4f9 --- /dev/null +++ b/omniNotes/src/beta/java/it/feio/android/omninotes/helpers/location/FuseLocationProvider.kt @@ -0,0 +1,37 @@ +/* + * Copyright (C) 2013-2024 Federico Iosue (federico@iosue.it) + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +package it.feio.android.omninotes.helpers.location + +import com.google.android.gms.location.LocationServices +import it.feio.android.omninotes.OmniNotes +import it.feio.android.omninotes.models.listeners.OnGeoUtilResultListener + +class FuseLocationProvider : LocationProvider { + + @kotlin.Throws(SecurityException::class) + override fun getLocation(onGeoUtilResultListener: OnGeoUtilResultListener?) { + LocationServices.getFusedLocationProviderClient(OmniNotes.getAppContext()).getLastLocation() + .addOnSuccessListener { location -> + if (location == null) { + onGeoUtilResultListener?.onLocationUnavailable(null) + } + onGeoUtilResultListener?.onLocationRetrieved(location) + } + .addOnFailureListener { e -> onGeoUtilResultListener?.onLocationUnavailable(e) } + } + +} diff --git a/omniNotes/src/beta/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java b/omniNotes/src/beta/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt similarity index 61% rename from omniNotes/src/beta/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java rename to omniNotes/src/beta/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt index b938ab847..1b59e41e9 100644 --- a/omniNotes/src/beta/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java +++ b/omniNotes/src/beta/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt @@ -1,9 +1,9 @@ /* - * Copyright (C) 2017-2024 Federico Iosue (federico.iosue@gmail.com) + * Copyright (C) 2013-2024 Federico Iosue (federico@iosue.it) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by - * the Free Software Foundatibehaon, either version 3 of the License, or + * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, @@ -14,9 +14,15 @@ * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ +package it.feio.android.omninotes.helpers.location -package it.feio.android.omninotes.helpers; +import lombok.experimental.UtilityClass -public class GeocodeProviderFactory extends GeocodeProviderBaseFactory { +@UtilityClass +object LocationProviderFactory { + @Override + fun getProvider(): LocationProvider { + return FuseLocationProvider() + } } diff --git a/omniNotes/src/foss/java/it/feio/android/omninotes/helpers/location/LocationManagerLocationProvider.kt b/omniNotes/src/foss/java/it/feio/android/omninotes/helpers/location/LocationManagerLocationProvider.kt new file mode 100644 index 000000000..59e84406a --- /dev/null +++ b/omniNotes/src/foss/java/it/feio/android/omninotes/helpers/location/LocationManagerLocationProvider.kt @@ -0,0 +1,55 @@ +/* + * Copyright (C) 2013-2024 Federico Iosue (federico@iosue.it) + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +package it.feio.android.omninotes.helpers.location + +import com.google.android.gms.location.LocationServices +import it.feio.android.omninotes.OmniNotes +import it.feio.android.omninotes.models.listeners.OnGeoUtilResultListener + +class FuseLocationProviderLocationManagerLocationProvider : LocationProvider { + + @kotlin.Throws(SecurityException::class) + override fun getLocation(onGeoUtilResultListener: OnGeoUtilResultListener?) { + val lastKnownLocationByGps = + locationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER) + lastKnownLocationByGps?.let { + locationByGps = lastKnownLocationByGps + } + + val lastKnownLocationByNetwork = + locationManager.getLastKnownLocation(LocationManager.NETWORK_PROVIDER) + lastKnownLocationByNetwork?.let { + locationByNetwork = lastKnownLocationByNetwork + } + + if (locationByGps != null && locationByNetwork != null) { + if (locationByGps.accuracy > locationByNetwork!!.accuracy) { + currentLocation = locationByGps + latitude = currentLocation.latitude + longitude = currentLocation.longitude + // use latitude and longitude as per your need + } else { + currentLocation = locationByNetwork + latitude = currentLocation.latitude + longitude = currentLocation.longitude + // use latitude and longitude as per your need + } + } + + } + +} diff --git a/omniNotes/src/play/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java b/omniNotes/src/foss/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt similarity index 59% rename from omniNotes/src/play/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java rename to omniNotes/src/foss/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt index 46047f148..065ddcbea 100644 --- a/omniNotes/src/play/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java +++ b/omniNotes/src/foss/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt @@ -14,20 +14,16 @@ * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ +package it.feio.android.omninotes.helpers.location -package it.feio.android.omninotes.helpers; +import lombok.experimental.UtilityClass +import java.lang.Override -import android.content.Context; -import io.nlopez.smartlocation.location.LocationProvider; -import io.nlopez.smartlocation.location.providers.LocationGooglePlayServicesWithFallbackProvider; +@UtilityClass +object LocationProviderFactory { -public class GeocodeProviderFactory { - - private GeocodeProviderFactory() { - // hides public constructor - } - - public static LocationProvider getProvider(Context context) { - return new LocationGooglePlayServicesWithFallbackProvider(context); - } + @Override + fun getProvider(): LocationProvider? { + return LocationManagerLocationProvider() + } } diff --git a/omniNotes/src/main/AndroidManifest.xml b/omniNotes/src/main/AndroidManifest.xml index f360e00fb..45d9d7d59 100644 --- a/omniNotes/src/main/AndroidManifest.xml +++ b/omniNotes/src/main/AndroidManifest.xml @@ -20,7 +20,6 @@ - diff --git a/omniNotes/src/main/java/it/feio/android/omninotes/DetailFragment.java b/omniNotes/src/main/java/it/feio/android/omninotes/DetailFragment.java index f0270cfa3..1e8882c42 100644 --- a/omniNotes/src/main/java/it/feio/android/omninotes/DetailFragment.java +++ b/omniNotes/src/main/java/it/feio/android/omninotes/DetailFragment.java @@ -20,7 +20,6 @@ import static android.content.Context.CLIPBOARD_SERVICE; import static android.content.Context.LAYOUT_INFLATER_SERVICE; import static android.content.pm.PackageManager.FEATURE_CAMERA; -import static android.content.pm.PackageManager.PERMISSION_GRANTED; import static android.widget.Toast.LENGTH_SHORT; import static androidx.core.view.ViewCompat.animate; import static it.feio.android.omninotes.BaseActivity.TRANSITION_HORIZONTAL; @@ -69,7 +68,6 @@ import static java.lang.Long.parseLong; import android.Manifest; -import android.Manifest.permission; import android.annotation.SuppressLint; import android.app.Activity; import android.app.PendingIntent; @@ -83,13 +81,13 @@ import android.graphics.Point; import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.Drawable; +import android.location.Address; import android.location.Location; import android.media.MediaPlayer; import android.media.MediaRecorder; import android.media.ThumbnailUtils; import android.net.Uri; import android.os.AsyncTask; -import android.os.Build; import android.os.Bundle; import android.os.Handler; import android.provider.MediaStore; @@ -114,10 +112,7 @@ import android.widget.CheckBox; import android.widget.ImageView; import android.widget.Toast; -import androidx.activity.result.ActivityResultCallback; -import androidx.activity.result.ActivityResultLauncher; -import androidx.activity.result.contract.ActivityResultContracts; -import androidx.core.content.ContextCompat; + import androidx.core.util.Pair; import androidx.drawerlayout.widget.DrawerLayout; import androidx.fragment.app.FragmentTransaction; @@ -145,13 +140,13 @@ import it.feio.android.omninotes.exceptions.checked.ContentSecurityException; import it.feio.android.omninotes.exceptions.checked.UnhandledIntentException; import it.feio.android.omninotes.helpers.AttachmentsHelper; -import it.feio.android.omninotes.helpers.BuildHelper; import it.feio.android.omninotes.helpers.IntentHelper; import it.feio.android.omninotes.helpers.LogDelegate; import it.feio.android.omninotes.helpers.PermissionsHelper; import it.feio.android.omninotes.helpers.TagOpenerHelper; import it.feio.android.omninotes.helpers.date.DateHelper; import it.feio.android.omninotes.helpers.date.RecurrenceHelper; +import it.feio.android.omninotes.helpers.location.LocationProviderFactory; import it.feio.android.omninotes.helpers.notifications.NotificationChannels.NotificationChannelNames; import it.feio.android.omninotes.helpers.notifications.NotificationsHelper; import it.feio.android.omninotes.models.Attachment; @@ -173,7 +168,7 @@ import it.feio.android.omninotes.utils.Display; import it.feio.android.omninotes.utils.FileHelper; import it.feio.android.omninotes.utils.FileProviderHelper; -import it.feio.android.omninotes.utils.GeocodeHelper; +import it.feio.android.omninotes.helpers.location.GeocodeHelper; import it.feio.android.omninotes.utils.IntentChecker; import it.feio.android.omninotes.utils.KeyboardUtils; import it.feio.android.omninotes.utils.PasswordHelper; @@ -297,12 +292,6 @@ public void onAttach(Context context) { EventBus.getDefault().post(new SwitchFragmentEvent(SwitchFragmentEvent.Direction.CHILDREN)); } - @Override - public void onStop() { - super.onStop(); - GeocodeHelper.stop(); - } - @Override public void onResume() { super.onResume(); @@ -718,9 +707,9 @@ private void initViewLocation() { private void getLocation(OnGeoUtilResultListener onGeoUtilResultListener) { PermissionsHelper - .requestPermission(this, Manifest.permission.ACCESS_FINE_LOCATION, R.string + .requestPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION, R.string .permission_coarse_location, binding.snackbarPlaceholder, - () -> GeocodeHelper.getLocation(onGeoUtilResultListener)); + () -> LocationProviderFactory.INSTANCE.getProvider().getLocation(onGeoUtilResultListener)); } private void initViewAttachments() { @@ -959,8 +948,8 @@ public void onLocationRetrieved(Location location) { } @Override - public void onLocationUnavailable() { - mainActivity.showMessage(R.string.location_not_found, ONStyle.ALERT); + public void onLocationUnavailable(Exception e) { + mainActivity.showMessage(R.string.location_not_found + ": " + e.getMessage(), ONStyle.ALERT); } public void onLocationNotEnabled(){ @@ -984,13 +973,18 @@ public void onAddressResolved(String address) { } @Override - public void onCoordinatesResolved(Location location, String address) { - if (location != null) { - noteTmp.setLatitude(location.getLatitude()); - noteTmp.setLongitude(location.getLongitude()); - noteTmp.setAddress(address); + public void onCoordinatesUnresolved(Exception e) { + mainActivity.showMessage(R.string.location_not_found + ": " + e.getMessage(), ONStyle.ALERT); + } + + @Override + public void onCoordinatesResolved(Address address) { + if (address != null) { + noteTmp.setLatitude(address.getLatitude()); + noteTmp.setLongitude(address.getLongitude()); + noteTmp.setAddress(address.getAddressLine(0)); binding.fragmentDetailContent.location.setVisibility(View.VISIBLE); - binding.fragmentDetailContent.location.setText(address); + binding.fragmentDetailContent.location.setText(address.getAddressLine(0)); fade(binding.fragmentDetailContent.location, true); } else { mainActivity.showMessage(R.string.location_not_found, ONStyle.ALERT); @@ -2235,13 +2229,18 @@ public void onAddressResolved(String address) { } @Override - public void onCoordinatesResolved(Location location, String address) { + public void onCoordinatesResolved(Address address) { + // Nothing to do + } + + @Override + public void onCoordinatesUnresolved(Exception e) { // Nothing to do } @Override - public void onLocationUnavailable() { - mainActivityWeakReference.get().showMessage(R.string.location_not_found, ONStyle.ALERT); + public void onLocationUnavailable(Exception e) { + mainActivityWeakReference.get().showMessage(R.string.location_not_found + ": " + e.getMessage(), ONStyle.ALERT); } @Override public void onLocationNotEnabled(){ diff --git a/omniNotes/src/main/java/it/feio/android/omninotes/SettingsFragment.java b/omniNotes/src/main/java/it/feio/android/omninotes/SettingsFragment.java index faa9d987f..004713fb7 100644 --- a/omniNotes/src/main/java/it/feio/android/omninotes/SettingsFragment.java +++ b/omniNotes/src/main/java/it/feio/android/omninotes/SettingsFragment.java @@ -72,7 +72,6 @@ import it.feio.android.omninotes.intro.IntroActivity; import it.feio.android.omninotes.models.ONStyle; import it.feio.android.omninotes.models.PasswordValidator.Result; -import it.feio.android.omninotes.utils.IntentChecker; import it.feio.android.omninotes.utils.PasswordHelper; import it.feio.android.omninotes.utils.ResourcesUtils; import it.feio.android.omninotes.utils.StorageHelper; diff --git a/omniNotes/src/main/java/it/feio/android/omninotes/helpers/GeocodeProviderBaseFactory.java b/omniNotes/src/main/java/it/feio/android/omninotes/helpers/GeocodeProviderBaseFactory.java deleted file mode 100644 index a2d8caec0..000000000 --- a/omniNotes/src/main/java/it/feio/android/omninotes/helpers/GeocodeProviderBaseFactory.java +++ /dev/null @@ -1,50 +0,0 @@ -/* - * Copyright (C) 2013-2024 Federico Iosue (federico@iosue.it) - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see . - */ - -package it.feio.android.omninotes.helpers; - -import android.content.Context; -import android.content.Intent; -import android.location.LocationManager; -import android.os.Build.VERSION_CODES; -import android.provider.Settings; -import android.widget.Toast; -import io.nlopez.smartlocation.location.LocationProvider; -import io.nlopez.smartlocation.location.providers.LocationGooglePlayServicesWithFallbackProvider; -import it.feio.android.omninotes.R; -import it.feio.android.omninotes.utils.GeocodeHelper; - -public class GeocodeProviderBaseFactory { - - protected GeocodeProviderBaseFactory() { - // hides public constructor - } - - public static LocationProvider getProvider(Context context) { - if (BuildHelper.isBelow(VERSION_CODES.P) && checkHighAccuracyLocationProvider(context)) { - Toast.makeText(context, R.string.location_set_high_accuracy, Toast.LENGTH_SHORT).show(); - context.startActivity((new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS))); - } - - return new LocationGooglePlayServicesWithFallbackProvider(context); - } - - public static boolean checkHighAccuracyLocationProvider(Context context) { - return GeocodeHelper.checkLocationProviderEnabled(context, LocationManager.GPS_PROVIDER); - } - -} diff --git a/omniNotes/src/main/java/it/feio/android/omninotes/utils/GeocodeHelper.java b/omniNotes/src/main/java/it/feio/android/omninotes/helpers/location/GeocodeHelper.java similarity index 55% rename from omniNotes/src/main/java/it/feio/android/omninotes/utils/GeocodeHelper.java rename to omniNotes/src/main/java/it/feio/android/omninotes/helpers/location/GeocodeHelper.java index 708b22e95..746432d86 100644 --- a/omniNotes/src/main/java/it/feio/android/omninotes/utils/GeocodeHelper.java +++ b/omniNotes/src/main/java/it/feio/android/omninotes/helpers/location/GeocodeHelper.java @@ -15,25 +15,25 @@ * along with this program. If not, see . */ -package it.feio.android.omninotes.utils; +package it.feio.android.omninotes.helpers.location; +import static android.os.Build.VERSION_CODES.TIRAMISU; import static it.feio.android.omninotes.BuildConfig.MAPS_API_KEY; -import static it.feio.android.omninotes.helpers.GeocodeProviderBaseFactory.checkHighAccuracyLocationProvider; -import static it.feio.android.omninotes.helpers.GeocodeProviderBaseFactory.getProvider; import android.content.Context; import android.location.Address; import android.location.Geocoder; import android.location.Location; -import android.location.LocationListener; import android.location.LocationManager; -import android.os.Bundle; import android.text.TextUtils; -import io.nlopez.smartlocation.SmartLocation; -import io.nlopez.smartlocation.location.config.LocationParams; + import it.feio.android.omninotes.OmniNotes; +import it.feio.android.omninotes.helpers.BuildHelper; import it.feio.android.omninotes.helpers.LogDelegate; import it.feio.android.omninotes.models.listeners.OnGeoUtilResultListener; +import it.feio.android.omninotes.utils.SystemHelper; +import lombok.experimental.UtilityClass; + import java.io.IOException; import java.io.InputStreamReader; import java.net.HttpURLConnection; @@ -50,131 +50,66 @@ import org.json.JSONObject; -public class GeocodeHelper implements LocationListener { +@UtilityClass +public class GeocodeHelper { private static final String PLACES_API_BASE = "https://maps.googleapis.com/maps/api/place"; private static final String TYPE_AUTOCOMPLETE = "/autocomplete"; private static final String OUT_JSON = "/json"; - @Override - public void onLocationChanged(Location newLocation) { - // Nothing to do - } - - - @Override - @Deprecated - public void onStatusChanged(String provider, int status, Bundle extras) { - // Nothing to do - } - - - @Override - public void onProviderEnabled(String provider) { - // Nothing to do - } - - - @Override - public void onProviderDisabled(String provider) { - // Nothing to do - } - - - public static void getLocation(OnGeoUtilResultListener onGeoUtilResultListener) { - SmartLocation.LocationControl bod = SmartLocation.with(OmniNotes.getAppContext()) - .location(getProvider(OmniNotes.getAppContext())) - .config(LocationParams.NAVIGATION).oneFix(); - - var location = bod.oneFix().getLastLocation(); - - if (location != null) { - onGeoUtilResultListener.onLocationRetrieved(location); - } else { - if (checkHighAccuracyLocationProvider(OmniNotes.getAppContext())) { - onGeoUtilResultListener.onLocationUnavailable(); - } else { - onGeoUtilResultListener.onLocationNotEnabled(); - } - } - } - - - public static void stop() { - SmartLocation.with(OmniNotes.getAppContext()).location().stop(); - if (Geocoder.isPresent()) { - SmartLocation.with(OmniNotes.getAppContext()).geocoding().stop(); - } - } - - - static String getAddressFromCoordinates(Context mContext, double latitude, + public String getAddressFromCoordinates(Context mContext, double latitude, double longitude) throws IOException { - String addressString = ""; - Geocoder geocoder = new Geocoder(mContext, Locale.getDefault()); - List
addresses = geocoder.getFromLocation(latitude, longitude, 1); - if (!addresses.isEmpty()) { + var geocoder = new Geocoder(mContext, Locale.getDefault()); + var addresses = geocoder.getFromLocation(latitude, longitude, 1); + if (addresses != null && !addresses.isEmpty()) { Address address = addresses.get(0); if (address != null) { - addressString = address.getThoroughfare() + ", " + address.getLocality(); + return address.getThoroughfare() + ", " + address.getLocality(); } } - return addressString; + return ""; } - - public static void getAddressFromCoordinates(Location location, + public void getAddressFromCoordinates(Location location, final OnGeoUtilResultListener onGeoUtilResultListener) { - if (!Geocoder.isPresent()) { - onGeoUtilResultListener.onAddressResolved(""); - } else { - SmartLocation.with(OmniNotes.getAppContext()).geocoding() - .reverse(location, (location1, list) -> { - String address = !list.isEmpty() ? list.get(0).getAddressLine(0) : null; - onGeoUtilResultListener.onAddressResolved(address); - }); - } - } - - - public static double[] getCoordinatesFromAddress(Context mContext, String address) - throws IOException { - double[] result = new double[2]; - Geocoder geocoder = new Geocoder(mContext, Locale.getDefault()); - List
addresses = geocoder.getFromLocationName(address, 1); - if (!addresses.isEmpty()) { - double latitude = addresses.get(0).getLatitude(); - double longitude = addresses.get(0).getLongitude(); - result[0] = latitude; - result[1] = longitude; + try { + var address= getAddressFromCoordinates(OmniNotes.getAppContext(), location.getLatitude(), + location.getLongitude()); + onGeoUtilResultListener.onAddressResolved(address); + } catch (IOException e) { + onGeoUtilResultListener.onLocationUnavailable(e); } - return result; } - - public static void getCoordinatesFromAddress(String address, final OnGeoUtilResultListener - listener) { - SmartLocation.with(OmniNotes.getAppContext()).geocoding().direct(address, (name, results) -> { - if (!results.isEmpty()) { - listener.onCoordinatesResolved(results.get(0).getLocation(), address); + public void getCoordinatesFromAddress(String address, final OnGeoUtilResultListener listener) { + try { + var geocoder = new Geocoder(OmniNotes.getAppContext(), Locale.getDefault()); + if (BuildHelper.isAboveOrEqual(TIRAMISU)) { + geocoder.getFromLocationName(address, 1, addresses -> listener.onCoordinatesResolved(addresses.get(0))); + } else { + var addresses = geocoder.getFromLocationName(address, 1); + if (addresses != null && !addresses.isEmpty()) { + listener.onCoordinatesResolved(addresses.get(0)); + } } - }); + } catch (IOException e) { + listener.onCoordinatesUnresolved(e); + } } - public static List autocomplete(String input) { if (TextUtils.isEmpty(MAPS_API_KEY)) { return Collections.emptyList(); } + ArrayList resultList = null; HttpURLConnection conn = null; InputStreamReader in = null; StringBuilder jsonResults = new StringBuilder(); try { - URL url = new URL( - PLACES_API_BASE + TYPE_AUTOCOMPLETE + OUT_JSON + "?key=" + MAPS_API_KEY + "&input=" + - URLEncoder.encode(input, "utf8")); + var url = new URL(PLACES_API_BASE + TYPE_AUTOCOMPLETE + OUT_JSON + "?key=" + + MAPS_API_KEY + "&input=" + URLEncoder.encode(input, "utf8")); conn = (HttpURLConnection) url.openConnection(); in = new InputStreamReader(conn.getInputStream()); // Load the results into a StringBuilder @@ -220,7 +155,6 @@ public static List autocomplete(String input) { return resultList; } - public static boolean areCoordinates(String string) { var p = Pattern.compile( "^[-+]?([1-8]?\\d(\\.\\d+)?|90(\\.0+)?),\\s*[-+]?(180(\\.0+)?|((1[0-7]\\d)|([1-9]?\\d))(\\.\\d+)?)$"); diff --git a/omniNotes/src/main/java/it/feio/android/omninotes/helpers/location/LocationProvider.java b/omniNotes/src/main/java/it/feio/android/omninotes/helpers/location/LocationProvider.java new file mode 100644 index 000000000..89c16f8fc --- /dev/null +++ b/omniNotes/src/main/java/it/feio/android/omninotes/helpers/location/LocationProvider.java @@ -0,0 +1,9 @@ +package it.feio.android.omninotes.helpers.location; + +import it.feio.android.omninotes.models.listeners.OnGeoUtilResultListener; + +public interface LocationProvider { + + void getLocation(OnGeoUtilResultListener onGeoUtilResultListener) throws SecurityException; + +} diff --git a/omniNotes/src/main/java/it/feio/android/omninotes/models/adapters/PlacesAutoCompleteAdapter.java b/omniNotes/src/main/java/it/feio/android/omninotes/models/adapters/PlacesAutoCompleteAdapter.java index fbd1f5fff..000d7cd56 100644 --- a/omniNotes/src/main/java/it/feio/android/omninotes/models/adapters/PlacesAutoCompleteAdapter.java +++ b/omniNotes/src/main/java/it/feio/android/omninotes/models/adapters/PlacesAutoCompleteAdapter.java @@ -21,7 +21,7 @@ import android.widget.ArrayAdapter; import android.widget.Filter; import android.widget.Filterable; -import it.feio.android.omninotes.utils.GeocodeHelper; +import it.feio.android.omninotes.helpers.location.GeocodeHelper; import java.util.List; diff --git a/omniNotes/src/foss/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java b/omniNotes/src/main/java/it/feio/android/omninotes/models/listeners/OnGeoUtilResultListener.kt similarity index 62% rename from omniNotes/src/foss/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java rename to omniNotes/src/main/java/it/feio/android/omninotes/models/listeners/OnGeoUtilResultListener.kt index d791f9159..15c9749ed 100644 --- a/omniNotes/src/foss/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java +++ b/omniNotes/src/main/java/it/feio/android/omninotes/models/listeners/OnGeoUtilResultListener.kt @@ -14,20 +14,21 @@ * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ +package it.feio.android.omninotes.models.listeners -package it.feio.android.omninotes.helpers; +import android.location.Address +import android.location.Location -import android.content.Context; -import io.nlopez.smartlocation.location.LocationProvider; -import io.nlopez.smartlocation.location.providers.LocationManagerProvider; -public class GeocodeProviderFactory { +interface OnGeoUtilResultListener { - private GeocodeProviderFactory() { - // hides public constructor - } + fun onAddressResolved(address: String?) - public static LocationProvider getProvider(Context context) { - return new LocationManagerProvider(); - } -} \ No newline at end of file + fun onCoordinatesResolved(address: Address?) + fun onCoordinatesUnresolved(exception: Exception?) + + fun onLocationRetrieved(location: Location?) + + fun onLocationUnavailable(e: Exception?) + fun onLocationNotEnabled() +} diff --git a/omniNotes/src/main/res/values/integers.xml b/omniNotes/src/main/res/values/integers.xml index 2c431a8e1..b6b4534c1 100644 --- a/omniNotes/src/main/res/values/integers.xml +++ b/omniNotes/src/main/res/values/integers.xml @@ -25,5 +25,5 @@ 1 2 - 9080000 + 12451000 diff --git a/omniNotes/src/play/java/it/feio/android/omninotes/helpers/location/FuseLocationProvider.kt b/omniNotes/src/play/java/it/feio/android/omninotes/helpers/location/FuseLocationProvider.kt new file mode 100644 index 000000000..b252ed4f9 --- /dev/null +++ b/omniNotes/src/play/java/it/feio/android/omninotes/helpers/location/FuseLocationProvider.kt @@ -0,0 +1,37 @@ +/* + * Copyright (C) 2013-2024 Federico Iosue (federico@iosue.it) + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +package it.feio.android.omninotes.helpers.location + +import com.google.android.gms.location.LocationServices +import it.feio.android.omninotes.OmniNotes +import it.feio.android.omninotes.models.listeners.OnGeoUtilResultListener + +class FuseLocationProvider : LocationProvider { + + @kotlin.Throws(SecurityException::class) + override fun getLocation(onGeoUtilResultListener: OnGeoUtilResultListener?) { + LocationServices.getFusedLocationProviderClient(OmniNotes.getAppContext()).getLastLocation() + .addOnSuccessListener { location -> + if (location == null) { + onGeoUtilResultListener?.onLocationUnavailable(null) + } + onGeoUtilResultListener?.onLocationRetrieved(location) + } + .addOnFailureListener { e -> onGeoUtilResultListener?.onLocationUnavailable(e) } + } + +} diff --git a/omniNotes/src/alpha/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java b/omniNotes/src/play/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt similarity index 75% rename from omniNotes/src/alpha/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java rename to omniNotes/src/play/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt index e2736784d..349a3d927 100644 --- a/omniNotes/src/alpha/java/it/feio/android/omninotes/helpers/GeocodeProviderFactory.java +++ b/omniNotes/src/play/java/it/feio/android/omninotes/helpers/location/LocationProviderFactory.kt @@ -14,9 +14,14 @@ * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ +package it.feio.android.omninotes.helpers.location -package it.feio.android.omninotes.helpers; +import lombok.experimental.UtilityClass -public class GeocodeProviderFactory extends GeocodeProviderBaseFactory { +@UtilityClass +object LocationProviderFactory { -} \ No newline at end of file + @JvmStatic + val provider: LocationProvider + get() = FuseLocationProvider() +}