This commit is contained in:
2025-04-08 15:20:52 +02:00
parent ab20b9d5a4
commit a287f4cf85

View File

@@ -325,10 +325,10 @@ class AstromicFormController extends FormController {
// Initialize the group instances
_initializeGroupControllers(groupStructure, initialCount);
}
}
/// Recursively initialize controllers for the group and its subgroups
void _initializeGroupControllers(FormGroupStructure groupStructure, int initialCount, {String parentPrefix = ''}) {
/// Recursively initialize controllers for the group and its subgroups
void _initializeGroupControllers(FormGroupStructure groupStructure, int initialCount, {String parentPrefix = ''}) {
// Add main group fields/values
for (int groupIndex = 0; groupIndex < initialCount; groupIndex++) {
_addGroupControllers(groupStructure, groupIndex, parentPrefix: parentPrefix);
@@ -336,21 +336,21 @@ class AstromicFormController extends FormController {
// Recursively handle subgroups
if (groupStructure.subGroups != null && groupStructure.subGroups!.isNotEmpty) {
for (final (FormGroupStructure subGroup, int subgroupInitialCount) in groupStructure.subGroups!) {
final String nestedPrefix = parentPrefix.isEmpty
? standeredGroupFormat(groupStructure.id, groupIndex, subGroup.id) // If no parentPrefix, use the group directly
: '$parentPrefix->${standeredGroupFormat(groupStructure.id, groupIndex, subGroup.id)}'; // Add to parentPrefix
final String subgroupPrefix = parentPrefix.isEmpty
? standeredGroupFormat(groupStructure.id, groupIndex, subGroup.id)
: '$parentPrefix->${standeredGroupFormat(groupStructure.id, groupIndex, subGroup.id)}'; // Add to parentPrefix only once
// Initialize subgroup controllers recursively
for (int subIndex = 0; subIndex < subgroupInitialCount; subIndex++) {
_initializeGroupControllers(subGroup, subgroupInitialCount, parentPrefix: nestedPrefix);
}
_initializeGroupControllers(subGroup, subgroupInitialCount, parentPrefix: subgroupPrefix);
}
}
}
}
}
/// Validate subgroups recursively
void _validateSubGroups(FormGroupStructure groupStructure) {
/// Validate subgroups recursively
void _validateSubGroups(FormGroupStructure groupStructure) {
groupStructure.subGroups?.forEach((subGroupTuple) {
final subGroup = subGroupTuple.$1;
assert(subGroup.fields.isNotEmpty, '${subGroup.id}: Subgroup fields should NOT be empty.');
@@ -360,7 +360,8 @@ class AstromicFormController extends FormController {
_validateSubGroups(subGroup);
}
});
}
}
// void initializeFormGroup(FormGroupStructure groupStructure, {int initialCount = 1}) {
// assert(groupStructure.fields.isNotEmpty, '$groupStructure: Group Fields should NOT be empty.');