Quantcast
Viewing all articles
Browse latest Browse all 18858

Passing parameters to a Page using constructors

In my application I have two pages placed on a Navigation Window.

Page 1 the Main Page and has three buttons on top ( like a ribbon menu) and a Frame ( on second half of the page to navigate within frame)

Page 2 - is the second page that will be directed within the frame when the buttons in Page 1 is clicked.

In Page 2 I have a datagrid displaying list of servers for test environment -  TestServer1 .. TestServerN, for development -DevServer1...DevServern and for Production -PrdServer1..PrdServerN.

currently when these button's are cliked , all the servers get displayed in the datagrid, but my concern is to display in the following order,

when user clicks

tstbutton ( test) - it should navigate to page 2 and display only servers which belongs to test system.

devbutton ( dev)-  it should navigate to page 2 and display only servers which belongs to development system.

prdbutton (prd) - it should navigate to page 2 and display only servers which belongs to production system.

I have tried the following, but I could achieve only for one server, by passing paramter through constructor.

Page1.cs

public partial class Page1 : Page
{
public Page1()
{
 InitializeComponent();
}
private void PRD_Btn_Click(object sender, RoutedEventArgs e)
{
//  Server x = new Server();
Page2 pg = new Page2();
this.NavigationService.Navigate(pg);
}
private void TST_Btn_Click(object sender, RoutedEventArgs e)
{
// this works, only if I pass one paramaterized constructor
Server s = new Server();
Page2 pg = new Page2(s);
this.NavigationService.Navigate(pg);
}
private void DEV_Btn_Click(object sender, RoutedEventArgs e)
{
//  Server y = new Server();
Page2 pg = new Page2();
this.NavigationService.Navigate(pg);
}
}

Page2.cs

public Page2()
{
InitializeComponent();
}   
public Page2(Server s)
{
Db_Entities db = new Db_Entities();
string tst = "TEST";
var query1 = (from a in this.db.Servers
             where a.ServerID.Contains(tst)
             orderby a.ServerID
             select a).ToList();
datagrid1.ItemsSource = query1.ToList();
} 

The above code works fine.. but if I uncomment the code for the other two click event's for the prdtst and devtst button, and I pass tha parameters along with (Server s) .. there is ambiguity and errors.. how to achieve for the other two servers ? any ideas ??

EDIT

I have following are the errors when I add these extra blocks to my code

 public Page2(Server x)
    {
    Db_Entities db = new Db_Entities();
    string prd = "PRD";
    var query1 = (from a in this.db.Servers
                 where a.ServerID.Contains(prd)
                 orderby a.ServerID
                 select a).ToList();
    datagrid1.ItemsSource = query1.ToList();
    } 
    public Page2(Server x)
    {
    Db_Entities db = new Db_Entities();
    string dev = "DEV";
    var query1 = (from a in this.db.Servers
                 where a.ServerID.Contains(dev)
                 orderby a.ServerID
                 select a).ToList();
    datagrid1.ItemsSource = query1.ToList();
    }     

Error 1 - I get this error 2 times
Type 'FN_UI.Views.Page2' already defines a member called 'Page2' with the same parameter types 

Error 2 - I get this error 3 times
The call is ambiguous between the following methods or properties: 'FN_UI.Views.Page2.Page2(FN_UI.Server)' and 'FN_UI.Views.Page2.Page2(FN_UI.Server)' 

kindly help

Thanks




Viewing all articles
Browse latest Browse all 18858

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>