lab2
This commit is contained in:
parent
ec97a1419c
commit
b1717c0a78
37
COP_LabWork.sln
Normal file
37
COP_LabWork.sln
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
|
||||||
|
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||||
|
# Visual Studio Version 17
|
||||||
|
VisualStudioVersion = 17.5.33502.453
|
||||||
|
MinimumVisualStudioVersion = 10.0.40219.1
|
||||||
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "TestForms", "TestForms\TestForms.csproj", "{8F7F9843-EC02-4318-B507-0D114253D021}"
|
||||||
|
EndProject
|
||||||
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "CustomComponents", "CustomComponents\CustomComponents.csproj", "{84341626-2887-45C2-9D91-FB8B5A14EBFB}"
|
||||||
|
EndProject
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ExcelComponents", "ExcelComponents\ExcelComponents.csproj", "{D649516B-CA77-4AEF-AB2C-515B92331527}"
|
||||||
|
EndProject
|
||||||
|
Global
|
||||||
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
Debug|Any CPU = Debug|Any CPU
|
||||||
|
Release|Any CPU = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
|
{8F7F9843-EC02-4318-B507-0D114253D021}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{8F7F9843-EC02-4318-B507-0D114253D021}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{8F7F9843-EC02-4318-B507-0D114253D021}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{8F7F9843-EC02-4318-B507-0D114253D021}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
{84341626-2887-45C2-9D91-FB8B5A14EBFB}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{84341626-2887-45C2-9D91-FB8B5A14EBFB}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{84341626-2887-45C2-9D91-FB8B5A14EBFB}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{84341626-2887-45C2-9D91-FB8B5A14EBFB}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
{D649516B-CA77-4AEF-AB2C-515B92331527}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{D649516B-CA77-4AEF-AB2C-515B92331527}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{D649516B-CA77-4AEF-AB2C-515B92331527}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{D649516B-CA77-4AEF-AB2C-515B92331527}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
|
HideSolutionNode = FALSE
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||||
|
SolutionGuid = {308288F3-F285-4816-9F45-4BE8A1BF6F8A}
|
||||||
|
EndGlobalSection
|
||||||
|
EndGlobal
|
10
CustomComponents/CustomComponents.csproj
Normal file
10
CustomComponents/CustomComponents.csproj
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<TargetFramework>net6.0-windows</TargetFramework>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
|
<UseWindowsForms>true</UseWindowsForms>
|
||||||
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
</Project>
|
59
CustomComponents/DateTextBox.Designer.cs
generated
Normal file
59
CustomComponents/DateTextBox.Designer.cs
generated
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
namespace CustomComponents
|
||||||
|
{
|
||||||
|
partial class DateTextBox
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Обязательная переменная конструктора.
|
||||||
|
/// </summary>
|
||||||
|
private System.ComponentModel.IContainer components = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Освободить все используемые ресурсы.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||||
|
protected override void Dispose(bool disposing)
|
||||||
|
{
|
||||||
|
if (disposing && (components != null))
|
||||||
|
{
|
||||||
|
components.Dispose();
|
||||||
|
}
|
||||||
|
base.Dispose(disposing);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Код, автоматически созданный конструктором компонентов
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||||
|
/// содержимое этого метода с помощью редактора кода.
|
||||||
|
/// </summary>
|
||||||
|
private void InitializeComponent()
|
||||||
|
{
|
||||||
|
textBox = new TextBox();
|
||||||
|
SuspendLayout();
|
||||||
|
//
|
||||||
|
// textBox
|
||||||
|
//
|
||||||
|
textBox.Anchor = AnchorStyles.Top | AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
|
||||||
|
textBox.Location = new Point(0, 0);
|
||||||
|
textBox.Name = "textBox";
|
||||||
|
textBox.Size = new Size(150, 27);
|
||||||
|
textBox.TabIndex = 0;
|
||||||
|
textBox.TextChanged += textBox_TextChanged;
|
||||||
|
textBox.Enter += textBox_Enter;
|
||||||
|
//
|
||||||
|
// DateTextBox
|
||||||
|
//
|
||||||
|
AutoScaleDimensions = new SizeF(8F, 20F);
|
||||||
|
AutoScaleMode = AutoScaleMode.Font;
|
||||||
|
Controls.Add(textBox);
|
||||||
|
Name = "DateTextBox";
|
||||||
|
Size = new Size(150, 28);
|
||||||
|
ResumeLayout(false);
|
||||||
|
PerformLayout();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
private TextBox textBox;
|
||||||
|
}
|
||||||
|
}
|
95
CustomComponents/DateTextBox.cs
Normal file
95
CustomComponents/DateTextBox.cs
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel;
|
||||||
|
using System.Data;
|
||||||
|
using System.Drawing;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Text.RegularExpressions;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Forms;
|
||||||
|
|
||||||
|
namespace CustomComponents
|
||||||
|
{
|
||||||
|
public partial class DateTextBox : UserControl
|
||||||
|
{
|
||||||
|
private string? pattern;
|
||||||
|
private string example = "Формат ввода: DD.MM.YYYY";
|
||||||
|
public DateTextBox()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
public string? Pattern
|
||||||
|
{
|
||||||
|
get { return pattern; }
|
||||||
|
set { pattern = value; }
|
||||||
|
}
|
||||||
|
public string TextBoxValue
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
Regex regex = new Regex(Pattern);
|
||||||
|
bool isValid = regex.IsMatch(textBox.Text);
|
||||||
|
if (isValid)
|
||||||
|
{
|
||||||
|
return textBox.Text;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Error = "Неправильный ввод";
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (value == null) return;
|
||||||
|
Regex regex = new Regex(Pattern);
|
||||||
|
bool isValid = regex.IsMatch(value);
|
||||||
|
if (isValid)
|
||||||
|
{
|
||||||
|
textBox.Text = value;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Error = "Неправильно";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public string Error
|
||||||
|
{
|
||||||
|
get; private set;
|
||||||
|
}
|
||||||
|
public void SetExample(string exampleStr)
|
||||||
|
{
|
||||||
|
Regex regex = new Regex(Pattern);
|
||||||
|
bool isValid = regex.IsMatch(exampleStr);
|
||||||
|
if (isValid)
|
||||||
|
{
|
||||||
|
example = exampleStr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void textBox_Enter(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
ToolTip tt = new ToolTip();
|
||||||
|
tt.Show(example, textBox, 30, -20, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void textBox_TextChanged(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
_changeEvent?.Invoke(sender, e);
|
||||||
|
}
|
||||||
|
|
||||||
|
private EventHandler _changeEvent;
|
||||||
|
public event EventHandler ChangeEvent
|
||||||
|
{
|
||||||
|
add
|
||||||
|
{
|
||||||
|
_changeEvent += value;
|
||||||
|
}
|
||||||
|
remove
|
||||||
|
{
|
||||||
|
_changeEvent -= value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
60
CustomComponents/DateTextBox.resx
Normal file
60
CustomComponents/DateTextBox.resx
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
<root>
|
||||||
|
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||||
|
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||||
|
<xsd:element name="root" msdata:IsDataSet="true">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:choice maxOccurs="unbounded">
|
||||||
|
<xsd:element name="metadata">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="assembly">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:attribute name="alias" type="xsd:string" />
|
||||||
|
<xsd:attribute name="name" type="xsd:string" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="data">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="resheader">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:choice>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:schema>
|
||||||
|
<resheader name="resmimetype">
|
||||||
|
<value>text/microsoft-resx</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="version">
|
||||||
|
<value>2.0</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="reader">
|
||||||
|
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="writer">
|
||||||
|
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
</root>
|
58
CustomComponents/DropDownList.Designer.cs
generated
Normal file
58
CustomComponents/DropDownList.Designer.cs
generated
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
namespace CustomComponents
|
||||||
|
{
|
||||||
|
partial class DropDownList
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Обязательная переменная конструктора.
|
||||||
|
/// </summary>
|
||||||
|
private System.ComponentModel.IContainer components = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Освободить все используемые ресурсы.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||||
|
protected override void Dispose(bool disposing)
|
||||||
|
{
|
||||||
|
if (disposing && (components != null))
|
||||||
|
{
|
||||||
|
components.Dispose();
|
||||||
|
}
|
||||||
|
base.Dispose(disposing);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Код, автоматически созданный конструктором компонентов
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||||
|
/// содержимое этого метода с помощью редактора кода.
|
||||||
|
/// </summary>
|
||||||
|
private void InitializeComponent()
|
||||||
|
{
|
||||||
|
ComboBox = new ComboBox();
|
||||||
|
SuspendLayout();
|
||||||
|
//
|
||||||
|
// ComboBox
|
||||||
|
//
|
||||||
|
ComboBox.DropDownStyle = ComboBoxStyle.DropDownList;
|
||||||
|
ComboBox.FormattingEnabled = true;
|
||||||
|
ComboBox.Location = new Point(0, 0);
|
||||||
|
ComboBox.Name = "ComboBox";
|
||||||
|
ComboBox.Size = new Size(151, 28);
|
||||||
|
ComboBox.TabIndex = 0;
|
||||||
|
ComboBox.SelectedIndexChanged += ComboBox_SelectedIndexChanged;
|
||||||
|
//
|
||||||
|
// DropDownList
|
||||||
|
//
|
||||||
|
AutoScaleDimensions = new SizeF(8F, 20F);
|
||||||
|
AutoScaleMode = AutoScaleMode.Font;
|
||||||
|
Controls.Add(ComboBox);
|
||||||
|
Name = "DropDownList";
|
||||||
|
Size = new Size(154, 29);
|
||||||
|
ResumeLayout(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
private ComboBox ComboBox;
|
||||||
|
}
|
||||||
|
}
|
70
CustomComponents/DropDownList.cs
Normal file
70
CustomComponents/DropDownList.cs
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel;
|
||||||
|
using System.Data;
|
||||||
|
using System.Drawing;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Forms;
|
||||||
|
|
||||||
|
namespace CustomComponents
|
||||||
|
{
|
||||||
|
public partial class DropDownList : UserControl
|
||||||
|
{
|
||||||
|
public DropDownList()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
public void AddToList(string value)
|
||||||
|
{
|
||||||
|
if (value == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ComboBox.Items.Add(value);
|
||||||
|
}
|
||||||
|
public void ClearList()
|
||||||
|
{
|
||||||
|
ComboBox.Items.Clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ComboBox_SelectedIndexChanged(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
_changeEvent?.Invoke(sender, e);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public string? Selected
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (ComboBox.Items.Count == 0 || ComboBox.SelectedItem == null)
|
||||||
|
{
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
return ComboBox.SelectedItem.ToString()!;
|
||||||
|
}
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (ComboBox.Items.Contains(value))
|
||||||
|
{
|
||||||
|
ComboBox.SelectedItem = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private EventHandler _changeEvent;
|
||||||
|
public event EventHandler ChangeEvent
|
||||||
|
{
|
||||||
|
add
|
||||||
|
{
|
||||||
|
_changeEvent += value;
|
||||||
|
}
|
||||||
|
remove
|
||||||
|
{
|
||||||
|
_changeEvent -= value;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
60
CustomComponents/DropDownList.resx
Normal file
60
CustomComponents/DropDownList.resx
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
<root>
|
||||||
|
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||||
|
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||||
|
<xsd:element name="root" msdata:IsDataSet="true">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:choice maxOccurs="unbounded">
|
||||||
|
<xsd:element name="metadata">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="assembly">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:attribute name="alias" type="xsd:string" />
|
||||||
|
<xsd:attribute name="name" type="xsd:string" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="data">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="resheader">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:choice>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:schema>
|
||||||
|
<resheader name="resmimetype">
|
||||||
|
<value>text/microsoft-resx</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="version">
|
||||||
|
<value>2.0</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="reader">
|
||||||
|
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="writer">
|
||||||
|
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
</root>
|
57
CustomComponents/ListBoxObjects.Designer.cs
generated
Normal file
57
CustomComponents/ListBoxObjects.Designer.cs
generated
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
namespace CustomComponents
|
||||||
|
{
|
||||||
|
partial class ListBoxObjects
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Обязательная переменная конструктора.
|
||||||
|
/// </summary>
|
||||||
|
private System.ComponentModel.IContainer components = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Освободить все используемые ресурсы.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||||
|
protected override void Dispose(bool disposing)
|
||||||
|
{
|
||||||
|
if (disposing && (components != null))
|
||||||
|
{
|
||||||
|
components.Dispose();
|
||||||
|
}
|
||||||
|
base.Dispose(disposing);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Код, автоматически созданный конструктором компонентов
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||||
|
/// содержимое этого метода с помощью редактора кода.
|
||||||
|
/// </summary>
|
||||||
|
private void InitializeComponent()
|
||||||
|
{
|
||||||
|
listBox = new ListBox();
|
||||||
|
SuspendLayout();
|
||||||
|
//
|
||||||
|
// listBox
|
||||||
|
//
|
||||||
|
listBox.FormattingEnabled = true;
|
||||||
|
listBox.ItemHeight = 20;
|
||||||
|
listBox.Location = new Point(0, 0);
|
||||||
|
listBox.Name = "listBox";
|
||||||
|
listBox.Size = new Size(458, 144);
|
||||||
|
listBox.TabIndex = 0;
|
||||||
|
//
|
||||||
|
// ListBoxObjects
|
||||||
|
//
|
||||||
|
AutoScaleDimensions = new SizeF(8F, 20F);
|
||||||
|
AutoScaleMode = AutoScaleMode.Font;
|
||||||
|
Controls.Add(listBox);
|
||||||
|
Name = "ListBoxObjects";
|
||||||
|
Size = new Size(458, 143);
|
||||||
|
ResumeLayout(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
private ListBox listBox;
|
||||||
|
}
|
||||||
|
}
|
95
CustomComponents/ListBoxObjects.cs
Normal file
95
CustomComponents/ListBoxObjects.cs
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel;
|
||||||
|
using System.Data;
|
||||||
|
using System.Drawing;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Forms;
|
||||||
|
|
||||||
|
namespace CustomComponents
|
||||||
|
{
|
||||||
|
public partial class ListBoxObjects : UserControl
|
||||||
|
{
|
||||||
|
private string LayoutString;
|
||||||
|
private string StartS;
|
||||||
|
private string EndS;
|
||||||
|
private int SelectedStr;
|
||||||
|
public ListBoxObjects()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
public int SelectedIndex {
|
||||||
|
get {
|
||||||
|
if (listBox.SelectedIndex == -1)
|
||||||
|
{
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return listBox.SelectedIndex;
|
||||||
|
}
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if(listBox.Items.Count != 0)
|
||||||
|
{
|
||||||
|
listBox.SelectedIndex = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void SetLayout(string layoutString, string startS, string endS)
|
||||||
|
{
|
||||||
|
if (layoutString == null || startS == null || endS == null) return;
|
||||||
|
LayoutString = layoutString;
|
||||||
|
StartS = startS;
|
||||||
|
EndS = endS;
|
||||||
|
}
|
||||||
|
public void AddItemInList<T>(T Object)
|
||||||
|
{
|
||||||
|
if (Object == null)
|
||||||
|
{
|
||||||
|
throw new ArgumentNullException();
|
||||||
|
}
|
||||||
|
if (!LayoutString.Contains(StartS) && !LayoutString.Contains(EndS))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
string str = LayoutString;
|
||||||
|
|
||||||
|
foreach (var prop in Object.GetType().GetProperties())
|
||||||
|
{
|
||||||
|
string str1 = $"{StartS}" + prop.Name + $"{EndS}";
|
||||||
|
str = str.Replace(str1, $"{StartS}" + prop.GetValue(Object).ToString() + $"{EndS}");
|
||||||
|
}
|
||||||
|
listBox.Items.Add(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
public T GetItemFromList<T>() where T : class, new()
|
||||||
|
{
|
||||||
|
string SelectedStr = "";
|
||||||
|
if (listBox.SelectedIndex != -1)
|
||||||
|
{
|
||||||
|
SelectedStr = listBox.SelectedItem.ToString();
|
||||||
|
}
|
||||||
|
|
||||||
|
T currentObject = new T();
|
||||||
|
|
||||||
|
foreach (var prop in typeof(T).GetProperties())
|
||||||
|
{
|
||||||
|
if (!prop.CanWrite)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
int startS = SelectedStr.IndexOf(StartS);
|
||||||
|
int endS = SelectedStr.IndexOf(EndS);
|
||||||
|
if (startS == -1 || endS == -1)
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
string propValue = SelectedStr.Substring(startS + 1, endS - startS - 1);
|
||||||
|
SelectedStr = SelectedStr.Substring(endS + 1);
|
||||||
|
prop.SetValue(currentObject, Convert.ChangeType(propValue, prop.PropertyType));
|
||||||
|
}
|
||||||
|
return currentObject;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
60
CustomComponents/ListBoxObjects.resx
Normal file
60
CustomComponents/ListBoxObjects.resx
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
<root>
|
||||||
|
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||||
|
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||||
|
<xsd:element name="root" msdata:IsDataSet="true">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:choice maxOccurs="unbounded">
|
||||||
|
<xsd:element name="metadata">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="assembly">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:attribute name="alias" type="xsd:string" />
|
||||||
|
<xsd:attribute name="name" type="xsd:string" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="data">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="resheader">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:choice>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:schema>
|
||||||
|
<resheader name="resmimetype">
|
||||||
|
<value>text/microsoft-resx</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="version">
|
||||||
|
<value>2.0</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="reader">
|
||||||
|
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="writer">
|
||||||
|
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
</root>
|
22
CustomComponents/Objects/DaysOfWeek.cs
Normal file
22
CustomComponents/Objects/DaysOfWeek.cs
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace CustomComponents.Objects
|
||||||
|
{
|
||||||
|
public class DaysOfWeek
|
||||||
|
{
|
||||||
|
public DateTime Date { get; set; }
|
||||||
|
public string Day { get; set; }
|
||||||
|
public int Temperature { get; set; }
|
||||||
|
public DaysOfWeek(DateTime date, string day, int temperature)
|
||||||
|
{
|
||||||
|
Date = date;
|
||||||
|
Day = day;
|
||||||
|
Temperature = temperature;
|
||||||
|
}
|
||||||
|
public DaysOfWeek() { }
|
||||||
|
}
|
||||||
|
}
|
36
ExcelComponents/BigTextExcel.Designer.cs
generated
Normal file
36
ExcelComponents/BigTextExcel.Designer.cs
generated
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
namespace ExcelComponents
|
||||||
|
{
|
||||||
|
partial class BigTextExcel
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Обязательная переменная конструктора.
|
||||||
|
/// </summary>
|
||||||
|
private System.ComponentModel.IContainer components = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Освободить все используемые ресурсы.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||||
|
protected override void Dispose(bool disposing)
|
||||||
|
{
|
||||||
|
if (disposing && (components != null))
|
||||||
|
{
|
||||||
|
components.Dispose();
|
||||||
|
}
|
||||||
|
base.Dispose(disposing);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Код, автоматически созданный конструктором компонентов
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||||
|
/// содержимое этого метода с помощью редактора кода.
|
||||||
|
/// </summary>
|
||||||
|
private void InitializeComponent()
|
||||||
|
{
|
||||||
|
components = new System.ComponentModel.Container();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
44
ExcelComponents/BigTextExcel.cs
Normal file
44
ExcelComponents/BigTextExcel.cs
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
using ExcelComponents.Models;
|
||||||
|
using System.ComponentModel;
|
||||||
|
|
||||||
|
namespace ExcelComponents
|
||||||
|
{
|
||||||
|
public partial class BigTextExcel : Component
|
||||||
|
{
|
||||||
|
private readonly ExcelBuilder builder = new();
|
||||||
|
public BigTextExcel()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
|
||||||
|
public BigTextExcel(IContainer container)
|
||||||
|
{
|
||||||
|
container.Add(this);
|
||||||
|
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
private static bool ConfigIsCorrect(BigTextConfig config)
|
||||||
|
{
|
||||||
|
if(config == null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if(string.IsNullOrEmpty(config.FilePath) || File.Exists(config.FilePath))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
public void BigTextGen(BigTextConfig config)
|
||||||
|
{
|
||||||
|
if(!ConfigIsCorrect(config))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
builder.CreateDocument();
|
||||||
|
builder.InsertText(1, 1, config.Title);
|
||||||
|
builder.InsertBigText(config.Text);
|
||||||
|
builder.SaveDocument(config.FilePath);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
221
ExcelComponents/ExcelBuilder.cs
Normal file
221
ExcelComponents/ExcelBuilder.cs
Normal file
@ -0,0 +1,221 @@
|
|||||||
|
using ExcelComponents.Models;
|
||||||
|
using OfficeOpenXml;
|
||||||
|
using OfficeOpenXml.Drawing.Chart;
|
||||||
|
using OfficeOpenXml.Style;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Data.Common;
|
||||||
|
using System.Drawing.Drawing2D;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ExcelComponents
|
||||||
|
{
|
||||||
|
public class ExcelBuilder
|
||||||
|
{
|
||||||
|
private ExcelPackage? package = null;
|
||||||
|
private ExcelWorksheet? worksheet = null;
|
||||||
|
public ExcelBuilder()
|
||||||
|
{
|
||||||
|
ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
|
||||||
|
}
|
||||||
|
private void SetStyle(int row, int col, ExcelCellStyle style)
|
||||||
|
{
|
||||||
|
if (worksheet == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ExcelStyle excelStyle = worksheet.Cells[row, col].Style;
|
||||||
|
excelStyle.WrapText = style.WrapText;
|
||||||
|
excelStyle.HorizontalAlignment = style.HorizontalAlignment;
|
||||||
|
excelStyle.VerticalAlignment = style.VerticalAlignment;
|
||||||
|
excelStyle.Border.Top.Style = style.TopBorderStyle;
|
||||||
|
excelStyle.Border.Bottom.Style = style.BottomBorderStyle;
|
||||||
|
excelStyle.Border.Left.Style = style.LeftBorderStyle;
|
||||||
|
excelStyle.Border.Right.Style = style.RightBorderStyle;
|
||||||
|
}
|
||||||
|
private void SetStyle(int row, int col, int endRow, int endCol, ExcelCellStyle style)
|
||||||
|
{
|
||||||
|
if (worksheet == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ExcelStyle excelStyle = worksheet.Cells[row, col, endRow, endCol].Style;
|
||||||
|
excelStyle.WrapText = style.WrapText;
|
||||||
|
excelStyle.HorizontalAlignment = style.HorizontalAlignment;
|
||||||
|
excelStyle.VerticalAlignment = style.VerticalAlignment;
|
||||||
|
excelStyle.Border.Top.Style = style.TopBorderStyle;
|
||||||
|
excelStyle.Border.Bottom.Style = style.BottomBorderStyle;
|
||||||
|
excelStyle.Border.Left.Style = style.LeftBorderStyle;
|
||||||
|
excelStyle.Border.Right.Style = style.RightBorderStyle;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void MergeCells(int row, int col, int endRow, int endCol, ExcelCellStyle? style = null)
|
||||||
|
{
|
||||||
|
if(worksheet == null) { return; }
|
||||||
|
worksheet.Cells[row, col, endRow, endCol].Merge = true;
|
||||||
|
style ??= new();
|
||||||
|
SetStyle(row, col, endRow, endCol, style);
|
||||||
|
}
|
||||||
|
public void ConfigureColumns(double[] columnWidth)
|
||||||
|
{
|
||||||
|
if(worksheet == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for(int i = 0; i < columnWidth.Length; i++)
|
||||||
|
{
|
||||||
|
worksheet.Column(i+1).Width = columnWidth[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void CreateDocument()
|
||||||
|
{
|
||||||
|
package = new();
|
||||||
|
worksheet = package.Workbook.Worksheets.Add("First list");
|
||||||
|
}
|
||||||
|
public void SaveDocument(string filePath)
|
||||||
|
{
|
||||||
|
package?.SaveAs(filePath);
|
||||||
|
}
|
||||||
|
public void InsertText(int row, int column, string str,ExcelCellStyle? style = null)
|
||||||
|
{
|
||||||
|
if(worksheet == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
worksheet.Cells[row, column].Value = str;
|
||||||
|
style ??= new();
|
||||||
|
SetStyle(row, column, style);
|
||||||
|
}
|
||||||
|
private static string GetPropertyValue<T>(string propertyName, T obj)
|
||||||
|
{
|
||||||
|
Type type = typeof(T);
|
||||||
|
string value = type.GetProperty(propertyName)!.GetValue(obj, null).ToString()!;
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
public void InsertTable<T>(Dictionary<int, int> merge, string[] headers, string[] props, T[] data )
|
||||||
|
{
|
||||||
|
if(worksheet == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ExcelCellStyle style = new()
|
||||||
|
{
|
||||||
|
NoBorder = false,
|
||||||
|
WrapText = true,
|
||||||
|
};
|
||||||
|
|
||||||
|
int rowInd = 2;
|
||||||
|
int colStart = 1;
|
||||||
|
int colInd = colStart;
|
||||||
|
int mergeskip = 0;
|
||||||
|
|
||||||
|
foreach(string header in headers){
|
||||||
|
InsertText(rowInd, colInd, header,style);
|
||||||
|
if (mergeskip == 0)
|
||||||
|
{
|
||||||
|
if (!merge.ContainsKey(colInd - colStart))
|
||||||
|
{
|
||||||
|
MergeCells(rowInd, colInd, rowInd + 1, colInd, style);
|
||||||
|
colInd++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
int colEnd = colInd + merge[colInd - colStart] - 1;
|
||||||
|
MergeCells(rowInd, colInd, rowInd, colEnd, style);
|
||||||
|
rowInd = 3;
|
||||||
|
mergeskip = merge[colInd - colStart];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
mergeskip--;
|
||||||
|
colInd++;
|
||||||
|
if(mergeskip == 0)
|
||||||
|
{
|
||||||
|
rowInd = 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
rowInd++;
|
||||||
|
for(int i = 0; i < data.Length; i++)
|
||||||
|
{
|
||||||
|
colInd = colStart;
|
||||||
|
rowInd++;
|
||||||
|
foreach(string prop in props)
|
||||||
|
{
|
||||||
|
string value = GetPropertyValue(prop, data[i]);
|
||||||
|
InsertText(rowInd, colInd, value, style);
|
||||||
|
colInd++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void InsertBigText(string[] text, ExcelCellStyle? style = null)
|
||||||
|
{
|
||||||
|
if (worksheet == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
style ??= new() { HorizontalAlignment = ExcelHorizontalAlignment.Left};
|
||||||
|
for (int i = 0; i < text.Length; i++)
|
||||||
|
{
|
||||||
|
worksheet.Cells[i + 2, 1].Value = text[i];
|
||||||
|
MergeCells(i + 2, 1, i + 2, text[i].Length / 7 + 1, style);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void InsertLinearChart(string chartTitle, List<(string, double[])> data, string[] labels, ChartLegendPosition legendPosition)
|
||||||
|
{
|
||||||
|
if(worksheet == null) { return; }
|
||||||
|
ExcelChart linearchar = (ExcelLineChart)worksheet.Drawings.AddChart("Linear Chart", eChartType.Line);
|
||||||
|
linearchar.Title.Text = chartTitle;
|
||||||
|
foreach(var item in data)
|
||||||
|
{
|
||||||
|
linearchar.Series.Add(ArrayToString(item.Item2)).Header = item.Item1;
|
||||||
|
}
|
||||||
|
linearchar.Series[0].XSeries = ArrayToString(labels);
|
||||||
|
linearchar.Legend.Position = GetLegendPosition(legendPosition);
|
||||||
|
linearchar.SetSize(500, 500);
|
||||||
|
linearchar.SetPosition(1, 0, 0, 0);
|
||||||
|
}
|
||||||
|
private static string ArrayToString<T>(T[] data)
|
||||||
|
{
|
||||||
|
StringBuilder builder = new StringBuilder("{");
|
||||||
|
for(int i = 0; i < data.Length; i++)
|
||||||
|
{
|
||||||
|
if (typeof(T) == typeof(string))
|
||||||
|
{
|
||||||
|
builder.Append($"\"{data[i]}\"");
|
||||||
|
}
|
||||||
|
else if (typeof(T) == typeof(double))
|
||||||
|
{
|
||||||
|
builder.Append(data[i].ToString().Replace(",", "."));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
builder.Append(data[i].ToString());
|
||||||
|
}
|
||||||
|
if(i == data.Length - 1)
|
||||||
|
{
|
||||||
|
builder.Append('}');
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
builder.Append(',');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return builder.ToString();
|
||||||
|
}
|
||||||
|
private static eLegendPosition GetLegendPosition(ChartLegendPosition legendPosition)
|
||||||
|
{
|
||||||
|
return legendPosition switch
|
||||||
|
{
|
||||||
|
ChartLegendPosition.Top => eLegendPosition.Top,
|
||||||
|
ChartLegendPosition.Bottom => eLegendPosition.Bottom,
|
||||||
|
ChartLegendPosition.Left => eLegendPosition.Left,
|
||||||
|
ChartLegendPosition.Right => eLegendPosition.Right,
|
||||||
|
_ => eLegendPosition.Right
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
14
ExcelComponents/ExcelComponents.csproj
Normal file
14
ExcelComponents/ExcelComponents.csproj
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<TargetFramework>net6.0-windows</TargetFramework>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
|
<UseWindowsForms>true</UseWindowsForms>
|
||||||
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<PackageReference Include="EPPlus" Version="6.2.9" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
</Project>
|
36
ExcelComponents/ExcelLinearChart.Designer.cs
generated
Normal file
36
ExcelComponents/ExcelLinearChart.Designer.cs
generated
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
namespace ExcelComponents
|
||||||
|
{
|
||||||
|
partial class ExcelLinearChart
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Обязательная переменная конструктора.
|
||||||
|
/// </summary>
|
||||||
|
private System.ComponentModel.IContainer components = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Освободить все используемые ресурсы.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||||
|
protected override void Dispose(bool disposing)
|
||||||
|
{
|
||||||
|
if (disposing && (components != null))
|
||||||
|
{
|
||||||
|
components.Dispose();
|
||||||
|
}
|
||||||
|
base.Dispose(disposing);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Код, автоматически созданный конструктором компонентов
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||||
|
/// содержимое этого метода с помощью редактора кода.
|
||||||
|
/// </summary>
|
||||||
|
private void InitializeComponent()
|
||||||
|
{
|
||||||
|
components = new System.ComponentModel.Container();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
57
ExcelComponents/ExcelLinearChart.cs
Normal file
57
ExcelComponents/ExcelLinearChart.cs
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
using ExcelComponents.Models;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ExcelComponents
|
||||||
|
{
|
||||||
|
public partial class ExcelLinearChart : Component
|
||||||
|
{
|
||||||
|
ExcelBuilder builder = new ExcelBuilder();
|
||||||
|
public ExcelLinearChart()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
|
||||||
|
public ExcelLinearChart(IContainer container)
|
||||||
|
{
|
||||||
|
container.Add(this);
|
||||||
|
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
private static bool ConfigIsCorrect(LinearChartConfig config)
|
||||||
|
{
|
||||||
|
if (config == null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (string.IsNullOrEmpty(config.FilePath) || File.Exists(config.FilePath))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
foreach(var item in config.Data)
|
||||||
|
{
|
||||||
|
if (config.Labels.Length != item.Item2.Length)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
public void GenChart(LinearChartConfig config)
|
||||||
|
{
|
||||||
|
if (!ConfigIsCorrect(config))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
builder.CreateDocument();
|
||||||
|
builder.InsertText(1, 1, config.Title);
|
||||||
|
builder.InsertLinearChart(config.ChartTitle, config.Data, config.Labels, config.LegendPosition);
|
||||||
|
builder.SaveDocument(config.FilePath);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
36
ExcelComponents/ExcelTable.Designer.cs
generated
Normal file
36
ExcelComponents/ExcelTable.Designer.cs
generated
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
namespace ExcelComponents
|
||||||
|
{
|
||||||
|
partial class ExcelTable
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Обязательная переменная конструктора.
|
||||||
|
/// </summary>
|
||||||
|
private System.ComponentModel.IContainer components = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Освободить все используемые ресурсы.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="disposing">истинно, если управляемый ресурс должен быть удален; иначе ложно.</param>
|
||||||
|
protected override void Dispose(bool disposing)
|
||||||
|
{
|
||||||
|
if (disposing && (components != null))
|
||||||
|
{
|
||||||
|
components.Dispose();
|
||||||
|
}
|
||||||
|
base.Dispose(disposing);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Код, автоматически созданный конструктором компонентов
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Требуемый метод для поддержки конструктора — не изменяйте
|
||||||
|
/// содержимое этого метода с помощью редактора кода.
|
||||||
|
/// </summary>
|
||||||
|
private void InitializeComponent()
|
||||||
|
{
|
||||||
|
components = new System.ComponentModel.Container();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
60
ExcelComponents/ExcelTable.cs
Normal file
60
ExcelComponents/ExcelTable.cs
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
using ExcelComponents.Models;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ExcelComponents
|
||||||
|
{
|
||||||
|
public partial class ExcelTable : Component
|
||||||
|
{
|
||||||
|
private readonly ExcelBuilder builder = new();
|
||||||
|
public ExcelTable()
|
||||||
|
{
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
|
||||||
|
public ExcelTable(IContainer container)
|
||||||
|
{
|
||||||
|
container.Add(this);
|
||||||
|
|
||||||
|
InitializeComponent();
|
||||||
|
}
|
||||||
|
private static bool ConfigIsCorrect<T>(TableConfig<T> config)
|
||||||
|
{
|
||||||
|
if (config == null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (string.IsNullOrEmpty(config.FilePath) || File.Exists(config.FilePath))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
int[] mergeIndexes = config.Merge.Keys.ToArray();
|
||||||
|
Array.Sort(mergeIndexes);
|
||||||
|
for(int i = 0; i < mergeIndexes.Length - 1; i++)
|
||||||
|
{
|
||||||
|
if (mergeIndexes[i] + config.Merge[mergeIndexes[i]] >= mergeIndexes[i+1])
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
public void GenTable<T>(TableConfig<T> config)
|
||||||
|
{
|
||||||
|
if(!ConfigIsCorrect(config))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
builder.CreateDocument();
|
||||||
|
builder.ConfigureColumns(config.ColWidth);
|
||||||
|
builder.InsertText(1, 1, config.Title);
|
||||||
|
builder.InsertTable(config.Merge, config.Headers, config.Props, config.Data);
|
||||||
|
builder.SaveDocument(config.FilePath);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
17
ExcelComponents/Models/BigTextConfig.cs
Normal file
17
ExcelComponents/Models/BigTextConfig.cs
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ExcelComponents.Models
|
||||||
|
{
|
||||||
|
public class BigTextConfig : ExcelConfig
|
||||||
|
{
|
||||||
|
public string[] Text { get; set; }
|
||||||
|
public BigTextConfig()
|
||||||
|
{
|
||||||
|
Text = Array.Empty<string>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
16
ExcelComponents/Models/ChartLegendPosition.cs
Normal file
16
ExcelComponents/Models/ChartLegendPosition.cs
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ExcelComponents.Models
|
||||||
|
{
|
||||||
|
public enum ChartLegendPosition
|
||||||
|
{
|
||||||
|
Top = 1,
|
||||||
|
Bottom = 2,
|
||||||
|
Left = 3,
|
||||||
|
Right = 4
|
||||||
|
}
|
||||||
|
}
|
92
ExcelComponents/Models/ExcelCellStyle.cs
Normal file
92
ExcelComponents/Models/ExcelCellStyle.cs
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
using OfficeOpenXml.Style;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Forms.VisualStyles;
|
||||||
|
|
||||||
|
namespace ExcelComponents.Models
|
||||||
|
{
|
||||||
|
public class ExcelCellStyle
|
||||||
|
{
|
||||||
|
public bool WrapText {get; set;}
|
||||||
|
public ExcelHorizontalAlignment HorizontalAlignment { get; set;}
|
||||||
|
public ExcelVerticalAlignment VerticalAlignment { get; set;}
|
||||||
|
public bool NoBorder { get; set;}
|
||||||
|
private ExcelBorderStyle topBorderStyle;
|
||||||
|
public ExcelBorderStyle TopBorderStyle {
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (NoBorder)
|
||||||
|
{
|
||||||
|
return ExcelBorderStyle.None;
|
||||||
|
}
|
||||||
|
return topBorderStyle;
|
||||||
|
}
|
||||||
|
set
|
||||||
|
{
|
||||||
|
topBorderStyle = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private ExcelBorderStyle bottomBorderStyle;
|
||||||
|
public ExcelBorderStyle BottomBorderStyle
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (NoBorder)
|
||||||
|
{
|
||||||
|
return ExcelBorderStyle.None;
|
||||||
|
}
|
||||||
|
return bottomBorderStyle;
|
||||||
|
}
|
||||||
|
set
|
||||||
|
{
|
||||||
|
bottomBorderStyle = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private ExcelBorderStyle leftBorderStyle;
|
||||||
|
public ExcelBorderStyle LeftBorderStyle
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (NoBorder)
|
||||||
|
{
|
||||||
|
return ExcelBorderStyle.None;
|
||||||
|
}
|
||||||
|
return leftBorderStyle;
|
||||||
|
}
|
||||||
|
set
|
||||||
|
{
|
||||||
|
leftBorderStyle = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private ExcelBorderStyle rightBorderStyle;
|
||||||
|
public ExcelBorderStyle RightBorderStyle
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (NoBorder)
|
||||||
|
{
|
||||||
|
return ExcelBorderStyle.None;
|
||||||
|
}
|
||||||
|
return rightBorderStyle;
|
||||||
|
}
|
||||||
|
set
|
||||||
|
{
|
||||||
|
rightBorderStyle = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public ExcelCellStyle()
|
||||||
|
{
|
||||||
|
WrapText = false;
|
||||||
|
NoBorder = true;
|
||||||
|
HorizontalAlignment = ExcelHorizontalAlignment.Center;
|
||||||
|
VerticalAlignment = ExcelVerticalAlignment.Center;
|
||||||
|
topBorderStyle = ExcelBorderStyle.Thin;
|
||||||
|
bottomBorderStyle = ExcelBorderStyle.Thin;
|
||||||
|
leftBorderStyle = ExcelBorderStyle.Thin;
|
||||||
|
rightBorderStyle = ExcelBorderStyle.Thin;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
20
ExcelComponents/Models/ExcelConfig.cs
Normal file
20
ExcelComponents/Models/ExcelConfig.cs
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Security.Policy;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ExcelComponents.Models
|
||||||
|
{
|
||||||
|
public class ExcelConfig
|
||||||
|
{
|
||||||
|
public string FilePath { get; set; }
|
||||||
|
public string Title { get; set; }
|
||||||
|
public ExcelConfig()
|
||||||
|
{
|
||||||
|
FilePath = string.Empty;
|
||||||
|
Title = string.Empty;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
23
ExcelComponents/Models/LinearChartConfig.cs
Normal file
23
ExcelComponents/Models/LinearChartConfig.cs
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ExcelComponents.Models
|
||||||
|
{
|
||||||
|
public class LinearChartConfig : ExcelConfig
|
||||||
|
{
|
||||||
|
public string ChartTitle { get; set; }
|
||||||
|
public List<(string, double[])> Data {get; set;}
|
||||||
|
public string[] Labels { get; set; }
|
||||||
|
public ChartLegendPosition LegendPosition { get; set; }
|
||||||
|
public LinearChartConfig()
|
||||||
|
{
|
||||||
|
ChartTitle = string.Empty;
|
||||||
|
Data = new List<(string, double[])>();
|
||||||
|
Labels = Array.Empty<string>();
|
||||||
|
LegendPosition = ChartLegendPosition.Right;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
25
ExcelComponents/Models/TableConfig.cs
Normal file
25
ExcelComponents/Models/TableConfig.cs
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ExcelComponents.Models
|
||||||
|
{
|
||||||
|
public class TableConfig<T> : ExcelConfig
|
||||||
|
{
|
||||||
|
public string[] Headers { get; set; }
|
||||||
|
public double[] ColWidth { get; set; }
|
||||||
|
public T[] Data { get; set; }
|
||||||
|
public string[] Props { get; set; }
|
||||||
|
public Dictionary<int, int> Merge { get; set; }
|
||||||
|
public TableConfig()
|
||||||
|
{
|
||||||
|
Headers = Array.Empty<string>();
|
||||||
|
ColWidth = Array.Empty<double>();
|
||||||
|
Data = Array.Empty<T>();
|
||||||
|
Merge = new();
|
||||||
|
Props = Array.Empty<string>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
16
TestForms/Employee.cs
Normal file
16
TestForms/Employee.cs
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
namespace TestForms
|
||||||
|
{
|
||||||
|
public class Employee
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public bool Status { get; set; }
|
||||||
|
public string FirstName { get; set; } = string.Empty;
|
||||||
|
public string LastName { get; set; } = string.Empty;
|
||||||
|
public int Age { get; set; }
|
||||||
|
public bool Children { get; set; }
|
||||||
|
public bool Car { get; set; }
|
||||||
|
public string Subdivision { get; set; } = string.Empty;
|
||||||
|
public string Post { get; set; } = string.Empty;
|
||||||
|
public double Bonus { get; set; }
|
||||||
|
}
|
||||||
|
}
|
17
TestForms/Program.cs
Normal file
17
TestForms/Program.cs
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
namespace TestForms
|
||||||
|
{
|
||||||
|
internal static class Program
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// The main entry point for the application.
|
||||||
|
/// </summary>
|
||||||
|
[STAThread]
|
||||||
|
static void Main()
|
||||||
|
{
|
||||||
|
// To customize application configuration such as set high DPI settings or default font,
|
||||||
|
// see https://aka.ms/applicationconfiguration.
|
||||||
|
ApplicationConfiguration.Initialize();
|
||||||
|
Application.Run(new TestForm());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
177
TestForms/TestForm.Designer.cs
generated
Normal file
177
TestForms/TestForm.Designer.cs
generated
Normal file
@ -0,0 +1,177 @@
|
|||||||
|
namespace TestForms
|
||||||
|
{
|
||||||
|
partial class TestForm
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Required designer variable.
|
||||||
|
/// </summary>
|
||||||
|
private System.ComponentModel.IContainer components = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Clean up any resources being used.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
|
||||||
|
protected override void Dispose(bool disposing)
|
||||||
|
{
|
||||||
|
if (disposing && (components != null))
|
||||||
|
{
|
||||||
|
components.Dispose();
|
||||||
|
}
|
||||||
|
base.Dispose(disposing);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Windows Form Designer generated code
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Required method for Designer support - do not modify
|
||||||
|
/// the contents of this method with the code editor.
|
||||||
|
/// </summary>
|
||||||
|
private void InitializeComponent()
|
||||||
|
{
|
||||||
|
components = new System.ComponentModel.Container();
|
||||||
|
textBoxTitle = new TextBox();
|
||||||
|
ButtonBigText = new Button();
|
||||||
|
saveFileDialog = new SaveFileDialog();
|
||||||
|
bigTextExcel = new ExcelComponents.BigTextExcel(components);
|
||||||
|
excelTable = new ExcelComponents.ExcelTable(components);
|
||||||
|
ButtonTable = new Button();
|
||||||
|
richTextBox = new RichTextBox();
|
||||||
|
label1 = new Label();
|
||||||
|
label2 = new Label();
|
||||||
|
label3 = new Label();
|
||||||
|
ButtonChart = new Button();
|
||||||
|
excelLinearChart = new ExcelComponents.ExcelLinearChart(components);
|
||||||
|
textBoxChartTitle = new TextBox();
|
||||||
|
label4 = new Label();
|
||||||
|
SuspendLayout();
|
||||||
|
//
|
||||||
|
// textBoxTitle
|
||||||
|
//
|
||||||
|
textBoxTitle.Location = new Point(12, 45);
|
||||||
|
textBoxTitle.Name = "textBoxTitle";
|
||||||
|
textBoxTitle.Size = new Size(148, 27);
|
||||||
|
textBoxTitle.TabIndex = 15;
|
||||||
|
//
|
||||||
|
// ButtonBigText
|
||||||
|
//
|
||||||
|
ButtonBigText.Location = new Point(12, 103);
|
||||||
|
ButtonBigText.Name = "ButtonBigText";
|
||||||
|
ButtonBigText.Size = new Size(148, 29);
|
||||||
|
ButtonBigText.TabIndex = 16;
|
||||||
|
ButtonBigText.Text = "Create Big Text";
|
||||||
|
ButtonBigText.UseVisualStyleBackColor = true;
|
||||||
|
ButtonBigText.Click += ButtonBigText_Click;
|
||||||
|
//
|
||||||
|
// saveFileDialog
|
||||||
|
//
|
||||||
|
saveFileDialog.FileName = "output.xlsx";
|
||||||
|
//
|
||||||
|
// ButtonTable
|
||||||
|
//
|
||||||
|
ButtonTable.Location = new Point(12, 138);
|
||||||
|
ButtonTable.Name = "ButtonTable";
|
||||||
|
ButtonTable.Size = new Size(148, 29);
|
||||||
|
ButtonTable.TabIndex = 18;
|
||||||
|
ButtonTable.Text = "Сreate Table";
|
||||||
|
ButtonTable.UseVisualStyleBackColor = true;
|
||||||
|
ButtonTable.Click += ButtonTable_Click;
|
||||||
|
//
|
||||||
|
// richTextBox
|
||||||
|
//
|
||||||
|
richTextBox.Location = new Point(185, 45);
|
||||||
|
richTextBox.Name = "richTextBox";
|
||||||
|
richTextBox.Size = new Size(432, 104);
|
||||||
|
richTextBox.TabIndex = 19;
|
||||||
|
richTextBox.Text = "Всё ускоряющаяся эволюция\n компьютерных технологий предъявила \nжёсткие\n требования к производителям как собственно вычислительной техники, так и\n периферийных устройств.";
|
||||||
|
//
|
||||||
|
// label1
|
||||||
|
//
|
||||||
|
label1.AutoSize = true;
|
||||||
|
label1.Location = new Point(12, 22);
|
||||||
|
label1.Name = "label1";
|
||||||
|
label1.Size = new Size(38, 20);
|
||||||
|
label1.TabIndex = 20;
|
||||||
|
label1.Text = "Title";
|
||||||
|
//
|
||||||
|
// label2
|
||||||
|
//
|
||||||
|
label2.AutoSize = true;
|
||||||
|
label2.Location = new Point(12, 80);
|
||||||
|
label2.Name = "label2";
|
||||||
|
label2.Size = new Size(83, 20);
|
||||||
|
label2.TabIndex = 21;
|
||||||
|
label2.Text = "Some work";
|
||||||
|
//
|
||||||
|
// label3
|
||||||
|
//
|
||||||
|
label3.AutoSize = true;
|
||||||
|
label3.Location = new Point(185, 22);
|
||||||
|
label3.Name = "label3";
|
||||||
|
label3.Size = new Size(69, 20);
|
||||||
|
label3.TabIndex = 22;
|
||||||
|
label3.Text = "BIG TEXT";
|
||||||
|
//
|
||||||
|
// ButtonChart
|
||||||
|
//
|
||||||
|
ButtonChart.Location = new Point(12, 173);
|
||||||
|
ButtonChart.Name = "ButtonChart";
|
||||||
|
ButtonChart.Size = new Size(148, 29);
|
||||||
|
ButtonChart.TabIndex = 23;
|
||||||
|
ButtonChart.Text = "Create chart";
|
||||||
|
ButtonChart.UseVisualStyleBackColor = true;
|
||||||
|
ButtonChart.Click += ButtonChart_Click;
|
||||||
|
//
|
||||||
|
// textBoxChartTitle
|
||||||
|
//
|
||||||
|
textBoxChartTitle.Location = new Point(185, 175);
|
||||||
|
textBoxChartTitle.Name = "textBoxChartTitle";
|
||||||
|
textBoxChartTitle.Size = new Size(123, 27);
|
||||||
|
textBoxChartTitle.TabIndex = 24;
|
||||||
|
//
|
||||||
|
// label4
|
||||||
|
//
|
||||||
|
label4.AutoSize = true;
|
||||||
|
label4.Location = new Point(185, 152);
|
||||||
|
label4.Name = "label4";
|
||||||
|
label4.Size = new Size(73, 20);
|
||||||
|
label4.TabIndex = 25;
|
||||||
|
label4.Text = "ChartTitle";
|
||||||
|
//
|
||||||
|
// TestForm
|
||||||
|
//
|
||||||
|
AutoScaleDimensions = new SizeF(8F, 20F);
|
||||||
|
AutoScaleMode = AutoScaleMode.Font;
|
||||||
|
ClientSize = new Size(632, 360);
|
||||||
|
Controls.Add(label4);
|
||||||
|
Controls.Add(textBoxChartTitle);
|
||||||
|
Controls.Add(ButtonChart);
|
||||||
|
Controls.Add(label3);
|
||||||
|
Controls.Add(label2);
|
||||||
|
Controls.Add(label1);
|
||||||
|
Controls.Add(richTextBox);
|
||||||
|
Controls.Add(ButtonTable);
|
||||||
|
Controls.Add(ButtonBigText);
|
||||||
|
Controls.Add(textBoxTitle);
|
||||||
|
Name = "TestForm";
|
||||||
|
Text = "TestForm";
|
||||||
|
ResumeLayout(false);
|
||||||
|
PerformLayout();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
private TextBox textBoxTitle;
|
||||||
|
private Button ButtonBigText;
|
||||||
|
private SaveFileDialog saveFileDialog;
|
||||||
|
private ExcelComponents.BigTextExcel bigTextExcel;
|
||||||
|
private ExcelComponents.ExcelTable excelTable;
|
||||||
|
private Button ButtonTable;
|
||||||
|
private RichTextBox richTextBox;
|
||||||
|
private Label label1;
|
||||||
|
private Label label2;
|
||||||
|
private Label label3;
|
||||||
|
private Button ButtonChart;
|
||||||
|
private ExcelComponents.ExcelLinearChart excelLinearChart;
|
||||||
|
private TextBox textBoxChartTitle;
|
||||||
|
private Label label4;
|
||||||
|
}
|
||||||
|
}
|
118
TestForms/TestForm.cs
Normal file
118
TestForms/TestForm.cs
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
using CustomComponents.Objects;
|
||||||
|
using ExcelComponents.Models;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel;
|
||||||
|
using System.Data;
|
||||||
|
using System.Drawing;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Windows.Forms;
|
||||||
|
|
||||||
|
namespace TestForms
|
||||||
|
{
|
||||||
|
public partial class TestForm : Form
|
||||||
|
{
|
||||||
|
public TestForm()
|
||||||
|
{
|
||||||
|
|
||||||
|
InitializeComponent();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ButtonBigText_Click(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
if (saveFileDialog.ShowDialog() == DialogResult.OK && !string.IsNullOrEmpty(textBoxTitle.Text))
|
||||||
|
{
|
||||||
|
bigTextExcel.BigTextGen(new BigTextConfig()
|
||||||
|
{
|
||||||
|
FilePath = saveFileDialog.FileName,
|
||||||
|
Title = textBoxTitle.Text,
|
||||||
|
Text = richTextBox.Lines
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ButtonTable_Click(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
if (saveFileDialog.ShowDialog() == DialogResult.OK && !string.IsNullOrEmpty(textBoxTitle.Text))
|
||||||
|
{
|
||||||
|
string[] headers = new[]
|
||||||
|
{
|
||||||
|
"Идент", "Статус", "Личные данные",
|
||||||
|
"Имя", "Фамилия", "Возраст",
|
||||||
|
"Дети", "Машина", "Работа",
|
||||||
|
"Подразделение", "Должность", "Премия"
|
||||||
|
};
|
||||||
|
double[] colWidth = new double[] { 10, 10, 15, 15, 15, 10, 10, 15, 15, 10 };
|
||||||
|
Dictionary<int, int> merge = new() { [7] = 2, [2] = 3 };
|
||||||
|
Employee[] data = new Employee[]
|
||||||
|
{
|
||||||
|
new Employee()
|
||||||
|
{
|
||||||
|
Id = 1,
|
||||||
|
Status = false,
|
||||||
|
FirstName = "First name 1",
|
||||||
|
LastName = "Last name 1",
|
||||||
|
Age = 20,
|
||||||
|
Children = true,
|
||||||
|
Car = false,
|
||||||
|
Subdivision = "Subdivision 1",
|
||||||
|
Post = "Post 1",
|
||||||
|
Bonus = 0.0
|
||||||
|
},
|
||||||
|
new Employee()
|
||||||
|
{
|
||||||
|
Id = 2,
|
||||||
|
Status = false,
|
||||||
|
FirstName = "First name 2",
|
||||||
|
LastName = "Last name 2",
|
||||||
|
Age = 21,
|
||||||
|
Children = false,
|
||||||
|
Car = true,
|
||||||
|
Subdivision = "Subdivision 2",
|
||||||
|
Post = "Post 2",
|
||||||
|
Bonus = 2.0
|
||||||
|
},
|
||||||
|
};
|
||||||
|
string[] props = new string[]
|
||||||
|
{
|
||||||
|
"Id", "Status", "FirstName",
|
||||||
|
"LastName", "Age", "Children",
|
||||||
|
"Car", "Subdivision", "Post", "Bonus"
|
||||||
|
};
|
||||||
|
excelTable.GenTable(new TableConfig<Employee>()
|
||||||
|
{
|
||||||
|
Title = textBoxTitle.Text,
|
||||||
|
FilePath = saveFileDialog.FileName,
|
||||||
|
ColWidth = colWidth,
|
||||||
|
Headers = headers,
|
||||||
|
Data = data,
|
||||||
|
Props = props,
|
||||||
|
Merge = merge
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ButtonChart_Click(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
if (saveFileDialog.ShowDialog() == DialogResult.OK && !string.IsNullOrEmpty(textBoxTitle.Text) && !string.IsNullOrEmpty(textBoxChartTitle.Text))
|
||||||
|
{
|
||||||
|
excelLinearChart.GenChart(new LinearChartConfig()
|
||||||
|
{
|
||||||
|
Title = textBoxTitle.Text,
|
||||||
|
FilePath = saveFileDialog.FileName,
|
||||||
|
ChartTitle = textBoxChartTitle.Text,
|
||||||
|
Data = new List<(string, double[])>
|
||||||
|
{
|
||||||
|
("header1", new double[] { 5.5, 4, 3, 2.7, 1 }),
|
||||||
|
("header2", new double[] { 1.2, 2.1, 3.2, 4, 5 })
|
||||||
|
},
|
||||||
|
Labels = new[] { "pepsi", "cola", "fanta", "idk", "pchel" },
|
||||||
|
LegendPosition = ChartLegendPosition.Bottom
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
72
TestForms/TestForm.resx
Normal file
72
TestForms/TestForm.resx
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
<root>
|
||||||
|
<xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
|
||||||
|
<xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
|
||||||
|
<xsd:element name="root" msdata:IsDataSet="true">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:choice maxOccurs="unbounded">
|
||||||
|
<xsd:element name="metadata">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" use="required" type="xsd:string" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="assembly">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:attribute name="alias" type="xsd:string" />
|
||||||
|
<xsd:attribute name="name" type="xsd:string" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="data">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
<xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
|
||||||
|
<xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
|
||||||
|
<xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
|
||||||
|
<xsd:attribute ref="xml:space" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
<xsd:element name="resheader">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
|
||||||
|
</xsd:sequence>
|
||||||
|
<xsd:attribute name="name" type="xsd:string" use="required" />
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:choice>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:schema>
|
||||||
|
<resheader name="resmimetype">
|
||||||
|
<value>text/microsoft-resx</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="version">
|
||||||
|
<value>2.0</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="reader">
|
||||||
|
<value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
<resheader name="writer">
|
||||||
|
<value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</resheader>
|
||||||
|
<metadata name="saveFileDialog.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||||
|
<value>17, 17</value>
|
||||||
|
</metadata>
|
||||||
|
<metadata name="bigTextExcel.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||||
|
<value>171, 17</value>
|
||||||
|
</metadata>
|
||||||
|
<metadata name="excelTable.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||||
|
<value>308, 17</value>
|
||||||
|
</metadata>
|
||||||
|
<metadata name="excelLinearChart.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
|
||||||
|
<value>431, 17</value>
|
||||||
|
</metadata>
|
||||||
|
</root>
|
16
TestForms/TestForms.csproj
Normal file
16
TestForms/TestForms.csproj
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<OutputType>WinExe</OutputType>
|
||||||
|
<TargetFramework>net6.0-windows</TargetFramework>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
|
<UseWindowsForms>true</UseWindowsForms>
|
||||||
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<ProjectReference Include="..\CustomComponents\CustomComponents.csproj" />
|
||||||
|
<ProjectReference Include="..\ExcelComponents\ExcelComponents.csproj" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
</Project>
|
Loading…
Reference in New Issue
Block a user