From ed644356e45b508d35f92ddcaca9eaf400847d0f Mon Sep 17 00:00:00 2001 From: volar Date: Mon, 9 Oct 2023 11:06:42 +0200 Subject: [PATCH 1/3] rename element key to property + make api safe to consume both variants --- .../AssetCustomMetadataElement.vue | 6 ++-- .../AssetCustomMetadataForm.vue | 12 ++++---- .../AssetCustomMetadataFormMassOperations.vue | 24 ++++++++-------- .../DamConfigAssetCustomFormService.ts | 13 +++++---- .../DamConfigDistributionCustomFormService.ts | 3 +- .../TempMapCustomFormElementHelper.ts | 28 +++++++++++++++++++ src/services/api/coreDam/assetApi.ts | 2 +- .../api/coreDam/assetCustomFormApi.ts | 7 +++-- src/stores/coreDam/uploadQueuesStore.ts | 9 +++--- src/types/coreDam/DamConfigAssetCustomForm.ts | 11 +++++++- .../queue/AssetQueueSelectedSidebar.vue | 20 ++++++------- .../DistributionCustomMetadataForm.vue | 8 +++--- 12 files changed, 92 insertions(+), 51 deletions(-) create mode 100644 src/services/TempMapCustomFormElementHelper.ts diff --git a/src/components/coreDam/customMetadata/AssetCustomMetadataElement.vue b/src/components/coreDam/customMetadata/AssetCustomMetadataElement.vue index 0095d712..d124bc49 100644 --- a/src/components/coreDam/customMetadata/AssetCustomMetadataElement.vue +++ b/src/components/coreDam/customMetadata/AssetCustomMetadataElement.vue @@ -11,7 +11,7 @@ const props = withDefaults( defineProps<{ modelValue: any config: DamConfigAssetCustomFormElement - elementKey: string + elementProperty: string validationScope?: ValidationScope }>(), { @@ -19,7 +19,7 @@ const props = withDefaults( } ) const emit = defineEmits<{ - (e: 'update:modelValue', data: { key: string; value: any }): void + (e: 'update:modelValue', data: { property: string; value: any }): void (e: 'blur', data: any): void }>() @@ -31,7 +31,7 @@ const fixValue = (value: any) => { } const updateModelValue = (value: any) => { - emit('update:modelValue', { key: props.elementKey, value: fixValue(value) }) + emit('update:modelValue', { property: props.elementProperty, value: fixValue(value) }) } const modelValueComputed = computed(() => { diff --git a/src/components/coreDam/customMetadata/AssetCustomMetadataForm.vue b/src/components/coreDam/customMetadata/AssetCustomMetadataForm.vue index 35187839..b582a118 100644 --- a/src/components/coreDam/customMetadata/AssetCustomMetadataForm.vue +++ b/src/components/coreDam/customMetadata/AssetCustomMetadataForm.vue @@ -24,9 +24,9 @@ const emit = defineEmits<{ const { showAllMetadata, toggleShowAllMetadata } = useAssetCustomMetadataForm() -const updateModelValue = (data: { key: string; value: any }) => { +const updateModelValue = (data: { property: string; value: any }) => { const updated = {} as { [key: string]: any } - updated[data.key] = data.value + updated[data.property] = data.value emit('update:modelValue', { ...props.modelValue, ...updated }) emit('anyChange') } @@ -73,8 +73,8 @@ const enableShowHide = computed(() => { @@ -95,8 +95,8 @@ const enableShowHide = computed(() => { diff --git a/src/components/coreDam/customMetadata/AssetCustomMetadataFormMassOperations.vue b/src/components/coreDam/customMetadata/AssetCustomMetadataFormMassOperations.vue index 34ec3c44..b534a89b 100644 --- a/src/components/coreDam/customMetadata/AssetCustomMetadataFormMassOperations.vue +++ b/src/components/coreDam/customMetadata/AssetCustomMetadataFormMassOperations.vue @@ -16,21 +16,21 @@ const props = withDefaults( ) const emit = defineEmits<{ (e: 'update:modelValue', data: any): void - (e: 'fillEmptyField', data: { assetType: AssetType; elementKey: string; value: any }): void - (e: 'replaceField', data: { assetType: AssetType; elementKey: string; value: any }): void + (e: 'fillEmptyField', data: { assetType: AssetType; elementProperty: string; value: any }): void + (e: 'replaceField', data: { assetType: AssetType; elementProperty: string; value: any }): void }>() -const updateModelValue = (data: { key: string; value: any }) => { +const updateModelValue = (data: { property: string; value: any }) => { const updated = {} as { [key: string]: any } - updated[data.key] = data.value + updated[data.property] = data.value emit('update:modelValue', { ...props.modelValue, ...updated }) } -const fillEmptyField = (elementKey: string, value: any) => { - emit('fillEmptyField', { assetType: props.assetType, elementKey, value }) +const fillEmptyField = (elementProperty: string, value: any) => { + emit('fillEmptyField', { assetType: props.assetType, elementProperty, value }) } -const replaceField = (elementKey: string, value: any) => { - emit('replaceField', { assetType: props.assetType, elementKey, value }) +const replaceField = (elementProperty: string, value: any) => { + emit('replaceField', { assetType: props.assetType, elementProperty, value }) } const elements = computed(() => { @@ -50,8 +50,8 @@ const elements = computed(() => {
{ size="small" variant="text" class="mr-1" - @click.stop="fillEmptyField(element.key, modelValue[element.key])" + @click.stop="fillEmptyField(element.property, modelValue[element.property])" > { icon size="small" variant="text" - @click.stop="replaceField(element.key, modelValue[element.key])" + @click.stop="replaceField(element.property, modelValue[element.property])" > []) => { +const setDamConfigAssetCustomFormElements = (responses: Awaited<{ data: DamConfigAssetCustomFormElementTemp[] }>[]) => { try { - damConfigAssetCustomFormElements.image = responses[0].data - damConfigAssetCustomFormElements.audio = responses[1].data - damConfigAssetCustomFormElements.video = responses[2].data - damConfigAssetCustomFormElements.document = responses[3].data + damConfigAssetCustomFormElements.image = mapElementsWithKeyToProperty(responses[0].data) + damConfigAssetCustomFormElements.audio = mapElementsWithKeyToProperty(responses[1].data) + damConfigAssetCustomFormElements.video = mapElementsWithKeyToProperty(responses[2].data) + damConfigAssetCustomFormElements.document = mapElementsWithKeyToProperty(responses[3].data) damConfigAssetCustomFormElementsInitialized.value = true } catch (err) { diff --git a/src/services/DamConfigDistributionCustomFormService.ts b/src/services/DamConfigDistributionCustomFormService.ts index 493a0512..473b1969 100644 --- a/src/services/DamConfigDistributionCustomFormService.ts +++ b/src/services/DamConfigDistributionCustomFormService.ts @@ -1,6 +1,7 @@ import { type Ref, ref } from 'vue' import { fetchDistributionCustomFormElements } from '@/services/api/coreDam/assetCustomFormApi' import type { DistributionServiceName } from '@/types/coreDam/DamConfig' +import { mapElementsWithKeyToProperty } from '@/services/TempMapCustomFormElementHelper' export const damConfigDistributionCustomFormElements: Ref> = ref({}) @@ -12,7 +13,7 @@ export const loadDamConfigDistributionCustomFormElements = (distributionServiceN } fetchDistributionCustomFormElements(distributionServiceName) .then((res) => { - damConfigDistributionCustomFormElements.value[distributionServiceName] = res.data + damConfigDistributionCustomFormElements.value[distributionServiceName] = mapElementsWithKeyToProperty(res.data) resolve(true) return }) diff --git a/src/services/TempMapCustomFormElementHelper.ts b/src/services/TempMapCustomFormElementHelper.ts new file mode 100644 index 00000000..ea7f90fe --- /dev/null +++ b/src/services/TempMapCustomFormElementHelper.ts @@ -0,0 +1,28 @@ +// todo will be removed once rename key => property will be implemented + +import type { + DamConfigAssetCustomFormElement, + DamConfigAssetCustomFormElementTemp +} from '@/types/coreDam/DamConfigAssetCustomForm' +import { isDefined } from '@anzusystems/common-admin' + +export function mapElementsWithKeyToProperty +(items: Array +): Array { + return items.map(item => { + return { + id: item.id, + property: isDefined(item.property) ? item.property as string : item.key as string, + name: item.name, + position: item.position, + attributes: item.attributes, + createdAt: item.createdAt, + modifiedAt: item.modifiedAt, + createdBy: item.createdBy, + modifiedBy: item.modifiedBy, + _system: item._system, + _resourceName: item._resourceName, + } + }) + +} diff --git a/src/services/api/coreDam/assetApi.ts b/src/services/api/coreDam/assetApi.ts index bb8cfa0f..9222d981 100644 --- a/src/services/api/coreDam/assetApi.ts +++ b/src/services/api/coreDam/assetApi.ts @@ -173,7 +173,7 @@ const handleMetadataValidationError = (error: any, assetType: AssetType) => { const items = [] as ValidationError[] for (const [key, values] of Object.entries(data.fields)) { const field = key.split('.').pop() - const found = damConfigAssetCustomFormElements[assetType].find((item) => item.key === field) + const found = damConfigAssetCustomFormElements[assetType].find((item) => item.property === field) if (found) { items.push({ field: found.name, diff --git a/src/services/api/coreDam/assetCustomFormApi.ts b/src/services/api/coreDam/assetCustomFormApi.ts index 56e15150..0ae77728 100644 --- a/src/services/api/coreDam/assetCustomFormApi.ts +++ b/src/services/api/coreDam/assetCustomFormApi.ts @@ -5,13 +5,16 @@ import { SYSTEM_CORE_DAM } from '@/model/systems' import type { AssetType } from '@/model/coreDam/valueObject/AssetType' import type { DamConfigAssetCustomFormElement } from '@/types/coreDam/DamConfigAssetCustomForm' import type { DistributionServiceName } from '@/types/coreDam/DamConfig' +import type { + DamConfigAssetCustomFormElementTemp +} from '@/types/coreDam/DamConfigAssetCustomForm' const END_POINT = '/adm/v1/asset-custom-form' const ENTITY = 'assetCustomForm' // todo limit set to 100 for now, add load for pagination? export const fetchAssetCustomFormElements = (extSystem: IntegerId, assetType: AssetType) => - apiFetchOne<{ data: DamConfigAssetCustomFormElement[] }>( + apiFetchOne<{ data: DamConfigAssetCustomFormElementTemp[] }>( damClient, END_POINT + '/ext-system/:extSystem/type/:assetType/element?order[position]=asc&limit=100', { extSystem, assetType }, @@ -21,7 +24,7 @@ export const fetchAssetCustomFormElements = (extSystem: IntegerId, assetType: As // todo limit set to 100 for now, add load for pagination? export const fetchDistributionCustomFormElements = (distributionService: DistributionServiceName) => - apiFetchOne<{ data: DamConfigAssetCustomFormElement[] }>( + apiFetchOne<{ data: DamConfigAssetCustomFormElementTemp[] }>( damClient, END_POINT + '/distribution-service/:distributionService/element?order[position]=asc&limit=100', { distributionService }, diff --git a/src/stores/coreDam/uploadQueuesStore.ts b/src/stores/coreDam/uploadQueuesStore.ts index 719e2037..f8345bb9 100644 --- a/src/stores/coreDam/uploadQueuesStore.ts +++ b/src/stores/coreDam/uploadQueuesStore.ts @@ -8,7 +8,7 @@ import type { UploadQueue, UploadQueueItem } from '@/types/coreDam/UploadQueue' import { QueueItemStatus, QueueItemType } from '@/types/coreDam/UploadQueue' import type { AssetFileNullable } from '@/types/coreDam/File' import { LinkType } from '@/types/coreDam/File' -import type { AssetSearchListItemDto } from '@/types/coreDam/Asset' +import type { AssetDetailItemDto, AssetSearchListItemDto } from '@/types/coreDam/Asset' import { AssetStatus } from '@/model/coreDam/valueObject/AssetStatus' import { getAssetTypeByMimeType } from '@/services/upload/mimeTypeService' import { AssetType } from '@/model/coreDam/valueObject/AssetType' @@ -25,7 +25,6 @@ import { useCachedAuthors } from '@/views/coreDam/author/composables/cachedAutho import { useCachedKeywords } from '@/views/coreDam/keyword/composables/cachedKeywords' import { getAuthorConflicts, updateNewNames } from '@/services/AssetSuggestionsService' import { useAssetDetailStore } from '@/stores/coreDam/assetDetailStore' -import type { AssetDetailItemDto } from '@/types/coreDam/Asset' import { fileTypeFix } from '@/services/fileType' interface State { @@ -474,15 +473,15 @@ export const useUploadQueuesStore = defineStore('damUploadQueuesStore', { }, queueItemsReplaceEmptyCustomDataValue( queueId: string, - data: { assetType: AssetType; elementKey: string; value: any }, + data: { assetType: AssetType; elementProperty: string; value: any }, forceReplace = false ) { const items = this.queues[queueId].items for (let i = 0; i < items.length; i++) { const item = items[i] if (item.assetType !== data.assetType) continue - if (forceReplace || isUndefined(item.customData[data.elementKey]) || item.customData[data.elementKey] === '') { - item.customData[data.elementKey] = data.value + if (forceReplace || isUndefined(item.customData[data.elementProperty]) || item.customData[data.elementProperty] === '') { + item.customData[data.elementProperty] = data.value } } }, diff --git a/src/types/coreDam/DamConfigAssetCustomForm.ts b/src/types/coreDam/DamConfigAssetCustomForm.ts index 4fc35e00..4369f8fb 100644 --- a/src/types/coreDam/DamConfigAssetCustomForm.ts +++ b/src/types/coreDam/DamConfigAssetCustomForm.ts @@ -20,7 +20,16 @@ export interface DamConfigAssetCustomFormAttributes { export interface DamConfigAssetCustomFormElement extends AnzuUserAndTimeTrackingAware, ResourceNameSystemAware { id: DocId - key: string + property: string + name: string + position: number + attributes: DamConfigAssetCustomFormAttributes +} + +export interface DamConfigAssetCustomFormElementTemp extends AnzuUserAndTimeTrackingAware, ResourceNameSystemAware { + id: DocId + key?: string + property?: string name: string position: number attributes: DamConfigAssetCustomFormAttributes diff --git a/src/views/coreDam/asset/components/queue/AssetQueueSelectedSidebar.vue b/src/views/coreDam/asset/components/queue/AssetQueueSelectedSidebar.vue index e5502885..0deafe3d 100644 --- a/src/views/coreDam/asset/components/queue/AssetQueueSelectedSidebar.vue +++ b/src/views/coreDam/asset/components/queue/AssetQueueSelectedSidebar.vue @@ -25,10 +25,10 @@ const panels = ref>(['general']) const uploadQueuesStore = useUploadQueuesStore() -const fillEmptyField = (data: { assetType: AssetType; elementKey: string; value: any }) => { +const fillEmptyField = (data: { assetType: AssetType; elementProperty: string; value: any }) => { uploadQueuesStore.queueItemsReplaceEmptyCustomDataValue(props.queueId, data) } -const replaceField = (data: { assetType: AssetType; elementKey: string; value: any }) => { +const replaceField = (data: { assetType: AssetType; elementProperty: string; value: any }) => { uploadQueuesStore.queueItemsReplaceEmptyCustomDataValue(props.queueId, data, true) } const fillEmptyKeywords = () => { @@ -44,45 +44,45 @@ const replaceAuthors = () => { uploadQueuesStore.queueItemsReplaceEmptyAuthors(props.queueId, massOperationsAuthors.value, true) } const fillAll = (forceReplace = false) => { - for (const [elementKey, value] of Object.entries(massOperationsData.value.image)) { + for (const [elementProperty, value] of Object.entries(massOperationsData.value.image)) { uploadQueuesStore.queueItemsReplaceEmptyCustomDataValue( props.queueId, { assetType: AssetType.Image, - elementKey, + elementProperty, value, }, forceReplace ) } - for (const [elementKey, value] of Object.entries(massOperationsData.value.video)) { + for (const [elementProperty, value] of Object.entries(massOperationsData.value.video)) { uploadQueuesStore.queueItemsReplaceEmptyCustomDataValue( props.queueId, { assetType: AssetType.Video, - elementKey, + elementProperty, value, }, forceReplace ) } - for (const [elementKey, value] of Object.entries(massOperationsData.value.audio)) { + for (const [elementProperty, value] of Object.entries(massOperationsData.value.audio)) { uploadQueuesStore.queueItemsReplaceEmptyCustomDataValue( props.queueId, { assetType: AssetType.Audio, - elementKey, + elementProperty, value, }, forceReplace ) } - for (const [elementKey, value] of Object.entries(massOperationsData.value.document)) { + for (const [elementProperty, value] of Object.entries(massOperationsData.value.document)) { uploadQueuesStore.queueItemsReplaceEmptyCustomDataValue( props.queueId, { assetType: AssetType.Document, - elementKey, + elementProperty, value, }, forceReplace diff --git a/src/views/coreDam/asset/detail/components/distribution/DistributionCustomMetadataForm.vue b/src/views/coreDam/asset/detail/components/distribution/DistributionCustomMetadataForm.vue index c3379752..c1222678 100644 --- a/src/views/coreDam/asset/detail/components/distribution/DistributionCustomMetadataForm.vue +++ b/src/views/coreDam/asset/detail/components/distribution/DistributionCustomMetadataForm.vue @@ -19,9 +19,9 @@ const emit = defineEmits<{ (e: 'anyChange'): void }>() -const updateModelValue = (data: { key: string; value: any }) => { +const updateModelValue = (data: { property: string; value: any }) => { const updated = {} as { [key: string]: any } - updated[data.key] = data.value + updated[data.property] = data.value emit('update:modelValue', { ...props.modelValue, ...updated }) emit('anyChange') } @@ -42,8 +42,8 @@ const elements = computed(() => { From ca0098df5fda82a718142231314cff41d69d6a25 Mon Sep 17 00:00:00 2001 From: volar Date: Mon, 9 Oct 2023 11:27:25 +0200 Subject: [PATCH 2/3] lint fix --- src/stores/coreDam/uploadQueuesStore.ts | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/stores/coreDam/uploadQueuesStore.ts b/src/stores/coreDam/uploadQueuesStore.ts index f8345bb9..8d3b4c6d 100644 --- a/src/stores/coreDam/uploadQueuesStore.ts +++ b/src/stores/coreDam/uploadQueuesStore.ts @@ -480,7 +480,11 @@ export const useUploadQueuesStore = defineStore('damUploadQueuesStore', { for (let i = 0; i < items.length; i++) { const item = items[i] if (item.assetType !== data.assetType) continue - if (forceReplace || isUndefined(item.customData[data.elementProperty]) || item.customData[data.elementProperty] === '') { + if ( + forceReplace || + isUndefined(item.customData[data.elementProperty]) || + item.customData[data.elementProperty] === '' + ) { item.customData[data.elementProperty] = data.value } } From fe7f9a5721478bce30332b085acbe5785168ccff Mon Sep 17 00:00:00 2001 From: volar Date: Mon, 9 Oct 2023 11:28:15 +0200 Subject: [PATCH 3/3] lint fix --- src/services/api/coreDam/assetCustomFormApi.ts | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/src/services/api/coreDam/assetCustomFormApi.ts b/src/services/api/coreDam/assetCustomFormApi.ts index 0ae77728..07a1b2d2 100644 --- a/src/services/api/coreDam/assetCustomFormApi.ts +++ b/src/services/api/coreDam/assetCustomFormApi.ts @@ -3,11 +3,8 @@ import { apiFetchOne } from '@anzusystems/common-admin' import { damClient } from '@/services/api/clients/damClient' import { SYSTEM_CORE_DAM } from '@/model/systems' import type { AssetType } from '@/model/coreDam/valueObject/AssetType' -import type { DamConfigAssetCustomFormElement } from '@/types/coreDam/DamConfigAssetCustomForm' +import type { DamConfigAssetCustomFormElementTemp } from '@/types/coreDam/DamConfigAssetCustomForm' import type { DistributionServiceName } from '@/types/coreDam/DamConfig' -import type { - DamConfigAssetCustomFormElementTemp -} from '@/types/coreDam/DamConfigAssetCustomForm' const END_POINT = '/adm/v1/asset-custom-form' const ENTITY = 'assetCustomForm'