From ac02daf4a2fcade4528a1bd6a8fc3ea0a3109790 Mon Sep 17 00:00:00 2001 From: "olga.karpova" Date: Fri, 20 Sep 2024 13:11:25 +0400 Subject: [PATCH] Add horizontal alignment "fill" to cell --- .../Excel.TemplateEngine.Tests.csproj | 2 +- .../FileGeneratingTests/ExcelStyleTests.cs | 9 +- .../FileGeneratingTests/Files/template.xlsx | Bin 9951 -> 9977 bytes .../Files/complexTemplate.xlsx | Bin 9069 -> 9800 bytes .../ObjectExcelPrintingTests.cs | 2 +- .../Caches/CacheItems/AlignmentCacheItem.cs | 148 +++--- .../Implementations/ExcelDocumentStyle.cs | 443 +++++++++--------- .../DataTypes/ExcelHorizontalAlignment.cs | 16 +- 8 files changed, 301 insertions(+), 319 deletions(-) diff --git a/Excel.TemplateEngine.Tests/Excel.TemplateEngine.Tests.csproj b/Excel.TemplateEngine.Tests/Excel.TemplateEngine.Tests.csproj index 9cef4ce..7b6507e 100644 --- a/Excel.TemplateEngine.Tests/Excel.TemplateEngine.Tests.csproj +++ b/Excel.TemplateEngine.Tests/Excel.TemplateEngine.Tests.csproj @@ -11,7 +11,7 @@ - + diff --git a/Excel.TemplateEngine.Tests/FileGeneratingTests/ExcelStyleTests.cs b/Excel.TemplateEngine.Tests/FileGeneratingTests/ExcelStyleTests.cs index 56a37be..89e998e 100644 --- a/Excel.TemplateEngine.Tests/FileGeneratingTests/ExcelStyleTests.cs +++ b/Excel.TemplateEngine.Tests/FileGeneratingTests/ExcelStyleTests.cs @@ -109,15 +109,16 @@ public void CellBorderFormatExtractionTest() style.BordersStyle.BottomBorder.Color.Blue.Should().Be(255); } - [Test] - public void CellAlignmentExtractionTest() + [TestCase(ExcelHorizontalAlignment.Left, "A1")] + [TestCase(ExcelHorizontalAlignment.Fill, "B1")] + public void CellAlignmentExtractionTest(ExcelHorizontalAlignment horizontalAlignment, string cellIndex) { var templateDocument = ExcelDocumentFactory.CreateFromTemplate(File.ReadAllBytes(GetFilePath("template.xlsx")), logger); - var cell = templateDocument.GetWorksheet(0).GetCell(new ExcelCellIndex("A1")); + var cell = templateDocument.GetWorksheet(0).GetCell(new ExcelCellIndex(cellIndex)); var style = cell.GetStyle(); style.Alignment.WrapText.Should().BeTrue(); - style.Alignment.HorizontalAlignment.Should().Be(ExcelHorizontalAlignment.Left); + style.Alignment.HorizontalAlignment.Should().Be(horizontalAlignment); } [Test] diff --git a/Excel.TemplateEngine.Tests/FileGeneratingTests/Files/template.xlsx b/Excel.TemplateEngine.Tests/FileGeneratingTests/Files/template.xlsx index ef83af1fd27bb5f3a2a27697c6e2a0e76a17abd9..eb7c7741db4cc9d9f8ebdcc8354777ba03d36bba 100644 GIT binary patch delta 3496 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 delta 3528 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 CbYIT^ diff --git a/Excel.TemplateEngine.Tests/ObjectPrintingTests/Files/complexTemplate.xlsx b/Excel.TemplateEngine.Tests/ObjectPrintingTests/Files/complexTemplate.xlsx index d41266ba7507844a3fc3d1ff205cbcec37be8f9c..ae2cd02aac310e6aa2a922ee69959e61def41ac5 100644 GIT binary patch literal 9800 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 P8~$O2hcPz8&$IsnJ4V(} delta 6620 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 UDd|bDKmZUR@a5_`%73B%1!!thegFUf diff --git a/Excel.TemplateEngine.Tests/ObjectPrintingTests/ObjectExcelPrintingTests.cs b/Excel.TemplateEngine.Tests/ObjectPrintingTests/ObjectExcelPrintingTests.cs index 47df763..edea614 100644 --- a/Excel.TemplateEngine.Tests/ObjectPrintingTests/ObjectExcelPrintingTests.cs +++ b/Excel.TemplateEngine.Tests/ObjectPrintingTests/ObjectExcelPrintingTests.cs @@ -119,7 +119,7 @@ public void PrintComplexObjectTest() }, DeliveryParty = new Organization { - Address = "DeliveryPartyAddress", + Address = "DeliveryPartyAddress,DeliveryPartyAddress,DeliveryPartyAddress", Name = "DeliveryPartyName" }, Vehicle = new VehicleInfo diff --git a/Excel.TemplateEngine/FileGenerating/Caches/CacheItems/AlignmentCacheItem.cs b/Excel.TemplateEngine/FileGenerating/Caches/CacheItems/AlignmentCacheItem.cs index 02b87ea..9d8b291 100644 --- a/Excel.TemplateEngine/FileGenerating/Caches/CacheItems/AlignmentCacheItem.cs +++ b/Excel.TemplateEngine/FileGenerating/Caches/CacheItems/AlignmentCacheItem.cs @@ -5,101 +5,81 @@ using SkbKontur.Excel.TemplateEngine.FileGenerating.DataTypes; -namespace SkbKontur.Excel.TemplateEngine.FileGenerating.Caches.CacheItems +namespace SkbKontur.Excel.TemplateEngine.FileGenerating.Caches.CacheItems; + +internal class AlignmentCacheItem : IEquatable { - internal class AlignmentCacheItem : IEquatable + public AlignmentCacheItem(ExcelCellAlignment cellAlignment) { - public AlignmentCacheItem(ExcelCellAlignment cellAlignment) - { - verticalAlignment = cellAlignment.VerticalAlignment; - horizontalAlignment = cellAlignment.HorizontalAlignment; - wrapText = cellAlignment.WrapText; - } + verticalAlignment = cellAlignment.VerticalAlignment; + horizontalAlignment = cellAlignment.HorizontalAlignment; + wrapText = cellAlignment.WrapText; + } - public bool Equals(AlignmentCacheItem other) - { - if (ReferenceEquals(null, other)) return false; - if (ReferenceEquals(this, other)) return true; - return verticalAlignment == other.verticalAlignment && horizontalAlignment == other.horizontalAlignment && wrapText.Equals(other.wrapText); - } + public bool Equals(AlignmentCacheItem other) + { + if (ReferenceEquals(null, other)) return false; + if (ReferenceEquals(this, other)) return true; + return verticalAlignment == other.verticalAlignment && horizontalAlignment == other.horizontalAlignment && wrapText.Equals(other.wrapText); + } - public Alignment ToAlignment() - { - return new Alignment - { - Horizontal = GetHorizontalAlignment(), - Vertical = GetVerticalAlignment(), - WrapText = wrapText ? new BooleanValue(true) : null - }; - } + public Alignment ToAlignment() + { + return new Alignment + { + Horizontal = GetHorizontalAlignment(), + Vertical = GetVerticalAlignment(), + WrapText = wrapText ? new BooleanValue(true) : null + }; + } - public override bool Equals(object obj) - { - if (ReferenceEquals(null, obj)) return false; - if (ReferenceEquals(this, obj)) return true; - if (obj.GetType() != GetType()) return false; - return Equals((AlignmentCacheItem)obj); - } + public override bool Equals(object obj) + { + if (ReferenceEquals(null, obj)) return false; + if (ReferenceEquals(this, obj)) return true; + if (obj.GetType() != GetType()) return false; + return Equals((AlignmentCacheItem)obj); + } - public override int GetHashCode() + public override int GetHashCode() + { + unchecked { - unchecked - { - var hashCode = (int)verticalAlignment; - hashCode = (hashCode * 397) ^ (int)horizontalAlignment; - hashCode = (hashCode * 397) ^ wrapText.GetHashCode(); - return hashCode; - } + var hashCode = (int)verticalAlignment; + hashCode = (hashCode * 397) ^ (int)horizontalAlignment; + hashCode = (hashCode * 397) ^ wrapText.GetHashCode(); + return hashCode; } + } - private EnumValue GetVerticalAlignment() - { - EnumValue result; - switch (verticalAlignment) + private EnumValue GetVerticalAlignment() + { + EnumValue result = verticalAlignment switch { - case ExcelVerticalAlignment.Top: - result = new EnumValue(VerticalAlignmentValues.Top); - break; - case ExcelVerticalAlignment.Center: - result = new EnumValue(VerticalAlignmentValues.Center); - break; - case ExcelVerticalAlignment.Bottom: - result = new EnumValue(VerticalAlignmentValues.Bottom); - break; - case ExcelVerticalAlignment.Default: - result = null; - break; - default: - throw new InvalidOperationException($"Unknown vertical alignment: {verticalAlignment}"); - } - return result; - } + ExcelVerticalAlignment.Top => new EnumValue(VerticalAlignmentValues.Top), + ExcelVerticalAlignment.Center => new EnumValue(VerticalAlignmentValues.Center), + ExcelVerticalAlignment.Bottom => new EnumValue(VerticalAlignmentValues.Bottom), + ExcelVerticalAlignment.Default => null, + _ => throw new InvalidOperationException($"Unknown vertical alignment: {verticalAlignment}") + }; + return result; + } - private EnumValue GetHorizontalAlignment() - { - EnumValue result; - switch (horizontalAlignment) + private EnumValue GetHorizontalAlignment() + { + EnumValue result = horizontalAlignment switch { - case ExcelHorizontalAlignment.Left: - result = new EnumValue(HorizontalAlignmentValues.Left); - break; - case ExcelHorizontalAlignment.Center: - result = new EnumValue(HorizontalAlignmentValues.Center); - break; - case ExcelHorizontalAlignment.Right: - result = new EnumValue(HorizontalAlignmentValues.Right); - break; - case ExcelHorizontalAlignment.Default: - result = null; - break; - default: - throw new InvalidOperationException($"Unknown horizontal alignment: {horizontalAlignment}"); - } - return result; - } - - private readonly ExcelVerticalAlignment verticalAlignment; - private readonly ExcelHorizontalAlignment horizontalAlignment; - private readonly bool wrapText; + ExcelHorizontalAlignment.Left => new EnumValue(HorizontalAlignmentValues.Left), + ExcelHorizontalAlignment.Center => new EnumValue(HorizontalAlignmentValues.Center), + ExcelHorizontalAlignment.Right => new EnumValue(HorizontalAlignmentValues.Right), + ExcelHorizontalAlignment.Fill => new EnumValue(HorizontalAlignmentValues.Fill), + ExcelHorizontalAlignment.Default => null, + _ => throw new InvalidOperationException($"Unknown horizontal alignment: {horizontalAlignment}") + }; + return result; } + + private readonly ExcelVerticalAlignment verticalAlignment; + private readonly ExcelHorizontalAlignment horizontalAlignment; + private readonly bool wrapText; } \ No newline at end of file diff --git a/Excel.TemplateEngine/FileGenerating/Caches/Implementations/ExcelDocumentStyle.cs b/Excel.TemplateEngine/FileGenerating/Caches/Implementations/ExcelDocumentStyle.cs index b34c499..2f17571 100644 --- a/Excel.TemplateEngine/FileGenerating/Caches/Implementations/ExcelDocumentStyle.cs +++ b/Excel.TemplateEngine/FileGenerating/Caches/Implementations/ExcelDocumentStyle.cs @@ -17,257 +17,258 @@ using ColorType = DocumentFormat.OpenXml.Spreadsheet.ColorType; using Fill = DocumentFormat.OpenXml.Spreadsheet.Fill; -namespace SkbKontur.Excel.TemplateEngine.FileGenerating.Caches.Implementations +namespace SkbKontur.Excel.TemplateEngine.FileGenerating.Caches.Implementations; + +internal class ExcelDocumentStyle : IExcelDocumentStyle { - internal class ExcelDocumentStyle : IExcelDocumentStyle + public ExcelDocumentStyle(Stylesheet stylesheet, Theme theme, ILog logger) { - public ExcelDocumentStyle(Stylesheet stylesheet, Theme theme, ILog logger) - { - this.stylesheet = stylesheet; - this.logger = logger; - numberingFormats = new ExcelDocumentNumberingFormats(stylesheet); - fillStyles = new ExcelDocumentFillStyles(stylesheet); - bordersStyles = new ExcelDocumentBordersStyles(stylesheet); - fontStyles = new ExcelDocumentFontStyles(stylesheet); - // Not using theme.ThemeElements.ColorScheme.Elements() here because of wrong order. - colorSchemeElements = new List - { - theme.ThemeElements?.ColorScheme?.Light1Color, - theme.ThemeElements?.ColorScheme?.Dark1Color, - theme.ThemeElements?.ColorScheme?.Light2Color, - theme.ThemeElements?.ColorScheme?.Dark2Color, - theme.ThemeElements?.ColorScheme?.Accent1Color, - theme.ThemeElements?.ColorScheme?.Accent2Color, - theme.ThemeElements?.ColorScheme?.Accent3Color, - theme.ThemeElements?.ColorScheme?.Accent4Color, - theme.ThemeElements?.ColorScheme?.Accent5Color, - theme.ThemeElements?.ColorScheme?.Accent6Color, - theme.ThemeElements?.ColorScheme?.Hyperlink, - theme.ThemeElements?.ColorScheme?.FollowedHyperlinkColor, - }; - cache = new Dictionary(); - inverseCache = new Dictionary(); - } - - public uint AddStyle(ExcelCellStyle style) - { - var fillId = fillStyles.AddStyle(style.FillStyle); - var fontId = fontStyles.AddFont(style.FontStyle); - var borderId = bordersStyles.AddStyle(style.BordersStyle); - var numberFormatId = numberingFormats.AddFormat(style.NumberingFormat); - var alignment = Alignment(style.Alignment); - var cacheItem = new CellStyleCacheItem - { - FillId = fillId, - FontId = fontId, - BorderId = borderId, - NumberFormatId = numberFormatId, - Alignment = alignment - }; - if (!cache.TryGetValue(cacheItem, out var result) && stylesheet.CellFormats != null) + this.stylesheet = stylesheet; + this.logger = logger; + numberingFormats = new ExcelDocumentNumberingFormats(stylesheet); + fillStyles = new ExcelDocumentFillStyles(stylesheet); + bordersStyles = new ExcelDocumentBordersStyles(stylesheet); + fontStyles = new ExcelDocumentFontStyles(stylesheet); + // Not using theme.ThemeElements.ColorScheme.Elements() here because of wrong order. + colorSchemeElements = new List { - result = stylesheet.CellFormats.Count; - stylesheet.CellFormats.Count++; - stylesheet.CellFormats.AppendChild(cacheItem.ToCellFormat()); - cache.Add(cacheItem, result); - } - return result; - } + theme.ThemeElements?.ColorScheme?.Light1Color, + theme.ThemeElements?.ColorScheme?.Dark1Color, + theme.ThemeElements?.ColorScheme?.Light2Color, + theme.ThemeElements?.ColorScheme?.Dark2Color, + theme.ThemeElements?.ColorScheme?.Accent1Color, + theme.ThemeElements?.ColorScheme?.Accent2Color, + theme.ThemeElements?.ColorScheme?.Accent3Color, + theme.ThemeElements?.ColorScheme?.Accent4Color, + theme.ThemeElements?.ColorScheme?.Accent5Color, + theme.ThemeElements?.ColorScheme?.Accent6Color, + theme.ThemeElements?.ColorScheme?.Hyperlink, + theme.ThemeElements?.ColorScheme?.FollowedHyperlinkColor, + }; + cache = new Dictionary(); + inverseCache = new Dictionary(); + } - public ExcelCellStyle GetStyle(int styleIndex) + public uint AddStyle(ExcelCellStyle style) + { + var fillId = fillStyles.AddStyle(style.FillStyle); + var fontId = fontStyles.AddFont(style.FontStyle); + var borderId = bordersStyles.AddStyle(style.BordersStyle); + var numberFormatId = numberingFormats.AddFormat(style.NumberingFormat); + var alignment = Alignment(style.Alignment); + var cacheItem = new CellStyleCacheItem + { + FillId = fillId, + FontId = fontId, + BorderId = borderId, + NumberFormatId = numberFormatId, + Alignment = alignment + }; + if (!cache.TryGetValue(cacheItem, out var result) && stylesheet.CellFormats != null) { - if (inverseCache.TryGetValue((uint)styleIndex, out var result)) - return result; - - var cellFormat = stylesheet?.CellFormats?.ChildElements.Count > styleIndex ? (CellFormat)stylesheet.CellFormats.ChildElements[styleIndex] : null; - result = new ExcelCellStyle - { - FillStyle = cellFormat?.FillId == null ? null : GetCellFillStyle(cellFormat.FillId.Value), - FontStyle = cellFormat?.FontId == null ? null : GetCellFontStyle(cellFormat.FontId.Value), - NumberingFormat = cellFormat?.NumberFormatId == null ? null : GetCellNumberingFormat(cellFormat.NumberFormatId.Value), - BordersStyle = cellFormat?.BorderId == null ? null : GetCellBordersStyle(cellFormat.BorderId.Value), - Alignment = cellFormat?.Alignment == null ? null : GetCellAlignment(cellFormat.Alignment) - }; - inverseCache.Add((uint)styleIndex, result); + result = stylesheet.CellFormats.Count; + stylesheet.CellFormats.Count++; + stylesheet.CellFormats.AppendChild(cacheItem.ToCellFormat()); + cache.Add(cacheItem, result); + } + return result; + } + public ExcelCellStyle GetStyle(int styleIndex) + { + if (inverseCache.TryGetValue((uint)styleIndex, out var result)) return result; - } - private ExcelCellAlignment GetCellAlignment(Alignment alignment) - { - return new ExcelCellAlignment - { - WrapText = true, //alignment.With(a => a.WrapText) != null && alignment.WrapText.Value, всегда делать перенос по словам - HorizontalAlignment = alignment?.Horizontal == null ? ExcelHorizontalAlignment.Default : ToExcelHorizontalAlignment(alignment.Horizontal), - VerticalAlignment = alignment?.Vertical == null ? ExcelVerticalAlignment.Default : ToExcelVerticalAlignment(alignment.Vertical) - }; - } + var cellFormat = stylesheet?.CellFormats?.ChildElements.Count > styleIndex ? (CellFormat)stylesheet.CellFormats.ChildElements[styleIndex] : null; + result = new ExcelCellStyle + { + FillStyle = cellFormat?.FillId == null ? null : GetCellFillStyle(cellFormat.FillId.Value), + FontStyle = cellFormat?.FontId == null ? null : GetCellFontStyle(cellFormat.FontId.Value), + NumberingFormat = cellFormat?.NumberFormatId == null ? null : GetCellNumberingFormat(cellFormat.NumberFormatId.Value), + BordersStyle = cellFormat?.BorderId == null ? null : GetCellBordersStyle(cellFormat.BorderId.Value), + Alignment = cellFormat?.Alignment == null ? null : GetCellAlignment(cellFormat.Alignment) + }; + inverseCache.Add((uint)styleIndex, result); - private ExcelVerticalAlignment ToExcelVerticalAlignment(EnumValue vertical) - { - if (vertical.Value == VerticalAlignmentValues.Bottom) - return ExcelVerticalAlignment.Bottom; - if (vertical.Value == VerticalAlignmentValues.Center) - return ExcelVerticalAlignment.Center; - if (vertical.Value == VerticalAlignmentValues.Top) - return ExcelVerticalAlignment.Top; - return ExcelVerticalAlignment.Default; - } + return result; + } - private ExcelHorizontalAlignment ToExcelHorizontalAlignment(EnumValue horizontal) - { - if (horizontal.Value == HorizontalAlignmentValues.Center) - return ExcelHorizontalAlignment.Center; - if (horizontal.Value == HorizontalAlignmentValues.Left) - return ExcelHorizontalAlignment.Left; - if (horizontal.Value == HorizontalAlignmentValues.Right) - return ExcelHorizontalAlignment.Right; - return ExcelHorizontalAlignment.Default; - } + private ExcelCellAlignment GetCellAlignment(Alignment alignment) + { + return new ExcelCellAlignment + { + WrapText = true, //alignment.With(a => a.WrapText) != null && alignment.WrapText.Value, всегда делать перенос по словам + HorizontalAlignment = alignment?.Horizontal == null ? ExcelHorizontalAlignment.Default : ToExcelHorizontalAlignment(alignment.Horizontal), + VerticalAlignment = alignment?.Vertical == null ? ExcelVerticalAlignment.Default : ToExcelVerticalAlignment(alignment.Vertical) + }; + } - private ExcelCellBordersStyle GetCellBordersStyle(uint borderId) - { - var bordersStyle = stylesheet?.Borders?.ChildElements.Count > borderId ? (Border)stylesheet.Borders.ChildElements[(int)borderId] : null; - return new ExcelCellBordersStyle - { - LeftBorder = bordersStyle?.LeftBorder == null ? null : GetBorderStyle(bordersStyle.LeftBorder), - RightBorder = bordersStyle?.RightBorder == null ? null : GetBorderStyle(bordersStyle.RightBorder), - TopBorder = bordersStyle?.TopBorder == null ? null : GetBorderStyle(bordersStyle.TopBorder), - BottomBorder = bordersStyle?.BottomBorder == null ? null : GetBorderStyle(bordersStyle.BottomBorder) - }; - } + private ExcelVerticalAlignment ToExcelVerticalAlignment(EnumValue vertical) + { + if (vertical.Value == VerticalAlignmentValues.Bottom) + return ExcelVerticalAlignment.Bottom; + if (vertical.Value == VerticalAlignmentValues.Center) + return ExcelVerticalAlignment.Center; + if (vertical.Value == VerticalAlignmentValues.Top) + return ExcelVerticalAlignment.Top; + return ExcelVerticalAlignment.Default; + } - private ExcelCellBorderStyle GetBorderStyle(BorderPropertiesType border) - { - return new ExcelCellBorderStyle - { - Color = ToExcelColor(border?.Color), - BorderType = border?.Style == null ? ExcelBorderType.None : ToExcelBorderType(border.Style) - }; - } + private ExcelHorizontalAlignment ToExcelHorizontalAlignment(EnumValue horizontal) + { + if (horizontal.Value == HorizontalAlignmentValues.Center) + return ExcelHorizontalAlignment.Center; + if (horizontal.Value == HorizontalAlignmentValues.Left) + return ExcelHorizontalAlignment.Left; + if (horizontal.Value == HorizontalAlignmentValues.Right) + return ExcelHorizontalAlignment.Right; + if (horizontal.Value == HorizontalAlignmentValues.Fill) + return ExcelHorizontalAlignment.Fill; + return ExcelHorizontalAlignment.Default; + } - private static ExcelBorderType ToExcelBorderType(EnumValue borderStyle) - { - if (borderStyle.Value == BorderStyleValues.None) - return ExcelBorderType.None; - if (borderStyle.Value == BorderStyleValues.Thin) - return ExcelBorderType.Thin; - if (borderStyle.Value == BorderStyleValues.Medium) - return ExcelBorderType.Single; - if (borderStyle.Value == BorderStyleValues.Thick) - return ExcelBorderType.Bold; - if (borderStyle.Value == BorderStyleValues.Double) - return ExcelBorderType.Double; - throw new InvalidOperationException($"Unknown border type: {borderStyle}"); - } + private ExcelCellBordersStyle GetCellBordersStyle(uint borderId) + { + var bordersStyle = stylesheet?.Borders?.ChildElements.Count > borderId ? (Border)stylesheet.Borders.ChildElements[(int)borderId] : null; + return new ExcelCellBordersStyle + { + LeftBorder = bordersStyle?.LeftBorder == null ? null : GetBorderStyle(bordersStyle.LeftBorder), + RightBorder = bordersStyle?.RightBorder == null ? null : GetBorderStyle(bordersStyle.RightBorder), + TopBorder = bordersStyle?.TopBorder == null ? null : GetBorderStyle(bordersStyle.TopBorder), + BottomBorder = bordersStyle?.BottomBorder == null ? null : GetBorderStyle(bordersStyle.BottomBorder) + }; + } - private ExcelCellNumberingFormat GetCellNumberingFormat(uint numberFormatId) - { - if (standardNumberingFormatsId.Contains(numberFormatId)) - return new ExcelCellNumberingFormat(numberFormatId); + private ExcelCellBorderStyle GetBorderStyle(BorderPropertiesType border) + { + return new ExcelCellBorderStyle + { + Color = ToExcelColor(border?.Color), + BorderType = border?.Style == null ? ExcelBorderType.None : ToExcelBorderType(border.Style) + }; + } - var numberFormat = (NumberingFormat)stylesheet?.NumberingFormats?.ChildElements - .FirstOrDefault(ce => ((NumberingFormat)ce)?.NumberFormatId != null && - ((NumberingFormat)ce).NumberFormatId!.Value == numberFormatId); - if (numberFormat?.FormatCode?.Value == null) - return null; + private static ExcelBorderType ToExcelBorderType(EnumValue borderStyle) + { + if (borderStyle.Value == BorderStyleValues.None) + return ExcelBorderType.None; + if (borderStyle.Value == BorderStyleValues.Thin) + return ExcelBorderType.Thin; + if (borderStyle.Value == BorderStyleValues.Medium) + return ExcelBorderType.Single; + if (borderStyle.Value == BorderStyleValues.Thick) + return ExcelBorderType.Bold; + if (borderStyle.Value == BorderStyleValues.Double) + return ExcelBorderType.Double; + throw new InvalidOperationException($"Unknown border type: {borderStyle}"); + } - return new ExcelCellNumberingFormat(numberFormat.NumberFormatId!.Value, numberFormat.FormatCode.Value); - } + private ExcelCellNumberingFormat GetCellNumberingFormat(uint numberFormatId) + { + if (standardNumberingFormatsId.Contains(numberFormatId)) + return new ExcelCellNumberingFormat(numberFormatId); - private ExcelCellFontStyle GetCellFontStyle(uint fontId) - { - var internalFont = stylesheet?.Fonts?.ChildElements.Count > fontId ? (Font)stylesheet.Fonts.ChildElements[(int)fontId] : null; - return new ExcelCellFontStyle - { - Bold = internalFont?.Bold != null, - Size = internalFont?.FontSize == null ? (int?)null : Convert.ToInt32((object)internalFont.FontSize?.Val?.Value), - Underlined = internalFont?.Underline != null, - Color = ToExcelColor(internalFont?.Color) - }; - } + var numberFormat = (NumberingFormat)stylesheet?.NumberingFormats?.ChildElements + .FirstOrDefault(ce => ((NumberingFormat)ce)?.NumberFormatId != null && + ((NumberingFormat)ce).NumberFormatId!.Value == numberFormatId); + if (numberFormat?.FormatCode?.Value == null) + return null; - private ExcelCellFillStyle GetCellFillStyle(uint fillId) - { - var fill = stylesheet?.Fills?.ChildElements.Count > fillId ? (Fill)stylesheet.Fills.ChildElements[(int)fillId] : null; - var color = ToExcelColor(fill?.PatternFill?.ForegroundColor); + return new ExcelCellNumberingFormat(numberFormat.NumberFormatId!.Value, numberFormat.FormatCode.Value); + } - if (color == null) - return null; + private ExcelCellFontStyle GetCellFontStyle(uint fontId) + { + var internalFont = stylesheet?.Fonts?.ChildElements.Count > fontId ? (Font)stylesheet.Fonts.ChildElements[(int)fontId] : null; + return new ExcelCellFontStyle + { + Bold = internalFont?.Bold != null, + Size = internalFont?.FontSize == null ? (int?)null : Convert.ToInt32((object)internalFont.FontSize?.Val?.Value), + Underlined = internalFont?.Underline != null, + Color = ToExcelColor(internalFont?.Color) + }; + } - return new ExcelCellFillStyle {Color = color}; - } + private ExcelCellFillStyle GetCellFillStyle(uint fillId) + { + var fill = stylesheet?.Fills?.ChildElements.Count > fillId ? (Fill)stylesheet.Fills.ChildElements[(int)fillId] : null; + var color = ToExcelColor(fill?.PatternFill?.ForegroundColor); - [CanBeNull] - private ExcelColor ToExcelColor([CanBeNull] ColorType color) - { - if (color == null) - return null; - if (color.Rgb?.HasValue == true) - { - return RgbStringToExcelColor(color.Rgb.Value!); - } - if (color.Theme?.HasValue == true) - { - var theme = color.Theme.Value; - var tint = color.Tint?.Value ?? 0; - return ThemeToExcelColor(theme, tint); - } + if (color == null) return null; - } - [CanBeNull] - private static ExcelColor RgbStringToExcelColor([NotNull] string hexRgbColor) + return new ExcelCellFillStyle {Color = color}; + } + + [CanBeNull] + private ExcelColor ToExcelColor([CanBeNull] ColorType color) + { + if (color == null) + return null; + if (color.Rgb?.HasValue == true) { - if (hexRgbColor.Length == 6) - hexRgbColor = "FF" + hexRgbColor; - return new ExcelColor(alpha : Convert.ToInt32(hexRgbColor.Substring(0, 2), 16), - red : Convert.ToInt32(hexRgbColor.Substring(2, 2), 16), - green : Convert.ToInt32(hexRgbColor.Substring(4, 2), 16), - blue : Convert.ToInt32(hexRgbColor.Substring(6, 2), 16)); + return RgbStringToExcelColor(color.Rgb.Value!); } - - [CanBeNull] - private ExcelColor ThemeToExcelColor(uint theme, double tint) + if (color.Theme?.HasValue == true) { - if (theme >= colorSchemeElements.Count) - throw new InvalidOperationException($"Theme with id '{theme}' not found"); - var color2Type = colorSchemeElements[(int)theme]; - var rgbColor = color2Type?.RgbColorModelHex?.Val?.Value ?? color2Type?.SystemColor?.LastColor?.Value; - if (rgbColor == null) - { - logger.Error("Failed to get rgbColor from theme"); - return null; - } - var hls = ColorConverter.RgbToHls(RgbStringToExcelColor(rgbColor)); - if (tint < 0) - hls.L = hls.L * (1.0 + tint); - else - hls.L = hls.L * (1.0 - tint) + tint; - return ColorConverter.HslToRgb(hls); + var theme = color.Theme.Value; + var tint = color.Tint?.Value ?? 0; + return ThemeToExcelColor(theme, tint); } + return null; + } + + [CanBeNull] + private static ExcelColor RgbStringToExcelColor([NotNull] string hexRgbColor) + { + if (hexRgbColor.Length == 6) + hexRgbColor = "FF" + hexRgbColor; + return new ExcelColor(alpha : Convert.ToInt32(hexRgbColor.Substring(0, 2), 16), + red : Convert.ToInt32(hexRgbColor.Substring(2, 2), 16), + green : Convert.ToInt32(hexRgbColor.Substring(4, 2), 16), + blue : Convert.ToInt32(hexRgbColor.Substring(6, 2), 16)); + } - private static AlignmentCacheItem Alignment(ExcelCellAlignment cellAlignment) + [CanBeNull] + private ExcelColor ThemeToExcelColor(uint theme, double tint) + { + if (theme >= colorSchemeElements.Count) + throw new InvalidOperationException($"Theme with id '{theme}' not found"); + var color2Type = colorSchemeElements[(int)theme]; + var rgbColor = color2Type?.RgbColorModelHex?.Val?.Value ?? color2Type?.SystemColor?.LastColor?.Value; + if (rgbColor == null) { - if (cellAlignment == null) - return null; - if (cellAlignment.HorizontalAlignment == ExcelHorizontalAlignment.Default && cellAlignment.VerticalAlignment == ExcelVerticalAlignment.Default && !cellAlignment.WrapText) - return null; - return new AlignmentCacheItem(cellAlignment); + logger.Error("Failed to get rgbColor from theme"); + return null; } + var hls = ColorConverter.RgbToHls(RgbStringToExcelColor(rgbColor)); + if (tint < 0) + hls.L = hls.L * (1.0 + tint); + else + hls.L = hls.L * (1.0 - tint) + tint; + return ColorConverter.HslToRgb(hls); + } - // standardNumberingFormatsId -- set of numbering formats that can be identified without format codes - // https://docs.microsoft.com/en-us/dotnet/api/documentformat.openxml.spreadsheet.numberingformat?view=openxml-2.8.1 - private static HashSet standardNumberingFormatsId = new HashSet {0, 1, 2, 3, 4, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 37, 38, 39, 40, 45, 46, 47, 48, 49}; - - private readonly Stylesheet stylesheet; - private readonly ILog logger; - private readonly ExcelDocumentNumberingFormats numberingFormats; - private readonly ExcelDocumentFillStyles fillStyles; - private readonly ExcelDocumentBordersStyles bordersStyles; - private readonly IExcelDocumentFontStyles fontStyles; - private readonly List colorSchemeElements; - private readonly IDictionary cache; - private readonly IDictionary inverseCache; + private static AlignmentCacheItem Alignment(ExcelCellAlignment cellAlignment) + { + if (cellAlignment == null) + return null; + if (cellAlignment.HorizontalAlignment == ExcelHorizontalAlignment.Default && cellAlignment.VerticalAlignment == ExcelVerticalAlignment.Default && !cellAlignment.WrapText) + return null; + return new AlignmentCacheItem(cellAlignment); } + + // standardNumberingFormatsId -- set of numbering formats that can be identified without format codes + // https://docs.microsoft.com/en-us/dotnet/api/documentformat.openxml.spreadsheet.numberingformat?view=openxml-2.8.1 + private static HashSet standardNumberingFormatsId = new HashSet {0, 1, 2, 3, 4, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 37, 38, 39, 40, 45, 46, 47, 48, 49}; + + private readonly Stylesheet stylesheet; + private readonly ILog logger; + private readonly ExcelDocumentNumberingFormats numberingFormats; + private readonly ExcelDocumentFillStyles fillStyles; + private readonly ExcelDocumentBordersStyles bordersStyles; + private readonly IExcelDocumentFontStyles fontStyles; + private readonly List colorSchemeElements; + private readonly IDictionary cache; + private readonly IDictionary inverseCache; } \ No newline at end of file diff --git a/Excel.TemplateEngine/FileGenerating/DataTypes/ExcelHorizontalAlignment.cs b/Excel.TemplateEngine/FileGenerating/DataTypes/ExcelHorizontalAlignment.cs index abb230b..8da453d 100644 --- a/Excel.TemplateEngine/FileGenerating/DataTypes/ExcelHorizontalAlignment.cs +++ b/Excel.TemplateEngine/FileGenerating/DataTypes/ExcelHorizontalAlignment.cs @@ -1,10 +1,10 @@ -namespace SkbKontur.Excel.TemplateEngine.FileGenerating.DataTypes +namespace SkbKontur.Excel.TemplateEngine.FileGenerating.DataTypes; + +public enum ExcelHorizontalAlignment { - public enum ExcelHorizontalAlignment - { - Default, - Left, - Center, - Right - } + Default, + Left, + Center, + Right, + Fill, } \ No newline at end of file