diff --git a/i18n/en.pot b/i18n/en.pot
index 26c9be81f..673b83104 100644
--- a/i18n/en.pot
+++ b/i18n/en.pot
@@ -5,8 +5,8 @@ msgstr ""
"Content-Type: text/plain; charset=utf-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Plural-Forms: nplurals=2; plural=(n != 1)\n"
-"POT-Creation-Date: 2024-02-12T17:08:02.188Z\n"
-"PO-Revision-Date: 2024-02-12T17:08:02.189Z\n"
+"POT-Creation-Date: 2024-03-01T15:50:32.586Z\n"
+"PO-Revision-Date: 2024-03-01T15:50:32.586Z\n"
msgid "Something went wrong when loading the current user!"
msgstr "Something went wrong when loading the current user!"
@@ -694,6 +694,12 @@ msgstr "Indexes"
msgid "Details by type"
msgstr "Details by type"
+msgid "All existing property values will be replaced"
+msgstr "All existing property values will be replaced"
+
+msgid "Values will be overwritten, even if the new value is null"
+msgstr "Values will be overwritten, even if the new value is null"
+
msgid "Advanced options"
msgstr "Advanced options"
diff --git a/src/components/MergeOperation/MergeOperation.js b/src/components/MergeOperation/MergeOperation.js
new file mode 100644
index 000000000..1d1849546
--- /dev/null
+++ b/src/components/MergeOperation/MergeOperation.js
@@ -0,0 +1,27 @@
+import i18n from '@dhis2/d2-i18n'
+import { NoticeBox } from '@dhis2/ui'
+import React from 'react'
+
+const mergeOperation = 'REPLACE'
+
+const MERGE_NOTICE_TITLE = i18n.t(
+ 'All existing property values will be replaced'
+)
+const MERGE_NOTICE_TEXT = i18n.t(
+ 'Values will be overwritten, even if the new value is null'
+)
+
+const MergeOperationNotice = () => {
+ return (
+
+
+ {MERGE_NOTICE_TEXT}
+
+
+ )
+}
+
+export { mergeOperation, MergeOperationNotice }
diff --git a/src/components/index.js b/src/components/index.js
index 4d1017a17..e6d231112 100644
--- a/src/components/index.js
+++ b/src/components/index.js
@@ -48,3 +48,7 @@ export { SchemeContainer } from './ElementSchemes/SchemeContainer.js'
export { StyledField } from './StyledField/StyledField.js'
export { Tooltip } from './Tooltip/Tooltip.js'
export { ValidationSummary } from './ValidationSummary/ValidationSummary.js'
+export {
+ mergeOperation,
+ MergeOperationNotice,
+} from './MergeOperation/MergeOperation.js'
diff --git a/src/pages/MetadataImport/MetadataImport.js b/src/pages/MetadataImport/MetadataImport.js
index 822a87d6f..eb4ba07f3 100644
--- a/src/pages/MetadataImport/MetadataImport.js
+++ b/src/pages/MetadataImport/MetadataImport.js
@@ -9,6 +9,8 @@ import {
MoreOptions,
BasicOptions,
ValidationSummary,
+ mergeOperation,
+ MergeOperationNotice,
} from '../../components/index.js'
import {
FileUpload,
@@ -26,8 +28,6 @@ import {
defaultImportStrategyOption,
AtomicMode,
defaultAtomicModeOption,
- MergeMode,
- defaultMergeModeOption,
FlushMode,
defaultFlushModeOption,
SkipSharing,
@@ -67,7 +67,7 @@ const createInitialValues = (prevJobDetails) => ({
defaultFirstRowIsHeaderOption
),
atomicMode: prevJobDetails.atomicMode || defaultAtomicModeOption,
- mergeMode: prevJobDetails.mergeMode || defaultMergeModeOption,
+ mergeMode: prevJobDetails.mergeMode || mergeOperation,
flushMode: prevJobDetails.flushMode || defaultFlushModeOption,
inclusionStrategy:
prevJobDetails.inclusionStrategy || defaultInclusionStrategyOption,
@@ -146,7 +146,7 @@ const MetadataImport = () => {
-
+