コード例 #1
0
ファイル: AnalysisUI.cs プロジェクト: tsybulsky/training
        private void ShowBalance()
        {
            int[]    columnWidths = { 12, 11, 11, 11, 11 };
            DateTime startDate    = CustomActionUI.InputDate("Введите начало периода: ", true) ?? ledger.MinWorkingDate.AddDays(1);
            DateTime endDate      = CustomActionUI.InputDate("Введите конец периода: ", true) ?? DateTime.Today;
            Balance  balance      = ledger.GetBalance(startDate, endDate);

            Console.Clear();
            Console.WriteLine($"Обороты за период с {startDate.ToString("dd.MM.yyyy")} по {endDate.ToString("dd.MM.yyyy")}");
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.HEADER_BORDER_SYMBOLS);
            Console.WriteLine("\u2502    Дата    \u2502 Начальный \u2502  Приход   \u2502  Расход   \u2502 Конечный  \u2502");
            Console.WriteLine("\u2502            \u2502  остаток  \u2502           \u2502           \u2502  остаток  \u2502");
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.MIDDLE_BORDER_SYMBOLS);
            decimal totalIncome = 0, totalExpense = 0;

            foreach (var item in balance)
            {
                Console.WriteLine($"\u2502 {item.Date.ToString("dd.MM.yyyy")} \u2502 " +
                                  $"{item.InitialBalance,9:F2} \u2502 " +
                                  $"{((item.Credit == 0) ? "" : item.Credit.ToString("F2")),9} \u2502 " +
                                  $"{((item.Debet == 0) ? "" : item.Debet.ToString("F2")),9} \u2502 " +
                                  $"{item.FinalBalance,9:F2} \u2502");
                totalIncome  += item.Credit;
                totalExpense += item.Debet;
            }
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.MIDDLE_BORDER_SYMBOLS);
            Console.WriteLine($"\u2502 Всего:     \u2502           \u2502 {totalIncome,9:F2} \u2502           \u2502 {totalExpense,9:F2} \u2502");
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.FOOTER_BORDER_SYMBOLS);
            Console.ReadKey();
        }
コード例 #2
0
ファイル: ExpensesUI.cs プロジェクト: tsybulsky/training
        private void ShowTable(DateTime startDate, DateTime endDate, bool showTotals)
        {
            int[] columnWidths = { 6, 12, 11, 45 };
            void ShowTitle()
            {
                Console.Clear();
                Console.WriteLine($"Расходы за период с {startDate.ToString("dd.MM.yyyy")} по {endDate.ToString("dd.MM.yyyy")}");
                CustomActionUI.DrawBorders(columnWidths, CustomActionUI.HEADER_BORDER_SYMBOLS);
                Console.WriteLine($"\u2502 №п/п \u2502    Дата    \u2502   Сумма   \u2502 {"Статья",-43} \u2502");
                CustomActionUI.DrawBorders(columnWidths, CustomActionUI.MIDDLE_BORDER_SYMBOLS);
            }

            Operations selectedItems = ledger.Expenses.GetOperationsByRange(startDate, endDate);

            ShowTitle();
            int index = 1;

            foreach (Operation item in selectedItems)
            {
                if (!(item is ExpenseOperation))
                {
                    continue;
                }
                ExpenseOperation expense         = item as ExpenseOperation;
                string           articleAndNotes = item.Article;
                if (!String.IsNullOrWhiteSpace(item.Notes))
                {
                    articleAndNotes += $" ({item.Notes})";
                    if (articleAndNotes.Length > 43)
                    {
                        articleAndNotes = articleAndNotes.Substring(0, 40) + "...";
                    }
                }
                Console.WriteLine($"\u2502 {index++,4} \u2502 {expense.Date.ToString("dd.MM.yyy")} \u2502 {expense.Value,9:F2} \u2502 {articleAndNotes,-43} \u2502");
            }
            if (showTotals)
            {
                CustomActionUI.DrawBorders(columnWidths, CustomActionUI.MIDDLE_BORDER_SYMBOLS);
                decimal sum = 0;
                selectedItems.ForEach(x => sum += x.Value);
                Console.WriteLine($"\u2502 {" ",4} \u2502 Всего:     \u2502 {sum,9:F2} \u2502 {" ",43} \u2502");
            }
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.FOOTER_BORDER_SYMBOLS);
        }
コード例 #3
0
ファイル: AnalysisUI.cs プロジェクト: tsybulsky/training
        private void OutputIncomesByArticle()
        {
            int[]      columnWidths  = { 11, 59 };
            DateTime   startDate     = CustomActionUI.InputDate("Введите начало периода: ", true) ?? ledger.MinWorkingDate;
            DateTime?  endDate       = CustomActionUI.InputDate("Введите конец периода: ", true);
            Operations selectedItems = ledger.Incomes.GetOperationsByArticle(startDate, endDate);

            Console.Clear();
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.HEADER_BORDER_SYMBOLS);
            Console.WriteLine($"\u2502   Сумма   \u2502 {"Статья дохода",-57} \u2502");
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.MIDDLE_BORDER_SYMBOLS);
            foreach (Operation item in selectedItems)
            {
                string article = (item.Article.Length > 57) ? item.Article.Substring(0, 54) + "..." : item.Article;
                Console.WriteLine($"\u2502 {item.Value,9:F2} \u2502 {article,-57} \u2502");
            }
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.FOOTER_BORDER_SYMBOLS);
            Console.ReadKey();
        }
コード例 #4
0
ファイル: AnalysisUI.cs プロジェクト: tsybulsky/training
        private void ShowTaxFreeIncomes()
        {
            int[]      columnWidths  = { 6, 12, 11, 10, 34 };
            DateTime   startDate     = CustomActionUI.InputDate("Введите начало периода: ", true) ?? ledger.MinWorkingDate.AddDays(1);
            DateTime   endDate       = CustomActionUI.InputDate("Введите конец периода: ", true) ?? DateTime.Today;
            Operations selectedItems = ledger.GetTaxFree(startDate, endDate);

            Console.Clear();
            Console.WriteLine($"Необлагаемые доходы за период с {startDate.ToString("dd.MM.yyyy")} по {endDate.ToString("dd.MM.yyyy")}");
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.HEADER_BORDER_SYMBOLS);
            Console.WriteLine($"\u2502 №п/п \u2502    Дата    \u2502   Сумма   \u2502   Налог  \u2502 {"Статья",-32} \u2502");
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.MIDDLE_BORDER_SYMBOLS);
            int index = 1;

            foreach (Operation item in selectedItems)
            {
                if (!(item is IncomeOperation))
                {
                    continue;
                }
                IncomeOperation income          = item as IncomeOperation;
                string          articleAndNotes = item.Article;
                if (!String.IsNullOrWhiteSpace(item.Notes))
                {
                    articleAndNotes += $" ({item.Notes})";
                    if (articleAndNotes.Length > 32)
                    {
                        articleAndNotes = articleAndNotes.Substring(0, 29) + "...";
                    }
                }
                Console.WriteLine($"\u2502 {index++,4} \u2502 {income.Date.ToString("dd.MM.yyy")} \u2502 {income.Value,9:F2} \u2502 {income.GetTaxValue(),8:F2} \u2502 {articleAndNotes,-32} \u2502");
            }
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.MIDDLE_BORDER_SYMBOLS);
            decimal sum = 0, taxSum = 0;

            selectedItems.ForEach(x => { sum += x.Value; taxSum += ((IncomeOperation)x).TaxValue; });
            Console.WriteLine($"\u2502 {" ",4} \u2502 Всего:     \u2502 {sum,9:F2} \u2502 {taxSum,8:F2} \u2502 {" ",32} \u2502");
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.FOOTER_BORDER_SYMBOLS);
            Console.WriteLine("Нажмите любую клавишу для продолжения");
            Console.ReadKey();
        }
コード例 #5
0
ファイル: IncomesUI.cs プロジェクト: tsybulsky/training
        private void ShowTable(DateTime startDate, DateTime endDate, bool ShowTotals)
        {
            int[]      columnWidths  = { 6, 12, 11, 10, 34 };
            Operations selectedItems = ledger.Incomes.GetOperationsByRange(startDate, endDate);

            Console.Clear();
            Console.WriteLine($"Доходы за период с {startDate.ToString("dd.MM.yyyy")} по {endDate.ToString("dd.MM.yyyy")}");
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.HEADER_BORDER_SYMBOLS);
            Console.WriteLine($"\u2502 №п/п \u2502    Дата    \u2502   Сумма   \u2502   Налог  \u2502 {"Статья",-32} \u2502");
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.MIDDLE_BORDER_SYMBOLS);
            int index = 1;

            foreach (Operation item in selectedItems)
            {
                if (!(item is IncomeOperation))
                {
                    continue;
                }
                IncomeOperation income          = item as IncomeOperation;
                string          articleAndNotes = item.Article;
                if (!String.IsNullOrWhiteSpace(item.Notes))
                {
                    articleAndNotes += $" ({item.Notes})";
                    if (articleAndNotes.Length > 32)
                    {
                        articleAndNotes = articleAndNotes.Substring(0, 29) + "...";
                    }
                }
                Console.WriteLine($"\u2502 {index++,4} \u2502 {income.Date.ToString("dd.MM.yyy")} \u2502 {income.Value,9:F2} \u2502 {income.GetTaxValue(),8:F2} \u2502 {articleAndNotes,-32} \u2502");
            }
            if (ShowTotals)
            {
                CustomActionUI.DrawBorders(columnWidths, CustomActionUI.MIDDLE_BORDER_SYMBOLS);
                decimal sum = 0, taxSum = 0;
                selectedItems.ForEach(x => { sum += x.Value; taxSum += ((IncomeOperation)x).TaxValue; });
                Console.WriteLine($"\u2502 {" ",4} \u2502 Всего:     \u2502 {sum,9:F2} \u2502 {taxSum,8:F2} \u2502 {" ",32} \u2502");
            }
            CustomActionUI.DrawBorders(columnWidths, CustomActionUI.FOOTER_BORDER_SYMBOLS);
        }