Using WECPOF in runtime
No edit summary
No edit summary
Line 45: Line 45:
'''Code Snippet'''
'''Code Snippet'''
   
   
public partial class Window1 : Window
{
  EcoSpace _ecospace;
  MenuHandling _MenuHandling;
  public Window1()
  {
    InitializeComponent();
    // Create ecospace or use one that you have
    _ecospace = new EcoProject1.EcoProject1EcoSpace();
    _ecospace.Active = true;
    // Start up the Eco UI dequeuer ; if not set nothing will show
    WPFDequeuer.Active = true;
    // Load viewmodel definitions from embedded resources
    ViewModelDefinitionsInApplication.Init(_ecospace);
    // Create a WECPOF menu handling component
    _MenuHandling = new MenuHandling();
    // Define where WECPOF should look for styles
    WecpofWinEnv.PathToStyles = Directory.GetCurrentDirectory() + "\\Styles";
    // And to where WECPOF should apply a choosen style
    WecpofWinEnv.ResourceDictionaryTargetForStyles(this);
    // Tell the MenuHandling component where to put the MenuItems. Hand over the list of Actions from ECO, hand over the EcoSpace.
    // Send in the WindowEnvironment defined in xaml, and say in what context should the speed keys be evaluated
    _MenuHandling.InitMainMenu(MainMenu, ViewModelDefinitionsInApplication.GetActionsRuntime(), _ecospace, WecpofWinEnv, this);
    // Let the WECPOF Window environment know about the MenuHandling component
    WecpofWinEnv.InstallMenuHandling(_MenuHandling);
    // Implement the event to implement Quit...
    MenuHandling.OnExit += new EventHandler<EventArgs>(MenuHandling_OnExit);
  }
  void MenuHandling_OnExit(object sender, EventArgs e)
  {
    Close();
  }
}


And you are done:
And you are done:

Revision as of 11:05, 27 October 2018

You can use WECPOF in design time ECO projects and in Gaffr.net files.

This article explains how to use it in runtime to deliver finished applications.

It starts out as an ordinary ECO project (create one from the wizard, Create new project Eco project).

You then create your model, update the code, configure your Persistence mapper of choice, set up any remote persistence mapper and synchronization if you want to just as the PDF-tutorials explain, Create or evolve your database, or derive the model from an existing database with the Reverse derive options.

Then add a WPF-Window or a WPF-Page (for browser applications).

Make sure your project references WECPOFLogic, then add a reference to the xaml :

xmlns:wecpof="clr-namespace:WECPOFLogic;assembly=WECPOFLogic"

And add a MainMenu and a WECPOFWindowEnvironment (this is where the WECPOF windows will be hosted)

Code Snippet

<Window x:Class="WpfApplication1.Window1"
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
   xmlns:toolkit="http://schemas.microsoft.com/wpf/2008/toolkit"
  xmlns:wecpof="clr-namespace:WECPOFLogic;assembly=WECPOFLogic"
  Title="Window1" Height="314" Width="354">
 <Window.Resources>
  <LinearGradientBrush x:Key="WECPOFWinBackgroundBrush" EndPoint="0,1" StartPoint="0,0">
    <GradientStop Color="#CCC" Offset="0.0" />
    <GradientStop Color="#EEE" Offset="1.0" />
  </LinearGradientBrush>
... cut for clarity...
  </Window.Resources>

 <Grid>
  <Grid.RowDefinitions>
   <RowDefinition Height="22"></RowDefinition>
   <RowDefinition></RowDefinition>
  </Grid.RowDefinitions>
  <Menu Grid.Row="0"  Name="MainMenu">
  </Menu>
  <wecpof:WECPOFWindowEnvironment x:Name="WecpofWinEnv">
  </wecpof:WECPOFWindowEnvironment>
 </Grid>
</Window>

In code behind we need to create our ecospace and hook everything up; this is boiler plate code:

Code Snippet

public partial class Window1 : Window {   EcoSpace _ecospace;   MenuHandling _MenuHandling;   public Window1()   {     InitializeComponent();

    // Create ecospace or use one that you have     _ecospace = new EcoProject1.EcoProject1EcoSpace();     _ecospace.Active = true;     // Start up the Eco UI dequeuer ; if not set nothing will show     WPFDequeuer.Active = true;     // Load viewmodel definitions from embedded resources     ViewModelDefinitionsInApplication.Init(_ecospace);

    // Create a WECPOF menu handling component     _MenuHandling = new MenuHandling();

    // Define where WECPOF should look for styles     WecpofWinEnv.PathToStyles = Directory.GetCurrentDirectory() + "\\Styles";     // And to where WECPOF should apply a choosen style     WecpofWinEnv.ResourceDictionaryTargetForStyles(this);     // Tell the MenuHandling component where to put the MenuItems. Hand over the list of Actions from ECO, hand over the EcoSpace.     // Send in the WindowEnvironment defined in xaml, and say in what context should the speed keys be evaluated     _MenuHandling.InitMainMenu(MainMenu, ViewModelDefinitionsInApplication.GetActionsRuntime(), _ecospace, WecpofWinEnv, this);     // Let the WECPOF Window environment know about the MenuHandling component     WecpofWinEnv.InstallMenuHandling(_MenuHandling);     // Implement the event to implement Quit...     MenuHandling.OnExit += new EventHandler<EventArgs>(MenuHandling_OnExit);   }

  void MenuHandling_OnExit(object sender, EventArgs e)   {     Close();   } }

And you are done:

This page was edited more than 11 months ago on 02/10/2024. What links here