| /******************************************************************************* |
| * You may amend and distribute as you like, but don't remove this header! |
| * |
| * EPPlus provides server-side generation of Excel 2007/2010 spreadsheets. |
| * See http://www.codeplex.com/EPPlus for details. |
| * |
| * Copyright (C) 2011 Jan Källman |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Lesser General Public |
| * License as published by the Free Software Foundation; either |
| * version 2.1 of the License, or (at your option) any later version. |
| |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
| * See the GNU Lesser General Public License for more details. |
| * |
| * The GNU Lesser General Public License can be viewed at http://www.opensource.org/licenses/lgpl-license.php |
| * If you unfamiliar with this license or have questions about it, here is an http://www.gnu.org/licenses/gpl-faq.html |
| * |
| * All code and executables are provided "as is" with no warranty either express or implied. |
| * The author accepts no liability for any damage or loss of business that this product may cause. |
| * |
| * Code change notes: |
| * |
| * Author Change Date |
| * ****************************************************************************** |
| * Jan Källman Initial Release 2009-10-01 |
| * Jan Källman License changed GPL-->LGPL 2011-12-16 |
| *******************************************************************************/ |
| |
| using System.Collections; |
| using System.Collections.Generic; |
| using System.Linq; |
| using System.Text; |
| using System.Xml; |
| |
| namespace OfficeOpenXml.Style; |
| |
| /// <summary> |
| /// Collection of Richtext objects |
| /// </summary> |
| public class ExcelRichTextCollection : XmlHelper, IEnumerable<ExcelRichText> { |
| private readonly List<ExcelRichText> _list = new(); |
| private readonly ExcelRangeBase _cells; |
| |
| internal ExcelRichTextCollection(XmlNamespaceManager ns, XmlNode topNode) |
| : base(ns, topNode) { |
| var nl = topNode.SelectNodes("d:r|d:t", NameSpaceManager); // Bug 15151 |
| if (nl != null) { |
| foreach (XmlNode n in nl) { |
| _list.Add(new(ns, n, this)); |
| } |
| } |
| } |
| |
| internal ExcelRichTextCollection(XmlNamespaceManager ns, XmlNode topNode, ExcelRangeBase cells) |
| : this(ns, topNode) { |
| _cells = cells; |
| } |
| |
| /// <summary> |
| /// Collection containing the richtext objects |
| /// </summary> |
| /// <param name="index"></param> |
| /// <returns></returns> |
| public ExcelRichText this[int index] { |
| get { |
| var item = _list[index]; |
| if (_cells != null) { |
| item.SetCallback(UpdateCells); |
| } |
| return item; |
| } |
| } |
| |
| /// <summary> |
| /// Items in the list |
| /// </summary> |
| public int Count => _list.Count; |
| |
| /// <summary> |
| /// Add a rich text string |
| /// </summary> |
| /// <param name="text">The text to add</param> |
| /// <returns></returns> |
| public ExcelRichText Add(string text) { |
| ConvertRichtext(); |
| XmlDocument doc; |
| if (TopNode is XmlDocument document) { |
| doc = document; |
| } else { |
| doc = TopNode.OwnerDocument; |
| } |
| var node = doc.CreateElement("d", "r", ExcelPackage._schemaMain); |
| TopNode.AppendChild(node); |
| var rt = new ExcelRichText(NameSpaceManager, node, this); |
| if (_list.Count > 0) { |
| ExcelRichText prevItem = _list[_list.Count - 1]; |
| rt.FontName = prevItem.FontName; |
| rt.Size = prevItem.Size; |
| rt.Color = prevItem.Color == "" ? "FF00000" : prevItem.Color; |
| rt.PreserveSpace = rt.PreserveSpace; |
| rt.Bold = prevItem.Bold; |
| rt.Italic = prevItem.Italic; |
| rt.UnderLine = prevItem.UnderLine; |
| } else if (_cells == null) { |
| rt.FontName = "Calibri"; |
| rt.Size = 11; |
| } else { |
| var style = _cells.Offset(0, 0).Style; |
| rt.FontName = style.Font.Name; |
| rt.Size = style.Font.Size; |
| rt.Bold = style.Font.Bold; |
| rt.Italic = style.Font.Italic; |
| _cells.IsRichText = true; |
| } |
| rt.Text = text; |
| rt.PreserveSpace = true; |
| if (_cells != null) { |
| rt.SetCallback(UpdateCells); |
| UpdateCells(); |
| } |
| _list.Add(rt); |
| return rt; |
| } |
| |
| internal void ConvertRichtext() { |
| if (_cells == null) { |
| return; |
| } |
| var isRt = _cells.Worksheet._flags.GetFlagValue( |
| _cells._fromRow, |
| _cells._fromCol, |
| CellFlags.RichText); |
| if (Count == 1 && isRt == false) { |
| _cells.Worksheet._flags.SetFlagValue( |
| _cells._fromRow, |
| _cells._fromCol, |
| true, |
| CellFlags.RichText); |
| var s = _cells.Worksheet._styles.GetValue(_cells._fromRow, _cells._fromCol); |
| //var fnt = cell.Style.Font; |
| var fnt = _cells.Worksheet.Workbook.Styles |
| .GetStyleObject( |
| s, |
| _cells.Worksheet.PositionID, |
| ExcelCellBase.GetAddress(_cells._fromRow, _cells._fromCol)) |
| .Font; |
| this[0].PreserveSpace = true; |
| this[0].Bold = fnt.Bold; |
| this[0].FontName = fnt.Name; |
| this[0].Italic = fnt.Italic; |
| this[0].Size = fnt.Size; |
| this[0].UnderLine = fnt.UnderLine; |
| } |
| } |
| |
| internal void UpdateCells() { |
| _cells.SetValueRichText(TopNode.InnerXml); |
| } |
| |
| /// <summary> |
| /// Removes an item at the specific index |
| /// </summary> |
| /// <param name="index"></param> |
| public void RemoveAt(int index) { |
| TopNode.RemoveChild(_list[index].TopNode); |
| _list.RemoveAt(index); |
| if (_cells != null && _list.Count == 0) { |
| _cells.IsRichText = false; |
| } |
| } |
| |
| /// <summary> |
| /// Removes an item |
| /// </summary> |
| /// <param name="item"></param> |
| public void Remove(ExcelRichText item) { |
| TopNode.RemoveChild(item.TopNode); |
| _list.Remove(item); |
| if (_cells != null && _list.Count == 0) { |
| _cells.IsRichText = false; |
| } |
| } |
| |
| //public void Insert(int index, string Text) |
| //{ |
| // _list.Insert(index, item); |
| //} |
| |
| /// <summary> |
| /// The text |
| /// </summary> |
| public string Text { |
| get { |
| StringBuilder sb = new StringBuilder(); |
| foreach (var item in _list) { |
| sb.Append(item.Text); |
| } |
| return sb.ToString(); |
| } |
| set { |
| if (Count == 0) { |
| Add(value); |
| } else { |
| this[0].Text = value; |
| for (int ix = 1; ix < Count; ix++) { |
| RemoveAt(ix); |
| } |
| } |
| } |
| } |
| |
| IEnumerator<ExcelRichText> IEnumerable<ExcelRichText>.GetEnumerator() { |
| return _list |
| .Select(x => { |
| x.SetCallback(UpdateCells); |
| return x; |
| }) |
| .GetEnumerator(); |
| } |
| |
| IEnumerator IEnumerable.GetEnumerator() { |
| return _list |
| .Select(x => { |
| x.SetCallback(UpdateCells); |
| return x; |
| }) |
| .GetEnumerator(); |
| } |
| } |