diff --git a/network/.gitignore b/network/.gitignore new file mode 100644 index 0000000..c6cbe56 --- /dev/null +++ b/network/.gitignore @@ -0,0 +1,8 @@ +*.iml +.gradle +/local.properties +/.idea/workspace.xml +/.idea/libraries +.DS_Store +/build +/captures diff --git a/network/.idea/.name b/network/.idea/.name new file mode 100644 index 0000000..0bbf462 --- /dev/null +++ b/network/.idea/.name @@ -0,0 +1 @@ +WalmartAPIApp \ No newline at end of file diff --git a/network/.idea/compiler.xml b/network/.idea/compiler.xml new file mode 100644 index 0000000..96cc43e --- /dev/null +++ b/network/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/network/.idea/copyright/profiles_settings.xml b/network/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000..e7bedf3 --- /dev/null +++ b/network/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/network/.idea/gradle.xml b/network/.idea/gradle.xml new file mode 100644 index 0000000..39139a6 --- /dev/null +++ b/network/.idea/gradle.xml @@ -0,0 +1,19 @@ + + + + + + \ No newline at end of file diff --git a/network/.idea/misc.xml b/network/.idea/misc.xml new file mode 100644 index 0000000..cca2cda --- /dev/null +++ b/network/.idea/misc.xml @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1.8 + + + + + + + + \ No newline at end of file diff --git a/network/.idea/modules.xml b/network/.idea/modules.xml new file mode 100644 index 0000000..c0f9262 --- /dev/null +++ b/network/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/network/.idea/runConfigurations.xml b/network/.idea/runConfigurations.xml new file mode 100644 index 0000000..7f68460 --- /dev/null +++ b/network/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/network/.idea/vcs.xml b/network/.idea/vcs.xml new file mode 100644 index 0000000..6564d52 --- /dev/null +++ b/network/.idea/vcs.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/network/app/.gitignore b/network/app/.gitignore new file mode 100644 index 0000000..796b96d --- /dev/null +++ b/network/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/network/app/build.gradle b/network/app/build.gradle new file mode 100644 index 0000000..490df8f --- /dev/null +++ b/network/app/build.gradle @@ -0,0 +1,26 @@ +apply plugin: 'com.android.application' + +android { + compileSdkVersion 23 + buildToolsVersion "23.0.2" + + defaultConfig { + applicationId "ypsitos.walmartapiapp" + minSdkVersion 16 + targetSdkVersion 23 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } +} + +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + testCompile 'junit:junit:4.12' + compile 'com.android.support:appcompat-v7:23.1.1' +} diff --git a/network/app/proguard-rules.pro b/network/app/proguard-rules.pro new file mode 100644 index 0000000..07bb98c --- /dev/null +++ b/network/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in /Users/YPsitos/Library/Android/sdk/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# 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 *; +#} diff --git a/network/app/src/androidTest/java/ypsitos/walmartapiapp/ApplicationTest.java b/network/app/src/androidTest/java/ypsitos/walmartapiapp/ApplicationTest.java new file mode 100644 index 0000000..4bd7797 --- /dev/null +++ b/network/app/src/androidTest/java/ypsitos/walmartapiapp/ApplicationTest.java @@ -0,0 +1,13 @@ +package ypsitos.walmartapiapp; + +import android.app.Application; +import android.test.ApplicationTestCase; + +/** + * Testing Fundamentals + */ +public class ApplicationTest extends ApplicationTestCase { + public ApplicationTest() { + super(Application.class); + } +} \ No newline at end of file diff --git a/network/app/src/main/AndroidManifest.xml b/network/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..fc34480 --- /dev/null +++ b/network/app/src/main/AndroidManifest.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + diff --git a/network/app/src/main/java/ypsitos/walmartapiapp/MainActivity.java b/network/app/src/main/java/ypsitos/walmartapiapp/MainActivity.java new file mode 100644 index 0000000..e6237f0 --- /dev/null +++ b/network/app/src/main/java/ypsitos/walmartapiapp/MainActivity.java @@ -0,0 +1,146 @@ +package ypsitos.walmartapiapp; + +import android.os.AsyncTask; +import android.support.v7.app.AppCompatActivity; +import android.os.Bundle; +import android.support.v7.widget.Toolbar; +import android.view.View; +import android.widget.ArrayAdapter; +import android.widget.Button; +import android.widget.ListView; + +import org.json.JSONArray; +import org.json.JSONException; +import org.json.JSONObject; + +import java.io.BufferedReader; +import java.io.IOException; +import java.io.InputStream; +import java.io.InputStreamReader; +import java.net.HttpURLConnection; +import java.net.MalformedURLException; +import java.net.URL; +import java.util.ArrayList; + +public class MainActivity extends AppCompatActivity { + Button mTeaButton; + Button mChocolateButton; + Button mCerealButton; + URL mTeaUrl; + URL mChocolateUrl; + URL mCerealUrl; + ListView mListView; + ArrayList mStringArray; + ArrayAdapter mAdapter; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_main); + try { + mTeaUrl = new URL("http://api.walmartlabs.com/v1/search?query=tea&format=json&apiKey=8u2tky93nyckurd5txzkqec4"); + mChocolateUrl = new URL("http://api.walmartlabs.com/v1/search?query=chocolate&format=json&apiKey=8u2tky93nyckurd5txzkqec4"); + mCerealUrl = new URL("http://api.walmartlabs.com/v1/search?query=cereal&format=json&apiKey=8u2tky93nyckurd5txzkqec4"); + } catch (MalformedURLException e) { + e.printStackTrace(); + } + + mTeaButton = (Button)findViewById(R.id.teaButton); + mTeaButton.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + WalmartTask walmartTask = new WalmartTask(); + walmartTask.execute(mTeaUrl.toString()); + } + }); + + + mChocolateButton = (Button)findViewById(R.id.chocolateButton); + mChocolateButton.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + WalmartTask walmartTask = new WalmartTask(); + walmartTask.execute(mChocolateUrl.toString()); + } + }); + + mCerealButton = (Button)findViewById(R.id.cerealButton); + mCerealButton.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + WalmartTask walmartTask = new WalmartTask(); + walmartTask.execute(mCerealUrl.toString()); + } + }); + + ArrayList mStringArray; + ArrayAdapter mAdapter; + + mStringArray = new ArrayList(); + ​ + mListView = (ListView) findViewById(R.id.listView1); + mAdapter = new ArrayAdapter(this, android.R.layout.simple_list_item_1, mStringArray); + mListView.setAdapter(mAdapter); + } + ​ + private String getInputData(InputStream inStream) throws IOException { + StringBuilder builder = new StringBuilder(); + BufferedReader reader = new BufferedReader( new InputStreamReader(inStream)); + ​ + String data; + ​ + while ((data = reader.readLine()) != null){ + builder.append(data); + } + ​ + reader.close(); + ​ + return builder.toString(); + } + ​ + public class WalmartTask extends AsyncTask{ + @Override + protected String doInBackground(String... urls) { + String data = ""; + try { + URL url = new URL(urls[0]); + HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + connection.connect(); + ​ + InputStream inStream = connection.getInputStream(); + ​ + data = getInputData(inStream); + ​ + } catch (Throwable thr) { + thr.printStackTrace(); + } + + try { + JSONObject dataObject = new JSONObject(data); + ​ + JSONArray itemJsonArray = dataObject.getJSONArray("name"); + ​ + mStringArray.clear(); + ​ + for (int i = 0; i < itemJsonArray.length(); i++){ + JSONObject object = itemJsonArray.optJSONObject(i); + String name = object.optString("name"); + ​ + mStringArray.add(name); + } + ​ + } catch (JSONException e) { + e.printStackTrace(); + } + ​ + ​ + return data; + }​ + @Override + protected void onPostExecute(String data) { + super.onPostExecute(data); + ​ + mAdapter.notifyDataSetChanged(); + } + } + ​} diff --git a/network/app/src/main/res/layout/activity_main.xml b/network/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000..1f89433 --- /dev/null +++ b/network/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,43 @@ + + + + +