aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Scripting/Tango.Scripting.Test/MainWindowVM.cs
diff options
context:
space:
mode:
authorRoy Ben Shabat <Roy@twine-s.com>2020-12-30 15:12:05 +0000
committerRoy Ben Shabat <Roy@twine-s.com>2020-12-30 15:12:05 +0000
commitb88a5d8fbfb4da46ec0e8f64b79fd83013a9de38 (patch)
treeea725abc39def99a755b041c13cba1fe0d594ddc /Software/Visual_Studio/Scripting/Tango.Scripting.Test/MainWindowVM.cs
parent1bdcaa9f51303bbff682507f31fb3b4414692ca4 (diff)
parentd33c19b3ac6803de4b5c8d475832efef131c1a45 (diff)
downloadTango-b88a5d8fbfb4da46ec0e8f64b79fd83013a9de38.tar.gz
Tango-b88a5d8fbfb4da46ec0e8f64b79fd83013a9de38.zip
Merged PR 6: Revert "Hope it is fine"
Revert "Hope it is fine" Reverted commit `1344a54c`.
Diffstat (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting.Test/MainWindowVM.cs')
-rw-r--r--Software/Visual_Studio/Scripting/Tango.Scripting.Test/MainWindowVM.cs69
1 files changed, 69 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting.Test/MainWindowVM.cs b/Software/Visual_Studio/Scripting/Tango.Scripting.Test/MainWindowVM.cs
new file mode 100644
index 000000000..f57de886f
--- /dev/null
+++ b/Software/Visual_Studio/Scripting/Tango.Scripting.Test/MainWindowVM.cs
@@ -0,0 +1,69 @@
+using Microsoft.Win32;
+using System;
+using System.Collections.Generic;
+using System.Collections.ObjectModel;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using System.Windows;
+using Tango.Core.Commands;
+using Tango.Scripting.Basic;
+using Tango.SharedUI;
+
+namespace Tango.Scripting.Test
+{
+ public class TestContext : IContext
+ {
+
+ }
+
+ public class MainWindowVM : ViewModel
+ {
+
+ public RelayCommand AddScriptCommand { get; set; }
+ public RelayCommand RunCommand { get; set; }
+
+ private Project<TestContext> _project;
+ public Project<TestContext> Project
+ {
+ get { return _project; }
+ set { _project = value; RaisePropertyChangedAuto(); }
+ }
+
+ public MainWindowVM()
+ {
+ Project = Project<TestContext>.New("untitled");
+ Project.Scripts.Add(Script.New("main.csx", Encoding.Default.GetString(Properties.Resources.template), true));
+ AddScriptCommand = new RelayCommand(AddScriptFile);
+ RunCommand = new RelayCommand(RunProject);
+ }
+
+ private void AddScriptFile()
+ {
+ OpenFileDialog dlg = new OpenFileDialog();
+ dlg.Filter = "CSharp Script|*.csx";
+ if (dlg.ShowDialog().Value)
+ {
+ AddScript(dlg.FileName);
+ }
+ }
+
+ private void AddScript(String file)
+ {
+ Project.Scripts.Add(Script.New(file));
+ }
+
+ private async void RunProject()
+ {
+ var session = await Project.Run(null);
+
+ session.StateChanged += (x, e) =>
+ {
+ if (e.State == ProjectSessionState.Completed)
+ {
+ MessageBox.Show(e.ReturnValue.ToString());
+ }
+ };
+ }
+ }
+}