Add logic for import of combination from xls files
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
using StructureHelperCommon.Infrastructures.Interfaces;
|
||||
using StructureHelperCommon.Models.Forces.Logics;
|
||||
using StructureHelperCommon.Services;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
@@ -11,31 +12,37 @@ namespace StructureHelperCommon.Models.Forces
|
||||
public class ForceCombinationFromFileUpdateStrategy : IUpdateStrategy<IForceCombinationFromFile>
|
||||
{
|
||||
private IUpdateStrategy<IForceAction> baseUpdateStrategy;
|
||||
private IUpdateStrategy<IForceFileProperty> fileUpdateStrategy;
|
||||
private IUpdateStrategy<IColumnedFileProperty> filePropertyUpdateStrategy;
|
||||
private IUpdateStrategy<IFactoredCombinationProperty> combinationPropertyUpdateStrategy;
|
||||
|
||||
public ForceCombinationFromFileUpdateStrategy(IUpdateStrategy<IForceAction> baseUpdateStrategy,
|
||||
IUpdateStrategy<IForceFileProperty> fileUpdateStrategy)
|
||||
IUpdateStrategy<IColumnedFileProperty> filePropertyUpdateStrategy,
|
||||
IUpdateStrategy<IFactoredCombinationProperty> combinationPropertyUpdateStrategy)
|
||||
{
|
||||
this.baseUpdateStrategy = baseUpdateStrategy;
|
||||
this.fileUpdateStrategy = fileUpdateStrategy;
|
||||
this.filePropertyUpdateStrategy = filePropertyUpdateStrategy;
|
||||
this.combinationPropertyUpdateStrategy = combinationPropertyUpdateStrategy;
|
||||
}
|
||||
|
||||
public ForceCombinationFromFileUpdateStrategy()
|
||||
{
|
||||
}
|
||||
|
||||
void IUpdateStrategy<IForceCombinationFromFile>.Update(IForceCombinationFromFile targetObject, IForceCombinationFromFile sourceObject)
|
||||
public void Update(IForceCombinationFromFile targetObject, IForceCombinationFromFile sourceObject)
|
||||
{
|
||||
CheckObject.IsNull(targetObject);
|
||||
CheckObject.IsNull(sourceObject);
|
||||
if (ReferenceEquals(targetObject, sourceObject)) { return; }
|
||||
InitializeLogics();
|
||||
baseUpdateStrategy.Update(targetObject, sourceObject);
|
||||
CheckObject.IsNull(targetObject.CombinationProperty, "Target object combination property");
|
||||
CheckObject.IsNull(sourceObject.CombinationProperty, "Source object combination property");
|
||||
combinationPropertyUpdateStrategy.Update(targetObject.CombinationProperty, sourceObject.CombinationProperty);
|
||||
targetObject.ForceFiles.Clear();
|
||||
foreach (var file in sourceObject.ForceFiles)
|
||||
{
|
||||
ForceFileProperty newProperty = new();
|
||||
fileUpdateStrategy.Update(newProperty, file);
|
||||
ColumnedFileProperty newProperty = new();
|
||||
filePropertyUpdateStrategy.Update(newProperty, file);
|
||||
targetObject.ForceFiles.Add(newProperty);
|
||||
}
|
||||
}
|
||||
@@ -43,7 +50,8 @@ namespace StructureHelperCommon.Models.Forces
|
||||
private void InitializeLogics()
|
||||
{
|
||||
baseUpdateStrategy ??= new ForceActionBaseUpdateStrategy();
|
||||
fileUpdateStrategy ??= new ForceFilePropertyUpdateStrategy();
|
||||
filePropertyUpdateStrategy ??= new ColumnedFilePropertyUpdateStrategy();
|
||||
combinationPropertyUpdateStrategy ??= new FactoredCombinationPropertyUpdateStrategy();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user