ba045459a4
Files correlati : ci0.exe ci0400a.msk Ricompilazione Demo : [ ] Commento : Corretta colorazione celle del calendario git-svn-id: svn://10.65.10.50/trunk@18236 c028cbd2-c16b-5b4b-a496-9718f37d4682
513 lines
13 KiB
C++
Executable File
513 lines
13 KiB
C++
Executable File
#include <applicat.h>
|
|
#include <automask.h>
|
|
#include <execp.h>
|
|
#include <relation.h>
|
|
#include <sheet.h>
|
|
#include <utility.h>
|
|
|
|
#include <doc.h>
|
|
|
|
#include "ci0.h"
|
|
#include "cilib.h"
|
|
#include "ci0400.h"
|
|
#include "ci0400a.h"
|
|
#include "ci0400b.h"
|
|
#include "..\ve\velib04.h"
|
|
#include <defmask.h>
|
|
|
|
|
|
///////////////////////////////////////////////////////////
|
|
// TImmissioneDocumenti_app
|
|
///////////////////////////////////////////////////////////
|
|
|
|
// Inizializzazioni
|
|
|
|
void TImmissioneDocumenti_app::init_tabs()
|
|
{
|
|
TImmissioneDocumenti_mask& m = mask();
|
|
|
|
m.filters().destroy();
|
|
m.ordered().reset();
|
|
|
|
TConfig configfile(CONFIG_DITTA, "ci");
|
|
configfile.write_protect(); // Evita che vengan scritti inutili default
|
|
|
|
int items = 0;
|
|
while (items == 0 || configfile.exist("Descr",items))
|
|
{
|
|
const TString& title = configfile.get("Descr", NULL, items, "Fatture");
|
|
m.filters().add(configfile.get("Filter", NULL, items, "F01"));
|
|
m.insert().set(items, configfile.get_bool("InsertRemain", NULL, items));
|
|
m.modify().set(items, configfile.get_bool("ModifyRemain", NULL, items));
|
|
m.doc_coll().set(items, configfile.get_bool("DocColl", NULL, items));
|
|
m.num_coll().add(configfile.get("NumColl", NULL, items), items);
|
|
m.tipo_coll().add(configfile.get("TipoColl", NULL, items), items);
|
|
m.stato_coll().add(configfile.get("StatoColl", NULL, items), items);
|
|
m.var_coll().add(configfile.get("Var", NULL, items), items);
|
|
m.mod_coll().set(items, configfile.get_bool("ModColl", NULL, items));
|
|
m.del_closed().set(items, configfile.get_bool("DeleteClosed", NULL, items));
|
|
m.activate_almanac(F_AL01 + items, title);
|
|
items++;
|
|
}
|
|
}
|
|
|
|
void TImmissioneDocumenti_app::init_flags()
|
|
{
|
|
TImmissioneDocumenti_mask & m = mask();
|
|
const int items = m.filters().items();
|
|
TDate currdate;
|
|
TDate currstart;
|
|
|
|
m.ordered().reset();
|
|
|
|
for(int i = 0; i < items; i++)
|
|
{
|
|
TString filter;
|
|
|
|
filter << "(ANNO==\"" << _year << "\")" << "&&" << "(CODNUM==\"" << m.filters().row(i) << "\")";
|
|
|
|
TRelation relation(LF_DOC);
|
|
TSorted_cursor cursor(&relation, "DATADOC", filter);
|
|
|
|
TCodice_numerazione c(m.filters().row(i));
|
|
|
|
if (!c.dont_test_datadoc())
|
|
m.ordered().set(i);
|
|
|
|
const int items = cursor.items();
|
|
|
|
if (m.flags().items()>i)
|
|
((TBit_array&) m.flags()[i]).reset();
|
|
else
|
|
m.flags().add(new TBit_array(366),i);
|
|
|
|
TBit_array & fl = (TBit_array&) m.flags()[i];
|
|
TDate caput_anni(1, 1, _year);
|
|
for (cursor = 0; cursor.pos() < items; ++cursor)
|
|
{
|
|
const TDate datadoc = relation.lfile().get_date(DOC_DATADOC);
|
|
|
|
if (datadoc.year() == caput_anni.year())
|
|
fl.set(datadoc - caput_anni, 1);
|
|
}
|
|
caput_anni += fl.last_one();
|
|
m.almanac(i).set_insert_date(m.ordered()[i] ? caput_anni : botime);
|
|
}
|
|
}
|
|
|
|
// Overrides
|
|
|
|
bool TImmissioneDocumenti_app::create()
|
|
{
|
|
open_files(LF_DOC, LF_RIGHEDOC, LF_CONDV, LF_RCONDV, LF_ANAMAG, LF_SCONTI, LF_UMART, LF_DESLIN, LF_CODCORR,
|
|
LF_TAB, LF_TABCOM, LF_CLIFO, LF_CFVEN, LF_INDSP, LF_OCCAS, LF_PCON, LF_MOV, LF_STOMAG,
|
|
LF_MOVMAG, LF_RMOVMAG, LF_MAG, LF_SVRIEP, LF_AGENTI, LF_PERCPROV, LF_ATTIV, LF_CAUSALI, 0);
|
|
_mask = new TImmissioneDocumenti_mask();
|
|
|
|
init_tabs();
|
|
init_flags();
|
|
|
|
return TSkeleton_application::create();
|
|
}
|
|
|
|
bool TImmissioneDocumenti_app::destroy()
|
|
{
|
|
delete _mask;
|
|
|
|
return TSkeleton_application::destroy();
|
|
}
|
|
|
|
void TImmissioneDocumenti_app::main_loop()
|
|
{
|
|
while (_mask->run() != K_QUIT);
|
|
}
|
|
|
|
// Chiamate dalla maschera
|
|
|
|
void TImmissioneDocumenti_app::change_year(int newyear, bool init_flg)
|
|
{
|
|
_year = newyear;
|
|
if (init_flg)
|
|
init_flags();
|
|
}
|
|
|
|
bool TImmissioneDocumenti_app::has_documents(int currpage, const TDate& day)
|
|
{
|
|
const int year = day.year();
|
|
if (year != _year)
|
|
change_year(year, true);
|
|
const TDate caput_anni(1, 1, _year);
|
|
return (((TBit_array&) _mask->flags()[currpage])[day - caput_anni]);
|
|
}
|
|
|
|
///////////////////////////////////////////////////////////
|
|
// TImmissioneDocumenti_mask
|
|
///////////////////////////////////////////////////////////
|
|
|
|
// Routines Proprietarie
|
|
|
|
void TImmissioneDocumenti_mask::next_page(int p)
|
|
{
|
|
TMask::next_page(p);
|
|
|
|
const int k = (p < 1000) ? curr_page() : p-1000;
|
|
enable(DLG_DELREC, del_closed()[k]);
|
|
}
|
|
|
|
void TImmissioneDocumenti_mask::open_day_mask(const TDate & date_mask)
|
|
{
|
|
TDate d(date_mask);
|
|
if (!d.ok())
|
|
d = almanac().selected_date();
|
|
|
|
const int currpage = curr_page();
|
|
|
|
const TString & codnum = filters().row(currpage);
|
|
TString filter;
|
|
|
|
filter << "(ANSI(DATADOC)==\"" << d.string(ANSI) << "\")" << "&&" << "(CODNUM==\"" << codnum << "\")";
|
|
|
|
TRelation relation(LF_DOC);
|
|
relation.add(LF_CLIFO, "TIPOCF==TIPOCF|CODCF==CODCF");
|
|
|
|
TCursor cursor(&relation, filter);
|
|
|
|
if (!almanac().can_insert(d) && is_date_void(currpage, d))
|
|
return;
|
|
|
|
TCursor_sheet sheet(&cursor,
|
|
"ANNO|CODNUM|TIPODOC|NUMDOCRIF|STATO|DATADOCRIF|NDOC|20->RAGSOC",
|
|
TR("Selezione documenti"),
|
|
HR("Anno|Num.|Tipo|Docum.Rif.|Stato|Data@10|Documento|Ragione Sociale@50"),
|
|
almanac().can_insert(d) ? 0x02|0x04 : 0x04, 3);
|
|
TList_field& fl = sheet.add_list(101, 0, "Tipo documento ", 1, 1, 60);
|
|
TToken_string codes;
|
|
TToken_string values;
|
|
TCodice_numerazione c(codnum);
|
|
const int items = c.ntipi_doc();
|
|
|
|
for (int i = 0; i < items; i++)
|
|
{
|
|
const TString16 codtipo(c.tipo_doc(i));
|
|
const TTipo_documento t(codtipo);
|
|
|
|
codes.add(codtipo);
|
|
|
|
TString80 str;
|
|
str << codtipo << " - " << t.descrizione();
|
|
values.add(str);
|
|
}
|
|
fl.replace_items(codes, values);
|
|
fl.enable(items > 1);
|
|
|
|
KEY exitval;
|
|
|
|
while ((exitval = sheet.run()) != K_ESC)
|
|
{
|
|
switch(exitval)
|
|
{
|
|
case K_ENTER:
|
|
call_ve0(exitval, relation, d, codnum, EMPTY_STRING, currpage);
|
|
break;
|
|
case K_DEL:
|
|
call_ve0(exitval, relation, d, codnum);
|
|
break;
|
|
case K_INS:
|
|
{
|
|
const TString16 tipo(sheet.get(101));
|
|
|
|
call_ve0(exitval, relation, d, codnum, tipo, currpage);
|
|
}
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
update_current_calendar(d.year());
|
|
}
|
|
|
|
void TImmissioneDocumenti_mask::update_current_calendar(int year)
|
|
{
|
|
TDate caput_anni(1, 1, year);
|
|
const int currpage = curr_page();
|
|
TBit_array & dayfl = (TBit_array&) flags()[currpage];
|
|
TString filter;
|
|
|
|
dayfl.reset();
|
|
filter.cut(0);
|
|
filter << "(ANNO==\"" << year << "\")" << "&&" << "(CODNUM==\"" << filters().row(currpage) << "\")";
|
|
|
|
TRelation relation(LF_DOC);
|
|
|
|
TCursor cursor(&relation, filter);
|
|
cursor.setfilter(filter);
|
|
|
|
const int doc_items = cursor.items();
|
|
|
|
for (cursor = 0; cursor.pos() < doc_items; ++cursor)
|
|
{
|
|
const TDate datadoc = relation.lfile().get_date(DOC_DATADOC);
|
|
if (datadoc.year() == year)
|
|
dayfl.set(datadoc - caput_anni, 1);
|
|
}
|
|
if (ordered()[currpage])
|
|
{
|
|
caput_anni += dayfl.last_one();
|
|
almanac(currpage).set_insert_date(caput_anni);
|
|
}
|
|
almanac().force_update();
|
|
}
|
|
|
|
void TImmissioneDocumenti_mask::call_ve0(int exitval, TRelation& relation, const TDate& date, const TString& codnum, const TString& doctype, byte currpage)
|
|
{
|
|
TFilename tempfile;
|
|
tempfile.temp("", "ini");
|
|
|
|
{
|
|
TConfig configfile(tempfile);
|
|
|
|
switch(exitval)
|
|
{
|
|
case K_ENTER:
|
|
configfile.set("Action", "Modify", "Transaction");
|
|
if (modify()[currpage])
|
|
configfile.set("Mode", "R", "Transaction");
|
|
configfile.set("NDOC", relation.lfile().get(DOC_NDOC), "33");
|
|
break;
|
|
case K_DEL:
|
|
configfile.set("Action", "Delete", "Transaction");
|
|
configfile.set("NDOC", relation.lfile().get(DOC_NDOC), "33");
|
|
break;
|
|
case K_INS:
|
|
configfile.set("Action", "Insert", "Transaction");
|
|
if (insert()[currpage])
|
|
configfile.set("Mode", "R", "Transaction");
|
|
configfile.set("DATADOC", date.string(), "33");
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
configfile.set(DOC_PROVV, "D", "33");
|
|
configfile.set(DOC_ANNO, date.year(), "33");
|
|
configfile.set(DOC_CODNUM, codnum, "33");
|
|
configfile.set(DOC_TIPODOC, doctype, "33");
|
|
}
|
|
|
|
TString commandline;
|
|
|
|
commandline.format("ve0 -0 /i%s",(const char*)tempfile);
|
|
|
|
TExternal_app ve(commandline);
|
|
ve.run();
|
|
|
|
if (doc_coll()[currpage])
|
|
{
|
|
TDocumento doc;
|
|
TLocalisamfile documenti(LF_DOC);
|
|
long recno;
|
|
long ndoc_coll = 0L;
|
|
bool new_doc = false;
|
|
|
|
{
|
|
TConfig configfile(tempfile);
|
|
|
|
recno = configfile.get_long("Record", "Transaction");
|
|
if (recno > 0L)
|
|
{
|
|
doc.head().readat(documenti, recno);
|
|
doc.read();
|
|
|
|
|
|
const TString16 num_coll(num_coll().row(currpage));
|
|
const TString16 tipo_coll(tipo_coll().row(currpage));
|
|
const TString16 stato_coll(stato_coll().row(currpage));
|
|
const long ndoc = doc.get_long(DOC_NDOC);
|
|
|
|
TLocalisamfile rdoc(LF_RIGHEDOC);
|
|
rdoc.setkey(4);
|
|
rdoc.put(RDOC_DAPROVV, "D");
|
|
rdoc.put(RDOC_DAANNO, date.year());
|
|
rdoc.put(RDOC_DACODNUM, codnum);
|
|
rdoc.put(RDOC_DANDOC, ndoc);
|
|
|
|
new_doc = rdoc.read(_isgteq) != NOERR;
|
|
|
|
if (!new_doc)
|
|
{
|
|
bool new_doc = (rdoc.get(RDOC_DAPROVV) != "D");
|
|
|
|
new_doc |= (rdoc.get_int(RDOC_DAANNO) != date.year());
|
|
new_doc |= (rdoc.get(RDOC_DACODNUM) != codnum);
|
|
new_doc |= (rdoc.get_long(RDOC_DANDOC) != ndoc);
|
|
|
|
if (!new_doc)
|
|
ndoc_coll = rdoc.get_long(RDOC_NDOC);
|
|
}
|
|
|
|
configfile.set(DOC_CODNUM, num_coll, "33");
|
|
configfile.set(DOC_TIPODOC, tipo_coll, "33");
|
|
|
|
if (exitval == K_DEL)
|
|
configfile.set("Action", "Delete", "Transaction");
|
|
else
|
|
{
|
|
TDocumento doc_coll('D', date.year(), num_coll, ndoc_coll);
|
|
|
|
configfile.set("Action", "Modify", "Transaction");
|
|
configfile.set("Mode", "", "Transaction");
|
|
configfile.set_paragraph("33");
|
|
configfile.remove("STATO"); // creato dalla transazione precedente ???
|
|
|
|
if (new_doc)
|
|
{
|
|
TToken_string var(var_coll().row(currpage), ' ');
|
|
|
|
doc_coll.copy_contents(doc);
|
|
|
|
for (const char * field = var.get(0); field && *field; field = var.get())
|
|
doc_coll.zero(field);
|
|
doc_coll.put(DOC_STATO, stato_coll);
|
|
doc_coll.write();
|
|
ndoc_coll = doc_coll.get_long(DOC_NDOC);
|
|
}
|
|
else
|
|
{
|
|
TString_array vals;
|
|
TToken_string var(var_coll().row(currpage), ' ');
|
|
const char * field;
|
|
|
|
var.add(DOC_STATO);
|
|
for (field = var.get(0); field && *field; field = var.get())
|
|
vals.add(doc_coll.get(field));
|
|
|
|
doc_coll.copy_contents(doc);
|
|
|
|
int i = 0;
|
|
|
|
for (field = var.get(0); field && *field; field = var.get())
|
|
doc_coll.put(field, vals.row(i++));
|
|
doc_coll.rewrite();
|
|
|
|
if (!mod_coll()[currpage])
|
|
ndoc_coll = 0L;
|
|
}
|
|
}
|
|
configfile.set(DOC_NDOC, ndoc_coll, "33");
|
|
}
|
|
}
|
|
if (ndoc_coll > 0L)
|
|
ve.run();
|
|
}
|
|
|
|
remove_file(tempfile);
|
|
}
|
|
|
|
// Richiami all'applicazione
|
|
|
|
void TImmissioneDocumenti_mask::change_year(int newyear)
|
|
{
|
|
immissione_documenti_app().change_year(newyear);
|
|
}
|
|
|
|
bool TImmissioneDocumenti_mask::is_date_void(int currpage, const TDate& cdate)
|
|
{
|
|
return !(immissione_documenti_app().has_documents(currpage, cdate));
|
|
}
|
|
|
|
bool delete_closed(const TRelation& rel, void* pJolly)
|
|
{
|
|
TDocumento & doc = (TDocumento &) rel.lfile().curr();
|
|
const int rows = doc.physical_rows();
|
|
bool closed = true;
|
|
TBit_array rows2delete;
|
|
|
|
for (int i = 1; i <= rows; i++)
|
|
{
|
|
const char t = doc[i].tipo().tipo();
|
|
if (t == RIGA_SCONTI || t == RIGA_OMAGGI || t == RIGA_DESCRIZIONI)
|
|
continue;
|
|
const TString & codcms = doc[i].codice_commessa();
|
|
const TRectype & cms = cache().get(LF_COMMESSE, codcms);
|
|
const bool closed_row = cms.get_bool("CHIUSA");
|
|
|
|
rows2delete.set(i, closed_row);
|
|
closed &= closed_row;
|
|
}
|
|
if (closed)
|
|
{
|
|
doc.stato('9');
|
|
doc.remove();
|
|
}
|
|
else
|
|
if (rows2delete.first_one() >= 0)
|
|
{
|
|
for (int i = rows; i >= 1 ; i--)
|
|
{
|
|
if (rows2delete[i])
|
|
doc.destroy_row(i, true);
|
|
}
|
|
doc.rewrite();
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
bool TImmissioneDocumenti_mask::on_field_event(TOperable_field& o, TField_event e, long jolly)
|
|
{
|
|
switch (o.dlg())
|
|
{
|
|
case DLG_DELREC:
|
|
if (e == fe_button)
|
|
{
|
|
TString descr;
|
|
TMask selection("ci0400b");
|
|
const int pos = id2pos(31000 + 100 * curr_page());
|
|
if (pos >= 0)
|
|
descr = fld(pos).prompt();
|
|
if (selection.run() == K_ENTER &&
|
|
yesno_box("Attenzione !! vuoi cancellare i documenti %s\n delle commesse chiuse", (const char *) descr) &&
|
|
yesno_box("Attenzione !! vuoi veramente cancellare i documenti %s\n delle commesse chiuse", (const char *) descr))
|
|
{
|
|
TRectype from(LF_DOC);
|
|
const TDate fromdate = selection.get_date(F_DA_DATA);
|
|
|
|
if (fromdate.ok())
|
|
from.put(DOC_DATADOC, fromdate);
|
|
|
|
TRectype to(LF_DOC);
|
|
const TDate todate = selection.get_date(F_A_DATA);
|
|
|
|
if (todate.ok())
|
|
to.put(DOC_DATADOC, todate);
|
|
|
|
TString filter;
|
|
|
|
filter.format("CODNUM==\"%s\"", (const char *) filters().row(curr_page()));
|
|
|
|
TCursor d(new TRelation(LF_DOC), filter, 3, &from, &to);
|
|
|
|
d.relation()->lfile().set_curr(new TDocumento());
|
|
d.scan(delete_closed, NULL, "Cancellazione documenti commesse chiuse");
|
|
update_current_calendar(selected_day().year());
|
|
}
|
|
}
|
|
break;
|
|
default:
|
|
TAlmanac_mask::on_field_event(o, e, jolly);
|
|
break;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
///////////////////////////////////////////////////////////
|
|
// Main
|
|
///////////////////////////////////////////////////////////
|
|
|
|
int ci0400(int argc, char* argv[])
|
|
{
|
|
TImmissioneDocumenti_app a ;
|
|
a.run(argc, argv, TR("Immissione Documenti"));
|
|
return 0;
|
|
}
|