From 340f6db46bd344696b35d77c59ee3cf9af960869 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 12:22:58 +0300 Subject: [PATCH 01/24] Add null annotations before converting BlockProcessorFactory --- .../org/wordpress/android/ui/posts/PostUtils.java | 2 +- .../BlockProcessorFactory.java | 13 ++++++++----- .../GalleryBlockProcessor.java | 2 +- .../MediaUploadCompletionProcessor.java | 11 +++++++---- 4 files changed, 17 insertions(+), 11 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/PostUtils.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/PostUtils.java index 8537f9d70275..f0524294a1c0 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/PostUtils.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/PostUtils.java @@ -431,7 +431,7 @@ public static boolean shouldShowGutenbergEditor(boolean isNewPost, String postCo public static String replaceMediaFileWithUrlInGutenbergPost(@NonNull String postContent, @NonNull String localMediaId, MediaFile mediaFile, - String siteUrl) { + @NonNull String siteUrl) { if (mediaFile != null && contentContainsGutenbergBlocks(postContent)) { MediaUploadCompletionProcessor processor = new MediaUploadCompletionProcessor(localMediaId, mediaFile, siteUrl); diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.java index 1e8fd766a95c..f95c74bd7086 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.java @@ -1,6 +1,7 @@ package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import org.wordpress.android.util.helpers.MediaFile; @@ -17,16 +18,16 @@ import static org.wordpress.android.ui.posts.mediauploadcompletionprocessors.MediaBlockType.VIDEOPRESS; class BlockProcessorFactory { + @NonNull private final MediaUploadCompletionProcessor mMediaUploadCompletionProcessor; - private final Map mMediaBlockTypeBlockProcessorMap; + private final Map mMediaBlockTypeBlockProcessorMap = new HashMap<>(); /** * This factory initializes block processors for all media block types and provides a method to retrieve a block * processor instance for a given block type. */ - BlockProcessorFactory(MediaUploadCompletionProcessor mediaUploadCompletionProcessor) { + BlockProcessorFactory(@NonNull MediaUploadCompletionProcessor mediaUploadCompletionProcessor) { mMediaUploadCompletionProcessor = mediaUploadCompletionProcessor; - mMediaBlockTypeBlockProcessorMap = new HashMap<>(); } /** @@ -35,7 +36,8 @@ class BlockProcessorFactory { * @param siteUrl The site url - used to generate the attachmentPage url * @return The factory instance - useful for chaining this method upon instantiation */ - BlockProcessorFactory init(@NonNull String localId, @NonNull MediaFile mediaFile, String siteUrl) { + @NonNull + BlockProcessorFactory init(@NonNull String localId, @NonNull MediaFile mediaFile, @NonNull String siteUrl) { mMediaBlockTypeBlockProcessorMap.put(IMAGE, new ImageBlockProcessor(localId, mediaFile)); mMediaBlockTypeBlockProcessorMap.put(VIDEOPRESS, new VideoPressBlockProcessor(localId, mediaFile)); mMediaBlockTypeBlockProcessorMap.put(VIDEO, new VideoBlockProcessor(localId, mediaFile)); @@ -56,7 +58,8 @@ BlockProcessorFactory init(@NonNull String localId, @NonNull MediaFile mediaFile * @param blockType The media block type for which to provide a {@link BlockProcessor} * @return The {@link BlockProcessor} for the given media block type */ - BlockProcessor getProcessorForMediaBlockType(MediaBlockType blockType) { + @Nullable + BlockProcessor getProcessorForMediaBlockType(@NonNull MediaBlockType blockType) { return mMediaBlockTypeBlockProcessorMap.get(blockType); } } diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java index a1a28992c574..63c55c6fb4db 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java @@ -36,7 +36,7 @@ public class GalleryBlockProcessor extends BlockProcessor { .append("(.*)") // inner block contents .append("(\\s*\\s*.*)").toString(), Pattern.DOTALL); - public GalleryBlockProcessor(@NonNull String localId, @NonNull MediaFile mediaFile, String siteUrl, + public GalleryBlockProcessor(@NonNull String localId, @NonNull MediaFile mediaFile, @NonNull String siteUrl, MediaUploadCompletionProcessor mediaUploadCompletionProcessor) { super(localId, mediaFile); mMediaUploadCompletionProcessor = mediaUploadCompletionProcessor; diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaUploadCompletionProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaUploadCompletionProcessor.java index 51f3f7790161..304111a570be 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaUploadCompletionProcessor.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaUploadCompletionProcessor.java @@ -21,7 +21,8 @@ public class MediaUploadCompletionProcessor { * @param mediaFile The mediaFile containing the remote id and remote url * @param siteUrl The site url - used to generate the attachmentPage url */ - public MediaUploadCompletionProcessor(@NonNull String localId, @NonNull MediaFile mediaFile, String siteUrl) { + public MediaUploadCompletionProcessor(@NonNull String localId, @NonNull MediaFile mediaFile, + @NonNull String siteUrl) { mBlockProcessorFactory = new BlockProcessorFactory(this) .init(localId, mediaFile, siteUrl); } @@ -82,10 +83,12 @@ public String processContent(String content) { @NonNull private String processBlock(@NonNull String block, Boolean isSelfClosingTag) { final MediaBlockType blockType = MediaBlockType.detectBlockType(block); - final BlockProcessor blockProcessor = mBlockProcessorFactory.getProcessorForMediaBlockType(blockType); - if (blockProcessor != null) { - return blockProcessor.processBlock(block, isSelfClosingTag); + if (blockType != null) { + final BlockProcessor blockProcessor = mBlockProcessorFactory.getProcessorForMediaBlockType(blockType); + if (blockProcessor != null) { + return blockProcessor.processBlock(block, isSelfClosingTag); + } } return block; From 7e0cd6d01f2d690c363330a6a0061c8762f7b009 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 12:24:18 +0300 Subject: [PATCH 02/24] Rename .java to .kt --- .../{BlockProcessorFactory.java => BlockProcessorFactory.kt} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/{BlockProcessorFactory.java => BlockProcessorFactory.kt} (100%) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt similarity index 100% rename from WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.java rename to WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt From a9949f039c0ed8e2a5db4b327fd7eb95530b8acb Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 12:24:18 +0300 Subject: [PATCH 03/24] Convert `BlockProcessorFactory` to Kotlin --- .../BlockProcessorFactory.kt | 84 ++++++++----------- 1 file changed, 36 insertions(+), 48 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt index f95c74bd7086..f0bd3150ecf0 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt @@ -1,34 +1,14 @@ -package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; +package org.wordpress.android.ui.posts.mediauploadcompletionprocessors -import androidx.annotation.NonNull; -import androidx.annotation.Nullable; +import org.wordpress.android.util.helpers.MediaFile -import org.wordpress.android.util.helpers.MediaFile; - -import java.util.HashMap; -import java.util.Map; - -import static org.wordpress.android.ui.posts.mediauploadcompletionprocessors.MediaBlockType.AUDIO; -import static org.wordpress.android.ui.posts.mediauploadcompletionprocessors.MediaBlockType.COVER; -import static org.wordpress.android.ui.posts.mediauploadcompletionprocessors.MediaBlockType.FILE; -import static org.wordpress.android.ui.posts.mediauploadcompletionprocessors.MediaBlockType.GALLERY; -import static org.wordpress.android.ui.posts.mediauploadcompletionprocessors.MediaBlockType.IMAGE; -import static org.wordpress.android.ui.posts.mediauploadcompletionprocessors.MediaBlockType.MEDIA_TEXT; -import static org.wordpress.android.ui.posts.mediauploadcompletionprocessors.MediaBlockType.VIDEO; -import static org.wordpress.android.ui.posts.mediauploadcompletionprocessors.MediaBlockType.VIDEOPRESS; - -class BlockProcessorFactory { - @NonNull - private final MediaUploadCompletionProcessor mMediaUploadCompletionProcessor; - private final Map mMediaBlockTypeBlockProcessorMap = new HashMap<>(); - - /** - * This factory initializes block processors for all media block types and provides a method to retrieve a block - * processor instance for a given block type. - */ - BlockProcessorFactory(@NonNull MediaUploadCompletionProcessor mediaUploadCompletionProcessor) { - mMediaUploadCompletionProcessor = mediaUploadCompletionProcessor; - } +internal class BlockProcessorFactory +/** + * This factory initializes block processors for all media block types and provides a method to retrieve a block + * processor instance for a given block type. + */(private val mMediaUploadCompletionProcessor: MediaUploadCompletionProcessor) { + private val mMediaBlockTypeBlockProcessorMap: MutableMap = + HashMap() /** * @param localId The local media id that needs replacement @@ -36,30 +16,38 @@ class BlockProcessorFactory { * @param siteUrl The site url - used to generate the attachmentPage url * @return The factory instance - useful for chaining this method upon instantiation */ - @NonNull - BlockProcessorFactory init(@NonNull String localId, @NonNull MediaFile mediaFile, @NonNull String siteUrl) { - mMediaBlockTypeBlockProcessorMap.put(IMAGE, new ImageBlockProcessor(localId, mediaFile)); - mMediaBlockTypeBlockProcessorMap.put(VIDEOPRESS, new VideoPressBlockProcessor(localId, mediaFile)); - mMediaBlockTypeBlockProcessorMap.put(VIDEO, new VideoBlockProcessor(localId, mediaFile)); - mMediaBlockTypeBlockProcessorMap.put(MEDIA_TEXT, new MediaTextBlockProcessor(localId, mediaFile)); - mMediaBlockTypeBlockProcessorMap.put(GALLERY, new GalleryBlockProcessor(localId, mediaFile, siteUrl, - mMediaUploadCompletionProcessor)); - mMediaBlockTypeBlockProcessorMap.put(COVER, new CoverBlockProcessor(localId, mediaFile, - mMediaUploadCompletionProcessor)); - mMediaBlockTypeBlockProcessorMap.put(FILE, new FileBlockProcessor(localId, mediaFile)); - mMediaBlockTypeBlockProcessorMap.put(AUDIO, new AudioBlockProcessor(localId, mediaFile)); - - return this; + fun init(localId: String, mediaFile: MediaFile, siteUrl: String): BlockProcessorFactory { + mMediaBlockTypeBlockProcessorMap[MediaBlockType.IMAGE] = + ImageBlockProcessor(localId, mediaFile) + mMediaBlockTypeBlockProcessorMap[MediaBlockType.VIDEOPRESS] = + VideoPressBlockProcessor(localId, mediaFile) + mMediaBlockTypeBlockProcessorMap[MediaBlockType.VIDEO] = + VideoBlockProcessor(localId, mediaFile) + mMediaBlockTypeBlockProcessorMap[MediaBlockType.MEDIA_TEXT] = + MediaTextBlockProcessor(localId, mediaFile) + mMediaBlockTypeBlockProcessorMap[MediaBlockType.GALLERY] = GalleryBlockProcessor( + localId, mediaFile, siteUrl, + mMediaUploadCompletionProcessor + ) + mMediaBlockTypeBlockProcessorMap[MediaBlockType.COVER] = CoverBlockProcessor( + localId, mediaFile, + mMediaUploadCompletionProcessor + ) + mMediaBlockTypeBlockProcessorMap[MediaBlockType.FILE] = + FileBlockProcessor(localId, mediaFile) + mMediaBlockTypeBlockProcessorMap[MediaBlockType.AUDIO] = + AudioBlockProcessor(localId, mediaFile) + + return this } /** * Retrieves the block processor instance for the given media block type. * - * @param blockType The media block type for which to provide a {@link BlockProcessor} - * @return The {@link BlockProcessor} for the given media block type + * @param blockType The media block type for which to provide a [BlockProcessor] + * @return The [BlockProcessor] for the given media block type */ - @Nullable - BlockProcessor getProcessorForMediaBlockType(@NonNull MediaBlockType blockType) { - return mMediaBlockTypeBlockProcessorMap.get(blockType); + fun getProcessorForMediaBlockType(blockType: MediaBlockType): BlockProcessor? { + return mMediaBlockTypeBlockProcessorMap[blockType] } } From 53ad66e3dc49542af864dfd9b8d1b9758613c24f Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 14:21:08 +0300 Subject: [PATCH 04/24] Reformat BlockProcessorFactory after conversion --- .../BlockProcessorFactory.kt | 60 +++++++------------ .../MediaUploadCompletionProcessor.java | 3 +- 2 files changed, 23 insertions(+), 40 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt index f0bd3150ecf0..98a34a391d75 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessorFactory.kt @@ -2,44 +2,30 @@ package org.wordpress.android.ui.posts.mediauploadcompletionprocessors import org.wordpress.android.util.helpers.MediaFile -internal class BlockProcessorFactory /** * This factory initializes block processors for all media block types and provides a method to retrieve a block * processor instance for a given block type. - */(private val mMediaUploadCompletionProcessor: MediaUploadCompletionProcessor) { - private val mMediaBlockTypeBlockProcessorMap: MutableMap = - HashMap() - - /** - * @param localId The local media id that needs replacement - * @param mediaFile The mediaFile containing the remote id and remote url - * @param siteUrl The site url - used to generate the attachmentPage url - * @return The factory instance - useful for chaining this method upon instantiation - */ - fun init(localId: String, mediaFile: MediaFile, siteUrl: String): BlockProcessorFactory { - mMediaBlockTypeBlockProcessorMap[MediaBlockType.IMAGE] = - ImageBlockProcessor(localId, mediaFile) - mMediaBlockTypeBlockProcessorMap[MediaBlockType.VIDEOPRESS] = - VideoPressBlockProcessor(localId, mediaFile) - mMediaBlockTypeBlockProcessorMap[MediaBlockType.VIDEO] = - VideoBlockProcessor(localId, mediaFile) - mMediaBlockTypeBlockProcessorMap[MediaBlockType.MEDIA_TEXT] = - MediaTextBlockProcessor(localId, mediaFile) - mMediaBlockTypeBlockProcessorMap[MediaBlockType.GALLERY] = GalleryBlockProcessor( - localId, mediaFile, siteUrl, - mMediaUploadCompletionProcessor - ) - mMediaBlockTypeBlockProcessorMap[MediaBlockType.COVER] = CoverBlockProcessor( - localId, mediaFile, - mMediaUploadCompletionProcessor - ) - mMediaBlockTypeBlockProcessorMap[MediaBlockType.FILE] = - FileBlockProcessor(localId, mediaFile) - mMediaBlockTypeBlockProcessorMap[MediaBlockType.AUDIO] = - AudioBlockProcessor(localId, mediaFile) - - return this - } + * @param localId The local media id that needs replacement + * @param mediaFile The mediaFile containing the remote id and remote url` + * @param siteUrl The site url - used to generate the attachmentPage url + * @return The factory instance - useful for chaining this method upon instantiation + */ +internal class BlockProcessorFactory( + mediaUploadCompletionProcessor: MediaUploadCompletionProcessor, + localId: String, + mediaFile: MediaFile, + siteUrl: String +) { + private val mediaBlockTypeBlockProcessorMap = hashMapOf( + MediaBlockType.IMAGE to ImageBlockProcessor(localId, mediaFile), + MediaBlockType.VIDEOPRESS to VideoPressBlockProcessor(localId, mediaFile), + MediaBlockType.VIDEO to VideoBlockProcessor(localId, mediaFile), + MediaBlockType.MEDIA_TEXT to MediaTextBlockProcessor(localId, mediaFile), + MediaBlockType.GALLERY to GalleryBlockProcessor(localId, mediaFile, siteUrl, mediaUploadCompletionProcessor), + MediaBlockType.COVER to CoverBlockProcessor(localId, mediaFile, mediaUploadCompletionProcessor), + MediaBlockType.FILE to FileBlockProcessor(localId, mediaFile), + MediaBlockType.AUDIO to AudioBlockProcessor(localId, mediaFile) + ) /** * Retrieves the block processor instance for the given media block type. @@ -47,7 +33,5 @@ internal class BlockProcessorFactory * @param blockType The media block type for which to provide a [BlockProcessor] * @return The [BlockProcessor] for the given media block type */ - fun getProcessorForMediaBlockType(blockType: MediaBlockType): BlockProcessor? { - return mMediaBlockTypeBlockProcessorMap[blockType] - } + fun getProcessorForMediaBlockType(blockType: MediaBlockType) = mediaBlockTypeBlockProcessorMap[blockType] } diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaUploadCompletionProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaUploadCompletionProcessor.java index 304111a570be..9cf13a536657 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaUploadCompletionProcessor.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaUploadCompletionProcessor.java @@ -23,8 +23,7 @@ public class MediaUploadCompletionProcessor { */ public MediaUploadCompletionProcessor(@NonNull String localId, @NonNull MediaFile mediaFile, @NonNull String siteUrl) { - mBlockProcessorFactory = new BlockProcessorFactory(this) - .init(localId, mediaFile, siteUrl); + mBlockProcessorFactory = new BlockProcessorFactory(this, localId, mediaFile, siteUrl); } /** From cbe2e688bab6632f67a3cdb57ced351cfccd3a74 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 14:49:19 +0300 Subject: [PATCH 05/24] Make Document parameter of processBlockContentDocument() NonNull --- .../AudioBlockProcessor.kt | 15 ++++++--------- .../BlockProcessor.kt | 4 ++-- .../CoverBlockProcessor.java | 5 +++-- .../FileBlockProcessor.kt | 15 ++++++--------- .../GalleryBlockProcessor.java | 2 +- .../ImageBlockProcessor.java | 2 +- .../MediaTextBlockProcessor.java | 2 +- .../VideoBlockProcessor.java | 2 +- .../VideoPressBlockProcessor.kt | 2 +- 9 files changed, 22 insertions(+), 27 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/AudioBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/AudioBlockProcessor.kt index 03e2ac4a1886..e949a14069cf 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/AudioBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/AudioBlockProcessor.kt @@ -5,17 +5,14 @@ import org.jsoup.nodes.Document import org.wordpress.android.util.helpers.MediaFile class AudioBlockProcessor(localId: String, mediaFile: MediaFile) : BlockProcessor(localId, mediaFile) { - override fun processBlockContentDocument(document: Document?): Boolean { - val audioElements = document?.select(AUDIO_TAG) + override fun processBlockContentDocument(document: Document): Boolean { + val audioElements = document.select(AUDIO_TAG) - audioElements?.let { elements -> - for (element in elements) { - // replaces the src attribute's local url with the remote counterpart. - element.attr(SRC_ATTRIBUTE, remoteUrl) - } - return true + for (element in audioElements) { + // replaces the src attribute's local url with the remote counterpart. + element.attr(SRC_ATTRIBUTE, remoteUrl) } - return false + return true } override fun processBlockJsonAttributes(jsonAttributes: JsonObject?): Boolean { diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessor.kt index b024416d51f4..fa666fd960dd 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessor.kt @@ -83,7 +83,7 @@ abstract class BlockProcessor internal constructor(@JvmField var localId: String .append(jsonAttributes) // json parser output .append(" /-->") .toString() - } else if (processBlockContentDocument(blockContentDocument)) { + } else if (blockContentDocument?.let { processBlockContentDocument(it) } == true) { // return injected block StringBuilder() .append("") - .toString() - } else if (blockContentDocument?.let { processBlockContentDocument(it) } == true) { - // return injected block - StringBuilder() - .append("\n") - .append(blockContentDocument?.body()?.html()) // HTML parser output - .append(closingComment) - .toString() - } else { - block - } - } else { - processInnerBlock(block) // delegate to inner blocks if needed + fun processBlock(block: String, isSelfClosingTag: Boolean = false) = when { + !splitBlock(block, isSelfClosingTag) -> block // leave block unchanged + !processBlockJsonAttributes(jsonAttributes) -> processInnerBlock(block) // delegate to inner blocks if needed + isSelfClosingTag -> { + // return injected block + StringBuilder() + .append("") + .toString() } - } else { - // leave block unchanged - block + + blockContentDocument?.let { processBlockContentDocument(it) } == true -> { + // return injected block + StringBuilder() + .append("\n") + .append(blockContentDocument?.body()?.html()) // HTML parser output + .append(closingComment) + .toString() + } + + else -> block // leave block unchanged } fun addIntPropertySafely(jsonAttributes: JsonObject, propertyName: String, value: String) = try { From 45ec0c403c2e340eb6e630c4758e244eaec8bb9c Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 15:18:36 +0300 Subject: [PATCH 07/24] Make jsonAttributes parameter of processBlockJsonAttributes() NonNull --- .../mediauploadcompletionprocessors/AudioBlockProcessor.kt | 4 ++-- .../mediauploadcompletionprocessors/BlockProcessor.kt | 7 +++++-- .../CoverBlockProcessor.java | 2 +- .../mediauploadcompletionprocessors/FileBlockProcessor.kt | 4 ++-- .../GalleryBlockProcessor.java | 3 +-- .../ImageBlockProcessor.java | 3 +-- .../MediaTextBlockProcessor.java | 3 +-- .../VideoBlockProcessor.java | 3 +-- .../VideoPressBlockProcessor.kt | 6 +++--- 9 files changed, 17 insertions(+), 18 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/AudioBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/AudioBlockProcessor.kt index e949a14069cf..18b7a82b0ad4 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/AudioBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/AudioBlockProcessor.kt @@ -15,8 +15,8 @@ class AudioBlockProcessor(localId: String, mediaFile: MediaFile) : BlockProcesso return true } - override fun processBlockJsonAttributes(jsonAttributes: JsonObject?): Boolean { - val id = jsonAttributes?.get(ID_ATTRIBUTE) + override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { + val id = jsonAttributes.get(ID_ATTRIBUTE) return if (id != null && !id.isJsonNull && id.asString == localId) { jsonAttributes.apply { diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessor.kt index 10aaf1887c43..0de94a0e19ed 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/BlockProcessor.kt @@ -74,7 +74,10 @@ abstract class BlockProcessor internal constructor(@JvmField var localId: String @JvmOverloads fun processBlock(block: String, isSelfClosingTag: Boolean = false) = when { !splitBlock(block, isSelfClosingTag) -> block // leave block unchanged - !processBlockJsonAttributes(jsonAttributes) -> processInnerBlock(block) // delegate to inner blocks if needed + jsonAttributes?.let { !processBlockJsonAttributes(it) } == true -> { + // delegate to inner blocks if needed + processInnerBlock(block) + } isSelfClosingTag -> { // return injected block StringBuilder() @@ -131,7 +134,7 @@ abstract class BlockProcessor internal constructor(@JvmField var localId: String * @param jsonAttributes the attributes object used to check for a match with the local id, and mutated if necessary * @return */ - abstract fun processBlockJsonAttributes(jsonAttributes: JsonObject?): Boolean + abstract fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean /** * This method can be optionally overridden by concrete implementations to delegate further processing via recursion diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.java index e30844ed0c2a..701d1a468035 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.java @@ -59,7 +59,7 @@ public String processInnerBlock(@NonNull String block) { } @Override - public boolean processBlockJsonAttributes(@Nullable JsonObject jsonAttributes) { + public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { JsonElement id = jsonAttributes.get("id"); if (id != null && !id.isJsonNull() && id.getAsInt() == Integer.parseInt(localId, 10)) { addIntPropertySafely(jsonAttributes, "id", remoteId); diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/FileBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/FileBlockProcessor.kt index 4a3ba1d2666b..0b6997e4dac6 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/FileBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/FileBlockProcessor.kt @@ -19,8 +19,8 @@ class FileBlockProcessor(localId: String, mediaFile: MediaFile) : BlockProcessor return true } - override fun processBlockJsonAttributes(jsonAttributes: JsonObject?): Boolean { - val id = jsonAttributes?.get(ID_ATTRIBUTE) + override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { + val id = jsonAttributes.get(ID_ATTRIBUTE) return if (id != null && !id.isJsonNull && id.asString == localId) { jsonAttributes.apply { diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java index bf9c06a8292e..031e623b8021 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java @@ -1,7 +1,6 @@ package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; import androidx.annotation.NonNull; -import androidx.annotation.Nullable; import com.google.gson.JsonArray; import com.google.gson.JsonElement; @@ -88,7 +87,7 @@ public boolean processBlockContentDocument(@NonNull Document document) { } @Override - public boolean processBlockJsonAttributes(@Nullable JsonObject jsonAttributes) { + public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { // The new format does not have an `ids` attributes, so returning false here will defer to recursive processing JsonArray ids = jsonAttributes.getAsJsonArray("ids"); if (ids == null || ids.isJsonNull()) { diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.java index 05917ba78415..9b2c9e86a7df 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.java @@ -1,7 +1,6 @@ package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; import androidx.annotation.NonNull; -import androidx.annotation.Nullable; import com.google.gson.JsonElement; import com.google.gson.JsonObject; @@ -37,7 +36,7 @@ public boolean processBlockContentDocument(@NonNull Document document) { } @Override - public boolean processBlockJsonAttributes(@Nullable JsonObject jsonAttributes) { + public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { JsonElement id = jsonAttributes.get("id"); if (id != null && !id.isJsonNull() && id.getAsString().equals(localId)) { addIntPropertySafely(jsonAttributes, "id", remoteId); diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.java index 2e73bd71928e..0bdbccfe74d9 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.java @@ -1,7 +1,6 @@ package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; import androidx.annotation.NonNull; -import androidx.annotation.Nullable; import com.google.gson.JsonElement; import com.google.gson.JsonObject; @@ -49,7 +48,7 @@ public boolean processBlockContentDocument(@NonNull Document document) { } @Override - public boolean processBlockJsonAttributes(@Nullable JsonObject jsonAttributes) { + public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { JsonElement id = jsonAttributes.get("mediaId"); if (id != null && !id.isJsonNull() && id.getAsString().equals(localId)) { addIntPropertySafely(jsonAttributes, "mediaId", remoteId); diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.java index adc1c7df7fae..dc290b33a8f3 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.java @@ -1,7 +1,6 @@ package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; import androidx.annotation.NonNull; -import androidx.annotation.Nullable; import com.google.gson.JsonElement; import com.google.gson.JsonObject; @@ -33,7 +32,7 @@ public boolean processBlockContentDocument(@NonNull Document document) { } @Override - public boolean processBlockJsonAttributes(@Nullable JsonObject jsonAttributes) { + public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { JsonElement id = jsonAttributes.get("id"); if (id != null && !id.isJsonNull() && id.getAsString().equals(localId)) { addIntPropertySafely(jsonAttributes, "id", remoteId); diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoPressBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoPressBlockProcessor.kt index 86491d220d07..7e5a6168c03b 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoPressBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoPressBlockProcessor.kt @@ -9,9 +9,9 @@ class VideoPressBlockProcessor(localId: String, mediaFile: MediaFile) : BlockPro return false } - override fun processBlockJsonAttributes(jsonAttributes: JsonObject?): Boolean { - val id = jsonAttributes?.get(ID_ATTRIBUTE) - val src = jsonAttributes?.get(SRC_ATTRIBUTE)?.asString + override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { + val id = jsonAttributes.get(ID_ATTRIBUTE) + val src = jsonAttributes.get(SRC_ATTRIBUTE)?.asString return if (id != null && !id.isJsonNull && id.asString == localId) { jsonAttributes.apply { From 4ce5cbb23d725f6579f99a381fd971ddd72ec966 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 15:20:17 +0300 Subject: [PATCH 08/24] Rename .java to .kt --- .../{CoverBlockProcessor.java => CoverBlockProcessor.kt} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/{CoverBlockProcessor.java => CoverBlockProcessor.kt} (100%) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt similarity index 100% rename from WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.java rename to WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt From 0e010460093e12a9b4ecc90a4fcb3beee9457fe6 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 15:20:17 +0300 Subject: [PATCH 09/24] Convert `CoverBlockProcessor` to Kotlin --- .../CoverBlockProcessor.kt | 134 ++++++++---------- 1 file changed, 62 insertions(+), 72 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt index 701d1a468035..ff8de93e9c82 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt @@ -1,106 +1,96 @@ -package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; +package org.wordpress.android.ui.posts.mediauploadcompletionprocessors -import androidx.annotation.NonNull; -import androidx.annotation.Nullable; +import com.google.gson.JsonObject +import org.jsoup.nodes.Document +import org.wordpress.android.util.helpers.MediaFile +import java.util.regex.Pattern -import com.google.gson.JsonElement; -import com.google.gson.JsonObject; +class CoverBlockProcessor( + localId: String, mediaFile: MediaFile, + private val mMediaUploadCompletionProcessor: MediaUploadCompletionProcessor +) : BlockProcessor(localId, mediaFile) { + private var mHasVideoBackground = false -import org.jsoup.nodes.Document; -import org.jsoup.nodes.Element; -import org.wordpress.android.util.helpers.MediaFile; - -import java.util.regex.Matcher; -import java.util.regex.Pattern; - -public class CoverBlockProcessor extends BlockProcessor { - private boolean mHasVideoBackground = false; - - /** - * Template pattern used to match and splice cover inner blocks - */ - private static final Pattern PATTERN_COVER_INNER = Pattern.compile(new StringBuilder() - .append("(^.*?
\\s*)") - .append("(.*)") // inner block contents - .append("(\\s*
\\s*\\s*.*)").toString(), Pattern.DOTALL); - - /** - * Pattern to match background-image url in cover block html content - */ - private static final Pattern PATTERN_BACKGROUND_IMAGE_URL = Pattern.compile( - "background-image:\\s*url\\([^\\)]+\\)"); - - @NonNull - private final MediaUploadCompletionProcessor mMediaUploadCompletionProcessor; - - public CoverBlockProcessor(@NonNull String localId, @NonNull MediaFile mediaFile, - @NonNull MediaUploadCompletionProcessor mediaUploadCompletionProcessor) { - super(localId, mediaFile); - mMediaUploadCompletionProcessor = mediaUploadCompletionProcessor; - } - - @NonNull - @Override - public String processInnerBlock(@NonNull String block) { - Matcher innerMatcher = PATTERN_COVER_INNER.matcher(block); - boolean innerCapturesFound = innerMatcher.find(); + override fun processInnerBlock(block: String): String { + val innerMatcher = PATTERN_COVER_INNER.matcher(block) + val innerCapturesFound = innerMatcher.find() // process inner contents recursively if (innerCapturesFound) { - String innerProcessed = mMediaUploadCompletionProcessor.processContent(innerMatcher.group(2)); // - return new StringBuilder() - .append(innerMatcher.group(1)) - .append(innerProcessed) - .append(innerMatcher.group(3)) - .toString(); + val innerProcessed = + mMediaUploadCompletionProcessor.processContent(innerMatcher.group(2)) // + return StringBuilder() + .append(innerMatcher.group(1)) + .append(innerProcessed) + .append(innerMatcher.group(3)) + .toString() } - return block; + return block } - @Override - public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { - JsonElement id = jsonAttributes.get("id"); - if (id != null && !id.isJsonNull() && id.getAsInt() == Integer.parseInt(localId, 10)) { - addIntPropertySafely(jsonAttributes, "id", remoteId); + override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { + val id = jsonAttributes["id"] + if (id != null && !id.isJsonNull && id.asInt == localId.toInt(10)) { + addIntPropertySafely(jsonAttributes, "id", remoteId) - jsonAttributes.addProperty("url", remoteUrl); + jsonAttributes.addProperty("url", remoteUrl) // check if background type is video - JsonElement backgroundType = jsonAttributes.get("backgroundType"); - mHasVideoBackground = backgroundType != null && !backgroundType.isJsonNull() && "video".equals( - backgroundType.getAsString()); - return true; + val backgroundType = jsonAttributes["backgroundType"] + mHasVideoBackground = + backgroundType != null && !backgroundType.isJsonNull && "video" == backgroundType.asString + return true } - return false; + return false } - @Override - public boolean processBlockContentDocument(@NonNull Document document) { + override fun processBlockContentDocument(document: Document): Boolean { // select cover block div - Element targetDiv = document.selectFirst(".wp-block-cover"); + val targetDiv = document.selectFirst(".wp-block-cover") // if a match is found, proceed with replacement if (targetDiv != null) { if (mHasVideoBackground) { - Element videoElement = targetDiv.selectFirst("video"); + val videoElement = targetDiv.selectFirst("video") if (videoElement != null) { - videoElement.attr("src", remoteUrl); + videoElement.attr("src", remoteUrl) } else { - return false; + return false } } else { // replace background-image url in style attribute - String style = PATTERN_BACKGROUND_IMAGE_URL.matcher(targetDiv.attr("style")).replaceFirst( - String.format("background-image:url(%1$s)", remoteUrl)); - targetDiv.attr("style", style); + val style = + PATTERN_BACKGROUND_IMAGE_URL.matcher(targetDiv.attr("style")).replaceFirst( + String.format("background-image:url(%1\$s)", remoteUrl) + ) + targetDiv.attr("style", style) } // return injected block - return true; + return true } - return false; + return false + } + + companion object { + /** + * Template pattern used to match and splice cover inner blocks + */ + private val PATTERN_COVER_INNER: Pattern = Pattern.compile( + StringBuilder() + .append("(^.*?
\\s*)") + .append("(.*)") // inner block contents + .append("(\\s*
\\s*\\s*.*)").toString(), Pattern.DOTALL + ) + + /** + * Pattern to match background-image url in cover block html content + */ + private val PATTERN_BACKGROUND_IMAGE_URL: Pattern = Pattern.compile( + "background-image:\\s*url\\([^\\)]+\\)" + ) } } From 923677354bc5537b9d82b2cfd4a9bbafc99d0b0d Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 15:29:09 +0300 Subject: [PATCH 10/24] Reformat CoverBlockProcessor after conversion --- .../CoverBlockProcessor.kt | 30 +++++++++---------- 1 file changed, 14 insertions(+), 16 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt index ff8de93e9c82..15a0b98aab48 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt @@ -6,10 +6,11 @@ import org.wordpress.android.util.helpers.MediaFile import java.util.regex.Pattern class CoverBlockProcessor( - localId: String, mediaFile: MediaFile, - private val mMediaUploadCompletionProcessor: MediaUploadCompletionProcessor + localId: String, + mediaFile: MediaFile, + private val mediaUploadCompletionProcessor: MediaUploadCompletionProcessor ) : BlockProcessor(localId, mediaFile) { - private var mHasVideoBackground = false + private var hasVideoBackground = false override fun processInnerBlock(block: String): String { val innerMatcher = PATTERN_COVER_INNER.matcher(block) @@ -17,8 +18,7 @@ class CoverBlockProcessor( // process inner contents recursively if (innerCapturesFound) { - val innerProcessed = - mMediaUploadCompletionProcessor.processContent(innerMatcher.group(2)) // + val innerProcessed = mediaUploadCompletionProcessor.processContent(innerMatcher.group(2)) return StringBuilder() .append(innerMatcher.group(1)) .append(innerProcessed) @@ -38,8 +38,9 @@ class CoverBlockProcessor( // check if background type is video val backgroundType = jsonAttributes["backgroundType"] - mHasVideoBackground = - backgroundType != null && !backgroundType.isJsonNull && "video" == backgroundType.asString + hasVideoBackground = backgroundType != null && + !backgroundType.isJsonNull && + "video" == backgroundType.asString return true } @@ -52,7 +53,7 @@ class CoverBlockProcessor( // if a match is found, proceed with replacement if (targetDiv != null) { - if (mHasVideoBackground) { + if (hasVideoBackground) { val videoElement = targetDiv.selectFirst("video") if (videoElement != null) { videoElement.attr("src", remoteUrl) @@ -61,10 +62,8 @@ class CoverBlockProcessor( } } else { // replace background-image url in style attribute - val style = - PATTERN_BACKGROUND_IMAGE_URL.matcher(targetDiv.attr("style")).replaceFirst( - String.format("background-image:url(%1\$s)", remoteUrl) - ) + val style = PATTERN_BACKGROUND_IMAGE_URL.matcher(targetDiv.attr("style")) + .replaceFirst(String.format("background-image:url(%1\$s)", remoteUrl)) targetDiv.attr("style", style) } @@ -83,14 +82,13 @@ class CoverBlockProcessor( StringBuilder() .append("(^.*?
\\s*)") .append("(.*)") // inner block contents - .append("(\\s*
\\s*\\s*.*)").toString(), Pattern.DOTALL + .append("(\\s*\\s*\\s*.*)").toString(), + Pattern.DOTALL ) /** * Pattern to match background-image url in cover block html content */ - private val PATTERN_BACKGROUND_IMAGE_URL: Pattern = Pattern.compile( - "background-image:\\s*url\\([^\\)]+\\)" - ) + private val PATTERN_BACKGROUND_IMAGE_URL: Pattern = Pattern.compile("background-image:\\s*url\\([^)]+\\)") } } From ee7ae6ca9026ba38c97a60b2f8e0332f4c4ad9a0 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 16:14:44 +0300 Subject: [PATCH 11/24] Fix detekt errors in `CoverBlockProcessor` --- .../CoverBlockProcessor.kt | 36 +++++++++---------- 1 file changed, 17 insertions(+), 19 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt index 15a0b98aab48..afdbb466c5fe 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/CoverBlockProcessor.kt @@ -3,6 +3,7 @@ package org.wordpress.android.ui.posts.mediauploadcompletionprocessors import com.google.gson.JsonObject import org.jsoup.nodes.Document import org.wordpress.android.util.helpers.MediaFile +import java.util.Locale import java.util.regex.Pattern class CoverBlockProcessor( @@ -22,7 +23,7 @@ class CoverBlockProcessor( return StringBuilder() .append(innerMatcher.group(1)) .append(innerProcessed) - .append(innerMatcher.group(3)) + .append(innerMatcher.group(GROUP_3)) .toString() } @@ -31,7 +32,7 @@ class CoverBlockProcessor( override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { val id = jsonAttributes["id"] - if (id != null && !id.isJsonNull && id.asInt == localId.toInt(10)) { + if (id != null && !id.isJsonNull && id.asInt == localId.toInt(RADIX)) { addIntPropertySafely(jsonAttributes, "id", remoteId) jsonAttributes.addProperty("url", remoteUrl) @@ -52,43 +53,40 @@ class CoverBlockProcessor( val targetDiv = document.selectFirst(".wp-block-cover") // if a match is found, proceed with replacement - if (targetDiv != null) { + return targetDiv?.let { targetDivElement -> if (hasVideoBackground) { - val videoElement = targetDiv.selectFirst("video") - if (videoElement != null) { - videoElement.attr("src", remoteUrl) - } else { - return false - } + val videoElement = targetDivElement.selectFirst("video") + videoElement?.attr("src", remoteUrl) ?: return false } else { // replace background-image url in style attribute - val style = PATTERN_BACKGROUND_IMAGE_URL.matcher(targetDiv.attr("style")) - .replaceFirst(String.format("background-image:url(%1\$s)", remoteUrl)) - targetDiv.attr("style", style) + val style = PATTERN_BACKGROUND_IMAGE_URL.matcher(targetDivElement.attr("style")) + .replaceFirst(String.format(Locale.getDefault(), "background-image:url(%1\$s)", remoteUrl)) + targetDivElement.attr("style", style) } // return injected block - return true - } - - return false + true + } ?: false } companion object { /** * Template pattern used to match and splice cover inner blocks */ - private val PATTERN_COVER_INNER: Pattern = Pattern.compile( + private val PATTERN_COVER_INNER = Pattern.compile( StringBuilder() .append("(^.*?
\\s*)") .append("(.*)") // inner block contents - .append("(\\s*
\\s*\\s*.*)").toString(), + .append("(\\s*\\s*\\s*.*)") + .toString(), Pattern.DOTALL ) /** * Pattern to match background-image url in cover block html content */ - private val PATTERN_BACKGROUND_IMAGE_URL: Pattern = Pattern.compile("background-image:\\s*url\\([^)]+\\)") + private val PATTERN_BACKGROUND_IMAGE_URL = Pattern.compile("background-image:\\s*url\\([^)]+\\)") + private const val GROUP_3 = 3 + private const val RADIX = 10 } } From 220453d389b652ff26a044d14162c6ba417d5556 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 19:41:50 +0300 Subject: [PATCH 12/24] Add null annotations to GalleryBlockProcessor --- .../GalleryBlockProcessor.java | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java index 031e623b8021..6425f9057f52 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java @@ -1,6 +1,7 @@ package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; import androidx.annotation.NonNull; +import androidx.annotation.Nullable; import com.google.gson.JsonArray; import com.google.gson.JsonElement; @@ -18,13 +19,17 @@ import static org.wordpress.android.util.AppLog.T.MEDIA; public class GalleryBlockProcessor extends BlockProcessor { + @NonNull private final MediaUploadCompletionProcessor mMediaUploadCompletionProcessor; + @Nullable private String mAttachmentPageUrl; + @Nullable private String mLinkTo; /** * Query selector for selecting the img element from gallery which needs processing */ + @NonNull private String mGalleryImageQuerySelector; /** @@ -36,7 +41,7 @@ public class GalleryBlockProcessor extends BlockProcessor { .append("(\\s*\\s*.*)").toString(), Pattern.DOTALL); public GalleryBlockProcessor(@NonNull String localId, @NonNull MediaFile mediaFile, @NonNull String siteUrl, - MediaUploadCompletionProcessor mediaUploadCompletionProcessor) { + @NonNull MediaUploadCompletionProcessor mediaUploadCompletionProcessor) { super(localId, mediaFile); mMediaUploadCompletionProcessor = mediaUploadCompletionProcessor; mGalleryImageQuerySelector = new StringBuilder() From 38a7891c92a104aa4173557a0c800d806fec0d97 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 19:42:26 +0300 Subject: [PATCH 13/24] Rename .java to .kt --- .../{GalleryBlockProcessor.java => GalleryBlockProcessor.kt} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/{GalleryBlockProcessor.java => GalleryBlockProcessor.kt} (100%) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt similarity index 100% rename from WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.java rename to WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt From 23fdbec6c2e79d4312e0fc9868564742c6096d19 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 19:42:26 +0300 Subject: [PATCH 14/24] Convert GalleryBlockProcessor to Kotlin --- .../GalleryBlockProcessor.kt | 173 ++++++++---------- 1 file changed, 74 insertions(+), 99 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt index 6425f9057f52..1d2e57578ba8 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt @@ -1,137 +1,112 @@ -package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; - -import androidx.annotation.NonNull; -import androidx.annotation.Nullable; - -import com.google.gson.JsonArray; -import com.google.gson.JsonElement; -import com.google.gson.JsonObject; -import com.google.gson.JsonPrimitive; - -import org.jsoup.nodes.Document; -import org.jsoup.nodes.Element; -import org.wordpress.android.util.AppLog; -import org.wordpress.android.util.helpers.MediaFile; - -import java.util.regex.Matcher; -import java.util.regex.Pattern; - -import static org.wordpress.android.util.AppLog.T.MEDIA; - -public class GalleryBlockProcessor extends BlockProcessor { - @NonNull - private final MediaUploadCompletionProcessor mMediaUploadCompletionProcessor; - @Nullable - private String mAttachmentPageUrl; - @Nullable - private String mLinkTo; +package org.wordpress.android.ui.posts.mediauploadcompletionprocessors + +import com.google.gson.JsonObject +import com.google.gson.JsonPrimitive +import org.jsoup.nodes.Document +import org.wordpress.android.util.AppLog +import org.wordpress.android.util.helpers.MediaFile +import java.util.regex.Pattern + +class GalleryBlockProcessor( + localId: String, mediaFile: MediaFile, siteUrl: String, + private val mMediaUploadCompletionProcessor: MediaUploadCompletionProcessor +) : BlockProcessor(localId, mediaFile) { + private val mAttachmentPageUrl: String? = mediaFile.getAttachmentPageURL(siteUrl) + private var mLinkTo: String? = null /** * Query selector for selecting the img element from gallery which needs processing */ - @NonNull - private String mGalleryImageQuerySelector; + private val mGalleryImageQuerySelector = StringBuilder() + .append("img[data-id=\"") + .append(localId) + .append("\"]") + .toString() - /** - * Template pattern used to match and splice inner image blocks in the refactored gallery format - */ - private static final Pattern PATTERN_GALLERY_INNER = Pattern.compile(new StringBuilder() - .append("(^.*?
\\s*)") - .append("(.*)") // inner block contents - .append("(\\s*
\\s*.*)").toString(), Pattern.DOTALL); - - public GalleryBlockProcessor(@NonNull String localId, @NonNull MediaFile mediaFile, @NonNull String siteUrl, - @NonNull MediaUploadCompletionProcessor mediaUploadCompletionProcessor) { - super(localId, mediaFile); - mMediaUploadCompletionProcessor = mediaUploadCompletionProcessor; - mGalleryImageQuerySelector = new StringBuilder() - .append("img[data-id=\"") - .append(localId) - .append("\"]") - .toString(); - mAttachmentPageUrl = mediaFile.getAttachmentPageURL(siteUrl); - } - - @Override - public boolean processBlockContentDocument(@NonNull Document document) { + override fun processBlockContentDocument(document: Document): Boolean { // select image element with our local id - Element targetImg = document.select(mGalleryImageQuerySelector).first(); + val targetImg = document.select(mGalleryImageQuerySelector).first() // if a match is found, proceed with replacement if (targetImg != null) { // replace attributes - targetImg.attr("src", remoteUrl); - targetImg.attr("data-id", remoteId); - targetImg.attr("data-full-url", remoteUrl); - targetImg.attr("data-link", mAttachmentPageUrl); + targetImg.attr("src", remoteUrl) + targetImg.attr("data-id", remoteId) + targetImg.attr("data-full-url", remoteUrl) + targetImg.attr("data-link", mAttachmentPageUrl) // replace class - targetImg.removeClass("wp-image-" + localId); - targetImg.addClass("wp-image-" + remoteId); + targetImg.removeClass("wp-image-$localId") + targetImg.addClass("wp-image-$remoteId") // set parent anchor href if necessary - Element parent = targetImg.parent(); - if (parent != null && parent.is("a") && mLinkTo != null) { - switch (mLinkTo) { - case "file": - parent.attr("href", remoteUrl); - break; - case "post": - parent.attr("href", mAttachmentPageUrl); - break; - default: - return false; + val parent = targetImg.parent() + if (parent != null && parent.`is`("a") && mLinkTo != null) { + when (mLinkTo) { + "file" -> parent.attr("href", remoteUrl) + "post" -> parent.attr("href", mAttachmentPageUrl) + else -> return false } } // return injected block - return true; + return true } - return false; + return false } - @Override - public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { + override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { // The new format does not have an `ids` attributes, so returning false here will defer to recursive processing - JsonArray ids = jsonAttributes.getAsJsonArray("ids"); - if (ids == null || ids.isJsonNull()) { - return false; + val ids = jsonAttributes.getAsJsonArray("ids") + if (ids == null || ids.isJsonNull) { + return false } - JsonElement linkTo = jsonAttributes.get("linkTo"); - if (linkTo != null && !linkTo.isJsonNull()) { - mLinkTo = linkTo.getAsString(); + val linkTo = jsonAttributes["linkTo"] + if (linkTo != null && !linkTo.isJsonNull) { + mLinkTo = linkTo.asString } - for (int i = 0; i < ids.size(); i++) { - JsonElement id = ids.get(i); - if (id != null && !id.isJsonNull() && id.getAsString().equals(localId)) { + for (i in 0 until ids.size()) { + val id = ids[i] + if (id != null && !id.isJsonNull && id.asString == localId) { try { - ids.set(i, new JsonPrimitive(Integer.parseInt(remoteId, 10))); - } catch (NumberFormatException e) { - AppLog.e(MEDIA, e.getMessage()); + ids[i] = JsonPrimitive(remoteId.toInt(10)) + } catch (e: NumberFormatException) { + AppLog.e(AppLog.T.MEDIA, e.message) } - return true; + return true } } - return false; + return false } - @NonNull - @Override - public String processInnerBlock(@NonNull String block) { - Matcher innerMatcher = PATTERN_GALLERY_INNER.matcher(block); - boolean innerCapturesFound = innerMatcher.find(); + override fun processInnerBlock(block: String): String { + val innerMatcher = PATTERN_GALLERY_INNER.matcher(block) + val innerCapturesFound = innerMatcher.find() // process inner contents recursively if (innerCapturesFound) { - String innerProcessed = mMediaUploadCompletionProcessor.processContent(innerMatcher.group(2)); // - return new StringBuilder() - .append(innerMatcher.group(1)) - .append(innerProcessed) - .append(innerMatcher.group(3)) - .toString(); + val innerProcessed = + mMediaUploadCompletionProcessor.processContent(innerMatcher.group(2)) // + return StringBuilder() + .append(innerMatcher.group(1)) + .append(innerProcessed) + .append(innerMatcher.group(3)) + .toString() } - return block; + return block + } + + companion object { + /** + * Template pattern used to match and splice inner image blocks in the refactored gallery format + */ + private val PATTERN_GALLERY_INNER: Pattern = Pattern.compile( + StringBuilder() + .append("(^.*?
\\s*)") + .append("(.*)") // inner block contents + .append("(\\s*
\\s*.*)").toString(), Pattern.DOTALL + ) } } From 6dfda9ea4f333aca4631123714ad9aa4b9be3498 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Sun, 9 Jun 2024 20:10:48 +0300 Subject: [PATCH 15/24] Fix detekt errors after converting GalleryBlockProcessor to Kotlin --- .../GalleryBlockProcessor.kt | 84 ++++++++++--------- 1 file changed, 43 insertions(+), 41 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt index 1d2e57578ba8..fd325ebe8f19 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/GalleryBlockProcessor.kt @@ -8,16 +8,18 @@ import org.wordpress.android.util.helpers.MediaFile import java.util.regex.Pattern class GalleryBlockProcessor( - localId: String, mediaFile: MediaFile, siteUrl: String, - private val mMediaUploadCompletionProcessor: MediaUploadCompletionProcessor + localId: String, + mediaFile: MediaFile, + siteUrl: String, + private val mediaUploadCompletionProcessor: MediaUploadCompletionProcessor ) : BlockProcessor(localId, mediaFile) { - private val mAttachmentPageUrl: String? = mediaFile.getAttachmentPageURL(siteUrl) - private var mLinkTo: String? = null + private val attachmentPageUrl = mediaFile.getAttachmentPageURL(siteUrl) + private var linkTo: String? = null /** * Query selector for selecting the img element from gallery which needs processing */ - private val mGalleryImageQuerySelector = StringBuilder() + private val galleryImageQuerySelector = StringBuilder() .append("img[data-id=\"") .append(localId) .append("\"]") @@ -25,56 +27,54 @@ class GalleryBlockProcessor( override fun processBlockContentDocument(document: Document): Boolean { // select image element with our local id - val targetImg = document.select(mGalleryImageQuerySelector).first() + val targetImg = document.select(galleryImageQuerySelector).first() // if a match is found, proceed with replacement - if (targetImg != null) { + return targetImg?.let { // replace attributes - targetImg.attr("src", remoteUrl) - targetImg.attr("data-id", remoteId) - targetImg.attr("data-full-url", remoteUrl) - targetImg.attr("data-link", mAttachmentPageUrl) + it.attr("src", remoteUrl) + it.attr("data-id", remoteId) + it.attr("data-full-url", remoteUrl) + it.attr("data-link", attachmentPageUrl) // replace class - targetImg.removeClass("wp-image-$localId") - targetImg.addClass("wp-image-$remoteId") + it.removeClass("wp-image-$localId") + it.addClass("wp-image-$remoteId") // set parent anchor href if necessary - val parent = targetImg.parent() - if (parent != null && parent.`is`("a") && mLinkTo != null) { - when (mLinkTo) { + val parent = it.parent() + if (parent != null && parent.`is`("a") && linkTo != null) { + when (linkTo) { "file" -> parent.attr("href", remoteUrl) - "post" -> parent.attr("href", mAttachmentPageUrl) + "post" -> parent.attr("href", attachmentPageUrl) else -> return false } } // return injected block - return true - } - - return false + true + } ?: false } override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { // The new format does not have an `ids` attributes, so returning false here will defer to recursive processing val ids = jsonAttributes.getAsJsonArray("ids") - if (ids == null || ids.isJsonNull) { - return false - } - val linkTo = jsonAttributes["linkTo"] - if (linkTo != null && !linkTo.isJsonNull) { - mLinkTo = linkTo.asString - } - for (i in 0 until ids.size()) { - val id = ids[i] - if (id != null && !id.isJsonNull && id.asString == localId) { - try { - ids[i] = JsonPrimitive(remoteId.toInt(10)) - } catch (e: NumberFormatException) { - AppLog.e(AppLog.T.MEDIA, e.message) + + if (ids != null && !ids.isJsonNull) { + val linkTo = jsonAttributes["linkTo"] + if (linkTo != null && !linkTo.isJsonNull) { + this.linkTo = linkTo.asString + } + + ids.forEachIndexed { index, jsonElement -> + if (jsonElement != null && !jsonElement.isJsonNull && jsonElement.asString == localId) { + try { + ids[index] = JsonPrimitive(remoteId.toInt(RADIX)) + } catch (e: NumberFormatException) { + AppLog.e(AppLog.T.MEDIA, e.message) + } + return true } - return true } } return false @@ -86,12 +86,11 @@ class GalleryBlockProcessor( // process inner contents recursively if (innerCapturesFound) { - val innerProcessed = - mMediaUploadCompletionProcessor.processContent(innerMatcher.group(2)) // + val innerProcessed = mediaUploadCompletionProcessor.processContent(innerMatcher.group(2)) return StringBuilder() .append(innerMatcher.group(1)) .append(innerProcessed) - .append(innerMatcher.group(3)) + .append(innerMatcher.group(GROUP_3)) .toString() } @@ -102,11 +101,14 @@ class GalleryBlockProcessor( /** * Template pattern used to match and splice inner image blocks in the refactored gallery format */ - private val PATTERN_GALLERY_INNER: Pattern = Pattern.compile( + private val PATTERN_GALLERY_INNER = Pattern.compile( StringBuilder() .append("(^.*?
\\s*)") .append("(.*)") // inner block contents - .append("(\\s*
\\s*.*)").toString(), Pattern.DOTALL + .append("(\\s*\\s*.*)").toString(), + Pattern.DOTALL ) + private const val RADIX = 10 + private const val GROUP_3 = 3 } } From fedca5cd5d35c3f08a03718414b8b9e392952c8e Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Mon, 10 Jun 2024 13:07:40 +0300 Subject: [PATCH 16/24] Rename .java to .kt --- .../{ImageBlockProcessor.java => ImageBlockProcessor.kt} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/{ImageBlockProcessor.java => ImageBlockProcessor.kt} (100%) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt similarity index 100% rename from WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.java rename to WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt From b5c6b6c9d909d579e1f21a01f68be2b2e783ee54 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Mon, 10 Jun 2024 13:07:40 +0300 Subject: [PATCH 17/24] Convert ImageBlockProcessor to Kotlin --- .../ImageBlockProcessor.kt | 49 +++++++------------ 1 file changed, 19 insertions(+), 30 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt index 9b2c9e86a7df..f7a3d4fbf5f2 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt @@ -1,47 +1,36 @@ -package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; +package org.wordpress.android.ui.posts.mediauploadcompletionprocessors -import androidx.annotation.NonNull; +import com.google.gson.JsonObject +import org.jsoup.nodes.Document +import org.wordpress.android.util.helpers.MediaFile -import com.google.gson.JsonElement; -import com.google.gson.JsonObject; - -import org.jsoup.nodes.Document; -import org.jsoup.nodes.Element; -import org.wordpress.android.util.helpers.MediaFile; - - -public class ImageBlockProcessor extends BlockProcessor { - public ImageBlockProcessor(@NonNull String localId, @NonNull MediaFile mediaFile) { - super(localId, mediaFile); - } - - @Override - public boolean processBlockContentDocument(@NonNull Document document) { +class ImageBlockProcessor(localId: String, mediaFile: MediaFile) : + BlockProcessor(localId, mediaFile) { + override fun processBlockContentDocument(document: Document): Boolean { // select image element with our local id - Element targetImg = document.select("img").first(); + val targetImg = document.select("img").first() // if a match is found, proceed with replacement if (targetImg != null) { // replace attributes - targetImg.attr("src", remoteUrl); + targetImg.attr("src", remoteUrl) // replace class - targetImg.removeClass("wp-image-" + localId); - targetImg.addClass("wp-image-" + remoteId); + targetImg.removeClass("wp-image-$localId") + targetImg.addClass("wp-image-$remoteId") - return true; + return true } - return false; + return false } - @Override - public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { - JsonElement id = jsonAttributes.get("id"); - if (id != null && !id.isJsonNull() && id.getAsString().equals(localId)) { - addIntPropertySafely(jsonAttributes, "id", remoteId); - return true; + override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { + val id = jsonAttributes["id"] + if (id != null && !id.isJsonNull && id.asString == localId) { + addIntPropertySafely(jsonAttributes, "id", remoteId) + return true } - return false; + return false } } From 5d5048dea310395e1a2416417f95ccde66dd386b Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Mon, 10 Jun 2024 13:10:45 +0300 Subject: [PATCH 18/24] Reformat ImageBlockProcessor after conversion --- .../ImageBlockProcessor.kt | 24 +++++++++---------- 1 file changed, 11 insertions(+), 13 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt index f7a3d4fbf5f2..5165596d47f1 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/ImageBlockProcessor.kt @@ -4,33 +4,31 @@ import com.google.gson.JsonObject import org.jsoup.nodes.Document import org.wordpress.android.util.helpers.MediaFile -class ImageBlockProcessor(localId: String, mediaFile: MediaFile) : - BlockProcessor(localId, mediaFile) { +class ImageBlockProcessor(localId: String, mediaFile: MediaFile) : BlockProcessor(localId, mediaFile) { override fun processBlockContentDocument(document: Document): Boolean { // select image element with our local id val targetImg = document.select("img").first() // if a match is found, proceed with replacement - if (targetImg != null) { + return targetImg?.let { // replace attributes - targetImg.attr("src", remoteUrl) + it.attr("src", remoteUrl) // replace class - targetImg.removeClass("wp-image-$localId") - targetImg.addClass("wp-image-$remoteId") + it.removeClass("wp-image-$localId") + it.addClass("wp-image-$remoteId") - return true - } - - return false + true + } ?: false } override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { val id = jsonAttributes["id"] - if (id != null && !id.isJsonNull && id.asString == localId) { + return if (id != null && !id.isJsonNull && id.asString == localId) { addIntPropertySafely(jsonAttributes, "id", remoteId) - return true + true + } else { + false } - return false } } From 9929f5c0b5934bce860e7488a122b23bb87bb8e7 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Mon, 10 Jun 2024 13:16:06 +0300 Subject: [PATCH 19/24] Rename .java to .kt --- .../{MediaTextBlockProcessor.java => MediaTextBlockProcessor.kt} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/{MediaTextBlockProcessor.java => MediaTextBlockProcessor.kt} (100%) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt similarity index 100% rename from WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.java rename to WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt From 78426b0ef5dd964ceb1b3eca7867a953dd221b6e Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Mon, 10 Jun 2024 13:16:06 +0300 Subject: [PATCH 20/24] Convert MediaTextBlockProcessor to Kotlin --- .../MediaTextBlockProcessor.kt | 54 ++++++++----------- 1 file changed, 22 insertions(+), 32 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt index 0bdbccfe74d9..06f13d6242ed 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt @@ -1,60 +1,50 @@ -package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; +package org.wordpress.android.ui.posts.mediauploadcompletionprocessors -import androidx.annotation.NonNull; +import com.google.gson.JsonObject +import org.jsoup.nodes.Document +import org.wordpress.android.util.helpers.MediaFile -import com.google.gson.JsonElement; -import com.google.gson.JsonObject; - -import org.jsoup.nodes.Document; -import org.jsoup.nodes.Element; -import org.wordpress.android.util.helpers.MediaFile; - -public class MediaTextBlockProcessor extends BlockProcessor { - public MediaTextBlockProcessor(@NonNull String localId, @NonNull MediaFile mediaFile) { - super(localId, mediaFile); - } - - @Override - public boolean processBlockContentDocument(@NonNull Document document) { +class MediaTextBlockProcessor(localId: String, mediaFile: MediaFile) : + BlockProcessor(localId, mediaFile) { + override fun processBlockContentDocument(document: Document): Boolean { // select image element with our local id - Element targetImg = document.select("img").first(); + val targetImg = document.select("img").first() // if a match is found for img, proceed with replacement if (targetImg != null) { // replace attributes - targetImg.attr("src", remoteUrl); + targetImg.attr("src", remoteUrl) // replace class - targetImg.removeClass("wp-image-" + localId); - targetImg.addClass("wp-image-" + remoteId); + targetImg.removeClass("wp-image-$localId") + targetImg.addClass("wp-image-$remoteId") // return injected block - return true; + return true } else { // try video // select video element with our local id - Element targetVideo = document.select("video").first(); + val targetVideo = document.select("video").first() // if a match is found for video, proceed with replacement if (targetVideo != null) { // replace attribute - targetVideo.attr("src", remoteUrl); + targetVideo.attr("src", remoteUrl) // return injected block - return true; + return true } } - return false; + return false } - @Override - public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { - JsonElement id = jsonAttributes.get("mediaId"); - if (id != null && !id.isJsonNull() && id.getAsString().equals(localId)) { - addIntPropertySafely(jsonAttributes, "mediaId", remoteId); - return true; + override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { + val id = jsonAttributes["mediaId"] + if (id != null && !id.isJsonNull && id.asString == localId) { + addIntPropertySafely(jsonAttributes, "mediaId", remoteId) + return true } - return false; + return false } } From 31798bfcadec830ec5413de8f93ad5d1d75ada91 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Mon, 10 Jun 2024 18:54:03 +0300 Subject: [PATCH 21/24] Reformat MediaTextBlockProcessor after conversion --- .../MediaTextBlockProcessor.kt | 23 ++++++++----------- 1 file changed, 10 insertions(+), 13 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt index 06f13d6242ed..810c59709c54 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/MediaTextBlockProcessor.kt @@ -4,14 +4,13 @@ import com.google.gson.JsonObject import org.jsoup.nodes.Document import org.wordpress.android.util.helpers.MediaFile -class MediaTextBlockProcessor(localId: String, mediaFile: MediaFile) : - BlockProcessor(localId, mediaFile) { +class MediaTextBlockProcessor(localId: String, mediaFile: MediaFile) : BlockProcessor(localId, mediaFile) { override fun processBlockContentDocument(document: Document): Boolean { // select image element with our local id val targetImg = document.select("img").first() // if a match is found for img, proceed with replacement - if (targetImg != null) { + return if (targetImg != null) { // replace attributes targetImg.attr("src", remoteUrl) @@ -20,31 +19,29 @@ class MediaTextBlockProcessor(localId: String, mediaFile: MediaFile) : targetImg.addClass("wp-image-$remoteId") // return injected block - return true + true } else { // try video // select video element with our local id val targetVideo = document.select("video").first() // if a match is found for video, proceed with replacement - if (targetVideo != null) { + targetVideo?.let { // replace attribute targetVideo.attr("src", remoteUrl) // return injected block - return true - } + true + } ?: false } - - return false } override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { val id = jsonAttributes["mediaId"] - if (id != null && !id.isJsonNull && id.asString == localId) { + return if (id != null && !id.isJsonNull && id.asString == localId) { addIntPropertySafely(jsonAttributes, "mediaId", remoteId) - return true + true + } else { + false } - - return false } } From ae9d19a9e378116e7c3fde9f83073274ed775469 Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Mon, 10 Jun 2024 19:22:54 +0300 Subject: [PATCH 22/24] Rename .java to .kt --- .../{VideoBlockProcessor.java => VideoBlockProcessor.kt} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/{VideoBlockProcessor.java => VideoBlockProcessor.kt} (100%) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.java b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt similarity index 100% rename from WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.java rename to WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt From e639e666d0273d7d8ced5313fe474e57dc8045cf Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Mon, 10 Jun 2024 19:22:54 +0300 Subject: [PATCH 23/24] Convert VideoBlockProcessor to Kotlin --- .../VideoBlockProcessor.kt | 44 +++++++------------ 1 file changed, 17 insertions(+), 27 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt index dc290b33a8f3..0cb09265af2d 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt @@ -1,43 +1,33 @@ -package org.wordpress.android.ui.posts.mediauploadcompletionprocessors; +package org.wordpress.android.ui.posts.mediauploadcompletionprocessors -import androidx.annotation.NonNull; +import com.google.gson.JsonObject +import org.jsoup.nodes.Document +import org.wordpress.android.util.helpers.MediaFile -import com.google.gson.JsonElement; -import com.google.gson.JsonObject; - -import org.jsoup.nodes.Document; -import org.jsoup.nodes.Element; -import org.wordpress.android.util.helpers.MediaFile; - -public class VideoBlockProcessor extends BlockProcessor { - public VideoBlockProcessor(@NonNull String localId, @NonNull MediaFile mediaFile) { - super(localId, mediaFile); - } - - @Override - public boolean processBlockContentDocument(@NonNull Document document) { +class VideoBlockProcessor(localId: String, mediaFile: MediaFile) : + BlockProcessor(localId, mediaFile) { + override fun processBlockContentDocument(document: Document): Boolean { // select video element with our local id - Element targetVideo = document.select("video").first(); + val targetVideo = document.select("video").first() // if a match is found for video, proceed with replacement if (targetVideo != null) { // replace attribute - targetVideo.attr("src", remoteUrl); + targetVideo.attr("src", remoteUrl) // return injected block - return true; + return true } - return false; + return false } - @Override - public boolean processBlockJsonAttributes(@NonNull JsonObject jsonAttributes) { - JsonElement id = jsonAttributes.get("id"); - if (id != null && !id.isJsonNull() && id.getAsString().equals(localId)) { - addIntPropertySafely(jsonAttributes, "id", remoteId); - return true; + override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { + val id = jsonAttributes["id"] + if (id != null && !id.isJsonNull && id.asString == localId) { + addIntPropertySafely(jsonAttributes, "id", remoteId) + return true } - return false; + return false } } From 4d4abeb1eda291e92389dbea8e019b1470acfdaa Mon Sep 17 00:00:00 2001 From: Irfan Omur Date: Mon, 10 Jun 2024 19:24:00 +0300 Subject: [PATCH 24/24] Reformat VideoBlockProcessor after conversion --- .../VideoBlockProcessor.kt | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt index 0cb09265af2d..4ede032a5b20 100644 --- a/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt +++ b/WordPress/src/main/java/org/wordpress/android/ui/posts/mediauploadcompletionprocessors/VideoBlockProcessor.kt @@ -4,30 +4,28 @@ import com.google.gson.JsonObject import org.jsoup.nodes.Document import org.wordpress.android.util.helpers.MediaFile -class VideoBlockProcessor(localId: String, mediaFile: MediaFile) : - BlockProcessor(localId, mediaFile) { +class VideoBlockProcessor(localId: String, mediaFile: MediaFile) : BlockProcessor(localId, mediaFile) { override fun processBlockContentDocument(document: Document): Boolean { // select video element with our local id val targetVideo = document.select("video").first() // if a match is found for video, proceed with replacement - if (targetVideo != null) { + return targetVideo?.let { // replace attribute targetVideo.attr("src", remoteUrl) // return injected block - return true - } - - return false + true + } ?: false } override fun processBlockJsonAttributes(jsonAttributes: JsonObject): Boolean { val id = jsonAttributes["id"] - if (id != null && !id.isJsonNull && id.asString == localId) { + return if (id != null && !id.isJsonNull && id.asString == localId) { addIntPropertySafely(jsonAttributes, "id", remoteId) - return true + true + } else { + false } - return false } }