コード例 #1
0
        public static void ClearColorMakers(IBackgroundContext context, LpuExecParams executorParams)
        {
            context.ProgressSeparator();
            context.ReportProgress(@"УДАЛЕНИЕ МАРКЕРОВ НЕДЕЙСТВИТЕЛЬНЫХ ПОЛИСОВ");
            context.ProgressSeparator();
            using (var dataContext = new VistaMedDataContext(context))
            {
                var invMarkerType = getInvMarkerType(dataContext);

                if(invMarkerType != null)
                {
                    context.ReportProgress(@"");
                    try
                    {
                        dataContext.VistaMed.ExecuteCommand(@"DELETE FROM Client_StatusObservation WHERE statusObservationType_id IS NULL");
                        dataContext.VistaMed.ExecuteCommand(@"DELETE FROM Client_StatusObservation WHERE statusObservationType_id = {0}", invMarkerType.Id);
                        dataContext.VistaMed.SubmitChanges();
                        context.ReportProgress(@"Удаление маркеров проведено");

                    }
                    catch (Exception exception)
                    {
                        context.ReportError(@"{0}", exception.Message);
                    }
                }
                else
                {
                    //context.ReportError(@"Тип маркера недействительного полиса не найден в БД ВистаМед");
                }
            }
            context.ProgressSeparator('-');
        }
コード例 #2
0
ファイル: SvodDdr.cs プロジェクト: vvboborykin/VistaMedTools
        public static void BuildSvedDdReport(IBackgroundContext context, MonthParams args)
        {
            var dateBegin = args.DateBegin;
            var dateEnd = args.DateEnd;
            var miacCode = args.LpuCode;

            using (var dataConext = new VistaMedDataContext(context))
            {
                var ddrDataContext = new DdrDataContext();

                ddrDataContext.dataConext = dataConext;
                ddrDataContext.context = context;
                ddrDataContext.dateEnd = dateEnd;
                ddrDataContext.dateBegin = dateBegin;
                ddrDataContext.LpuCode = miacCode;

                var templateFileName = @"SvodDdr.xls";
                var templateName = Utils.GetReportFileName(templateFileName);
                if (File.Exists(templateName))
                {
                    var excel = new Application();
                    excel.Visible = true;

                    ddrDataContext.planDd = PlanDd.LoadPlanDd(excel, context);

                    var newDoc = excel.Workbooks.Add(templateName);
                    ddrDataContext.newDoc = newDoc;

                    excel.ScreenUpdating = false;

                    var lpu = dataConext.VistaMed.Organisations.FirstOrDefault(x => x.MiacCode == miacCode);
                    if (lpu != null)
                    {
                        ddrDataContext.LpuId = lpu.Id;
                        newDoc.Names.Item("ЛПУ").RefersToRange.Value2 = lpu.FullName;
                        newDoc.Names.Item("Адрес").RefersToRange.Value2 = lpu.Address;
                    }

                    SvodDdr1000.Fill1000(ddrDataContext);
                    SvodDdr2000.Fill2000(ddrDataContext);
                    SvodDdr3000.Fill3000(ddrDataContext);
                    SvodDdr4000.Fill4000(ddrDataContext);
                    SvodDdr5000.Fill5000(ddrDataContext);
                    SvodDdr6000.Fill6000(ddrDataContext);
                    SvodDdr7000.Fill7000(ddrDataContext);

                    excel.ScreenUpdating = true;
                }
            }
            context.ReportProgress(@"Формирование отчета закончено");
            context.ProgressSeparator('-');
        }
コード例 #3
0
        /// <summary>
        /// Заполнение формы контроля
        /// </summary>
        /// <param name="context"></param>
        /// <param name="args"></param>
        /// <param name="methodCaption"></param>
        /// <param name="fillAction"></param>
        private static void fillAccountCheckPlan(IBackgroundContext context,
            MonthParams args, string methodCaption,
            Action<PageType, Worksheet, MonthParams> fillAction)
        {
            context.ProgressSeparator();
            context.ReportProgress(methodCaption);
            context.ProgressSeparator();

            string templateName = Path.Combine(Path.GetFullPath(@".\"),
                string.Format(@"AccountCheckPlan{0}.xls", args.DateEnd.Year));

            if (File.Exists(templateName))
            {
                var excel = new Application();
                excel.Visible = true;
                Workbook newDoc = excel.Workbooks.Add(templateName);
                newDoc.Names.Item(@"Период").RefersToRange.Value2 = Utils.GetPeriodName(args.DateBegin, args.DateEnd);
                newDoc.Names.Item(@"КоличествоМесяцев").RefersToRange.Value2 = args.DateEnd.Month;
                excel.ScreenUpdating = false;
                using (var dataContext = new VistaMedDataContext(context))
                {
                    dataContext.VistaMed.Connection.Open();

                    try
                    {
                        List<PageType> pageTypes = (new PageType[]
                            {
                                new Polyclinic(context, dataContext),
                                new Stacionar(context, dataContext),
                                new Ambulance(context, dataContext)
                            }).ToList();

                        foreach (Worksheet ws in newDoc.Worksheets.Cast<Worksheet>())
                        {
                            pageTypes.ForEach(x => fillAction(x, ws, args));
                        }

                    }
                    finally
                    {
                        dataContext.VistaMed.Connection.Close();
                    }
                }
                excel.ScreenUpdating = true;
            }
            else
                context.ReportError(@"Не найден файл {0}", templateName);

            context.ProgressSeparator('-');
        }
コード例 #4
0
        public static void SetBillNumbers(IBackgroundContext context, BillsEnumeratorParams args)
        {
            if (!(args.UseBillDate || args.UseCreateDate))
                return;

            context.ProgressSeparator();
            context.ReportProgress(@"ПРОСТАНОВКА НОМЕРОВ СЧЕТОВ");
            context.ReportProgress("");

            using (var dataContext = new VistaMedDataContext(context))
            {
                if (context.CancellationPending) return;

                var sqlText = string.Format(@"SELECT
                    a.id AS Id,
                    a.number AS Number,
                    a.amount AS Amount,
                    a.sum AS Summa,
                    a.settleDate AS BillDate,
                    a.date AS CreateDate,
                    o.miacCode AS SmoCode,
                    o.shortName AS SmoName,
                    IF(DATE_ADD(a.settleDate, INTERVAL 1 MONTH)  < a.date, 1, 0) AS IsDop,
                    MAX(et.code) AS MaxEtCode
                    FROM Account a
                    JOIN Contract c ON a.contract_id = c.id
                    JOIN rbFinance f ON c.finance_id = f.id
                    JOIN Organisation o ON c.payer_id = o.id
                    JOIN Account_Item ai ON a.id = ai.master_id
                    JOIN Event e ON ai.event_id = e.id
                    JOIN EventType et ON e.eventType_id = et.id
                    WHERE a.deleted = 0 AND ai.deleted = 0 AND e.deleted = 0 AND f.name LIKE 'омс'
                    AND ('{0}' = '0' OR a.settleDate = '{1}')
                    AND ('{2}' = '0' OR a.date = '{3}')
                    AND a.number NOT LIKE '%перевыпол%'
                    GROUP BY 1",
                    args.UseBillDate ? 1 : 0,
                    args.BillDate.SqlStr(),
                    args.UseCreateDate ? 1 : 0,
                    args.CreateDate.SqlStr());

                var billData = dataContext.VistaMed.SelectSqlData<AccountData>(sqlText).
                    OrderByDescending(x => x.IsDop).ThenBy(x => x.SmoIndex).
                    ThenBy(x => x.TypeIndex).ThenBy(x => x.Id).ToList();

                assignBillNumbers(context, dataContext, billData);

            }
            context.ProgressSeparator('-');
        }
コード例 #5
0
        public override void SetDataSource(object source)
        {
            var list = new List<EventCreatorPerson> {new EventCreatorPerson {Id = 0, Name = ""}};

            using (var dataContext = new VistaMedDataContext(null))
            {
                var allPersons = dataContext.VistaMed.People.Where(c => !c.Deleted && c.RetireDate == null).ToList();
                list.AddRange((from c in allPersons
                    select new EventCreatorPerson {Id = c.Id, Name = string.Format(@"{0} ({1})", c.FIO, c.Code)})
                    .OrderBy(x => x.Name).ToList());
            }

            eventCreatorPersonBindingSource.DataSource = list;

            base.SetDataSource(source);
        }
コード例 #6
0
        private static void verifyMkb(IBackgroundContext context, PrevalidatorParams args, VistaMedDataContext dataContext)
        {
            if (context.CancellationPending) return;

            context.ReportProgress(@"Проверка на пустые МКБ");
            var emptyMkbActions = (from action in dataContext.VistaMed.ActionsNotInAccount
                                  where action.EndDate >= args.DateBegin && action.EndDate <= args.DateEnd
                                        && action.Event != null && action.Event.EventType != null
                                        && action.Event.EventType.Name.ToLower().Contains(@"стоматология")
                                        && action.MKB == null
                                  select action).ToList();
            if (emptyMkbActions.Any())
            {
                context.ReportError(@"Неопределенный МКБ для услуг");
                foreach (var action in emptyMkbActions)
                {
                    context.ReportProgress(@"    > {0} {1}", action.Event, action.ToShortString());
                    if (context.CancellationPending) return;
                }
            }

            if (context.CancellationPending) return;
            var emptyMkbDs = from d in dataContext.VistaMed.Diagnoses
                             from ds in dataContext.VistaMed.Diagnostics
                             where (d.MKB == null || string.IsNullOrEmpty(d.MKB))
                                   && ds.DiagnosisId == d.Id
                                   && ds.Event != null && ds.Event.ExecDate >= args.DateBegin &&
                                   ds.Event.ExecDate <= args.DateEnd
                                   && !dataContext.VistaMed.AccountItems.Any(x => x.EventId == ds.EventId)
                             select ds.Event;
            if (emptyMkbDs.Any())
            {
                context.ReportError(@"Неопределенный МКБ для диагнозов");
                foreach (var dsEvent in emptyMkbDs)
                {
                    context.ReportProgress(@"    > {0}", dsEvent);
                    if (context.CancellationPending) return;
                }
            }

            var unknownMkbActions = (from action in dataContext.VistaMed.ActionsNotInAccount
                                   where action.EndDate >= args.DateBegin && action.EndDate <= args.DateEnd
                                         && action.Event != null && action.Event.EventType != null
                                         && !string.IsNullOrEmpty(action.MKB)
                                         && !(from m in dataContext.VistaMed.MKBs where action.MKB == m.DiagID select m).Any()
                                   select action).ToList();

            if (context.CancellationPending) return;
            if (unknownMkbActions.Any())
            {
                context.ReportError(@"Несуществующий МКБ");
                foreach (var action in unknownMkbActions)
                {
                    context.ReportProgress(@"    > {0} {1}", action.Event, action.ToShortString());
                    if (context.CancellationPending) return;
                }
            }
        }
コード例 #7
0
        private static void assignBillNumbers(IBackgroundContext context, VistaMedDataContext dataContext,
            List<AccountData> billData)
        {
            if (billData.Any())
            {
                var fileName = Path.GetFullPath(Settings.Default.BillsListFileName);
                var excel = new Application();
                excel.Visible = true;
                var wb = excel.Workbooks.Open(fileName);
                try
                {
                    var groupKey = "";
                    var billIndexInGroup = 1;
                    foreach (var bill in billData)
                    {
                        if (groupKey != bill.Name)
                        {
                            groupKey = bill.Name;
                            billIndexInGroup = 1;
                        }
                        var billKey = bill.Name + " " + billIndexInGroup;

                        var year = bill.BillDate.ToString("yyyy");
                        var ws = wb.Worksheets.Cast<Worksheet>().FirstOrDefault(x => x.Name == year);
                        if (ws != null)
                        {

                            Range keyColumnRange = ws.UsedRange.Columns[6];
                            Range foundCell = keyColumnRange.Find(billKey);
                            if (foundCell == null)
                            {
                                int lastNum = 0;
                                Range numColumn = ws.UsedRange.Columns[1];
                                for (int i = numColumn.Cells.Count; i >=1 ; i--)
                                {
                                    var numCell = numColumn.Cells[i, 1];
                                    var numVal = numCell.Value2;
                                    if (numVal != null)
                                       if ( int.TryParse(numVal.ToString(), out lastNum))
                                           break;
                                }
                                lastNum++;

                                var newRowIndex = ws.UsedRange.Rows.Count + 1;
                                var colIndex = 1;
                                ws.Cells.SetCellValue(newRowIndex, colIndex++, lastNum);
                                ws.Cells.SetCellValue(newRowIndex, colIndex++, bill.CreateDate);
                                ws.Cells.SetCellValue(newRowIndex, colIndex++, bill.Name
                                    + (billIndexInGroup == 1 ? "" : " #" + billIndexInGroup));
                                ws.Cells.SetCellValue(newRowIndex, colIndex++, bill.Amount);
                                ws.Cells.SetCellValue(newRowIndex, colIndex++, bill.Summa);
                                ws.Cells.SetCellValue(newRowIndex, colIndex++, billKey);

                                dataContext.VistaMed.ExecuteSql(
                                    string.Format(@"UPDATE Account SET number = '{0}' WHERE id = {1}",
                                    lastNum, bill.Id));
                            }

                        }
                        else
                            context.ReportError(@"Не найден лист {0}", year);

                        billIndexInGroup++;
                    }
                    wb.Save();
                }
                finally
                {
                    dataContext.VistaMed.SubmitChanges();
                    excel.Quit();
                }
            }
            else
            {
                context.ReportError(@"Счета не найдены");
            }
        }
コード例 #8
0
        private static void verifyPolicies(IBackgroundContext context, VistaMedDataContext dataContext, List<Event> allEvents)
        {
            context.ReportProgress(@"Проверка длины номера полисов ...");

            var errors = new List<string>();

            var policies = (from e in allEvents
                            where e.Client != null
                            select e.Client.GetActivePolicy(dataContext.VistaMed)).Distinct()
                            .Where(x => x != null).ToList();

            var errPol9 = (from p in policies
                where p.RbPolicyKind != null
                      && p.RbPolicyKind.FederalCode == "2"
                      && !string.IsNullOrEmpty(p.Number)
                      && p.Number.Length != 9
                select p).ToList();

            if (errPol9.Count > 0)
            {
                errors.Add(string.Format(@"ВРЕМЕННЫЕ СВИДЕТЕЛЬСТВА С НЕВЕРНОЙ ДЛИНОЙ НОМЕРА (НЕОБХОДИМО 9 СИМВОЛОВ)"));
                foreach (var clientPolicy in errPol9)
                {
            #if NOPERSONALDATA
                    var policyNumber = clientPolicy.Number.OfChar('N');
            #else
                    var policyNumber = clientPolicy.Number;
            #endif

                    errors.Add(string.Format(@"    {0} номер {1} длина номера {2}",
                        clientPolicy.Client.CardMarker, policyNumber, clientPolicy.Number.Length));
                }
            }

            var errPol16 = (from p in policies
                            where p.RbPolicyKind != null
                                 && p.RbPolicyKind.FederalCode == "3"
                                 && !string.IsNullOrEmpty(p.Number)
                                 && p.Number.Length != 16
                           select p).ToList();

            if (errPol16.Count > 0)
            {
                errors.Add(string.Format(@"ПОЛИСЫ НОВОГО ОБРАЗЦА С НЕВЕРНОЙ ДЛИНОЙ НОМЕРА (НЕОБХОДИМО 16 СИМВОЛОВ)"));
                foreach (var clientPolicy in errPol16)
                {
            #if NOPERSONALDATA
                    var policyNumber = clientPolicy.Number.OfChar('N');
            #else
                    var policyNumber = clientPolicy.Number;
            #endif
                    errors.Add(string.Format(@"    {0} номер {1} длина номера {2}",
                       clientPolicy.Client.CardMarker, policyNumber, clientPolicy.Number.Length));
                }
            }

            if (errors.Count > 0 && !context.CancellationPending)
            {
                context.ReportError("ПРОВЕРКА ДЛИНЫ НОМЕРОВ ПОЛИСОВ");
                errors.ForEach(x => context.ReportProgress(@"    -> {0}", x));
            }

            errors.Clear();

            var errPolType = (from p in policies
                            where p.RbPolicyKind != null
                            && !(p.RbPolicyKind.FederalCode == "1" || p.RbPolicyKind.FederalCode == "2" || p.RbPolicyKind.FederalCode == "3")
                            select p).ToList();

            if (errPolType.Count > 0)
            {
                errors.Add(string.Format(@"ПОЛИСЫ ОШИБОЧНОГО ВИДА"));
                foreach (var clientPolicy in errPolType)
                {
            #if NOPERSONALDATA
                    var policyNumber = clientPolicy.Number.OfChar('N');
            #else
                    var policyNumber = clientPolicy.Number;
            #endif
                    errors.Add(string.Format(@"    {0} код вида {1} вид '{2}'",
                       clientPolicy.Client.CardMarker, clientPolicy.RbPolicyKind.FederalCode, clientPolicy.RbPolicyKind.Name));
                }
            }

            if (errors.Count > 0 && !context.CancellationPending)
            {
                errors.ForEach(x => context.ReportProgress(@"    -> {0}", x));
            }
        }
コード例 #9
0
        public static void BuildSvedReport(IBackgroundContext context, MonthAccountParams args)
        {
            var dateBegin = args.DateBegin;
            var dateEnd = args.DateEnd;
            var miacCode = args.LpuCode;
            using (var dataConext = new VistaMedDataContext(context))
            {
                var smpBills = (from b in dataConext.VistaMed.Accounts
                                where b.Date >= args.DateBegin.AddDays(15) && b.Date < args.NextMonthBegin.AddDays(15)
                                && b.Contract != null && b.Contract.RbFinance != null
                                && b.Contract.RbFinance.Name.ToLower() == "омс"
                                    && (from a in b.AccountItems
                                        from s in dataConext.VistaMed.RbServices
                                        where a.ServiceId == s.Id
                                        && s.Code.StartsWith("062")
                                        select a).Any()
                                select b).ToList();

                smpBills = smpBills.Where(x => x.AccountType == AccountType.ProfOsm).ToList();
                smpBills = smpBills.Where(x => args.IsValidAccountNumber(x.Number)).ToList();

                if (smpBills.Count == 0)
                    context.ReportError(@"Счета ДД за период с {0} по {1} не найдены", dateBegin, dateEnd);
                else
                {
                    var templateName = Utils.GetReportFileName(@"SvodSpravProf.xls");
                    if (File.Exists(templateName))
                    {
                        var excel = new Application();
                        excel.Visible = true;

                        foreach (var smpBill in smpBills)
                        {
                            var newDoc = excel.Workbooks.Add(templateName);
                            excel.ScreenUpdating = false;

                            var ws = ((Worksheet)newDoc.Worksheets[1]);
                            newDoc.Names.Item(@"ОтчетныйПериод").RefersToRange.Value2 =
                                Utils.GetPeriodName(smpBill.SettleDate.BeginOfMonth(), smpBill.SettleDate);

                            var lpu = dataConext.VistaMed.Organisations.FirstOrDefault(x => x.MiacCode == miacCode);
                            if (lpu != null)
                            {
                                newDoc.Names.Item("ЛПУ").RefersToRange.Value2 = lpu.FullName;
                                newDoc.Names.Item("ФИОРуководителя").RefersToRange.Value2 = lpu.Chief;
                                newDoc.Names.Item("ФИОГлавбуха").RefersToRange.Value2 = lpu.Accountant;
                            }

                            var smo =
                                (from payer in dataConext.VistaMed.Organisations
                                 where payer.Id == smpBill.PayerId
                                 select payer).FirstOrDefault();
                            if (smo != null)
                            {
                                newDoc.Names.Item("СМО").RefersToRange.Value2 = smo.FullName;
                            }

                            ReportData colData;

                            var eventList = (from a in smpBill.AccountItems
                                             where !a.Deleted && a.Event != null && a.Event.RbResult != null && a.Action != null && a.Action.ActionType != null
                                             group a by a.Event into e
                                             select e).ToList();

                            colData = new ReportData();
                            colData.Prof = eventList.Count;

                            fillColumn(ws, colData, 2);

                            colData = new ReportData();
                            colData.Prof = (from e in eventList from a in e select a).Sum(x => x.Sum);

                            fillColumn(ws, colData, 3);

                            excel.ScreenUpdating = true;
                            ws.Activate();

                        }
                    }
                }
            }
            context.ProgressSeparator('-');
        }
コード例 #10
0
 public Ambulance(IBackgroundContext context, VistaMedDataContext dataContext)
     : base(context, dataContext)
 {
 }
コード例 #11
0
        private static void verifyKolUsl(IBackgroundContext context, List<Action> allActions, VistaMedDataContext dataContext)
        {
            var errorActions = (from a in allActions where Math.Abs(a.Amount - 0) < 0.00001 && a.Event != null
                                    && a.Event.EventType != null
                                    && !a.Event.EventType.Code.StartsWith("dd2013") select a).ToList();

            if(errorActions.Any())
            {
                context.ReportError(@"МЕРОПРИЯТИЯ С НУЛЕВЫМ КОЛИЧЕСТВОМ");
                foreach (var errorAction in errorActions)
                {
                    context.ReportProgress(@"  {0}", errorAction.Event, errorAction);
                    context.ReportProgress(@"    {0}", errorAction);
                }
            }
        }
コード例 #12
0
        /// <summary>
        /// Заполняем сведения о выполнении заказ-задания
        /// </summary>
        /// <param name="context"></param>
        /// <param name="args"></param>
        public static void FillFomsReport(IBackgroundContext context, AccountCorrectParams args)
        {
            context.ProgressSeparator();
            context.ReportProgress(@"ФОРМИРОВАНИЕ СВЕДЕНИЙ О ВЫПОЛНЕНИИ ЗАКАЗ-ЗАДАНИЯ");
            context.ProgressSeparator();

            // книга планов
            var excelFileName = args.AccountCheckPlanFileName;
            if (File.Exists(excelFileName))
            {
                var excel = new Application();
                excel.Visible = true;

                var reportData = getFomsReportData(context, args, excelFileName, excel);

                if (reportData.Count > 0)
                {

                    excel.ScreenUpdating = false;
                    using (var dataContext = new VistaMedDataContext(context))
                    {
                        dataContext.VistaMed.Connection.Open();

                        var templateName = Path.Combine(Path.GetFullPath(@".\"), @"AccountFomsReport.xls");

                        Workbook newDoc = excel.Workbooks.Add(templateName);
                        newDoc.Names.Item(@"Период").RefersToRange.Value2 =
                            Utils.GetPeriodName(args.DateBegin, args.DateEnd);

                        var lpu = dataContext.VistaMed.Organisations.FirstOrDefault(x => x.MiacCode == args.LpuCode);
                        if (lpu != null)
                        {
                            newDoc.Names.Item("ЛПУ").RefersToRange.Value2 = lpu.FullName;
                            newDoc.Names.Item("ФИОРуководителя").RefersToRange.Value2 = lpu.Chief;
                            //newDoc.Names.Item("ФИОГлавбуха").RefersToRange.Value2 = lpu.Accountant;
                        }

                        try
                        {
                            var ws = (Worksheet)newDoc.Worksheets[1];
                            for (int rowIndex = 8; rowIndex < 19; rowIndex++)
                            {
                                var row = (Range)ws.Rows[rowIndex];
                                var rowName = row.GetCellValue<string>(1, 1);
                                var smoCode = row.GetCellValue<string>(1, 8);
                                if (!string.IsNullOrEmpty(smoCode))
                                {
                                    var rowDataType = (rowName.StartsWith("Плановое")
                                        ? FomsReportRowType.Plan
                                        : FomsReportRowType.Fact);

                                    var rowData = reportData.FirstOrDefault(x => x.SmoCode == smoCode
                                                                                 && x.RowType == rowDataType);

                                    if (rowData != null)
                                    {
                                        var colIndex = 2;
                                        row.SetCellValue(1, colIndex++, rowData.StacFullCount + rowData.StacApuCount);
                                        row.SetCellValue(1, colIndex++, rowData.StacDayCount);
                                        row.SetCellValue(1, colIndex++, rowData.EmergencyCount);
                                        row.SetCellValue(1, colIndex++, rowData.TreatmentCount);
                                        row.SetCellValue(1, colIndex++, rowData.VisitCount + rowData.ProfilacticCount);
                                        row.SetCellValue(1, colIndex++, rowData.AmbulanceCount);
                                    }

                                }
                            }
                        }
                        finally
                        {
                            dataContext.VistaMed.Connection.Close();
                        }
                    }
                    excel.ScreenUpdating = true;
                }
            }
            else
                context.ReportError(@"Файл {0} не найден", excelFileName);

            context.ProgressSeparator('-');
        }
コード例 #13
0
        private static void verifyStationarLittleStrangerFlag(IBackgroundContext context, List<Event> allEvents, VistaMedDataContext dataContext)
        {
            var littleStrangerEvents = (from e in allEvents where e.LittleStrangerId != null select e).ToList();

            var errorEvents = from e in littleStrangerEvents
                              from d in e.Diagnostics
                              where d.Diagnosis != null && d.Diagnosis.MKB.StartsWith("O")
                              select new { Event = e, Mkb = d.Diagnosis.MKB};

            var errors = new List<string>();

            foreach (var badItem in errorEvents)
            {
                errors.Add(string.Format(@"{0}. Диагноз {1} для новорожденного. Уберите флаг новорожденного в талоне.",
                    badItem.Event, badItem.Mkb));
            }

            if (errors.Count > 0)
            {
                context.ReportError(@"СТАЦИОНАР: Недопустимые диагнозы для новорожденных");
                errors.ForEach(x => context.ReportProgress(@"    -> {0}", x));
            }
        }
コード例 #14
0
        private static void verifyStationar(IBackgroundContext context, List<Event> allEvents, VistaMedDataContext dataContext, List<Action> allActions)
        {
            if (context.CancellationPending) return;

            context.ReportProgress(@"Проверка талонов стационара");

            // тип мероприятия - "Движение"
            var moveActType =
                (from c in dataContext.VistaMed.ActionTypes where c.Name == "Движение" && c.Code == "2" select c)
                .FirstOrDefault();

            // тип свойства - "койка"
            var bedPropType = (from c in moveActType.ActionPropertyTypes
                               where !c.Deleted && c.Name == "койка" && c.TypeName == "HospitalBed"
                               select c).FirstOrDefault();

            verifyStationarBedProfile(context, allEvents, dataContext, moveActType, bedPropType, "Стационарная помощь");
            verifyStationarBedProfile(context, allEvents, dataContext, moveActType, bedPropType, "Дневной стационар");

            verifyStationarPeriods(context, allEvents, dataContext, moveActType);

            verifyStationarMovePerson(context, allActions, dataContext, moveActType);
            verifyStationarLittleStrangerFlag(context, allEvents, dataContext);
        }
コード例 #15
0
ファイル: ReestrDd.cs プロジェクト: vvboborykin/VistaMedTools
        private static void afterFill(IBackgroundContext context, ReestrDdParams args, VistaMedDataContext dataConext,
            Account smpBill, Workbook newDoc, List<ReestrTotals> totals, List<IGrouping<Event, AccountItem>> eventGroups, List<ErrorZeroSum> errors, List<string> zeroFioList)
        {
            var insurer = (from o in dataConext.VistaMed.Organisations
                where o.Id == smpBill.Contract.PayerId
                select o).FirstOrDefault();

            if (insurer != null)
            {
                string insurerName = "";
                if (insurer.MiacCode == "67002")
                    insurerName = "СОГАЗ";
                else if (insurer.MiacCode == "67003")
                    insurerName = "МАКС";
                else if (insurer.MiacCode == "67004")
                    insurerName = "РГС";
                else if (insurer.MiacCode == "67005")
                    insurerName = "СПВ";
                if (string.IsNullOrEmpty(insurerName))
                {
                    insurerName = new string(insurer.ShortName.ToArray()
                        .Except(Path.GetInvalidFileNameChars()).ToArray());
                }

                saveReport(context, args, insurerName, smpBill, newDoc);
                totals.Add(new ReestrTotals()
                {
                    AccountType = smpBill.AccountType,
                    InsurerName = insurerName,
                    Kol = eventGroups.Count
                });
                errors.AddRange(zeroFioList.Select(x =>
                    new ErrorZeroSum() {AccountType = smpBill.AccountType, Fio = x, Insurer = insurerName}));
            }
        }
コード例 #16
0
        private static void verifyContracts(IBackgroundContext context, PrevalidatorParams prevalidatorParams, VistaMedDataContext dataContext)
        {
            if (context.CancellationPending) return;

            var errors = (from a in dataContext.VistaMed.Actions
                          let e = a.Event
                          where e.ExecDate != null && e.Contract != null
                                && e.ExecDate >= prevalidatorParams.DateBegin
                                && e.ExecDate <= prevalidatorParams.DateEnd
                                && !dataContext.VistaMed.AccountItems.Any(x => x.EventId == e.Id)
                                && a.Contract != null && a.Contract != e.Contract
                          select new {Event = e, Action = a}).ToList();

            var invalidGroups = (from s in errors group s by s.Event into g select g).ToList();
            if (invalidGroups.Any())
            {
                context.ReportError(@"Несовпадение договора в талоне и услугах");
                foreach (var invalidGroup in invalidGroups)
                {
                    context.ReportProgress(@"    > {0}", invalidGroup.Key);
                    context.ReportProgress(@"    > договор события {0}",
                                           invalidGroup.Key.Contract.GetFullName(dataContext.VistaMed));

                    foreach (var action in invalidGroup.Select(x => x.Action))
                    {
                        var actionStr = (action.ActionType == null ? "" : action.ActionType.Code);
                        context.ReportProgress(@"    > договор мероприятия {0} {1}",
                                               actionStr, action.Contract.GetFullName(dataContext.VistaMed));
                    }
                }
            }
        }
コード例 #17
0
        private static void verifyStationarPeriods(IBackgroundContext context, List<Event> allEvents, VistaMedDataContext dataContext, ActionType moveActType)
        {
            var stationarEvents = from e in allEvents
                                  where e.EventType.RbMedicalAidType != null
                                  && e.EventType.RbMedicalAidType.Name != null
                                  && e.EventType.RbMedicalAidType.Name.ToLower().Contains("стационар")
                                  && !e.EventType.RbMedicalAidType.Name.ToLower().Contains("дневной")
                                  select e;

            var moveActions = from e in stationarEvents
                              from c in e.Actions
                              where !c.Deleted && c.ActionType == moveActType
                              select c;

            var errors = new List<string>();

            foreach (var moveAction in moveActions.TakeWhile(x => !context.CancellationPending))
            {
                var dateRange = new DateRange(moveAction.BegDate, moveAction.EndDate);

                var client = moveAction.Event.Client;
                var clientActions = (from e in allEvents where e.Client == client && e != moveAction.Event select e).ToList();

                var theEvents = (from a in clientActions let dr = new DateRange(a.SetDate, a.ExecDate)
                                   where dr.Intersects(dateRange)
                                   && (dr.EndDate != dateRange.StartDate)
                                   && (dr.EndDate != dateRange.EndDate)
                                   select a).ToList();

                if (theEvents.Any())
                {
                    errors.Add(string.Format(@"СТАЦИОНАР.ТАЛОН '{0}'", moveAction.Event));
                    errors.Add(string.Format(@"  ДВИЖЕНИЕ '{0}'", moveAction));
                    foreach (var theEvent in theEvents)
                    {
                        errors.Add(string.Format(@"    Пересечение периодов '{0}'", theEvent));
                    }
                }
            }

            if (errors.Count > 0 && !context.CancellationPending)
            {
                context.ReportError(@"""{0}""", "ПЕРЕСЕЧЕНИЕ ПЕРИОДОВ");
                errors.ForEach(x => context.ReportProgress(@"    -> {0}", x));
            }
        }
コード例 #18
0
        private static void verifyStationarMovePerson(IBackgroundContext context, List<Action> allActions, 
            VistaMedDataContext dataContext, ActionType moveActType)
        {
            var badMoveActions = (from c in allActions
                                  where c.ActionType == moveActType
                                        && c.Person_SetPersonId != c.Event.Person_ExecPersonId
                                  select c).ToList();

            var errors = new List<string>();

            foreach (var badAction in badMoveActions)
            {
                errors.Add(string.Format(@"{0}. Исполнитель в мероприятии ""{1}"" а в талоне ""{2}""", badAction.Event,
                    badAction.Person_PersonId == null ? "не задан" : badAction.Person_PersonId.FIO,
                    badAction.Event.Person_ExecPersonId == null ? "не задан" : badAction.Event.Person_ExecPersonId.FIO));
            }

            if (errors.Count > 0)
            {
                context.ReportError(@"СТАЦИОНАР: МЕРОПРИЯТИЯ ДВИЖЕНИЯ С НЕВЕРНЫМ ИСПОЛНИТЕЛЕМ");
                errors.ForEach(x => context.ReportProgress(@"    -> {0}", x));
            }
        }
コード例 #19
0
ファイル: SvedProf.cs プロジェクト: vvboborykin/VistaMedTools
        public static void BuildSvedProf(IBackgroundContext context, MonthAccountParams args)
        {
            var dateBegin = args.DateBegin;
            var dateEnd = args.DateEnd;
            var miacCode = args.LpuCode;
            using (var dataConext = new VistaMedDataContext(context))
            {
                var smpBills = (from b in dataConext.VistaMed.Accounts
                                where b.Date >= args.DateBegin.AddDays(15) && b.Date < args.NextMonthBegin.AddDays(15)
                                && b.Contract != null && b.Contract.RbFinance != null
                                && b.Contract.RbFinance.Name.ToLower() == "омс"
                                    && (from a in b.AccountItems
                                        from s in dataConext.VistaMed.RbServices
                                        where a.ServiceId == s.Id
                                        && s.Code.StartsWith("062")
                                        select a).Any()
                                select b).ToList();

                smpBills = smpBills.Where(x => args.IsValidAccountNumber(x.Number)
                    && !x.Number.StartsWith(PlanExecution.ReserveAccountName)).ToList();

               if (smpBills.Count == 0)
                    context.ReportError(@"Счета ДД за период с {0} по {1} не найдены", dateBegin, dateEnd);
                else
                {
                    var excel = new Application();
                    excel.Visible = true;

                    var plans = loadPlans(excel);
                    var templateName = Utils.GetReportFileName(@"SvedProf.xls");

                    if (File.Exists(templateName))
                    {
                        var newDoc = excel.Workbooks.Add(templateName);
                        excel.ScreenUpdating = false;

                        var ws = ((Worksheet) newDoc.Worksheets[1]);
                        newDoc.Names.Item(@"ДатаНачала").RefersToRange.Value2 = dateBegin;
                        newDoc.Names.Item(@"ДатаКонца").RefersToRange.Value2 = dateEnd;
                        newDoc.Names.Item(@"ДатаОтчета").RefersToRange.Value2 = DateTime.Today;
                        newDoc.Names.Item(@"ОтчетныйПериод").RefersToRange.Value2 = Utils.GetPeriodName(dateBegin, dateEnd);

                        var lpu = dataConext.VistaMed.Organisations.FirstOrDefault(x => x.MiacCode == miacCode);
                        if (lpu != null)
                        {
                            newDoc.Names.Item("ЛПУ").RefersToRange.Value2 = lpu.FullName;
                            newDoc.Names.Item("ФИОРуководителя").RefersToRange.Value2 = lpu.Chief;
                            newDoc.Names.Item("ФИОГлавбуха").RefersToRange.Value2 = lpu.Accountant;
                        }

                        var reportColumn = new ReportColumn();
                        reportColumn.Man = plans.Sum(x => x.Man);
                        reportColumn.Woman = plans.Sum(x => x.Woman);
                        fillReportColumn(ws, reportColumn, 3);

                        reportColumn = new ReportColumn();
                        reportColumn.Man = plans.Where(y => y.Month == dateEnd.Month).Sum(x => x.Man);
                        reportColumn.Woman = plans.Where(y => y.Month == dateEnd.Month).Sum(x => x.Woman);
                        fillReportColumn(ws, reportColumn, 7);

                        var allevents = (from b in smpBills
                            from a in b.AccountItems
                            where !a.Deleted && a.Event != null && a.Event.Client != null
                            group a by a.Event
                            into e
                            select new {Event = e.Key, Client = e.Key.Client, Summa = e.Sum(x => x.Sum)}).ToList();

                        var man = (from e in allevents where e.Client.Sex == 1 select e).ToList();
                        var woman = (from e in allevents where e.Client.Sex == 2 select e).ToList();

                        reportColumn = new ReportColumn();
                        reportColumn.Man = man.Sum(x => x.Summa);
                        reportColumn.Woman = woman.Sum(x => x.Summa);
                        fillReportColumn(ws, reportColumn, 8);

                        reportColumn = new ReportColumn();
                        reportColumn.Man = man.Count();
                        reportColumn.Woman = woman.Count();
                        fillReportColumn(ws, reportColumn, 9);

                        excel.ScreenUpdating = true;
                        ws.Activate();
                    }
                }
            }
        }
コード例 #20
0
 public Stacionar(IBackgroundContext context, VistaMedDataContext dataContext)
     : base(context, dataContext)
 {
 }
コード例 #21
0
ファイル: ReestrDd.cs プロジェクト: vvboborykin/VistaMedTools
        public static void BuildReestrDd(IBackgroundContext context, ReestrDdParams args)
        {
            var dateBegin = args.DateBegin;
            var dateEnd = args.DateEnd;
            var miacCode = args.LpuCode;
            var billNum = args.AccountNumbers;
            using (var dataConext = new VistaMedDataContext(context))
            {
                var smpBills = (from b in dataConext.VistaMed.Accounts
                                where b.SettleDate >= dateBegin && b.SettleDate <= dateEnd && b.Date == args.CreateDate
                                && b.Contract != null && b.Contract.RbFinance != null
                                && b.Contract.RbFinance.Name.ToLower() == "омс"
                                    && (from a in b.AccountItems
                                        from s in dataConext.VistaMed.RbServices
                                        where a.ServiceId == s.Id
                                        && (s.Code.StartsWith("061") || s.Code.StartsWith("161")
                                        || s.Code.StartsWith("062") || s.Code.StartsWith("162"))
                                        select a).Any()
                                select b).ToList();

                if (!string.IsNullOrEmpty(billNum))
                {
                    var billNumList = billNum.Split(',');
                    smpBills = smpBills.Where(x => billNumList.Contains(x.Number)).ToList();
                }

                if (smpBills.Count == 0)
                    context.ReportError(@"Счета ДД за период с {0} по {1} не найдены", dateBegin, dateEnd);
                else
                {
                    var excel = new Application();
                    excel.Visible = true;

                    var totals = new List<ReestrTotals>();
                    var errors = new List<ErrorZeroSum>();

                    foreach (var smpBill in smpBills)
                    {
                        var templateFileName = @"ReestrDd.xls";
                        if (smpBill.AccountType == AccountType.DDR2)
                            templateFileName = @"ReestrDd2.xls";

                        var templateName = Utils.GetReportFileName(templateFileName);
                        var zeroFioList = new List<string>();

                        if (!File.Exists(templateName))
                            continue;

                        var newDoc = excel.Workbooks.Add(templateName);
                        excel.ScreenUpdating = false;

                        var ws = ((Worksheet)newDoc.Worksheets[1]);
                        newDoc.Names.Item(@"ДатаНачала").RefersToRange.Value2 = dateBegin;
                        newDoc.Names.Item(@"ДатаКонца").RefersToRange.Value2 = dateEnd;
                        newDoc.Names.Item(@"ДатаОтчета").RefersToRange.Value2 = DateTime.Today;

                        var lpu = dataConext.VistaMed.Organisations.FirstOrDefault(x => x.MiacCode == miacCode);
                        if (lpu != null)
                        {
                            newDoc.Names.Item("ЛПУ").RefersToRange.Value2 = lpu.FullName + " ОГРН " + lpu.OGRN ?? "";
                            newDoc.Names.Item("ФИОРуководителя").RefersToRange.Value2 = lpu.Chief;
                            newDoc.Names.Item("ФИОГлавбуха").RefersToRange.Value2 = lpu.Accountant;
                        }

                        var smo =
                            (from payer in dataConext.VistaMed.Organisations
                             where payer.Id == smpBill.PayerId
                             select payer).FirstOrDefault();
                        if (smo != null)
                        {
                            newDoc.Names.Item("СМО").RefersToRange.Value2 = smo.FullName;
                        }

                        newDoc.Names.Item("НомерСчета").RefersToRange.Value2 = smpBill.Number;
                        newDoc.Names.Item("ДатаСчета").RefersToRange.Value2 = smpBill.SettleDate;

                        string ddName = null;
                        string tarifHeader = null;
                        string header13 = null;

                        switch (smpBill.AccountType)
                        {
                            case AccountType.DdVet:
                                ddName = "в рамках первого этапа диспансеризации ветеранов ВОВ и инвалидов";
                                tarifHeader =
                                    "Тариф на плату первого этапа диспансеризации, проведенной застрахованному лицу";
                                header13 = "Первый этап диспансеризации в объеме, утвержденном Минздравом России, " +
                                           "специальность медицинского работника, проводящего диспансеризацию (код)";
                                break;
                            case AccountType.DDR1:
                                ddName = "в рамках первого этапа диспансеризации определенных групп взрослого населения";
                                tarifHeader =
                                    "Тариф на плату первого этапа диспансеризации, проведенной застрахованному лицу";
                                header13 = "Первый этап диспансеризации в объеме, утвержденном Минздравом России, " +
                                           "специальность медицинского работника, проводящего диспансеризацию (код)";
                                break;
                            case AccountType.DDR2:
                                ddName = "в рамках второго этапа диспансеризации определенных групп взрослого населения";
                                tarifHeader =
                                    "Стоимость второго этапа диспансеризации, проведенной застрахованному лицу";
                                header13 = "Второй этап диспансеризации в объеме, утвержденном Минздравом России, " +
                                           "специальность медицинского работника, проводящего диспансеризацию (код), " +
                                           "тариф на оплату второго этапа диспансеризации, проведенной застрахованному лицу";
                                break;
                            case AccountType.DDOrhan:
                                ddName =
                                    "в рамках  диспансеризации детей-сирот и детей, оставшихся без попечения родителей, " +
                                    "в том числе усыновленных (удочеренных), принятых под опеку (попечительство), " +
                                    "в приемную или патронатную семью";
                                header13 = "Диспансеризация в объеме утвержденном Минздравом России, " +
                                           "специальность медицинского работника, проводящего диспансеризацию (код)";
                                tarifHeader = "Тариф на оплату диспансеризации проведенной застрахованному лицу";
                                break;
                            case AccountType.DDHardLive:
                                ddName =
                                    "в рамках  диспансеризации детей сирот, пребывающих в стационарных учреждениях и детей, " +
                                    "находящихся в трудной жизненной ситуации";
                                header13 = "Диспансеризация в объеме утвержденном Минздравом России, " +
                                           "специальность медицинского работника, проводящего диспансеризацию (код)";
                                tarifHeader = "Тариф на оплату диспансеризации проведенной застрахованному лицу";
                                break;
                            case AccountType.DD14:
                                break;
                            case AccountType.Osm18:
                                ddName = "в рамках медицинских осмотров несовершеннолетних";
                                header13 =
                                    "Медицинские осмотры несовершеннолетних в объеме, утвержденном Минздравом России, " +
                                    "специальность медицинского работника, проводящего медицинские осмотры (код)";
                                tarifHeader = "Тариф на оплату медицинского осмотра проведенного застрахованному лицу";
                                break;
                            case AccountType.ProfOsm:
                                ddName = "за проведенные профилактические медицинские осмотры взрослого населения";
                                header13 = "Медицинские осмотры в объеме, утвержденном Минздравом России, " +
                                           "специальность медицинского работника, проводящего профилактический " +
                                           "медицинский осмотр (код)";
                                tarifHeader = "Тариф на оплату профилактических медицинских осмотров, " +
                                              "проведенных застрахованному лицу";
                                break;
                            default:
                                break;
                        }

                        if (!string.IsNullOrEmpty(ddName))
                            newDoc.Names.Item("НазваниеДД").RefersToRange.Value2 = ddName;
                        if (!string.IsNullOrEmpty(tarifHeader))
                            newDoc.Names.Item("ЗаголовокТарифа").RefersToRange.Value2 = tarifHeader;
                        if (!string.IsNullOrEmpty(header13))
                            newDoc.Names.Item("Кол13").RefersToRange.Value2 = header13;

                        var eventGroups = (from accItem in smpBill.AccountItems
                                           group accItem by accItem.Event
                                               into g
                                               orderby g.Key.Client.Fio
                                               select g).ToList();

                        foreach (var eventGroup in eventGroups)
                        {
                            ((Range)ws.Rows[14]).Insert();
                            ((Range)ws.Rows[15]).Copy(Destination: ((Range)ws.Rows[14]));
                        }

                        var rowIndex = 1;

                        foreach (var eventGroup in eventGroups)
                        {
                            var client = eventGroup.Key.Client;
                            if (client != null)
                            {
                                var newRow = ((Range)ws.Rows[rowIndex + 13]);

                                ((Range)newRow.Cells[1, 1]).Value2 = rowIndex;
                                ((Range)newRow.Cells[1, 2]).Value2 = client.Fio;

                                ((Range)newRow.Cells[1, 3]).Value2 = client.Sex == 1 ? "М" : "Ж";
                                ((Range)newRow.Cells[1, 4]).Value2 = client.BirthDate;

                                var clientDocId = dataConext.VistaMed.GetClientDocumentId(client.Id);
                                var clientDoc =
                                    (from c in dataConext.VistaMed.ClientDocuments
                                     where c.Id == clientDocId
                                     select c).FirstOrDefault();

                                if (clientDoc != null)
                                    ((Range)newRow.Cells[1, 6]).Value2 = clientDoc.Serial + " " + clientDoc.Number;

                                ((Range)newRow.Cells[1, 7]).Value2 = dataConext.VistaMed.GetClientLocAddress(client.Id);

                                var clientPolicyId = dataConext.VistaMed.GetClientPolicyId(client.Id, 1);
                                var clientPolicy =
                                    dataConext.VistaMed.ClientPolicies.FirstOrDefault(x => x.Id == clientPolicyId);

                                ((Range)newRow.Cells[1, 9]).Value2 = client.GetSnilsFormatted();

                                if (clientPolicy != null)
                                    ((Range)newRow.Cells[1, 10]).Value2 =
                                        (clientPolicy.Serial + " " + clientPolicy.Number).Trim();

                                ((Range)newRow.Cells[1, 11]).Value2 = "1";
                                var diagnosisId = dataConext.VistaMed.GetEventDiagnosis(eventGroup.Key.Id);
                                var mkb =
                                    (from d in dataConext.VistaMed.Diagnoses where d.Id == diagnosisId select d.MKB)
                                        .FirstOrDefault();
                                ((Range)newRow.Cells[1, 12]).Value2 = mkb ?? "";

                                var prnActions = (from item in eventGroup
                                                  where item.Action != null
                                                        &&
                                                        (item.Action.ActionType.Name.StartsWith(@"Комплексная услуга")
                                                        || item.Action.ActionType.Name.StartsWith(@"Комп. услуга")
                                                         || item.Action.ActionType.Name.StartsWith(@"Осмотр врача"))
                                                  select item).ToList();

                                ((Range)newRow.Cells[1, 13]).Value2 = string.Join(" ",
                                    prnActions.Select(x => x.Action.ActionType.Code));
                                ((Range)newRow.Cells[1, 14]).Value2 = string.Join(" ",
                                    prnActions.Select(x => x.Action.BegDate.Value.ToShortDateString()));
                                ((Range)newRow.Cells[1, 15]).Value2 = string.Join(" ",
                                    prnActions.Select(x => x.Action.EndDate.Value.ToShortDateString()));
                                ((Range)newRow.Cells[1, 16]).Value2 = string.Join(" ",
                                    prnActions.Select(
                                        x =>
                                            x.Action.Person_PersonId == null
                                                ? ""
                                                : x.Action.Person_PersonId.RbSpeciality.FederalCode.PadRight(15)));
                                var colIndex = 17;
                                if (smpBill.AccountType == AccountType.DDR2)
                                {
                                    ((Range)newRow.Cells[1, colIndex++]).Value2 = string.Join(" ",
                                        prnActions.Select(x => x.Sum.ToString(@"F2")));
                                }

                                var summa = eventGroup.Sum(x => x.Sum);

                                ((Range) newRow.Cells[1, colIndex++]).Value2 = summa;
                                ((Range)newRow.Cells[1, colIndex++]).Value2 = eventGroup.Key.RbResult.FederalCode;

                                if (Math.Abs(summa) < 0.01)
                                {
                                    zeroFioList.Add(eventGroup.Key.Client.Fio + " " + eventGroup.Key.Client.BirthDate.ToShortDateString());
                                }

                                rowIndex++;
                            }
                        }

                        var totalRow = ((Range)ws.Rows[rowIndex + 13]);
                        ((Range)totalRow.Cells[1, 2]).Value2 = @"ИТОГО";
                        ((Range)totalRow.Cells[1, 17 + (smpBill.AccountType == AccountType.DDR2 ? 1 : 0)]).Value2 = smpBill.Sum;

                        excel.ScreenUpdating = true;
                        ws.Activate();

                        afterFill(context, args, dataConext, smpBill, newDoc, totals, eventGroups, errors, zeroFioList);
                    }

                    generateTotals(excel, totals, errors, args, context);
                }
            }
        }
コード例 #22
0
        private static void verifyStationarBedProfile(IBackgroundContext context, 
            List<Event> allEvents, 
            VistaMedDataContext dataContext, ActionType moveActType,
            ActionPropertyType bedPropType, string eventKindName)
        {
            var eventTypes = from c in dataContext.VistaMed.EventTypes
                             where c.RbMedicalAidType != null
                                   && c.RbMedicalAidType.Name == eventKindName
                             select c;

            var stationarEvents = from e in allEvents
                                  where eventTypes.Contains(e.EventType)
                                  select e;

            // мероприятия "Движение"
            var moveActions = from e in stationarEvents
                              from c in e.Actions
                              where !c.Deleted && c.ActionType == moveActType
                              select new {Event = e, Action = c};

            // выборка свойств "койка"
            var actProp = from c in moveActions
                          from p in c.Action.ActionProperties
                          where p.ActionPropertyType == bedPropType && !p.Deleted
                          select new { Event = c.Event, Action = c.Action, BedProp = p };

            // выборка значений "койка"
            var actBed = (from c in actProp
                          join bedTypedProp in dataContext.VistaMed.ActionPropertyHospitalBeds on c.BedProp.Id equals bedTypedProp.Id
                          select new { c.Event, c.Action, Bed = bedTypedProp.OrgStructureHospitalBed }).ToList();

            Func<RbHospitalBedProfile, bool> comparator;
            if(eventKindName.Contains("Дневной"))
                comparator = x => x.Name.Contains(" ДС");
            else
                comparator = x => !x.Name.Contains(" ДС");

            var wrongBeds = from c in actBed
                           where c.Bed.RbHospitalBedProfile != null && !comparator(c.Bed.RbHospitalBedProfile)
                           select c;

            var errors = new List<string>();

            foreach (var wrongBed in wrongBeds)
            {
                errors.Add(string.Format(@"{0}. Неверный тип койки {1}", wrongBed.Event,
                    wrongBed.Bed.RbHospitalBedProfile.Name));
            }

            if (errors.Count > 0)
            {
                context.ReportError(@"""{0}""", eventKindName);
                errors.ForEach(x => context.ReportProgress(@"    -> {0}", x));
            }
        }
コード例 #23
0
        private static List<FomsReportRowData> getFomsReportData(IBackgroundContext context, AccountCorrectParams args, string excelFileName,
            Application excel)
        {
            var result = new List<FomsReportRowData>();

            Workbook newDoc;
            try
            {
                context.ReportProgress(@"Открываем файл {0} ...", excelFileName);
                newDoc = excel.Workbooks.Open(excelFileName);
            }
            catch (Exception exception)
            {
                newDoc = null;
                context.ReportError(@"Ошибка открытия файла {0} : {1}", excelFileName, exception.Message);
            }

            if (newDoc != null)
            {
                // ищем имя КоличествоМесяцев
                var kolMonthExists = false;
                for (int i = 1; i <= newDoc.Names.Count; i++)
                {
                    if (newDoc.Names.Item(i).Name == @"КоличествоМесяцев")
                    {
                        kolMonthExists = true;
                        break;
                    }
                }

                if (kolMonthExists)
                {
                    // сравниваем КоличествоМесяцев из книги с отчетным периодом
                    int kolMonth = (int)newDoc.Names.Item(@"КоличествоМесяцев").RefersToRange.Value2;

                    if (args.DateEnd.Month == kolMonth)
                    {
                        excel.ScreenUpdating = false;
                        using (var dataContext = new VistaMedDataContext(context))
                        {
                            dataContext.VistaMed.Connection.Open();

                            try
                            {
                                // массив с объектами - типами листов книги
                                List<PageType> pageTypes = (new PageType[]
                                {
                                    new Polyclinic(context, dataContext),
                                    new Stacionar(context, dataContext),
                                    new Ambulance(context, dataContext)
                                }).ToList();

                                // сканируем все листы
                                foreach (Worksheet ws in newDoc.Worksheets.Cast<Worksheet>())
                                {
                                    // попытка обработать текущий лист для всех типов листов
                                    // фактическая работа делается в этих объектах
                                    pageTypes.ForEach(x => x.SelectFomsReportData(ws, args, result));
                                }
                            }
                            finally
                            {
                                dataContext.VistaMed.Connection.Close();
                            }
                        }
                        excel.ScreenUpdating = true;
                    }
                    else
                        context.ReportError(@"КоличествоМесяцев в файле не соответствует выбранному Вами периоду");
                }
                else
                    context.ReportError(@"Имя ячейки ""КоличествоМесяцев"" не найдено в файле {0}", excelFileName);

                newDoc.Close(false);
            }

            return result;
        }
コード例 #24
0
        public static void Build(IBackgroundContext context, DdActionListParams args)
        {
            using (var dataConext = new VistaMedDataContext(context))
            {
                var dateField = args.SelectByEventDate ? "e.execDate" : "a.endDate";

                var sqlInAccount = "";
                if (args.InAccount ^ args.NotInAccount)
                {
                    sqlInAccount = @"EXISTS(SELECT ai.id FROM Account_Item ai WHERE ai.deleted = 0 AND ai.action_id = a.id)";
                    if (args.NotInAccount)
                        sqlInAccount = "NOT " + sqlInAccount;
                    sqlInAccount = "AND " + sqlInAccount;
                }

                string gerderFilter = "1=1";
                if (args.IsMan ^ args.IsWoman)
                {
                    if (args.IsMan)
                        gerderFilter = "c.Sex = 1";
                    if (args.IsWoman)
                        gerderFilter = "c.Sex = 2";
                }

                var sqlText = string.Format(@"SELECT
                    CONCAT(c.lastName, ' ', c.firstName, ' ', c.patrName) AS ClientFio,
                    c.birthDate AS ClientBirthDate,
                    a.MKB AS Mkb,
                    a.endDate AS ActionDate,
                    aty.code AS ActionCode,
                    aty.name AS ActionName,
                    CONCAT(p.lastName, ' ', p.firstName, ' ', p.patrName) AS PersonFio,
                    p.code AS PersonCode,
                    et.code AS EventCode,
                    et.name AS EventName,
                    CONCAT_WS(' ', pc.lastName, pc.firstName, pc.patrName) AS OperFio
                    FROM Event e
                    JOIN Client c ON c.id = e.client_id
                    JOIN EventType et ON et.id = e.eventType_id AND et.deleted = 0 AND e.deleted = 0
                    JOIN Action a ON a.event_id = e.id AND a.deleted = 0
                    JOIN ActionType aty ON aty.id = a.actionType_id AND aty.deleted = 0
                    LEFT OUTER JOIN Person p ON p.id = a.person_id AND p.deleted = 0
                    LEFT OUTER JOIN rbSpeciality spec ON spec.id = p.speciality_id
                    LEFT OUTER JOIN Person pc ON pc.id = a.createPerson_id AND pc.deleted = 0
                    WHERE {7} >= '{0}' AND {7} < '{1}' {2} {3} {4} {5} {6} {8} {9} {10} {11}
                    AND {12} {13}
                    ORDER BY 1",
                               args.DateBegin.SqlStr(),
                               args.DateEnd.AddDays(1).SqlStr(),
                               dataConext.VistaMed.GetMaskSql("aty.code", args.ActionCodes),
                               dataConext.VistaMed.GetMaskSql("aty.name", args.ActionNames),
                               dataConext.VistaMed.GetMaskSql("et.code", args.EventCodes),
                               dataConext.VistaMed.GetMaskSql("et.name", args.EventNames),
                               dataConext.VistaMed.GetMaskSql("CONCAT(p.lastName, ' ', p.firstName, ' ', p.patrName)", args.ExecPersonFio),
                               dateField,
                               sqlInAccount,
                               dataConext.VistaMed.GetMaskSql("spec.federalCode", args.SpecCodes),
                               dataConext.VistaMed.GetMaskSql("spec.name", args.SpecNames),
                               dataConext.VistaMed.GetMaskSql("a.MKB", args.MkbCodes),
                               gerderFilter,
                               (string.IsNullOrEmpty(args.CreatorName) ? "" :
                               "AND CONCAT_WS(' ', pc.lastName, pc.firstName, pc.patrName) LIKE '" + args.CreatorName + "%'")
                               );

                var sourceData = dataConext.VistaMed.SelectSqlData<SourceData>(sqlText);

                if (sourceData.Count == 0)
                    context.ReportError(@"Даные за период с {0} по {1} не найдены", args.DateBegin, args.DateEnd);
                else
                {
                    var templateName = Utils.GetReportFileName(@"DdActionList.xls");
                    if (File.Exists(templateName))
                    {
                        var excel = new Application();
                        excel.Visible = true;

                        var newDoc = excel.Workbooks.Add(templateName);
                        excel.ScreenUpdating = false;

                        var ws = ((Worksheet)newDoc.Worksheets[1]);
                        newDoc.Names.Item(@"Период").RefersToRange.Value2 = Utils.GetPeriodName(args.DateBegin, args.DateEnd);

                        var lpu = dataConext.VistaMed.Organisations.FirstOrDefault(x => x.MiacCode == Properties.Settings.Default.LpuMiacCode);
                        if (lpu != null)
                        {
                            newDoc.Names.Item("ЛПУ").RefersToRange.Value2 = lpu.FullName;
                        }

                        var rowIndex = 6;
                        var npp = 1;
                        foreach (var data in sourceData)
                        {
                            var row = (Range) ws.Rows[rowIndex];
                            var colIndex = 1;
                            ((Range)row.Cells[1, colIndex++]).Value2 = npp;
                            ((Range)row.Cells[1, colIndex++]).Value2 = data.ClientFio;
                            ((Range)row.Cells[1, colIndex++]).Value2 = data.ClientBirthDate;
                            ((Range)row.Cells[1, colIndex++]).Value2 = data.Mkb;
                            ((Range)row.Cells[1, colIndex++]).Value2 = data.ActionDate;
                            ((Range)row.Cells[1, colIndex++]).Value2 = string.Concat(data.ActionCode , " " , data.ActionName);
                            ((Range)row.Cells[1, colIndex++]).Value2 = string.Concat(data.PersonFio, " (", data.PersonCode, ")");
                            ((Range)row.Cells[1, colIndex++]).Value2 = data.EventName;
                            ((Range)row.Cells[1, colIndex++]).Value2 = data.OperFio;
                            rowIndex++;
                            npp++;
                        }

                        excel.ScreenUpdating = true;
                        ws.Activate();
                    }
                }
            }
            context.ProgressSeparator('-');
        }
コード例 #25
0
 public Polyclinic(IBackgroundContext context, VistaMedDataContext dataContext)
     : base(context, dataContext)
 {
 }
コード例 #26
0
        public static void BuildSvedReport(IBackgroundContext context, MonthAccountParams args)
        {
            var dateBegin = args.DateBegin;
            var dateEnd = args.DateEnd;
            var miacCode = args.LpuCode;
            using (var dataConext = new VistaMedDataContext(context))
            {
                var smpBills = (from b in dataConext.VistaMed.Accounts
                                where b.Date >= args.DateBegin.AddDays(15) && b.Date < args.NextMonthBegin.AddDays(15)
                                && b.Contract != null && b.Contract.RbFinance != null
                                && b.Contract.RbFinance.Name.ToLower() == "омс"
                                    && (from a in b.AccountItems
                                        from s in dataConext.VistaMed.RbServices
                                        where a.ServiceId == s.Id
                                        && s.Code.StartsWith("162")
                                        select a).Any()
                                select b).ToList();

                smpBills = smpBills.Where(x => x.AccountType == AccountType.Osm18).ToList();
                smpBills = smpBills.Where(x => args.IsValidAccountNumber(x.Number)).ToList();

                if (smpBills.Count == 0)
                    context.ReportError(@"Счета ДД за период с {0} по {1} не найдены", dateBegin, dateEnd);
                else
                {
                    var templateName = Utils.GetReportFileName(@"SvodSpravOsm18.xls");
                    if (File.Exists(templateName))
                    {
                        var excel = new Application();
                        excel.Visible = true;

                        foreach (var smpBill in smpBills)
                        {
                            var newDoc = excel.Workbooks.Add(templateName);
                            excel.ScreenUpdating = false;

                            var ws = ((Worksheet)newDoc.Worksheets[1]);
                            newDoc.Names.Item(@"ОтчетныйПериод").RefersToRange.Value2 =
                                Utils.GetPeriodName(smpBill.SettleDate.BeginOfMonth(), smpBill.SettleDate);

                            var lpu = dataConext.VistaMed.Organisations.FirstOrDefault(x => x.MiacCode == miacCode);
                            if (lpu != null)
                            {
                                newDoc.Names.Item("ЛПУ").RefersToRange.Value2 = lpu.FullName;
                                newDoc.Names.Item("ФИОРуководителя").RefersToRange.Value2 = lpu.Chief;
                                newDoc.Names.Item("ФИОГлавбуха").RefersToRange.Value2 = lpu.Accountant;
                            }

                            var smo =
                                (from payer in dataConext.VistaMed.Organisations
                                 where payer.Id == smpBill.PayerId
                                 select payer).FirstOrDefault();
                            if (smo != null)
                            {
                                newDoc.Names.Item("СМО").RefersToRange.Value2 = smo.FullName;
                            }

                            ReportData colData;

                            var eventList = (from a in smpBill.AccountItems
                                             where !a.Deleted && a.Event != null && a.Event.RbResult != null && a.Action != null && a.Action.ActionType != null
                                             group a by a.Event into e
                                             select e).ToList();

                            var profActionCodes = new[] { "162043", "162044", "162045", "162046", "162002",
                            "162003", "162005", "162006", "162007", "162008", "162009", "162010" };

                            var predActionCodes = new[] { "162040", "162041", "162042" };

                            var txtFileName = Utils.GetOptionsFileName(@"SvedOsm18Services.txt");
                            if (File.Exists(txtFileName))
                            {
                                var allLines = File.ReadAllLines(txtFileName, Encoding.GetEncoding(1251));
                                foreach (var currLine in allLines)
                                {
                                    if (currLine.StartsWith(@"Профилактика"))
                                    {
                                        var lines2 = currLine.Split('=');
                                        profActionCodes = lines2[1].Split(',');
                                    }
                                    if (currLine.StartsWith(@"Предварительные"))
                                    {
                                        var lines2 = currLine.Split('=');
                                        predActionCodes = lines2[1].Split(',');
                                    }
                                }
                            }

                            var profList = (from e in eventList
                                            where e.Any(a => profActionCodes.Any(x => a.Action.ActionType.Code == x))
                                            select e).ToList();

                            var predList = (from e in eventList
                                            where e.Any(a => predActionCodes.Any(x => a.Action.ActionType.Code == x))
                                            select e).ToList();

                            var periodList = eventList.Except(profList).Except(predList).ToList();

                            colData = new ReportData();
                            colData.Prof = profList.Count;
                            colData.Pred = predList.Count;
                            colData.Period = periodList.Count;

                            fillColumn(ws, colData, 2);

                            colData = new ReportData();
                            colData.Prof = (from e in profList from a in e select a).Sum(x => x.Sum);
                            colData.Pred = (from e in predList from a in e select a).Sum(x => x.Sum);
                            colData.Period = (from e in periodList from a in e select a).Sum(x => x.Sum);

                            fillColumn(ws, colData, 3);

                            excel.ScreenUpdating = true;
                            ws.Activate();

                        }
                    }
                }
            }
            context.ProgressSeparator('-');
        }
コード例 #27
0
 public Section(int minRowIndex, int maxRowIndex,
     VistaMedDataContext dataContext,
     StacionarType stacionarType,
     IBackgroundContext context)
 {
     this.minRowIndex = minRowIndex;
     this.maxRowIndex = maxRowIndex;
     this.dataContext = dataContext;
     this.stacionarType = stacionarType;
     this.context = context;
 }
コード例 #28
0
        public static void BuildSvedReport(IBackgroundContext context, MonthAccountParams args)
        {
            var dateBegin = args.DateBegin;
            var dateEnd = args.DateEnd;
            var miacCode = args.LpuCode;
            using (var dataConext = new VistaMedDataContext(context))
            {
                var smpBills = (from b in dataConext.VistaMed.Accounts
                                where b.Date >= args.DateBegin.AddDays(15) && b.Date < args.NextMonthBegin.AddDays(15)
                                && b.Contract != null && b.Contract.RbFinance != null
                                && b.Contract.RbFinance.Name.ToLower() == "омс"
                                    && (from a in b.AccountItems
                                        from s in dataConext.VistaMed.RbServices
                                        where a.ServiceId == s.Id
                                        && (s.Code.StartsWith("161") || s.Code.StartsWith("162"))
                                        select a).Any()
                                select b).ToList();

                smpBills = smpBills.Where(x => x.AccountType == AccountType.Osm18
                    && args.IsValidAccountNumber(x.Number)
                    && !x.Number.StartsWith(PlanExecution.ReserveAccountName)).ToList();

                if (smpBills.Count == 0)
                    context.ReportError(@"Счета ДД за период с {0} по {1} не найдены", dateBegin, dateEnd);
                else
                {
                    var templateName = Utils.GetReportFileName(@"SvedOsm18.xls");
                    if (File.Exists(templateName))
                    {
                        var excel = new Application();
                        excel.Visible = true;

                        var planDataList = loadPlan(excel);

                        var newDoc = excel.Workbooks.Add(templateName);
                        excel.ScreenUpdating = false;

                        var ws = ((Worksheet)newDoc.Worksheets[1]);
                        newDoc.Names.Item(@"ДатаНачала").RefersToRange.Value2 = dateBegin;
                        newDoc.Names.Item(@"ДатаКонца").RefersToRange.Value2 = dateEnd;
                        newDoc.Names.Item(@"ДатаОтчета").RefersToRange.Value2 = DateTime.Today;
                        newDoc.Names.Item(@"ОтчетныйПериод").RefersToRange.Value2 = Utils.GetPeriodName(dateBegin, dateEnd);

                        var lpu = dataConext.VistaMed.Organisations.FirstOrDefault(x => x.MiacCode == miacCode);
                        if (lpu != null)
                        {
                            newDoc.Names.Item("ЛПУ").RefersToRange.Value2 = lpu.FullName;
                            newDoc.Names.Item("ФИОРуководителя").RefersToRange.Value2 = lpu.Chief;
                            newDoc.Names.Item("ФИОГлавбуха").RefersToRange.Value2 = lpu.Accountant;
                        }

                        ReportData colData;

                        colData = new ReportData();
                        colData.Prof = planDataList.Sum(x => x.Prof);
                        colData.Pred = null;
                        colData.Period = planDataList.Sum(x => x.Period); ;
                        fillColumn(ws, colData, 3);

                        colData = new ReportData();
                        colData.Prof = planDataList.Where(y => y.Month <= dateEnd.Month).Sum(x => x.Prof);
                        colData.Pred = null;
                        colData.Period = planDataList.Where(y => y.Month <= dateEnd.Month).Sum(x => x.Period); ;
                        fillColumn(ws, colData, 4);

                        var eventList = (from b in smpBills
                                         from a in b.AccountItems
                                         where !a.Deleted && a.Event != null && a.Event.RbResult != null && a.Action != null && a.Action.ActionType != null
                                         group a by a.Event into e select e).ToList();

                        var profActionCodes = new[] { "162043", "162044", "162045", "162046", "162002",
                            "162003", "162005", "162006", "162007", "162008", "162009", "162010" };

                        var predActionCodes = new[] { "162040", "162041", "162042" };

                        var perActionsCodes = new[] { "162060", "162061", "162062"};

                        var txtFileName = Utils.GetOptionsFileName(@"SvedOsm18Services.txt");
                        if (File.Exists(txtFileName))
                        {
                            var allLines = File.ReadAllLines(txtFileName, Encoding.GetEncoding(1251));
                            foreach (var currLine in allLines)
                            {
                                if (currLine.StartsWith(@"Профилактика"))
                                {
                                    var lines2 = currLine.Split('=');
                                    profActionCodes = lines2[1].Split(',');
                                }
                                if (currLine.StartsWith(@"Предварительные"))
                                {
                                    var lines2 = currLine.Split('=');
                                    predActionCodes = lines2[1].Split(',');
                                }
                                if (currLine.StartsWith(@"Периодические"))
                                {
                                    var lines2 = currLine.Split('=');
                                    perActionsCodes = lines2[1].Split(',');
                                }
                            }
                        }

                        var profList = (from e in eventList
                            where e.Any(a => profActionCodes.Any(x => a.Action.ActionType.Code == x))
                            select e).ToList();

                        var predList = (from e in eventList
                            where e.Any(a => predActionCodes.Any(x => a.Action.ActionType.Code == x))
                            select e).ToList();

                        var periodList = eventList.Except(profList).Except(predList).ToList();

                        colData = new ReportData();
                        colData.Prof = (from e in profList from a in e select a).Sum(x => x.Sum) / 1000;
                        colData.Pred = (from e in predList from a in e select a).Sum(x => x.Sum) / 1000;
                        colData.Period = (from e in periodList from a in e select a).Sum(x => x.Sum) / 1000;
                        fillColumn(ws, colData, 5);

                        colData = new ReportData();
                        colData.Prof = profList.Count;
                        colData.Pred = predList.Count;
                        colData.Period = periodList.Count;

                        fillColumn(ws, colData, 6);

                        string grName = "";
                        int grColIndex = 0;

                        grColIndex = 15;

                        grName = @" I группа";
                        grZd(profList, grName, predList, ws, grColIndex++);
                        grName = @" II группа";
                        grZd(profList, grName, predList, ws, grColIndex++);
                        grName = @" III группа";
                        grZd(profList, grName, predList, ws, grColIndex++);
                        grName = @" IV группа";
                        grZd(profList, grName, predList, ws, grColIndex++);
                        grName = @" V группа";
                        grZd(profList, grName, predList, ws, grColIndex++);

                        excel.ScreenUpdating = true;
                        ws.Activate();
                    }
                }
            }
            context.ProgressSeparator('-');
        }
コード例 #29
0
 protected PageType(IBackgroundContext context, VistaMedDataContext dataContext)
 {
     this.context = context;
     this.dataContext = dataContext;
 }
コード例 #30
0
        /// <summary>
        /// Провести автоматическую коррекцию реестров (устранить пере(недо)выполнение) по результатам проверки
        /// </summary>
        /// <param name="context"></param>
        /// <param name="args"></param>
        public static void AutoCorrectAccounts(IBackgroundContext context, AccountCorrectParams args)
        {
            context.ProgressSeparator();
            context.ReportProgress(@"АВТОМАТИЧЕСКАЯ КОРРЕКТИРОВКА РЕЕСТРОВ В СООТВЕТСТВИИ С ПЛАНАМИ");
            context.ProgressSeparator();

            // книга планов
            var excelFileName = args.AccountCheckPlanFileName;
            if (File.Exists(excelFileName))
            {
                var excel = new Application();
                excel.Visible = true;

                Workbook newDoc;
                try
                {
                    context.ReportProgress(@"Открываем файл {0} ...", excelFileName);
                    newDoc = excel.Workbooks.Open(excelFileName);
                }
                catch (Exception exception)
                {
                    newDoc = null;
                    context.ReportError(@"Ошибка открытия файла {0} : {1}", excelFileName, exception.Message);
                }

                if (newDoc != null)
                {
                    // ищем имя КоличествоМесяцев
                    var kolMonthExists = false;
                    for (int i = 1; i <= newDoc.Names.Count; i++)
                    {
                        if (newDoc.Names.Item(i).Name == @"КоличествоМесяцев")
                        {
                            kolMonthExists = true;
                            break;
                        }
                    }

                    if (kolMonthExists)
                    {
                        // сравниваем КоличествоМесяцев из книги с отчетным периодом
                        int kolMonth = (int) newDoc.Names.Item(@"КоличествоМесяцев").RefersToRange.Value2;

                        if (args.DateEnd.Month == kolMonth)
                        {
                            excel.ScreenUpdating = false;
                            using (var dataContext = new VistaMedDataContext(context))
                            {
                                dataContext.VistaMed.Connection.Open();

                                // новая транзакция для обеспечения атомарности всех изменений БД для текущего метода
                                dataContext.VistaMed.ActiveTransaction = dataContext.VistaMed.Connection
                                    .BeginTransaction(IsolationLevel.ReadCommitted);

                                try
                                {
                                    // массив с объектами - типами листов книги
                                    List<PageType> pageTypes = (new PageType[]
                                    {
                                        new Polyclinic(context, dataContext),
                                        new Stacionar(context, dataContext),
                                        new Ambulance(context, dataContext)
                                    }).ToList();

                                    // сканируем все листы
                                    foreach (Worksheet ws in newDoc.Worksheets.Cast<Worksheet>())
                                    {
                                        // попытка обработать текущий лист для всех типов листов
                                        // фактическая работа делается в этих объектах
                                        pageTypes.ForEach(x => x.AutoCorrectAccounts(ws, args));
                                    }

                                    try
                                    {
                                        dataContext.VistaMed.ActiveTransaction.Commit();
                                        context.ReportProgress(@"Изменения записаны в БД");
                                    }
                                    catch (Exception exception)
                                    {
                                        dataContext.VistaMed.ActiveTransaction.Rollback();
                                        context.ReportProgress(@"Ошибка записи изменений в БД: {0}", exception.Message);
                                    }
                                }
                                finally
                                {
                                    dataContext.VistaMed.ActiveTransaction.Dispose();
                                    dataContext.VistaMed.ActiveTransaction = null;
                                    dataContext.VistaMed.Connection.Close();
                                }
                            }
                            excel.ScreenUpdating = true;

                        }
                        else
                            context.ReportError(@"КоличествоМесяцев в файле не соответствует выбранному Вами периоду");
                    }
                    else
                        context.ReportError(@"Имя ячейки ""КоличествоМесяцев"" не найдено в файле {0}", excelFileName);

                    newDoc.Close(false);
                }
            }
            else
                context.ReportError(@"Файл {0} не найден", excelFileName);

            context.ProgressSeparator('-');
        }