Skip to content

Commit 20bfe7c

Browse files
committed
Merge remote-tracking branch 'origin/master'
2 parents 9bd4897 + 0bf0798 commit 20bfe7c

13 files changed

+685
-211
lines changed

Src/SwqlStudio/CrudOperation.cs

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
namespace SwqlStudio
2+
{
3+
public enum CrudOperation
4+
{
5+
Create, Update, Delete
6+
}
7+
}

Src/SwqlStudio/CrudTab.Designer.cs

Lines changed: 57 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

Src/SwqlStudio/CrudTab.cs

Lines changed: 169 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,169 @@
1+
using System;
2+
using System.Collections.Generic;
3+
using System.Windows.Forms;
4+
using SolarWinds.InformationService.Contract2;
5+
using SwqlStudio.Metadata;
6+
7+
namespace SwqlStudio
8+
{
9+
public partial class CrudTab : UserControl, IConnectionTab
10+
{
11+
private const int ControlsMargin = 3;
12+
private readonly CrudOperation _operation;
13+
14+
private readonly Dictionary<Property, TextBox> _textboxes = new Dictionary<Property, TextBox>();
15+
private TextBox _uri;
16+
private Entity _entity;
17+
18+
public CrudTab(CrudOperation operation)
19+
{
20+
_operation = operation;
21+
InitializeComponent();
22+
}
23+
24+
public Entity Entity
25+
{
26+
get => _entity;
27+
set
28+
{
29+
_entity = value;
30+
CreateSubComponents();
31+
}
32+
}
33+
34+
/// <inheritdoc />
35+
public IApplicationService ApplicationService { get; set; }
36+
37+
/// <inheritdoc />
38+
public ConnectionInfo ConnectionInfo { get; set; }
39+
40+
public event EventHandler CloseItself;
41+
42+
private void CreateSubComponents()
43+
{
44+
_textboxes.Clear();
45+
container.Controls.Clear();
46+
container.SuspendLayout();
47+
try
48+
{
49+
var y = 0;
50+
51+
bool createProperties = true;
52+
switch (_operation)
53+
{
54+
case CrudOperation.Create:
55+
break;
56+
case CrudOperation.Delete:
57+
createProperties = false;
58+
goto case CrudOperation.Update;
59+
case CrudOperation.Update:
60+
_uri = CreateLabelAndTextbox("SwisUri", ref y);
61+
y += ControlsMargin * 3;
62+
break;
63+
default:
64+
throw new ArgumentOutOfRangeException();
65+
}
66+
67+
// for delete, uri is enough
68+
if (createProperties)
69+
{
70+
foreach (var property in _entity.Properties)
71+
{
72+
var textBox = CreateLabelAndTextbox(property.Name, ref y);
73+
74+
_textboxes[property] = textBox;
75+
}
76+
}
77+
78+
var commit = new Button();
79+
container.Controls.Add(commit);
80+
81+
commit.Text = _operation.ToString();
82+
commit.Top = y;
83+
commit.AutoSize = true;
84+
commit.Click += OnCommit;
85+
}
86+
finally
87+
{
88+
container.ResumeLayout();
89+
}
90+
}
91+
92+
private void OnCommit(object sender, EventArgs e)
93+
{
94+
var propertyBag = CreatePropertyBag();
95+
96+
try
97+
{
98+
var message = "";
99+
switch (_operation)
100+
{
101+
case CrudOperation.Create:
102+
var rv = ConnectionInfo.Proxy.Create(_entity.FullName, propertyBag);
103+
message = $"Created: {rv}";
104+
break;
105+
case CrudOperation.Update:
106+
ConnectionInfo.Proxy.Update(_uri.Text, propertyBag);
107+
message = "OK";
108+
break;
109+
case CrudOperation.Delete:
110+
ConnectionInfo.Proxy.Delete(_uri.Text);
111+
message = "OK";
112+
break;
113+
default:
114+
throw new ArgumentOutOfRangeException();
115+
}
116+
117+
MessageBox.Show(message, "SwqlStudio", MessageBoxButtons.OK, MessageBoxIcon.Information);
118+
OnCloseItself();
119+
}
120+
catch (Exception ex)
121+
{
122+
MessageBox.Show($"Failed to {_operation}: {ex.Message}",
123+
"SwqlStudio",
124+
MessageBoxButtons.OK,
125+
MessageBoxIcon.Error);
126+
}
127+
}
128+
129+
private PropertyBag CreatePropertyBag()
130+
{
131+
var rv = new PropertyBag();
132+
foreach (var property in _textboxes)
133+
{
134+
if (!string.IsNullOrEmpty(property.Value.Text))
135+
{
136+
rv[property.Key.Name] = property.Value.Text;
137+
}
138+
}
139+
140+
return rv;
141+
}
142+
143+
144+
private TextBox CreateLabelAndTextbox(string name, ref int y)
145+
{
146+
var label = new Label();
147+
container.Controls.Add(label);
148+
149+
label.Text = name;
150+
label.AutoSize = true;
151+
label.Top = y;
152+
y += label.Height + ControlsMargin;
153+
154+
var textBox = new TextBox();
155+
container.Controls.Add(textBox);
156+
textBox.Top = y;
157+
textBox.Anchor = AnchorStyles.Left | AnchorStyles.Top | AnchorStyles.Right;
158+
textBox.Width = container.Width - ControlsMargin * 2;
159+
textBox.Left = ControlsMargin;
160+
y += textBox.Height + ControlsMargin;
161+
return textBox;
162+
}
163+
164+
protected virtual void OnCloseItself()
165+
{
166+
CloseItself?.Invoke(this, EventArgs.Empty);
167+
}
168+
}
169+
}

Src/SwqlStudio/CrudTab.resx

Lines changed: 120 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,120 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<root>
3+
<!--
4+
Microsoft ResX Schema
5+
6+
Version 2.0
7+
8+
The primary goals of this format is to allow a simple XML format
9+
that is mostly human readable. The generation and parsing of the
10+
various data types are done through the TypeConverter classes
11+
associated with the data types.
12+
13+
Example:
14+
15+
... ado.net/XML headers & schema ...
16+
<resheader name="resmimetype">text/microsoft-resx</resheader>
17+
<resheader name="version">2.0</resheader>
18+
<resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
19+
<resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
20+
<data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
21+
<data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
22+
<data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
23+
<value>[base64 mime encoded serialized .NET Framework object]</value>
24+
</data>
25+
<data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
26+
<value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
27+
<comment>This is a comment</comment>
28+
</data>
29+
30+
There are any number of "resheader" rows that contain simple
31+
name/value pairs.
32+
33+
Each data row contains a name, and value. The row also contains a
34+
type or mimetype. Type corresponds to a .NET class that support
35+
text/value conversion through the TypeConverter architecture.
36+
Classes that don't support this are serialized and stored with the
37+
mimetype set.
38+
39+
The mimetype is used for serialized objects, and tells the
40+
ResXResourceReader how to depersist the object. This is currently not
41+
extensible. For a given mimetype the value must be set accordingly:
42+
43+
Note - application/x-microsoft.net.object.binary.base64 is the format
44+
that the ResXResourceWriter will generate, however the reader can
45+
read any of the formats listed below.
46+
47+
mimetype: application/x-microsoft.net.object.binary.base64
48+
value : The object must be serialized with
49+
: System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
50+
: and then encoded with base64 encoding.
51+
52+
mimetype: application/x-microsoft.net.object.soap.base64
53+
value : The object must be serialized with
54+
: System.Runtime.Serialization.Formatters.Soap.SoapFormatter
55+
: and then encoded with base64 encoding.
56+
57+
mimetype: application/x-microsoft.net.object.bytearray.base64
58+
value : The object must be serialized into a byte array
59+
: using a System.ComponentModel.TypeConverter
60+
: and then encoded with base64 encoding.
61+
-->
62+
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
63+
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
64+
<xsd:element name="root" msdata:IsDataSet="true">
65+
<xsd:complexType>
66+
<xsd:choice maxOccurs="unbounded">
67+
<xsd:element name="metadata">
68+
<xsd:complexType>
69+
<xsd:sequence>
70+
<xsd:element name="value" type="xsd:string" minOccurs="0" />
71+
</xsd:sequence>
72+
<xsd:attribute name="name" use="required" type="xsd:string" />
73+
<xsd:attribute name="type" type="xsd:string" />
74+
<xsd:attribute name="mimetype" type="xsd:string" />
75+
<xsd:attribute ref="xml:space" />
76+
</xsd:complexType>
77+
</xsd:element>
78+
<xsd:element name="assembly">
79+
<xsd:complexType>
80+
<xsd:attribute name="alias" type="xsd:string" />
81+
<xsd:attribute name="name" type="xsd:string" />
82+
</xsd:complexType>
83+
</xsd:element>
84+
<xsd:element name="data">
85+
<xsd:complexType>
86+
<xsd:sequence>
87+
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
88+
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
89+
</xsd:sequence>
90+
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
91+
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
92+
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
93+
<xsd:attribute ref="xml:space" />
94+
</xsd:complexType>
95+
</xsd:element>
96+
<xsd:element name="resheader">
97+
<xsd:complexType>
98+
<xsd:sequence>
99+
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
100+
</xsd:sequence>
101+
<xsd:attribute name="name" type="xsd:string" use="required" />
102+
</xsd:complexType>
103+
</xsd:element>
104+
</xsd:choice>
105+
</xsd:complexType>
106+
</xsd:element>
107+
</xsd:schema>
108+
<resheader name="resmimetype">
109+
<value>text/microsoft-resx</value>
110+
</resheader>
111+
<resheader name="version">
112+
<value>2.0</value>
113+
</resheader>
114+
<resheader name="reader">
115+
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
116+
</resheader>
117+
<resheader name="writer">
118+
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
119+
</resheader>
120+
</root>

Src/SwqlStudio/IApplicationService.cs

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -13,5 +13,7 @@ public interface IApplicationService
1313
void OpenActivityMonitor(string title, ConnectionInfo connectionInfo);
1414

1515
void OpenInvokeTab(string title, ConnectionInfo connectionInfo, Verb verb);
16+
17+
void OpenCrudTab(CrudOperation operation, ConnectionInfo connectionInfo, Entity entity);
1618
}
1719
}

Src/SwqlStudio/MainForm.ApplicationService.cs

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -38,5 +38,28 @@ public void OpenInvokeTab(string title, ConnectionInfo info, Verb verb)
3838
fileTabs.Controls.Add(tab);
3939
fileTabs.SelectedTab = tab;
4040
}
41+
42+
/// <inheritdoc />
43+
public void OpenCrudTab(CrudOperation operation, ConnectionInfo info, Entity entity)
44+
{
45+
var tab = new TabPage(entity.FullName + " - " + operation) { BorderStyle = BorderStyle.None, Padding = new Padding(0) };
46+
var crudTab = new CrudTab(operation)
47+
{
48+
ConnectionInfo = info,
49+
Dock = DockStyle.Fill,
50+
ApplicationService = this,
51+
Entity = entity
52+
};
53+
54+
crudTab.CloseItself += (s, e) =>
55+
{
56+
fileTabs.TabPages.Remove(tab);
57+
tab.Dispose();
58+
};
59+
60+
tab.Controls.Add(crudTab);
61+
fileTabs.Controls.Add(tab);
62+
fileTabs.SelectedTab = tab;
63+
}
4164
}
4265
}

0 commit comments

Comments
 (0)