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 = () => { - +