diff --git a/app/build.gradle b/app/build.gradle
index 6e71ea6..e446c1d 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -4,17 +4,17 @@ apply plugin: 'kotlin-kapt'
apply plugin: 'kotlin-android-extensions'
android {
- compileSdkVersion 29
+ compileSdkVersion 30
buildToolsVersion "29.0.3"
- dataBinding {
- enabled = true
+ buildFeatures {
+ dataBinding = true
}
defaultConfig {
applicationId "fr.sanchezm.attestationsCovid19"
minSdkVersion 23
- targetSdkVersion 29
+ targetSdkVersion 30
versionCode 1002
versionName "1.0.5-beta1"
@@ -74,24 +74,20 @@ dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
// Android X
- implementation 'androidx.appcompat:appcompat:1.1.0'
- implementation 'androidx.core:core-ktx:1.2.0'
- implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
+ implementation 'androidx.appcompat:appcompat:1.2.0'
+ implementation 'androidx.core:core-ktx:1.3.2'
+ implementation 'androidx.constraintlayout:constraintlayout:2.0.2'
implementation 'androidx.legacy:legacy-support-v4:1.0.0'
implementation 'androidx.lifecycle:lifecycle-extensions:2.2.0'
implementation 'androidx.lifecycle:lifecycle-viewmodel-ktx:2.2.0'
- implementation 'androidx.navigation:navigation-fragment-ktx:2.2.2'
- implementation 'androidx.navigation:navigation-fragment:2.2.2'
- implementation 'androidx.navigation:navigation-ui-ktx:2.2.2'
- implementation 'androidx.navigation:navigation-ui:2.2.2'
+ implementation 'androidx.navigation:navigation-fragment-ktx:2.3.1'
+ implementation 'androidx.navigation:navigation-fragment:2.3.1'
+ implementation 'androidx.navigation:navigation-ui-ktx:2.3.1'
+ implementation 'androidx.navigation:navigation-ui:2.3.1'
// Design
- implementation 'com.google.android.material:material:1.1.0'
-
- // Room
-// implementation 'androidx.room:room-runtime:2.2.5'
-// kapt 'androidx.room:room-compiler:2.2.5'
+ implementation 'com.google.android.material:material:1.2.1'
// PDF
implementation 'com.tom_roush:pdfbox-android:1.8.10.1'
@@ -110,6 +106,6 @@ dependencies {
// Test
testImplementation 'junit:junit:4.12'
- androidTestImplementation 'androidx.test.ext:junit:1.1.1'
- androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
+ androidTestImplementation 'androidx.test.ext:junit:1.1.2'
+ androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0'
}
diff --git a/app/src/main/assets/attestation.pdf b/app/src/main/assets/attestation.pdf
index 22e0e02..7b13041 100644
Binary files a/app/src/main/assets/attestation.pdf and b/app/src/main/assets/attestation.pdf differ
diff --git a/app/src/main/java/fr/sanchezm/attestationsCovid19/data/db/MyDatabase.kt b/app/src/main/java/fr/sanchezm/attestationsCovid19/data/db/MyDatabase.kt
index 28ff7ed..329957c 100644
--- a/app/src/main/java/fr/sanchezm/attestationsCovid19/data/db/MyDatabase.kt
+++ b/app/src/main/java/fr/sanchezm/attestationsCovid19/data/db/MyDatabase.kt
@@ -28,40 +28,3 @@ class MyDatabase private constructor(private val savePath: String, private val f
}
}
}
-
-/*
-import android.content.Context
-import androidx.room.Database
-import androidx.room.Room
-import androidx.room.RoomDatabase
-import fr.sanchezm.attestationsCovid19.data.db.dao.AttestationDao
-import fr.sanchezm.attestationsCovid19.data.db.dao.ProfileDao
-import fr.sanchezm.attestationsCovid19.data.db.entity.Profile
-
-@Database(
- entities = [Profile::class],
- version = 1
-)
-abstract class MyDatabase private constructor() : RoomDatabase() {
-
- abstract fun profileDao(): ProfileDao
- abstract fun attestationDao(): AttestationDao
-
- companion object {
- @Volatile
- private var instance: MyDatabase? = null
- private val LOCK = Any()
-
- operator fun invoke(context: Context) = instance ?: synchronized(LOCK) {
- instance ?: buildDatabase(context).also { instance = it }
- }
-
- private fun buildDatabase(context: Context) =
- Room.databaseBuilder(
- context.applicationContext,
- MyDatabase::class.java, "data.db"
- )
- .build()
- }
-}
-*/
diff --git a/app/src/main/java/fr/sanchezm/attestationsCovid19/data/db/entity/Attestation.kt b/app/src/main/java/fr/sanchezm/attestationsCovid19/data/db/entity/Attestation.kt
index fc5939a..994ceb5 100644
--- a/app/src/main/java/fr/sanchezm/attestationsCovid19/data/db/entity/Attestation.kt
+++ b/app/src/main/java/fr/sanchezm/attestationsCovid19/data/db/entity/Attestation.kt
@@ -34,15 +34,16 @@ data class Attestation(
private fun getDate(dateTime: Long): String = SimpleDateFormat(PATTERN, Locale.FRANCE).format(Date(dateTime))
- private fun getMotifText(i: Int): String {
+ fun getMotifText(i: Int): String {
return when (i) {
1 -> "travail"
- 2 -> "courses"
- 3 -> "sante"
- 4 -> "famille"
- 5 -> "sport"
- 6 -> "judiciare"
- 7 -> "missions"
+ 2 -> "sante"
+ 3 -> "famille"
+ 4 -> "handicap"
+ 5 -> "convocation"
+ 6 -> "missions"
+ 7 -> "transits"
+ 8 -> "animaux"
else -> "Error $i not found"
}
}
diff --git a/app/src/main/java/fr/sanchezm/attestationsCovid19/ui/add/AddViewModel.kt b/app/src/main/java/fr/sanchezm/attestationsCovid19/ui/add/AddViewModel.kt
index 260237d..6a0a60d 100644
--- a/app/src/main/java/fr/sanchezm/attestationsCovid19/ui/add/AddViewModel.kt
+++ b/app/src/main/java/fr/sanchezm/attestationsCovid19/ui/add/AddViewModel.kt
@@ -60,6 +60,7 @@ class AddViewModel(
val reason5 = MutableLiveData(false)
val reason6 = MutableLiveData(false)
val reason7 = MutableLiveData(false)
+ val reason8 = MutableLiveData(false)
// endregion
private val datePattern = "dd/MM/yyyy"
@@ -204,6 +205,7 @@ class AddViewModel(
if (reason5.value!!) reasons.add(5)
if (reason6.value!!) reasons.add(6)
if (reason7.value!!) reasons.add(7)
+ if (reason8.value!!) reasons.add(8)
return reasons
}
diff --git a/app/src/main/java/fr/sanchezm/attestationsCovid19/utilities/PdfUtils.kt b/app/src/main/java/fr/sanchezm/attestationsCovid19/utilities/PdfUtils.kt
index 7e85f0f..829af30 100644
--- a/app/src/main/java/fr/sanchezm/attestationsCovid19/utilities/PdfUtils.kt
+++ b/app/src/main/java/fr/sanchezm/attestationsCovid19/utilities/PdfUtils.kt
@@ -65,8 +65,7 @@ class PdfUtils private constructor(
attestation,
size / 3,
page1.mediaBox.upperRightX - margin - size / 3 - 30,
- 141f,
- true
+ 101f
)
// Add QRCode on a new page
@@ -83,8 +82,7 @@ class PdfUtils private constructor(
attestation: Attestation,
size: Int,
x: Float,
- y: Float,
- addText: Boolean = false
+ y: Float
) {
val contentStream = PDPageContentStream(document, page, true, false)
@@ -92,21 +90,7 @@ class PdfUtils private constructor(
LosslessFactory.createFromImage(document, QRCodeUtils.getQrCode(attestation, size))
contentStream.drawImage(alphaXimage, x, y)
- if (addText) {
- contentStream.beginText()
- contentStream.setFont(font, 7f)
- contentStream.newLineAtOffset(page.mediaBox.upperRightX - size - 20, 145f)
- contentStream.showText("Date de création:")
- contentStream.endText()
-
- contentStream.beginText()
- contentStream.setFont(font, 7f)
- contentStream.newLineAtOffset(page.mediaBox.upperRightX - size - 27, 138f)
- contentStream.showText(attestation.getCreatedAtFormattedDate())
- contentStream.endText()
- }
contentStream.close()
-
}
private fun setFieldsData(acroForm: PDAcroForm, attestation: Attestation): Boolean {
@@ -117,21 +101,21 @@ class PdfUtils private constructor(
val namesField = acroForm.getField("Nom et prénom") as PDTextField
val birthdayField = acroForm.getField("Date de naissance") as PDTextField
val birthPlaceField = acroForm.getField("Lieu de naissance") as PDTextField
- val addressField = acroForm.getField("Adresse actuelle") as PDTextField
+ val addressField = acroForm.getField("Adresse") as PDTextField
+ val postalAndCityField = acroForm.getField("Ville et code postal") as PDTextField
val cityField = acroForm.getField("Ville") as PDTextField
val dateField = acroForm.getField("Date") as PDTextField
- val hourField = acroForm.getField("Heure") as PDTextField
- val minutesField = acroForm.getField("Minute") as PDTextField
+ val exitField = acroForm.getField("Heure") as PDTextField
// val signatureField = acroForm.getField("Signature") as PDTextField
namesField.value = "${profile.firstName} ${profile.lastName}"
birthdayField.value = profile.birthday
birthPlaceField.value = profile.birthPlace
- addressField.value = "${profile.address} ${profile.postalCode} ${profile.city}"
+ addressField.value = profile.address
+ postalAndCityField.value = "${profile.postalCode} ${profile.city}"
cityField.value = profile.city
dateField.value = attestation.exitDate
- hourField.value = attestation.exitHour.split(":")[0]
- minutesField.value = attestation.exitHour.split(":")[1]
+ exitField.value = attestation.exitHour
return true
} catch (e: Exception) {
Log.e(TAG, "${e.message}")
@@ -141,7 +125,7 @@ class PdfUtils private constructor(
private fun setCheckboxFields(acroForm: PDAcroForm, attestation: Attestation) {
attestation.reasons.forEach {
- (acroForm.getField(checkboxListNames[it - 1]) as PDCheckbox).check()
+ (acroForm.getField(attestation.getMotifText(it)) as PDCheckbox).check()
}
}
diff --git a/app/src/main/res/layout/fragment_add_attestation.xml b/app/src/main/res/layout/fragment_add_attestation.xml
index 8a25283..8675807 100644
--- a/app/src/main/res/layout/fragment_add_attestation.xml
+++ b/app/src/main/res/layout/fragment_add_attestation.xml
@@ -256,6 +256,14 @@
android:checked="@={viewModel.reason7}"
android:text="@string/reason_7" />
+
+
+
+
+ app:layout_constraintTop_toBottomOf="@+id/explication_5" />
- Attestation de déplacement dérogatoire
+ Attestation de déplacement dérogatoire (couvre-feu)
Nouvelle Attestation
Mes Attestations
À Propos
@string/app_name
- #RestonsChezNous
+ Respectons les gestes barrières et les distanciations sociales et faisons barrière à la Covid-19
Attestation générée
Aucune attestation, veuillez en générer une.
@@ -18,25 +18,27 @@
Adresse
Ville
Code Postal
- Choisissez le ou les motif(s) de sortie
+ Je certifie que mon déplacement est lié au motif suivant (cocher la case) autorisé en application des mesures générales nécessaires pour faire face à l\'épidémie de Covid19 dans le cadre de l\'état d\'urgence sanitaire :
Date de sortie
Heure de sortie
Générer l\'attestation
- Déplacements entre le domicile et le lieu d’exercice de l’activité professionnelle, lorsqu\'ils sont indispensables à l\'exercice d’activités ne pouvant être organisées sous forme de télétravail ou déplacements professionnels ne pouvant être différés.
- Déplacements pour effectuer des achats de fournitures nécessaires à l’activité professionnelle et des achats de première nécessité dans des établissements dont les activités demeurent autorisées
- Consultations et soins ne pouvant être assurés à distance et ne pouvant être différés ; consultations et soins des patients atteints d\'une affection de longue durée.
- Déplacements pour motif familial impérieux, pour l’assistance aux personnes vulnérables ou la garde d’enfants.
- Déplacements brefs, dans la limite d\'une heure quotidienne et dans un rayon maximal d\'un kilomètre autour du domicile, liés soit à l\'activité physique individuelle des personnes, à l\'exclusion de toute pratique sportive collective et de toute proximité avec d\'autres personnes, soit à la promenade avec les seules personnes regroupées dans un même domicile, soit aux besoins des animaux de compagnie.
- Convocation judiciaire ou administrative.
- Participation à des missions d’intérêt général sur demande de l’autorité administrative.
+ Déplacements entre le domicile et le lieu d\'exercice de l\'activité professionnelle ou le lieu d\'enseignement et de formation.
+ Déplacements pour des consultations et soins ne pouvant être assurés à distance et ne pouvant être différés ou pour l\'achat de produits de santé.
+ Déplacements pour motif familial impérieux, pour l\'assistance aux personnes vulnérables ou précaires ou pour la garde d\'enfants.
+ Déplacements des personnes en situation de handicap et de leur accompagnant.
+ Déplacements pour répondre à une convocation judiciaire ou administrative.
+ Déplacements pour participer à des missions d\'intérêt général sur demande de l\'autorité administrative.
+ Déplacements liés à des transits pour des déplacements de longues distances.
+ Déplacements brefs, dans un rayon maximal d\'un kilomètre autour du domicile pour les besoins des animaux de compagnie.
- Merci de n\'utiliser l\'application qu\'en cas de nécessité.
- Cette application n\'aura jamais de publicité.
- Toutes les données sont stockées uniquement sur votre téléphone, utilisable hors ligne.
- Application non gouvernementale ni officielle, développée par un étudiant.
+ - J\'ai, moi-même été touché par ce virus, même à 22 ans il m\'a mis KO 2\-3 jours, faites attention à vous et à vos proches.
Petit remerciement pour l\'aide apportée au développement de l\'application :
TomRoush: PdfBox-Android
Barteksc: AndroidPdfViewer
diff --git a/build.gradle b/build.gradle
index 6c8070b..ea71a43 100644
--- a/build.gradle
+++ b/build.gradle
@@ -2,7 +2,7 @@
buildscript {
ext {
- kotlin_version = '1.3.72'
+ kotlin_version = '1.4.10'
db_version = '1'
}
@@ -13,7 +13,7 @@ buildscript {
}
dependencies {
- classpath 'com.android.tools.build:gradle:3.6.3'
+ classpath 'com.android.tools.build:gradle:4.1.0'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
// NOTE: Do not place your application dependencies here; they belong
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
index f2abdf3..a07cb3f 100644
--- a/gradle/wrapper/gradle-wrapper.properties
+++ b/gradle/wrapper/gradle-wrapper.properties
@@ -1,6 +1,6 @@
-#Sun Apr 12 01:14:42 CEST 2020
+#Sat Oct 24 15:33:39 CEST 2020
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.4-all.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-6.5-all.zip