mirror of
https://framagit.org/tom79/nitterizeme
synced 2025-01-31 17:44:58 +01:00
Fix #3 - Support Bibliogram
This commit is contained in:
parent
5b07f5edc0
commit
10ced0b09c
@ -101,7 +101,7 @@ public class MainActivity extends AppCompatActivity {
|
|||||||
Objects.requireNonNull(getSupportActionBar()).setDisplayShowHomeEnabled(true);
|
Objects.requireNonNull(getSupportActionBar()).setDisplayShowHomeEnabled(true);
|
||||||
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
|
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
|
||||||
|
|
||||||
domains = new String[twitter_domains.length + youtube_domains.length + shortener_domains.length];
|
domains = new String[twitter_domains.length + youtube_domains.length + shortener_domains.length + instagram_domains.length];
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (String host : twitter_domains) {
|
for (String host : twitter_domains) {
|
||||||
domains[i] = host;
|
domains[i] = host;
|
||||||
|
@ -44,8 +44,10 @@ import java.util.Objects;
|
|||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
import static app.fedilab.nitterizeme.MainActivity.SET_BIBLIOGRAM_ENABLED;
|
||||||
import static app.fedilab.nitterizeme.MainActivity.SET_INVIDIOUS_ENABLED;
|
import static app.fedilab.nitterizeme.MainActivity.SET_INVIDIOUS_ENABLED;
|
||||||
import static app.fedilab.nitterizeme.MainActivity.SET_NITTER_ENABLED;
|
import static app.fedilab.nitterizeme.MainActivity.SET_NITTER_ENABLED;
|
||||||
|
import static app.fedilab.nitterizeme.MainActivity.instagram_domains;
|
||||||
import static app.fedilab.nitterizeme.MainActivity.shortener_domains;
|
import static app.fedilab.nitterizeme.MainActivity.shortener_domains;
|
||||||
import static app.fedilab.nitterizeme.MainActivity.twitter_domains;
|
import static app.fedilab.nitterizeme.MainActivity.twitter_domains;
|
||||||
import static app.fedilab.nitterizeme.MainActivity.youtube_domains;
|
import static app.fedilab.nitterizeme.MainActivity.youtube_domains;
|
||||||
@ -56,6 +58,7 @@ public class TransformActivity extends Activity {
|
|||||||
|
|
||||||
final Pattern youtubePattern = Pattern.compile("(www\\.|m\\.)?(youtube\\.com|youtu\\.be|youtube-nocookie\\.com)/(((?!([\"'<])).)*)");
|
final Pattern youtubePattern = Pattern.compile("(www\\.|m\\.)?(youtube\\.com|youtu\\.be|youtube-nocookie\\.com)/(((?!([\"'<])).)*)");
|
||||||
final Pattern nitterPattern = Pattern.compile("(mobile\\.|www\\.)?twitter.com([\\w-/]+)");
|
final Pattern nitterPattern = Pattern.compile("(mobile\\.|www\\.)?twitter.com([\\w-/]+)");
|
||||||
|
final Pattern bibliogramPattern = Pattern.compile("(m\\.|www\\.)?instagram.com([\\w-/]+)");
|
||||||
final Pattern maps = Pattern.compile("/maps/place/[^@]+@([\\d.,z]{3,}).*");
|
final Pattern maps = Pattern.compile("/maps/place/[^@]+@([\\d.,z]{3,}).*");
|
||||||
final Pattern extractPlace = Pattern.compile("/maps/place/(((?!/data).)*)");
|
final Pattern extractPlace = Pattern.compile("/maps/place/(((?!/data).)*)");
|
||||||
private Thread thread;
|
private Thread thread;
|
||||||
@ -226,6 +229,24 @@ public class TransformActivity extends Activity {
|
|||||||
} else {
|
} else {
|
||||||
forwardToBrowser(intent);
|
forwardToBrowser(intent);
|
||||||
}
|
}
|
||||||
|
} //Instagram URLs
|
||||||
|
else if (Arrays.asList(instagram_domains).contains(host)) {
|
||||||
|
boolean bibliogram_enabled = sharedpreferences.getBoolean(SET_BIBLIOGRAM_ENABLED, true);
|
||||||
|
if (bibliogram_enabled) {
|
||||||
|
Intent delegate = new Intent(Intent.ACTION_VIEW);
|
||||||
|
String transformedURL = transformUrl(url);
|
||||||
|
if (transformedURL != null) {
|
||||||
|
delegate.setData(Uri.parse(transformUrl(url)));
|
||||||
|
delegate.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
||||||
|
if (delegate.resolveActivity(getPackageManager()) != null) {
|
||||||
|
startActivity(delegate);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
forwardToBrowser(intent);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
forwardToBrowser(intent);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
//Maps URLs (containing /maps/place like Google Maps links)
|
//Maps URLs (containing /maps/place like Google Maps links)
|
||||||
else if (url.contains("/maps/place")) {
|
else if (url.contains("/maps/place")) {
|
||||||
@ -345,6 +366,19 @@ public class TransformActivity extends Activity {
|
|||||||
} else {
|
} else {
|
||||||
return url;
|
return url;
|
||||||
}
|
}
|
||||||
|
}else if (Arrays.asList(instagram_domains).contains(host)) {
|
||||||
|
boolean bibliogram_enabled = sharedpreferences.getBoolean(SET_BIBLIOGRAM_ENABLED, true);
|
||||||
|
if (bibliogram_enabled) {
|
||||||
|
Matcher matcher = bibliogramPattern.matcher(url);
|
||||||
|
while (matcher.find()) {
|
||||||
|
final String bibliogram_directory = matcher.group(2);
|
||||||
|
String bibliogramHost = sharedpreferences.getString(MainActivity.SET_BIBLIOGRAM_HOST, MainActivity.DEFAULT_BIBLIOGRAM_HOST).toLowerCase();
|
||||||
|
newUrl = "https://" + bibliogramHost + bibliogram_directory;
|
||||||
|
}
|
||||||
|
return newUrl;
|
||||||
|
} else {
|
||||||
|
return url;
|
||||||
|
}
|
||||||
} else if (url.contains("/maps/place")) {
|
} else if (url.contains("/maps/place")) {
|
||||||
boolean osm_enabled = sharedpreferences.getBoolean(MainActivity.SET_OSM_ENABLED, true);
|
boolean osm_enabled = sharedpreferences.getBoolean(MainActivity.SET_OSM_ENABLED, true);
|
||||||
if (osm_enabled) {
|
if (osm_enabled) {
|
||||||
@ -455,6 +489,16 @@ public class TransformActivity extends Activity {
|
|||||||
newUrl = "https://" + nitterHost + nitter_directory;
|
newUrl = "https://" + nitterHost + nitter_directory;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if (Arrays.asList(instagram_domains).contains(host)) {
|
||||||
|
boolean bibliogram_enabled = sharedpreferences.getBoolean(SET_BIBLIOGRAM_ENABLED, true);
|
||||||
|
if (bibliogram_enabled) {
|
||||||
|
Matcher matcher = bibliogramPattern.matcher(url);
|
||||||
|
while (matcher.find()) {
|
||||||
|
final String bibliogram_directory = matcher.group(2);
|
||||||
|
String bibliogramHost = sharedpreferences.getString(MainActivity.SET_BIBLIOGRAM_HOST, MainActivity.DEFAULT_BIBLIOGRAM_HOST).toLowerCase();
|
||||||
|
newUrl = "https://" + bibliogramHost + bibliogram_directory;
|
||||||
|
}
|
||||||
|
}
|
||||||
} else if (url.contains("/maps/place/")) {
|
} else if (url.contains("/maps/place/")) {
|
||||||
boolean osm_enabled = sharedpreferences.getBoolean(MainActivity.SET_OSM_ENABLED, true);
|
boolean osm_enabled = sharedpreferences.getBoolean(MainActivity.SET_OSM_ENABLED, true);
|
||||||
if (osm_enabled) {
|
if (osm_enabled) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user