// Скрипт импорта накладной от Резерв Астрахань

const UseBarcode = true; // определяет, будет ли использоваться штрихкод, поставляемый поставщиком


var
    Header :TStringList; // предопределена приложением
    Data :TStringList; // предопределена приложением
    ExportAgent :string; // все определены приложением
    FileName :string;

    ExportAgentName :string;
    ExportNakladNom :string;
    ExportNakladID_DOC :string;
    ExportNakladData :string;
    ExportNakladSklad :string;
    ExportSkladName :string;
    EXPORTNAKLADSROK :string;

var Table :TDBF;//TTable;
    num_doc :string;
    Item :variant;
    i,k :integer;
    tmpname :string;
    OpenDialog :TOpenDialog;
    ThF :TField;
    str,str1 :string;
    Field :TField;
    FPrice_Reg :TField;
    FBarcode :TField;

    List :TStringList;
    List1 :TSTringList;
    List2 :Tstringlist;

    function StrToDTStr( str :string) :string;
    begin
      if length(str)<>8
      then begin
        result := str;
      end
      else begin
        result := copy(str,7,2)+'.'+copy(str,5,2)+'.'+ copy(str,1,4);
      end;
    end;

    function GetItemValue(Item :Variant; Name :String) :string;
    begin
       try
         result := vartostr(Item.attributes.getNamedItem(Name).value);
       except
         result := ''
       end;
    end;

    function IFSTR(BoolVal :boolean; const TrueVal :string; const FAlseVal :string = '') :string;
    begin
      if BoolVal then Result := TrueVal
      else Result := FalseVal;
    end;

    procedure AddStr(var Destination :string; FieldNameList :tstringLIst; const FieldName :string; FieldValueList :TStringlist);
    var j :integer;
    begin
      j := FieldNameList.indexof(FieldName);
      //createhint('i='+inttostr(i)+',Name =' +FieldName+',NC ='+inttostr(FieldNamelist.count)+', VC='+inttostr(fieldvaluelist.count));
      if j>=0
      then Destination := Destination + FieldValueList[j];
      Destination := Destination + #9;
    end;

 begin
     //FileName := '';
     if filename = ''
     then begin
       OpenDialog := TOpenDialog.create(nil);
       try
         OpenDialog.Title := 'Укажите файл';
         OpenDialog.FileName  := AppIniFile.readstring('plugins_rezerv','filename','');
         opendialog.initialdir := extractfilepath(opendialog.filename);
         OpenDialog.Filter := 'Файлы-накладные(*.dbf,*.txt)|*.dbf;*.txt|Все файлы(*.*)|*.*';
         while  OpenDialog.execute do begin
           if not fileexists(OpenDialog.FileName) then CreateHint('Укажите правильно файл ')
           else begin
             Filename := OpenDialog.FileName;
             AppIniFile.writestring('plugins_rezerv','filename',OpenDialog.filename);
             break;
           end;
         end;
       finally
         OpenDialog.free;
       end;
     end;

     if FileName = '' then exit;

     with TMyWait.create('Идет импорт накладной') do
     try

       if uppercase(extractfileext(filename))='.DBF'
       then begin
         //createhintw('Не реализовано, обратитесь в техподдержку');
        // exit;




         Table := TDBF.create(nil);// TTable.Create(nil);
         try

          //table.tabletype := ttFoxpro;

          tmpname := gettempdir + extractfilename(FileName);
          filedelete(tmpname);
          //Table.tabletype := ttfoxpro;
          copyfile(FileName,tmpname,False);
          //SetTableLangDriver(Table,'db866ru0');
          
          CheckDBFCP(tmpname,38); //866DOS

          table.tablename := tmpname;
          Table.Open;
          Table.First;

          data.Clear;

          
          if (table.findfield('NDOC') <> nil)  and (table.findfield('DATEDOC') <> nil)
          then begin
             Header.Values[ExportNakladNom] := table.fieldbyname('NDOC').asstring;
             Header.Values[ExportNakladData] := StrTodtStr( table.fieldbyname('DATEDOC').asstring);
             //Header.Values[ExportNakladSROK] := strtodtstr( table.fieldbyname('datepay').asstring);

              data.Add(
              'srok'+#9+
              'sroksertif'+#9+
              'sertifname'+#9+
              'kol'+#9+
              'nds'+#9+
              'name'+#9+
              'firstcena'+#9+
              'seria'+#9+
              'sertif'+#9+
              'producername'+#9+
              'datesertif'+#9+
              'tamog'+#9+
              'countryname'+#9+
              'regn'+#9+ //+'cenanotnds'
              'barcode'+#9+
              'summa'+#9+
              'price_reg');

              FPrice_reg := table.findfield('REGPRC');

              if UseBarcode then
                FBarcode := Table.findfield('EAN13')
              else
                FBarcode := nil;


              while not Table.eof do begin
              str :=
                   Table.FieldByName('GDATE').AsString+#9+
                   table.fieldbyname('SERTDATE').asstring +#9+
                   Table.FieldByName('SERTORG').AsString+#9+
                   Table.FieldByName('QNT').AsString+#9+
                   Table.FieldByName('nds').AsString+#9+
                   Table.FieldByName('NAME').AsString+#9+
                   Table.FieldByName('PRICE1').asstring+#9+
                   Table.FieldByName('SER').AsString+#9+
                   Table.FieldByName('SERTIF').AsString+#9+
                   Table.FieldByName('FIRM').AsString+#9+
                   {Table.FieldByName('dates').AsString+}#9+
                   Table.FieldByName('NUMGTD').AsString+#9+
                   Table.FieldByName('CNTR').AsString+#9+
                   {Table.FieldByName('regn').AsString+}#9;

                if (FBarcode<>nil)
                then Str := Str + FBarcode.asstring;
                Str := Str + #9;

                Str := Str + Table.FieldByName('SUMR').AsString;
                Str := Str + #9;

                if (FPrice_Reg<>nil) and (FPrice_Reg.asFloat <>0)
                then Str := Str +FPrice_Reg.asstring;
                // else оставляем пустым

                data.Add(str);
                Table.Next;
              end;
              
              //data.savetofile('c:\temp\1.sql');

          end
          else begin
            raiseexception('Таблица имеет формат, не согласованный с поставщиком. Обратитесь в техподдержку');
          end;

         finally
            Table.free;
         end;
       end
       
     
       else CreateHintE('Данный формат накладных от Панда не исследован, обратитесь в техподдержку');

     finally
       free
     end;

     createhint('Операция завершена');
 end.
