niveau 3 et 4
15
DepannRien/.gitignore
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
*.iml
|
||||||
|
.gradle
|
||||||
|
/local.properties
|
||||||
|
/.idea/caches
|
||||||
|
/.idea/libraries
|
||||||
|
/.idea/modules.xml
|
||||||
|
/.idea/workspace.xml
|
||||||
|
/.idea/navEditor.xml
|
||||||
|
/.idea/assetWizardSettings.xml
|
||||||
|
.DS_Store
|
||||||
|
/build
|
||||||
|
/captures
|
||||||
|
.externalNativeBuild
|
||||||
|
.cxx
|
||||||
|
local.properties
|
3
DepannRien/.idea/.gitignore
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# Default ignored files
|
||||||
|
/shelf/
|
||||||
|
/workspace.xml
|
1
DepannRien/.idea/.name
generated
Normal file
@ -0,0 +1 @@
|
|||||||
|
Depanntout
|
6
DepannRien/.idea/compiler.xml
generated
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="CompilerConfiguration">
|
||||||
|
<bytecodeTargetLevel target="21" />
|
||||||
|
</component>
|
||||||
|
</project>
|
10
DepannRien/.idea/deploymentTargetSelector.xml
generated
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="deploymentTargetSelector">
|
||||||
|
<selectionStates>
|
||||||
|
<SelectionState runConfigName="app">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
</selectionStates>
|
||||||
|
</component>
|
||||||
|
</project>
|
20
DepannRien/.idea/gradle.xml
generated
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="GradleMigrationSettings" migrationVersion="1" />
|
||||||
|
<component name="GradleSettings">
|
||||||
|
<option name="linkedExternalProjectsSettings">
|
||||||
|
<GradleProjectSettings>
|
||||||
|
<option name="testRunner" value="CHOOSE_PER_TEST" />
|
||||||
|
<option name="externalProjectPath" value="$PROJECT_DIR$" />
|
||||||
|
<option name="gradleJvm" value="jbr-21" />
|
||||||
|
<option name="modules">
|
||||||
|
<set>
|
||||||
|
<option value="$PROJECT_DIR$" />
|
||||||
|
<option value="$PROJECT_DIR$/app" />
|
||||||
|
</set>
|
||||||
|
</option>
|
||||||
|
<option name="resolveExternalAnnotations" value="false" />
|
||||||
|
</GradleProjectSettings>
|
||||||
|
</option>
|
||||||
|
</component>
|
||||||
|
</project>
|
10
DepannRien/.idea/migrations.xml
generated
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectMigrations">
|
||||||
|
<option name="MigrateToGradleLocalJavaHome">
|
||||||
|
<set>
|
||||||
|
<option value="$PROJECT_DIR$" />
|
||||||
|
</set>
|
||||||
|
</option>
|
||||||
|
</component>
|
||||||
|
</project>
|
7
DepannRien/.idea/misc.xml
generated
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ExternalStorageConfigurationManager" enabled="true" />
|
||||||
|
<component name="ProjectRootManager" version="2" languageLevel="JDK_21" default="true" project-jdk-name="jbr-21" project-jdk-type="JavaSDK">
|
||||||
|
<output url="file://$PROJECT_DIR$/out" />
|
||||||
|
</component>
|
||||||
|
</project>
|
17
DepannRien/.idea/runConfigurations.xml
generated
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="RunConfigurationProducerService">
|
||||||
|
<option name="ignoredProducers">
|
||||||
|
<set>
|
||||||
|
<option value="com.intellij.execution.junit.AbstractAllInDirectoryConfigurationProducer" />
|
||||||
|
<option value="com.intellij.execution.junit.AllInPackageConfigurationProducer" />
|
||||||
|
<option value="com.intellij.execution.junit.PatternConfigurationProducer" />
|
||||||
|
<option value="com.intellij.execution.junit.TestInClassConfigurationProducer" />
|
||||||
|
<option value="com.intellij.execution.junit.UniqueIdConfigurationProducer" />
|
||||||
|
<option value="com.intellij.execution.junit.testDiscovery.JUnitTestDiscoveryConfigurationProducer" />
|
||||||
|
<option value="org.jetbrains.kotlin.idea.junit.KotlinJUnitRunConfigurationProducer" />
|
||||||
|
<option value="org.jetbrains.kotlin.idea.junit.KotlinPatternConfigurationProducer" />
|
||||||
|
</set>
|
||||||
|
</option>
|
||||||
|
</component>
|
||||||
|
</project>
|
7
DepannRien/.idea/vcs.xml
generated
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="VcsDirectoryMappings">
|
||||||
|
<mapping directory="" vcs="Git" />
|
||||||
|
<mapping directory="$PROJECT_DIR$/.." vcs="Git" />
|
||||||
|
</component>
|
||||||
|
</project>
|
1
DepannRien/app/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
/build
|
43
DepannRien/app/build.gradle.kts
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
plugins {
|
||||||
|
alias(libs.plugins.android.application)
|
||||||
|
}
|
||||||
|
|
||||||
|
android {
|
||||||
|
namespace = "com.example.depanntout"
|
||||||
|
compileSdk = 34
|
||||||
|
|
||||||
|
defaultConfig {
|
||||||
|
applicationId = "com.example.depanntout"
|
||||||
|
minSdk = 24
|
||||||
|
targetSdk = 34
|
||||||
|
versionCode = 1
|
||||||
|
versionName = "1.0"
|
||||||
|
|
||||||
|
testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
|
||||||
|
}
|
||||||
|
|
||||||
|
buildTypes {
|
||||||
|
release {
|
||||||
|
isMinifyEnabled = false
|
||||||
|
proguardFiles(
|
||||||
|
getDefaultProguardFile("proguard-android-optimize.txt"),
|
||||||
|
"proguard-rules.pro"
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
compileOptions {
|
||||||
|
sourceCompatibility = JavaVersion.VERSION_11
|
||||||
|
targetCompatibility = JavaVersion.VERSION_11
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
dependencies {
|
||||||
|
|
||||||
|
implementation(libs.appcompat)
|
||||||
|
implementation(libs.material)
|
||||||
|
implementation(libs.activity)
|
||||||
|
implementation(libs.constraintlayout)
|
||||||
|
testImplementation(libs.junit)
|
||||||
|
androidTestImplementation(libs.ext.junit)
|
||||||
|
androidTestImplementation(libs.espresso.core)
|
||||||
|
}
|
21
DepannRien/app/proguard-rules.pro
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# Add project specific ProGuard rules here.
|
||||||
|
# You can control the set of applied configuration files using the
|
||||||
|
# proguardFiles setting in build.gradle.
|
||||||
|
#
|
||||||
|
# For more details, see
|
||||||
|
# http://developer.android.com/guide/developing/tools/proguard.html
|
||||||
|
|
||||||
|
# If your project uses WebView with JS, uncomment the following
|
||||||
|
# and specify the fully qualified class name to the JavaScript interface
|
||||||
|
# class:
|
||||||
|
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
|
||||||
|
# public *;
|
||||||
|
#}
|
||||||
|
|
||||||
|
# Uncomment this to preserve the line number information for
|
||||||
|
# debugging stack traces.
|
||||||
|
#-keepattributes SourceFile,LineNumberTable
|
||||||
|
|
||||||
|
# If you keep the line number information, uncomment this to
|
||||||
|
# hide the original source file name.
|
||||||
|
#-renamesourcefileattribute SourceFile
|
@ -0,0 +1,26 @@
|
|||||||
|
package com.example.depanntout;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import androidx.test.platform.app.InstrumentationRegistry;
|
||||||
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Instrumented test, which will execute on an Android device.
|
||||||
|
*
|
||||||
|
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
||||||
|
*/
|
||||||
|
@RunWith(AndroidJUnit4.class)
|
||||||
|
public class ExampleInstrumentedTest {
|
||||||
|
@Test
|
||||||
|
public void useAppContext() {
|
||||||
|
// Context of the app under test.
|
||||||
|
Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
|
||||||
|
assertEquals("com.example.depanntout", appContext.getPackageName());
|
||||||
|
}
|
||||||
|
}
|
44
DepannRien/app/src/main/AndroidManifest.xml
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools">
|
||||||
|
|
||||||
|
<application
|
||||||
|
android:allowBackup="true"
|
||||||
|
android:dataExtractionRules="@xml/data_extraction_rules"
|
||||||
|
android:fullBackupContent="@xml/backup_rules"
|
||||||
|
android:icon="@mipmap/ic_launcher"
|
||||||
|
android:label="@string/app_name"
|
||||||
|
android:roundIcon="@mipmap/ic_launcher_round"
|
||||||
|
android:supportsRtl="true"
|
||||||
|
android:theme="@style/Theme.Depanntout"
|
||||||
|
tools:targetApi="31">
|
||||||
|
<activity
|
||||||
|
android:name=".CreateInter"
|
||||||
|
android:exported="false" />
|
||||||
|
<activity
|
||||||
|
android:name=".GestionInter"
|
||||||
|
android:exported="false" />
|
||||||
|
<activity
|
||||||
|
android:name=".ModifInter"
|
||||||
|
android:exported="false" />
|
||||||
|
<activity
|
||||||
|
android:name=".CreateClient"
|
||||||
|
android:exported="false" />
|
||||||
|
<activity
|
||||||
|
android:name=".GestionClient"
|
||||||
|
android:exported="false" />
|
||||||
|
<activity
|
||||||
|
android:name=".ModifClient"
|
||||||
|
android:exported="false" />
|
||||||
|
<activity
|
||||||
|
android:name=".MainActivity"
|
||||||
|
android:exported="true">
|
||||||
|
<intent-filter>
|
||||||
|
<action android:name="android.intent.action.MAIN" />
|
||||||
|
|
||||||
|
<category android:name="android.intent.category.LAUNCHER" />
|
||||||
|
</intent-filter>
|
||||||
|
</activity>
|
||||||
|
</application>
|
||||||
|
|
||||||
|
</manifest>
|
75
DepannRien/app/src/main/java/bdd/ClientDAO.java
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
package bdd;
|
||||||
|
|
||||||
|
import android.content.ContentValues;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.database.Cursor;
|
||||||
|
import android.database.sqlite.SQLiteDatabase;
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
|
import metier.Client;
|
||||||
|
|
||||||
|
public class ClientDAO {
|
||||||
|
private DAO dao = null;
|
||||||
|
private SQLiteDatabase db = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructeur
|
||||||
|
* @param context
|
||||||
|
*/
|
||||||
|
|
||||||
|
public ClientDAO(Context context){
|
||||||
|
dao = new DAO(context);
|
||||||
|
db = dao.open();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fermeture de la base de données
|
||||||
|
*/
|
||||||
|
|
||||||
|
public void close() {
|
||||||
|
dao.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Cursor readLesClients() {
|
||||||
|
String reqSql = "Select id as '_id', nom, prenom, numTel, adrMail, adrPostale FROM " + CreateBdDepannTout.TABLE_CLIENT +";";
|
||||||
|
// Execution de la requête
|
||||||
|
Cursor c = db.rawQuery(reqSql, null);
|
||||||
|
Log.d("bdd", "le curseur contient " + c.getCount() + " lignes");
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long create(Client c) {
|
||||||
|
ContentValues values = new ContentValues();
|
||||||
|
values.put("nom", c.getNom());
|
||||||
|
values.put("prenom", c.getPrenom());
|
||||||
|
values.put("numTel", c.getNumTel());
|
||||||
|
values.put("adrMail", c.getAdrMail());
|
||||||
|
values.put("adrPostale", c.getAdrPostale());
|
||||||
|
Log.d("bdd", "insert, :" + c);
|
||||||
|
return db.insert(CreateBdDepannTout.TABLE_CLIENT, null, values);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean delete(int id) {
|
||||||
|
int result = db.delete(CreateBdDepannTout.TABLE_CLIENT,
|
||||||
|
"id = ?",
|
||||||
|
new String[]{String.valueOf(id)});
|
||||||
|
db.close();
|
||||||
|
return result > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean update(int id, String nom, String prenom, int numTel, String adrMail, String adrPostale) {
|
||||||
|
ContentValues values = new ContentValues();
|
||||||
|
values.put("nom", nom);
|
||||||
|
values.put("prenom", prenom);
|
||||||
|
values.put("numTel", numTel);
|
||||||
|
values.put("adrMail", adrMail);
|
||||||
|
values.put("adrPostale", adrPostale);
|
||||||
|
int result = db.update(CreateBdDepannTout.TABLE_CLIENT,
|
||||||
|
values,
|
||||||
|
"id = ?",
|
||||||
|
new String[]{String.valueOf(id)});
|
||||||
|
db.close();
|
||||||
|
return result > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
128
DepannRien/app/src/main/java/bdd/CreateBdDepannTout.java
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
package bdd;
|
||||||
|
|
||||||
|
import android.content.ContentValues;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.database.sqlite.SQLiteDatabase;
|
||||||
|
import android.database.sqlite.SQLiteOpenHelper;
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
|
public class CreateBdDepannTout extends SQLiteOpenHelper {
|
||||||
|
|
||||||
|
public static final String TABLE_CLIENT = "client";
|
||||||
|
public static final String TABLE_INTER = "intervention";
|
||||||
|
private static final String CREATE_TABLE_CLIENT =
|
||||||
|
"CREATE TABLE " + TABLE_CLIENT + "(" +
|
||||||
|
"id INTEGER PRIMARY KEY AUTOINCREMENT, " +
|
||||||
|
"nom TEXT NOT NULL, " +
|
||||||
|
"prenom TEXT NOT NULL, " +
|
||||||
|
"numTel TEXT NOT NULL, " +
|
||||||
|
"adrMail TEXT NOT NULL, " +
|
||||||
|
"adrPostale TEXT NOT NULL);";
|
||||||
|
|
||||||
|
private static final String CREATE_TABLE_INTER =
|
||||||
|
"CREATE TABLE " + TABLE_INTER + "(" +
|
||||||
|
"id INTEGER PRIMARY KEY AUTOINCREMENT, " +
|
||||||
|
"idCli TEXT NOT NULL, " +
|
||||||
|
"date TEXT NOT NULL, " +
|
||||||
|
"heure TEXT NOT NULL," +
|
||||||
|
"observation TEXT NOT NULL);";
|
||||||
|
|
||||||
|
private static final String INSERT_INTO_INTERVENTION =
|
||||||
|
"INSERT INTO " + TABLE_INTER + " (idCli, date, heure, observation) VALUES " +
|
||||||
|
"(1, '03/01/2025', '12h30', 'dégât des eaux dans la cuisine'), " +
|
||||||
|
"(2, '03/01/2025', '13h00', 'dégât des eaux dans la salle de bain'), " +
|
||||||
|
"(3, '03/01/2025', '14h15', 'fuite d''eau dans le salon'), " +
|
||||||
|
"(4, '03/01/2025', '15h45', 'dégât des eaux dans le garage'), " +
|
||||||
|
"(5, '03/01/2025', '16h00', 'fuite d''eau dans la chambre'), " +
|
||||||
|
"(6, '03/01/2025', '17h30', 'dégât des eaux sur la terrasse'), " +
|
||||||
|
"(7, '03/01/2025', '18h10', 'fuite d''eau dans les toilettes'), " +
|
||||||
|
"(8, '03/01/2025', '19h00', 'dégât des eaux dans le bureau'), " +
|
||||||
|
"(9, '03/01/2025', '20h15', 'fuite d''eau dans l''entrée'), " +
|
||||||
|
"(10, '03/01/2025', '21h00', 'dégât des eaux dans la buanderie')";
|
||||||
|
|
||||||
|
private static final String INSERT_INTO_CLIENT =
|
||||||
|
"INSERT INTO " + TABLE_CLIENT + " (nom, prenom, numTel, adrMail, adrPostale) VALUES " +
|
||||||
|
"('Dupont', 'Jean', '0600000001', 'jean.dupont@example.com', '10 Rue de Paris, 75001 Paris'), " +
|
||||||
|
"('Martin', 'Sophie', '0600000002', 'sophie.martin@example.com', '15 Rue de Lyon, 69001 Lyon'), " +
|
||||||
|
"('Durand', 'Paul', '0600000003', 'paul.durand@example.com', '20 Rue de Bordeaux, 33000 Bordeaux'), " +
|
||||||
|
"('Lemoine', 'Claire', '0600000004', 'claire.lemoine@example.com', '25 Rue de Lille, 59000 Lille'), " +
|
||||||
|
"('Morel', 'Luc', '0600000005', 'luc.morel@example.com', '30 Rue de Nantes, 44000 Nantes'), " +
|
||||||
|
"('Blanc', 'Julie', '0600000006', 'julie.blanc@example.com', '35 Rue de Marseille, 13000 Marseille'), " +
|
||||||
|
"('Garcia', 'Emma', '0600000007', 'emma.garcia@example.com', '40 Rue de Toulouse, 31000 Toulouse'), " +
|
||||||
|
"('Petit', 'Hugo', '0600000008', 'hugo.petit@example.com', '45 Rue de Strasbourg, 67000 Strasbourg'), " +
|
||||||
|
"('Roux', 'Chloe', '0600000009', 'chloe.roux@example.com', '50 Rue de Nice, 06000 Nice'), " +
|
||||||
|
"('Fournier', 'Lucas', '0600000010', 'lucas.fournier@example.com', '55 Rue de Rennes, 35000 Rennes')";
|
||||||
|
|
||||||
|
// Constructeur, à générer automatiquement
|
||||||
|
public CreateBdDepannTout(@Nullable Context context, @Nullable String name,
|
||||||
|
@Nullable SQLiteDatabase.CursorFactory factory, int version) {
|
||||||
|
super(context, name, factory, version);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Création de la base de données si elle n'existe pas
|
||||||
|
*
|
||||||
|
* @param db base
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void onCreate(SQLiteDatabase db) {
|
||||||
|
db.execSQL(CREATE_TABLE_CLIENT);
|
||||||
|
Log.d("bdd", "table client créée");
|
||||||
|
|
||||||
|
db.execSQL(CREATE_TABLE_INTER);
|
||||||
|
Log.d("bdd", "table intervention créée");
|
||||||
|
|
||||||
|
db.execSQL(INSERT_INTO_INTERVENTION);
|
||||||
|
Log.d("bdd", "données table intervention inserées");
|
||||||
|
|
||||||
|
db.execSQL(INSERT_INTO_CLIENT);
|
||||||
|
Log.d("bdd", "données table client inserées");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Création d'une nouvelle base en cas de changement de version
|
||||||
|
*
|
||||||
|
* @param db
|
||||||
|
* @param oldVersion
|
||||||
|
* @param newVersion
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
|
||||||
|
db.execSQL("DROP TABLE " + TABLE_CLIENT + ";");
|
||||||
|
Log.d("bdd", "Table " + TABLE_CLIENT + " supprimée");
|
||||||
|
db.execSQL("DROP TABLE " + TABLE_INTER + ";");
|
||||||
|
Log.d("bdd", "Table " + TABLE_INTER + " supprimée");
|
||||||
|
onCreate(db);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void insertDataInter(SQLiteDatabase db) {
|
||||||
|
// Sample data to insert
|
||||||
|
String[][] data = {
|
||||||
|
{"1", "03/01/2025", "12h30", "dégât des eaux dans la cuisine"},
|
||||||
|
{"2", "03/01/2025", "13h00", "dégât des eaux dans la salle de bain"},
|
||||||
|
{"3", "03/01/2025", "14h15", "fuite d'eau dans le salon"},
|
||||||
|
{"4", "03/01/2025", "15h45", "dégât des eaux dans le garage"},
|
||||||
|
{"5", "03/01/2025", "16h00", "fuite d'eau dans la chambre"},
|
||||||
|
{"6", "03/01/2025", "17h30", "dégât des eaux sur la terrasse"},
|
||||||
|
{"7", "03/01/2025", "18h10", "fuite d'eau dans les toilettes"},
|
||||||
|
{"8", "03/01/2025", "19h00", "dégât des eaux dans le bureau"},
|
||||||
|
{"9", "03/01/2025", "20h15", "fuite d'eau dans l'entrée"},
|
||||||
|
{"10", "03/01/2025", "21h00", "dégât des eaux dans la buanderie"}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Insert each row into the database
|
||||||
|
for (String[] row : data) {
|
||||||
|
ContentValues values = new ContentValues();
|
||||||
|
values.put("idCli", row[0]);
|
||||||
|
values.put("date", row[1]);
|
||||||
|
values.put("heure", row[2]);
|
||||||
|
values.put("observation", row[3]);
|
||||||
|
|
||||||
|
db.insert("Intervention", null, values); // Insert the row
|
||||||
|
Log.d("bdd", "Insertion intervention réussie " + values);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
34
DepannRien/app/src/main/java/bdd/DAO.java
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
package bdd;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.database.sqlite.SQLiteDatabase;
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
|
public class DAO {
|
||||||
|
private static final int VERSION_BDD = 8;
|
||||||
|
private static final String NOM_BDD = "bdDepannTout";
|
||||||
|
private CreateBdDepannTout createBd = null;
|
||||||
|
private SQLiteDatabase db = null;
|
||||||
|
|
||||||
|
public DAO(Context context){
|
||||||
|
createBd = new CreateBdDepannTout(context, NOM_BDD, null, VERSION_BDD);
|
||||||
|
Log.d("bdd", "Appel au constructeur de DAO ok, bdd créée");
|
||||||
|
}
|
||||||
|
|
||||||
|
public SQLiteDatabase open(){
|
||||||
|
if (db == null){
|
||||||
|
db = createBd.getWritableDatabase();
|
||||||
|
Log.d("bdd", "Base de données ouverte");
|
||||||
|
} else {
|
||||||
|
Log.d("bdd", "base de données accessible");
|
||||||
|
}
|
||||||
|
return db;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void close() {
|
||||||
|
if(db != null){
|
||||||
|
db.close();
|
||||||
|
Log.d("bdd", "Base de données fermée");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
73
DepannRien/app/src/main/java/bdd/InterventionDAO.java
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
package bdd;
|
||||||
|
|
||||||
|
import android.content.ContentValues;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.database.Cursor;
|
||||||
|
import android.database.sqlite.SQLiteDatabase;
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
|
import metier.Intervention;
|
||||||
|
|
||||||
|
public class InterventionDAO {
|
||||||
|
private DAO dao = null;
|
||||||
|
private SQLiteDatabase db = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructeur
|
||||||
|
* @param context
|
||||||
|
*/
|
||||||
|
|
||||||
|
public InterventionDAO(Context context){
|
||||||
|
dao = new DAO(context);
|
||||||
|
db = dao.open();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fermeture de la base de données
|
||||||
|
*/
|
||||||
|
|
||||||
|
public void close() {
|
||||||
|
dao.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Cursor readLesInterventions() {
|
||||||
|
String reqSql = "Select id as '_id', date, heure, observation, idCli FROM " + CreateBdDepannTout.TABLE_INTER +";";
|
||||||
|
// Execution de la requête
|
||||||
|
Cursor c = db.rawQuery(reqSql, null);
|
||||||
|
Log.d("bdd", "le curseur contient " + c.getCount() + " lignes");
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long create(Intervention i) {
|
||||||
|
ContentValues values = new ContentValues();
|
||||||
|
values.put("date", i.getDate());
|
||||||
|
values.put("heure", i.getHeure());
|
||||||
|
values.put("idCli", i.getIdCli());
|
||||||
|
values.put("observation", i.getObservation());
|
||||||
|
Log.d("bdd", "insert, :" + i);
|
||||||
|
return db.insert(CreateBdDepannTout.TABLE_INTER, null, values);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean delete(int id) {
|
||||||
|
int result = db.delete(CreateBdDepannTout.TABLE_INTER,
|
||||||
|
"id = ?",
|
||||||
|
new String[]{String.valueOf(id)});
|
||||||
|
db.close();
|
||||||
|
return result > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean update(int id, String date, String heure, String observation, int idCli) {
|
||||||
|
ContentValues values = new ContentValues();
|
||||||
|
values.put("date", date);
|
||||||
|
values.put("heure", heure);
|
||||||
|
values.put("observation", observation);
|
||||||
|
values.put("idCli", idCli);
|
||||||
|
int result = db.update(CreateBdDepannTout.TABLE_INTER,
|
||||||
|
values,
|
||||||
|
"id = ?",
|
||||||
|
new String[]{String.valueOf(id)});
|
||||||
|
db.close();
|
||||||
|
return result > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,91 @@
|
|||||||
|
package com.example.depanntout;
|
||||||
|
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.EditText;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import bdd.ClientDAO;
|
||||||
|
import metier.Client;
|
||||||
|
|
||||||
|
public class CreateClient extends AppCompatActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_create_client);
|
||||||
|
initialisation();
|
||||||
|
gererCreateClient();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initialisation() {
|
||||||
|
// gestion du boutton Quitter
|
||||||
|
Button btQuitterCreate = (Button) findViewById(R.id.btQuitterCreate);
|
||||||
|
// Association d'un écouteur d'événement au clic de btQuitter
|
||||||
|
btQuitterCreate.setOnClickListener(new View.OnClickListener() {
|
||||||
|
public void onClick(View arg0) {
|
||||||
|
clientDAO.close();
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private ClientDAO clientDAO = null;
|
||||||
|
Client cli = null;
|
||||||
|
|
||||||
|
// Contrôle graphiques
|
||||||
|
private EditText etNom;
|
||||||
|
private EditText etPrenom;
|
||||||
|
private EditText etNumTel;
|
||||||
|
private EditText etAdrMail;
|
||||||
|
private EditText etAdrPostale;
|
||||||
|
private Button btCreateClient;
|
||||||
|
|
||||||
|
//Valeur saisies
|
||||||
|
String nom;
|
||||||
|
String prenom;
|
||||||
|
String numTel;
|
||||||
|
String adrMail;
|
||||||
|
String adrPostale;
|
||||||
|
|
||||||
|
private void gererCreateClient() {
|
||||||
|
// Reconnaissance des contrôles graphiques de la vue
|
||||||
|
etNom = (EditText) findViewById(R.id.ptSasirNom);
|
||||||
|
etPrenom = (EditText) findViewById(R.id.ptSaisirPrenom);
|
||||||
|
etNumTel = (EditText) findViewById(R.id.ptSaisirNumTel);
|
||||||
|
etAdrMail = (EditText) findViewById(R.id.ptSaisirMailClient);
|
||||||
|
etAdrPostale = (EditText) findViewById(R.id.ptSaisirAdrClient);
|
||||||
|
btCreateClient = (Button) findViewById(R.id.btCreateClient);
|
||||||
|
// Accès à la table client
|
||||||
|
clientDAO = new ClientDAO(this);
|
||||||
|
// Gestion de l'événement onClick sur le boutn Ajouter
|
||||||
|
btCreateClient.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View arg0) {
|
||||||
|
// Récupération des zones saisies
|
||||||
|
nom = etNom.getText().toString();
|
||||||
|
prenom = etPrenom.getText().toString();
|
||||||
|
numTel = etNumTel.getText().toString();
|
||||||
|
adrMail = etAdrMail.getText().toString();
|
||||||
|
adrPostale = etAdrPostale.getText().toString();
|
||||||
|
// Création de l'article correspondant
|
||||||
|
cli = new Client(nom, prenom, numTel, adrMail, adrPostale);
|
||||||
|
// Insertion de l'article dans la base de données
|
||||||
|
long idClientCree = clientDAO.create(cli);
|
||||||
|
// Message à l'écran
|
||||||
|
Toast.makeText(getApplicationContext(), "Produit ajouté + " +
|
||||||
|
"(no : " + idClientCree + " )", Toast.LENGTH_SHORT).show();
|
||||||
|
// Zones de saisies effacées
|
||||||
|
etNom.setText("");
|
||||||
|
etNom.requestFocus();
|
||||||
|
etPrenom.setText("");
|
||||||
|
etNumTel.setText("");
|
||||||
|
etAdrMail.setText("");
|
||||||
|
etAdrPostale.setText("");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,89 @@
|
|||||||
|
package com.example.depanntout;
|
||||||
|
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.EditText;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import bdd.InterventionDAO;
|
||||||
|
import metier.Intervention;
|
||||||
|
|
||||||
|
public class CreateInter extends AppCompatActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_create_inter);
|
||||||
|
initialisation();
|
||||||
|
gererCreateInter();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
private void initialisation() {
|
||||||
|
// gestion du boutton Quitter
|
||||||
|
Button btQuitterCreate = (Button) findViewById(R.id.btQuitterCreate);
|
||||||
|
// Association d'un écouteur d'événement au clic de btQuitter
|
||||||
|
btQuitterCreate.setOnClickListener(new View.OnClickListener() {
|
||||||
|
public void onClick(View arg0) {
|
||||||
|
interventionDAO.close();
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
private InterventionDAO interventionDAO = null;
|
||||||
|
Intervention inter = null;
|
||||||
|
|
||||||
|
|
||||||
|
// Contrôle graphiques
|
||||||
|
private EditText etDate;
|
||||||
|
private EditText etHeure;
|
||||||
|
private EditText etObs;
|
||||||
|
private EditText etIdCli;
|
||||||
|
private Button btCreateInter;
|
||||||
|
|
||||||
|
//Valeur saisies
|
||||||
|
String date;
|
||||||
|
String heure;
|
||||||
|
String observation;
|
||||||
|
int idCli;
|
||||||
|
|
||||||
|
private void gererCreateInter() {
|
||||||
|
// Reconnaissance des contrôles graphiques de la vue
|
||||||
|
etDate = (EditText) findViewById(R.id.ptSaisiDate);
|
||||||
|
etHeure = (EditText) findViewById(R.id.ptSaisiHeure);
|
||||||
|
etObs = (EditText) findViewById(R.id.ptSaisiObserv);
|
||||||
|
etIdCli = (EditText) findViewById(R.id.ptSaisiIdClient);
|
||||||
|
btCreateInter = (Button) findViewById(R.id.btCreateInter);
|
||||||
|
// Accès à la table article
|
||||||
|
interventionDAO = new InterventionDAO(this);
|
||||||
|
// Gestion de l'événement onClick sur le boutn Ajouter
|
||||||
|
btCreateInter.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View arg0) {
|
||||||
|
// Récupération des zones saisies
|
||||||
|
date = etDate.getText().toString();
|
||||||
|
heure = etHeure.getText().toString();
|
||||||
|
observation = etObs.getText().toString();
|
||||||
|
idCli = Integer.parseInt(etIdCli.getText().toString());
|
||||||
|
// // Création de l'article correspondant
|
||||||
|
inter = new Intervention(date, heure, observation, idCli);
|
||||||
|
// // Insertion de l'article dans la base de données
|
||||||
|
long idInterCree = interventionDAO.create(inter);
|
||||||
|
// // Message à l'écran
|
||||||
|
Toast.makeText(getApplicationContext(), "Intervention ajoutée + " +
|
||||||
|
"(no : " + idInterCree + " )", Toast.LENGTH_SHORT).show();
|
||||||
|
Toast.makeText(getApplicationContext(), "Intervention ajoutée + " +
|
||||||
|
date + heure + observation + idCli + " )", Toast.LENGTH_SHORT).show();
|
||||||
|
// // Zones de saisies effacées
|
||||||
|
etDate.setText("");
|
||||||
|
etHeure.setText("");
|
||||||
|
etObs.requestFocus();
|
||||||
|
etIdCli.setText("");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,89 @@
|
|||||||
|
package com.example.depanntout;
|
||||||
|
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.database.Cursor;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.ListView;
|
||||||
|
import android.widget.SimpleCursorAdapter;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import bdd.ClientDAO;
|
||||||
|
|
||||||
|
public class GestionClient extends AppCompatActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_gestion_client);
|
||||||
|
initialisation();
|
||||||
|
afficherLesClients();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initialisation() {
|
||||||
|
// gestion du boutton Quitter
|
||||||
|
Button btQuitterClient = (Button) findViewById(R.id.btQuitterInter);
|
||||||
|
// Association d'un écouteur d'événement au clic de btQuitter
|
||||||
|
btQuitterClient.setOnClickListener(new View.OnClickListener() {
|
||||||
|
public void onClick(View arg0) {
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// gestion du boutton Gestion des clients
|
||||||
|
Button btCreerClient = (Button) findViewById(R.id.btCreerInter);
|
||||||
|
btCreerClient.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View view) {
|
||||||
|
demarrerCreerClient();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void demarrerCreerClient(){
|
||||||
|
Intent intent = new Intent(GestionClient.this, CreateClient.class);
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void afficherLesClients(){
|
||||||
|
Log.d("bdd", "Début de afficherLesClients");
|
||||||
|
ClientDAO clientDAO = new ClientDAO(this);
|
||||||
|
Cursor c = clientDAO.readLesClients();
|
||||||
|
Toast.makeText(getApplicationContext(), "Il y a +" +
|
||||||
|
c.getCount() + "articles", Toast.LENGTH_SHORT).show();
|
||||||
|
String[] from = new String[]{"_id", "nom", "prenom", "numTel", "adrMail", "adrPostale"};
|
||||||
|
int[] to = new int[] {R.id.tvIdClient, R.id.tvNomClient, R.id.tvPrenomClient, R.id.tvNumTelClient, R.id.tvAdrMailClient, R.id.tvAdrPostClient};
|
||||||
|
SimpleCursorAdapter dataAdapter = new SimpleCursorAdapter(this, R.layout.ligne_client, c, from, to, 0);
|
||||||
|
ListView lvClients = (ListView) findViewById(R.id.lvClients);
|
||||||
|
lvClients.setAdapter(dataAdapter);
|
||||||
|
|
||||||
|
// Set an item click listener for the ListView
|
||||||
|
lvClients.setOnItemClickListener((parent, view, position, id) -> {
|
||||||
|
// Move the Cursor to the clicked item's position
|
||||||
|
c.moveToPosition(position);
|
||||||
|
|
||||||
|
// Extract details from the cursor
|
||||||
|
int idCli = c.getInt(c.getColumnIndexOrThrow("_id"));
|
||||||
|
String prenom = c.getString(c.getColumnIndexOrThrow("prenom"));
|
||||||
|
String nom = c.getString(c.getColumnIndexOrThrow("nom"));
|
||||||
|
int numTel = c.getInt(c.getColumnIndexOrThrow("numTel"));
|
||||||
|
String adrMail = c.getString(c.getColumnIndexOrThrow("adrMail"));
|
||||||
|
String adrPostale = c.getString(c.getColumnIndexOrThrow("adrPostale"));
|
||||||
|
|
||||||
|
|
||||||
|
// Pass the details to the new activity using Intent
|
||||||
|
Intent intent = new Intent(this, ModifClient.class);
|
||||||
|
intent.putExtra("_id", idCli);
|
||||||
|
intent.putExtra("prenom", prenom);
|
||||||
|
intent.putExtra("nom", nom);
|
||||||
|
intent.putExtra("numTel", numTel);
|
||||||
|
intent.putExtra("adrMail", adrMail);
|
||||||
|
intent.putExtra("adrPostale", adrPostale);
|
||||||
|
startActivity(intent);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,88 @@
|
|||||||
|
package com.example.depanntout;
|
||||||
|
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.database.Cursor;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.ListView;
|
||||||
|
import android.widget.SimpleCursorAdapter;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import bdd.InterventionDAO;
|
||||||
|
|
||||||
|
public class GestionInter extends AppCompatActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_gestion_inter);
|
||||||
|
initialisation();
|
||||||
|
afficherLesInterventions();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initialisation() {
|
||||||
|
// gestion du boutton Quitter
|
||||||
|
Button btQuitterInter = (Button) findViewById(R.id.btQuitterInter);
|
||||||
|
// Association d'un écouteur d'événement au clic de btQuitter
|
||||||
|
btQuitterInter.setOnClickListener(new View.OnClickListener() {
|
||||||
|
public void onClick(View arg0) {
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// gestion du boutton Gestion des interventions
|
||||||
|
Button btCreateInter = (Button) findViewById(R.id.btCreerInter);
|
||||||
|
btCreateInter.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View view) {
|
||||||
|
demarrerCreerInter();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void demarrerCreerInter(){
|
||||||
|
Intent intent = new Intent(GestionInter.this, CreateInter.class);
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void afficherLesInterventions(){
|
||||||
|
Log.d("bdd", "Début de afficherLesInterventions");
|
||||||
|
InterventionDAO clientDAO = new InterventionDAO(this);
|
||||||
|
Cursor c = clientDAO.readLesInterventions();
|
||||||
|
Toast.makeText(getApplicationContext(), "Il y a +" +
|
||||||
|
c.getCount() + "interventions", Toast.LENGTH_SHORT).show();
|
||||||
|
String[] from = new String[]{"date", "heure", "observation", "idCli"};
|
||||||
|
int[] to = new int[] {R.id.tvDateLigne, R.id.tvHeureLigne, R.id.tvObsLigne, R.id.tvIdClientInterLigne};
|
||||||
|
SimpleCursorAdapter dataAdapter = new SimpleCursorAdapter(this, R.layout.ligne_intervention, c, from, to, 0);
|
||||||
|
ListView lvInterventions = (ListView) findViewById(R.id.lvClients);
|
||||||
|
lvInterventions.setAdapter(dataAdapter);
|
||||||
|
|
||||||
|
// Set an item click listener for the ListView
|
||||||
|
lvInterventions.setOnItemClickListener((parent, view, position, id) -> {
|
||||||
|
// Move the Cursor to the clicked item's position
|
||||||
|
c.moveToPosition(position);
|
||||||
|
|
||||||
|
// Extract details from the cursor
|
||||||
|
int idInter = c.getInt(c.getColumnIndexOrThrow("_id"));
|
||||||
|
String date = c.getString(c.getColumnIndexOrThrow("date"));
|
||||||
|
String heure = c.getString(c.getColumnIndexOrThrow("heure"));
|
||||||
|
String observation = c.getString(c.getColumnIndexOrThrow("observation"));
|
||||||
|
int idCli = c.getInt(c.getColumnIndexOrThrow("idCli"));
|
||||||
|
|
||||||
|
// Pass the details to the new activity using Intent
|
||||||
|
Intent intent = new Intent(this, ModifInter.class);
|
||||||
|
intent.putExtra("_id", idInter);
|
||||||
|
intent.putExtra("date", date);
|
||||||
|
intent.putExtra("heure", heure);
|
||||||
|
intent.putExtra("observation", observation);
|
||||||
|
intent.putExtra("idCli", idCli);
|
||||||
|
startActivity(intent);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,74 @@
|
|||||||
|
package com.example.depanntout;
|
||||||
|
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.database.sqlite.SQLiteDatabase;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import bdd.CreateBdDepannTout;
|
||||||
|
|
||||||
|
public class MainActivity extends AppCompatActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_main);
|
||||||
|
initialisation();
|
||||||
|
|
||||||
|
// Create an instance of your database helper
|
||||||
|
CreateBdDepannTout dbHelper = new CreateBdDepannTout(this, "DepannTout.db", null, 1);
|
||||||
|
|
||||||
|
// Open the database in writable mode
|
||||||
|
SQLiteDatabase db = dbHelper.getWritableDatabase();
|
||||||
|
|
||||||
|
// Call the insertData function to populate your table
|
||||||
|
// dbHelper.insertDataInter(db);
|
||||||
|
// Log.d("MainActivity", "Data inserted into the intervention table");
|
||||||
|
//
|
||||||
|
// dbHelper.insertClientData(db);
|
||||||
|
// Log.d("MainActivity", "Data inserted into the client table");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initialisation() {
|
||||||
|
// gestion du boutton Quitter
|
||||||
|
Button btQuitter = (Button) findViewById(R.id.btQuitter);
|
||||||
|
// Association d'un écouteur d'événement au clic de btQuitter
|
||||||
|
btQuitter.setOnClickListener(new View.OnClickListener(){
|
||||||
|
public void onClick(View arg0){
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// gestion du boutton Gestion des clients
|
||||||
|
Button btGestClient = (Button) findViewById(R.id.btGestClient);
|
||||||
|
btGestClient.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View view) {
|
||||||
|
demarrerClient();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// gestion du boutton Gestion des Interventions
|
||||||
|
Button btGestInter = (Button) findViewById(R.id.btGestInter);
|
||||||
|
btGestInter.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View view) {
|
||||||
|
demarrerInter();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void demarrerClient(){
|
||||||
|
Intent intent = new Intent(MainActivity.this, GestionClient.class);
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void demarrerInter() {
|
||||||
|
Intent intent = new Intent(MainActivity.this, GestionInter.class);
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,109 @@
|
|||||||
|
package com.example.depanntout;
|
||||||
|
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.EditText;
|
||||||
|
import android.widget.TextView;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import bdd.ClientDAO;
|
||||||
|
import metier.Client;
|
||||||
|
|
||||||
|
public class ModifClient extends AppCompatActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_modif_client);
|
||||||
|
initialisation();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initialisation() {
|
||||||
|
|
||||||
|
String prenom = getIntent().getStringExtra("prenom");
|
||||||
|
String nom = getIntent().getStringExtra("nom");
|
||||||
|
int numTel = getIntent().getIntExtra("numTel", -1);
|
||||||
|
String adrMail = getIntent().getStringExtra("adrMail");
|
||||||
|
String adrPostale = getIntent().getStringExtra("adrPostale");
|
||||||
|
idCli = getIntent().getIntExtra("_id", -1);
|
||||||
|
|
||||||
|
EditText etPrenom = findViewById(R.id.ptModifPrenom);
|
||||||
|
EditText etNom = findViewById(R.id.ptModifNom);
|
||||||
|
EditText etNumTel = findViewById(R.id.ptModifNumTel);
|
||||||
|
EditText etAdrMail = findViewById(R.id.ptModifAdrMail);
|
||||||
|
EditText etAdrPostale = findViewById(R.id.ptModifAdrPostale);
|
||||||
|
|
||||||
|
etPrenom.setText(prenom);
|
||||||
|
etNom.setText(nom);
|
||||||
|
etNumTel.setText(numTel != -1 ? String.valueOf(numTel) : "");
|
||||||
|
etAdrMail.setText(adrMail);
|
||||||
|
etAdrPostale.setText(adrPostale);
|
||||||
|
|
||||||
|
Button btnDeleteClient = findViewById(R.id.btnDeleteClient);
|
||||||
|
Button btnModifClient = findViewById(R.id.btnModifClient);
|
||||||
|
|
||||||
|
// Accès à la table client
|
||||||
|
clientDAO = new ClientDAO(this);
|
||||||
|
|
||||||
|
// Gestion de l'événement onClick sur le boutn Ajouter
|
||||||
|
btnDeleteClient.setOnClickListener(v -> {
|
||||||
|
boolean isDeleted = clientDAO.delete(idCli);
|
||||||
|
if (isDeleted) {
|
||||||
|
Toast.makeText(this, "Client deleted successfully", Toast.LENGTH_SHORT).show();
|
||||||
|
finish();
|
||||||
|
} else {
|
||||||
|
Toast.makeText(this, "Delete failed", Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
btnModifClient.setOnClickListener(v -> {
|
||||||
|
|
||||||
|
String prenomModif = etPrenom.getText().toString();
|
||||||
|
String nomModif = etNom.getText().toString();
|
||||||
|
int numTelModif = Integer.parseInt(etNumTel.getText().toString());
|
||||||
|
String adrMailModif = etAdrMail.getText().toString();
|
||||||
|
String adrPostaleModif = etAdrPostale.getText().toString();
|
||||||
|
|
||||||
|
Log.d("UpdateDebug", idCli + nomModif + prenomModif + numTelModif + adrMailModif + adrPostaleModif);
|
||||||
|
boolean isUpdated = clientDAO.update(idCli, nomModif, prenomModif, numTelModif, adrMailModif, adrPostaleModif);
|
||||||
|
if (isUpdated) {
|
||||||
|
Toast.makeText(this, "Client updated successfully", Toast.LENGTH_SHORT).show();
|
||||||
|
finish();
|
||||||
|
} else {
|
||||||
|
Toast.makeText(this, "Update failed", Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// gestion du boutton Quitter
|
||||||
|
Button btQuitterInter = (Button) findViewById(R.id.btQuitterClient);
|
||||||
|
// Association d'un écouteur d'événement au clic de btQuitter
|
||||||
|
btQuitterInter.setOnClickListener(new View.OnClickListener() {
|
||||||
|
public void onClick(View arg0) {
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private ClientDAO clientDAO = null;
|
||||||
|
Client cli = null;
|
||||||
|
|
||||||
|
// Contrôle graphiques
|
||||||
|
private EditText etNom;
|
||||||
|
private EditText etPrenom;
|
||||||
|
private EditText etNumTel;
|
||||||
|
private EditText etAdrMail;
|
||||||
|
private EditText etAdrPostale;
|
||||||
|
private Button btnDeleteClient;
|
||||||
|
|
||||||
|
//Valeur saisies
|
||||||
|
Integer idCli;
|
||||||
|
String nom;
|
||||||
|
String prenom;
|
||||||
|
Integer numTel;
|
||||||
|
String adrMail;
|
||||||
|
String adrPostale;
|
||||||
|
}
|
@ -0,0 +1,89 @@
|
|||||||
|
package com.example.depanntout;
|
||||||
|
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.TextView;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import bdd.InterventionDAO;
|
||||||
|
import metier.Intervention;
|
||||||
|
|
||||||
|
public class ModifInter extends AppCompatActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_modif_inter);
|
||||||
|
|
||||||
|
initialisation();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initialisation() {
|
||||||
|
|
||||||
|
// Get data from Intent
|
||||||
|
String date = getIntent().getStringExtra("date");
|
||||||
|
String heure = getIntent().getStringExtra("heure");
|
||||||
|
String observation = getIntent().getStringExtra("observation");
|
||||||
|
int idCli = getIntent().getIntExtra("idCli", -1);
|
||||||
|
int idInter = getIntent().getIntExtra("_id", -1);
|
||||||
|
|
||||||
|
// Reference TextViews
|
||||||
|
TextView etDate = findViewById(R.id.ptModifDate);
|
||||||
|
TextView etHeure = findViewById(R.id.ptModifHeure);
|
||||||
|
TextView etObservation = findViewById(R.id.ptModifObserv);
|
||||||
|
TextView etIdCli = findViewById(R.id.ptModifIdClient);
|
||||||
|
|
||||||
|
// Set data in TextViews
|
||||||
|
etDate.setText(date);
|
||||||
|
etHeure.setText(heure);
|
||||||
|
etObservation.setText(observation);
|
||||||
|
etIdCli.setText(String.valueOf(idCli));
|
||||||
|
|
||||||
|
// gestion du boutton Quitter
|
||||||
|
Button btQuitterInter = (Button) findViewById(R.id.btQuitterInter);
|
||||||
|
// Association d'un écouteur d'événement au clic de btQuitter
|
||||||
|
btQuitterInter.setOnClickListener(new View.OnClickListener() {
|
||||||
|
public void onClick(View arg0) {
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
Button btnDeleteInter = findViewById(R.id.btnDeleteInter);
|
||||||
|
Button btnModifInter = findViewById(R.id.btnModifInter);
|
||||||
|
|
||||||
|
// Accès à la table intervention
|
||||||
|
InterventionDAO interventionDAO = new InterventionDAO(this);
|
||||||
|
|
||||||
|
// Gestion de l'événement onClick sur le boutn Ajouter
|
||||||
|
btnDeleteInter.setOnClickListener(v -> {
|
||||||
|
boolean isDeleted = interventionDAO.delete(idCli);
|
||||||
|
if (isDeleted) {
|
||||||
|
Toast.makeText(this, "Client deleted successfully", Toast.LENGTH_SHORT).show();
|
||||||
|
finish();
|
||||||
|
} else {
|
||||||
|
Toast.makeText(this, "Delete failed", Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
btnModifInter.setOnClickListener(v -> {
|
||||||
|
|
||||||
|
String dateModif = etDate.getText().toString();
|
||||||
|
String heureModif = etHeure.getText().toString();
|
||||||
|
String obsModif = etObservation.getText().toString();
|
||||||
|
int idCliModif = Integer.parseInt(etIdCli.getText().toString());
|
||||||
|
|
||||||
|
boolean isUpdated = interventionDAO.update(idInter, dateModif, heureModif, obsModif, idCliModif);
|
||||||
|
if (isUpdated) {
|
||||||
|
Toast.makeText(this, "Client updated successfully", Toast.LENGTH_SHORT).show();
|
||||||
|
finish();
|
||||||
|
} else {
|
||||||
|
Toast.makeText(this, "Update failed", Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
63
DepannRien/app/src/main/java/metier/Client.java
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
package metier;
|
||||||
|
|
||||||
|
public class Client {
|
||||||
|
private int id = 0;
|
||||||
|
private String nom;
|
||||||
|
private String prenom;
|
||||||
|
private String numTel;
|
||||||
|
private String adrMail;
|
||||||
|
private String adrPostale;
|
||||||
|
|
||||||
|
public int getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNom() {
|
||||||
|
return nom;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPrenom() {
|
||||||
|
return prenom;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNumTel() {
|
||||||
|
return numTel;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getAdrMail() {
|
||||||
|
return adrMail;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getAdrPostale() {
|
||||||
|
return adrPostale;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "Client{" +
|
||||||
|
"id=" + id +
|
||||||
|
", nom='" + nom + '\'' +
|
||||||
|
", prenom='" + prenom + '\'' +
|
||||||
|
", numTel='" + numTel + '\'' +
|
||||||
|
", adrMail='" + adrMail + '\'' +
|
||||||
|
", adrPostale='" + adrPostale + '\'' +
|
||||||
|
'}';
|
||||||
|
}
|
||||||
|
|
||||||
|
public Client(int id, String nom, String prenom, String numTel, String adrMail, String adrPostale) {
|
||||||
|
this.id = id;
|
||||||
|
this.nom = nom;
|
||||||
|
this.prenom = prenom;
|
||||||
|
this.numTel = numTel;
|
||||||
|
this.adrMail = adrMail;
|
||||||
|
this.adrPostale = adrPostale;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Client(String nom, String prenom, String numTel, String adrMail, String adrPostale) {
|
||||||
|
this.nom = nom;
|
||||||
|
this.prenom = prenom;
|
||||||
|
this.numTel = numTel;
|
||||||
|
this.adrMail = adrMail;
|
||||||
|
this.adrPostale = adrPostale;
|
||||||
|
}
|
||||||
|
}
|
71
DepannRien/app/src/main/java/metier/Intervention.java
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
package metier;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.Timer;
|
||||||
|
|
||||||
|
public class Intervention {
|
||||||
|
private int id;
|
||||||
|
private String date;
|
||||||
|
private String heure;
|
||||||
|
private String observation;
|
||||||
|
private int idCli;
|
||||||
|
|
||||||
|
public Intervention(String date, String heure, String observation, int idCli) {
|
||||||
|
this.date = date;
|
||||||
|
this.heure = heure;
|
||||||
|
this.observation = observation;
|
||||||
|
this.idCli = idCli;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "Intervention{" +
|
||||||
|
"id=" + id +
|
||||||
|
"id=" + id +
|
||||||
|
", date='" + date + '\'' +
|
||||||
|
", heure='" + heure + '\'' +
|
||||||
|
", observation='" + observation + '\'' +
|
||||||
|
", idCli=" + idCli +
|
||||||
|
'}';
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(int id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDate() {
|
||||||
|
return date;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDate(String date) {
|
||||||
|
this.date = date;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getHeure() {
|
||||||
|
return heure;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setHeure(String heure) {
|
||||||
|
this.heure = heure;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getObservation() {
|
||||||
|
return observation;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setObservation(String observation) {
|
||||||
|
this.observation = observation;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getIdCli() {
|
||||||
|
return idCli;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setIdCli(int idCli) {
|
||||||
|
this.idCli = idCli;
|
||||||
|
}
|
||||||
|
}
|
170
DepannRien/app/src/main/res/drawable/ic_launcher_background.xml
Normal file
@ -0,0 +1,170 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:width="108dp"
|
||||||
|
android:height="108dp"
|
||||||
|
android:viewportWidth="108"
|
||||||
|
android:viewportHeight="108">
|
||||||
|
<path
|
||||||
|
android:fillColor="#3DDC84"
|
||||||
|
android:pathData="M0,0h108v108h-108z" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M9,0L9,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,0L19,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M29,0L29,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M39,0L39,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M49,0L49,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M59,0L59,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M69,0L69,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M79,0L79,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M89,0L89,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M99,0L99,108"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,9L108,9"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,19L108,19"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,29L108,29"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,39L108,39"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,49L108,49"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,59L108,59"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,69L108,69"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,79L108,79"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,89L108,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M0,99L108,99"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,29L89,29"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,39L89,39"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,49L89,49"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,59L89,59"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,69L89,69"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M19,79L89,79"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M29,19L29,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M39,19L39,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M49,19L49,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M59,19L59,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M69,19L69,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
<path
|
||||||
|
android:fillColor="#00000000"
|
||||||
|
android:pathData="M79,19L79,89"
|
||||||
|
android:strokeWidth="0.8"
|
||||||
|
android:strokeColor="#33FFFFFF" />
|
||||||
|
</vector>
|
@ -0,0 +1,30 @@
|
|||||||
|
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:aapt="http://schemas.android.com/aapt"
|
||||||
|
android:width="108dp"
|
||||||
|
android:height="108dp"
|
||||||
|
android:viewportWidth="108"
|
||||||
|
android:viewportHeight="108">
|
||||||
|
<path android:pathData="M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z">
|
||||||
|
<aapt:attr name="android:fillColor">
|
||||||
|
<gradient
|
||||||
|
android:endX="85.84757"
|
||||||
|
android:endY="92.4963"
|
||||||
|
android:startX="42.9492"
|
||||||
|
android:startY="49.59793"
|
||||||
|
android:type="linear">
|
||||||
|
<item
|
||||||
|
android:color="#44000000"
|
||||||
|
android:offset="0.0" />
|
||||||
|
<item
|
||||||
|
android:color="#00000000"
|
||||||
|
android:offset="1.0" />
|
||||||
|
</gradient>
|
||||||
|
</aapt:attr>
|
||||||
|
</path>
|
||||||
|
<path
|
||||||
|
android:fillColor="#FFFFFF"
|
||||||
|
android:fillType="nonZero"
|
||||||
|
android:pathData="M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z"
|
||||||
|
android:strokeWidth="1"
|
||||||
|
android:strokeColor="#00000000" />
|
||||||
|
</vector>
|
BIN
DepannRien/app/src/main/res/drawable/logodepann.png
Normal file
After Width: | Height: | Size: 488 KiB |
132
DepannRien/app/src/main/res/layout/activity_create_client.xml
Normal file
@ -0,0 +1,132 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
tools:context=".CreateClient">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<include layout="@layout/header_layout" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_margin="15sp"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvTitreCreateClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:gravity="center"
|
||||||
|
android:text="@string/libTvTitreCreateClient"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateNomClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvCreateNomClient"
|
||||||
|
android:textColor="#1976D2"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptSasirNom"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:hint="@string/libPtSaisirNomClient"
|
||||||
|
android:inputType="textPersonName"
|
||||||
|
android:minHeight="48dp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tcCreatePrenomClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvCreatePrenomClient"
|
||||||
|
android:textColor="#1976D2"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptSaisirPrenom"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:hint="@string/libPtSaisirPrenomClient"
|
||||||
|
android:inputType="textPersonName"
|
||||||
|
android:minHeight="48dp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateNumTelClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvCreateNumTelClient"
|
||||||
|
android:textColor="#1976D2"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptSaisirNumTel"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:hint="@string/libPtSaisirNumTel"
|
||||||
|
android:inputType="number"
|
||||||
|
android:minHeight="48dp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateMailClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvCreateMailClient"
|
||||||
|
android:textColor="#1976D2"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptSaisirMailClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:hint="@string/libPtSaisirMailClient"
|
||||||
|
android:inputType="textPersonName"
|
||||||
|
android:minHeight="48dp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateAdrClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvCreateAdrClient"
|
||||||
|
android:textColor="#008EFF"
|
||||||
|
android:textSize="16sp"
|
||||||
|
tools:ignore="TextContrastCheck" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptSaisirAdrClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:hint="@string/libPtSaisirAdrClient"
|
||||||
|
android:inputType="textPersonName"
|
||||||
|
android:minHeight="48dp" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btCreateClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libBtCreateClient" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btQuitterCreate"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libBtQuitter" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
97
DepannRien/app/src/main/res/layout/activity_create_inter.xml
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
tools:context=".CreateInter">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<include layout="@layout/header_layout" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_margin="15sp"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvTitreCreateInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:gravity="center"
|
||||||
|
android:text="@string/libTvTitreCreateInter"
|
||||||
|
android:textColor="#FF0000"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateIdClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Client concerné" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptSaisiIdClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="number" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateDate"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Date" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptSaisiDate"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="textPersonName" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateHeure"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Heure" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptSaisiHeure"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="textPersonName" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateObserv"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Observation" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptSaisiObserv"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="textPersonName" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btCreateInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libBtCreateClient" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btQuitterCreate"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libBtQuitter" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
</LinearLayout>
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
@ -0,0 +1,58 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
tools:context=".GestionClient">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">>
|
||||||
|
|
||||||
|
<include layout="@layout/header_layout" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvTitreInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:gravity="center"
|
||||||
|
android:text="@string/libTvGestClient"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<ListView
|
||||||
|
android:id="@+id/lvClients"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="500sp"
|
||||||
|
android:layout_margin="15sp" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btCreerInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="@string/libBtCreateClient" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btQuitterInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="@string/libBtQuitter" />
|
||||||
|
</LinearLayout>
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
@ -0,0 +1,58 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
tools:context=".GestionClient">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">>
|
||||||
|
|
||||||
|
<include layout="@layout/header_layout" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvTitreInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:gravity="center"
|
||||||
|
android:text="@string/libTvTitreInter"
|
||||||
|
android:textSize="20sp" />
|
||||||
|
|
||||||
|
<ListView
|
||||||
|
android:id="@+id/lvClients"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="500sp"
|
||||||
|
android:layout_margin="15sp" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btCreerInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="@string/libBtCreateInter" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btQuitterInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="@string/libBtQuitterInter" />
|
||||||
|
</LinearLayout>
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
48
DepannRien/app/src/main/res/layout/activity_main.xml
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:id="@+id/main"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
tools:context=".MainActivity">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<include layout="@layout/header_layout" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btGestClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libBtGestClient"
|
||||||
|
android:textColor="#FFFFFF" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btGestInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libBtGestInter"
|
||||||
|
android:textColor="#FFFFFF" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btQuitter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libBtQuitter"
|
||||||
|
android:textColor="#FFFFFF" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
<!--TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Hello World!"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent" /-->
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
115
DepannRien/app/src/main/res/layout/activity_modif_client.xml
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<include layout="@layout/header_layout" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_margin="15sp"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvModifNomClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvNomClient"
|
||||||
|
android:textColor="#1976D2"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptModifNom"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="textPersonName" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvModifPrenomClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvPrenomClient"
|
||||||
|
android:textColor="#1976D2"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptModifPrenom"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="textPersonName" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvModifNumTel"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvNumTelClient"
|
||||||
|
android:textColor="#1976D2"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptModifNumTel"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="number" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvModifAdrMail"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvMailClient"
|
||||||
|
android:textColor="#1976D2"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptModifAdrMail"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvModifAdrPostale"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libTvAdrClient"
|
||||||
|
android:textColor="#1976D2"
|
||||||
|
android:textSize="16sp" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptModifAdrPostale"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btnModifClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Modifier" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btnDeleteClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Supprimer" />
|
||||||
|
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btQuitterClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libBtQuitter" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
100
DepannRien/app/src/main/res/layout/activity_modif_inter.xml
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
tools:context=".ModifInter">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<include layout="@layout/header_layout" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_margin="15sp"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvModifIdClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Client concerné" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptModifIdClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="number" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateDate"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Date" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptModifDate"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="textPersonName" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateHeure"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Heure" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptModifHeure"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="textPersonName" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvCreateObserv"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Observation" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/ptModifObserv"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:ems="10"
|
||||||
|
android:inputType="textPersonName" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btnModifInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Modifier" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btnDeleteInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Supprimer" />
|
||||||
|
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btQuitterInter"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/libBtQuitter" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
31
DepannRien/app/src/main/res/layout/header_layout.xml
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_margin="15sp">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="center_horizontal"
|
||||||
|
android:layout_margin="20sp"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/imageView"
|
||||||
|
android:layout_width="104dp"
|
||||||
|
android:layout_height="101dp"
|
||||||
|
app:srcCompat="@drawable/logodepann" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvApp_name2"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="101sp"
|
||||||
|
android:gravity="center"
|
||||||
|
android:text="@string/app_name"
|
||||||
|
android:textSize="50sp" />
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
69
DepannRien/app/src/main/res/layout/ligne_client.xml
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvIdClient"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginRight="10sp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="@string/libTvIdClient"
|
||||||
|
android:textSize="16sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvPrenomClient"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginEnd="10sp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="@string/libTvPrenomClient"
|
||||||
|
android:textSize="16sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvNomClient"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginRight="10sp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="TextView"
|
||||||
|
android:textSize="16sp"
|
||||||
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvNumTelClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="TextView" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvAdrMailClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="TextView" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvAdrPostClient"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="TextView" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
58
DepannRien/app/src/main/res/layout/ligne_intervention.xml
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_margin="10sp">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvIdClientInterLigne"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginRight="10sp"
|
||||||
|
android:paddingRight="5sp"
|
||||||
|
android:text="ID" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvDateLigne"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginRight="10sp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:paddingRight="5sp"
|
||||||
|
android:text="Date" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvHeureLigne"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginRight="10sp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:paddingRight="5sp"
|
||||||
|
android:text="Heure" />
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvObsLigne"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="5sp"
|
||||||
|
android:text="Obs" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
</LinearLayout>
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<background android:drawable="@drawable/ic_launcher_background" />
|
||||||
|
<foreground android:drawable="@drawable/ic_launcher_foreground" />
|
||||||
|
<monochrome android:drawable="@drawable/ic_launcher_foreground" />
|
||||||
|
</adaptive-icon>
|
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<background android:drawable="@drawable/ic_launcher_background" />
|
||||||
|
<foreground android:drawable="@drawable/ic_launcher_foreground" />
|
||||||
|
<monochrome android:drawable="@drawable/ic_launcher_foreground" />
|
||||||
|
</adaptive-icon>
|
BIN
DepannRien/app/src/main/res/mipmap-hdpi/ic_launcher.webp
Normal file
After Width: | Height: | Size: 1.4 KiB |
BIN
DepannRien/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp
Normal file
After Width: | Height: | Size: 2.8 KiB |
BIN
DepannRien/app/src/main/res/mipmap-mdpi/ic_launcher.webp
Normal file
After Width: | Height: | Size: 982 B |
BIN
DepannRien/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp
Normal file
After Width: | Height: | Size: 1.7 KiB |
BIN
DepannRien/app/src/main/res/mipmap-xhdpi/ic_launcher.webp
Normal file
After Width: | Height: | Size: 1.9 KiB |
BIN
DepannRien/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp
Normal file
After Width: | Height: | Size: 3.8 KiB |
BIN
DepannRien/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp
Normal file
After Width: | Height: | Size: 2.8 KiB |
BIN
DepannRien/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp
Normal file
After Width: | Height: | Size: 5.8 KiB |
BIN
DepannRien/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp
Normal file
After Width: | Height: | Size: 3.8 KiB |
After Width: | Height: | Size: 7.6 KiB |
16
DepannRien/app/src/main/res/values-night/themes.xml
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<resources xmlns:tools="http://schemas.android.com/tools">
|
||||||
|
<!-- Base application theme. -->
|
||||||
|
<style name="Base.Theme.Depanntout" parent="Theme.Material3.DayNight.NoActionBar">
|
||||||
|
<!-- Customize your dark theme here. -->
|
||||||
|
<!-- <item name="colorPrimary">@color/my_dark_primary</item> -->
|
||||||
|
<item name="colorPrimary">@color/purple_200</item>
|
||||||
|
<item name="colorPrimaryVariant">@color/purple_700</item>
|
||||||
|
<item name="colorOnPrimary">@color/black</item>
|
||||||
|
<!-- Secondary brand color. -->
|
||||||
|
<item name="colorSecondary">@color/teal_200</item>
|
||||||
|
<item name="colorSecondaryVariant">@color/teal_200</item>
|
||||||
|
<item name="colorOnSecondary">@color/black</item>
|
||||||
|
<!-- Status bar color. -->
|
||||||
|
<item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item>
|
||||||
|
</style>
|
||||||
|
</resources>
|
10
DepannRien/app/src/main/res/values/colors.xml
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<resources>
|
||||||
|
<color name="purple_200">#FFBB86FC</color>
|
||||||
|
<color name="purple_500">#FF6200EE</color>
|
||||||
|
<color name="purple_700">#FF3700B3</color>
|
||||||
|
<color name="teal_200">#FF03DAC5</color>
|
||||||
|
<color name="teal_700">#FF018786</color>
|
||||||
|
<color name="black">#FF000000</color>
|
||||||
|
<color name="white">#FFFFFFFF</color>
|
||||||
|
</resources>
|
36
DepannRien/app/src/main/res/values/strings.xml
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
<resources>
|
||||||
|
<string name="app_name">Depanntout</string>
|
||||||
|
<string name="libTvTitre">Dépannages à domicile</string>
|
||||||
|
<string name="libBtGestClient">Gestion des clients</string>
|
||||||
|
<string name="libBtGestInter">Gestion des interventions</string>
|
||||||
|
<string name="libTvGestClient">La gestion des clients</string>
|
||||||
|
<string name="libTvIdClient">Id</string>
|
||||||
|
<string name="libTvNomClient">Nom</string>
|
||||||
|
<string name="libTvPrenomClient">Prenom</string>
|
||||||
|
<string name="libTvNumTelClient">n° Tel</string>
|
||||||
|
<string name="libTvMailClient">e-Mail</string>
|
||||||
|
<string name="libTvAdrClient">Adresse Postale</string>
|
||||||
|
<string name="libBtCréerClient">Créer Client</string>
|
||||||
|
<string name="libBtQuitter">Quitter</string>
|
||||||
|
<string name="libTvTitreCreateClient">Création d\'un client</string>
|
||||||
|
<string name="libTvCreateNomClient">Entrez le nom :</string>
|
||||||
|
<string name="libPtSaisirNomClient">Saisir le nom ici</string>
|
||||||
|
<string name="libTvCreatePrenomClient">Entrez le prénom :</string>
|
||||||
|
<string name="libPtSaisirPrenomClient">Saisir le prénom ici</string>
|
||||||
|
<string name="libTvCreateNumTelClient">Entrez le numéro de téléphone :</string>
|
||||||
|
<string name="libPtSaisirNumTel">Saisir le numéro de téléphone ici</string>
|
||||||
|
<string name="libTvCreateAdrClient">Entrez adesse postale :</string>
|
||||||
|
<string name="libPtSaisirAdrClient">Saisir adresse postale ici</string>
|
||||||
|
<string name="libTvCreateMailClient">Entrez adresse mail :</string>
|
||||||
|
<string name="libPtSaisirMailClient">Saisir adresse mail ici</string>
|
||||||
|
<string name="libBtCreateClient">Créer</string>
|
||||||
|
<string name="libTvTitreInter">Gestion des interventions</string>
|
||||||
|
<string name="libTvIdInter">id</string>
|
||||||
|
<string name="libTvDateInter">Date</string>
|
||||||
|
<string name="libTvHeureInter">Heure</string>
|
||||||
|
<string name="libTvObervInter">Observation</string>
|
||||||
|
<string name="libTvIdClientInter">Id Client</string>
|
||||||
|
<string name="libBtCreateInter">Ajouter</string>
|
||||||
|
<string name="libBtQuitterInter">Quitter</string>
|
||||||
|
<string name="libTvTitreCreateInter">Création d\'une intervention</string>
|
||||||
|
</resources>
|
19
DepannRien/app/src/main/res/values/themes.xml
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
<resources xmlns:tools="http://schemas.android.com/tools">
|
||||||
|
<!-- Base application theme. -->
|
||||||
|
<style name="Base.Theme.Depanntout" parent="Theme.Material3.DayNight.NoActionBar">
|
||||||
|
<!-- Customize your light theme here. -->
|
||||||
|
<!-- <item name="colorPrimary">@color/my_light_primary</item> -->
|
||||||
|
<!-- Primary brand color. -->
|
||||||
|
<item name="colorPrimary">@color/purple_500</item>
|
||||||
|
<item name="colorPrimaryVariant">@color/purple_700</item>
|
||||||
|
<item name="colorOnPrimary">@color/white</item>
|
||||||
|
<!-- Secondary brand color. -->
|
||||||
|
<item name="colorSecondary">@color/teal_200</item>
|
||||||
|
<item name="colorSecondaryVariant">@color/teal_700</item>
|
||||||
|
<item name="colorOnSecondary">@color/black</item>
|
||||||
|
<!-- Status bar color. -->
|
||||||
|
<item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<style name="Theme.Depanntout" parent="Base.Theme.Depanntout" />
|
||||||
|
</resources>
|
13
DepannRien/app/src/main/res/xml/backup_rules.xml
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?><!--
|
||||||
|
Sample backup rules file; uncomment and customize as necessary.
|
||||||
|
See https://developer.android.com/guide/topics/data/autobackup
|
||||||
|
for details.
|
||||||
|
Note: This file is ignored for devices older that API 31
|
||||||
|
See https://developer.android.com/about/versions/12/backup-restore
|
||||||
|
-->
|
||||||
|
<full-backup-content>
|
||||||
|
<!--
|
||||||
|
<include domain="sharedpref" path="."/>
|
||||||
|
<exclude domain="sharedpref" path="device.xml"/>
|
||||||
|
-->
|
||||||
|
</full-backup-content>
|
19
DepannRien/app/src/main/res/xml/data_extraction_rules.xml
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?><!--
|
||||||
|
Sample data extraction rules file; uncomment and customize as necessary.
|
||||||
|
See https://developer.android.com/about/versions/12/backup-restore#xml-changes
|
||||||
|
for details.
|
||||||
|
-->
|
||||||
|
<data-extraction-rules>
|
||||||
|
<cloud-backup>
|
||||||
|
<!-- TODO: Use <include> and <exclude> to control what is backed up.
|
||||||
|
<include .../>
|
||||||
|
<exclude .../>
|
||||||
|
-->
|
||||||
|
</cloud-backup>
|
||||||
|
<!--
|
||||||
|
<device-transfer>
|
||||||
|
<include .../>
|
||||||
|
<exclude .../>
|
||||||
|
</device-transfer>
|
||||||
|
-->
|
||||||
|
</data-extraction-rules>
|
@ -0,0 +1,17 @@
|
|||||||
|
package com.example.depanntout;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Example local unit test, which will execute on the development machine (host).
|
||||||
|
*
|
||||||
|
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
||||||
|
*/
|
||||||
|
public class ExampleUnitTest {
|
||||||
|
@Test
|
||||||
|
public void addition_isCorrect() {
|
||||||
|
assertEquals(4, 2 + 2);
|
||||||
|
}
|
||||||
|
}
|
4
DepannRien/build.gradle.kts
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
||||||
|
plugins {
|
||||||
|
alias(libs.plugins.android.application) apply false
|
||||||
|
}
|
21
DepannRien/gradle.properties
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# Project-wide Gradle settings.
|
||||||
|
# IDE (e.g. Android Studio) users:
|
||||||
|
# Gradle settings configured through the IDE *will override*
|
||||||
|
# any settings specified in this file.
|
||||||
|
# For more details on how to configure your build environment visit
|
||||||
|
# http://www.gradle.org/docs/current/userguide/build_environment.html
|
||||||
|
# Specifies the JVM arguments used for the daemon process.
|
||||||
|
# The setting is particularly useful for tweaking memory settings.
|
||||||
|
org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8
|
||||||
|
# When configured, Gradle will run in incubating parallel mode.
|
||||||
|
# This option should only be used with decoupled projects. For more details, visit
|
||||||
|
# https://developer.android.com/r/tools/gradle-multi-project-decoupled-projects
|
||||||
|
# org.gradle.parallel=true
|
||||||
|
# AndroidX package structure to make it clearer which packages are bundled with the
|
||||||
|
# Android operating system, and which are packaged with your app's APK
|
||||||
|
# https://developer.android.com/topic/libraries/support-library/androidx-rn
|
||||||
|
android.useAndroidX=true
|
||||||
|
# Enables namespacing of each library's R class so that its R class includes only the
|
||||||
|
# resources declared in the library itself and none from the library's dependencies,
|
||||||
|
# thereby reducing the size of the R class for that library
|
||||||
|
android.nonTransitiveRClass=true
|
22
DepannRien/gradle/libs.versions.toml
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
[versions]
|
||||||
|
agp = "8.7.2"
|
||||||
|
junit = "4.13.2"
|
||||||
|
junitVersion = "1.2.1"
|
||||||
|
espressoCore = "3.6.1"
|
||||||
|
appcompat = "1.7.0"
|
||||||
|
material = "1.12.0"
|
||||||
|
activity = "1.9.3"
|
||||||
|
constraintlayout = "2.2.0"
|
||||||
|
|
||||||
|
[libraries]
|
||||||
|
junit = { group = "junit", name = "junit", version.ref = "junit" }
|
||||||
|
ext-junit = { group = "androidx.test.ext", name = "junit", version.ref = "junitVersion" }
|
||||||
|
espresso-core = { group = "androidx.test.espresso", name = "espresso-core", version.ref = "espressoCore" }
|
||||||
|
appcompat = { group = "androidx.appcompat", name = "appcompat", version.ref = "appcompat" }
|
||||||
|
material = { group = "com.google.android.material", name = "material", version.ref = "material" }
|
||||||
|
activity = { group = "androidx.activity", name = "activity", version.ref = "activity" }
|
||||||
|
constraintlayout = { group = "androidx.constraintlayout", name = "constraintlayout", version.ref = "constraintlayout" }
|
||||||
|
|
||||||
|
[plugins]
|
||||||
|
android-application = { id = "com.android.application", version.ref = "agp" }
|
||||||
|
|
BIN
DepannRien/gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
6
DepannRien/gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#Fri Jan 03 14:15:07 CET 2025
|
||||||
|
distributionBase=GRADLE_USER_HOME
|
||||||
|
distributionPath=wrapper/dists
|
||||||
|
distributionUrl=https\://services.gradle.org/distributions/gradle-8.9-bin.zip
|
||||||
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
|
zipStorePath=wrapper/dists
|
185
DepannRien/gradlew
vendored
Normal file
@ -0,0 +1,185 @@
|
|||||||
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
|
#
|
||||||
|
# Copyright 2015 the original author or 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 UN*X
|
||||||
|
##
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
# Attempt to set APP_HOME
|
||||||
|
# Resolve links: $0 may be a link
|
||||||
|
PRG="$0"
|
||||||
|
# Need this for relative symlinks.
|
||||||
|
while [ -h "$PRG" ] ; do
|
||||||
|
ls=`ls -ld "$PRG"`
|
||||||
|
link=`expr "$ls" : '.*-> \(.*\)$'`
|
||||||
|
if expr "$link" : '/.*' > /dev/null; then
|
||||||
|
PRG="$link"
|
||||||
|
else
|
||||||
|
PRG=`dirname "$PRG"`"/$link"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
SAVED="`pwd`"
|
||||||
|
cd "`dirname \"$PRG\"`/" >/dev/null
|
||||||
|
APP_HOME="`pwd -P`"
|
||||||
|
cd "$SAVED" >/dev/null
|
||||||
|
|
||||||
|
APP_NAME="Gradle"
|
||||||
|
APP_BASE_NAME=`basename "$0"`
|
||||||
|
|
||||||
|
# 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"'
|
||||||
|
|
||||||
|
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
||||||
|
MAX_FD="maximum"
|
||||||
|
|
||||||
|
warn () {
|
||||||
|
echo "$*"
|
||||||
|
}
|
||||||
|
|
||||||
|
die () {
|
||||||
|
echo
|
||||||
|
echo "$*"
|
||||||
|
echo
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# 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
|
||||||
|
;;
|
||||||
|
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"
|
||||||
|
which java >/dev/null 2>&1 || 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
|
||||||
|
|
||||||
|
# Increase the maximum file descriptors if we can.
|
||||||
|
if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
|
||||||
|
MAX_FD_LIMIT=`ulimit -H -n`
|
||||||
|
if [ $? -eq 0 ] ; then
|
||||||
|
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
|
||||||
|
MAX_FD="$MAX_FD_LIMIT"
|
||||||
|
fi
|
||||||
|
ulimit -n $MAX_FD
|
||||||
|
if [ $? -ne 0 ] ; then
|
||||||
|
warn "Could not set maximum file descriptor limit: $MAX_FD"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# For Darwin, add options to specify how the application appears in the dock
|
||||||
|
if $darwin; then
|
||||||
|
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
|
||||||
|
fi
|
||||||
|
|
||||||
|
# For Cygwin or MSYS, switch paths to Windows format before running java
|
||||||
|
if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
|
||||||
|
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
|
||||||
|
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
|
||||||
|
|
||||||
|
JAVACMD=`cygpath --unix "$JAVACMD"`
|
||||||
|
|
||||||
|
# We build the pattern for arguments to be converted via cygpath
|
||||||
|
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
|
||||||
|
SEP=""
|
||||||
|
for dir in $ROOTDIRSRAW ; do
|
||||||
|
ROOTDIRS="$ROOTDIRS$SEP$dir"
|
||||||
|
SEP="|"
|
||||||
|
done
|
||||||
|
OURCYGPATTERN="(^($ROOTDIRS))"
|
||||||
|
# Add a user-defined pattern to the cygpath arguments
|
||||||
|
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
|
||||||
|
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
|
||||||
|
fi
|
||||||
|
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
||||||
|
i=0
|
||||||
|
for arg in "$@" ; do
|
||||||
|
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
|
||||||
|
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
|
||||||
|
|
||||||
|
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
|
||||||
|
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
|
||||||
|
else
|
||||||
|
eval `echo args$i`="\"$arg\""
|
||||||
|
fi
|
||||||
|
i=`expr $i + 1`
|
||||||
|
done
|
||||||
|
case $i in
|
||||||
|
0) set -- ;;
|
||||||
|
1) set -- "$args0" ;;
|
||||||
|
2) set -- "$args0" "$args1" ;;
|
||||||
|
3) set -- "$args0" "$args1" "$args2" ;;
|
||||||
|
4) set -- "$args0" "$args1" "$args2" "$args3" ;;
|
||||||
|
5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
|
||||||
|
6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
|
||||||
|
7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
|
||||||
|
8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
|
||||||
|
9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Escape application args
|
||||||
|
save () {
|
||||||
|
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
|
||||||
|
echo " "
|
||||||
|
}
|
||||||
|
APP_ARGS=`save "$@"`
|
||||||
|
|
||||||
|
# Collect all arguments for the java command, following the shell quoting and substitution rules
|
||||||
|
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
|
||||||
|
|
||||||
|
exec "$JAVACMD" "$@"
|
89
DepannRien/gradlew.bat
vendored
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
@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=.
|
||||||
|
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%" == "0" goto execute
|
||||||
|
|
||||||
|
echo.
|
||||||
|
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
|
echo.
|
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
echo location of your Java installation.
|
||||||
|
|
||||||
|
goto fail
|
||||||
|
|
||||||
|
:findJavaFromJavaHome
|
||||||
|
set JAVA_HOME=%JAVA_HOME:"=%
|
||||||
|
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
||||||
|
|
||||||
|
if exist "%JAVA_EXE%" goto execute
|
||||||
|
|
||||||
|
echo.
|
||||||
|
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
||||||
|
echo.
|
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
echo location of your Java installation.
|
||||||
|
|
||||||
|
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%"=="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!
|
||||||
|
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
|
||||||
|
exit /b 1
|
||||||
|
|
||||||
|
:mainEnd
|
||||||
|
if "%OS%"=="Windows_NT" endlocal
|
||||||
|
|
||||||
|
:omega
|
24
DepannRien/settings.gradle.kts
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
pluginManagement {
|
||||||
|
repositories {
|
||||||
|
google {
|
||||||
|
content {
|
||||||
|
includeGroupByRegex("com\\.android.*")
|
||||||
|
includeGroupByRegex("com\\.google.*")
|
||||||
|
includeGroupByRegex("androidx.*")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
mavenCentral()
|
||||||
|
gradlePluginPortal()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dependencyResolutionManagement {
|
||||||
|
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
|
||||||
|
repositories {
|
||||||
|
google()
|
||||||
|
mavenCentral()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
rootProject.name = "Depanntout"
|
||||||
|
include(":app")
|
||||||
|
|