本文整理匯總了PHP中DataObject::get_rel方法的典型用法代碼示例。如果您正苦於以下問題:PHP DataObject::get_rel方法的具體用法?PHP DataObject::get_rel怎麽用?PHP DataObject::get_rel使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類DataObject
的用法示例。
在下文中一共展示了DataObject::get_rel方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: anular
function anular($numero)
{
$this->rapyd->load('dataobject');
$error = '';
$do = new DataObject("bi_trasla");
$do->rel_one_to_many('bi_ittrasla', 'bi_ittrasla', array('numero' => 'numero'));
$do->load($numero);
$tipo = $do->get('tipo');
$alma = $do->get('alma');
if ($tipo == 'I') {
$recibe = '0000';
} elseif ($tipo == 'D') {
$recibe = $alma;
}
$recibe = $this->db->escape($recibe);
$sta = $do->get('status');
if ($sta == 'C') {
for ($i = 0; $i < $do->count_rel('bi_ittrasla'); $i++) {
$bien = $do->get_rel('bi_ittrasla', 'bien', $i);
$tabla = substr($bien, 0, 1);
$bien = $this->db->escape($bien);
$this->db->query("UPDATE " . $this->tablas[$tabla] . " SET alma={$recibe} WHERE id={$bien}");
}
} else {
$error .= "<div class='alert'><p>No se puede realizar la operacion para la transferencia {$numero} </p></div>";
}
if (empty($error)) {
$do->set('status', 'A');
$do->save();
logusu('bi_trasla', "Anulo bi_traslado {$numero}");
redirect($this->url . "/dataedit/show/{$numero}");
} else {
$data['content'] = $error . anchor($this->url . "/dataedit/show/{$numero}", 'Regresar');
$data['title'] = $this->tits;
$data["head"] = $this->rapyd->get_head();
$this->load->view('view_ventanas', $data);
}
}
示例2: actualizar
function actualizar($id)
{
$this->rapyd->load('dataobject');
$do = new DataObject("ocompra");
$do->rel_one_to_many('itocompra', 'itocompra', array('numero' => 'numero'));
$do->load($id);
$error = '';
$factura = $do->get('factura');
$numero = $do->get('numero');
$cod_prov = $do->get('cod_prov');
$controlfac = $do->get('controlfac');
$fechafac = $do->get('fechafac');
$imptimbre = $do->get('imprtimbre');
$reten = $do->get('reten');
$ivag = $do->get('ivag');
$ivar = $do->get('ivar');
$ivaa = $do->get('ivaa');
$iva = $ivar + $ivaa + $ivag;
$ide = $this->db->escape($id);
if ($iva > 0 || $reten > 0 || $imptimbre > 0) {
if (empty($factura) || empty($controlfac)) {
$cant = $this->db->simple_query("SELECT COUNT(*) FROM itfac WHERE numero={$ide}");
if ($cant == 0) {
$error .= "<div class='alert'><p>Los Campos Factura, Control Fiscal y Fecha de Factura, no pueden estar en blanco</p></div>";
}
} else {
$this->chexiste_factura($numero, $factura, $controlfac, $cod_prov, 'F', $e);
$error .= $e;
}
}
if (empty($error)) {
$sta = $do->get('status');
if ($sta == 'C') {
$partidaiva = $this->datasis->traevalor("PARTIDAIVA");
$ivan = 0;
$importes = array();
$ivas = array();
$admfondo = array();
for ($i = 0; $i < $do->count_rel('itocompra'); $i++) {
$codigoadm = $do->get_rel('itocompra', 'codigoadm', $i);
$fondo = $do->get_rel('itocompra', 'fondo', $i);
$codigopres = $do->get_rel('itocompra', 'partida', $i);
$importe = $do->get_rel('itocompra', 'importe', $i);
$iva = $do->get_rel('itocompra', 'iva', $i);
$ordinal = $do->get_rel('itocompra', 'ordinal', $i);
$ivan = $importe * $iva / 100;
$error .= $this->itpartida($codigoadm, $fondo, $codigopres, $ordinal);
$cadena = $codigoadm . '_._' . $fondo . '_._' . $codigopres;
//.'_._'.$ordinal.'_._'.$iva;
if (array_key_exists($cadena, $importes)) {
$importes[$cadena] += $importe;
//$ivas[$cadena] =$iva;
} else {
$importes[$cadena] = $importe;
//$ivas[$cadena] =$iva;
}
$cadena2 = $codigoadm . '_._' . $fondo;
$admfondo[$cadena2] = array_key_exists($cadena2, $admfondo) ? $admfondo[$cadena2] += $ivan : ($admfondo[$cadena2] = $ivan);
}
if (empty($error)) {
//foreach($admfondo AS $cadena=>$monto){
// $temp = explode('_._',$cadena);
// $error.=$this->chequeapresup($temp[0],$temp[1],'PARTIDAIVA','',$monto,0,'round($monto,2) > $disponible=round(($comprometido-$causado),2)','El Monto ($monto) es mayor al disponible (round(($disponible),2)) para causar para la partida de IVA, ('.$temp[0].')('.$temp[1].') ');
//}
foreach ($importes as $cadena => $monto) {
$temp = explode('_._', $cadena);
$iva = $ivas[$cadena];
$error .= $this->chequeapresup($temp[0], $temp[1], $temp[2], '', $monto, 0, 'round($monto,2) > $disponible=round(($comprometido-$causado),2)', 'El Monto ($monto) es mayor al disponible ($disponible) para la partida (' . $temp[0] . ' (' . $temp[1] . ') (' . $temp[2] . ')');
}
}
if (empty($error)) {
//$ivan=0;
//for($i=0;$i < $do->count_rel('itocompra');$i++){
// $codigopres = $do->get_rel('itocompra','partida',$i);
// $importe = $do->get_rel('itocompra','importe',$i);
// $iva = $do->get_rel('itocompra','iva' ,$i);
// $ordinal = $do->get_rel('itocompra','ordinal',$i);
// $ivan += $importe*$iva/100;
//
// $error.=$this->afectapresup($codigoadm,$fondo,$codigopres,$ordinal,$importe,$iva, 1 ,array("causado"));
//}
foreach ($importes as $cadena => $monto) {
$temp = explode('_._', $cadena);
//$iva = $ivas[$cadena];
$error .= $this->afectapresup($temp[0], $temp[1], $temp[2], '', $monto, 0, 1, array("causado"));
}
//if(empty($error)){
// foreach($admfondo AS $cadena=>$monto){
// $temp = explode('_._',$cadena);
// $error.=$this->afectapresup($temp[0],$temp[1],'PARTIDAIVA','',$monto,0, 1 ,array("causado"));
// }
//}
if (empty($error)) {
$do->set('status', 'T');
$do->set('fcausado', date('Ymd'));
$do->save();
}
}
} else {
$error .= "<div class='alert'><p>No se puede Causar esta orden de pago</p></div>";
//.........這裏部分代碼省略.........
示例3: actualizar
function actualizar($id)
{
$this->rapyd->load('dataobject');
$do = new DataObject("odirect");
$do->rel_one_to_many('itodirect', 'itodirect', array('numero' => 'numero'));
$do->load($id);
$error = "";
$multiple = $do->get('multiple');
$factura = $do->get('factura');
$controlfac = $do->get('controlfac');
$fechafac = $do->get('fechafac');
$reteiva = $do->get('reteiva');
//if($multiple == 'N'){
// if($reteiva > 0 && (empty($factura) || empty($controlfac) || empty($fechafac)))
// $error.="<div class='alert'><p> Los campos Nro. Factura, Nro Control y Fecha factura no pueden estar en blanco</p></div>";
//}else{
// $facs = $this->datasis->dameval("SELECT COUNT(*) FROM itfac WHERE numero=$id ");
// if($facs <= 0)
// $error.="<div class='alert'><p> Debe ingresar las factura por el modulo de factura multiple primero</p></div>";
//}
if (empty($error)) {
$sta = $do->get('status');
if ($sta == "C1") {
$importes = array();
$ivas = array();
$admfondo = array();
$ordenes = array();
for ($i = 0; $i < $do->count_rel('itodirect'); $i++) {
$codigoadm = $do->get_rel('itodirect', 'codigoadm', $i);
$fondo = $do->get_rel('itodirect', 'fondo', $i);
$codigopres = $do->get_rel('itodirect', 'partida', $i);
$iva = $do->get_rel('itodirect', 'iva', $i);
$importe = $do->get_rel('itodirect', 'importe', $i);
$ordinal = $do->get_rel('itodirect', 'ordinal', $i);
$ocompra = $do->get_rel('itodirect', 'ocompra', $i);
$ivan = $importe * $iva / 100;
$error .= $this->itpartida($codigoadm, $fondo, $codigopres, $ordinal);
$cadena = $codigoadm . '_._' . $fondo . '_._' . $codigopres;
if (array_key_exists($cadena, $importes)) {
$importes[$cadena] += $importe;
} else {
$importes[$cadena] = $importe;
}
$cadena2 = $codigoadm . '_._' . $fondo;
$admfondo[$cadena2] = array_key_exists($cadena2, $admfondo) ? $admfondo[$cadena2] += $ivan : ($admfondo[$cadena2] = $ivan);
$cadena3 = $ocompra . '_._' . $codigoadm . '_._' . $fondo . '_._' . $codigopres;
if (array_key_exists($cadena3, $ordenes)) {
$ordenes[$cadena3] += $importe;
} else {
$ordenes[$cadena3] = $importe;
}
}
if (empty($error)) {
//foreach($admfondo AS $cadena=>$monto){
// $temp = explode('_._',$cadena);
// $error.=$this->chequeapresup($temp[0],$temp[1],'PARTIDAIVA','',$monto,0,'round($monto,2) > $disponible=round(($presupuesto-$comprometido),2)','El Monto ($monto) es mayor al disponible (round(($disponible),2)) para la partida de IVA, ('.$temp[0].')('.$temp[1].') ');
//}
foreach ($importes as $cadena => $monto) {
$temp = explode('_._', $cadena);
//$iva = $ivas[$cadena];
$error .= $this->chequeapresup($temp[0], $temp[1], $temp[2], '', $monto, 0, 'round($monto,2) > $disponible=round(($comprometido-$causado),2)', 'El Monto ($monto) es mayor al disponible ($disponible) para la partida (' . $temp[0] . ') (' . $temp[1] . ') (' . $temp[2] . ') ');
}
}
if (empty($error)) {
foreach ($ordenes as $k => $v) {
$temp = explode('_._', $v);
$query = "SELECT SUM(a.importe) \n\t\t\t\t\t\tFROM itodirect a\n\t\t\t\t\t\tJOIN odirect b ON a.numero=b.numero\n\t\t\t\t\t\tWHERE a.ocompra='" . $temp[0] . "' AND a.codigoadm='" . $temp[1] . "' AND a.fondo='" . $temp[2] . "' AND a.partida='" . $temp[3] . "' \n\t\t\t\t\t\tAND b.status IN ('C2','C3')\n\t\t\t\t\t\t";
$totcau = $this->datasis->dameval($query);
}
}
if (empty($error)) {
foreach ($importes as $cadena => $monto) {
$temp = explode('_._', $cadena);
//$iva = $ivas[$cadena];
$error .= $this->afectapresup($temp[0], $temp[1], $temp[2], '', $monto, 0, 1, array("causado", "opago"));
}
if (empty($error)) {
$do->set('fopago', date('Ymd'));
$do->set('status', 'C2');
$do->save();
}
}
}
}
if (empty($error)) {
logusu('odirect', "Actualizo Orden de Pago Directo Nro {$id}");
redirect($this->url . "dataedit/show/{$id}");
} else {
logusu('odirect', "Actualizo Orden de Pago Directo Nro {$id}. con ERROR:{$error} ");
$data['content'] = $error . anchor($this->url . "dataedit/show/{$id}", 'Regresar');
$data['title'] = " {$this->tits} ";
$data["head"] = $this->rapyd->get_head() . script('jquery.js') . script("plugins/jquery.numeric.pack.js");
$this->load->view('view_ventanas', $data);
}
}
示例4: reversar
function reversar($id)
{
$this->rapyd->load('dataobject');
$do = new DataObject("pmov");
$do->rel_one_to_many('itpmov', 'itpmov', array('numero' => 'numero'));
$do->load($id);
$codigoadm = $do->get('estadmin');
$fondo = $do->get('fondo');
$presup = new DataObject("presupuesto");
$pk = array('codigoadm' => $codigoadm, 'tipo' => $fondo);
$error = '';
$tot = 0;
$sta = $do->get('status');
if ($sta == "T") {
for ($i = 0; $i < $do->count_rel('itpmov'); $i++) {
$codigopres = $do->get_rel('itpmov', 'partida', $i);
$monto = $do->get_rel('itpmov', 'monto', $i);
$tot += $monto;
$pk['codigopres'] = $codigopres;
$presup->load($pk);
$recibido = $presup->get("recibido");
if ($recibido < 0) {
$error .= "<div class='alert'><p>partida ({$codigopre}):El monto debe ser positivo</p></div>";
}
}
if (empty($error)) {
$tot = 0;
for ($i = 0; $i < $do->count_rel('itpmov'); $i++) {
$codigopres = $do->get_rel('itpmov', 'partida', $i);
$monto = $do->get_rel('itpmov', 'monto', $i);
$tot += $monto;
$pk['codigopres'] = $codigopres;
$presup->load($pk);
$recibido = $presup->get("recibido");
$recibido -= $monto;
$presup->set("recibido", $recibido);
$presup->save();
}
$do->set('status', 'C');
$do->save();
}
}
if (empty($error)) {
redirect($this->url . "/dataedit/show/{$id}");
} else {
$data['content'] = $error . anchor($this->url . "/dataedit/show/{$id}", 'Regresar');
$data['title'] = " {$this->tits} ";
$data["head"] = $this->rapyd->get_head() . script('jquery.js') . script("plugins/jquery.numeric.pack.js");
$this->load->view('view_ventanas', $data);
}
}
示例5: reversar
function reversar($id)
{
$this->rapyd->load('dataobject');
$do = new DataObject("opago");
$do->rel_one_to_many('itopago', 'itopago', array('numero' => 'numero'));
$do->load($id);
$sta = $do->get('status');
if ($sta == 'C') {
$codigoadm = $do->get('estadmin');
$fondo = $do->get('fondo');
$ordc = new DataObject("ocompra");
$ordc->rel_one_to_many('itocompra', 'itocompra', array('numero' => 'numero'));
$error = '';
for ($i = 0; $i < $do->count_rel('itopago'); $i++) {
$orden = $do->get_rel('itopago', 'orden', $i);
$pago = $do->get_rel('itopago', 'pago', $i);
$pk2 = array('numero' => $orden);
$ordc->load($pk2);
$debe = $ordc->get('total');
$status = $ordc->get('status');
if ($status != 'R') {
$error .= "<div class='alert'><p>Orden Compra ({$orden}): No ha sido Procesada</p></div>";
}
}
}
if (empty($error)) {
$presup = new DataObject("presupuesto");
for ($i = 0; $i < $do->count_rel('itopago'); $i++) {
$orden = $do->get_rel('itopago', 'orden', $i);
$pago = $do->get_rel('itopago', 'pago', $i);
$pk2 = array('numero' => $orden);
$ordc->load($pk2);
$debe = $ordc->get('total');
$codigoadm = $ordc->get('estadmin');
$fondo = $ordc->get('fondo');
$abono = $ordc->get('abono');
$pk = array('codigoadm' => $codigoadm, 'tipo' => $fondo);
for ($i = 0; $i < $ordc->count_rel('itocompra'); $i++) {
$codigopres = $ordc->get_rel('itocompra', 'partida', $i);
$importe = $ordc->get_rel('itocompra', 'importe', $i);
$iva = $ordc->get_rel('itocompra', 'iva', $i);
$mont = $importe * (($iva + 100) / 100);
$pk['codigopres'] = $codigopres;
$presup->load($pk);
$causado = $presup->get("causado");
$causado -= $mont;
$presup->set("opago", $causado);
$presup->save();
}
$ordc->set('status', 'T');
$ordc->save();
$do->set('status', 'P');
$do->save();
}
redirect("presupuesto/opago2/dataedit/show/{$id}");
} else {
$data['content'] = $error . anchor("presupuesto/opago2/dataedit/show/{$id}", 'Regresar');
$data['title'] = " Orden de Pago ";
$data["head"] = $this->rapyd->get_head() . script('jquery.js') . script("plugins/jquery.numeric.pack.js");
$this->load->view('view_ventanas', $data);
}
}
示例6: reversar
function reversar($id)
{
$this->rapyd->load('dataobject');
$error = '';
$do = new DataObject("odirect");
$do->rel_one_to_many('itodirect', 'itodirect', array('numero' => 'numero'));
$do->load($id);
$codigoadm = $do->get('estadmin');
$fondo = $do->get('fondo');
$id_mbanc = $do->get('mbanc');
$monto = $do->get('monto');
$abonado = $do->get('abonado');
//$observa = $do->get('observa');
//$fecha = $do->get('fecha');
//$benefi = $do->get('benefi');
$row = $this->datasis->damerow("SELECT monto,abonado,codbanc FROM mbanc WHERE id={$id_mbanc}");
$m_abonado = $row['abonado'];
$m_monto = $row['monto'];
//$a=$m_monto-$m_abonado;
//if(($monto)>($a))
// $error.="<div class='alert'><p>El monto del $this->tits ($monto) es mayor que el monto adeudado ($a) del Anticipo ($devo)</p></div>";
$presup = new DataObject("presupuesto");
$pk = array('codigoadm' => $codigoadm, 'tipo' => $fondo);
$tiva = 0;
$tmont = 0;
$partidaiva = $this->datasis->traevalor("PARTIDAIVA");
$sta = $do->get('status');
if ($sta == "C") {
$tiva = $tsub = $ttot = 0;
/*for($i=0;$i < $do->count_rel('itodirect');$i++){
$codigopres = $do->get_rel('itodirect','partida',$i);
$subtotal = $do->get_rel('itodirect','subt' ,$i);
$total = $do->get_rel('itodirect','total' ,$i);
$numfac = $do->get_rel('itodirect','numfac' ,$i);
$tiva += $total-$subtotal;
$tsub += $subtotal;
$ttot += $total;
$pk['codigopres'] = $codigopres;
$presup->load($pk);
$asignacion = $presup->get("asignacion");
$aumento = $presup->get("aumento");
$disminucion = $presup->get("disminucion");
$traslados = $presup->get("traslados");
$comprometido = $presup->get("comprometido");
$disponible=(($asignacion+$aumento-$disminucion)+($traslados))-$comprometido;
if($subtotal > $disponible)
$error.="<div class='alert'><p>No se Puede Completar la Transaccion debido a que el monto del $this->tits ($subtotal) es mayor al monto disponible ($disponible) para la partida: $codigopres y factura ($numfac)</p></div>";
}
$pk['codigopres'] = $partidaiva;
$presup->load($pk);
$asignacion = $presup->get("asignacion");
$aumento = $presup->get("aumento");
$disminucion = $presup->get("disminucion");
$traslados = $presup->get("traslados");
$comprometido = $presup->get("comprometido");
$disponible=(($asignacion+$aumento-$disminucion)+($traslados))-$comprometido;
if($tiva > $disponible)
$error.="<div class='alert'><p>El monto de iva ($tiva) de la orden de compra, es mayor al monto disponible ($disponible) para la partida de iva ($partidaiva)</p></div>";
$c=$m_monto-$m_abonado;
if($ttot > $m_monto-$m_abonado)
$error.="<div class='alert'><p>El monto ($ttot) de la orden de pago directa, es mayor al monto disponible ($c) para el anticipo ($id_mbanc)</p></div>";
*/
if (empty($error)) {
$tiva = $tsub = $ttot = 0;
for ($i = 0; $i < $do->count_rel('itodirect'); $i++) {
$codigopres = $do->get_rel('itodirect', 'partida', $i);
$subtotal = $do->get_rel('itodirect', 'subt', $i);
$total = $do->get_rel('itodirect', 'total', $i);
$numfac = $do->get_rel('itodirect', 'numfac', $i);
$tiva += $total - $subtotal;
$tsub += $subtotal;
$ttot += $total;
$pk['codigopres'] = $codigopres;
$presup->load($pk);
$comprometido = $presup->get("comprometido");
$causado = $presup->get("causado");
$opago = $presup->get("opago");
$pagado = $presup->get("pagado");
$comprometido -= $subtotal;
$causado -= $subtotal;
$opago -= $subtotal;
$pagado -= $subtotal;
$presup->set("comprometido", $comprometido);
$presup->set("causado", $causado);
$presup->set("opago", $opago);
$presup->set("pagado", $pagado);
$presup->save();
}
$pk['codigopres'] = $partidaiva;
$presup->load($pk);
//.........這裏部分代碼省略.........
示例7: reversar
function reversar($id)
{
$this->rapyd->load('dataobject');
$error = '';
$odirect = new DataObject("odirect");
$odirect->load($id);
$status = $odirect->get('status');
$compra = $odirect->get('compra');
$pago = $odirect->get('pago');
//print_r($odirect->get_all());
//
//echo "-".$status;
//exit;
if ($status == 'O') {
$ocompra = new DataObject("ocompra");
$ocompra->rel_one_to_many('odirect', 'odirect', array('numero' => 'compra'));
$ocompra->load($compra);
$o_subtotal = $ocompra->get('subtotal');
$o_ivag = $ocompra->get('ivag');
$o_ivar = $ocompra->get('ivar');
$o_ivaa = $ocompra->get('ivaa');
$o_reten = $ocompra->get('reten');
$o_reteiva = $ocompra->get('reteiva');
$o_abonado = $ocompra->get('abonado');
$o_iva = $o_ivaa + $o_ivag + $o_ivar;
$o_debe = $o_subtotal + ($o_iva - ($o_reten + $o_reteiva));
$tot = 0;
for ($i = 0; $i < $ocompra->count_rel('odirect'); $i++) {
$r_pago = $ocompra->get_rel('odirect', 'pago', $i);
$tot += $r_pago;
}
//$a = $o_debe-($tot-$pago);
//if($pago > $a)
// $error.="<div class='alert'><p>El monto de la orden de pago($pago) es mayor al monto adeudado ($a)</p></div>";
} else {
$error .= "<div class='alert'><p>No se Puede Completar la operacion</p></div>";
}
if (empty($error)) {
$ocompra->set('abonado', $tot - $pago);
$odirect->set('status', 'T');
if ($tot = $o_debe) {
$odirect->set('ivag', 0);
$odirect->set('ivar', 0);
$odirect->set('ivaa', 0);
$odirect->set('reten', 0);
$odirect->set('creten', 0);
$odirect->set('reteiva', 0);
$odirect->set('exento', 0);
}
$ocompra->save();
$odirect->save();
} else {
//$odirect -> delete();
}
if (empty($error)) {
redirect($this->url . "dataedit/show/{$id}");
} else {
$data['content'] = $error . anchor($this->url . "/dataedit/show/{$id}", 'Regresar');
$data['title'] = " " . $this->tits . " ";
$data["head"] = $this->rapyd->get_head() . script('jquery.js') . script("plugins/jquery.numeric.pack.js");
$this->load->view('view_ventanas', $data);
}
}
示例8: convertir
function convertir($numero)
{
$this->rapyd->load('dataobject');
$requi = new DataObject("requi");
$requi->rel_one_to_many('itrequi', 'itrequi', array('numero' => 'numero'));
$requi->load($numero);
$ocompra = $requi->get('ocompra');
$do = new DataObject("ocompra");
$do->rel_one_to_many('itocompra', 'itocompra', array('numero' => 'numero'));
if (!empty($ocompra)) {
redirect("presupuesto/ocompra/dataedit/show/{$ocompra}");
}
$do->set('uejecutora', $requi->get('uejecuta'));
$do->set('observa', $requi->get('objetivo'));
//$do->set('responsable' ,$requi->get('responsable' ));
$iva = $this->datasis->dameval("SELECT tasa FROM civa ORDER BY fecha DESC LIMIT 1");
for ($i = 0; $i < $requi->count_rel('itrequi'); $i++) {
$do->set_rel('itocompra', 'cantidad', $requi->get_rel('itrequi', 'cantidad', $i), $i);
$do->set_rel('itocompra', 'unidad', $requi->get_rel('itrequi', 'unidad', $i), $i);
$do->set_rel('itocompra', 'descripcion', $requi->get_rel('itrequi', 'descrip', $i), $i);
$do->set_rel('itocompra', 'precio', $requi->get_rel('itrequi', 'precio', $i), $i);
$do->set_rel('itocompra', 'importe', $requi->get_rel('itrequi', 'importe', $i), $i);
$do->set_rel('itocompra', 'partida', $requi->get_rel('itrequi', 'partida', $i), $i);
$do->set_rel('itocompra', 'iva', $iva, $i);
}
$do->set('estadmin', $requi->get('estadmin'));
$do->set('fondo', $requi->get('fondo'));
$do->set('fecha', date('Ymd'));
$do->save();
$numero = $do->get('numero');
$requi->set('ocompra', $numero);
$requi->set('status', 'X');
$requi->save();
redirect("presupuesto/ocompra/dataedit/modify/{$numero}");
}
示例9: reversar
function reversar($id)
{
$this->rapyd->load('dataobject');
$error = '';
$ord = new DataObject("ordinal");
$mbanc = new DataObject("mbanc");
$mbanc->rel_one_to_many('itppro', 'itppro', array('id' => 'mbanc'));
$mbanc->load($id);
$m_codbanc = $mbanc->get('codbanc');
$m_monto = $mbanc->get('monto');
$banc = new DataObject("banc");
$banc->load($m_codbanc);
$saldo = $banc->get('saldo');
$activo = $banc->get('activo');
$odirect = new DataObject("odirect");
$odirect->rel_one_to_many('pacom', 'pacom', array('numero' => 'pago'));
$odirect->rel_one_to_many('itodirect', 'itodirect', array('numero' => 'numero'));
$odirect->rel_one_to_many('islr', 'islr', array('numero' => 'odirect'));
$ocompra = new DataObject("ocompra");
$ocompra->rel_one_to_many('itocompra', 'itocompra', array('numero' => 'numero'));
$riva = new DataObject("riva");
$presup = new DataObject("presupuesto");
$presupante = new DataObject("presupuestoante");
$ordinalante = new DataObject("ordinalante");
$partidaiva = $this->datasis->traevalor("PARTIDAIVA");
if ($activo != 'S') {
$error .= "<div class='alert'><p>El banco ({$banco}) esta inactivo</p></div>";
}
$sta = $mbanc->get('status');
if ($sta == "E2") {
$t = 0;
if (empty($error)) {
for ($j = 0; $j < $mbanc->count_rel('itppro'); $j++) {
$orden = $mbanc->get_rel('itppro', 'orden', $j);
$it_monto = $mbanc->get_rel('itppro', 'monto', $j);
$odirect->load($orden);
$status = $odirect->get('status');
$od_numero = $odirect->get('numero');
$od_estadmin = $odirect->get('estadmin');
$od_fondo = $odirect->get('fondo');
$od_ivag = $odirect->get('ivag');
$od_ivaa = $odirect->get('ivaa');
$od_ivar = $odirect->get('ivar');
$od_reten = $odirect->get('reten');
$od_reteiva = $odirect->get('reteiva');
$od_subtotal = $odirect->get('subtotal');
$od_pr = $od_reten * 100 / $od_subtotal;
if ($status == "F3") {
for ($g = 0; $g < $odirect->count_rel('pacom'); $g++) {
$p_t = $odirect->get_rel('pacom', 'total', $g);
$p_compra = $odirect->get_rel('pacom', 'compra', $g);
$ocompra->load($p_compra);
$oc_codigoadm = $ocompra->get('estadmin');
$oc_fondo = $ocompra->get('fondo');
$oc_status = $ocompra->get('status');
//$pagado=$this->datasis->dameval("SELECT SUM(a.monto) FROM itppro a JOIN mbanc d ON d.id=a.mbanc JOIN odirect b ON a.orden=b.numero JOIN pacom c ON b.numero=c.pago WHERE c.compra=$p_compra AND d.status='E2'");
//$pagado+=$it_monto;
//
$ivaa = $ocompra->get('ivaa');
$ivag = $ocompra->get('ivag');
$ivar = $ocompra->get('ivar');
//$subtotal = $ocompra->get('subtotal');
$reteiva = $ocompra->get('reteiva');
$reteiva_prov = $ocompra->get('reteiva_prov');
$reten = $ocompra->get('reten');
$ivan = $ivag + $ivar + $ivaa;
//$total = $subtotal+($ivan-($reteiva+$reten));
//if($total==$pagado){
$pk = array('codigoadm' => $oc_codigoadm, 'tipo' => $oc_fondo);
$partidaiva = $this->datasis->traevalor("PARTIDAIVA");
$pk['codigopres'] = $partidaiva;
$presup->load($pk);
$pasignacion = $presup->get("asignacion");
$odirect->count_rel('pacom');
for ($h = 0; $h < $odirect->count_rel('pacom'); $h++) {
$p_compra = $odirect->get_rel('pacom', 'compra', $h);
for ($k = 0; $k < $ocompra->count_rel('itocompra'); $k++) {
$codigopres = $ocompra->get_rel('itocompra', 'partida', $k);
$importe = $ocompra->get_rel('itocompra', 'importe', $k);
$islrid = $ocompra->get_rel('itocompra', 'islrid', $k);
$ordinal = $ocompra->get_rel('itocompra', 'ordinal', $k);
$iva = $ocompra->get_rel('itocompra', 'iva', $k);
if ($pasignacion > 0) {
$mont = $importe;
} else {
$mont = $importe + ($importe * $iva / 100 - $importe * $iva / 100 * $reteiva_prov / 100);
}
$pk = array('codigoadm' => $oc_codigoadm, 'tipo' => $oc_fondo, 'codigopres' => $codigopres);
$presup->load($pk);
$pagado = $presup->get("pagado");
$pagado = $pagado - $mont;
$presup->set("pagado", $pagado);
$presup->save();
if (!empty($ordinal)) {
$ord->load(array("codigoadm" => $oc_codigoadm, "fondo" => $oc_fondo, "codigopres" => $codigopres, "ordinal" => $ordinal));
$opa = $ord->get("pagado");
$opa -= $mont;
$ord->set("pagado", $opa);
$ord->save();
}
//.........這裏部分代碼省略.........
示例10: reversar
function reversar($id)
{
$this->rapyd->load('dataobject');
$do = new DataObject("audis");
$do->rel_one_to_many('itaudis', 'itaudis', array('numero' => 'numero'));
$do->load($id);
$sta = $do->get('status');
if ($sta == 'C') {
$tipo = $do->get('tipo');
$campo = $tipo == 'AUMENTO' ? 'aumento' : 'disminucion';
$factor = 1;
$error = '';
if ($tipo == 'AUMENTO') {
for ($i = 0; $i < $do->count_rel('itaudis'); $i++) {
$codigopres = $do->get_rel('itaudis', 'codigopres', $i);
$monto = $do->get_rel('itaudis', 'monto', $i);
$ordinal = $do->get_rel('itaudis', 'ordinal', $i);
$codigoadm = $do->get_rel('itaudis', 'codigoadm', $i);
$fondo = $do->get_rel('itaudis', 'fondo', $i);
$error .= $this->chequeapresup($codigoadm, $fondo, $codigopres, $ordinal, $monto, 0, '$monto > ($presupuesto-$comprometido)', "El Monto ({$monto}) es mayor al disponible para la partida ({$codigoadm}) ({$fondo}) ({$codigopres})");
}
if (empty($error)) {
$factor = -1;
}
}
if (empty($error)) {
for ($i = 0; $i < $do->count_rel('itaudis'); $i++) {
$codigopres = $do->get_rel('itaudis', 'codigopres', $i);
$monto = $do->get_rel('itaudis', 'monto', $i);
$ordinal = $do->get_rel('itaudis', 'ordinal', $i);
$codigoadm = $do->get_rel('itaudis', 'codigoadm', $i);
$fondo = $do->get_rel('itaudis', 'fondo', $i);
$error .= $this->afectapresup($codigoadm, $fondo, $codigopres, $ordinal, $monto, 0, 1 * $factor, array($campo));
}
if (empty($error)) {
$do->set('status', 'A');
$do->save();
$this->sp_presucalc($codigoadm);
}
}
} else {
$error .= "<div class='alert'><p>No se puede realizar la operacion para este aumento � disminucion</p></div>";
}
if (empty($error)) {
logusu('audis', "reverso {$campo} numero {$id}");
redirect("presupuesto/audis/dataedit/show/{$id}");
} else {
logusu('audis', "reverso {$campo} numero {$id} con error {$error}");
$data['content'] = $error . anchor("presupuesto/audis/dataedit/show/{$id}", 'Regresar');
$data['title'] = " Aumentos y Disminuciones ";
$data["head"] = $this->rapyd->get_head();
$this->load->view('view_ventanas', $data);
}
}
示例11: actualizar
function actualizar($numero)
{
$this->rapyd->load('dataobject');
$do = new DataObject("casi");
$do->rel_one_to_many('itcasi', 'itcasi', array('comprob' => 'comprob'));
$do->load($numero);
$error = '';
$fecha = $do->get('fecha');
$error .= $this->chcasise($fecha);
$tdebe = $thaber = 0;
for ($i = 0; $i < $do->count_rel('itcasi'); $i++) {
$cuenta = $do->get_rel('itcasi', 'cuenta', $i);
$debe = $do->get_rel('itcasi', 'debe', $i);
$haber = $do->get_rel('itcasi', 'haber', $i);
$tdebe += $debe;
$thaber += $haber;
if ($debe != 0 && $haber != 0) {
$error .= "<div class='alert'><p>Error en la cuenta {$cuenta}: Uno de los campos debe o haber debe contener un valor positivo y el otro cero(0)</p></div>";
}
}
if ($this->datasis->traevalor('CASIDESCUDRADO', 'N', 'PERMITE ACTURALIZAR UN ASIENTO DESCUADRADO') != 'S') {
if (round($tdebe, 2) != round($thaber, 2)) {
$error .= "<div class='alert'><p>Asiento Descuadrado</p></div>";
}
}
if (empty($error)) {
$do->set('debe', $tdebe);
$do->set('haber', $thaber);
$do->set('total', $tdebe - $thaber);
$do->set('status', 'C2');
$do->save();
}
if (empty($error)) {
$fecha = $do->get('fecha');
$mes = str_pad(date('m', strtotime($fecha)), 2, '0', STR_PAD_LEFT);
$this->cal_nrocomp($mes);
logusu('CASI', 'Actualizo Asiento Contable ' . $numero);
redirect($this->url . "dataedit/show/{$numero}");
} else {
$data['content'] = "<div class='alert'>" . $error . "</div>" . anchor($this->url . "dataedit/show/{$numero}", 'Regresar');
$data['title'] = "{$this->tits}";
$data["head"] = $this->rapyd->get_head();
$this->load->view('view_ventanas', $data);
return false;
}
}
示例12: DataObject
function cd_reversar($numero, $anular = false, $redirect = true)
{
$this->rapyd->load('dataobject');
$error = '';
$do = new DataObject("cdisp");
$do->rel_one_to_many('itcdisp', 'itcdisp', array('numero' => 'numero'));
$do->load($numero);
$status = $do->get('status');
if ($status == 'C') {
$importes = array();
for ($i = 0; $i < $do->count_rel('itcdisp'); $i++) {
$codigoadm = $do->get_rel('itcdisp', 'codigoadm', $i);
$fondo = $do->get_rel('itcdisp', 'fondo', $i);
$codigopres = $do->get_rel('itcdisp', 'codigopres', $i);
$importe = $do->get_rel('itcdisp', 'importe', $i);
$soli = $do->get_rel('itcdisp', 'soli', $i);
$cadena = $codigoadm . '_._' . $fondo . '_._' . $codigopres;
if (array_key_exists($cadena, $importes)) {
$importes[$cadena] += $soli;
} else {
$importes[$cadena] = $soli;
}
}
if (empty($error) && $status == 'C') {
foreach ($importes as $cadena => $monto) {
$temp = explode('_._', $cadena);
$error .= $this->chequeapresup($temp[0], $temp[1], $temp[2], '', $monto, 0, 'round($monto,2) > $disponible=round(($apartado),2)', 'El Monto ($monto) es mayor al apartado ($disponible) para la partida (' . $temp[0] . ') (' . $temp[1] . ') (' . $temp[2] . ') ');
}
}
//print_r($importes);
//exit('Hello World'.$error);
if (empty($error)) {
foreach ($importes as $cadena => $monto) {
$temp = explode('_._', $cadena);
$error .= $this->afectapresup($temp[0], $temp[1], $temp[2], '', $monto, 0, -1, array("apartado"));
}
}
} else {
$error .= "<div class='alert'>No se puede realizar la operacion para el certificado</div>";
}
if (empty($error)) {
if ($anular) {
$do->set('fanulado', date('Ymd'));
$do->set('status', 'A');
logusu('cdisp', "Marco como anulado certificado nro {$numero}");
} else {
$do->set('ffinal', date('Ymd'));
if ($status == 'F') {
$do->set('status', 'C');
} else {
$do->set('status', 'F');
}
logusu('cdisp', "Marco como finalizado certificado nro {$numero}");
}
$do->save();
if ($redirect) {
redirect($this->url . "dataedit/show/{$numero}");
}
} else {
logusu('cdisp', "Marco como anulado certificado nro {$numero} con ERROR {$error}");
$data['content'] = $error . anchor($this->url . "dataedit/show/{$numero}", 'Regresar');
$data['title'] = " {$this->tits}";
$data["head"] = $this->rapyd->get_head();
$this->load->view('view_ventanas', $data);
}
}
示例13: DataObject
function actpresup2($id, $apartar = null)
{
$this->rapyd->load('dataobject');
$do = new DataObject("trasla");
$do->rel_one_to_many('ittrasla', 'ittrasla', array('numero' => 'numero'));
$do->load($id);
$sta = $do->get('status');
if ($sta == 'P' || $sta == 'H') {
$tdisminucion = $do->get('tdisminucion');
$taumento = $do->get('taumento');
$error = '';
if ($tdisminucion == $taumento) {
$montos = array();
for ($i = 0; $i < $do->count_rel('ittrasla'); $i++) {
$ordinal = $do->get_rel('ittrasla', 'ordinal', $i);
$codigopres = $do->get_rel('ittrasla', 'codigopres', $i);
$codigoadm = $do->get_rel('ittrasla', 'codigoadm', $i);
$fondo = $do->get_rel('ittrasla', 'fondo', $i);
$disminucion = $do->get_rel('ittrasla', 'disminucion', $i);
$aumento = $do->get_rel('ittrasla', 'aumento', $i);
$monto = $aumento - $disminucion;
if ($sta == 'H') {
$monto = -1 * $monto;
}
$error .= $this->itpartida($codigoadm, $fondo, $codigopres, $ordinal);
$cadena = $codigoadm . '_._' . $fondo . '_._' . $codigopres . '_._' . $ordinal;
if (array_key_exists($cadena, $montos)) {
$montos[$cadena] += $monto;
} else {
$montos[$cadena] = $monto;
}
}
if (empty($error)) {
foreach ($montos as $cadena => $monto) {
$temp = explode('_._', $cadena);
if ($monto < 0) {
$error .= $this->chequeapresup($temp[0], $temp[1], $temp[2], $temp[3], abs($monto), 0, 'round($monto,2) > $disponible=round(($presupuesto-($comprometido+$apartado)),2)', 'El Monto ($monto) es mayor al disponible ($disponible) para la partida (' . $temp[0] . ') (' . $temp[1] . ') (' . $temp[2] . ') (' . $temp[3] . ')');
}
}
}
if (empty($error)) {
foreach ($montos as $cadena => $monto) {
$temp = explode('_._', $cadena);
if ($sta == 'P') {
if ($monto < 0) {
$error .= $this->afectapresup($temp[0], $temp[1], $temp[2], $temp[3], abs($monto), 0, 1, array("apartado"));
}
} elseif ($sta == 'H') {
if ($monto > 0) {
$error .= $this->afectapresup($temp[0], $temp[1], $temp[2], $temp[3], abs($monto), 0, -1, array("apartado"));
}
}
}
}
} else {
$error .= "<div class='alert'><p>No se puede realizar la Transferencia si El total de Disminuciónes ({$tdisminucion}) es Diferente al total de Aumentos ({$taumento}) </p></div>";
}
if (empty($error)) {
if ($sta == 'P') {
$do->set('status', 'H');
logusu('trasla', "Aparto traslado {$id}");
}
if ($sta == 'H') {
$do->set('status', 'P');
logusu('trasla', "desaparto traslado {$id}");
}
$do->save();
}
} else {
$error .= "<div class='alert'><p>No se puede realizar la operacion para la transferencia {$id} </p></div>";
}
if (empty($error)) {
redirect("presupuesto/trasla/dataedit/show/{$id}");
} else {
$data['content'] = $error . anchor("presupuesto/trasla/dataedit/show/{$id}", 'Regresar');
$data['title'] = "Traslados";
$data["head"] = $this->rapyd->get_head();
$this->load->view('view_ventanas', $data);
}
}
示例14: creariva
function creariva($id)
{
$this->rapyd->load('dataobject');
$error = '';
$do = new DataObject("rendi");
$do->pointer('sprv', 'sprv.proveed=rendi.cod_prov', 'sprv.reteiva as reteivap');
$do->rel_one_to_many('itrendi', 'itrendi', array('numero' => 'numero'));
$do->load($id);
$sta = $do->get('status');
$cod_prov = $do->get('cod_prov');
$reteiva_prov = $do->get_pointer('reteivap');
$qq = $this->db->query("SELECT tasa, redutasa, sobretasa FROM civa ORDER BY fecha DESC LIMIT 1");
$ivaplica = $qq->row_array();
$ivaplica['redutasa'];
$ivaplica['tasa'];
$ivaplica['sobretasa'];
if ($sta == "C") {
for ($i = 0; $i < $do->count_rel('itrendi'); $i++) {
$codigoadm = $do->get_rel('itrendi', 'codigoadm', $i);
$fondo = $do->get_rel('itrendi', 'fondo', $i);
$subtotal = $do->get_rel('itrendi', 'subtotal', $i);
$iva = $do->get_rel('itrendi', 'iva', $i);
$factura = $do->get_rel('itrendi', 'factura', $i);
$controlfac = $do->get_rel('itrendi', 'controlfac', $i);
$fechafac = $do->get_rel('itrendi', 'fechafac', $i);
$tivag = $mivag = $tivaa = $ivaa = $tivar = $mivar = 0;
$tasaiva = $iva * 100 / $subtotal;
if (round($tasaiva, 2) == round($ivaplica['redutasa'], 2)) {
$tivar = $ivaplica['redutasa'];
$mivar = $iva;
} elseif (round($tasaiva, 2) == round($ivaplica['sobretasa'], 2)) {
$tivaa = $ivaplica['sobretasa'];
$mivaa = $iva;
} elseif (round($tasaiva, 2) == round($ivaplica['tasa'], 2)) {
$tivag = $ivaplica['tasa'];
$mivag = $iva;
} else {
$error = "El Monto de IVA no corresponde con alguno de las tasas actuales";
}
}
$ide = $this->db->query($id);
$r = $this->datasis->dameval("SELECT SUM(iva*(SELECT reteiva_prov FROM sprv WHERE proveed=(SELECT cod_prov FROM rendi WHERE numero={$ide}))/100) FROM itrendi WHERE numero={$ide}");
if ($r > 0) {
$nriva = $this->datasis->fprox_numero('nriva');
}
if (empty($error)) {
for ($i = 0; $i < $do->count_rel('itrendi'); $i++) {
$codigoadm = $do->get_rel('itrendi', 'codigoadm', $i);
$fondo = $do->get_rel('itrendi', 'fondo', $i);
$subtotal = $do->get_rel('itrendi', 'subtotal', $i);
$iva = $do->get_rel('itrendi', 'iva', $i);
$factura = $do->get_rel('itrendi', 'factura', $i);
$controlfac = $do->get_rel('itrendi', 'controlfac', $i);
$fechafac = $do->get_rel('itrendi', 'fechafac', $i);
$tivag = $mivag = $tivaa = $ivaa = $tivar = $mivar = 0;
$tasaiva = $iva * 100 / $subtotal;
if (round($tasaiva, 2) == round($ivaplica['redutasa'], 2)) {
$tivar = $ivaplica['redutasa'];
$mivar = $iva;
} elseif (round($tasaiva, 2) == round($ivaplica['sobretasa'], 2)) {
$tivaa = $ivaplica['sobretasa'];
$mivaa = $iva;
} elseif (round($tasaiva, 2) == round($ivaplica['tasa'], 2)) {
$tivag = $ivaplica['tasa'];
$mivag = $iva;
}
$reteiva = $iva * $reteiva_prov / 100;
if ($reteiva > 0) {
$error = $this->riva($nriva, $codigoadm, $fondo, '', '', '', $factura, $controlfac, $fechafac, $cod_prov, 0, $tivag, $mivag, $tivaa, $ivaa, $tivar, $mivar, $reteiva, '', '', $reteiva_prov, $id);
}
}
}
}
if (1 * $error > 0) {
$salida = "Se creo retencion de IVA numero {$error}";
} else {
$salida = $error;
}
$data['content'] = $salida . "</br>" . anchor($this->url . "dataedit/show/{$id}", 'Regresar');
$data['title'] = ' Crear Retencion de IVA ';
$data["head"] = $this->rapyd->get_head();
$this->load->view('view_ventanas', $data);
}
示例15: reversar
function reversar($id)
{
$this->rapyd->load('dataobject');
$do = new DataObject("opago");
$do->rel_one_to_many('itopago', 'itopago', array('numero' => 'numero'));
$do->load($id);
$sta = $do->get('status');
if ($sta == 'C') {
$codigoadm = $do->get('estadmin');
$fondo = $do->get('fondo');
$presup = new DataObject("presupuesto");
$pk = array('codigoadm' => $codigoadm, 'tipo' => $fondo);
for ($i = 0; $i < $do->count_rel('itopago'); $i++) {
$codigopres = $do->get_rel('itopago', 'partida', $i);
$pago = $do->get_rel('itopago', 'pago', $i);
$pk['codigopres'] = $codigopres;
$presup->load($pk);
$pagado = $presup->get("pagado");
if ($sta == "C") {
$pagado = $pagado - $pago;
}
$presup->set("pagado", $pago);
$presup->save();
}
if ($sta == "P") {
$do->set('status', 'C');
}
if ($sta == "C") {
$do->set('status', 'P');
}
$do->save();
}
if (empty($error)) {
redirect("presupuesto/opago/dataedit/show/{$id}");
} else {
$data['content'] = $error . anchor("presupuesto/opago/dataedit/show/{$id}", 'Regresar');
$data['title'] = " Orden de Pago ";
$data["head"] = $this->rapyd->get_head() . script('jquery.js') . script("plugins/jquery.numeric.pack.js");
$this->load->view('view_ventanas', $data);
}
}