|  | /******************************************************************************* | 
|  | * 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 | 
|  | *******************************************************************************/ | 
|  |  | 
|  | namespace OfficeOpenXml.Style; | 
|  |  | 
|  | /// <summary> | 
|  | /// The numberformat of the cell | 
|  | /// </summary> | 
|  | public sealed class ExcelNumberFormat : StyleBase { | 
|  | internal ExcelNumberFormat( | 
|  | ExcelStyles styles, | 
|  | XmlHelper.ChangedEventHandler changedEvent, | 
|  | int positionId, | 
|  | string address, | 
|  | int index) | 
|  | : base(styles, changedEvent, positionId, address) { | 
|  | Index = index; | 
|  | } | 
|  |  | 
|  | /// <summary> | 
|  | /// The numeric index fror the format | 
|  | /// </summary> | 
|  | public int NumFmtID => Index; | 
|  |  | 
|  | /// <summary> | 
|  | /// The numberformat | 
|  | /// </summary> | 
|  | public string Format { | 
|  | get { | 
|  | for (int i = 0; i < _styles.NumberFormats.Count; i++) { | 
|  | if (Index == _styles.NumberFormats[i].NumFmtId) { | 
|  | return _styles.NumberFormats[i].Format; | 
|  | } | 
|  | } | 
|  | return "general"; | 
|  | } | 
|  | set => | 
|  | _ChangedEvent( | 
|  | this, | 
|  | new( | 
|  | eStyleClass.Numberformat, | 
|  | eStyleProperty.Format, | 
|  | (string.IsNullOrEmpty(value) ? "General" : value), | 
|  | _positionID, | 
|  | _address)); | 
|  | } | 
|  |  | 
|  | internal override string Id => Format; | 
|  |  | 
|  | /// <summary> | 
|  | /// If the numeric format is a build-in from. | 
|  | /// </summary> | 
|  | public bool BuildIn { get; private set; } | 
|  |  | 
|  | internal static string GetFromBuildInFromId(int numFmtId) { | 
|  | switch (numFmtId) { | 
|  | case 0: | 
|  | return "General"; | 
|  | case 1: | 
|  | return "0"; | 
|  | case 2: | 
|  | return "0.00"; | 
|  | case 3: | 
|  | return "#,##0"; | 
|  | case 4: | 
|  | return "#,##0.00"; | 
|  | case 9: | 
|  | return "0%"; | 
|  | case 10: | 
|  | return "0.00%"; | 
|  | case 11: | 
|  | return "0.00E+00"; | 
|  | case 12: | 
|  | return "# ?/?"; | 
|  | case 13: | 
|  | return "# ??/??"; | 
|  | case 14: | 
|  | return "mm-dd-yy"; | 
|  | case 15: | 
|  | return "d-mmm-yy"; | 
|  | case 16: | 
|  | return "d-mmm"; | 
|  | case 17: | 
|  | return "mmm-yy"; | 
|  | case 18: | 
|  | return "h:mm AM/PM"; | 
|  | case 19: | 
|  | return "h:mm:ss AM/PM"; | 
|  | case 20: | 
|  | return "h:mm"; | 
|  | case 21: | 
|  | return "h:mm:ss"; | 
|  | case 22: | 
|  | return "m/d/yy h:mm"; | 
|  | case 37: | 
|  | return "#,##0 ;(#,##0)"; | 
|  | case 38: | 
|  | return "#,##0 ;[Red](#,##0)"; | 
|  | case 39: | 
|  | return "#,##0.00;(#,##0.00)"; | 
|  | case 40: | 
|  | return "#,##0.00;[Red](#,##0.00)"; | 
|  | case 45: | 
|  | return "mm:ss"; | 
|  | case 46: | 
|  | return "[h]:mm:ss"; | 
|  | case 47: | 
|  | return "mmss.0"; | 
|  | case 48: | 
|  | return "##0.0"; | 
|  | case 49: | 
|  | return "@"; | 
|  | default: | 
|  | return string.Empty; | 
|  | } | 
|  | } | 
|  |  | 
|  | internal static int GetFromBuildIdFromFormat(string format) { | 
|  | switch (format) { | 
|  | case "General": | 
|  | case "": | 
|  | return 0; | 
|  | case "0": | 
|  | return 1; | 
|  | case "0.00": | 
|  | return 2; | 
|  | case "#,##0": | 
|  | return 3; | 
|  | case "#,##0.00": | 
|  | return 4; | 
|  | case "0%": | 
|  | return 9; | 
|  | case "0.00%": | 
|  | return 10; | 
|  | case "0.00E+00": | 
|  | return 11; | 
|  | case "# ?/?": | 
|  | return 12; | 
|  | case "# ??/??": | 
|  | return 13; | 
|  | case "mm-dd-yy": | 
|  | return 14; | 
|  | case "d-mmm-yy": | 
|  | return 15; | 
|  | case "d-mmm": | 
|  | return 16; | 
|  | case "mmm-yy": | 
|  | return 17; | 
|  | case "h:mm AM/PM": | 
|  | return 18; | 
|  | case "h:mm:ss AM/PM": | 
|  | return 19; | 
|  | case "h:mm": | 
|  | return 20; | 
|  | case "h:mm:ss": | 
|  | return 21; | 
|  | case "m/d/yy h:mm": | 
|  | return 22; | 
|  | case "#,##0 ;(#,##0)": | 
|  | return 37; | 
|  | case "#,##0 ;[Red](#,##0)": | 
|  | return 38; | 
|  | case "#,##0.00;(#,##0.00)": | 
|  | return 39; | 
|  | case "#,##0.00;[Red](#,##0.00)": | 
|  | return 40; | 
|  | case "mm:ss": | 
|  | return 45; | 
|  | case "[h]:mm:ss": | 
|  | return 46; | 
|  | case "mmss.0": | 
|  | return 47; | 
|  | case "##0.0": | 
|  | return 48; | 
|  | case "@": | 
|  | return 49; | 
|  | default: | 
|  | return int.MinValue; | 
|  | } | 
|  | } | 
|  | } |