Click or drag to resize

Fields Class

Provides a collection for an IMapper.Fields collection of IField objects. The string index is the IField.Key and is treated case-insensitively.

Commonly used features of the collection are:

Inheritance Hierarchy

Namespace:  NetQuarry.Data
Assembly:  EAP.Core (in EAP.Core.dll) Version: 2.0.0.0 (4.6.8.0)
Syntax
public class Fields : EAPCollectionBase

The Fields type exposes the following members.

Constructors
  NameDescription
Public methodFields
Initializes a new instance of the collection.
Top
Properties
  NameDescription
Public propertyCount
The number of elements actually contained in the ArrayList.
(Inherited from EAPCollectionBase.)
Public propertyDirty
Dirty is used to determine or specify whether a set of fields has any changed values. Dirty returns true if the IField.Dirty flag is true for one of more fields in the collection. When written, the Dirty flag sets all the IField.Dirty flags to the specified state.
Public propertyIsFixedSize
true if the ArrayList has a fixed size; otherwise, false. The default is false.
(Inherited from EAPCollectionBase.)
Public propertyIsReadOnly
Returns true if the collection is read-only. (Default is false)
(Inherited from EAPCollectionBase.)
Public propertyIsSynchronized
true if access to the internal ArrayList is synchronized (thread-safe); otherwise, false. The default is false.
(Inherited from EAPCollectionBase.)
Public propertyItemInt32
Integer indexer for this collection.
Public propertyItemString
String indexer for this collection. Note that if the field is not found then an entry is logged in the devlog. If it is expected that the field may not exist in the mapper's Fields collection and no such devlog entry is desired use Find(String, FieldFindType, FindBehaviour) or Field(String) to obtain the field.
Public propertyOmitted
A map of fields omitted by the mapper due to versioning or flavoring. The dictionary maps field key to field id.
Public propertyOmittedInfo
A map of additional information about fields omitted by the mapper due to versioning or flavoring. The dictionary maps field key to the additional information whose content is not specified at this time and subject to change.
Public propertySyncRoot
An object that can be used to synchronize access to the ArrayList.
(Inherited from EAPCollectionBase.)
Top
Methods
  NameDescription
Public methodAdd(IField)
Adds an IField to the collection.
Protected methodAdd(String, Object)
Adds an object to the collection. Override. This method simply calls the Add method with CollectionAddFlags.replace as the flags.
(Inherited from EAPCollectionBase.)
Protected methodAdd(String, Object, CollectionAddFlags)
Adds an item to the collection
(Inherited from EAPCollectionBase.)
Protected methodAddAt
Adds an item to the collection at the specified index. To append an item use -1 or the collection item count as the index.
(Inherited from EAPCollectionBase.)
Public methodAddLabel
Add a label to its associated field. The collection is scanned for a field whose ControlName matches the label's AssociatedControlID. If found, the field's label (LabelControl) is set to reference the label.
Public methodClear
Clears the collection
(Inherited from EAPCollectionBase.)
Public methodContains(Object)
Determines whether an element is in the collection.
(Inherited from EAPCollectionBase.)
Public methodContains(String)
Determines if a field with the specified Key exists in the collection.
Public methodContainsKey
Checks for the existence of an item in the hashtable
(Inherited from EAPCollectionBase.)
Public methodCopyTo
Copies the entire ArrayList to a compatible one-dimensional Array, starting at the beginning of the target array.
(Inherited from EAPCollectionBase.)
Public methodEquals
Determines whether the specified Object is equal to the current Object.
(Inherited from Object.)
Public methodField(String)
Retrieves the specified IField object from the collection. Note that, unlike the Fields[Key] indexer, if the field is not found then no entry is logged to the devlog. For finer control over behaviour when the field is not found, use the Find(String, FieldFindType, FindBehaviour) method specifying the desired FindBehaviour.
Public methodField(String, FindBehaviour)
Retrieves the specified IField object from the collection. Note that, unlike the Fields[Key] indexer, if the field is not found no entry is logged to the devlog. For finer control over behaviour when the field is not found, use the Find(String, FieldFindType, FindBehaviour) method specifying the desired FindBehaviour.
Protected methodFinalize
Allows an Object to attempt to free resources and perform other cleanup operations before the Object is reclaimed by garbage collection.
(Inherited from Object.)
Public methodFind(String, FieldFindType)
Searches for a field in the collection based on FieldFindType using OkIfNotFound. See Find(String, FieldFindType, FindBehaviour) for additional details.
Public methodFind(String, FieldFindType, FindBehaviour)
Searches for an IField in the collection based on FieldFindType.

The searchID depends on the findType:

findTypesearchID
ByKeyThe field's Key name IField.Key.
ByCtrlNmThe field's IField.ControlName.
PKFinds the first field marked PK in the collection.
ByAliasFind field by IField.AliasName
UniqueKeyFinds the field marked UniqueKey in the collection (there should be no more than one), if any, else the first field marked PK.
ByCtrlUniqueIdFinds field by it's BaseControl's fully qualified UniqueID
ByFieldIDFinds field by it's GUID (xmt_fields.field_id).
AlternateKeyFinds the field marked AlternateKey, or if no such field and there is exactly one field marked as PK, that field.
Public methodGetBoolValue
Get the value for the specified field, converted to a bool. The behaviour when the field is not found is dictated by the FindBehaviour parameter.
Public methodGetDateTimeValue
Get the value for the specified field, converted to a DateTime. The behaviour when the field is not found is dictated by the FindBehaviour parameter.
Public methodGetDecimalValue
Get the value for the specified field, converted to a decimal. The behaviour when the field is not found is dictated by the FindBehaviour parameter.
Public methodGetDisplayText
The DisplayText (see cref="IField.DisplayTextGet"/>) for the specified field. The behaviour when the field is not found is dictated by the FindBehaviour parameter.
Public methodGetDoubleValue
Get the value for the specified field, converted to a double. The behaviour when the field is not found is dictated by the FindBehaviour parameter.
Public methodGetEnumerator
Returns an enumerator that can iterate through the ArrayList.
(Inherited from EAPCollectionBase.)
Public methodGetHashCode
Serves as a hash function for a particular type.
(Inherited from Object.)
Public methodGetIntValue
Get the value for the specified field, converted to an int. The behaviour when the field is not found is dictated by the FindBehaviour parameter.
Protected methodGetItem(Int32)
Returns an item that matches the specified string index
(Inherited from EAPCollectionBase.)
Protected methodGetItem(String)
Returns an item that matches the specified string index
(Inherited from EAPCollectionBase.)
Public methodGetItemName
Returns the name of the item, a IField.Key
(Overrides EAPCollectionBaseGetItemName(Object).)
Public methodGetStringValue
Get the value for the specified field, converted to a string (without internationalization). The behaviour when the field is not found is dictated by the FindBehaviour parameter.
Public methodGetType
Gets the Type of the current instance.
(Inherited from Object.)
Public methodGetValue(String)
Get the value for the specified field. If the field is not found then an error is raised.
Public methodGetValue(String, Object, FindBehaviour)
Get the value for the specified field, or the defaultValue if not found. The behaviour when the field is not found is dictated by the FindBehaviour parameter.
Public methodIndexOf
Returns the zero-based index of the first occurrence of an object in the internal ArrayList or in a portion of it.
(Inherited from EAPCollectionBase.)
Public methodIndexOfKey
Returns the index of the item in the collection (by key)
(Inherited from EAPCollectionBase.)
Public methodInsert
Inserts an element into the internal ArrayList at the specified index
(Inherited from EAPCollectionBase.)
Protected methodIsMarkedForDeletion
Determines if this element is marked for deletion. Note that this base implementation must be overridden in order to support RemoveMarkedItems() for a partular collection.
(Inherited from EAPCollectionBase.)
Protected methodIsTypeOK
Verifies the item is an acceptable type. Generally this is a test like "return (item is [class]);".
(Overrides EAPCollectionBaseIsTypeOK(Object).)
Public methodKeyList
Extracts the keys for the fields in the collection as a semi-colon separated list.
Protected methodMemberwiseClone
Creates a shallow copy of the current Object.
(Inherited from Object.)
Public methodNotify
Send a notification to all fields in the collection.
Protected methodRecalcHash
Recalculates the internal hash
(Inherited from EAPCollectionBase.)
Public methodRemove(Object)
Removes the first occurrence of a specific object from the collection
(Inherited from EAPCollectionBase.)
Public methodRemove(String)
Remove the specified item from the collection.
(Inherited from EAPCollectionBase.)
Public methodRemoveAt
Removes the element at the specified index
(Inherited from EAPCollectionBase.)
Public methodRemoveMarkedItems
Removes the properties marked for deletion.
(Inherited from EAPCollectionBase.)
Public methodRemoveRange
Removes the element at the specified index
(Inherited from EAPCollectionBase.)
Protected methodSetItem(Int32, Object)
Sets an item's value at the specified index.
(Inherited from EAPCollectionBase.)
Protected methodSetItem(String, Object)
Sets an item's value at the string index indicated by the parameters.
(Inherited from EAPCollectionBase.)
Public methodSetValue(String, Object)
Set the value for the specified field. If the field is not found, an error is raised.
Public methodSetValue(String, Object, SetValFlags, FindBehaviour)
Set the value for the specified field per the provided SetValFlags. Behaviour in the case where the specified field is not found in the collection is dictated by FindBehaviour.
Public methodSort(Boolean)
Sort the list by its key value.
(Inherited from EAPCollectionBase.)
Public methodSort(IComparer)
Sort the collection using the provided comparer.
(Inherited from EAPCollectionBase.)
Public methodSort(String)
Sorts the Fields collection in the order specified by the provided semi-colon-separated list of field keys. Fields not in the provided sort list retain their relative positions, but following all explicitly ordered fields. The list is handled case-insensitively, but may provide slightly better performance if provided in all lower-case.
Public methodSubset
Obtain a Fields collection with a subset of this collection's IField objects. The criteria for determining which fields to include in the subset is specified using FieldSubsetType:
  • AttributeIsSet - Get the subset of fields where any of the specified set of FieldAttrs, provided in criteria, is set.
  • ByCellType - Find all fields whose CellTypes matches the criteria.
  • RowKeys - Get the subset of fields comprising the RowKeys for the mapper (criteria ignored).
  • PropSet - Get the subset of fields where the specified property value, provided as a string in criteria, is not null/blank.
  • Visible - Get the subset of fields with the specified Visible value, provided as a boolean in criteria.
  • Dirty - Get the subset of fields with the specified Dirty value, provided as a boolean in criteria..
Public methodToString
Returns a String that represents the current Object.
(Inherited from Object.)
Public methodTruncate
Truncate the array starting at the specified index.
(Inherited from EAPCollectionBase.)
Protected methodUnload
Called when the collection is cleared allowing a derived class to clean up.
(Inherited from EAPCollectionBase.)
Top
Events
  NameDescription
Public eventOnFieldNotFound
This event is fired when an attempt is made to obtain a field that is not in the collection.
Top
Extension Methods
  NameDescription
Public Extension MethodEqualValue
Determines if the object value is equal to another object. If the two objects are null, then this returns true. There is special handling for guid comparisons (since a guid could be a string formatted in up to 3 different ways). If the special guid handling is not performed, then the object.Equals method is used.
(Defined by EAPUtil.)
Top
Remarks
You can access fields in an IMapper through this collection. While the collection supports iteration and retrieval via numeric (positional) index, you generally access fields in the collection by using the Key property as the index.
Remarks
Whan a IMapper is loaded, the IField objects for the IMapper are loaded into the collection ordered by each field's Column Order (as specified in the NetQuarry Studio), ascending. Note that at this time the Column Order is used by the IMapper to load the collection, but is not exposed on the IField object once loaded. By default, the IMapper will present the fields in the order in which they occur in the collection. Many renderers support a per-PageElement FieldOrder property (e.g. ConsoleDetail_FieldOrder) to allow for per-page customization of field order. In addition, the Datasheet allows for user customization of the field order (this can be disabled on a page-by-page basis and/or for particular fields) that trumps other field orderings. It is possible to manipulate a mapper's field order programmatically by moving fields within the Fields collection using the collection's Remove(String) and Insert(Int32, Object) methods (typically in a BeforeLayout event). Note, however, that any per-PageElement FieldOrder or user customized field order would take precedence.
Examples

These examples show several different ways to set a field's value safely when it is possible that the field does not exist in the mapper.

Example #1 - Test for existence then set field value.
if (sender.Fields.ContainsKey("date_expires"))
{
    TimeSpan span = new System.TimeSpan(0, hoursToExpires, 0, 0, 0);
    sender.Fields["date_expires"].Value = System.DateTime.Now + span;
}
Example #2 - Efficient test for existence then set field value (requires indexing into collection only once).
IField fld = sender.Fields["date_expires"];

if (fld != null)
{
    TimeSpan span = new System.TimeSpan(0, hoursToExpires, 0, 0, 0);
    fld.Value = System.DateTime.Now + span;
}
Example #3 - Safe set field value without explicit test for existence.
TimeSpan span = new System.TimeSpan(0, hoursToExpires, 0, 0, 0);
sender.Fields.SetValue("date_expires", System.DateTime.Now + span, FindBehaviour.OkIfNotFound);
See Also