first commit
This commit is contained in:
		
						commit
						00b0211767
					
				| 
						 | 
				
			
			@ -0,0 +1,63 @@
 | 
			
		|||
###############################################################################
 | 
			
		||||
# Set default behavior to automatically normalize line endings.
 | 
			
		||||
###############################################################################
 | 
			
		||||
* text=auto
 | 
			
		||||
 | 
			
		||||
###############################################################################
 | 
			
		||||
# Set default behavior for command prompt diff.
 | 
			
		||||
#
 | 
			
		||||
# This is need for earlier builds of msysgit that does not have it on by
 | 
			
		||||
# default for csharp files.
 | 
			
		||||
# Note: This is only used by command line
 | 
			
		||||
###############################################################################
 | 
			
		||||
#*.cs     diff=csharp
 | 
			
		||||
 | 
			
		||||
###############################################################################
 | 
			
		||||
# Set the merge driver for project and solution files
 | 
			
		||||
#
 | 
			
		||||
# Merging from the command prompt will add diff markers to the files if there
 | 
			
		||||
# are conflicts (Merging from VS is not affected by the settings below, in VS
 | 
			
		||||
# the diff markers are never inserted). Diff markers may cause the following 
 | 
			
		||||
# file extensions to fail to load in VS. An alternative would be to treat
 | 
			
		||||
# these files as binary and thus will always conflict and require user
 | 
			
		||||
# intervention with every merge. To do so, just uncomment the entries below
 | 
			
		||||
###############################################################################
 | 
			
		||||
#*.sln       merge=binary
 | 
			
		||||
#*.csproj    merge=binary
 | 
			
		||||
#*.vbproj    merge=binary
 | 
			
		||||
#*.vcxproj   merge=binary
 | 
			
		||||
#*.vcproj    merge=binary
 | 
			
		||||
#*.dbproj    merge=binary
 | 
			
		||||
#*.fsproj    merge=binary
 | 
			
		||||
#*.lsproj    merge=binary
 | 
			
		||||
#*.wixproj   merge=binary
 | 
			
		||||
#*.modelproj merge=binary
 | 
			
		||||
#*.sqlproj   merge=binary
 | 
			
		||||
#*.wwaproj   merge=binary
 | 
			
		||||
 | 
			
		||||
###############################################################################
 | 
			
		||||
# behavior for image files
 | 
			
		||||
#
 | 
			
		||||
# image files are treated as binary by default.
 | 
			
		||||
###############################################################################
 | 
			
		||||
#*.jpg   binary
 | 
			
		||||
#*.png   binary
 | 
			
		||||
#*.gif   binary
 | 
			
		||||
 | 
			
		||||
###############################################################################
 | 
			
		||||
# diff behavior for common document formats
 | 
			
		||||
# 
 | 
			
		||||
# Convert binary document formats to text before diffing them. This feature
 | 
			
		||||
# is only available from the command line. Turn it on by uncommenting the 
 | 
			
		||||
# entries below.
 | 
			
		||||
###############################################################################
 | 
			
		||||
#*.doc   diff=astextplain
 | 
			
		||||
#*.DOC   diff=astextplain
 | 
			
		||||
#*.docx  diff=astextplain
 | 
			
		||||
#*.DOCX  diff=astextplain
 | 
			
		||||
#*.dot   diff=astextplain
 | 
			
		||||
#*.DOT   diff=astextplain
 | 
			
		||||
#*.pdf   diff=astextplain
 | 
			
		||||
#*.PDF   diff=astextplain
 | 
			
		||||
#*.rtf   diff=astextplain
 | 
			
		||||
#*.RTF   diff=astextplain
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,363 @@
 | 
			
		|||
## Ignore Visual Studio temporary files, build results, and
 | 
			
		||||
## files generated by popular Visual Studio add-ons.
 | 
			
		||||
##
 | 
			
		||||
## Get latest from https://github.com/github/gitignore/blob/master/VisualStudio.gitignore
 | 
			
		||||
 | 
			
		||||
# User-specific files
 | 
			
		||||
*.rsuser
 | 
			
		||||
*.suo
 | 
			
		||||
*.user
 | 
			
		||||
*.userosscache
 | 
			
		||||
*.sln.docstates
 | 
			
		||||
 | 
			
		||||
# User-specific files (MonoDevelop/Xamarin Studio)
 | 
			
		||||
*.userprefs
 | 
			
		||||
 | 
			
		||||
# Mono auto generated files
 | 
			
		||||
mono_crash.*
 | 
			
		||||
 | 
			
		||||
# Build results
 | 
			
		||||
[Dd]ebug/
 | 
			
		||||
[Dd]ebugPublic/
 | 
			
		||||
[Rr]elease/
 | 
			
		||||
[Rr]eleases/
 | 
			
		||||
x64/
 | 
			
		||||
x86/
 | 
			
		||||
[Ww][Ii][Nn]32/
 | 
			
		||||
[Aa][Rr][Mm]/
 | 
			
		||||
[Aa][Rr][Mm]64/
 | 
			
		||||
bld/
 | 
			
		||||
[Bb]in/
 | 
			
		||||
[Oo]bj/
 | 
			
		||||
[Oo]ut/
 | 
			
		||||
[Ll]og/
 | 
			
		||||
[Ll]ogs/
 | 
			
		||||
 | 
			
		||||
# Visual Studio 2015/2017 cache/options directory
 | 
			
		||||
.vs/
 | 
			
		||||
# Uncomment if you have tasks that create the project's static files in wwwroot
 | 
			
		||||
#wwwroot/
 | 
			
		||||
 | 
			
		||||
# Visual Studio 2017 auto generated files
 | 
			
		||||
Generated\ Files/
 | 
			
		||||
 | 
			
		||||
# MSTest test Results
 | 
			
		||||
[Tt]est[Rr]esult*/
 | 
			
		||||
[Bb]uild[Ll]og.*
 | 
			
		||||
 | 
			
		||||
# NUnit
 | 
			
		||||
*.VisualState.xml
 | 
			
		||||
TestResult.xml
 | 
			
		||||
nunit-*.xml
 | 
			
		||||
 | 
			
		||||
# Build Results of an ATL Project
 | 
			
		||||
[Dd]ebugPS/
 | 
			
		||||
[Rr]eleasePS/
 | 
			
		||||
dlldata.c
 | 
			
		||||
 | 
			
		||||
# Benchmark Results
 | 
			
		||||
BenchmarkDotNet.Artifacts/
 | 
			
		||||
 | 
			
		||||
# .NET Core
 | 
			
		||||
project.lock.json
 | 
			
		||||
project.fragment.lock.json
 | 
			
		||||
artifacts/
 | 
			
		||||
 | 
			
		||||
# ASP.NET Scaffolding
 | 
			
		||||
ScaffoldingReadMe.txt
 | 
			
		||||
 | 
			
		||||
# StyleCop
 | 
			
		||||
StyleCopReport.xml
 | 
			
		||||
 | 
			
		||||
# Files built by Visual Studio
 | 
			
		||||
*_i.c
 | 
			
		||||
*_p.c
 | 
			
		||||
*_h.h
 | 
			
		||||
*.ilk
 | 
			
		||||
*.meta
 | 
			
		||||
*.obj
 | 
			
		||||
*.iobj
 | 
			
		||||
*.pch
 | 
			
		||||
*.pdb
 | 
			
		||||
*.ipdb
 | 
			
		||||
*.pgc
 | 
			
		||||
*.pgd
 | 
			
		||||
*.rsp
 | 
			
		||||
*.sbr
 | 
			
		||||
*.tlb
 | 
			
		||||
*.tli
 | 
			
		||||
*.tlh
 | 
			
		||||
*.tmp
 | 
			
		||||
*.tmp_proj
 | 
			
		||||
*_wpftmp.csproj
 | 
			
		||||
*.log
 | 
			
		||||
*.vspscc
 | 
			
		||||
*.vssscc
 | 
			
		||||
.builds
 | 
			
		||||
*.pidb
 | 
			
		||||
*.svclog
 | 
			
		||||
*.scc
 | 
			
		||||
 | 
			
		||||
# Chutzpah Test files
 | 
			
		||||
_Chutzpah*
 | 
			
		||||
 | 
			
		||||
# Visual C++ cache files
 | 
			
		||||
ipch/
 | 
			
		||||
*.aps
 | 
			
		||||
*.ncb
 | 
			
		||||
*.opendb
 | 
			
		||||
*.opensdf
 | 
			
		||||
*.sdf
 | 
			
		||||
*.cachefile
 | 
			
		||||
*.VC.db
 | 
			
		||||
*.VC.VC.opendb
 | 
			
		||||
 | 
			
		||||
# Visual Studio profiler
 | 
			
		||||
*.psess
 | 
			
		||||
*.vsp
 | 
			
		||||
*.vspx
 | 
			
		||||
*.sap
 | 
			
		||||
 | 
			
		||||
# Visual Studio Trace Files
 | 
			
		||||
*.e2e
 | 
			
		||||
 | 
			
		||||
# TFS 2012 Local Workspace
 | 
			
		||||
$tf/
 | 
			
		||||
 | 
			
		||||
# Guidance Automation Toolkit
 | 
			
		||||
*.gpState
 | 
			
		||||
 | 
			
		||||
# ReSharper is a .NET coding add-in
 | 
			
		||||
_ReSharper*/
 | 
			
		||||
*.[Rr]e[Ss]harper
 | 
			
		||||
*.DotSettings.user
 | 
			
		||||
 | 
			
		||||
# TeamCity is a build add-in
 | 
			
		||||
_TeamCity*
 | 
			
		||||
 | 
			
		||||
# DotCover is a Code Coverage Tool
 | 
			
		||||
*.dotCover
 | 
			
		||||
 | 
			
		||||
# AxoCover is a Code Coverage Tool
 | 
			
		||||
.axoCover/*
 | 
			
		||||
!.axoCover/settings.json
 | 
			
		||||
 | 
			
		||||
# Coverlet is a free, cross platform Code Coverage Tool
 | 
			
		||||
coverage*.json
 | 
			
		||||
coverage*.xml
 | 
			
		||||
coverage*.info
 | 
			
		||||
 | 
			
		||||
# Visual Studio code coverage results
 | 
			
		||||
*.coverage
 | 
			
		||||
*.coveragexml
 | 
			
		||||
 | 
			
		||||
# NCrunch
 | 
			
		||||
_NCrunch_*
 | 
			
		||||
.*crunch*.local.xml
 | 
			
		||||
nCrunchTemp_*
 | 
			
		||||
 | 
			
		||||
# MightyMoose
 | 
			
		||||
*.mm.*
 | 
			
		||||
AutoTest.Net/
 | 
			
		||||
 | 
			
		||||
# Web workbench (sass)
 | 
			
		||||
.sass-cache/
 | 
			
		||||
 | 
			
		||||
# Installshield output folder
 | 
			
		||||
[Ee]xpress/
 | 
			
		||||
 | 
			
		||||
# DocProject is a documentation generator add-in
 | 
			
		||||
DocProject/buildhelp/
 | 
			
		||||
DocProject/Help/*.HxT
 | 
			
		||||
DocProject/Help/*.HxC
 | 
			
		||||
DocProject/Help/*.hhc
 | 
			
		||||
DocProject/Help/*.hhk
 | 
			
		||||
DocProject/Help/*.hhp
 | 
			
		||||
DocProject/Help/Html2
 | 
			
		||||
DocProject/Help/html
 | 
			
		||||
 | 
			
		||||
# Click-Once directory
 | 
			
		||||
publish/
 | 
			
		||||
 | 
			
		||||
# Publish Web Output
 | 
			
		||||
*.[Pp]ublish.xml
 | 
			
		||||
*.azurePubxml
 | 
			
		||||
# Note: Comment the next line if you want to checkin your web deploy settings,
 | 
			
		||||
# but database connection strings (with potential passwords) will be unencrypted
 | 
			
		||||
*.pubxml
 | 
			
		||||
*.publishproj
 | 
			
		||||
 | 
			
		||||
# Microsoft Azure Web App publish settings. Comment the next line if you want to
 | 
			
		||||
# checkin your Azure Web App publish settings, but sensitive information contained
 | 
			
		||||
# in these scripts will be unencrypted
 | 
			
		||||
PublishScripts/
 | 
			
		||||
 | 
			
		||||
# NuGet Packages
 | 
			
		||||
*.nupkg
 | 
			
		||||
# NuGet Symbol Packages
 | 
			
		||||
*.snupkg
 | 
			
		||||
# The packages folder can be ignored because of Package Restore
 | 
			
		||||
**/[Pp]ackages/*
 | 
			
		||||
# except build/, which is used as an MSBuild target.
 | 
			
		||||
!**/[Pp]ackages/build/
 | 
			
		||||
# Uncomment if necessary however generally it will be regenerated when needed
 | 
			
		||||
#!**/[Pp]ackages/repositories.config
 | 
			
		||||
# NuGet v3's project.json files produces more ignorable files
 | 
			
		||||
*.nuget.props
 | 
			
		||||
*.nuget.targets
 | 
			
		||||
 | 
			
		||||
# Microsoft Azure Build Output
 | 
			
		||||
csx/
 | 
			
		||||
*.build.csdef
 | 
			
		||||
 | 
			
		||||
# Microsoft Azure Emulator
 | 
			
		||||
ecf/
 | 
			
		||||
rcf/
 | 
			
		||||
 | 
			
		||||
# Windows Store app package directories and files
 | 
			
		||||
AppPackages/
 | 
			
		||||
BundleArtifacts/
 | 
			
		||||
Package.StoreAssociation.xml
 | 
			
		||||
_pkginfo.txt
 | 
			
		||||
*.appx
 | 
			
		||||
*.appxbundle
 | 
			
		||||
*.appxupload
 | 
			
		||||
 | 
			
		||||
# Visual Studio cache files
 | 
			
		||||
# files ending in .cache can be ignored
 | 
			
		||||
*.[Cc]ache
 | 
			
		||||
# but keep track of directories ending in .cache
 | 
			
		||||
!?*.[Cc]ache/
 | 
			
		||||
 | 
			
		||||
# Others
 | 
			
		||||
ClientBin/
 | 
			
		||||
~$*
 | 
			
		||||
*~
 | 
			
		||||
*.dbmdl
 | 
			
		||||
*.dbproj.schemaview
 | 
			
		||||
*.jfm
 | 
			
		||||
*.pfx
 | 
			
		||||
*.publishsettings
 | 
			
		||||
orleans.codegen.cs
 | 
			
		||||
 | 
			
		||||
# Including strong name files can present a security risk
 | 
			
		||||
# (https://github.com/github/gitignore/pull/2483#issue-259490424)
 | 
			
		||||
#*.snk
 | 
			
		||||
 | 
			
		||||
# Since there are multiple workflows, uncomment next line to ignore bower_components
 | 
			
		||||
# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622)
 | 
			
		||||
#bower_components/
 | 
			
		||||
 | 
			
		||||
# RIA/Silverlight projects
 | 
			
		||||
Generated_Code/
 | 
			
		||||
 | 
			
		||||
# Backup & report files from converting an old project file
 | 
			
		||||
# to a newer Visual Studio version. Backup files are not needed,
 | 
			
		||||
# because we have git ;-)
 | 
			
		||||
_UpgradeReport_Files/
 | 
			
		||||
Backup*/
 | 
			
		||||
UpgradeLog*.XML
 | 
			
		||||
UpgradeLog*.htm
 | 
			
		||||
ServiceFabricBackup/
 | 
			
		||||
*.rptproj.bak
 | 
			
		||||
 | 
			
		||||
# SQL Server files
 | 
			
		||||
*.mdf
 | 
			
		||||
*.ldf
 | 
			
		||||
*.ndf
 | 
			
		||||
 | 
			
		||||
# Business Intelligence projects
 | 
			
		||||
*.rdl.data
 | 
			
		||||
*.bim.layout
 | 
			
		||||
*.bim_*.settings
 | 
			
		||||
*.rptproj.rsuser
 | 
			
		||||
*- [Bb]ackup.rdl
 | 
			
		||||
*- [Bb]ackup ([0-9]).rdl
 | 
			
		||||
*- [Bb]ackup ([0-9][0-9]).rdl
 | 
			
		||||
 | 
			
		||||
# Microsoft Fakes
 | 
			
		||||
FakesAssemblies/
 | 
			
		||||
 | 
			
		||||
# GhostDoc plugin setting file
 | 
			
		||||
*.GhostDoc.xml
 | 
			
		||||
 | 
			
		||||
# Node.js Tools for Visual Studio
 | 
			
		||||
.ntvs_analysis.dat
 | 
			
		||||
node_modules/
 | 
			
		||||
 | 
			
		||||
# Visual Studio 6 build log
 | 
			
		||||
*.plg
 | 
			
		||||
 | 
			
		||||
# Visual Studio 6 workspace options file
 | 
			
		||||
*.opt
 | 
			
		||||
 | 
			
		||||
# Visual Studio 6 auto-generated workspace file (contains which files were open etc.)
 | 
			
		||||
*.vbw
 | 
			
		||||
 | 
			
		||||
# Visual Studio LightSwitch build output
 | 
			
		||||
**/*.HTMLClient/GeneratedArtifacts
 | 
			
		||||
**/*.DesktopClient/GeneratedArtifacts
 | 
			
		||||
**/*.DesktopClient/ModelManifest.xml
 | 
			
		||||
**/*.Server/GeneratedArtifacts
 | 
			
		||||
**/*.Server/ModelManifest.xml
 | 
			
		||||
_Pvt_Extensions
 | 
			
		||||
 | 
			
		||||
# Paket dependency manager
 | 
			
		||||
.paket/paket.exe
 | 
			
		||||
paket-files/
 | 
			
		||||
 | 
			
		||||
# FAKE - F# Make
 | 
			
		||||
.fake/
 | 
			
		||||
 | 
			
		||||
# CodeRush personal settings
 | 
			
		||||
.cr/personal
 | 
			
		||||
 | 
			
		||||
# Python Tools for Visual Studio (PTVS)
 | 
			
		||||
__pycache__/
 | 
			
		||||
*.pyc
 | 
			
		||||
 | 
			
		||||
# Cake - Uncomment if you are using it
 | 
			
		||||
# tools/**
 | 
			
		||||
# !tools/packages.config
 | 
			
		||||
 | 
			
		||||
# Tabs Studio
 | 
			
		||||
*.tss
 | 
			
		||||
 | 
			
		||||
# Telerik's JustMock configuration file
 | 
			
		||||
*.jmconfig
 | 
			
		||||
 | 
			
		||||
# BizTalk build output
 | 
			
		||||
*.btp.cs
 | 
			
		||||
*.btm.cs
 | 
			
		||||
*.odx.cs
 | 
			
		||||
*.xsd.cs
 | 
			
		||||
 | 
			
		||||
# OpenCover UI analysis results
 | 
			
		||||
OpenCover/
 | 
			
		||||
 | 
			
		||||
# Azure Stream Analytics local run output
 | 
			
		||||
ASALocalRun/
 | 
			
		||||
 | 
			
		||||
# MSBuild Binary and Structured Log
 | 
			
		||||
*.binlog
 | 
			
		||||
 | 
			
		||||
# NVidia Nsight GPU debugger configuration file
 | 
			
		||||
*.nvuser
 | 
			
		||||
 | 
			
		||||
# MFractors (Xamarin productivity tool) working folder
 | 
			
		||||
.mfractor/
 | 
			
		||||
 | 
			
		||||
# Local History for Visual Studio
 | 
			
		||||
.localhistory/
 | 
			
		||||
 | 
			
		||||
# BeatPulse healthcheck temp database
 | 
			
		||||
healthchecksdb
 | 
			
		||||
 | 
			
		||||
# Backup folder for Package Reference Convert tool in Visual Studio 2017
 | 
			
		||||
MigrationBackup/
 | 
			
		||||
 | 
			
		||||
# Ionide (cross platform F# VS Code tools) working folder
 | 
			
		||||
.ionide/
 | 
			
		||||
 | 
			
		||||
# Fody - auto-generated XML schema
 | 
			
		||||
FodyWeavers.xsd
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,25 @@
 | 
			
		|||
using System;
 | 
			
		||||
using System.Collections.Generic;
 | 
			
		||||
using System.Linq;
 | 
			
		||||
using System.Text;
 | 
			
		||||
using System.Threading.Tasks;
 | 
			
		||||
 | 
			
		||||
namespace kmCustomReportsNET.ClassObj;
 | 
			
		||||
 | 
			
		||||
public class ClsConstants
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
  public static string KDrive = @"\\salem\k";
 | 
			
		||||
 | 
			
		||||
  /// <summary>
 | 
			
		||||
  /// T = Dot-Net (C#) version of the reports
 | 
			
		||||
  /// </summary>
 | 
			
		||||
  public enum enuReportIDs : byte
 | 
			
		||||
  {
 | 
			
		||||
    /// <summary>
 | 
			
		||||
    /// Dobbs Monthly Email Contests
 | 
			
		||||
    /// </summary>
 | 
			
		||||
    T1439 = 101
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,263 @@
 | 
			
		|||
using Microsoft.Data.SqlClient;
 | 
			
		||||
using OfficeOpenXml;
 | 
			
		||||
using System;
 | 
			
		||||
using System.Collections.Generic;
 | 
			
		||||
using System.Data;
 | 
			
		||||
using System.Drawing;
 | 
			
		||||
using System.Linq;
 | 
			
		||||
using System.Text;
 | 
			
		||||
using System.Threading.Tasks;
 | 
			
		||||
//using static kmCustomReportsNET.ClassObj.ClsConstants;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
namespace kmCustomReportsNET.ClassObj;
 | 
			
		||||
 | 
			
		||||
internal class ClsDobbsEmail_T1439 : IDisposable
 | 
			
		||||
{
 | 
			
		||||
  public string RptSaveToFolder { get; set; } = ClsConstants.KDrive + @"\Projects\Daily Report Archive";
 | 
			
		||||
  public string Template1Path { get; set; } = ClsConstants.KDrive + @"\Projects\Daily Reports - Dobbs\T1439 Template 01.xlsx";
 | 
			
		||||
  public string BusinessName { get; set; } = "DobbsTire";
 | 
			
		||||
  public ClsConstants.enuReportIDs ReportID { get; set; } = ClsConstants.enuReportIDs.T1439;
 | 
			
		||||
  public bool DebugMode { get; set; } = false;
 | 
			
		||||
 | 
			
		||||
  #region "Private Variables"
 | 
			
		||||
  DataSet? ds = null;
 | 
			
		||||
  List<string> FilesToAttach = new();
 | 
			
		||||
  #endregion
 | 
			
		||||
 | 
			
		||||
  public void Dispose()
 | 
			
		||||
  {
 | 
			
		||||
    if (ds != null)
 | 
			
		||||
      ds.Dispose();
 | 
			
		||||
    ds = null;
 | 
			
		||||
    FilesToAttach.Clear();
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  internal void Go()
 | 
			
		||||
  {
 | 
			
		||||
    ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
 | 
			
		||||
    using (var cn = new SqlConnection(kmCommonLibsCore.Constants.cnRDB))
 | 
			
		||||
    {
 | 
			
		||||
      cn.Open();
 | 
			
		||||
 | 
			
		||||
      using (var cm = new SqlCommand("crpt.[Dobbs_T1439_EmailContests]", cn) { CommandType = CommandType.StoredProcedure, CommandTimeout = 120 })
 | 
			
		||||
      using (var da = new SqlDataAdapter(cm))
 | 
			
		||||
      {
 | 
			
		||||
        cm.Parameters.Add("@DateThruOverride", SqlDbType.Date).Value = DateTime.Parse("Oct 7, 2025");
 | 
			
		||||
        ds = new DataSet();
 | 
			
		||||
        da.Fill(ds);
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    //
 | 
			
		||||
 | 
			
		||||
    if (ds != null && ds.Tables.Count > 2 && ds.Tables[0].Rows.Count == 1)
 | 
			
		||||
    {
 | 
			
		||||
      CreateWeeklyStandings();
 | 
			
		||||
      CreateDetailSnapshots();
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  private void CreateWeeklyStandings()
 | 
			
		||||
  {
 | 
			
		||||
    DataRow drDates = ds.Tables[0].Rows[0];
 | 
			
		||||
    string xlsFilename;
 | 
			
		||||
    int ctr = 0;
 | 
			
		||||
 | 
			
		||||
    xlsFilename = Path.Combine(RptSaveToFolder, string.Format("Dobbs {0:yyyy-MM MMM} Week {1} Email Contest Results.xlsx", drDates["mthTo"], drDates["WeekNumber"]));
 | 
			
		||||
    if (File.Exists(xlsFilename))
 | 
			
		||||
    {
 | 
			
		||||
      string f0 = xlsFilename;
 | 
			
		||||
      while (File.Exists(f0))
 | 
			
		||||
      {
 | 
			
		||||
        f0 = Path.Combine(RptSaveToFolder, string.Format("Dobbs {0:yyyy-MM MMM} Week {1} Email Contest Results - OLD{2:000}.xlsx", drDates["mthTo"], drDates["WeekNumber"], ctr));
 | 
			
		||||
        ctr += 1;
 | 
			
		||||
      }
 | 
			
		||||
      File.Move(xlsFilename, f0);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Standings file first
 | 
			
		||||
 | 
			
		||||
    using (var fs = new FileStream(Template1Path, FileMode.Open))
 | 
			
		||||
    using (var pkg = new ExcelPackage(fs))
 | 
			
		||||
    {
 | 
			
		||||
      ExcelWorksheet? s = null;  //pkg.Workbook.Worksheets[1];
 | 
			
		||||
      int r = 4, rTot = ds.Tables[1].Rows.Count;
 | 
			
		||||
 | 
			
		||||
      if (pkg.Workbook.Worksheets.Count < 1)
 | 
			
		||||
        s = pkg.Workbook.Worksheets.Add("Sheet1");
 | 
			
		||||
      else
 | 
			
		||||
        s = pkg.Workbook.Worksheets[0];
 | 
			
		||||
 | 
			
		||||
      s.Name = string.Format("{0:MMM-yyyy} Week {1} Results", drDates["mthTo"], drDates["WeekNumber"]);
 | 
			
		||||
 | 
			
		||||
      //s.Cells[1, 1].Value = string.Format("Email Contest Results\n{0:ddd MMM d} through {1:ddd MMM d, yyyy}", drDates["wkFrom"], drDates["wkTo"]);
 | 
			
		||||
      s.Cells[1, 1].Value = string.Format("Email Contest Results through {1:ddd MMM d, yyyy}", drDates["wkFrom"], drDates["wkTo"]);
 | 
			
		||||
      s.Cells[3, 3].Value = string.Format("Week {0}\nNew Emails", drDates["WeekNumber"]);
 | 
			
		||||
 | 
			
		||||
      foreach (DataRow dr in ds.Tables[1].Rows)
 | 
			
		||||
      {
 | 
			
		||||
        s.Cells[r, 1].Value = dr["Division"].ToString();
 | 
			
		||||
        s.Cells[r, 2].Value = Convert.ToInt32(dr["StoreNumber"]);
 | 
			
		||||
        s.Cells[r, 3].Value = Convert.ToInt32(dr["NewEmails"]);
 | 
			
		||||
        s.Cells[r, 4].Value = Convert.ToInt32(dr["TransactionsGreaterThanZero"]);
 | 
			
		||||
        s.Cells[r, 5].FormulaR1C1 = "=IF(RC[-1]=0,0,RC[-2]/RC[-1])";
 | 
			
		||||
 | 
			
		||||
        // Borders around each cell
 | 
			
		||||
        using (var rng = s.Cells[r, 1, r, 5])
 | 
			
		||||
        {
 | 
			
		||||
          rng.Style.Border.BorderAround(OfficeOpenXml.Style.ExcelBorderStyle.Thin);
 | 
			
		||||
          rng.Style.Border.Left.Style = OfficeOpenXml.Style.ExcelBorderStyle.Medium;
 | 
			
		||||
          rng.Style.Border.Right.Style = OfficeOpenXml.Style.ExcelBorderStyle.Medium;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        for (int c = 1; c <= 3; c++)
 | 
			
		||||
          s.Cells[r, c].Style.Border.Right.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
 | 
			
		||||
        s.Cells[r, 5].Style.Border.BorderAround(OfficeOpenXml.Style.ExcelBorderStyle.Medium);
 | 
			
		||||
 | 
			
		||||
        // Shading
 | 
			
		||||
        if (r >= (rTot - 3 + 4))      // +4 since that's where we started
 | 
			
		||||
        {
 | 
			
		||||
          s.Cells[r, 5].Style.Fill.PatternType = OfficeOpenXml.Style.ExcelFillStyle.Solid;
 | 
			
		||||
          s.Cells[r, 5].Style.Fill.BackgroundColor.SetColor(Color.Red);
 | 
			
		||||
        }
 | 
			
		||||
        else
 | 
			
		||||
        {
 | 
			
		||||
          s.Cells[r, 5].Style.Fill.PatternType = OfficeOpenXml.Style.ExcelFillStyle.Solid;
 | 
			
		||||
          s.Cells[r, 5].Style.Fill.BackgroundColor.SetColor(Color.Yellow);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        r++;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      // Totals
 | 
			
		||||
      using (var rng = s.Cells[r, 1, r, 5])
 | 
			
		||||
      {
 | 
			
		||||
        rng.Style.Border.BorderAround(OfficeOpenXml.Style.ExcelBorderStyle.Thin);
 | 
			
		||||
        rng.Style.Border.Left.Style = OfficeOpenXml.Style.ExcelBorderStyle.Medium;
 | 
			
		||||
        rng.Style.Border.Right.Style = OfficeOpenXml.Style.ExcelBorderStyle.Medium;
 | 
			
		||||
        rng.Style.Fill.PatternType = OfficeOpenXml.Style.ExcelFillStyle.Solid;
 | 
			
		||||
        rng.Style.Fill.BackgroundColor.SetColor(Color.LightGray);
 | 
			
		||||
        rng.Style.Font.Bold = true;
 | 
			
		||||
      }
 | 
			
		||||
      for (int c = 1; c <= 3; c++)
 | 
			
		||||
        s.Cells[r, c].Style.Border.Right.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
 | 
			
		||||
      s.Cells[r, 5].Style.Border.BorderAround(OfficeOpenXml.Style.ExcelBorderStyle.Medium);
 | 
			
		||||
 | 
			
		||||
      //
 | 
			
		||||
      s.Cells[r, 1].Value = "Totals";
 | 
			
		||||
      s.Cells[r, 3].FormulaR1C1 = "=SUM(R4C:R[-1]C)";
 | 
			
		||||
      s.Cells[r, 4].FormulaR1C1 = "=SUM(R4C:R[-1]C)";
 | 
			
		||||
      s.Cells[r, 5].FormulaR1C1 = "=IF(RC[-1]=0,0,RC[-2]/RC[-1])";
 | 
			
		||||
 | 
			
		||||
      r++;
 | 
			
		||||
      pkg.SaveAs(xlsFilename);
 | 
			
		||||
      FilesToAttach.Add(xlsFilename);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  private void CreateDetailSnapshots()
 | 
			
		||||
  {
 | 
			
		||||
    DataRow drDates = ds.Tables[0].Rows[0];
 | 
			
		||||
    string xlsFilename;
 | 
			
		||||
    int ctr = 0;
 | 
			
		||||
    List<string> cols = new() { "dtRangeHumanized;Period;@","Division;Location;@",
 | 
			
		||||
      "TotalEmails;Total Emails;#,##0;R","NewEmails;New Emails;#,##0;R","OldEmails;Old Emails;#,##0;R",
 | 
			
		||||
      "Transactions;;#,##0;R","TransactionsGreaterThanZero;Invoices Greater than Zero;#,##0;R","Penetration;Penetration Rate;0.0%;R"};
 | 
			
		||||
 | 
			
		||||
    xlsFilename = Path.Combine(RptSaveToFolder, string.Format("Dobbs {0:yyyy-MM MMM} Week {1} Email Contest Detail.xlsx", drDates["mthTo"], drDates["WeekNumber"]));
 | 
			
		||||
    if (File.Exists(xlsFilename))
 | 
			
		||||
    {
 | 
			
		||||
      string f0 = xlsFilename;
 | 
			
		||||
      while (File.Exists(f0))
 | 
			
		||||
      {
 | 
			
		||||
        f0 = Path.Combine(RptSaveToFolder, string.Format("Dobbs {0:yyyy-MM MMM} Week {1} Email Contest Detail - OLD{2:000}.xlsx", drDates["mthTo"], drDates["WeekNumber"], ctr));
 | 
			
		||||
        ctr += 1;
 | 
			
		||||
      }
 | 
			
		||||
      File.Move(xlsFilename, f0);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    using (var fs = new FileStream(xlsFilename, FileMode.Create, FileAccess.Write, FileShare.None))
 | 
			
		||||
    using (var pkg = new ExcelPackage(fs))
 | 
			
		||||
    {
 | 
			
		||||
      ExcelWorksheet? s = null;
 | 
			
		||||
 | 
			
		||||
      for (int tbNumber = 2; tbNumber < ds.Tables.Count; tbNumber++)
 | 
			
		||||
      {
 | 
			
		||||
        var dt = ds.Tables[tbNumber];
 | 
			
		||||
        int r = 2, c;
 | 
			
		||||
 | 
			
		||||
        if (dt != null && dt.Rows.Count > 0)
 | 
			
		||||
        {
 | 
			
		||||
          if (pkg.Workbook.Worksheets.Count < (tbNumber - 1))
 | 
			
		||||
            s = pkg.Workbook.Worksheets.Add("Sheet1");
 | 
			
		||||
          else
 | 
			
		||||
            s = pkg.Workbook.Worksheets[0];
 | 
			
		||||
 | 
			
		||||
          if (tbNumber == 2)
 | 
			
		||||
            s.Name = string.Format("Month of {0:MMM-yyyy}", drDates["mthTo"]); //dt.Rows[0]["dtRangeHumanized"]);
 | 
			
		||||
          else
 | 
			
		||||
            s.Name = string.Format("Week thru {0:ddd MMM d}", dt.Rows[0]["dtTo"]);
 | 
			
		||||
 | 
			
		||||
          c = 0;
 | 
			
		||||
          foreach (var col in cols)
 | 
			
		||||
          {
 | 
			
		||||
            var fld = col.Split(';');
 | 
			
		||||
 | 
			
		||||
            c++;
 | 
			
		||||
            if (fld.Length > 2 && !string.IsNullOrWhiteSpace(fld[2]))
 | 
			
		||||
              s.Columns[c].Style.Numberformat.Format = fld[2];
 | 
			
		||||
            if (fld.Length > 3 && fld[3] == "R")
 | 
			
		||||
              s.Columns[c].Style.HorizontalAlignment = OfficeOpenXml.Style.ExcelHorizontalAlignment.Right;
 | 
			
		||||
 | 
			
		||||
            s.Cells[1, c].Style.Numberformat.Format = "@";
 | 
			
		||||
            s.Cells[1, c].Style.Font.Bold = true;
 | 
			
		||||
            if (fld.Length > 1 && !string.IsNullOrWhiteSpace(fld[1]))
 | 
			
		||||
              s.Cells[1, c].Value = fld[1];
 | 
			
		||||
            else
 | 
			
		||||
              s.Cells[1, c].Value = fld[0];
 | 
			
		||||
 | 
			
		||||
            if (fld.Length > 3 && fld[3] == "R")
 | 
			
		||||
              s.Cells[1, c].Style.HorizontalAlignment = OfficeOpenXml.Style.ExcelHorizontalAlignment.Right;
 | 
			
		||||
          }
 | 
			
		||||
 | 
			
		||||
          foreach (DataRow dr in dt.Rows)
 | 
			
		||||
          {
 | 
			
		||||
            c = 0;
 | 
			
		||||
            foreach (var col in cols)
 | 
			
		||||
            {
 | 
			
		||||
              var fld = col.Split(';');
 | 
			
		||||
 | 
			
		||||
              s.Cells[r, ++c].Value = dr[fld[0]];
 | 
			
		||||
            }
 | 
			
		||||
            //s.Cells[r, 8].FormulaR1C1 = "=IF(RC7=0,0,RC4/RC7)";
 | 
			
		||||
            //s.Cells[r, 8].FormulaR1C1 = "=IF(RC6-RC5=0,0,RC4/(RC6-RC5))";
 | 
			
		||||
            s.Cells[r, 8].FormulaR1C1 = "=IF(RC[-2]-RC[-3]=0,0,RC[-4]/(RC[-2]-RC[-3]))";
 | 
			
		||||
            r++;
 | 
			
		||||
          }
 | 
			
		||||
 | 
			
		||||
          // Grand Totals
 | 
			
		||||
          r++;
 | 
			
		||||
          using (var rng = s.Cells[r, 1, r, 8])
 | 
			
		||||
            rng.Style.Font.Bold = true;
 | 
			
		||||
 | 
			
		||||
          s.Cells[r, 2].Value = "Totals";
 | 
			
		||||
          for (c = 3; c <= 7; c++)
 | 
			
		||||
          {
 | 
			
		||||
            s.Cells[r, c].FormulaR1C1 = "=SUM(R2C:R[-1]C)";
 | 
			
		||||
          }
 | 
			
		||||
          //s.Cells[r, 8].FormulaR1C1 = "=IF(RC7=0,0,RC4/RC7)";
 | 
			
		||||
          //s.Cells[r, 8].FormulaR1C1 = "=IF(RC6-RC5=0,0,RC4/(RC6-RC5))";
 | 
			
		||||
          s.Cells[r, 8].FormulaR1C1 = "=IF(RC[-2]-RC[-3]=0,0,RC[-4]/(RC[-2]-RC[-3]))";
 | 
			
		||||
 | 
			
		||||
          s.Cells.AutoFitColumns();
 | 
			
		||||
          s.View.FreezePanes(2, 1);
 | 
			
		||||
          s.Select("A2");
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      pkg.Save();//As(xlsFilename);
 | 
			
		||||
      FilesToAttach.Add(xlsFilename);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,61 @@
 | 
			
		|||
using log4net;
 | 
			
		||||
using System;
 | 
			
		||||
using System.Collections.Concurrent;
 | 
			
		||||
using System.Collections.Generic;
 | 
			
		||||
using System.Linq;
 | 
			
		||||
using System.Text;
 | 
			
		||||
using System.Threading.Tasks;
 | 
			
		||||
using Topshelf;
 | 
			
		||||
 | 
			
		||||
namespace kmCustomReportsNET.ClassObj;
 | 
			
		||||
 | 
			
		||||
internal class ServiceMain : ServiceControl
 | 
			
		||||
{
 | 
			
		||||
  ILog appLog = LogManager.GetLogger(Program.AppName);
 | 
			
		||||
  ConcurrentBag<Task> tasks = new();
 | 
			
		||||
 | 
			
		||||
  public bool Start(HostControl hostControl)
 | 
			
		||||
  {
 | 
			
		||||
    tasks.Add(Task.Run(() => { Looper(); }));
 | 
			
		||||
    appLog.Info(string.Format("Service successfully started."));
 | 
			
		||||
    return true;
 | 
			
		||||
  } //Start
 | 
			
		||||
 | 
			
		||||
  public bool Stop(HostControl hostControl)
 | 
			
		||||
  {
 | 
			
		||||
    Program.isExiting = true;
 | 
			
		||||
    Task.WaitAll(tasks.ToArray());
 | 
			
		||||
    return true;
 | 
			
		||||
  } //Stop
 | 
			
		||||
 | 
			
		||||
  private void Looper()
 | 
			
		||||
  {
 | 
			
		||||
    var dtNext = DateTimeOffset.Now.AddSeconds(15);
 | 
			
		||||
    var rn = new Random();
 | 
			
		||||
    while (!Program.isExiting)
 | 
			
		||||
    {
 | 
			
		||||
      Thread.Sleep(rn.Next(250, 1500));
 | 
			
		||||
      if (dtNext < DateTimeOffset.Now)
 | 
			
		||||
      {
 | 
			
		||||
        try
 | 
			
		||||
        {
 | 
			
		||||
          RunTheReports();
 | 
			
		||||
        }
 | 
			
		||||
        catch //(Exception)
 | 
			
		||||
        {
 | 
			
		||||
          // do nothing
 | 
			
		||||
        }
 | 
			
		||||
        dtNext = DateTimeOffset.Now.AddSeconds(rn.Next(60, 90));
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  private void RunTheReports()
 | 
			
		||||
  {
 | 
			
		||||
    using (var obj = new ClsDobbsEmail_T1439() { DebugMode = false })
 | 
			
		||||
    {
 | 
			
		||||
      obj.Go();
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,44 @@
 | 
			
		|||
using log4net;
 | 
			
		||||
using log4net.Config;
 | 
			
		||||
using System.Reflection;
 | 
			
		||||
using Topshelf;
 | 
			
		||||
using kmCustomReportsNET.ClassObj;
 | 
			
		||||
using System.Diagnostics;
 | 
			
		||||
 | 
			
		||||
namespace kmCustomReportsNET;
 | 
			
		||||
 | 
			
		||||
internal class Program
 | 
			
		||||
{
 | 
			
		||||
  internal static string AppPath = AppDomain.CurrentDomain.BaseDirectory.Trim();
 | 
			
		||||
  internal static string AppName = AppDomain.CurrentDomain.FriendlyName.Trim();
 | 
			
		||||
  internal static string MachineName = Environment.MachineName.Trim();
 | 
			
		||||
 | 
			
		||||
  public static bool isExiting = false;
 | 
			
		||||
 | 
			
		||||
  static void Main(string[] args)
 | 
			
		||||
  {
 | 
			
		||||
    var logRepo = LogManager.GetRepository(Assembly.GetEntryAssembly());
 | 
			
		||||
    XmlConfigurator.Configure(logRepo, new FileInfo(Path.Combine(AppPath, "log4net.config")));
 | 
			
		||||
    GlobalContext.Properties["Application"] = AppName;
 | 
			
		||||
 | 
			
		||||
    if (Debugger.IsAttached)
 | 
			
		||||
    {
 | 
			
		||||
      using (var obj = new ClsDobbsEmail_T1439())
 | 
			
		||||
      {
 | 
			
		||||
        obj.Go();
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    else
 | 
			
		||||
    {
 | 
			
		||||
      var rc = HostFactory.Run(x =>
 | 
			
		||||
      {
 | 
			
		||||
        x.Service<ServiceMain>();
 | 
			
		||||
        x.EnableServiceRecovery(r => r.RestartService(TimeSpan.FromSeconds(15)));
 | 
			
		||||
        x.SetServiceName("kmAtomicTime2");
 | 
			
		||||
        x.StartAutomaticallyDelayed();
 | 
			
		||||
        x.SetDescription("Will run some custom reports occasionally for KeyMotive's customers.");
 | 
			
		||||
        x.UseLog4Net();
 | 
			
		||||
      });
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,23 @@
 | 
			
		|||
<Project Sdk="Microsoft.NET.Sdk">
 | 
			
		||||
 | 
			
		||||
  <PropertyGroup>
 | 
			
		||||
    <OutputType>Exe</OutputType>
 | 
			
		||||
    <TargetFramework>net9.0</TargetFramework>
 | 
			
		||||
    <ImplicitUsings>enable</ImplicitUsings>
 | 
			
		||||
    <Nullable>enable</Nullable>
 | 
			
		||||
  </PropertyGroup>
 | 
			
		||||
 | 
			
		||||
  <ItemGroup>
 | 
			
		||||
    <PackageReference Include="EPPlus" Version="7.7.3" />
 | 
			
		||||
    <PackageReference Include="kmCommonLibsCore" Version="2.0.0.158" />
 | 
			
		||||
    <PackageReference Include="Topshelf" Version="4.3.0" />
 | 
			
		||||
    <PackageReference Include="Topshelf.Log4Net" Version="4.3.0" />
 | 
			
		||||
  </ItemGroup>
 | 
			
		||||
 | 
			
		||||
  <ItemGroup>
 | 
			
		||||
    <None Update="log4net.config">
 | 
			
		||||
      <CopyToOutputDirectory>Always</CopyToOutputDirectory>
 | 
			
		||||
    </None>
 | 
			
		||||
  </ItemGroup>
 | 
			
		||||
 | 
			
		||||
</Project>
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,25 @@
 | 
			
		|||
 | 
			
		||||
Microsoft Visual Studio Solution File, Format Version 12.00
 | 
			
		||||
# Visual Studio Version 17
 | 
			
		||||
VisualStudioVersion = 17.14.36518.9 d17.14
 | 
			
		||||
MinimumVisualStudioVersion = 10.0.40219.1
 | 
			
		||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "kmCustomReportsNET", "kmCustomReportsNET.csproj", "{99353FF6-5263-4F1E-98DA-C3192D6FF6D4}"
 | 
			
		||||
EndProject
 | 
			
		||||
Global
 | 
			
		||||
	GlobalSection(SolutionConfigurationPlatforms) = preSolution
 | 
			
		||||
		Debug|Any CPU = Debug|Any CPU
 | 
			
		||||
		Release|Any CPU = Release|Any CPU
 | 
			
		||||
	EndGlobalSection
 | 
			
		||||
	GlobalSection(ProjectConfigurationPlatforms) = postSolution
 | 
			
		||||
		{99353FF6-5263-4F1E-98DA-C3192D6FF6D4}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
 | 
			
		||||
		{99353FF6-5263-4F1E-98DA-C3192D6FF6D4}.Debug|Any CPU.Build.0 = Debug|Any CPU
 | 
			
		||||
		{99353FF6-5263-4F1E-98DA-C3192D6FF6D4}.Release|Any CPU.ActiveCfg = Release|Any CPU
 | 
			
		||||
		{99353FF6-5263-4F1E-98DA-C3192D6FF6D4}.Release|Any CPU.Build.0 = Release|Any CPU
 | 
			
		||||
	EndGlobalSection
 | 
			
		||||
	GlobalSection(SolutionProperties) = preSolution
 | 
			
		||||
		HideSolutionNode = FALSE
 | 
			
		||||
	EndGlobalSection
 | 
			
		||||
	GlobalSection(ExtensibilityGlobals) = postSolution
 | 
			
		||||
		SolutionGuid = {B77A2F6F-83CF-426A-BC18-F22D1D479835}
 | 
			
		||||
	EndGlobalSection
 | 
			
		||||
EndGlobal
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,24 @@
 | 
			
		|||
<?xml version="1.0" encoding="utf-8" ?>
 | 
			
		||||
<log4net>
 | 
			
		||||
  <root>
 | 
			
		||||
    <level value="ALL" />
 | 
			
		||||
    <appender-ref ref="console" />
 | 
			
		||||
    <appender-ref ref="file" />
 | 
			
		||||
  </root>
 | 
			
		||||
  <appender name="console" type="log4net.Appender.ConsoleAppender">
 | 
			
		||||
    <layout type="log4net.Layout.PatternLayout">
 | 
			
		||||
      <conversionPattern value="%date %level %logger - %message%newline" />
 | 
			
		||||
    </layout>
 | 
			
		||||
  </appender>
 | 
			
		||||
  <appender name="file" type="log4net.Appender.RollingFileAppender">
 | 
			
		||||
    <file value="thisApplication.log" />
 | 
			
		||||
    <appendToFile value="true" />
 | 
			
		||||
    <rollingStyle value="Size" />
 | 
			
		||||
    <maxSizeRollBackups value="5" />
 | 
			
		||||
    <maximumFileSize value="10MB" />
 | 
			
		||||
    <staticLogFileName value="true" />
 | 
			
		||||
    <layout type="log4net.Layout.PatternLayout">
 | 
			
		||||
      <conversionPattern value="%date [%thread] %level %logger - %message%newline" />
 | 
			
		||||
    </layout>
 | 
			
		||||
  </appender>
 | 
			
		||||
</log4net>
 | 
			
		||||
		Loading…
	
		Reference in New Issue