using DocumentFormat.OpenXml.Packaging; using DocumentFormat.OpenXml.Wordprocessing; using DocumentFormat.OpenXml; using EmployeeManagmentBusinessLogic.BusinessLogic; using EmployeeManagmentContracts.BusinessLogicContracts; using EmployeeManagmentContracts.ViewModels; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.IO; using Microsoft.Win32; namespace EmployeeManagmentView.Employee { /// /// Логика взаимодействия для AddEmployeeWindow.xaml /// public partial class AddEmployeeWindow : Window { private readonly IEmployeeLogic _employeeLogic; private readonly IPhisicalPersonLogic _phisicalPersonLogic; public AddEmployeeWindow(IEmployeeLogic employeeLogic, IPhisicalPersonLogic phisicalPersonLogic) { _employeeLogic = employeeLogic; _phisicalPersonLogic = phisicalPersonLogic; InitializeComponent(); LoadPhysicalPersons(); } private void LoadPhysicalPersons() { if (PhysicalPersonComboBox == null) { throw new InvalidOperationException("PhysicalPersonComboBox не инициализирован."); } var persons = _phisicalPersonLogic.GetFullList(); PhysicalPersonComboBox.ItemsSource = persons; PhysicalPersonComboBox.DisplayMemberPath = "FullNameWithBirthday"; PhysicalPersonComboBox.SelectedValuePath = "Id"; } private void NameTextBox_PreviewTextInput(object sender, System.Windows.Input.TextCompositionEventArgs e) { // Разрешаем только буквы e.Handled = !char.IsLetter(e.Text, 0); } private void NameTextBox_TextChanged(object sender, TextChangedEventArgs e) { var textBox = sender as TextBox; if (textBox == null) return; // Получаем текущий текст string currentText = textBox.Text; // Если текст не пустой, преобразуем первую букву в заглавную, а остальные в строчные if (!string.IsNullOrEmpty(currentText)) { // Разбиваем строку по пробелам, чтобы обрабатывать каждое слово отдельно var words = currentText.Split(new[] { ' ' }, StringSplitOptions.RemoveEmptyEntries); for (int i = 0; i < words.Length; i++) { // Преобразуем первую букву в заглавную, а остальные в строчные words[i] = char.ToUpper(words[i][0]) + words[i].Substring(1).ToLower(); } // Объединяем слова обратно в строку и обновляем текст textBox.Text = string.Join(" ", words); // Устанавливаем курсор в конец текста textBox.SelectionStart = textBox.Text.Length; } } // Проверка на ввод только чисел и одной запятой private void DecimalTextBox_PreviewTextInput(object sender, System.Windows.Input.TextCompositionEventArgs e) { var textBox = sender as TextBox; if (textBox == null) return; // Разрешаем только цифры и запятую e.Handled = !(char.IsDigit(e.Text, 0) || e.Text == ","); // Проверка на количество запятых if (e.Text == "," && textBox.Text.Contains(",")) { e.Handled = true; } } // Ограничение на 2 знака после запятой private void DecimalTextBox_TextChanged(object sender, TextChangedEventArgs e) { var textBox = sender as TextBox; if (textBox == null) return; // Получаем текущий текст string currentText = textBox.Text; // Проверяем наличие запятой int commaIndex = currentText.IndexOf(','); if (commaIndex != -1 && currentText.Length - commaIndex > 3) { // Обрезаем текст до двух знаков после запятой textBox.Text = currentText.Substring(0, commaIndex + 3); textBox.SelectionStart = textBox.Text.Length; // Устанавливаем курсор в конец текста } } private void TelephoneTextBox_PreviewTextInput(object sender, System.Windows.Input.TextCompositionEventArgs e) { e.Handled = !char.IsDigit(e.Text, 0); } public static void CreateEmploymentContract(string filePath, string employeeName, string jobTitle, DateTime startDate, DateTime? endDate, decimal hourlyRate, string partTimeInfo) { using (WordprocessingDocument wordDocument = WordprocessingDocument.Create(filePath, WordprocessingDocumentType.Document)) { // Добавление основной части документа MainDocumentPart mainPart = wordDocument.AddMainDocumentPart(); mainPart.Document = new Document(); Body body = new Body(); // Канцелярская информация body.Append(new Paragraph(new Run(new Text($"Номер договора: {Guid.NewGuid().ToString("N").ToUpper().Substring(0, 10)}")))); body.Append(new Paragraph(new Run(new Text($"Дата составления: {DateTime.Now:dd.MM.yyyy}")))); // Заголовок body.Append(new Paragraph(new Run(new Text("Трудовой договор")) { RunProperties = new RunProperties { Bold = new Bold(), FontSize = new FontSize { Val = "28" } } })); // Преамбула body.Append(new Paragraph(new Run(new Text( "Настоящий трудовой договор (далее – Договор) заключается между Работодателем, " + "именуемым далее «Работодатель», и Работником, именуемым далее «Работник», на " + "основании Трудового кодекса Российской Федерации. Работодатель обязуется " + "предоставить Работнику работу по должности, указанной в настоящем договоре, " + "обеспечивать необходимые условия труда, а Работник обязуется лично выполнять " + "трудовые функции в соответствии с условиями договора." )))); // Сведения о работнике body.Append(new Paragraph(new Run(new Text($"Сотрудник: {employeeName}")))); body.Append(new Paragraph(new Run(new Text($"Должность: {jobTitle}")))); body.Append(new Paragraph(new Run(new Text($"Дата начала работы: {startDate:dd.MM.yyyy}")))); body.Append(new Paragraph(new Run(new Text(endDate.HasValue ? $"Дата окончания работы: {endDate:dd.MM.yyyy}" : "Дата окончания работы: бессрочный договор")))); body.Append(new Paragraph(new Run(new Text($"Ставка: {hourlyRate}")))); body.Append(new Paragraph(new Run(new Text($"Совместительство: {partTimeInfo}")))); // Создание параграфа с текстом, который будет перенесен body.Append(new Paragraph( new Run(new Text("Условия трудового договора:")))); // Пример добавления нескольких строк с переносом string contractConditions = "1. Рабочее время Работника составляет 40 часов в неделю, если иное не предусмотрено " + "действующим законодательством. Работник обязуется являться на рабочее место своевременно, " + "выполнять свои трудовые обязанности добросовестно и качественно.\n" + "2. Работодатель обязуется своевременно выплачивать Работнику заработную плату. Заработная плата " + "состоит из оклада и дополнительных выплат в виде премий и надбавок.\n" + "3. Работник имеет право на ежегодный оплачиваемый отпуск продолжительностью 28 календарных дней, " + "а также другие виды отпусков в соответствии с законодательством.\n" + "4. Работодатель имеет право привлекать Работника к дисциплинарной ответственности в случаях, " + "предусмотренных Трудовым кодексом РФ."; // Разбиваем на строки и добавляем в документ foreach (var line in contractConditions.Split('\n')) { body.Append(new Paragraph(new Run(new Text(line)))); } // Права и обязанности работника body.Append(new Paragraph(new Run(new Text("Права и обязанности Работника:")))); string rules = "1. Работник имеет право на:\n" + " 1.1. Получение своевременной оплаты труда.\n" + " 1.2. Условия труда, соответствующие установленным нормам охраны труда.\n" + " 1.3. Отдых в соответствии с трудовым законодательством Российской Федерации.\n" + "2. Работник обязан:\n" + " 2.1. Соблюдать правила внутреннего трудового распорядка.\n" + " 2.2. Выполнять должностные обязанности в соответствии с трудовым договором и локальными нормативными актами Работодателя.\n" + " 2.3. Бережно относиться к имуществу Работодателя."; // Разбиваем на строки и добавляем в документ foreach (var line in rules.Split('\n')) { body.Append(new Paragraph(new Run(new Text(line)))); } // Права и обязанности работодателя body.Append(new Paragraph(new Run(new Text("Права и обязанности Работодателя:")))); string rulesRussia = "1. Работодатель имеет право на:\n" + " 1.1. Привлечение Работника к выполнению трудовых функций в рамках установленных обязанностей.\n" + " 1.2. Осуществление контроля за выполнением Работником трудовых обязанностей.\n" + "2. Работодатель обязан:\n" + " 2.1. Своевременно выплачивать заработную плату Работнику.\n" + " 2.2. Предоставлять Работнику возможность использовать ежегодный оплачиваемый отпуск.\n" + " 2.3. Соблюдать нормы трудового законодательства Российской Федерации."; // Разбиваем на строки и добавляем в документ foreach (var line in rulesRussia.Split('\n')) { body.Append(new Paragraph(new Run(new Text(line)))); } // Подписи сторон body.Append(new Paragraph(new Run(new Text("\nПодписи сторон:")))); body.Append(new Paragraph(new Run(new Text("\nРаботодатель: _______________________")))); body.Append(new Paragraph(new Run(new Text("\nРаботник: ___________________________")))); // Привязка тела документа mainPart.Document.Append(body); mainPart.Document.Save(); } } private void GenerateContractButton_Click(object sender, RoutedEventArgs e) { // Проверка данных if (string.IsNullOrWhiteSpace(JobNameTextBox.Text) || !StartDatePicker.SelectedDate.HasValue || string.IsNullOrWhiteSpace(BidTextBox.Text) || string.IsNullOrWhiteSpace(PhysicalPersonComboBox.Text)) { MessageBox.Show("Пожалуйста, заполните все обязательные поля."); return; } // Получение данных string employeeName = PhysicalPersonComboBox.Text; string jobTitle = JobNameTextBox.Text; DateTime startDate = StartDatePicker.SelectedDate.Value; DateTime? endDate = EndDatePicker.SelectedDate; decimal hourlyRate = decimal.Parse(BidTextBox.Text); string partTimeInfo = PartTimeJobTextBox.Text; try { // Открытие диалогового окна для сохранения файла SaveFileDialog saveFileDialog = new SaveFileDialog { Filter = "Excel файлы (*.docx)|*.docx", // фильтр для файлов .docx Title = "Сохранить договор о трудоустройстве", // заголовок окна FileName = "Договор.docx" // имя по умолчанию }; // Проверка, что пользователь выбрал путь и имя файла if (saveFileDialog.ShowDialog() == true) { string filePath = saveFileDialog.FileName; // Путь и имя файла CreateEmploymentContract(filePath, employeeName, jobTitle, startDate, endDate, hourlyRate, partTimeInfo); // Генерация отчета MessageBox.Show($"Договор успешно сохранен: {filePath}", "Успех", MessageBoxButton.OK, MessageBoxImage.Information); } } catch (Exception ex) { MessageBox.Show($"Ошибка при создании документа: {ex.Message}"); } } private void TelephoneTextBox_TextChanged(object sender, TextChangedEventArgs e) { var textBox = sender as TextBox; if (textBox == null) return; // Удаляем все символы, кроме цифр string rawInput = new string(textBox.Text.Where(char.IsDigit).ToArray()); // Добавляем "7" по умолчанию if (!rawInput.StartsWith("7")) rawInput = "7" + rawInput; if (rawInput.Length > 11) rawInput = rawInput.Substring(0, 11); // Форматируем как +7 (XXX) XXX-XX-XX if (rawInput.Length <= 1) textBox.Text = "+7 "; else if (rawInput.Length <= 4) textBox.Text = $"+7 ({rawInput.Substring(1)}"; else if (rawInput.Length <= 7) textBox.Text = $"+7 ({rawInput.Substring(1, 3)}) {rawInput.Substring(4)}"; else if (rawInput.Length <= 9) textBox.Text = $"+7 ({rawInput.Substring(1, 3)}) {rawInput.Substring(4, 3)}-{rawInput.Substring(7)}"; else textBox.Text = $"+7 ({rawInput.Substring(1, 3)}) {rawInput.Substring(4, 3)}-{rawInput.Substring(7, 2)}-{rawInput.Substring(9)}"; // Устанавливаем курсор в конец textBox.SelectionStart = textBox.Text.Length; } private void SaveButton_Click(object sender, RoutedEventArgs e) { bool isValid = true; // Проверка обязательных полей if (string.IsNullOrWhiteSpace(JobNameTextBox.Text)) { isValid = false; MessageBox.Show("Поле 'Название должности' не заполнено."); } if (string.IsNullOrWhiteSpace(PartTimeJobTextBox.Text)) { isValid = false; MessageBox.Show("Поле 'Совместительство' не заполнено."); } if (string.IsNullOrWhiteSpace(BidTextBox.Text)) { isValid = false; MessageBox.Show("Поле 'Ставка' не заполнено."); } if (!StartDatePicker.SelectedDate.HasValue) { isValid = false; MessageBox.Show("Поле 'Начало работы' не выбрано."); } if (!EndDatePicker.SelectedDate.HasValue) { isValid = false; MessageBox.Show("Поле 'Конец работы' не выбрано."); } // Если все поля заполнены, продолжаем выполнение if (isValid) try { var model = new EmployeeViewModel { NameJob = JobNameTextBox.Text, StartJob = StartDatePicker.SelectedDate.Value.ToUniversalTime(), EndJob = EndDatePicker.SelectedDate.Value.ToUniversalTime(), Bid = float.Parse(BidTextBox.Text), PartTimeJob = PartTimeJobTextBox.Text, PhysicalPersonsId = (int?)PhysicalPersonComboBox.SelectedValue }; _employeeLogic.Insert(model); MessageBox.Show("Данные сотрудника успешно сохранены!"); } catch (Exception ex) { MessageBox.Show($"Ошибка: {ex.Message}"); } } } }