@fboss99

Распределить код между модулем формы и модулем объекта?

&НаКлиенте 
Процедура Отправить(Кнопка) 
  
 Если НЕ ПроверитьЗаполнение() Тогда 
  Возврат 
 КонецЕсли; 
 ОтправкаТаблицы(); 
  
  
КонецПроцедуры 
 
 
&НаСервере 
Процедура ОтправкаТаблицы() 
  
 ПрофильПодключения = Новый ИнтернетПочтовыйПрофиль; 
  ПрофильПодключения.АдресСервераSMTP ="smtp.yandex.ru"; 
  ПрофильПодключения.ИспользоватьSSLSMTP=Истина; 
  ПрофильПодключения.ПортSMTP = 465; 
  ПрофильПодключения.ПользовательSMTP = "boss229.13@yandex.ru"; 
  ПрофильПодключения.ПарольSMTP ="12345678Boss"; 
  
 Почта = Новый ИнтернетПочта; 
  
 Попытка 
  Почта.Подключиться(ПрофильПодключения); 
 Исключение 
  Сообщить("Не удалось подключиться к серверу smtp.yandex.ru"); 
  Сообщить(ОписаниеОшибки()); 
  Возврат; 
 КонецПопытки; 
  
 Письмо = Новый ИнтернетПочтовоеСообщение; 
 Текст = Письмо.Тексты.Добавить(); 
 Текст.ТипТекста = ТипТекстаПочтовогоСообщения.HTML; 
  
  
 Текст.Текст = " 
  |<html> 
  |<body> 
  |Здравствуйте, Иван Иванович! 
  |<br><br> 
  |Список заказов с суммой от "+ сумма + ". за период с " + Период + ":" 
  " 
  |<style> 
  |th { 
  |font-weight: normal; 
  |} 
  |table { 
  |width: 50%; 
  |border-collapse: collapse; 
  |} 
  |td, th { 
  |padding: 4px; 
  |border: 1px solid black; 
  |} 
  |</style> 
  |<table> 
  |<thead> 
  |<th> № </th><th>Дата</th><th>Клиент</th><th>Сумма</th><th>Менеджер</th> 
  |</thead> 
  |<tbody>"; 
   
 
 Запрос = Новый Запрос; 
 Запрос.Текст = 
  "ВЫБРАТЬ 
  | ЗаказКлиента.СуммаДокумента КАК СуммаДокумента, 
  | ЗаказКлиента.Менеджер.Наименование КАК МенеджерНаименование, 
  | ЗаказКлиента.Номер КАК Номер, 
  | ЗаказКлиента.Контрагент.Наименование КАК КонтрагентНаименование, 
  | ЗаказКлиента.Дата КАК Дата 
  |ИЗ 
  | Документ.ЗаказКлиента КАК ЗаказКлиента 
  |ГДЕ 
  | ЗаказКлиента.СуммаДокумента >= &СуммаДокумента"; 
  
 Запрос.УстановитьПараметр("СуммаДокумента", Сумма); 
  
 РезультатЗапроса = Запрос.Выполнить(); 
  
 ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать(); 
  
 СуммаДокументов = 0; 
  
 Пока ВыборкаДетальныеЗаписи.Следующий() Цикл 
 
 стрТаб = СтрШаблон("<tr><td>%1</td><td>%2</td><td>%3</td><td>%4 руб. </td><td>%5</td></tr>", 
       ВыборкаДетальныеЗаписи.Номер, 
        ФОРМАТ(ВыборкаДетальныеЗаписи.Дата, "ДФ=dd.MM.yyyy"), 
        ВыборкаДетальныеЗаписи.КонтрагентНаименование , 
        ВыборкаДетальныеЗаписи.СуммаДокумента, 
        ВыборкаДетальныеЗаписи.МенеджерНаименование); 
         
 Текст.Текст = Текст.Текст + стрТаб; 
   
  СуммаДокументов = СуммаДокументов + ВыборкаДетальныеЗаписи.СуммаДокумента; 
   
 КонецЦикла; 
  
 Текст.Текст = Текст.Текст + " 
  |</tbody> 
  |</table> 
  |<br><br> 
  |Всего заказов " + ВыборкаДетальныеЗаписи.Количество() + " на сумму " + СуммаДокументов + " (" + ЧислоПрописью(СуммаДокументов, ("Л = ru_RU; НД = Ложь"),"рубль, рубля, рублей, м, копейка, копейки, копеек, ж, 0") + ").» 
  |</body> 
  |</html>"; 
  
 ////////////////////////////////////// 
  
 Письмо.Тема    = "|«Крупные заказы за период с " + Период +""; 
 Письмо.Отправитель   = "boss229.13@yandex.ru"; 
 Письмо.ИмяОтправителя  = "Феофанов Александр Владимирович"; 
 Письмо.Получатели.Добавить("boss229.13@yandex.ru"); 
 Письмо.СлепыеКопии.Добавить("boss229.13@yandex.ru"); 
  
 Попытка 
  Почта.Послать(Письмо); 
  Сообщить("Письмо отправлено"); 
 Исключение 
  Сообщить("Не удалось отправить письмо "); 
  Сообщить(ОписаниеОшибки()); 
 КонецПопытки; 
  
 Почта.Отключиться(); 
  
КонецПроцедуры
  • Вопрос задан
  • 113 просмотров
Пригласить эксперта
Ответы на вопрос 1
fosihas
@fosihas
Автоматизации учета на 1С.
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы