// Экспорт заявок в СИА Интернейшнл.
// Формат впервые использовался в Саратове (Фармцентр)

var // предопределенные переменные

  Dataset :TDataset;
  VarExportEMail :string;
  VarName_Storage :variant;
  VarID_Storage :variant;
  varname_org :variant;
  varid_orgs :variant;
  VarDate_Doc :variant;
  varTime_Doc :tdatetime;
  VarNumber_Doc :variant;
  VarID :variant;
  VarPreq_Sum :variant;
  VarRows_count :variant;
  VarExportReport :string;
  VarINfo :string;
  VarExportOutPreqOriginalPrices :boolean; // флаг, нужно ли экспортировать цену оригинальную из прайс-листа. иначе - цену, указанную в заявке


const
   MessageSubject = 'Электронная заявка SolPrice';


var
    MailMessage :Variant;
    ExportFilename :string;
    Bodystr :string;

    FileStr :string;
    strval :string;
    DirName :string;

function GetPrice :double;
begin
  if VarExportOutPreqOriginalPrices
  then result := Dataset.fieldbyname('price_pr').asfloat
  else result := Dataset.fieldbyname('price').asfloat;
end;


procedure AddStr(var DestStr: string; SourceStr :string;UseCR :boolean = true);
begin
  if DestStr >'' then begin
     if UseCR then DestSTr := DestStr + #13;
     DestStr := DestStr + #10;
  end;

  DestStr := DestStr + SourceStr;
end;

function ifthen_1(BoolVal :boolean; trueval,falseval :string) :string;
begin
  if boolval
  then result := trueval
  else result := falseval
end;

procedure CheckParams;
begin
   if asint64(varid_storage)=0
   then begin
     varid_storage := id_storage_current;
   end;
   if (asint64(varid_storage)<>0) and (varname_storage='')
   then begin
     varname_storage := dbQueryvalue('select name from orgs where id = :id ',[varid_storage]);
   end;
   if asint64(varid_storage)<>0
   then begin
     id_org_main := coalesce_int64( asint64( DBQueryvalue('select id_parent_org from orgs where id = :id',[VARID_STORAGE]))
                                    ,id_org_main);
   end;
end;

begin
   Checkparams;


   filestr := '';
   bodystr := '';



   strval := strpadright('Клиент',13)+': '
             +coalesce_string(asstring(getexternalorgcode(id_org_main,varid_orgs)),
                              asstring(getexternalorgcode(0,varid_orgs))
                             )
             +', '
             + asstring(dbQueryvalue('select name from orgs where id = :id',[id_org_main]));

   AddStr(FileStr,strval);
   addstr(BodyStr,strval,true);


   //showmessage(asstring(varid_orgs)+':'+asstring(varname_org));

   strval := strpadright('Получатель',13)+': '
            + coalesce_string(asstring(getexternalorgcode(asint64(varid_storage),varid_orgs)),
                              asstring(getexternalorgcode(id_org_main,varid_orgs)),
                              asstring(getexternalorgcode(0,varid_orgs))
                             )
            +', '
            + coalesce_string(asstring(DBQueryvalue('select address from orgs where id = :id',[VARID_STORAGE])),
                             asstring(DBQueryvalue('select address from orgs where id = :id',[id_org_main])));
   AddStr(FileStr,strval);
   addstr(BodyStr,strval,true);

   strval := strpadright('Оплата',13)+': 0';
   AddStr(FileStr,strval);
   //addstr(BodyStr,strval);

   strval := strpadright('ID заказа',13)+': '+asstring(varID);
   AddStr(FileStr,strval);

   strval := strpadright('Дата заказа',13)+': '+formatdatetime('dd.mm.yyyy hh:nn:ss',vardate_doc+vartime_doc);
   AddStr(FileStr,strval);
   addstr(BodyStr,strval,true);

   dataset.last; // вдруг это fibdataset, и он не добран

   strval := strpadright('Позиций',13)+': '+asstring(dataset.recordcount);
   AddStr(FileStr,strval);
   addstr(BodyStr,strval,true);


   strval := strpadright('Версия EXE',13)+': ';
   AddStr(FileStr,strval);
   strval := strpadright('Версия CFG',13)+': ';
   AddStr(FileStr,strval);
   strval := strpadright('Статус CFG',13)+': ';
   AddStr(FileStr,strval);

   strval := strpadright('Прайс-лист',13)+': '
            +formatdatetime('dd.mm.yyyy hh:nn:ss',
             asdatetime(dbQueryValue('select first 1 a.update_org from prices_headers_upd a '
                                     +' join prices_rows b on a.id = b.id_prices_headers '
                                     +' join out_preq_rows c on b.id = c.id_prices_rows '
                                     +' where c.id_out_preq = :id',[varid]))
            );
   AddStr(FileStr,strval);


   strval := strpadright('Комментарий',13)+': '+asString(VarInfo);
   AddStr(FileStr,strval);
   addstr(BodyStr,strval,true);


   AddStr(Filestr,''); // отступ

   dataset.first;
   while not dataset.eof do
   begin

     addstr(Filestr,
            coalesce_string( dataset.fieldbyname('price_code').asstring, dataset.fieldbyname('price_code_goods').asstring)
            +stringofchar(' ',9)+
            dataset.fieldbyname('quantity').asstring
           );


     dataset.next;
   end;

   AddStr(Filestr,''); // отступ


    ExportFilename :=  gettempdir + 'Заявка_от_'+formatdatetime('yyyy_mm_dd_hh-nn-ss',vardate_doc+vartime_doc)+'.txt';   //getuniquefilename(gettempdir+'
    StringToFile(ExportFilename,FileStr);

    if pos('@',varexportemail)>0
    then begin

      MailMessage := CreateOleObject('mailprocessor.mpmailmessage');

      if not MailMessage.srv.connected
      then MailMessage.SRV.ConnectWP('Пользователь','1');

      if not MailMessage.srv.connected
      then begin
        CreateHintE('Не могу присоединиться.');
        exit;
      end;


      MailMessage.ID := 0;
      MailMessage.Recipients :=  varexportemail;


      MailMessage.Subject := MessageSubject;

      MailMessage.Body := BodyStr;

      MailMessage.AddAttachment(ExportFilename);

      if (VarExportReport>'')
         and fileexists(VarExportReport)
      then
        MailMessage.AddAttachment(VarExportReport);


      MailMessage.Save;

    end
    else begin // значит там указан каталог, сохраняем в этом каталоге
      DirName := includetrailingpathdelimiter(VarExportEmail);
      ForceDirectories(Dirname);
      CopyFile(ExportFilename, DirName + ExtractFileName(ExportFileName));

    end;

    deletefile(exportfilename);

end.
