Ejemplo n.º 1
0
 public static function CreaTempKardex($idvale, $codmov, $row)
 {
     $retorno = true;
     ///VERIFICANDO QUE NO S EHAYA CREADO YA
     //var_dump($row);
     $cuantoshay = Tempalkardex::model()->findAll("hidvale=:vhidvale AND\r\r\n                                            idref=:vidfila AND\r\r\n                                            coddoc=:vcoddoc AND\r\r\n                                             idusertemp=" . Yii::app()->user->id . "  ", array(":vhidvale" => $idvale, ":vidfila" => $row[self::CAMPO_ID_FILA], ":vcoddoc" => $row[self::CAMPO_CODIGO_DOCUMENTO]));
     $retorno = false;
     $kardex = new Tempalkardex();
     $kardex->hidvale = $idvale;
     $kardex->setscenario('salidareserva');
     $kardex->codart = $row[self::CAMPO_CODIGO_MATERIAL];
     $kardex->um = $row[self::CAMPO_UM_MATERIAL];
     $kardex->codmov = $codmov;
     $kardex->idstatus = 1;
     ///OJO SIEMPRE ES AGREGADO +1
     $kardex->codocuref = $row[self::CAMPO_CODIGO_DOCUMENTO];
     $kardex->numdocref = $row[self::CAMPO_NUMERO_DOC];
     $kardex->idref = $row[self::CAMPO_ID_REF];
     $kardex->preciounit = $row[self::CAMPO_PRECIO_UNITARIO_MATERIAL];
     self::Mensaje('notice', __CLASS__ . '  ' . __FUNCTION__ . '  LA CANTIDAD SOLICITADA DEL MATERIAL  : ' . $kardex->codart . '  =>  ' . $row[self::CAMPO_CANTIDAD_MATERIAL]);
     self::Mensaje('notice', __CLASS__ . '  ' . __FUNCTION__ . '  LA CANTIDAD ACUMULADA DEL AMTERIAL   : ' . $kardex->codart . '  =>  ' . (double) $row['n_sumita']);
     // self::Mensaje('notice',__CLASS__.'  '.__FUNCTION__.' El signo es '. Almacenmovimientos::model()->findByPk($codmov)->signo);
     // $kardex->cant=(double)$row['n_sumita'];
     // $kardex->cant=$row[self::CAMPO_CANTIDAD_MATERIAL];
     $kardex->cant = (abs($row[self::CAMPO_CANTIDAD_MATERIAL]) - (double) $row['n_sumita']) * Almacenmovimientos::model()->findByPk($codmov)->signo;
     /*  echo " <br><br>";
         var_dump($kardex->attributes);*/
     if ($kardex->save()) {
         $retorno = true;
     }
     self::Mensaje('success', 'Se inserta el temporal ' . $kardex->codart);
     return $retorno;
 }
Ejemplo n.º 2
0
 public function actualizacostes($model, $transaccion, $ceco = null)
 {
     //Public function actionpruebax() {
     $todook = true;
     $hijos = Alkardex::model()->findall("hidvale=:hid and codestado not in('98')  ", array(":hid" => $model->id));
     // $hijos=Alkardex::model()->findall("id=437");
     for ($i = 0; $i < count($hijos); $i++) {
         $modelogastos = new CcGastos();
         if (is_null($ceco)) {
             ///Rebuscamos la solpe
             if ($hijos[$i]['codmov'] == '70') {
                 //Si es un reingreso debemos de buscar recursivamente en el Kardex
                 $modelodetalle = Desolpe::model()->findByPk(Alkardex::model()->findByPk($hijos[$i]['idref'])->idref);
             } else {
                 $modelodetalle = Desolpe::model()->findByPk($hijos[$i]['idref']);
             }
             $modelogastos->ceco = $modelodetalle->imputacion;
         } else {
             $modelogastos->ceco = $ceco;
         }
         //$modelodetalle=Desolpe::model()->findByPk(232);
         $modelogastos->fechacontable = $hijos[$i]['fecha'];
         //Los costos salen del inventario no del precio unitario del Kardex; (Punit+ Punitdif)
         $registroinventario = Alinventario::model()->findByPk(Alkardex::model()->findByPk($hijos[$i]['id'])->alkardex_alinventario->id);
         ///////////////haciendo el calculo estandar de signo y conversiones
         $signo = Almacenmovimientos::model()->findByPk($hijos[$i]['codmov'])->signo * -1;
         /// Como son costos , es el opuesto
         $conversion = Alconversiones::model()->convierte($hijos[$i]['codart'], $hijos[$i]['um']);
         //echo " la conversion  ".$conversion."  ".gettype($conversion)."      \n";
         //echo " material y um  ".$hijos[$i]['codart']."  ".$hijos[$i]['um']."      \n";
         //echo " el signo  es ".Almacenmovimientos::model()->findByPk($hijos[$i]['codmov'])->signo."  ".gettype(Almacenmovimientos::model()->findByPk($hijos[$i]['codmov'])->signo)."      \n";
         //$signo=Almacenmovimientos::model()->findByPk($movimiento)->signo*-1;  /// Como son costos , es el opuesto
         $cantidadmovida = $signo * abs($conversion) * abs($hijos[$i]['cant']);
         ///////////ok///////////////////////////////////////
         ////ahora calculando el precio unitario real, para esto actualizamos el Registro de Inventario,
         ///Esto es indiependiente si el material tiene control de precio S o V
         $registroinventario->Actualizar($hijos[$i]['codmov'], $hijos[$i]['cant'], $hijos[$i]['preciounit']);
         $modelogastos->monto = $cantidadmovida * ($registroinventario->punit + $registroinventario->punitdif);
         ///
         //echo  " la conversion ".$conversion."\n";
         //echo  " la cantidad movida ".$cantidadmovida."\n";
         //echo " precio unitario ".$registroinventario->punit."\n";
         // echo   "El monto    ".$modelogastos->monto."\n";
         //echo " la diferencia  ".$registroinventario->punit."  ".gettype($registroinventario->punit)."      \n";
         //echo " la diferencia  ".$registroinventario->punitdif."  ".gettype($registroinventario->punitdif)."      \n";
         //yii::app()->end();
         $modelogastos->idref = $hijos[$i]['id'];
         //con el kardex lo amarramos
         $modelogastos->clasecolector = 'K';
         //CENTRO DE COSTO
         $modelogastos->tipo = 'M';
         //materialkes
         $modelogastos->codmoneda = Yii::app()->params['monedadef'];
         if (!$modelogastos->save()) {
             //$transaccion->rollback();
             //throw new CHttpException(500,'No se pudo grabar los costos');
             Yii::app()->user->setFlash('error', 'No se pudieron grabar los costes');
             $todook = false;
         }
     }
     return $todook;
 }
Ejemplo n.º 3
0
		<?php 
if (is_null($model->codocuref) or empty($model->codocuref)) {
    ?>
			<?php 
    $datos1 = CHtml::listData(Documentos::model()->findAll(array('order' => 'desdocu')), 'coddocu', 'desdocu');
    echo $form->DropDownList($model, 'codocuref', $datos1, array('empty' => '--Seleccione un documento--', 'disabled' => $model->isNewRecord ? '' : 'disabled'));
    ?>



		<?php 
} else {
    ?>
			<?php 
    echo Chtml::textField('SORA', Almacenmovimientos::model()->findByPk($model->codmovimiento)->documentos->desdocu, array('disabled' => 'disabled', 'size' => 30));
    ?>
			<?php 
    $form->hiddenField($model, 'codocuref');
    ?>
		<?php 
}
?>





		<?php 
echo $form->error($model, 'codocuref');
?>
Ejemplo n.º 4
0
 public function checkcantidad($attribute, $params)
 {
     $regisin = Alinventario::model()->encontrarregistro($this->codcentro, $this->alemi, $this->codart);
     if ($this->isNewrecord) {
         $cantidadlibre = $regisin->cantlibre;
         $umbase = $regisin->maestro->um;
         $nombreumbase = $regisin->maestro->maestro_ums->desum;
         //unset($regisin);
     } else {
         $cantidadlibre = $this->alkardex_alinventario->cantlibre;
         $umbase = $this->alkardex_alinventario->maestro->um;
         $nombreumbase = $this->alkardex_alinventario->maestro->maestro_ums->desum;
     }
     $nombrecampo = Almacenmovimientos::model()->findByPk($this->codmov)->campoafectadoinv;
     $conversion = Alconversiones::model()->convierte($this->codart, $this->um, $umbase);
     if (abs($this->cant * $conversion) > $regisin->{$nombrecampo}) {
         //$matriz2=Alconversiones::model()->findAll("um1='".trim($unidad)."'");
         $this->adderror('cant', 'No se puede mover : [' . $this->cant * $conversion . '] ' . $nombreumbase . '(s)  mas de los que hay (' . $regisin->getAttributeLabel($nombrecampo) . ')  : [' . $regisin->{$nombrecampo} . '] ' . $nombreumbase . '(s) . Verifique por favor   ');
     }
 }
Ejemplo n.º 5
0
 public function actionCreaConformidad()
 {
     $model = new Almacendocs();
     $model->valorespordefecto(CODIGO_DOC_VALE_ALMACEN);
     $this->Verificamov(CODIGO_MOVIMIENTO_INGRESO_ACTIVIDAD);
     $model->codmovimiento = CODIGO_MOVIMIENTO_INGRESO_ACTIVIDAD;
     $model->setEscenarioMov();
     $model->setScenario($model->getEscenarioMov());
     $model->codocuref = Almacenmovimientos::model()->findByPk($model->codmovimiento)->codocu;
     /*echo "<br><br><br><br> El escenario es   ".$model->getScenario()."<BR>";
     		PRINT_R($model->rules());
     		YII::APP()->END();*/
     $this->ClearBuffer($id);
     $model->iduser = Yii::app()->user->id;
     if (isset($_POST['Almacendocs'])) {
         $model->attributes = $_POST['Almacendocs'];
         if ($model->save()) {
             $this->redirect(array('confirmar', 'id' => $model->id));
         }
     }
     //echo "<br><br><br><br> al final   ".($model->isnewRecord)?"ES NUEVO ":"YA NO ES NUVEO";
     $this->render('n_create', array('model' => $model));
 }
Ejemplo n.º 6
0
 private function puedeeditarcantidad()
 {
     return Almacenmovimientos::model()->findByPk($this->codmov)->editarcantidad == '1' ? true : false;
 }
Ejemplo n.º 7
0
 public function checkvaleingreso($attribute, $params)
 {
     //Verfiicando que exista primero
     $registro = Almacendocs::model()->findAll("numvale=:nimi", array("nimi" => trim($this->numdocref)));
     if (!(count($registro) > 0)) {
         $this->adderror('numdocref', 'Este vale no existe ' . $this->numdocref . '-' . count($registro));
     } else {
         // $this->adderror('numdocref','pasffdfdfdfdfdo');
         //verificando que sea un vale adecuado para anular, un vale solo puede anular a su antagonico opuesto
         $movimientoopuesto = Almacenmovimientos::model()->findByPk($registro[0]['codmovimiento'])->anticodmov;
         if (trim($movimientoopuesto) != trim($this->codmovimiento)) {
             //si no corresponde ERROR
             $this->adderror('numdocref', 'Este vale no se puede anular con este movimiento ' . $this->codmovimiento);
         } else {
             //verificando primero si es anulable, si ya s egeneraron los registros en le kardex, si ha habido anulacion
             $matriz = Alkardex::model()->findAll("idref=:mipa and valido='1' and codmov =:movi ", array("mipa" => $registro[0]['id'], "movi" => $movimientoopuesto));
             if (count($matriz) > 0) {
                 $this->adderror('numdocref', 'Este vale ya ha sido anulado ');
             }
             //ahora verificando la fecha
             if (!Yii::app()->periodo->verificaFechas($registro[0]['fechacont'], $this->fechacont)) {
                 $this->adderror('fechacont', 'La fecha de la anulación es menor que la fecha de creación del documento a anular ');
             }
         }
     }
 }
Ejemplo n.º 8
0
 /**
  * Returns the data model based on the primary key given in the GET variable.
  * If the data model is not found, an HTTP exception will be raised.
  * @param integer $id the ID of the model to be loaded
  * @return Almacenmovimientos the loaded model
  * @throws CHttpException
  */
 public function loadModel($id)
 {
     $model = Almacenmovimientos::model()->findByPk($id);
     if ($model === null) {
         throw new CHttpException(404, 'The requested page does not exist.');
     }
     return $model;
 }
Ejemplo n.º 9
0
 public function actionPio()
 {
     $images = glob(yii::getPathOfAlias('webroot.materiales') . DIRECTORY_SEPARATOR . "{14000035.*}", GLOB_BRACE);
     //echo yii::getPathOfAlias('webroot.materiales.gallery').DIRECTORY_SEPARATOR;
     //echo "<br>";
     //imprime el nombre de cada archivo
     foreach ($images as $image) {
         echo $image . '<br />';
     }
     print_r($images);
     yii::app()->end();
     echo "  falta copmpraer " . Desolpe::model()->findByPk(730)->cuantofaltacomprar();
     yii::app()->end();
     echo "  del material azufre <br>";
     echo "   una caja   vale :  " . Alconversiones::convierte('18004728', '190') . "     unidades <br>";
     echo "   un KG  vale :  " . Alconversiones::convierte('18004728', '123') . "     unidades <br>";
     echo "   unA caja  vale :  " . Alconversiones::convierte('18004728', '190', '120') . "     unidades <br>";
     echo "   unA UNIDAD  vale :  " . Alconversiones::convierte('18004728', '120', '190') . "    CAJAS <br>";
     echo "   un KG  vale :  " . Alconversiones::convierte('18004728', '123', '120') . "     unidades <br>";
     echo "   unA UNIDAD  vale :  " . Alconversiones::convierte('18004728', '120', '123') . "    KILOGRAMOS <br>";
     echo "   un KG  vale :  " . Alconversiones::convierte('18004728', '123', '190') . "    CAJAS <br>";
     echo "   unA CAJA  vale :  " . Alconversiones::convierte('18004728', '190', '123') . "    KILOGRAMOS <br>";
     yii::app()->end();
     $model = new Noticias();
     var_dump(get_class($model));
     yii::app()->end();
     var_dump(count(Peticion::model()->search()->getdata()));
     yii::app()->end();
     ini_set('soap.wsdl_cache_enable', 0);
     ini_set('soap.wsdl_cache_ttl', 0);
     $wsdlURL = 'https://www.sunat.gob.pe/ol-ti-itcpgem-beta/billService?wsdl';
     $client = new SoapClient($wsdlURL);
     var_dump($client->__getFunctions());
     echo "<BR>";
     echo "<BR>";
     var_dump($client->__getTypes());
     //var_dump($client);
     yii::app()->end();
     //$result=$client->giveTimestamp();
     //echo $result;
     var_dump(yii::app()->user);
     echo "<br>";
     echo "<br>";
     echo "<br>";
     $elusuario = Yii::app()->user->um->LoadUserById(yii::app()->user->id);
     var_dump($elusuario);
     $sesion_activa = Yii::app()->user->um->findSession($elusuario);
     echo "<br>";
     echo " LA DURACION MAXIMA DE LA SESION " . Yii::app()->user->um->getDefaultSystem()->getn('sessionmaxdurationmins') . "   Minutos";
     echo "<br>";
     echo " la sesion expira  " . date("Y-m-d H:i:s", $sesion_activa->expire);
     echo "<br>";
     echo " la sesion inicio en " . date(" H:i:s", $sesion_activa->created);
     echo "<br>";
     echo " Ultimo uso  " . date("H:i:s", $sesion_activa->lastusage);
     echo "<br>";
     echo " la hora actual  " . date("H:i:s");
     echo "<br>";
     echo " Han pasado :   " . (time() - $sesion_activa->created) / 60 . "   minutos       con  ";
     echo "<br>";
     echo "  Sesion expirada? :\n\t\t        ->             " . var_dump($sesion_activa->isSessionExpired());
     echo "<br>";
     echo "  Sesion name  : " . $sesion_activa->getSessionName();
     echo "<br>";
     echo "  Sesion valida : " . $sesion_activa->validateSession();
     //	$sesion_activa->getSessionFilter();
     echo "<br>";
     //print_r($sesion_activa);
     yii::app()->end();
     echo yii::getPathOfAlias('webroot.materiales');
     //echo yii::app()->baseUrl;
     YII::APP()->END();
     /*var_dump(yii::app()->request);
     		echo "<br>";
     		print_r(yii::app()->request->baseUrl);*/
     echo yii::app()->getBaseUrl(true);
     echo "<br>";
     var_dump(is_dir(yii::app()->getBaseUrl(true)));
     YII::APP()->END();
     $images = glob(yii::getPathOfAlias('webroot.materiales') . DIRECTORY_SEPARATOR . "{*.JPG,*.PNG,*.JPEG,*.GIF,*.BMP}", GLOB_BRACE);
     //echo yii::getPathOfAlias('webroot.materiales.gallery').DIRECTORY_SEPARATOR;
     //echo "<br>";
     //imprime el nombre de cada archivo
     foreach ($images as $image) {
         echo $image . '<br />';
     }
     print_r($images);
     yii::app()->end();
     var_dump(is_dir("/public_html/recurso/materiales/"));
     YII::APP()->END();
     var_dump(yii::app()->estadisticas->linear_regression(array(2, 3, 3.5, 5), array(2, 3, 4, 6)));
     $this->render('//alinventario/vw_loginventario', array());
     yii::app()->end();
     $modelinv = Alinventario::model()->findByPk(343569);
     $modelinv->actualiza_stock('77', 1, null);
     yii::app()->end();
     echo Yii::app()->baseUrl;
     yii::app()->end();
     $criterio = new CDbcriteria();
     $criterio->addcondition("hidsolpe=:vid");
     $criterio->params = array(":vid" => 387);
     $objeto = new Miproveedor('Desolpe', array('criteria' => $criterio));
     //var_dump($objeto->getdata());
     $objeto->camposasumar = array("TOTAL CANTIDAD" => 'cant', 'SUBTOTAL PLANEADO' => "punitplan", 'SUBTOTAL REAL' => "punitreal");
     $subtotales = $objeto->Total();
     var_dump($subtotales);
     yii::app()->end();
     $nuevoarray = array();
     $nuevoarray['uno'] = 1;
     $nuevoarray['dos'] = 2;
     var_dump($nuevoarray);
     yii::app()->end();
     $criterio = new CDbcriteria();
     $objeto = new CActiveDataProvider('Impuestos');
     // $dataProvider->getData() will return a list of Post objects
     var_dump($objeto->getdata());
     yii::app()->end();
     //echo Almacendocs::model()->findByPk(709)->almacendocs_almacenmovimientos->eventos->estadofinal;
     var_dump(Almacendocs::model()->findByPk(709)->almacendocs_almacenmovimientos);
     yii::app()->end();
     $criterio = new CDbCriteria();
     $criterio->addCondition("hidguia=:xdet");
     $criterio->params = array(':xdet' => 59);
     //var_dump($criterio->condition);
     print_r(MiFactoria::arrayColumnaSQL(Docompra::model()->tableName(), 'id', $criterio));
     yii::app()->end();
     $images = glob(yii::getPathOfAlias('webroot.materiales') . DIRECTORY_SEPARATOR . "{*.JPG,*.PNG,*.JPEG,*.GIF,*.BMP}", GLOB_BRACE);
     //echo yii::getPathOfAlias('webroot.materiales.gallery').DIRECTORY_SEPARATOR;
     //echo "<br>";
     //imprime el nombre de cada archivo
     foreach ($images as $image) {
         echo $image . '<br />';
     }
     print_r($images);
     yii::app()->end();
     $modelito = new Ocompra();
     $modelito->codocu = $this->documento;
     echo $modelito->correlativo('numcot');
     yii::app()->end();
     echo dirname(__FILE__) . '/css/estilogrid.css';
     var_dump(is_file($_SERVER['SCRIPT_NAME'] . '/css/estilogrid.css'));
     //ECHO "..//".(strlen(dirname($_SERVER['SCRIPT_NAME']))>1 ? dirname($_SERVER['SCRIPT_NAME']) : '' ) . '/css/estilogrid.css';
     yii::app()->end();
     // una ffraccion de la forma   1/2 , 3/4 , 45/3, 1 /2 , 7./3 , 1/ 3, 234/567,  4/.5 ,
     $cadena1 = "PERNO  11/45 INOXIDABLE  7/8 HF   1/2 x 3/4  1/12 * 5/16 ";
     $cadena2 = "PERNO   12./. 56  3 1/2 INOXIDABLE  17/8 HF ";
     $cadena3 = "PERNO  45/ 34 INOXIDABLE  7./ 8 HF ";
     $cadena4 = "PERNO  1/2 4 5/34 INOXIDABLE  7 /8  HF ";
     $cadena5 = " PERNO   4/.63 INOXIDABLE  756/458 HF ";
     $cadena6 = "3/4 PERNO  1 / 3 INOXIDABLE  17/8*1 HF ";
     $cadena7 = "PERNO INOXIDABLE  3*41 25/16 1781 HF ";
     $patron = "/^(\\s)[0-9]{1,}[\\.|\\s]?[\\/]{1}[\\.|\\s]?[0-9]{1,}(\\s)\$/";
     $patron2 = '/[1-9]{0,}+[\\s|*|x|X]{1}[0-9]{1,}[\\.|\\s]{0,1}[\\/]{1}[\\.|\\s]{0,1}[0-9]{1,}[\\s|*|x|X]{1}/';
     echo $cadena1 . "    " . preg_match_all($patron2, $cadena1, $resultado1) . "<br>";
     print_r($resultado1);
     echo "<br>";
     echo "<br>";
     echo $cadena2 . "    " . preg_match_all($patron2, $cadena2, $resultado2) . "<br>";
     print_r($resultado2);
     echo "<br>";
     echo "<br>";
     echo $cadena3 . "    " . preg_match_all($patron2, $cadena3, $resultado3) . "<br>";
     print_r($resultado3);
     echo "<br>";
     echo "<br>";
     echo $cadena4 . "    " . preg_match_all($patron2, $cadena4, $resultado4) . "<br>";
     print_r($resultado4);
     echo "<br>";
     echo "<br>";
     echo $cadena5 . "    " . preg_match_all($patron2, $cadena5, $resultado5) . "<br>";
     print_r($resultado5);
     echo "<br>";
     echo "<br>";
     echo $cadena6 . "    " . preg_match_all($patron2, $cadena6, $resultado6) . "<br>";
     print_r($resultado6);
     echo "<br>";
     echo "<br>";
     echo $cadena7 . "    " . preg_match_all($patron2, $cadena7, $resultado7) . "<br>";
     print_r($resultado7);
     echo "<br>";
     echo "<br>";
     //echo $cadena8. "    ". preg_match('/^(\s)[0-9]{1,}[\.|\s]?[\/]{1}[\.|\s]?[0-9]{1,}(\s)$/',$cadena1) ."<br>";
     yii::app()->end();
     print_r(Yii::app()->user->rbac->getMenu());
     yii::app()->end();
     //$model=new Impuestos;
     yii::app()->crugemailer->mail_con_archivo('*****@*****.**', '*****@*****.**', 'hi', '130165');
     //	var_dump(mail('*****@*****.**','holas','holas'));
     yii::app()->end();
     echo Valorimpuestos::getimpuesto('200');
     $model->codocumento = '1';
     echo Valorimpuestos::model()->getimpuesto('100');
     yii::app()->end();
     $model->codocumento = '130';
     echo $model->Correlativo('numero');
     yii::app()->end();
     $modelin = CactiveRecord::model('Alkardex');
     print_r($modelin->getTableSchema());
     yii::app()->end();
     echo get_include_path();
     yii::app()->end();
     echo " la sesion expira  " . date("Y-m-d,H-i:s");
     yii::app()->end();
     echo MiFactoria::decimal(47 / 3);
     yii::app()->end();
     print_r(MiFactoria::opcionestoolbar(345, '130', '20'));
     yii::app()->end();
     $model = new Inventario();
     $objeto = $model->getMetaData();
     foreach ($objeto->columns as $columna) {
         echo "campo  " . $columna->name . "    ancho " . $columna->size . "  el tipo  : " . $columna->dbType . "<br>";
     }
     print_r($objeto->columns);
     //$model->rucpro='121212121212121';
     //$model->save();
     //print_r($model->getMetaData());
     yii::app()->end();
     $movimientoauxiliar = '45';
     $filakardexoriginal = Alkardex::model()->findByPk(1691);
     $filakardexoriginal->alkardex_alinventario->actualiza_stock($movimientoauxiliar, abs(3), null);
     yii::app()->end();
     $modeloreserva = Alreserva::model()->findByPk(255);
     var_dump($modeloreserva->alreserva_cantidadatendida);
     yii::app()->end();
     var_dump($kardex = Alkardex::model()->findByPk(1514)->alkardex_despacho);
     yii::app()->end();
     //tag(string $tag, array $htmlOptions=array ( ), mixed $content=false, boolean $closeTag=true)
     $arrayes = Almacendocs::model()->findAll("numvale=:nimi", array("nimi" => trim('130200000129')));
     echo count($arrayes);
     yii::app()->end();
     if (is_dir('assets')) {
         echo " si es un directrio";
     }
     yii::app()->end();
     Yii::app()->crugemailer->prueba();
     //echo CHtml::tag("div",array("style"=>"font:23px;fotn-size:445;"),"AQUI",true);
     $calse = new Cc();
     echo $calse::BELONGS_TO;
     //	var_dump($calse);
     //phpinfo(INFO_MODULES);
     yii::app()->end();
     //tag(string $tag, array $htmlOptions=array ( ), mixed $content=false, boolean $closeTag=true)
     $arrayes = Almacendocs::model()->findAll("numvale=:nimi", array("nimi" => trim('130200000129')));
     echo count($arrayes);
     yii::app()->end();
     echo strpos("manicomo", "c");
     Yii::app()->user->setFlash('error', "MENSAJE ERRO1");
     Yii::app()->user->setFlash('error2', "MENSAJE ERR2");
     Yii::app()->user->setFlash('error3', "MENSAJE ERR3");
     Yii::app()->user->setFlash('notice', "MENSAJE NORICE1");
     Yii::app()->user->setFlash('notice2', "MENSAJE NOTICE2");
     Yii::app()->user->setFlash('notice3', "MENSAJE NOTICE3");
     Yii::app()->user->setFlash('success', "SUCCESS ERRO1");
     Yii::app()->user->setFlash('success2', "SUCCESS ERR2");
     Yii::app()->user->setFlash('success3', "SUCCESS ERR3");
     // PRINT_R(Yii::app()->user->getFlashes());
     yii::app()->end();
     //$this->ConfirmaBuffer($id);
     $kardexhijos = MiFactoria::DevuelveKardexHijos($id);
     echo count($kardexhijos);
     /*foreach ( $kardexhijos as $filakardex ) {
     			//$filakardex->preciounit=$filakardex->getMonto();
     			//$filakardex->VerificaCantAtenReservas();
     			//$filakardex->InsertaAtencionReserva($filakardex->id);
     			echo "   id del kardex ".$filakardex->id."<br>";
     			//$filakardex->alkardex_alinventario->actualiza_stock($filakardex->codmov,abs($filakardex->cantidadbase()),null);
     
     			//$filakardex->InsertaCcGastos();
     		}
     	*/
     yii::app()->end();
     $id = 160;
     $modeloreserva = Alreserva::model()->findByPk($id);
     $modeloreserva->anular();
     PRINT_R(Yii::app()->user->getFlashes());
     yii::app()->end();
     $id = 490;
     $kardexhijos = MiFactoria::DevuelveKardexHijos($id);
     //var_dump($kardexhijos);
     foreach ($kardexhijos as $filakardex) {
         //calculando el precio unitario
         $filakardex->preciounit = $filakardex->getMonto();
         if ($filakardex->VerificaCantAtenReservas()) {
             PRINT_R($filakardex->mensajes);
         }
         //ECHO " GRABA  ".$filakardex->InsertaAtencionReserva($filakardex->id);
         $filakardex->alkardex_alinventario->actualiza_stock($filakardex->codmov, abs($filakardex->cantidadbase()), null);
         print_r($filakardex->alkardex_alinventario->mensajes);
         //verificandso si hay errrores recoger los mensajes
         /*if(!$filakardex->VerificaCantAtenReservas() or
                     !$filakardex->InsertaAtencionReserva() or
                     !$filakardex->alkardex_alinventario->actualiza_stock($filakardex->codmovimiento,$filakardex->cant,null)
                    )
                  $this->mensajes=array_merge($this->mensajes,$filakardex->mensajes,$filakardex->alkardex_alinventario->mensajes);
           */
         $filakardex->InsertaCcGastos();
     }
     yii::app()->end();
     //$nuevo=new MiFactoria();
     //Mifactoria::InsertaAtencionReserva(1357);
     $row = Alkardex::model()->findByPk(NULL);
     $matrix = Alreserva::model()->findAll("hidesolpe=:vhidsolpe AND codocu='450' ", array(":vhidsolpe" => $row->idref));
     $model = new Atencionreserva();
     $model->cant = $row->cant;
     $model->hidkardex = $row->id;
     $model->hidreserva = $matrix[0]['id'];
     $model->estadoatencion = Atencionreserva::ESTADO_CREADO;
     if (!$model->save()) {
         throw new CHttpException(500, "NO se Pudo insertar el registro de atenciones reservas ");
     }
     unset($model);
     unset($matrix);
     unset($row);
     yii::app()->end();
     $mimo = new ModeloGeneral();
     $mimo->insertamensaje('success', 'primermamesaje');
     $mimo->insertamensaje('success1', 'segundo mensaje');
     $mimo->insertamensaje('error', 'tercer mensaje');
     $mimox = new ModeloGeneral();
     $mimox->insertamensaje('successx', 'primermamesaje');
     $mimox->insertamensaje('success1x', 'segundo mensaje');
     $mimox->insertamensaje('errorx', 'tercer mensaje');
     /*$gg= new Alinventario();*/
     print_r($mimo->mensajes);
     echo "<br><br>";
     print_r($mimox->mensajes);
     $mensaj = array();
     $mensaj = array_merge($mensaj, $mimo->mensajes);
     $mensaj = array_merge($mensaj, $mimox->mensajes);
     //array_merge($mensaj,$mimox->mensajes);
     //$mensaj[]=$mimo->mensajes;
     //$mensaj[]=$mimox->mensajes+$mimo->mensajes;
     //array_push($mensaj,$mimox->mensajes);
     echo "<br><br>";
     print_r($mensaj);
     yii::app()->end();
     var_dump(Almacenmovimientos::model()->findByPk('10')->signo);
     //echo "total   ".Alinventario::getStockTotal('11000004');
     yii::app()->end();
     /*if(Yii::app()->periodo->getModel()->HoyDentroPeriodo()){
     			echo "ESTAMOS DENTRO DEL PERIODO";
     		} else {
     			echo "no  ESTAMOS DENTRO DEL PERIODO";
     		}
     
     		yii::app()->end();*/
     if (Yii::app()->periodo->verificaFechas('2015-03-5', '2015-03-4')) {
         echo "ESTAMOS DENTRO DEL PERIODO";
     } else {
         echo "no ESTAMOS DENTRO DEL PERIODO";
     }
     yii::app()->end();
     $gg = new Alkardex();
     //$gg=Alkardex::model()->findByPk(1236);
     //var_dump($gg->oldAttributes);
     echo "<BR><BR> ESCENARIO :" . $gg->getScenario() . "<BR>";
     $gg->save();
     var_dump($gg->errors);
     $ggt = new Tempalkardex();
     //$gg=Alkardex::model()->findByPk(1236);
     //var_dump($gg->oldAttributes);
     echo "<BR><BR> ESCENARIO :" . $ggt->getScenario() . "<BR>";
     $ggt->save();
     var_dump($ggt->errors);
     yii::app()->end();
     $matriz = $gg->relations();
     $nuevoarr = array();
     //print_r($matriz);
     foreach ($matriz as $clave => $matricita) {
         if ($matricita[0] == 'CHasManyRelation') {
             $nuevoarr[$matricita[2]] = $matricita[1];
         }
     }
     print_r($nuevoarr);
     //$hallo=array_search('CHasManyRelation',$matriz);
     // echo var_dump($hallo);
     yii::app()->end();
     $arreglo = array();
     /*$arreglo1=array('uno'=>1);
     		$arreglo2=array('dos'=>2);
     		$arreglo3=array('tres'=>3);*/
     $arreglo['uno'] = 1;
     $arreglo['dos'] = 2;
     print_r($arreglo);
     yii::app()->end();
     /***********************************************
      * Prueba de la propieda mensajes ARRAY() de
      * la clase MODELOGENERAL
      *
      * *******************       */
     $modelo = new ModeloGeneral();
     $modelo->insertamensaje('error', 'MENSAJE 1');
     $modelo->insertamensaje('error', 'MENSAJE 2');
     $modelo->insertamensaje('error', 'MENSAJE 3');
     $modelo->insertamensaje('notice', 'notice 1');
     $modelo->insertamensaje('notice', 'notice 2');
     $modelo->insertamensaje('success', 'succes 3');
     echo $modelo->parsemensajes('error');
     echo $modelo->parsemensajes('notice');
     echo $modelo->parsemensajes('success');
     //PRINT_R($modelo->mensajes);
     yii::app()->end();
     foreach ($arreglo as $registro) {
         echo $registro->cant;
         echo " <br><br>";
     }
     //var_dump($modelo->desolpe_alreserva);
     yii::app()->end();
     /***********************************************************
      *
      */
     /***********************************************
      * Prueba de que los registros hijos pueden ser
      * llmados desde la relacion
      *  HAS:MANY                                   */
     $modelo = Desolpe::model()->findByPk(168);
     $arreglo = $modelo->desolpe_alreserva;
     ///LLAMA A LA RELACION Y RETORNA OBJETOS HIJOS
     PRINT_R($arreglo);
     foreach ($arreglo as $registro) {
         echo $registro->cant;
         echo " <br><br>";
     }
     //var_dump($modelo->desolpe_alreserva);
     yii::app()->end();
     /***********************************************************
      *
      */
     echo Alconversiones::convierte('18005239', '120');
     yii::app()->end();
     $petri = new Peticion();
     print_r($petri->behaviors());
     if (array_key_exists('ActiveRecordLogableBehavior', $petri->behaviors())) {
         echo "salio";
     }
     yii::app()->end();
     /*print_r(MiFactoria::ExisteRegistroTemporal('Tempdpeticion',127));
     		yii::app()->end();*/
     /*print_r(Peticion::relations());
     		$campoenlace=Peticion::getFieldLink(Peticion::relations(),'Peticion','Tempdpeticion');
     		echo "<br>";
     		echo "campo enl ace   :   ".$campoenlace;
     		yii::app()->end();*/
     $id = 127;
     $con = $this->IniciaBuffer($id);
     foreach ($con as $grupo) {
         echo "<br>";
         foreach ($grupo as $objeto) {
             echo "<br>";
             foreach ($objeto as $row) {
                 echo "======================================================<br>";
                 print_r($row);
                 echo "======================================================<br>";
                 echo "<br>";
             }
         }
         echo "<br>";
     }
     $nombremodelocabecera = 'Peticion';
     foreach ($con as $registroshijos) {
         // foreach ($grupo as $registroshijos)
         //{
         // $campoenlace=$nombremodelocabecera::getFieldLink($nombremodelocabecera::relations(), $nombremodelocabecera,$nombremodelohijo);
         // $registroshijos=MiFactoria::getRegistrosHijos($nombremodelohijo,$campoenlace,$id);
         foreach ($registroshijos as $row) {
             if (is_null(MiFactoria::ExisteRegistro('Tempdpeticion', $id))) {
                 if ($row->save()) {
                     echo " <br>";
                     echo " *********************************";
                     echo " <br>";
                     echo "grabo     " . $row->getTableAlias();
                     echo " <br>";
                     echo " *********************************";
                     echo " <br>";
                 }
             }
         }
     }
     yii::app()->end();
     print_r($con);
     yii::app()->end();
     //	$lalo=null;
     $modeloant = Solpe::model()->findByPk(239);
     $matriz = $modeloant->relations();
     $palo = $this->recorro($matriz);
     //echo Solpe::HAS_MANY;
     print_r($palo);
     yii::app()->end();
     $modeloant = Solpe::model()->findByPk(239);
     print_r($modeloant->relations());
     //echo $modeloant->codart;
     yii::app()->end();
     $modelo = "Dpeticion";
     $s = new $modelo();
     print_r($s);
     yii::app()->end();
     $clasetemporal = "Alinventario";
     $valor = $clasetemporal::model()->hasAttribute('codart');
     echo "   gfgfgf " . $valor;
     yii::app()->end();
     $registroshijos = $modelo::model()->findAllBySql(" select *from\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t" . Yii::app()->params['prefijo'] . "dpeticion\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t where\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t hidpeticion=54 ");
     print_r($registroshijos);
     yii::app()->end();
     $inv = 'Alinventario';
     $arraymodelos = array();
     $modelo = $inv::model()->findByPk(343563);
     $modelo2 = $inv::model()->findByPk(343564);
     array_push($arraymodelos, $modelo);
     array_push($arraymodelos, $modelo2);
     //$nuevomod=Bloqueos::prueba();
     echo $arraymodelos[0]->codart;
     //print_r($modelo);
     yii::app()->end();
     // $modelo=new ModInventario();
     $modelo = ModInventario::loadModel(343563);
     $modeloant = ModInventario::loadModel(343563);
     //echo " hola  ".gettype($modelo->codart);
     //$modelo->actualizaprecio($cantmov,1.23,$this->CAMPO_STOCK_LIBRE);
     $nuevoprecio = 500;
     $cantmov = 100;
     if ($modelo->actualizaprecio($cantmov, $nuevoprecio, ModInventario::CAMPO_STOCK_LIBRE)) {
         echo "ok se relaizo el proceso :<br>";
         echo "cant libre :  " . $modelo->cantlibre . "                 anterior : " . $modeloant->cantlibre . "<br>";
         echo "cant reserva :  " . $modelo->cantres . "                  anterior : " . $modeloant->cantres . "<br>";
         echo "cant reserva :  " . $modelo->canttran . "                    anterior : " . $modeloant->canttran . "<br>";
         echo "Precio unitario :" . $modelo->punit . "                      anterior : " . round($modeloant->punit, 3) . "<br>";
         echo "dif de precio unitario :  " . $modelo->punitdif . "                 anterior : " . $modeloant->punitdif . "<br>";
         echo "cant stock afectado por el ambio de precio  :  " . $modelo->getStockCamposAfectadosPrecio() . "<br>";
         echo "cant movida  :   " . $cantmov . "<br>";
         echo "precio unitario nuevo  :   " . $nuevoprecio . "<br>";
         echo "-------<br><br>";
     } else {
         $matriz = $modelo->getMensajes();
         echo " HAY  " . COUNT($matriz) . "     Elementos";
         print_r($matriz);
         foreach ($matriz as $arreglo) {
             // echo   "  ".$arregloclave."  :   ".$valor."<br>";
         }
         echo "hu,,-------<br><r>";
     }
     yii::app()->end();
     $am = new MyCrugeAuthManager();
     $am->init();
     foreach ($am->autoDetect() as $itemName) {
         printf("%s\n", $itemName);
     }
     echo "  la direccion IP:  " . CrugeUtil::hash("julian");
     echo " es una instancia de " . gettype(Yii::app()->crugemailer);
     /*if (Yii::app()->CrugeMailer instanceof CrugeMailer) {
     			echo 'Crugemailer';
     		} else  {
     			echo "que carajo sera";
     		}*/
     yii::app()->end();
     $id = 54;
     $difiere = false;
     ///Asumismos que no ha variado
     $registrosactuales = Tempdpeticion::model()->findAllBySql(" select *from\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t" . Yii::app()->params['prefijo'] . "tempdpeticion\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t where\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t hidpeticion=" . $id . " and idusertemp = " . Yii::app()->user->id . " ");
     $registrosviejos = Dpeticion::model()->findAllBySql(" select *from\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t" . Yii::app()->params['prefijo'] . "dpeticion\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t where\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t hidpeticion=" . $id . " ");
     foreach ($registrosactuales as $row) {
         $newattributes = $row->getAttributes();
         ///Los valores de este instante
         foreach ($registrosviejos as $rowviejo) {
             $oldattributes = $rowviejo->getAttributes();
             echo " Emparewjando : " . $oldattributes['id'] . "  con  " . $newattributes['id'] . " <br>";
             if ($oldattributes['id'] == $newattributes['id']) {
                 echo " En la fila " . $oldattributes['id'] . "  : <br>";
                 foreach ($oldattributes as $clave => $valor) {
                     echo "Comparando  :<br>";
                     echo " original  :  " . $clave . "                               original=" . $valor . "   actual=" . $newattributes[$clave] . "<br>";
                     if ($valor != $newattributes[$clave] and $clave != 'idtemp' and $clave != 'idusertemp') {
                         echo " DIFERENTE <br><br> ";
                         $difiere = true;
                         break;
                     }
                 }
                 echo "  <br><br><br><br>";
             }
             /* print_r($newattributes );
                 echo "<br>";
                  print_r($atributos);
                echo "<br><br><br>";*/
             if ($difiere) {
                 break;
             }
         }
         /*print_r($this->bufferdetalle);
         		echo "<br>";
         		        if($difiere)
         			   break;*/
         if ($difiere) {
             break;
         }
     }
     echo "<br><br>   total    " . $difiere;
     yii::app()->end();
     $registrostemporalesdpeticion = array();
     $datosdebuffer = array();
     ///Estos datos
     $datosbufferdefila = array();
     $registroshijos = Dpeticion::model()->findAllBySql(" select *from\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t" . Yii::app()->params['prefijo'] . "dpeticion\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t where\n  \t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t hidpeticion=" . $hidpeticion . "  ");
     foreach ($registroshijos as $row) {
         ///Evitamos levantar items duplicados
         $existeregistro = Tempdpeticion::model()->find("id= " . $row->id . " AND idusertemp=" . Yii::app()->user->id . " ");
         if (is_null($existeregistro)) {
             ///Solo si no existe
             $modelotempdpeticion = new Tempdpeticion();
             $modelotempdpeticion->attributes = $row->attributes;
             $modelotempdpeticion->idusertemp = Yii::app()->user->id;
             array_push($registrostemporalesdpeticion, $modelotempdpeticion);
             $datosbufferdefila = $row->attributes;
             //array_push($datosbufferdefila,array('micalve'=>$row->id));
             array_push($datosdebuffer, $datosbufferdefila);
         }
     }
     //print_r($datosdebuffer);
     foreach ($datosdebuffer as $clave => $atributos) {
         print_r($atributos);
         echo "<br><br>";
     }
     //$this->bufferdetalle=$registrostemporalesdpeticion; ///Guarda el bu¡ffer de datos
     //return $registrostemporalesdpeticion;
     yii::app()->end();
     $arreglo = array();
     $arreglo1 = array('uno' => 1);
     $arreglo2 = array('dos' => 2);
     $arreglo3 = array('tres' => 3);
     array_push($arreglo, array('uno' => 1));
     array_push($arreglo, array('dos' => 2));
     print_r($arreglo);
     yii::app()->end();
     $id = 34;
     if ($id) {
         echo "dsdsdsds eco ";
     }
     yii::app()->end();
     $me = Yii::app()->user->id;
     $cadena = " select distinct idusertemp from " . Yii::app()->params['prefijo'] . "temppeticion WHERE id=" . $id . " and idusertemp <> " . $me . " ";
     $quien = Yii::app()->db->createCommand($cadena)->queryScalar();
     echo $cadena;
     echo " El tipo de quien " . gettype($quien) . "    -----    " . $quien;
     //yii::app()->end();
     if ($quien) {
         /// Quiere decir que hay otros que estan ediotnado el documento
         ///PARA VER SIS ES CIERTO DEEBMOS VERIFICAR Q ESTE USUARIO NO HA DEJADO LA VENTANA ABANDONADA CON E DOMCUENTO EN EDICION
         $elusuario = Yii::app()->user->um->LoadUserById($quien);
         ///hallando la sesion activa de este usuario
         $sesion_activa = Yii::app()->user->um->findSession($elusuario);
         if (is_null($sesion_activa)) {
             echo "  NO esta cupado man ";
             //No esta ocupado por que estaba editando pero ya temrino sus sesion, alo mejor dejo la ventana abierta
         } else {
             echo "  Estaa cupado por el usuario " . $elusuario->username;
             ///Si esta ocupado por que el usuario tiene sesion activa, y eszta editando
         }
     } else {
         echo "  NO esta cupado , estas solo mano  ";
     }
     yii::app()->end();
     $usuariojesus = Yii::app()->user->um->loadUser('admin', false);
     print_r($usuariojesus);
     echo "<br><br><br><br>";
     $modelo = Yii::app()->user->um->findSession($usuariojesus);
     echo " el tipo retoranado es " . gettype($modelo);
     print_r($modelo);
     echo "<br><br><br><br>El  modelo de sesion de Jesus";
     $modelo = Yii::app()->user->um->findSession(Yii::app()->user->um->loadUser('jesus', false));
     echo " el tipo retoranado es " . gettype($modelo);
     print_r($modelo);
     yii::app()->end();
     $modelo->isSessionExpired();
     if ($expiro) {
         echo "   Ya expiro ";
     } else {
         echo "   Todavia esta vignte la sesion  ";
     }
     yii::app()->end();
     $this->layout = '//layouts/iframe';
     $this->render('carachita');
     yii::app()->end();
     // $modelosolpe=Desolpe::model()->findByPk(79);
     $modelokardex = Alkardex::model()->findByPk(1236);
     $clonado = $modelokardex->clonaregistro();
     //echo $clonado->cant;
     print_r($clonado);
     yii::app()->end();
     echo " numeor reservar compras " . $modelosolpe->numero_reservascompras;
     echo " modelo cant " . $modelosolpe->cant;
     yii::app()->end();
     if ($cantidadatendidaacumulada + $modelokardex->cant == $modeloreserva->cant) {
         $modeloreserva->estadoreserva = '20';
         ///Completo...!
         ///Veriifcar primero si DESOLPE tiene partido RESERVA +RESERVA PARA COMPRA
         if ($modelodesolpe->numero_reservascompras == 0) {
             ///Si no tiene solicitudes de compra
             $modelodesolpe->est == '40';
         }
         ///Completo...!
     }
     $kardex = Alkardex::model()->findByPk(1125);
     echo "  la sumatoria de las cantidades :  " . $kardex->alkardex_alkardextraslado_emisor_cant;
     echo "  la cantidad  :  " . $kardex->cant;
     yii::app()->end();
     $modelo = new Alkardex();
     $centro = $modelo->alkardex_alinventario->cantlibre;
     echo "  el cento es  " . $centro;
     yii::app()->end();
     $modelo = Desolpe::model()->findByPk(74)->desolpe_alinventario;
     $modelo->cantlibre = 1234;
     $modelo->setScenario('modificacantidad');
     $modelo->save();
     echo "  ES " . $modelo->codart;
     yii::app()->end();
     //$modelo->Actualizar($movimiento,$cantidad,$unidad,$punitario=null);
     $mensaje = $modelo->Actualizar('80', 0.03, '140', null);
     //echo " El almacen : ".$modelo->desolpe_alinventario->codalm."  \n";
     if (strlen($mensaje) == 0) {
         echo " cantidad  libre : " . $modelo->cantlibre . "  \n";
         echo " cantidad  libre : " . $modelo->cantlibre . "  \n";
         echo " cantidad reservada : " . $modelo->cantres . "  \n";
         echo " cantidad  transito : " . $modelo->canttran . "  \n";
         echo " precio unitario : " . $modelo->punit . "  \n";
         echo " cantidad  movida : " . $modelo->cantidadmovida . "  \n";
         echo " monto movido : " . $modelo->montomovido . "  \n";
         // echo " La conversion  : ".Alconversiones::model()->convierte($modelo->codart,$modelo->um)."  \n";
         //echo " catidad reservada  : ".$modelo->desolpe_alinventario->cantres."  \n";
     } else {
         echo "  " . $mensaje;
     }
     yii::app()->end();
 }
Ejemplo n.º 10
0
 public function Actualizar($movimiento, $cantidad, $unidad, $punitario = null)
 {
     //obtenemos el signo del movimiento
     $signo = Almacenmovimientos::model()->findByPk($movimiento)->signo;
     $conversion = Alconversiones::convierte($this->codart, $unidad);
     $this->cantidadmovida = $signo * abs($conversion) * abs($cantidad);
     $mensajitoinv = "";
     //$nombrecampostock_a=gettipostock($movimiento)
     $nombrecampo_stock_a_incrementar_o_disminuir = $this->gettipostock($movimiento)['campoafectadocantidad'];
     $nombrecampo_stock_destino = $this->gettipostock($movimiento)['campodestino'];
     $array_campos_afectados_precio = $array_campos_stock_afectados_por_precio = $this->gettipostock($movimiento)['camposafectadosprecio'];
     ///Pero de que stock moveremos ?, eso se lo dejamos a la funcion gettipostock() del modelo
     $stock_a_incrementar_o_disminuir = $this->{$nombrecampo_stock_a_incrementar_o_disminuir};
     //es el stock que se va a ver (+) o (-)
     // con el movimeintos  puede ser EL VALOR DE CUALQUIER  DE ESTOS CAMPOS, SEGUN EL MOVEIMIENTO
     /*  STOCK RESERVADO    "CANTRES";
     		       STOCK EN TRANSITO   "CANTTRAN",
     		       STOCK LIBRE  "CANTLIBRE",
     		  */
     ///LA SUMA DE STOCKS AFECTADOS POR EL PRECIO VIENE ASER  LA SUAM DE LOS STOCKS CON LOS QUE SE DIVIDIRA LA SUMA DE LOS PONDERADOS DE CANTIDADES Y PRECIOS
     $suma_de_stocks_afectados_por_el_precio = 0;
     foreach ($array_campos_stock_afectados_por_precio as $key => $valor) {
         $suma_de_stocks_afectados_por_el_precio += $this->{$valor};
     }
     // con el movimeintos  puede ser EL VALOR DE CUALQUIER  DE ESTOS CAMPOS, SEGUN EL MOVEIMIENTO
     /*  STOCK RESERVADO    "CANTRES";
     		       STOCK EN TRANSITO   "CANTTRAN",
     		       STOCK LIBRE  "CANTLIBRE",
     		  */
     //verificando la consistencia del movimiento
     //para estop verificamos que los que se quiere mover (En este caso solo "quitar")
     // no es mayor que el stock  arrojado por GETTIPOSTOCK(),
     //if($signo==-1){  ///Si es un movimieto que va a sacar cosas del almacen
     if ($signo == -1 and abs($this->cantidadmovida) > $stock_a_incrementar_o_disminuir) {
         //si lo que quiere es sacar hay que analizar bien  de que movimeitno se trata
         $mensajitoinv = $mensajitoinv . "<br> Esta intentado sacar " . $this->cantidadmovida . "  (" . $this->maestro->um . " s) del material " . $this->codart . " Pero en " . $this->getAttributeLabel($nombrecampo_stock_a_incrementar_o_disminuir) . " solo hay " . $stock_a_incrementar_o_disminuir . "   Verifique bien ";
     } else {
         //En otro caso proceder
         //actualizamos la cantidad y el precio unitario
         //$this->cantlibre=$this->cantlibre+$this->cantidadmovida;
         //ECHO "CANTIDAD MOVIDA ".$cantidadmovida."  \N";
         //Yii::app()->end();
         //Buscamos el precio unitario
         ///Verificando el comportamiento del precio del material en este centro y este almacen
         $controlprecio = $this->alinventario_maestrodetalle->controlprecio;
         if (is_null($controlprecio) or empty($controlprecio) or trim($controlprecio) == '') {
             $mensajitoinv = $mensajitoinv . "<br> El material  " . $this->codart . "  No tiene registrado el control de precio en el centro  " . $this->codcen . " , y almacen  " . $this->codalm . "  Verifique los datos maestros ";
         } else {
             if (is_null($punitario)) {
                 ///Si  es nulo quiere decir que no es  dato   y debemos jalra el precio del mismo  inventario
                 if ($suma_de_stocks_afectados_por_el_precio > 0) {
                     //Si hay stock se toma el valor del inventario del mismo
                     $punitario = $this->punit;
                 } else {
                     /// ups... pero q pasa si no hay stock
                     if ($controlprecio == 'V') {
                         $mensajitoinv = $mensajitoinv . "<br> Para el material  " . $this->codart . "  No tiene stocks sensibles  en el centro  " . $this->codcen . " , y almacen  " . $this->codalm . " y no se ha suminsitrado el precio unitario en el movimiento, no es posible asignar un precio ";
                     } else {
                         /// Si es ESTANDAR  'S' , CABALLEOR NOMAS SE RESPETA EL QUE SE EUCNEUTRAEN  INVENITARIO ASI NO HAYA STOCK
                         $punitario = $this->punit;
                     }
                 }
             }
             if ($controlprecio == 'V') {
                 echo " <br>";
                 echo " <br>";
                 echo " <br>";
                 echo " <br>";
                 echo " <br>";
                 echo " <br>";
                 echo " <br>";
                 echo " <br>";
                 echo " <br>";
                 echo " <br>";
                 echo " CALCULO DEL PRECIO UNITARIO  :  Ppreciounitario x Pcantidad   x conversion :    (" . $punitario . ")  x (" . $cantidad . ") x ( " . $conversion . ")  :    " . $punitario * $cantidad * $conversion . "<br>";
                 echo "   this->punit x suma de stocks afectados  : (" . $this->punit . ")  x (" . $suma_de_stocks_afectados_por_el_precio . ")  : " . $this->punit * $suma_de_stocks_afectados_por_el_precio . " <br>";
                 echo "  vsuma_de_stocks_afectados_por_el_precio  +  this--cantidadmovida (denominador) : " . $suma_de_stocks_afectados_por_el_precio . " +  " . $this->cantidadmovida . "     :" . ($suma_de_stocks_afectados_por_el_precio + $this->cantidadmovida) . "   <br>";
                 $this->punit = abs((abs($punitario * $cantidad * $conversion) + $this->punit * $suma_de_stocks_afectados_por_el_precio) / ($suma_de_stocks_afectados_por_el_precio + abs($this->cantidadmovida)));
                 //da
                 echo " Al final se calcula el precio unitario asi: ( abs(vpunitario*vcantidad*vconversion)+ vthis->punit*vsuma_de_stocks_afectados_por_el_precio   )/(vsuma_de_stocks_afectados_por_el_precio + abs(vthis->cantidadmovida))) :   " . $this->punit . "  <br>";
             }
             ///Si es "S" estandar actualiuzar solo el campo de  la diferencia unitaria
             if ($controlprecio == 'S') {
                 $this->punitdif = $this->cantidadmovida * ($punitario - $this->punit) / ($suma_de_stocks_afectados_por_el_precio + $this->cantidadmovida);
             }
             //ntidadmovida
             $this->montomovido = $punitario * $cantidad * $conversion;
             $this->{$nombrecampo_stock_a_incrementar_o_disminuir} = $stock_a_incrementar_o_disminuir + $this->cantidadmovida;
             //OBSERVE QUE EN EL CASO QUE SEA UN MOVIMIETO QUE REQUIERA TRASLADAR UN TIPO DE STOCK A OTRO EN EL MISMO ALMACEN
             //POR EJEMPLO SEPARAR MATERIALES PARA UN TRASLADO  (CANTLIBRE -> CANTTRAN)
             if (!is_null($nombrecampo_stock_destino)) {
                 $this->{$nombrecampo_stock_destino} = $this->{$nombrecampo_stock_destino} - $this->cantidadmovida;
             }
             echo "convenrsion  :" . $conversion . " <br>";
             echo "cantidad movida  \$ this->cantidadmovida  :  " . $this->cantidadmovida . " <br>";
             echo "monto movido \$ this->montomovido :   " . $this->montomovido . " <br>";
             echo "nombrecampo a incrementar o disminuir \$ nombrecampo_stock_a_incrementar_o_disminuir  : " . $nombrecampo_stock_a_incrementar_o_disminuir . " <br>";
             echo "Stockq ue cambia    (" . $nombrecampo_stock_a_incrementar_o_disminuir . ") : " . $this->{$nombrecampo_stock_a_incrementar_o_disminuir} . " <br>";
             echo "suma de stocks  afectados por precio  : " . $suma_de_stocks_afectados_por_el_precio . "    <br>";
             echo "precio unitario   \$ this->punit   " . $this->punit . " <br>";
             echo "precio unitario dif  \$ this->punitdif : " . $this->punitdif . " <br>";
             echo " movimiento (Dato del kardex) : " . $movimiento . " <br>";
             echo "cantidad  (Dato del kardex) :" . $cantidad . " <br>";
             echo "unidad  (Dato del kardex): " . $unidad . " <br>";
             echo "preciounit (Dato del kardex)  : " . $punitario . " <br>";
             echo "Finalmente queda ASI <br>";
             echo "\$ this->cantlibre :" . $this->cantlibre . " <br>";
             echo "\$ this->cantres :" . $this->cantres . " <br>";
             echo "\$ this->canttran :" . $this->canttran . " <br>";
             echo "\$ this->cantlibre :" . $this->cantlibre . " <br>";
             echo "\$ this->punit :" . $this->punit . " <br>";
             echo "\$ this->punitdif :" . $this->punitdif . " <br>";
             echo "\$ idkardex :" . $idkardex . " <br>";
             //  Yii::app()->end();
             //  $row->codmov,$row->cant,$row->um,$row->preciounit
             ///Fin del CASE SITCW Del movimiento
         }
         //Fin del else : Es un material que tiene control de precio
     }
     //}
     return $mensajitoinv;
 }
Ejemplo n.º 11
0
        <div class="row">
            <?php 
echo $form->labelEx($model, 'codart');
?>
            <?php 
$this->widget('ext.matchcode1.Seleccionavarios', array('nombrecampo' => 'codart', 'controlador' => 'VwKardex', 'relaciones' => $model->relations(), 'tamano' => 8, 'model' => $model, 'nombremodelo' => 'Maestrocompo', 'form' => $form, 'nombredialogo' => 'cru-dialog3', 'nombreframe' => 'cru-frame3'));
?>
        </div>

	<div class="row">
		<?php 
echo $form->label($model, 'codmov');
?>

        <?php 
$datos1 = CHtml::listData(Almacenmovimientos::model()->findAll(array('order' => 'movimiento')), 'codmov', 'movimiento');
echo $form->DropDownList($model, 'codmov', $datos1, array('empty' => '--Seleccione un movimiento--'));
?>

    </div>



	<div class="row">
		<?php 
echo $form->label($model, 'alemi');
?>
		<?php 
echo $form->textField($model, 'alemi', array('size' => 3, 'maxlength' => 3));
?>
	</div>