1
0
Fork 0
mirror of synced 2024-09-28 15:21:28 +12:00

Format dates

This commit is contained in:
Adria Navarro 2024-09-25 17:29:44 +02:00
parent 337ac90906
commit 863ff4d9f9
2 changed files with 35 additions and 11 deletions

View file

@ -35,5 +35,9 @@ const TypeComponentMap = {
[FieldType.BB_REFERENCE_SINGLE]: BBReferenceSingleCell,
}
export const getCellRenderer = column => {
return TypeComponentMap[column?.schema?.type] || TextCell
return (
TypeComponentMap[column?.schema?.cellRenderType] ||
TypeComponentMap[column?.schema?.type] ||
TextCell
)
}

View file

@ -1,4 +1,25 @@
import { FieldType } from "@budibase/types"
import { Helpers } from "@budibase/bbui"
const columnTypeManyOverrides = {
[FieldType.DATETIME]: {
overridedType: FieldType.STRING,
parser: (value, field) => {
const { timeOnly, dateOnly, ignoreTimezones } = field
const enableTime = !dateOnly
const parsedValue = Helpers.parseDate(value, {
timeOnly,
enableTime,
ignoreTimezones,
})
const result = Helpers.getDateDisplayValue(parsedValue, {
enableTime,
timeOnly,
})
return result
},
},
}
export function enrichSchemaWithRelColumns(schema) {
if (!schema) {
@ -19,6 +40,9 @@ export function enrichSchemaWithRelColumns(schema) {
...relField,
name,
related: { field: c, subField: relColumn },
cellRenderType:
columnTypeManyOverrides[relField.type]?.overridedType ||
relField.type,
}
}
}
@ -34,19 +58,15 @@ export function getRelatedTableValues(row, field, isSingle) {
if (isSingle) {
result = row[field.related.field]?.[0]?.[field.related.subField]
} else {
const parser =
columnTypeManyOverrides[field.type]?.parser || (value => value)
result = Array.from(
new Set(
row[field.related.field].flatMap(r => r[field.related.subField])
row[field.related.field].flatMap(r =>
parser(r[field.related.subField], field)
)
)
)
switch (field.type) {
case FieldType.STRING:
case FieldType.NUMBER:
case FieldType.BIGINT:
case FieldType.BARCODEQR:
result = result.join(", ")
break
}
).join(", ")
}
} catch (e) {
result = "Not rendable"