Search code examples
wcfsilverlightdomaindatasource

Add new object to domain data source


it drives me crazy. I'm working at a Silverlight 5 Business Application and using WCF Ria Services (Domain Data Source). In a simple ChildControl I load the defined (see code below) domain data source "ddsTerminKonfiguration". The query method returns a generic IQueryable<TerminKonfiguration> list. If this list has no items (...DataView.Count == 0) I want to add a new object of "TerminKonfiguration". When I try to execute ddsTerminKonfiguration.DataView.Add(new TerminKonfiguration()); I run into an error "'Add' isn't supported by this ICollectionView" (I only know the german error message ... so I hope everybody can understand my translation :-D). Comparable code snippets in this project (coded by other developers) are working properly ... and I don't know, how to solve this problem.

Does anyone have an idea or solution for my problem?

My domain data source ...

<riaControls:DomainDataSource Name="ddsTerminKonfiguration"
                              Width="0"
                              Height="0"
                              AutoLoad="False"
                              d:DesignData="{d:DesignInstance my1:TerminKonfiguration, CreateList=true}"
                              LoadedData="ddsTerminKonfiguration_LoadedData"
                              SubmittedChanges="ddsTerminKonfiguration_SubmittedChanges"
                              QueryName="GetTerminKonfigurationQuery">
    <riaControls:DomainDataSource.DomainContext>
        <my:RRPDomainContext />
    </riaControls:DomainDataSource.DomainContext>
    <riaControls:DomainDataSource.QueryParameters>
        <riaControls:Parameter ParameterName="param01" />
        <riaControls:Parameter ParameterName="param02" />
        <riaControls:Parameter ParameterName="param03" />
        <riaControls:Parameter ParameterName="param04" />
    </riaControls:DomainDataSource.QueryParameters>
</riaControls:DomainDataSource>

The namespace "my" references to "Project".Web.Services and "my1" to "Project".Web.Models.

The query method ...

    public IQueryable<TerminKonfiguration> GetTerminKonfiguration(string param01, string param02, int param03, int param04) {
        return this.ObjectContext.TerminKonfiguration.Where(d => (d.MandantenNr == param01) && (d.WorkflowNr == param02) && (d.WfAufgabeId == param03) && (d.WfAufgabeIdGlobal == param04));
    }

The snippet, where I try to add the new object to the DataView ...

if (this.ddsTerminKonfiguration.DataView.Count == 0) {
    TerminKonfiguration tmpConfig = new TerminKonfiguration();
    /*
        define the new object
    */

    this.ddsTerminKonfiguration.DataView.Add(tmpConfig); // problematic line
}

this.ddsTerminKonfiguration.SubmitChanges();

Solution

  • DataView is a DataView this is the cause. DataView is the view of data.

    With a datasource you can filter order etc then you see the effects on DataView.

     this.ddsTerminKonfiguration.DataView.Add is not a valid operation.
    

    http://msdn.microsoft.com/en-us/library/ee707363(v=vs.91).aspx

    Basic usage is

    <Grid x:Name="LayoutRoot" Background="White">
    <riaControls:DomainDataSource x:Name="source" QueryName="GetProductsByColor" AutoLoad="true">
        <riaControls:DomainDataSource.DomainContext>
            <domain:ProductDomainContext />
        </riaControls:DomainDataSource.DomainContext>
        <riaControls:DomainDataSource.QueryParameters>
            <riaData:Parameter ParameterName="color" Value="Black" />
        </riaControls:DomainDataSource.QueryParameters>
    </riaControls:DomainDataSource>
    
     <data:DataGrid ItemsSource="{Binding Data, ElementName=source}" />
    
      </Grid>
    

    As you notice it DataGrid bound to Data not DataView.

    {Binding Data, ElementName=source}"