Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 15 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -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 changes: 3 additions & 0 deletions .idea/.gitignore

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 6 additions & 0 deletions .idea/compiler.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

22 changes: 22 additions & 0 deletions .idea/gradle.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

25 changes: 25 additions & 0 deletions .idea/jarRepositories.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

9 changes: 9 additions & 0 deletions .idea/misc.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 6 additions & 0 deletions .idea/vcs.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

10 changes: 5 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,9 @@ http://docs.starwarsfavorites.apiary.io/#

### Lista de Personagens

Para obter os personagens, sua aplicação deverá utilizar o recurso `people` da Swapi (documentação disponível no topo do documento). A aplicação deve exibir todos os 87 personagens e permitir pesquisar o personagem pelo nome. Sugerimos exibir as primeiras páginas enquanto carrega as outras, em um formato de scroll infinito.
Para obter os personagens, sua aplicação deverá utilizar o recurso `people` da Swapi (documentação disponível no topo do documento). A aplicação deve exibir todos os 87 personagens e permitir pesquisar o personagem pelo nome. Sugerimos exibir as primeiras páginas enquanto carrega as outras, em um formato de scroll infinito.

A lista de itens deve exibir as seguintes informações:
A lista de itens deve exibir as seguintes informações:
+ Nome [name]
+ Altura [height]
+ Genero [gender]
Expand All @@ -24,7 +24,7 @@ Os dados devem ser salvos em banco de dados local para acesso offline e atualiza

### Detalhes do Personagem

Ao clicar em um item da lista o seu app deve mostrar as informações abaixo:
Ao clicar em um item da lista o seu app deve mostrar as informações abaixo:

+ name
+ height
Expand All @@ -41,7 +41,7 @@ A busca pelo nome do planeta e da espécie deve ser feita em paralelo.

### Favoritos

Na lista e nos detalhes deve ser possível adicionar e remover um personagem a sua lista de favoritos. Tambem deve ser possível filtrar quais personagens foram favoritados na lista principal.
Na lista e nos detalhes deve ser possível adicionar e remover um personagem a sua lista de favoritos. Tambem deve ser possível filtrar quais personagens foram favoritados na lista principal.

##### Adição e Remoção de Favoritos

Expand All @@ -56,7 +56,7 @@ A aplicação deve:

Em metade das requisições enviadas para a api starwarsfavorites a aplicação deve adicionar o header `Prefer` com o valor `status=400`.

P.S.: O candidato deve escolher o ID.
P.S.: O candidato deve escolher o ID.

---
#### LICENSE
Expand Down
1 change: 1 addition & 0 deletions app/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
/build
41 changes: 41 additions & 0 deletions app/build.gradle
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
plugins {
id 'com.android.application'
}

android {
compileSdkVersion 29

defaultConfig {
applicationId "com.example.desafiopopcode"
minSdkVersion 16
targetSdkVersion 29
versionCode 1
versionName "1.0"

testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}

buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}

dependencies {

implementation 'androidx.appcompat:appcompat:1.2.0'
implementation 'com.google.android.material:material:1.2.1'
implementation 'androidx.constraintlayout:constraintlayout:2.0.4'
testImplementation 'junit:junit:4.+'
androidTestImplementation 'androidx.test.ext:junit:1.1.2'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0'
implementation 'com.squareup.retrofit:retrofit:1.8.0'
implementation 'com.squareup.okhttp:okhttp:2.1.0'
implementation 'com.squareup.okhttp:okhttp-urlconnection:2.1.0'
}
21 changes: 21 additions & 0 deletions app/proguard-rules.pro
Original file line number Diff line number Diff line change
@@ -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
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
package com.example.desafiopopcode;

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.desafiopopcode", appContext.getPackageName());
}
}
25 changes: 25 additions & 0 deletions app/src/main/AndroidManifest.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.desafiopopcode">

<uses-permission android:name="android.permission.INTERNET" />

<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.Desafiopopcode">
<activity android:name=".Favs"></activity>
<activity android:name=".Detalhes" />
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>

</manifest>
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
package com.example.desafiopopcode.Controllers;

import retrofit.RestAdapter;

public class FavApi {

private FavController fav;
private static FavApi Instance;

private FavApi() {
final RestAdapter restAdapter = new RestAdapter.Builder()
.setClient(new SWClient())
.setEndpoint("https://private-782d3-starwarsfavorites.apiary-mock.com/")
.setLogLevel(RestAdapter.LogLevel.FULL)
.build();
fav = restAdapter.create(FavController.class);
}

public static void init() {
Instance = new FavApi();
}

public static FavController getApi() {
return Instance.fav;
}

public void setApi(FavController favApi) {
Instance.fav = favApi;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
package com.example.desafiopopcode.Controllers;

import android.os.Build;
import retrofit.client.OkClient;
import retrofit.client.Request;

import java.io.IOException;
import java.net.HttpURLConnection;

public class FavClient extends OkClient {

public FavClient() {
super();
}

@Override
protected HttpURLConnection openConnection(Request request) throws IOException {
HttpURLConnection connection = super.openConnection(request);
connection.setRequestProperty("User-Agent", "starwarsfavorites-android-" + Build.VERSION.RELEASE);
return connection;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package com.example.desafiopopcode.Controllers;

import com.example.desafiopopcode.Models.Personagem;

import retrofit.Callback;
import retrofit.http.POST;
import retrofit.http.Path;

public interface FavController {

@POST("/favorite/{id}")
public void favPerson(@Path("id") int id, Callback<Personagem> callback);

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
package com.example.desafiopopcode.Controllers;

import retrofit.RestAdapter;

public class SWApi {

private SWWiki sw;
private static SWApi Instance;

private SWApi() {
final RestAdapter restAdapter = new RestAdapter.Builder()
.setClient(new SWClient())
.setEndpoint("https://swapi.dev/api/")
.setLogLevel(RestAdapter.LogLevel.FULL)
.build();
sw = restAdapter.create(SWWiki.class);
}

public static void init() {
Instance = new SWApi();
}

public static SWWiki getApi() {
return Instance.sw;
}

public void setApi(SWWiki swApi) {
Instance.sw = swApi;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
package com.example.desafiopopcode.Controllers;

import android.os.Build;
import retrofit.client.OkClient;
import retrofit.client.Request;

import java.io.IOException;
import java.net.HttpURLConnection;

public class SWClient extends OkClient {

public SWClient() {
super();
}

@Override
protected HttpURLConnection openConnection(Request request) throws IOException {
HttpURLConnection connection = super.openConnection(request);
connection.setRequestProperty("User-Agent", "swapi-android-" + Build.VERSION.RELEASE);
return connection;
}
}
Loading