Merge pull request #11948 from Budibase/BUDI-7500/validation-not-triggering-for-required-foreign-keys
Validation not triggering for required foreign keys
This commit is contained in:
commit
ab8cb75336
|
@ -277,10 +277,7 @@
|
||||||
dispatch("updatecolumns")
|
dispatch("updatecolumns")
|
||||||
gridDispatch("close-edit-column")
|
gridDispatch("close-edit-column")
|
||||||
|
|
||||||
if (
|
if (saveColumn.type === LINK_TYPE) {
|
||||||
saveColumn.type === LINK_TYPE &&
|
|
||||||
saveColumn.relationshipType === RelationshipType.MANY_TO_MANY
|
|
||||||
) {
|
|
||||||
// Fetching the new tables
|
// Fetching the new tables
|
||||||
tables.fetch()
|
tables.fetch()
|
||||||
// Fetching the new relationships
|
// Fetching the new relationships
|
||||||
|
@ -312,6 +309,11 @@
|
||||||
confirmDeleteDialog.hide()
|
confirmDeleteDialog.hide()
|
||||||
dispatch("updatecolumns")
|
dispatch("updatecolumns")
|
||||||
gridDispatch("close-edit-column")
|
gridDispatch("close-edit-column")
|
||||||
|
|
||||||
|
if (editableColumn.type === LINK_TYPE) {
|
||||||
|
// Updating the relationships
|
||||||
|
datasources.fetch()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
notifications.error(`Error deleting column: ${error.message}`)
|
notifications.error(`Error deleting column: ${error.message}`)
|
||||||
|
|
|
@ -57,7 +57,8 @@
|
||||||
label: table.name,
|
label: table.name,
|
||||||
value: table._id,
|
value: table._id,
|
||||||
}))
|
}))
|
||||||
$: valid = getErrorCount(errors) === 0 && allRequiredAttributesSet()
|
$: valid =
|
||||||
|
getErrorCount(errors) === 0 && allRequiredAttributesSet(relationshipType)
|
||||||
$: isManyToMany = relationshipType === RelationshipType.MANY_TO_MANY
|
$: isManyToMany = relationshipType === RelationshipType.MANY_TO_MANY
|
||||||
$: isManyToOne = relationshipType === RelationshipType.MANY_TO_ONE
|
$: isManyToOne = relationshipType === RelationshipType.MANY_TO_ONE
|
||||||
|
|
||||||
|
@ -114,7 +115,7 @@
|
||||||
return Object.entries(errors).filter(entry => !!entry[1]).length
|
return Object.entries(errors).filter(entry => !!entry[1]).length
|
||||||
}
|
}
|
||||||
|
|
||||||
function allRequiredAttributesSet() {
|
function allRequiredAttributesSet(relationshipType) {
|
||||||
const base = getTable(fromId) && getTable(toId) && fromColumn && toColumn
|
const base = getTable(fromId) && getTable(toId) && fromColumn && toColumn
|
||||||
if (relationshipType === RelationshipType.MANY_TO_ONE) {
|
if (relationshipType === RelationshipType.MANY_TO_ONE) {
|
||||||
return base && fromPrimary && fromForeign
|
return base && fromPrimary && fromForeign
|
||||||
|
@ -124,9 +125,10 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
function validate() {
|
function validate() {
|
||||||
if (!allRequiredAttributesSet() && !hasValidated) {
|
if (!allRequiredAttributesSet(relationshipType) && !hasValidated) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
hasValidated = true
|
hasValidated = true
|
||||||
errorChecker.setType(relationshipType)
|
errorChecker.setType(relationshipType)
|
||||||
const fromTable = getTable(fromId),
|
const fromTable = getTable(fromId),
|
||||||
|
|
|
@ -21,15 +21,22 @@
|
||||||
function getRelationships(tables) {
|
function getRelationships(tables) {
|
||||||
const relatedColumns = {}
|
const relatedColumns = {}
|
||||||
|
|
||||||
tables.forEach(({ name: tableName, schema }) => {
|
tables.forEach(({ name: tableName, schema, _id: tableId }) => {
|
||||||
Object.values(schema).forEach(column => {
|
Object.values(schema).forEach(column => {
|
||||||
if (column.type !== "link") return
|
if (column.type !== "link") return
|
||||||
|
|
||||||
relatedColumns[column._id] ??= {}
|
const columnId =
|
||||||
relatedColumns[column._id].through =
|
column.through ||
|
||||||
relatedColumns[column._id].through || column.through
|
column._id ||
|
||||||
|
(column.main
|
||||||
|
? `${tableId}_${column.fieldName}__${column.tableId}_${column.foreignKey}`
|
||||||
|
: `${column.tableId}_${column.foreignKey}__${tableId}_${column.fieldName}`)
|
||||||
|
|
||||||
relatedColumns[column._id][column.main ? "from" : "to"] = {
|
relatedColumns[columnId] ??= {}
|
||||||
|
relatedColumns[columnId].through =
|
||||||
|
relatedColumns[columnId].through || column.through
|
||||||
|
|
||||||
|
relatedColumns[columnId][column.main ? "from" : "to"] = {
|
||||||
...column,
|
...column,
|
||||||
tableName,
|
tableName,
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue