added IITC version info to settings
This commit is contained in:
parent
3a8ea9161b
commit
0e298c3526
@ -2,7 +2,7 @@
|
|||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
package="com.cradle.iitc_mobile"
|
package="com.cradle.iitc_mobile"
|
||||||
android:versionCode="1"
|
android:versionCode="1"
|
||||||
android:versionName="0.2.4" >
|
android:versionName="0.2.5" >
|
||||||
|
|
||||||
<uses-sdk
|
<uses-sdk
|
||||||
android:minSdkVersion="14"
|
android:minSdkVersion="14"
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
<string name="locate">Get Location</string>
|
<string name="locate">Get Location</string>
|
||||||
<string name="local">local</string>
|
<string name="local">local</string>
|
||||||
<string name="build_version">Build Version</string>
|
<string name="build_version">Build Version</string>
|
||||||
|
<string name="iitc_version">IITC Version</string>
|
||||||
|
|
||||||
<string name="pref_force_desktop">Force desktop mode</string>
|
<string name="pref_force_desktop">Force desktop mode</string>
|
||||||
<string name="pref_force_desktop_sum">Nice for tablets, looks awful on smartphones</string>
|
<string name="pref_force_desktop_sum">Nice for tablets, looks awful on smartphones</string>
|
||||||
|
@ -21,5 +21,11 @@
|
|||||||
android:title="@string/build_version"
|
android:title="@string/build_version"
|
||||||
android:enabled="false"
|
android:enabled="false"
|
||||||
android:selectable="false" />
|
android:selectable="false" />
|
||||||
|
|
||||||
|
<ListPreference
|
||||||
|
android:key="pref_iitc_version"
|
||||||
|
android:title="@string/iitc_version"
|
||||||
|
android:enabled="false"
|
||||||
|
android:selectable="false" />
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
@ -128,7 +128,9 @@ public class IITC_Mobile extends Activity {
|
|||||||
iitc_view.loadUrl("javascript: window.map.locate({setView : true, maxZoom: 13});");
|
iitc_view.loadUrl("javascript: window.map.locate({setView : true, maxZoom: 13});");
|
||||||
return true;
|
return true;
|
||||||
case R.id.settings:
|
case R.id.settings:
|
||||||
startActivity(new Intent(this, IITC_Settings.class));
|
Intent intent = new Intent(this, IITC_Settings.class);
|
||||||
|
intent.putExtra("iitc_version", iitc_view.getWebViewClient().getIITCVersion());
|
||||||
|
startActivity(intent);
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
return super.onOptionsItemSelected(item);
|
return super.onOptionsItemSelected(item);
|
||||||
|
@ -4,13 +4,17 @@ import android.app.Activity;
|
|||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
|
||||||
public class IITC_Settings extends Activity {
|
public class IITC_Settings extends Activity {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
|
IITC_SettingsFragment settings = new IITC_SettingsFragment();
|
||||||
|
settings.setArguments(getIntent().getExtras());
|
||||||
|
|
||||||
// Display the fragment as the main content.
|
// Display the fragment as the main content.
|
||||||
getFragmentManager().beginTransaction()
|
getFragmentManager().beginTransaction()
|
||||||
.replace(android.R.id.content, new IITC_SettingsFragment())
|
.replace(android.R.id.content, settings)
|
||||||
.commit();
|
.commit();
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -11,12 +11,15 @@ import android.preference.Preference.OnPreferenceChangeListener;
|
|||||||
import android.preference.PreferenceFragment;
|
import android.preference.PreferenceFragment;
|
||||||
|
|
||||||
public class IITC_SettingsFragment extends PreferenceFragment {
|
public class IITC_SettingsFragment extends PreferenceFragment {
|
||||||
|
|
||||||
|
String iitc_version;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
|
iitc_version = getArguments().getString("iitc_version");
|
||||||
|
|
||||||
addPreferencesFromResource(R.xml.preferences);
|
addPreferencesFromResource(R.xml.preferences);
|
||||||
|
|
||||||
// set build version
|
// set build version
|
||||||
@ -28,15 +31,21 @@ public class IITC_SettingsFragment extends PreferenceFragment {
|
|||||||
version = info.versionName;
|
version = info.versionName;
|
||||||
}
|
}
|
||||||
catch (NameNotFoundException e) {
|
catch (NameNotFoundException e) {
|
||||||
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
pref_build_version.setSummary(version);
|
pref_build_version.setSummary(version);
|
||||||
|
|
||||||
|
// set iitc version
|
||||||
|
ListPreference pref_iitc_version = (ListPreference) findPreference("pref_iitc_version");
|
||||||
|
pref_iitc_version.setSummary(iitc_version);
|
||||||
|
|
||||||
// set iitc source
|
// set iitc source
|
||||||
EditTextPreference pref_iitc_source = (EditTextPreference) findPreference("pref_iitc_source");
|
EditTextPreference pref_iitc_source = (EditTextPreference) findPreference("pref_iitc_source");
|
||||||
pref_iitc_source.setOnPreferenceChangeListener(new OnPreferenceChangeListener() {
|
pref_iitc_source.setOnPreferenceChangeListener(new OnPreferenceChangeListener() {
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
preference.setSummary((CharSequence) newValue);
|
preference.setSummary((CharSequence) newValue);
|
||||||
|
// TODO: update iitc_version when iitc source has changed
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -21,6 +21,7 @@ public class IITC_WebViewClient extends WebViewClient {
|
|||||||
private static final ByteArrayInputStream empty = new ByteArrayInputStream("".getBytes());
|
private static final ByteArrayInputStream empty = new ByteArrayInputStream("".getBytes());
|
||||||
|
|
||||||
private WebResourceResponse iitcjs;
|
private WebResourceResponse iitcjs;
|
||||||
|
private String js = null;
|
||||||
|
|
||||||
public IITC_WebViewClient(Context c) {
|
public IITC_WebViewClient(Context c) {
|
||||||
try {
|
try {
|
||||||
@ -30,6 +31,20 @@ public class IITC_WebViewClient extends WebViewClient {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getIITCVersion() {
|
||||||
|
String header = js.substring(js.indexOf("==UserScript=="), js.indexOf("==/UserScript=="));
|
||||||
|
// remove new line comments
|
||||||
|
header = header.replace("\n//", "");
|
||||||
|
// get a list of key-value
|
||||||
|
String[] attributes = header.split(" +");
|
||||||
|
String iitc_version = "not found";
|
||||||
|
for (int i = 0; i < attributes.length; i++) {
|
||||||
|
// search vor version and use the value
|
||||||
|
if (attributes[i].contains("@version")) iitc_version = attributes[i+1];
|
||||||
|
}
|
||||||
|
return iitc_version;
|
||||||
|
}
|
||||||
|
|
||||||
public void loadIITC_JS(Context c) throws java.io.IOException {
|
public void loadIITC_JS(Context c) throws java.io.IOException {
|
||||||
// in developer options, you are able to load the script from external source
|
// in developer options, you are able to load the script from external source
|
||||||
// if a http address is given, use script from this address. else use the local script
|
// if a http address is given, use script from this address. else use the local script
|
||||||
@ -49,6 +64,8 @@ public class IITC_WebViewClient extends WebViewClient {
|
|||||||
js = new String(buffer);
|
js = new String(buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.js = js;
|
||||||
|
|
||||||
// need to wrap the mobile iitc.js version in a document ready. IITC
|
// need to wrap the mobile iitc.js version in a document ready. IITC
|
||||||
// expects to be injected after the DOM has been loaded completely.
|
// expects to be injected after the DOM has been loaded completely.
|
||||||
// Since the mobile client injects IITC by replacing the gen_dashboard
|
// Since the mobile client injects IITC by replacing the gen_dashboard
|
||||||
|
Loading…
x
Reference in New Issue
Block a user