ObservableLinq is an open source, portable class library that can be easily deployed from nuget and used in .NET 4.5, Windows Phone 8 and Windows Store applications.
ObservableLinq proposes to implement a subset of the LINQ operators on
ObservableCollection, where source collection changes are automatically reflected in the result collection.
Using the Code
Project Data between Different Domains
Larger applications are often architectured in multiple layers, across multiple tiers. The different layers can enrich data coming from another layer with new attributes, filters and sort criteria.
Consider an editable data grid that contains personal data in an MVVM application. The model class will contain records with first name, last name, etc. Your view model might wrap the model object and have additional attributes, like '
IsEditing' and '
IsChanged'. Your UI layer will transform the view model into rows in the
ObservableLinq not only allows you to project your model into view models, but when your original collection changes, it will keep the view model collection up to date, without losing the added data on the view model level.
Change between Different Views of the Same Collection
ObservableLinq provides a special collection class, called
ObserverCollection. This collection can be instructed to follow a different observable collection. However,
ObserverCollection can change from one observed collection to another at any time. Items present in both will be retained and moved to their new position.
Let's consider our personal data view models from before. We can project that collection into one where we sort by first name and another one where we sort by last name. Maybe another one, where we filter out unchanged items. Then, we bind our
datagrid to an observer collection that switches between these collections according to user input...
Display Changes Visually to the User
The basic modification events on the
ICollectionChanged interface can be translated into animations like in the figure above, which results in a user interface that is both appealing and gives plenty of visual clues to the user in order to correctly understand the underlying data manipulation.
Points of Interest
The project is currently in an "alpha" state. The currently supported set of operators is the following:
The goal for version 1.0 is to have functional parity with Linq on these operators and
Install the library from the nuget command prompt using the following command:
Install-Package ObservableLinq -Pre
ObservableLinq is hosted on GitHub, contributions are welcome. Please read the guidelines in the project "readme" file.
- April 30, 2014 - Initial article submission