Compare commits
No commits in common. "lab2" and "master" have entirely different histories.
@ -1,37 +0,0 @@
|
|||||||
|
|
||||||
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
|
|
@ -1,10 +0,0 @@
|
|||||||
<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
59
CustomComponents/DateTextBox.Designer.cs
generated
@ -1,59 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,95 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,60 +0,0 @@
|
|||||||
<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
58
CustomComponents/DropDownList.Designer.cs
generated
@ -1,58 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,70 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,60 +0,0 @@
|
|||||||
<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
57
CustomComponents/ListBoxObjects.Designer.cs
generated
@ -1,57 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,95 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,60 +0,0 @@
|
|||||||
<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>
|
|
@ -1,22 +0,0 @@
|
|||||||
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
36
ExcelComponents/BigTextExcel.Designer.cs
generated
@ -1,36 +0,0 @@
|
|||||||
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
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,44 +0,0 @@
|
|||||||
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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,221 +0,0 @@
|
|||||||
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
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,14 +0,0 @@
|
|||||||
<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
36
ExcelComponents/ExcelLinearChart.Designer.cs
generated
@ -1,36 +0,0 @@
|
|||||||
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
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,57 +0,0 @@
|
|||||||
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
36
ExcelComponents/ExcelTable.Designer.cs
generated
@ -1,36 +0,0 @@
|
|||||||
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
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,60 +0,0 @@
|
|||||||
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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,17 +0,0 @@
|
|||||||
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>();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,16 +0,0 @@
|
|||||||
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
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,92 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,20 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,23 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
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>();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,16 +0,0 @@
|
|||||||
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; }
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,17 +0,0 @@
|
|||||||
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
177
TestForms/TestForm.Designer.cs
generated
@ -1,177 +0,0 @@
|
|||||||
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;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,118 +0,0 @@
|
|||||||
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
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,72 +0,0 @@
|
|||||||
<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>
|
|
@ -1,16 +0,0 @@
|
|||||||
<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