Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/master' into templating_improv…
Browse files Browse the repository at this point in the history
…ements
  • Loading branch information
harshad1 committed Nov 6, 2023
2 parents 32031b6 + a050e8a commit a4e2e78
Show file tree
Hide file tree
Showing 6 changed files with 1,684 additions and 60 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/build-android-project.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,10 +22,10 @@ jobs:
steps:

- name: "Checkout: Code"
uses: actions/checkout@v2
uses: actions/checkout@v3

- name: "Checkout: Code (PR)"
uses: actions/checkout@v2
uses: actions/checkout@v3
if: "contains(github.event_name, 'pull_request')"
with:
ref: ${{github.event.pull_request.head.ref}}
Expand Down
1 change: 1 addition & 0 deletions CONTRIBUTORS.md
Original file line number Diff line number Diff line change
Expand Up @@ -49,3 +49,4 @@ Where:
* **[Frederic Jacob](https://github.com/fredericjacob)**<br>~° Added Zim-Wiki highlighting, text actions, view mode, page creation.
* **[Winston Feng](https://github.com/tifish)**<br>~° Support spaces in URL.
* **[k3b](https://github.com/k3b)**<br>~° Added CSV-Support.
* **[Ayowel](https://github.com/ayowel)**<br>~° Mermaid update.
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,7 @@ public static void showInsertImageOrLinkDialog(
final AlertDialog dialog = builder.setView(view).create();

// Helper func
final GsCallback.a1<InsertType> _insertItem = (type) -> insertItem(type, textFormatId, activity, edit, currentFile, dialog);
final GsCallback.a1<InsertType> _insertItem = (type) -> insertItem(type, textFormatId, activity, edit, currentFile, sel, dialog);

// Setup all the various choices
final InsertType browseType, okType;
Expand Down Expand Up @@ -216,14 +216,20 @@ private static void insertItem(
final Activity activity,
final Editable text,
final File currentFile,
@Nullable final int[] region,
@Nullable AlertDialog dialog
) {
final int[] sel = TextViewUtils.getSelection(text);
final int[] sel;
if (region != null && region.length > 1 && region[0] >= 0 && region[1] >= 0) {
sel = region;
} else {
sel = TextViewUtils.getSelection(text);
}

final AppSettings _appSettings = ApplicationObject.settings();
final File attachmentDir = _appSettings.getAttachmentFolder(currentFile);

// Source, dest to be written when the user hits accept
// Title, path to be written when the user hits accept
final GsCallback.a2<String, String> insertLink = (title, path) -> {
if (TextViewUtils.isNullOrEmpty(path)) {
return;
Expand All @@ -244,7 +250,7 @@ private static void insertItem(
newText = newText.replaceFirst("\\|]]$", "]]");
}

if (!text.subSequence(sel[0], sel[1]).equals(newText)) {
if (!newText.equals(text.subSequence(sel[0], sel[1]).toString())) {
text.replace(sel[0], sel[1], newText);
}

Expand Down Expand Up @@ -297,13 +303,17 @@ private static void insertItem(
}
case IMAGE_EDIT: {
if (pathEdit != null) {
String filepath = pathEdit.getText().toString().replace("%20", " ");
if (!filepath.startsWith("/")) {
filepath = new File(currentFile.getParent(), filepath).getAbsolutePath();
final String path = pathEdit.getText().toString().replace("%20", " ");

final File abs = new File(path).getAbsoluteFile();
if (abs.isFile()) {
shu.requestFileEdit(activity, abs);
break;
}
File file = new File(filepath);
if (file.exists() && file.isFile()) {
shu.requestPictureEdit(activity, file);

final File rel = new File(currentFile.getParentFile(), path).getAbsoluteFile();
if (rel.isFile()) {
shu.requestFileEdit(activity, rel);
}
}
break;
Expand Down Expand Up @@ -355,7 +365,7 @@ public static void insertCameraPhoto(
final Editable text,
final File currentFile
) {
insertItem(InsertType.IMAGE_CAMERA, textFormatId, activity, text, currentFile, null);
insertItem(InsertType.IMAGE_CAMERA, textFormatId, activity, text, currentFile, null, null);
}

public static void insertGalleryPhoto(
Expand All @@ -364,7 +374,7 @@ public static void insertGalleryPhoto(
final Editable text,
final File currentFile
) {
insertItem(InsertType.IMAGE_GALLERY, textFormatId, activity, text, currentFile, null);
insertItem(InsertType.IMAGE_GALLERY, textFormatId, activity, text, currentFile, null, null);
}

public static void insertAudioRecording(
Expand All @@ -373,6 +383,6 @@ public static void insertAudioRecording(
final Editable text,
final File currentFile
) {
insertItem(InsertType.AUDIO_RECORDING, textFormatId, activity, text, currentFile, null);
insertItem(InsertType.AUDIO_RECORDING, textFormatId, activity, text, currentFile, null, null);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -427,7 +427,7 @@ public void insertOrReplaceTextOnCursor(final String newText) {

if (newCursorPos >= 0) {
setSelection(sel[0] + newCursorPos);
TextViewUtils.showSelection(this);
postDelayed(() -> TextViewUtils.showSelection(this), 500);
}
}
}
Expand Down
57 changes: 16 additions & 41 deletions app/src/main/java/net/gsantner/opoc/util/GsContextUtils.java
Original file line number Diff line number Diff line change
Expand Up @@ -143,8 +143,6 @@
import java.io.OutputStream;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.net.URI;
import java.net.URISyntaxException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
Expand All @@ -163,8 +161,6 @@ public class GsContextUtils {
//########################
public static final GsContextUtils instance = new GsContextUtils();

private static String _authority = null;

public GsContextUtils() {
}

Expand Down Expand Up @@ -1083,15 +1079,12 @@ public List<ProviderInfo> getProvidersInfos(final Context context) {
}

public String getFileProvider(final Context context) {
if (_authority == null) {
for (final ProviderInfo info : getProvidersInfos(context)) {
if (info.name.matches("(?i).*fileprovider.*")) {
_authority = info.authority;
break;
}
for (final ProviderInfo info : getProvidersInfos(context)) {
if (info.name.matches("(?i).*fileprovider.*")) {
return info.authority;
}
}
return _authority;
throw new RuntimeException("Error at GsContextUtils::getFileProviderAuthority(context): No FileProvider authority setup");
}

/**
Expand Down Expand Up @@ -1129,30 +1122,11 @@ public <T extends GsContextUtils> T animateToActivity(final Activity context, fi
}


public String getFileProviderAuthority(final Context context) {
final String provider = getFileProvider(context);
if (TextUtils.isEmpty(provider)) {
throw new RuntimeException("Error at GsContextUtils::getFileProviderAuthority(context): No FileProvider authority setup");
}
return provider;
}


public <T extends GsContextUtils> T setChooserTitle(final String title) {
m_chooserTitle = title;
return thisp();
}

/**
* Convert a {@link File} to an {@link Uri}
*
* @param file the file
* @return Uri for this file
*/
public Uri getUriByFileProviderAuthority(final Context context, final File file) {
return FileProvider.getUriForFile(context, getFileProviderAuthority(context), file);
}

/**
* Allow to choose a handling app for given intent
*
Expand Down Expand Up @@ -1250,7 +1224,7 @@ public boolean shareStream(final Context context, final File file, final String
intent.setType(mimeType);

try {
Uri fileUri = FileProvider.getUriForFile(context, getFileProviderAuthority(context), file);
final Uri fileUri = FileProvider.getUriForFile(context, getFileProvider(context), file);
intent.putExtra(Intent.EXTRA_STREAM, fileUri);
showChooser(context, intent, null);
return true;
Expand All @@ -1269,7 +1243,7 @@ public boolean shareStreamMultiple(final Context context, final Collection<File>
ArrayList<Uri> uris = new ArrayList<>();
for (File file : files) {
File uri = new File(file.toString());
uris.add(FileProvider.getUriForFile(context, getFileProviderAuthority(context), file));
uris.add(FileProvider.getUriForFile(context, getFileProvider(context), file));
}

try {
Expand Down Expand Up @@ -1338,7 +1312,7 @@ public boolean viewFileInOtherApp(final Context context, final File file, @Nulla
// On some specific devices the first won't work
Uri fileUri = null;
try {
fileUri = FileProvider.getUriForFile(context, getFileProviderAuthority(context), file);
fileUri = FileProvider.getUriForFile(context, getFileProvider(context), file);
} catch (Exception ignored) {
try {
fileUri = Uri.fromFile(file);
Expand Down Expand Up @@ -1375,7 +1349,7 @@ public boolean requestApkInstallation(final Context context, final File file) {

Uri fileUri = null;
try {
fileUri = FileProvider.getUriForFile(context, getFileProviderAuthority(context), file);
fileUri = FileProvider.getUriForFile(context, getFileProvider(context), file);
} catch (Exception ignored) {
try {
fileUri = Uri.fromFile(file);
Expand Down Expand Up @@ -1778,7 +1752,7 @@ public void requestCameraPicture(final Activity activity) {
// Continue only if the File was successfully created
final Uri uri;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
uri = FileProvider.getUriForFile(activity, getFileProviderAuthority(activity), imageTemp);
uri = FileProvider.getUriForFile(activity, getFileProvider(activity), imageTemp);
} else {
uri = Uri.fromFile(imageTemp);
}
Expand Down Expand Up @@ -1934,18 +1908,19 @@ public void onReceive(Context context, Intent intent) {
}

/**
* Request edit of image (by image editor/viewer - for example to crop image)
* Request edit of file
*
* @param file File that should be edited
*/
public void requestPictureEdit(final Context context, final File file) {
final Uri uri = getUriByFileProviderAuthority(context, file);
public void requestFileEdit(final Context context, final File file) {
final Uri uri = FileProvider.getUriForFile(context, getFileProvider(context), file);
final Intent intent = new Intent(Intent.ACTION_EDIT);
intent.setDataAndType(uri, "image/*");
intent.addFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION | Intent.FLAG_GRANT_READ_URI_PERMISSION);
intent.setDataAndType(uri, GsFileUtils.getMimeType(file));
intent.addFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION);
intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
intent.putExtra(MediaStore.EXTRA_OUTPUT, uri);
intent.putExtra(EXTRA_FILEPATH, file.getAbsolutePath());
startActivity(context, Intent.createChooser(intent, null));
startActivity(context, intent);
}

/**
Expand Down
1,644 changes: 1,641 additions & 3 deletions app/thirdparty/assets/mermaid/mermaid.min.js

Large diffs are not rendered by default.

0 comments on commit a4e2e78

Please sign in to comment.