Commons app mirror
Find a file
2017-03-21 12:08:27 +03:00
app Remove duplicates 2017-03-21 12:08:27 +03:00
assets-source Added new launcher icons 2013-07-18 17:27:51 +00:00
design Material design logo, screenshots 2016-06-21 21:31:59 +09:00
gradle/wrapper Merged, Resolve merge conflicts 2017-03-13 23:06:42 +05:30
script/style Added support for butterknife library for view bindings 2017-03-21 00:04:32 +05:30
update-license-info Merge "commons" into the project root directory 2016-07-02 16:48:57 +09:00
.gitignore Merge "commons" into the project root directory 2016-07-02 16:48:57 +09:00
.gitreview Add .gitreview 2013-06-17 10:44:28 +00:00
.travis.yml Update .travis.yml 2017-03-12 15:47:13 +00:00
build.gradle Use gradle constants and update GSON 2017-03-12 15:52:49 +00:00
CHANGELOG.md Update changelog.md, remove beta 2017-03-13 03:44:25 +10:00
COPYING Relicense to Apache License 2013-04-23 21:16:43 +05:30
CREDITS Update credits.md 2017-03-19 09:56:39 +10:00
find-broken-strings-variables.sh Updated path 2016-10-26 19:56:49 +09:00
gradle.properties Added support for butterknife library for view bindings 2017-03-21 00:04:32 +05:30
gradlew Merge "commons" into the project root directory 2016-07-02 16:48:57 +09:00
gradlew.bat Merge "commons" into the project root directory 2016-07-02 16:48:57 +09:00
README.md Add two buttons to get the app 2017-03-12 13:18:21 +01:00
RELEASE-CHECKLIST.md Update RELEASE-CHECKLIST 2013-04-27 00:58:19 +05:30
ruleset.xml Add PMD settings 2017-03-18 17:16:02 +09:00
settings.gradle Merge "commons" into the project root directory 2016-07-02 16:48:57 +09:00
sign.sh Prepare for Google Play release 2015-09-08 10:10:04 +09:00
upload-to-commons.patch Migrate event logging to www.wikimedia.org/beacon 2016-08-03 15:00:09 -07:00

Wikimedia Commons Android app Build status

The Wikimedia Commons Android app allows users to upload pictures from their Android phone/tablet to Wikimedia Commons. Download the app here, or view our website.

Initially started by the Wikimedia Foundation, this app is now maintained by volunteers. Anyone is welcome to improve it, just choose among the open issues and send us a pull request :-)

Get it on F-Droid Get it on Google Play

Develop with Android Studio or IntelliJ

Download Android Studio (recommended) or IntelliJ.

  1. Open Android Studio/IntelliJ. Open the project: File > New > Project from Version Control... > Git
    or
    (From Quick Start menu): Check out project from Version Control
  2. Enter https://github.com/commons-app/apps-android-commons/ as Git Repository URL. Specify a (new) local directory you would like to clone into and select OK.

Build Manually

Requirements

  1. Java SDK 8 (OpenJDK 8 or Oracle Java SE 8)
  2. Android SDK (Level 23)
  3. Gradle

Build Instructions

  1. Set the environment variable ANDROID_HOME to be the path to your Android SDK
  2. Set the environment variable JAVA_HOME to the path to your Java SDK
  3. Run gradlew.bat assembleDebug (Windows) or ./gradlew assembleDebug (Mac / Linux) to build an unisgned apk
  4. Alternatively, you can also connect your Android device via USB and install the app on it directly by running gradlew.bat installDebug (Windows) or ./gradlew installDebug (Mac / Linux)

There are more thorough instructions on the Android Developers website

License

This software is open source, licensed under the Apache License 2.0.

Code Structure

Key breakdowns:

Activities started within the UI:

  • ContributionsActivity (ContributionsListFragment, MediaDetailPagerFragment, MediaDetailFragment) - main "my uploads" list and detail view
  • LoginActivity - login screen when setting up an account
  • SettingsActivity - settings screen
  • AboutActivity - about screen

Activities receiving intents:

  • ShareActivity (SingleUploadFragment, CategorizationFragment) - handles receiving a file from another app, accepting a title/desc, and slating it for upload
  • MultipleShareActivity (MultipleUploadListFragment, CategorizationFragment) - handles receiving a batch of multiple files from another app, accepting a title/desc, and slating them for upload

Services:

  • WikiAccountAuthenticatorService - authentication service
  • UploadService - performs actual file uploads in background
  • ContributionsSyncService - polls for updated contributions list from server
  • ModificationsSyncService - pushes category additions up to server

Content providers:

  • ContributionsContentProvider - private storage for local copy of user's contribution list
  • ModificationsContentProvider - private storage for pending category and template modifications
  • CategoryContentProvider - private storage for recently used categories

On-Device Storage

Account credentials are encapsulated in an account provider. Currently only one Wikimedia Commons account is supported at a time. (Question: what is the actual storage for credentials?)

Preferences are stored in Android's SharedPreferences.

Information about past and pending uploads is stored in the Contributions content provider, which uses an SQLite database on the backend.

A list of recently-used categories is stored in the Categories content provider, which uses an SQLite database on the backend.

Captured files are not currently stored within the app, but are passed by content: or file: URI from other apps.

Thumbnail images are not currently cached.