The simple solution to querying for ShopGun data.
If you haven't already added jCenter
to your build.gradle
, you'll need this:
repositories {
jcenter()
}
Now add these lines to your module's build.gradle
:
dependencies {
compile 'com.shopgun.android:sdk:3.2.2'
}
or clone from github, and add this to your project's settings.gradle
:
include ':shopGunSdk'
project(':shopGunSdk').projectDir=new File('/path/to/shopgun-android-sdk/shopGunSdk')
You will need to get an API key and API secret from our ShopGun Developer site (look for "My Apps")
If you wish to try our demo app, just clone and run it. We've included an API key and secret, that will work straight out of the box. But the key only provides a limited amount of quereis pr day so don't use it in production.
We need certain permissions, to make the whole thing run:
<!-- Obviously we'll need internet -->
<uses-permission android:name="android.permission.INTERNET"/>
<!-- Check for connectivity, prior to performing shoppinglist synchronization -->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
Now add the ApiKey and ApiSecret, you obtained in API key and secret section.
<application android:label="@string/app_name" ...>
...
<meta-data android:name="com.shopgun.android.sdk.api_key"
android:value="your_shopgun_sdk_api_key"/>
<meta-data android:name="com.shopgun.android.sdk.api_secret"
android:value="your_shopgun_sdk_api_secret"/>
<meta-data android:name="com.shopgun.android.sdk.develop.api_key"
android:value="your_shopgun_sdk_api_key_debug"/>
<meta-data android:name="com.shopgun.android.sdk.develop.api_secret"
android:value="your_shopgun_sdk_api_secret_debug"/>
...
</application>
By default you can call ShopGun.getInstance(Context)
and we will set everything up for you, no worries. But if you want to custimize your experience, you can use the ShopGun.Builder
to do so. Before you call ShopGun.getInstance(Context)
for the very first time, just create a new Builder
setit up, and call Builder.build()
. See the example below.
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (!ShopGun.hasInstance()) {
// The builder will automatically attach the ShopGun singleton.
new ShopGun.Builder(Activity.this)
.setDevelop(BuildConfig.DEBUG)
.build();
}
}
further more, we'll need to know when your Activity
performs onStart()
and
onStop()
, in order to perform certain synchronization steps.
@Override
protected void onStart() {
ShopGun.getInstance(Activity.this).onStart();
super.onStart();
}
@Override
protected void onStop() {
super.onStop();
ShopGun.getInstance(Activity.this).onStop();
}
We are very keen on delivering content close to the user, therefore we'll need to know their location.
// ShopGun Headquater (Copenhagen), and radius 100km
SgnLocation loc = ShopGun.getInstance().getLocation();
loc.setLatitude(55.6310771f);
loc.setLongitude(12.5771624f);
loc.setRadius(100000);
loc.setSensor(false);
Typically you'll hook into LocationManager to get the device location, rather than hardcode it ;-)
Let's try to get a list of catalogs.
// The callback interface
LoaderRequest.Listener<List<Catalog>> catalogListener = new LoaderRequest.Listener<List<Catalog>>() {
@Override
public void onRequestComplete(List<Catalog> response, List<ShopGunError> errors) {
if (errors.isEmpty()) {
// Hurray it's a successful request!
} else {
// Whh something went wrong
}
}
@Override
public void onRequestIntermediate(List<Catalog> response, List<ShopGunError> errors) {
// Do intermediate update of UI, or other actions needed.
if (errors.isEmpty()) {
// Hurray it's a successful request!
} else {
// Whh something went wrong
}
}
};
// The request
CatalogListRequest request = new CatalogListRequest(catalogListener);
// Add the request to the request queue
ShopGun.getInstance().add(request);
That's it, you've performed your first request to our ShopGun API :-)
For more exampels, please have a look at the ShopGun SDK Demo. There you can find some common usecases for the SDK. It's bundled with the SDK.
If you have any feedback, then please feel free to let us know. Issues and suggestions can be submitted via GitHub issues. Comments can be emailed to me at [email protected]
If you would like to contribute to the ShopGun Android SDK, feel free to do so. Just fork the repository on GitHub, and send us a pull request.
Please try to follow existing code convention and style, when committing code.
Copyright 2015 ShopGun
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
http://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.