本文整理匯總了C#中System.ComponentModel.Model.AddLogEntry方法的典型用法代碼示例。如果您正苦於以下問題:C# Model.AddLogEntry方法的具體用法?C# Model.AddLogEntry怎麽用?C# Model.AddLogEntry使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類System.ComponentModel.Model
的用法示例。
在下文中一共展示了Model.AddLogEntry方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: Execute
/// <summary>
/// Executes the specified workflow.
/// </summary>
/// <param name="rockContext">The rock context.</param>
/// <param name="action">The workflow action.</param>
/// <param name="entity">The entity.</param>
/// <param name="errorMessages">The error messages.</param>
/// <returns></returns>
/// <exception cref="System.NotImplementedException"></exception>
public override bool Execute( RockContext rockContext, Model.WorkflowAction action, Object entity, out List<string> errorMessages )
{
var checkInState = GetCheckInState( entity, out errorMessages );
if ( checkInState == null )
{
return false;
}
var family = checkInState.CheckIn.CurrentFamily;
if ( family != null )
{
var remove = GetAttributeValue( action, "Remove" ).AsBoolean();
bool ageRequired = checkInState.CheckInType == null || checkInState.CheckInType.AgeRequired;
// get the admin-selected attribute key instead of using a hardcoded key
var ageRangeAttributeKey = string.Empty;
var ageRangeAttributeGuid = GetAttributeValue( action, "GroupAgeRangeAttribute" ).AsGuid();
if ( ageRangeAttributeGuid != Guid.Empty )
{
ageRangeAttributeKey = AttributeCache.Read( ageRangeAttributeGuid, rockContext ).Key;
}
// log a warning if the attribute is missing or invalid
if ( string.IsNullOrWhiteSpace( ageRangeAttributeKey ) )
{
action.AddLogEntry( string.Format( "The Group Age Range attribute is not selected or invalid for '{0}'.", action.ActionType.Name ) );
}
foreach ( var person in family.People )
{
var ageAsDouble = person.Person.AgePrecise;
decimal? age = null;
if ( !ageAsDouble.HasValue && !ageRequired )
{
continue;
}
if ( ageAsDouble.HasValue )
{
age = Convert.ToDecimal( ageAsDouble.Value );
}
foreach ( var groupType in person.GroupTypes.ToList() )
{
foreach ( var group in groupType.Groups.ToList() )
{
var ageRange = group.Group.GetAttributeValue( ageRangeAttributeKey ).ToStringSafe();
var ageRangePair = ageRange.Split( new char[] { ',' }, StringSplitOptions.None );
string minAgeValue = null;
string maxAgeValue = null;
if ( ageRangePair.Length == 2 )
{
minAgeValue = ageRangePair[0];
maxAgeValue = ageRangePair[1];
}
if ( minAgeValue != null )
{
decimal minAge = 0;
if ( decimal.TryParse( minAgeValue, out minAge ) )
{
decimal? personAgePrecise = null;
if ( age.HasValue )
{
int groupMinAgePrecision = minAge.GetDecimalPrecision();
personAgePrecise = age.Floor( groupMinAgePrecision );
}
if ( !age.HasValue || personAgePrecise < minAge )
{
if ( remove )
{
groupType.Groups.Remove( group );
}
else
{
group.ExcludedByFilter = true;
}
continue;
}
}
}
if ( maxAgeValue != null )
{
decimal maxAge = 0;
//.........這裏部分代碼省略.........
示例2: Execute
/// <summary>
/// Executes the specified workflow.
/// </summary>
/// <param name="rockContext">The rock context.</param>
/// <param name="action">The workflow action.</param>
/// <param name="entity">The entity.</param>
/// <param name="errorMessages">The error messages.</param>
/// <returns></returns>
/// <exception cref="System.NotImplementedException"></exception>
public override bool Execute( RockContext rockContext, Model.WorkflowAction action, Object entity, out List<string> errorMessages )
{
var checkInState = GetCheckInState( entity, out errorMessages );
if ( checkInState == null )
{
return false;
}
var family = checkInState.CheckIn.CurrentFamily;
if ( family != null )
{
var remove = GetAttributeValue( action, "Remove" ).AsBoolean();
bool removeSNGroups = GetAttributeValue( action, "RemoveSpecialNeedsGroups" ).AsBoolean( true );
bool removeNonSNGroups = GetAttributeValue( action, "RemoveNonSpecialNeedsGroups" ).AsBoolean();
// get the admin-selected attribute key instead of using a hardcoded key
var personSpecialNeedsKey = string.Empty;
var personSpecialNeedsGuid = GetAttributeValue( action, "PersonSpecialNeedsAttribute" ).AsGuid();
if ( personSpecialNeedsGuid != Guid.Empty )
{
personSpecialNeedsKey = AttributeCache.Read( personSpecialNeedsGuid, rockContext ).Key;
}
var groupSpecialNeedsKey = string.Empty;
var groupSpecialNeedsGuid = GetAttributeValue( action, "GroupSpecialNeedsAttribute" ).AsGuid();
if ( groupSpecialNeedsGuid != Guid.Empty )
{
groupSpecialNeedsKey = AttributeCache.Read( groupSpecialNeedsGuid, rockContext ).Key;
}
// log a warning if the attribute is missing or invalid
if ( string.IsNullOrWhiteSpace( personSpecialNeedsKey ) )
{
action.AddLogEntry( string.Format( "The Person Special Needs attribute is not selected or invalid for '{0}'.", action.ActionType.Name ) );
}
if ( string.IsNullOrWhiteSpace( groupSpecialNeedsKey ) )
{
action.AddLogEntry( string.Format( "The Group Special Needs attribute is not selected or invalid for '{0}'.", action.ActionType.Name ) );
}
foreach ( var person in family.People )
{
if ( person.Person.Attributes == null )
{
person.Person.LoadAttributes( rockContext );
}
bool isSNPerson = person.Person.GetAttributeValue( personSpecialNeedsKey ).AsBoolean();
foreach ( var groupType in person.GroupTypes.ToList() )
{
foreach ( var group in groupType.Groups.ToList() )
{
bool isSNGroup = group.Group.GetAttributeValue( groupSpecialNeedsKey ).AsBoolean();
// If the group is special needs but the person is not, then remove it.
if ( removeSNGroups && isSNGroup && !( isSNPerson ) )
{
if ( remove )
{
groupType.Groups.Remove( group );
}
else
{
group.ExcludedByFilter = true;
}
continue;
}
// or if the setting is enabled and the person is SN but the group is not.
if ( removeNonSNGroups && isSNPerson && !isSNGroup )
{
if ( remove )
{
groupType.Groups.Remove( group );
}
else
{
group.ExcludedByFilter = true;
}
}
}
}
}
}
return true;
}