/// <summary> /// Get tax documment from 1C 7.7 /// </summary> /// <param name="global">handle to global module 1C 7.7</param> /// <param name="Doc">Handle to tax document in 1C 7.7</param> /// <param name="ConfigType">Configuration 1C 7.7 enum</param> /// <param name="org">Organization reference</param> public static J1201010 GetFrom1C77(GlobalObject1C77 global, COMObject doc, IOrganization org) { J1201010 result = org.IS_NP?new J1201010():new F1201010(); // шапка налоговой result.TIN = Get1C77_HKSEL(doc, org); //result.C_DOC //result.C_DOC_SUB //result.C_DOC_VER result.C_DOC_TYPE = 0; result.C_REG = org.C_REG; result.C_RAJ = org.C_RAJ; var str = doc.GetPropertyString("DocNum"); try { var str1 = (new string(str.Where(s => Char.IsDigit(s)).ToArray())).TrimStart('0'); result.C_DOC_CNT = uint.Parse(str1); } catch { string error = $"Error parse tax number {str} as uint"; Trace.TraceError(error); throw new Exception(error); } result.PERIOD_TYPE = 1; DateTime date = doc.GetPropertyDateTime("DocDate"); result.PERIOD_YEAR = date.Year; result.PERIOD_MONTH = date.Month; result.D_FILL = DateTime.Now; result.R01G1 = new int?(); result.R03G10S = Get1C77_R03G10S(doc, org); result.HORIG1 = new int?(); result.HTYPR = new DGPNtypr?(); result.HKSEL = Get1C77_HKSEL(doc, org); result.HNAMESEL = Get1C77_HNAMESEL(doc, org); result.HTINSEL = Get1C77_TINSEL(doc, org); result.HNUM2 = org.FilialNumber == ""?null: org.FilialNumber; result.HFILL = date.DateToOPZFormat(); result.HNUM = result.C_DOC_CNT; result.HNUM1 = new ulong?(); result.HNAMEBUY = Get1C77_HNAMEBUY(doc, org); result.HKBUY = Get1C77_HKBUY(doc, org); result.HFBUY = Get1C77_HFBUY(doc, org); result.HTINBUY = Get1C77_HTINBUY(doc, org); result.HBOS = org.Manager; result.HKBOS = org.ManagerIPN; if (doc.MethodDouble("SelectLines") == 1) { while (doc.MethodDouble("GetLine") == 1) { //DateTime DataDoc = Doc.Property("ДатаДок").ToDateTime(); //if (OLE.IsEmtyValue(Doc.Property("ТМЦ"))) continue; J1201010T1 t1 = new J1201010T1(); t1.RXXXXG3S = Get1C77_TmcDescription(doc, org); //ТМЦ if (doc.Is1C77_usluga(org)) { t1.RXXXXG33 = doc.Get1C77_UKTZED(org); } else { t1.RXXXXG4 = doc.Get1C77_UKTZED(org); } t1.RXXXXG4S = doc.GetPropertyObject("Ед").GetPropertyString("Наименование"); // UnitOfMeasure t1.RXXXXG105_2S = Get1C77_UnitCode(doc, org); t1.RXXXXG5 = Get1C77_quantity(doc, org); t1.RXXXXG6 = Get1C77_CostWithoutVAT(doc, org); t1.RXXXXG008 = Get1C77_StavkaNDS(doc, org); t1.RXXXXG009 = Get1C77_PilgaNDS(doc, org); t1.RXXXXG010 = Get1C77_SumWithoutVAT(doc, org); t1.RXXXXG11_10 = new decimal?((decimal)doc.Get1C77_VAT(org)); result.T1.Add(t1); } } return(result); }
/// <summary> /// Выгрузка корректировки к налоговой накладной /// </summary> /// <param name="_connection"> Соединение с 1С</param> /// <param name="Doc">Переданая накладная</param> /// <param name="Organization">Организация по которой проводим выгрузку</param> public static J1201010 GetJ12010(dynamic _connection, dynamic Doc, dynamic Organization) { J1201010 dc = new J1201010(); string DocNumber = Doc.Number; //dc.SetDocNum(ulong.Parse(DocNumber.DigitalSubstring().TrimStart('0'))); //dc.SetDocPeriod((DateTime)Doc.Date, 1); //dc.SetOrganization(Organization); dc.HFILL = ((DateTime)(Doc.Date)).DateToOPZFormat(); string s = ((string)(Doc.Number)).Trim(); s = s.DigitalSubstring().PadLeft(5, '0'); dc.HNUM = ulong.Parse(s.Substring(s.Length - 5)); dc.HNUM1 = null; dc.HNUM2 = null; dc.HNAMESEL = Organization.FULL_NAME; dc.HKSEL = Organization.KODE; string КодЯзыкаПечать = "uk"; dynamic СведенияОПродавце = _connection.УправлениеНебольшойФирмойСервер.СведенияОЮрФизЛице(КодЯзыкаПечать, Organization, Doc.Дата); dynamic СведенияОПокупателе = _connection.УправлениеНебольшойФирмойСервер.СведенияОЮрФизЛице(КодЯзыкаПечать, Doc.Контрагент, Doc.Дата); s = _connection.УправлениеНебольшойФирмойСервер.ОписаниеОрганизации(СведенияОПокупателе, "ПолноеНаименование,", false); dc.HNAMEBUY = s.Trim(); dc.HKBUY = _connection.УправлениеНебольшойФирмойСервер.ОписаниеОрганизации(СведенияОПокупателе, "ИНН,", false); dc.HBOS = Organization.Manager; // таблична частина запаси int Lines = Doc.Запасы.Количество(); for (int i = 0; i < Lines; i++) { dynamic СтрокаТаблицы = Doc.Запасы.Get(i); J1201010T1 t1 = new J1201010T1(); t1.RXXXXG3S = СтрокаТаблицы.Номенклатура.НаименованиеПолное; //ТМЦ // если запас t1.RXXXXG4 = СтрокаТаблицы.КодУКТВЭД.Код; // услуга //t1.RXXXXG33 = СтрокаТаблицы.КодУКТВЭД.Код; uint? DGchk = new uint?(); string DGDKPP = null; t1.RXXXXG4S = СтрокаТаблицы.ЕдиницаИзмерения.Наименование; t1.RXXXXG105_2S = СтрокаТаблицы.ЕдиницаИзмерения.Code; t1.RXXXXG5 = (decimal)СтрокаТаблицы.Количество; bool СуммаВключаетНДС = Doc.СуммаВключаетНДС; decimal Price = (decimal)(СтрокаТаблицы.Цена); t1.RXXXXG6 = decimal.Round(СуммаВключаетНДС ? Price / 1.2m : Price, 2); t1.RXXXXG008 = EVAT.Default; t1.RXXXXG009 = null; t1.RXXXXG010 = (decimal)(СуммаВключаетНДС ? СтрокаТаблицы.Сумма - СтрокаТаблицы.СуммаНДС : СтрокаТаблицы.Сумма); t1.RXXXXG11_10 = (decimal)СтрокаТаблицы.НДС; dc.T1.Add(t1); } return(dc); }