File: postPoReturnCreditMemo.cpp

package info (click to toggle)
postbooks 4.10.0-2
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 112,660 kB
  • ctags: 22,890
  • sloc: cpp: 310,358; sh: 607; xml: 214; python: 140; awk: 104; makefile: 50
file content (88 lines) | stat: -rw-r--r-- 2,883 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*
 * This file is part of the xTuple ERP: PostBooks Edition, a free and
 * open source Enterprise Resource Planning software suite,
 * Copyright (c) 1999-2014 by OpenMFG LLC, d/b/a xTuple.
 * It is licensed to you under the Common Public Attribution License
 * version 1.0, the full text of which (including xTuple-specific Exhibits)
 * is available at www.xtuple.com/CPAL.  By using this software, you agree
 * to be bound by its terms.
 */

#include "postPoReturnCreditMemo.h"

#include <QVariant>
#include <QMessageBox>
#include <openreports.h>
#include "errorReporter.h"

postPoReturnCreditMemo::postPoReturnCreditMemo(QWidget* parent, const char* name, bool modal, Qt::WindowFlags fl)
    : XDialog(parent, name, modal, fl)
{
  setupUi(this);

  connect(_post, SIGNAL(clicked()), this, SLOT(sPost()));

  _qty->setPrecision(omfgThis->qtyVal());

  _porejectid = -1;
}

postPoReturnCreditMemo::~postPoReturnCreditMemo()
{
  // no need to delete child widgets, Qt does it all for us
}

void postPoReturnCreditMemo::languageChange()
{
  retranslateUi(this);
}

enum SetResponse postPoReturnCreditMemo::set(const ParameterList & pParams)
{
  XSqlQuery postet;
  XDialog::set(pParams);
  QVariant param;
  bool     valid;

  param = pParams.value("poreject_id", &valid);
  if(valid)
  {
    _porejectid = param.toInt();
    postet.prepare("SELECT pohead_curr_id,"
              "       COALESCE(item_number, poitem_vend_item_number) AS itemnumber,"
              "       poreject_qty,"
              "       (COALESCE(recv_purchcost, poitem_unitprice) * poreject_qty) AS itemAmount"
              "  FROM poreject JOIN poitem ON (poitem_id=poreject_poitem_id)"
              "                JOIN pohead ON (pohead_id=poitem_pohead_id)"
              "                LEFT OUTER JOIN itemsite ON (poitem_itemsite_id=itemsite_id)"
              "                LEFT OUTER JOIN item ON (itemsite_item_id=item_id)"
              "                LEFT OUTER JOIN recv ON (recv_id=poreject_recv_id) "
              " WHERE (poreject_id=:poreject_id);");
    postet.bindValue(":poreject_id", _porejectid);
    postet.exec();
    if(postet.first())
    {
      _item->setText(postet.value("itemNumber").toString());
      _qty->setDouble(postet.value("poreject_qty").toDouble());
      _amount->set(postet.value("itemAmount").toDouble(), postet.value("pohead_curr_id").toInt(), QDate::currentDate(), false);
    }
  }

  return NoError;
}

void postPoReturnCreditMemo::sPost()
{
  XSqlQuery postPost;
  postPost.prepare("SELECT postPoReturnCreditMemo(:poreject_id, :amount) AS result;");
  postPost.bindValue(":poreject_id", _porejectid);
  postPost.bindValue(":amount", _amount->localValue());
  if(!postPost.exec())
  {
    ErrorReporter::error(QtCriticalMsg, this, tr("Error Posting Credit Memo"),
                         postPost, __FILE__, __LINE__);
    return;
  }

  accept();
}