diff --git a/www/app/entity/doc/goodsissue.php b/www/app/entity/doc/goodsissue.php index 36988627f..fe0d57010 100644 --- a/www/app/entity/doc/goodsissue.php +++ b/www/app/entity/doc/goodsissue.php @@ -3,6 +3,7 @@ namespace App\Entity\Doc; use App\Entity\Entry; +use App\Entity\Item; use App\Helper as H; /** @@ -85,7 +86,6 @@ public function generateReport() { } public function Execute() { - //$conn = \ZDB\DB::getConnect(); $k = 1; //учитываем скидку if ($this->headerdata["paydisc"] > 0 && $this->amount > 0) { @@ -93,6 +93,28 @@ public function Execute() { } $amount = 0; foreach ($this->unpackDetails('detaildata') as $item) { + + + //оприходуем с производства + if( $this->headerdata['fromprod'] ==1 && $item->item_type==Item::TYPE_PROD) { + $price = $item->getProdprice() ; + + if($price ==0){ + throw new \Exception(H::l('noselfprice',$item->itemname)) ; + + } + $stock = \App\Entity\Stock::getStock($this->headerdata['store'], $item->item_id, $price, $item->snumber, $item->sdate, true); + + $sc = new Entry($this->document_id, $item->quantity * $price, $item->quantity); + $sc->setStock($stock->stock_id); + + + $sc->save(); + + } + + + //продажа $listst = \App\Entity\Stock::pickup($this->headerdata['store'], $item); foreach ($listst as $st) { @@ -102,8 +124,18 @@ public function Execute() { $sc->save(); $amount += $item->price * $k * $st->quantity; } + + + + } + + + + + + //списываем бонусы if ($this->headerdata['paydisc'] > 0 && $this->customer_id > 0) { $customer = \App\Entity\Customer::load($this->customer_id); diff --git a/www/app/entity/doc/prodreceipt.php b/www/app/entity/doc/prodreceipt.php index ad89a9b7b..4b9bb1e6e 100644 --- a/www/app/entity/doc/prodreceipt.php +++ b/www/app/entity/doc/prodreceipt.php @@ -55,20 +55,45 @@ public function generateReport() { public function Execute() { $types = array(); $common = \App\System::getOptions("common"); - - //аналитика + $parts = array(); + + foreach ($this->unpackDetails('detaildata') as $item) { - $listst = \App\Entity\Stock::pickup($this->headerdata['store'], $item); - - foreach ($listst as $st) { - $sc = new Entry($this->document_id, $st->quantity * $item->price, $st->quantity); - $sc->setStock($st->stock_id); - $sc->save(); - } + + $stock = \App\Entity\Stock::getStock($this->headerdata['store'], $item->item_id, $item->price, $item->snumber, $item->sdate, true); - } + $sc = new Entry($this->document_id, $item->quantity * $item->price, $item->quantity); + $sc->setStock($stock->stock_id); + // $sc->setExtCode($item->price); //Для АВС + + $sc->save(); + + $set = \App\Entity\ItemSet::find("pitem_id=" . $item->item_id); + foreach($set as $part) { + if( isset($parts[$part->item_id])==false) $parts[$part->item_id] =0; + $parts[$part->item_id] += $part->qty; + } + + + } + // списываем в производство + if($this->headerdata['storefrom'] >0) { + foreach($parts as $id=>$qty) { + $item = \App\Entity\Item::load($id); + $item->quantity = $qty; + $listst = \App\Entity\Stock::pickup($this->headerdata['storefrom'], $item); + + foreach ($listst as $st) { + $sc = new Entry($this->document_id, 0 - $st->quantity * $st->partion, 0 - $st->quantity); + $sc->setStock($st->stock_id); + + $sc->save(); + } + + } + } return true; } diff --git a/www/app/entity/item.php b/www/app/entity/item.php index 4174f756a..63aa3082a 100644 --- a/www/app/entity/item.php +++ b/www/app/entity/item.php @@ -453,7 +453,9 @@ public function getProdprice(){ $price += ($iset->qty * $pr); } } - + if($price==0) { //ищем последнюю партию + $pr = $this->getLastPartion(0); + } return $price; } diff --git a/www/app/entity/stock.php b/www/app/entity/stock.php index dfa9e3707..ced721942 100644 --- a/www/app/entity/stock.php +++ b/www/app/entity/stock.php @@ -163,7 +163,7 @@ public static function pickup($store_id, $item) { $last = self::getFirst($where, ' stock_id desc '); if ($last == null) { $conn = \ZDB\DB::getConnect(); - $lastpartion = $conn->GetOne("select coalesce(partion,0) from store_stock where qty > 0 and item_id={$item_id} order by stock_id desc limit 0,1 ") ; + $lastpartion = $conn->GetOne("select coalesce(partion,0) from store_stock where qty > 0 and item_id={$item->item_id} order by stock_id desc limit 0,1 ") ; if($lastpartion==0) $lastpartion= $price; $last = new Stock(); diff --git a/www/app/entity/user.php b/www/app/entity/user.php index a6c2fe6d1..10f6e98cc 100644 --- a/www/app/entity/user.php +++ b/www/app/entity/user.php @@ -20,6 +20,7 @@ protected function init() { $this->user_id = 0; $this->defstore = 0; $this->defmf = 0; + $this->deffirm = 0; $this->hidesidebar = 0; $this->pagesize = 25; $this->createdon = time(); diff --git a/www/app/pages/base.php b/www/app/pages/base.php index 318160684..708b2891d 100644 --- a/www/app/pages/base.php +++ b/www/app/pages/base.php @@ -114,6 +114,10 @@ public function __construct($params = null) { $this->_tvars["hidesidebar"] = $user->hidesidebar == 1 ? 'hold-transition sidebar-collapse' : 'hold-transition sidebar-mini sidebar-collapse'; //для скрытия блока разметки в шаблоне страниц $this->_tvars["hideblock"] = false; + + + $this->generateTosats(); + } public function LogoutClick($sender) { @@ -215,5 +219,23 @@ public function addJavaScript($js, $docready = false) { public function goDocView() { $this->goAnkor('dankor'); } - + + private function generateTosats() { + + $this->_tvars["toasts"] = array(); + if(\App\Session::getSession()->toasts == true) return;//уже показан + + $user = System::getUser() ; + if($user->defstore ==0) { + $this->_tvars["toasts"][] = array('title'=>"title:\"".Helper::l("nodefstore")."\"") ; + } + if($user->deffirm ==0) { + $this->_tvars["toasts"][] = array('title'=>"title:\"".Helper::l("nodeffirm")."\"") ; + } + if($user->defmf ==0) { + $this->_tvars["toasts"][] = array('title'=>"title:\"".Helper::l("nodefmf")."\"") ; + } + + \App\Session::getSession()->toasts = true; + } } diff --git a/www/app/pages/doc/goodsissue.php b/www/app/pages/doc/goodsissue.php index 851be81de..1bc616668 100644 --- a/www/app/pages/doc/goodsissue.php +++ b/www/app/pages/doc/goodsissue.php @@ -18,6 +18,7 @@ use Zippy\Html\Form\DropDownChoice; use Zippy\Html\Form\Form; use Zippy\Html\Form\SubmitButton; +use Zippy\Html\Form\CheckBox; use Zippy\Html\Form\TextInput; use Zippy\Html\Label; use Zippy\Html\Link\ClickLink; @@ -86,6 +87,7 @@ public function __construct($docid = 0, $basedocid = 0) { $this->docform->add(new TextInput('order')); $this->docform->add(new TextInput('notes')); + $this->docform->add(new CheckBox('fromprod')); $cp = \App\Session::getSession()->clipboard; $this->docform->add(new ClickLink('paste', $this, 'onPaste'))->setVisible(is_array($cp) && count($cp) > 0); @@ -133,6 +135,7 @@ public function __construct($docid = 0, $basedocid = 0) { $this->docform->total->setText($this->_doc->amount); $this->docform->document_date->setDate($this->_doc->document_date); + $this->docform->fromprod->setChecked($this->_doc->headerdata['fromprod']); $this->docform->payment->setValue($this->_doc->headerdata['payment']); $this->docform->payamount->setText($this->_doc->payamount); @@ -306,7 +309,7 @@ public function __construct($docid = 0, $basedocid = 0) { $this->_tvars['manlist'][] = array('mitem' => $man); } - + $this->checkProd(); } public function detailOnRow($row) { @@ -347,7 +350,8 @@ public function deleteOnClick($sender) { $this->docform->detail->Reload(); $this->calcTotal(); $this->calcPay(); - } + $this->checkProd(); + } public function addrowOnClick($sender) { $this->editdetail->setVisible(true); @@ -544,6 +548,7 @@ public function saverowOnClick($sender) { $this->editdetail->editserial->setText(""); $this->calcTotal(); $this->calcPay(); + $this->checkProd(); } public function cancelrowOnClick($sender) { @@ -611,6 +616,7 @@ public function savedocOnClick($sender) { $this->_doc->headerdata['store_name'] = $this->docform->store->getValueName(); $this->_doc->headerdata['pricetype'] = $this->docform->pricetype->getValue(); $this->_doc->headerdata['pricetypename'] = $this->docform->pricetype->getValueName(); + $this->_doc->headerdata['fromprod'] = $this->docform->fromprod->isChecked() ?1:0; $this->_doc->headerdata['order_id'] = $this->_orderid; $this->_doc->packDetails('detaildata', $this->_itemlist); @@ -1007,6 +1013,20 @@ public function onPaste($sender) { $this->calcPay(); } + public function checkProd(){ + $this->docform->fromprod->setVisible(false); + foreach ($this->_itemlist as $item) { + if($item->item_type == Item::TYPE_PROD) { + $this->docform->fromprod->setVisible(true); + + return; + } + + } + + + } + } diff --git a/www/app/pages/doc/ordercust.php b/www/app/pages/doc/ordercust.php index 050dd1c19..9c225b999 100644 --- a/www/app/pages/doc/ordercust.php +++ b/www/app/pages/doc/ordercust.php @@ -128,10 +128,10 @@ public function detailOnRow($row) { $row->add(new Label('desc', $item->desc)); $row->add(new Label('amount', H::fa($item->quantity * $item->price))); - $row->add(new ClickLink('edit'))->onClick($this, 'editOnClick'); + $row->add(new SubmitLink('edit'))->onClick($this, 'editOnClick'); $row->edit->setVisible($item->old != true); - $row->add(new ClickLink('delete'))->onClick($this, 'deleteOnClick'); + $row->add(new SubmitLink('delete'))->onClick($this, 'deleteOnClick'); } public function editOnClick($sender) { diff --git a/www/app/pages/doc/prodreceipt.php b/www/app/pages/doc/prodreceipt.php index f2de4ba40..e6c1d3a32 100644 --- a/www/app/pages/doc/prodreceipt.php +++ b/www/app/pages/doc/prodreceipt.php @@ -41,6 +41,7 @@ public function __construct($docid = 0, $basedocid = 0) { $this->docform->add(new Date('document_date'))->setDate(time()); $this->docform->add(new DropDownChoice('parea', \App\Entity\Prodarea::findArray("pa_name", ""), 0)); $this->docform->add(new DropDownChoice('store', Store::getList(), H::getDefStore())); + $this->docform->add(new DropDownChoice('storefrom', Store::getList(), H::getDefStore())); $this->docform->add(new TextInput('notes')); @@ -72,6 +73,7 @@ public function __construct($docid = 0, $basedocid = 0) { $this->docform->parea->setValue($this->_doc->headerdata['parea']); $this->docform->store->setValue($this->_doc->headerdata['store']); + $this->docform->storefrom->setValue($this->_doc->headerdata['storefrom']); $this->_itemlist = $this->_doc->unpackDetails('detaildata'); @@ -84,6 +86,7 @@ public function __construct($docid = 0, $basedocid = 0) { $this->_basedocid = $basedocid; if ($basedoc->meta_name == 'ProdReceipt') { $this->docform->store->setValue($basedoc->headerdata['store']); + $this->docform->storefrom->setValue($basedoc->headerdata['storefrom']); $this->docform->parea->setValue($basedoc->headerdata['parea']); $this->_itemlist = $basedoc->unpackDetails('detaildata'); @@ -264,6 +267,7 @@ public function savedocOnClick($sender) { $this->_doc->headerdata['parea'] = $this->docform->parea->getValue(); $this->_doc->headerdata['pareaname'] = $this->docform->parea->getValueName(); $this->_doc->headerdata['store'] = $this->docform->store->getValue(); + $this->_doc->headerdata['storefrom'] = $this->docform->storefrom->getValue(); $this->_doc->packDetails('detaildata', $this->_itemlist); diff --git a/www/app/pages/reference/itemlist.php b/www/app/pages/reference/itemlist.php index 33307f645..ba20446cf 100644 --- a/www/app/pages/reference/itemlist.php +++ b/www/app/pages/reference/itemlist.php @@ -431,7 +431,7 @@ public function OnAutoSet($sender) { } $in .= ")"; - return Item::findArray('itemname', "coalesce(item_type,0) <> 1 and coalesce(item_type,0) <>3 and item_id not in {$in} and (itemname like {$text} or item_code like {$text}) and disabled <> 1", 'itemname'); + return Item::findArray('itemname', "coalesce(item_type,0) in (2,5) and item_id not in {$in} and (itemname like {$text} or item_code like {$text}) and disabled <> 1", 'itemname'); } public function OnAddSet($sender) { diff --git a/www/app/pages/register/gilist.php b/www/app/pages/register/gilist.php index f7b6e4a65..6aabda897 100644 --- a/www/app/pages/register/gilist.php +++ b/www/app/pages/register/gilist.php @@ -236,7 +236,7 @@ public function updateStatusButtons() { $this->statuspan->statusform->closeorder->setVisible(false); if ($this->_doc->headerdata['order_id'] > 0) { $order = Document::load($this->_doc->headerdata['order_id']); - if ($order->payamount == $order->payed) { + if ($order->payamount == $order->payed || $order->headerdata['payment']==0) { $this->statuspan->statusform->closeorder->setVisible(true); } } diff --git a/www/app/pages/register/orderlist.php b/www/app/pages/register/orderlist.php index bbf6911a7..d56effddf 100644 --- a/www/app/pages/register/orderlist.php +++ b/www/app/pages/register/orderlist.php @@ -266,7 +266,7 @@ public function updateStatusButtons() { $this->statuspan->statusform->bttn->setVisible(true); $this->statuspan->statusform->binv->setVisible(false); - $this->statuspan->statusform->bgi->setVisible(false); + $this->statuspan->statusform->bgi->setVisible(true); $this->statuspan->statusform->btask->setVisible(false); } diff --git a/www/app/pages/report/prod.php b/www/app/pages/report/prod.php index b5e06e3a8..3b6f1ddb8 100644 --- a/www/app/pages/report/prod.php +++ b/www/app/pages/report/prod.php @@ -81,8 +81,8 @@ private function generateReport() { join `items` i on e.`item_id` = i.`item_id` join `documents_view` d on d.`document_id` = e.`document_id` - where e.`item_id` >0 and e.`quantity` <>0 - and d.`meta_name` in ('ProdIssue') + where e.`item_id` >0 and e.`quantity` < 0 + and d.`meta_name` in ('ProdIssue','ProdReceipt') {$wparea} AND DATE(e.document_date) >= " . $conn->DBDate($from) . " AND DATE(e.document_date) <= " . $conn->DBDate($to) . " @@ -108,8 +108,8 @@ private function generateReport() { join `items` i on e.`item_id` = i.`item_id` join `documents_view` d on d.`document_id` = e.`document_id` - where e.`item_id` >0 and e.`quantity` <>0 - and d.`meta_name` in ('ProdReceipt') + where e.`item_id` >0 and e.`quantity` >0 + and d.`meta_name` in ('GoodsIssue','ProdIssue','ProdReceipt') AND DATE(e.document_date) >= " . $conn->DBDate($from) . " AND DATE(e.document_date) <= " . $conn->DBDate($to) . " diff --git a/www/app/pages/userlogin.php b/www/app/pages/userlogin.php index e3efc3c61..e24e8a312 100644 --- a/www/app/pages/userlogin.php +++ b/www/app/pages/userlogin.php @@ -86,6 +86,7 @@ public function onsubmit($sender) { $user = Helper::login($login, $password); if ($user instanceof User) { + \App\Session::getSession()->clean() ; $user->lastlogin = time(); $user->save(); System::setUser($user); @@ -96,7 +97,7 @@ public function onsubmit($sender) { setcookie("remember", $user->user_id . '_' . md5($user->user_id . $_config['common']['salt']), time() + 60 * 60 * 24 * 30); } - //$logger->info('Logined ' . $user->userlogin . ', ' . $_SERVER["REMOTE_ADDR"]); + if ($_config['modules']['shop'] == 1) { App::Redirect('\App\Pages\Main'); } else { diff --git a/www/app/session.php b/www/app/session.php index 15e79a4c1..8e96d2e5c 100644 --- a/www/app/session.php +++ b/www/app/session.php @@ -36,4 +36,9 @@ public static function getSession() { return $_SESSION['App_session']; } + public function clean(){ + $this->values = array(); + $this->filter = array(); + + } } diff --git a/www/assets/css/app.css b/www/assets/css/app.css index ce153fd61..549cb85bd 100644 --- a/www/assets/css/app.css +++ b/www/assets/css/app.css @@ -111,4 +111,7 @@ body { table { font-family: "Arial" } - \ No newline at end of file +.toast-header { + + background-color: #fff; +} \ No newline at end of file diff --git a/www/templates/lang.json b/www/templates/lang.json index b7bc3bdb9..a992366b7 100644 --- a/www/templates/lang.json +++ b/www/templates/lang.json @@ -393,6 +393,10 @@ "paymentseq": "Счета одинаковые" , "custcreated": "Добавлен %s пользователем %s", "custlastdoc": "Последний документ %s от %s. Всего %s" , - "enterleadsource": "Не введен источник лида", - "enterleadstatus": "Не введено состояние лида" + "noselfprice": "Не расчитана себестоимость готовой продукции %s", + "enterleadsource": "Не введен источник лида", + "enterleadstatus": "Не введено состояние лида", + "nodefstore": "Укажите в профиле склад по умолчанию", + "nodefmf": "Укажите в профиле кассу по умолчанию", + "nodeffirm": "Укажите в профиле компанию по умолчанию" } \ No newline at end of file diff --git a/www/templates/pages/base.html b/www/templates/pages/base.html index 0c2c6579f..e1ef456e1 100644 --- a/www/templates/pages/base.html +++ b/www/templates/pages/base.html @@ -731,6 +731,9 @@
_______________
+ + +
@@ -757,6 +760,9 @@
_______________
+ + +
@@ -766,10 +772,24 @@
_______________
+ +