Jump to content
  • Sky
  • Blueberry
  • Slate
  • Blackcurrant
  • Watermelon
  • Strawberry
  • Orange
  • Banana
  • Apple
  • Emerald
  • Chocolate
  • Charcoal

Leaderboard


Popular Content

Showing content with the highest reputation since 10/17/20 in all areas

  1. 11 points
    ¡Hola! Hace mucho tiempo que no hay novedades sobre el foro y el proyecto. Lo cierto es que me gustaría explicar muchas cosas, pero no dispongo de mucho tiempo actualmente. Este hilo lo publico para informar de que próximamente se traspasará la administración a @Mari0x, antiguo miembro del staff de PHPost. Conoce el proyecto desde el inicio y al igual que yo, quiere que siga vivo y tiene planes para él. Todo usuario que quiera que su cuenta o información sea eliminada, puede enviarme un mensaje privado indicándolo. Cuando llegue el momento se informará más detalladamente. ¡Saludos!
  2. 8 points
    Como dice Isidro, conocemos hace tiempo esta hermosa comunidad y queremos que siga viva, creemos que todavia queda muchisimo potencial por explotar. Invitamos a todos los usuarios a seguir siendo parte de esto, comentando, ayudando, compartiendo y lo mas importante, hacer muchos amigos. Es un gran agrado para mi poder comandar de aqui en adelante el proyecto, trayendo nuevas ideas, empujando ideas que aun estan en el tintero y por supuesto escuchando y alentando a las nuevas. Como ya dijo Isidro arriba, estaremos informando con mas detalles cuando todo este listo. Saludos PHPosteros!
  3. 7 points
    Hola a [email protected], ya se pueden descargar el tema V7 actualizado y ya funcionando con PHP 8.0.3 Cualquier duda o lo que sea lo pueden preguntar aquí mismo o en mi foro. Para cualquier otro tema, mods... no duden en preguntar. Saludos. - Se han actualizado todas las librerías del sistema, ya que las versiones anteriores tenían riesgos conocidos en la seguridad que ponen en peligro los sitios web con esas versiones al público. - Se ha creado un nuevo diseño basado en la versión de taringa la cual hemos llamado V7 Taringa el tema será llamado default en el directorio, ya que es en base al default de phpost. - Se han modificado y reestilizado los esquemas agregando un diseño mejorado, limpio y responsivo, que es lo más importante para un sitio web de actualidad. - Se han corregido muchísimos errores en la actualización del sistema, ya que la versión anterior Risus 1.3 tenía bastantes errores que ya se han corregido y otros debido a todas las actualizaciones de librerías y repositorios de terceros. - Funcionalidad completa con php 8.0.3 y anteriores, dejando la retrocompatibilidad con todas las versiones de php hasta ahora conocidas. - Algunas funcionalidades y mejoras fueron agregadas para darle un toque más parecido a lo que buscan los usuarios que usan PHPost. - Se ha mejorado el sistema en rendimiento y funcionalidad, colocando nuevas rutinas, funciones y correcciones de cosas que no funcionaban según reportes de usuarios. Demo Descarga
  4. 6 points
    Hola a [email protected], os dejo el mod de videos actualizado a 1.3 y fixeado, lo he probado en el tema default de risus pero tiene que funcionar en cualquier tema, lo que cambia es el diseño, más tarde lo dejo adaptado al diseño de la V5 y V6. Ver Demo Ejecutar estas consultas CREATE TABLE IF NOT EXISTS `v_videos` ( `vid_id` int(11) NOT NULL AUTO_INCREMENT, `vid_title` varchar(40) NOT NULL, `vid_date` int(10) NOT NULL, `vid_description` text NOT NULL, `vid_url` varchar(200) NOT NULL, `vid_user` int(11) NOT NULL, `vid_closed` int(1) NOT NULL DEFAULT '0', `vid_visitas` int(1) NOT NULL DEFAULT '0', `vid_votos_pos` int(3) NOT NULL DEFAULT '0', `vid_votos_neg` int(3) NOT NULL DEFAULT '0', `vid_status` int(1) NOT NULL DEFAULT '0', `vid_last` int(1) NOT NULL DEFAULT '0', `vid_hits` int(11) NOT NULL DEFAULT '0', `vid_ip` varchar(15) NOT NULL DEFAULT '0', PRIMARY KEY (`vid_id`) ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1; CREATE TABLE IF NOT EXISTS `v_comentarios` ( `cid` int(11) NOT NULL AUTO_INCREMENT, `c_vid_id` int(11) NOT NULL, `c_user` int(11) NOT NULL, `c_date` int(10) NOT NULL, `c_body` text NOT NULL, `c_ip` varchar(15) NOT NULL, PRIMARY KEY (`cid`) ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ; CREATE TABLE IF NOT EXISTS `v_votos` ( `vid` int(11) NOT NULL AUTO_INCREMENT, `v_vid_id` int(11) NOT NULL, `v_user` int(11) NOT NULL, `v_type` int(1) NOT NULL, `v_date` int(11) NOT NULL, PRIMARY KEY (`vid`) ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ; ALTER TABLE `w_medallas` ADD `m_cond_video` INT( 11 ) NOT NULL; ALTER TABLE `w_medallas` ADD `m_cond_video` INT( 11 ) NOT NULL; ALTER TABLE `w_stats` ADD `stats_video_comments` INT NOT NULL; ALTER TABLE `w_stats` ADD `stats_video_comments` INT NOT NULL; En c.admin.php --> inc --> class --> c.admin.php Buscar: function GetAdminStats() { $num = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'2\') as fotos_eliminadas, (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'1\') as fotos_ocultas, (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'0\') as fotos_visibles, (SELECT count(post_id) FROM p_posts WHERE post_status = \'0\') as posts_visibles, (SELECT count(post_id) FROM p_posts WHERE post_status = \'1\') as posts_ocultos, (SELECT count(post_id) FROM p_posts WHERE post_status = \'2\') as posts_eliminados, (SELECT count(post_id) FROM p_posts WHERE post_status = \'3\') as posts_revision, (SELECT count(cid) FROM p_comentarios WHERE c_status = \'0\') as comentarios_posts_visibles, (SELECT count(cid) FROM p_comentarios WHERE c_status = \'1\') as comentarios_posts_ocultos, (SELECT count(user_id) FROM u_miembros WHERE user_activo = \'1\') as usuarios_activos, (SELECT count(user_id) FROM u_miembros WHERE user_activo = \'0\' ) as usuarios_inactivos, (SELECT count(user_id) FROM u_miembros WHERE user_baneado = \'1\' ) as usuarios_baneados, (SELECT count(cid) FROM f_comentarios) as comentarios_fotos_total, (SELECT count(follow_id) FROM u_follows WHERE f_type = \'1\' ) AS usuarios_follows, (SELECT count(follow_id) FROM u_follows WHERE f_type = \'2\' ) AS posts_follows, (SELECT count(follow_id) FROM u_follows WHERE f_type = \'3\' ) AS posts_compartidos, (SELECT count(fav_id) FROM p_favoritos) AS posts_favoritos, (SELECT count(mr_id) FROM u_respuestas) AS usuarios_respuestas, (SELECT count(mp_id) FROM u_mensajes) AS mensajes_total, (SELECT count(mp_id) FROM u_mensajes WHERE mp_del_to = \'1\') AS mensajes_de_eliminados, (SELECT count(mp_id) FROM u_mensajes WHERE mp_del_from = \'1\') AS mensajes_para_eliminados, (SELECT count(bid) FROM p_borradores) AS posts_borradores, (SELECT count(bid) FROM u_bloqueos) AS usuarios_bloqueados, (SELECT count(bid) FROM u_bloqueos) AS usuarios_bloqueados, (SELECT count(medal_id) FROM w_medallas WHERE m_type = \'1\') AS medallas_usuarios, (SELECT count(medal_id) FROM w_medallas WHERE m_type = \'2\') AS medallas_posts, (SELECT count(medal_id) FROM w_medallas WHERE m_type = \'3\') AS medallas_fotos, (SELECT count(id) FROM w_medallas_assign) AS medallas_asignadas, (SELECT count(aid) FROM w_afiliados WHERE a_active = \'1\') AS afiliados_activos, (SELECT count(aid) FROM w_afiliados WHERE a_active = \'0\') AS afiliados_inactivos, (SELECT count(pub_id) FROM u_muro) AS muro_estados, (SELECT count(cid) FROM u_muro_comentarios) AS muro_comentarios ')); $num['usuarios_total'] = $num['usuarios_activos'] + $num['usuarios_inactivos'] + $num['usuarios_baneados']; $num['seguidos_total'] = $num['posts_follows'] + $num['usuarios_follows']; $num['muro_total'] = $num['muro_estados'] + $num['muro_comentarios']; $num['afiliados_total'] = $num['afiliados_activos'] + $num['afiliados_inactivos']; $num['posts_total'] = $num['posts_visibles'] + $num['posts_ocultos'] + $num['posts_eliminados']; $num['comentarios_posts_total'] = $num['comentarios_posts_visibles'] + $num['comentarios_posts_ocultos']; $num['medallas_total'] = $num['medallas_usuarios'] + $num['medallas_posts'] + $num['medallas_fotos']; $num['fotos_total'] = $num['fotos_visibles'] + $num['fotos_ocultas'] + $num['fotos_eliminadas']; Reemplazar por: function GetAdminStats() { $num = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'2\') as fotos_eliminadas, (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'1\') as fotos_ocultas, (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'0\') as fotos_visibles, (SELECT count(vid_id) FROM v_videos WHERE vid_status = \'2\') as videos_eliminados, (SELECT count(vid_id) FROM v_videos WHERE vid_status = \'1\') as videos_ocultos, (SELECT count(vid_id) FROM v_videos WHERE vid_status = \'0\') as videos_visibles, (SELECT count(post_id) FROM p_posts WHERE post_status = \'0\') as posts_visibles, (SELECT count(post_id) FROM p_posts WHERE post_status = \'1\') as posts_ocultos, (SELECT count(post_id) FROM p_posts WHERE post_status = \'2\') as posts_eliminados, (SELECT count(post_id) FROM p_posts WHERE post_status = \'3\') as posts_revision, (SELECT count(cid) FROM p_comentarios WHERE c_status = \'0\') as comentarios_posts_visibles, (SELECT count(cid) FROM p_comentarios WHERE c_status = \'1\') as comentarios_posts_ocultos, (SELECT count(user_id) FROM u_miembros WHERE user_activo = \'1\') as usuarios_activos, (SELECT count(user_id) FROM u_miembros WHERE user_activo = \'0\' ) as usuarios_inactivos, (SELECT count(user_id) FROM u_miembros WHERE user_baneado = \'1\' ) as usuarios_baneados, (SELECT count(cid) FROM f_comentarios) as comentarios_fotos_total, (SELECT count(cid) FROM v_comentarios) as comentarios_videos_total, (SELECT count(follow_id) FROM u_follows WHERE f_type = \'1\' ) AS usuarios_follows, (SELECT count(follow_id) FROM u_follows WHERE f_type = \'2\' ) AS posts_follows, (SELECT count(follow_id) FROM u_follows WHERE f_type = \'3\' ) AS posts_compartidos, (SELECT count(fav_id) FROM p_favoritos) AS posts_favoritos, (SELECT count(mr_id) FROM u_respuestas) AS usuarios_respuestas, (SELECT count(mp_id) FROM u_mensajes) AS mensajes_total, (SELECT count(mp_id) FROM u_mensajes WHERE mp_del_to = \'1\') AS mensajes_de_eliminados, (SELECT count(mp_id) FROM u_mensajes WHERE mp_del_from = \'1\') AS mensajes_para_eliminados, (SELECT count(bid) FROM p_borradores) AS posts_borradores, (SELECT count(bid) FROM u_bloqueos) AS usuarios_bloqueados, (SELECT count(bid) FROM u_bloqueos) AS usuarios_bloqueados, (SELECT count(medal_id) FROM w_medallas WHERE m_type = \'1\') AS medallas_usuarios, (SELECT count(medal_id) FROM w_medallas WHERE m_type = \'2\') AS medallas_posts, (SELECT count(medal_id) FROM w_medallas WHERE m_type = \'3\') AS medallas_fotos, (SELECT count(medal_id) FROM w_medallas WHERE m_type = \'4\') AS medallas_videos, (SELECT count(id) FROM w_medallas_assign) AS medallas_asignadas, (SELECT count(aid) FROM w_afiliados WHERE a_active = \'1\') AS afiliados_activos, (SELECT count(aid) FROM w_afiliados WHERE a_active = \'0\') AS afiliados_inactivos, (SELECT count(pub_id) FROM u_muro) AS muro_estados, (SELECT count(cid) FROM u_muro_comentarios) AS muro_comentarios ')); $num['usuarios_total'] = $num['usuarios_activos'] + $num['usuarios_inactivos'] + $num['usuarios_baneados']; $num['seguidos_total'] = $num['posts_follows'] + $num['usuarios_follows']; $num['muro_total'] = $num['muro_estados'] + $num['muro_comentarios']; $num['afiliados_total'] = $num['afiliados_activos'] + $num['afiliados_inactivos']; $num['posts_total'] = $num['posts_visibles'] + $num['posts_ocultos'] + $num['posts_eliminados']; $num['comentarios_posts_total'] = $num['comentarios_posts_visibles'] + $num['comentarios_posts_ocultos']; $num['medallas_total'] = $num['medallas_usuarios'] + $num['medallas_posts'] + $num['medallas_videos'] + $num['medallas_fotos']; $num['fotos_total'] = $num['fotos_visibles'] + $num['fotos_ocultas'] + $num['fotos_eliminadas']; $num['videos_total'] = $num['videos_visibles'] + $num['videos_ocultos'] + $num['videos_eliminados']; En c.moderacion.php --> inc --> class --> c.moderacion.php Buscar: case 'mps': $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT r.*, m.mp_id, m.mp_to, m.mp_from, m.mp_subject, m.mp_preview, m.mp_date FROM w_denuncias AS r LEFT JOIN u_mensajes AS m ON r.obj_id = m.mp_id WHERE d_type = 2 GROUP BY r.obj_id ORDER BY r.d_date DESC'); $data = result_array($query); break; Debajo agregar: case 'videos': $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT r.*, SUM(d_total) AS total, v.vid_id, v.vid_title, v.vid_status, u.user_id, u.user_name FROM w_denuncias AS r LEFT JOIN v_videos AS v ON r.obj_id = v.vid_id LEFT JOIN u_miembros AS u ON v.vid_user = u.user_id WHERE d_type = \'5\' &amp;&amp; v.vid_status < 2 GROUP BY r.obj_id ORDER BY total DESC, r.d_date DESC'); $data = result_array($query); break; Buscar: case 'users': $d_type = 3; $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT user_id, user_name FROM u_miembros WHERE user_id = ' . $obj . ' LIMIT 1'); break; Debajo agregar: case 'videos': $d_type = 5; $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT v.vid_id, v.vid_title, v.vid_status, u.user_name FROM v_videos AS v LEFT JOIN u_miembros AS u ON v.vid_user = u.user_id WHERE v.vid_id = ' . $obj . ' LIMIT 1'); break; Buscar: $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT f.foto_id, f.f_title, f.f_user, f.f_date, f.f_ip, u.user_name FROM f_fotos AS f LEFT JOIN u_miembros AS u ON f.f_user = u.user_id WHERE ' . ($tipo == 1 ? 'f.f_ip ' . $met . '' : 'f.f_title ' . $met . ' OR f.f_description ' . $met)); $data['fotos'] = result_array($query); $data['f_total'] = count($data['fotos']); // Debajo agregar: $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT v.vid_id, v.vid_title, v.vid_user, v.vid_date, v.vid_ip, u.user_name FROM v_videos AS f LEFT JOIN u_miembros AS u ON v.vid_user = u.user_id WHERE ' . ($tipo == 1 ? 'v.vid_ip ' . $met . '' : 'v.vid_title ' . $met . ' OR v.vid_description ' . $met)); $data['videos'] = result_array($query); $data['v_total'] = count($data['videos']); Buscar: // $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT u.user_id, u.user_name, f.* , c.* FROM f_comentarios AS c LEFT JOIN u_miembros AS u ON u.user_id = c.c_user LEFT JOIN f_fotos AS f ON f.foto_id = c.c_foto_id WHERE ' . ($tipo == 1 ? 'c.c_ip ' . $met . '' : 'c.c_user ' . $met . ' OR c.c_body ' . $met)); $data['f_comentarios'] = result_array($query); $data['c_f_total'] = count($data['f_comentarios']); // Debajo agregar: $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT u.user_id, u.user_name, v.* , c.* FROM v_comentarios AS c LEFT JOIN u_miembros AS u ON u.user_id = c.c_user LEFT JOIN v_videos AS f ON v.vid_id = c.c_video_id WHERE ' . ($tipo == 1 ? 'c.c_ip ' . $met . '' : 'c.c_user ' . $met . ' OR c.c_body ' . $met)); $data['v_comentarios'] = result_array($query); $data['c_v_total'] = count($data['v_comentarios']); // Buscar: /** * @name deletePost($pid) * @access public * @param int * @return string */ Arriba agregar: function rebootVideo($vid) { global $tsUser; if ($tsUser->is_admod) { $rows = db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT obj_id FROM w_denuncias WHERE obj_id = \'' . (int)$mid . '\' AND `d_type` = \'5\'')); if ($rows && $tsUser->is_admod) { $canview = true; } //BORRAMOS LA DENUNCIA if (db_exec(array(__FILE__, __LINE__), 'query', 'DELETE FROM `w_denuncias` WHERE `obj_id` = \'' . (int)$vid . '\' AND `d_type` = \'5\'')) { db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE `v_videos` SET vid_status= \'0\' WHERE `vid_id` = \'' . (int) $vid . '\''); return '1: Denuncia eliminada'; } else return '0: No se pudo eliminar la denuncia'; } else return '0: No contin&uacute;e por aqu&iacute;.'; } Buscar: /** * @name setSticky * @access public * @param $post_id * @return string * @info Pone sticky un post */ Arriba agregar: public function deleteVideo($vid) { global $tsCore, $tsMonitor, $tsUser; if ($tsUser->is_admod) { // RAZON $razon = $tsCore->setSecure($_POST['razon']); $razon_desc = $tsCore->setSecure($_POST['razon_desc']); $razon_db = ($razon != 8) ? $razon : $razon_desc; // if (db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE `v_videos` SET `vid_status` = \'2\' WHERE `vid_id` = \'' . $vid . '\'')) { db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE `w_stats` SET `stats_videos` = stats_videos - \'1\' WHERE `stats_no` = \'1\''); if ($data['vid_user'] != $tsUser->uid) { // ENVIAR AVISO $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT v.vid_user, v.vid_title, u.user_name FROM v_videos AS v LEFT JOIN u_miembros AS u ON v.vid_user = u.user_id WHERE v.vid_id = \'' . (int)$vid . '\' LIMIT 1'); $data = db_exec('fetch_assoc', $query); // RAZON if (is_numeric($razon_db)) { include (TS_EXTRA . 'datos.php'); $razon_db = $tsDenuncias['videos'][$razon_db]; } // AVISO $aviso = 'Hola <b>' . $data['user_name'] . "</b>\n\n Lamento contarte que tu video titulado <b>" . $data['vid_title'] . "</b> ha sido eliminado.\n\n Causa: <b>" . $razon_db . "</b>\n\n Te recomendamos leer el <a href=\"" . $tsCore->settings['url'] . "/pages/protocolo/\">Protocolo</a> para evitar futuras sanciones.\n\n Muchas gracias por entender!"; $status = $tsMonitor->setAviso($data['vid_user'], 'Video eliminado', $aviso, 1); // } // ELIMINAR DENUNCIAS db_exec(array(__FILE__, __LINE__), 'query', 'DELETE FROM `w_denuncias` WHERE `obj_id` = \'' . $vid . '\' AND `d_type` = \'5\''); $this->setHistory('borrar', 'video', $vid); return '1: El video ha sido eliminado.'; } // return '0: El video NO pudo ser eliminado.'; } else return '0: No deberías continuar con esto.'; } Buscar: } public function getPospelera() { Arriba agregar: elseif ($type == 'video') { // DATOS $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT `vid_id`, `vid_description`, `vid_title`, `vid_user` FROM `v_videos` WHERE `vid_id` = \'' . (int)$data . '\' LIMIT 1'); $video = db_exec('fetch_assoc', $query); switch ($action) { case 'borrar': // RAZON $razon = $tsCore->setSecure($_POST['razon']); $razon_desc = $tsCore->setSecure($_POST['razon_desc']); $razon_db = ($razon != 8) ? $razon : $razon_desc; // INSERTAR db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO w_historial (`pofid`, `action`, `type`, `mod`, `reason`, `date`, `mod_ip`) VALUES (\'' . (int)$video['vid_id'] . '\', \'2\', \'2\', \'' . $tsUser->uid . '\', \'' . $tsCore->setSecure($razon_db) . '\', \'' . time() . '\', \'' . $tsCore->setSecure($_SERVER['REMOTE_ADDR']) . '\')'); return true; break; } } Buscar: public function getComentariosD() { Arriba agregar: public function getVipelera() { global $tsUser, $tsCore; // $max = 20; // MAXIMO A MOSTRAR $limit = $tsCore->setPageLimit($max, true); // PAGINAS $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(*) FROM v_videos AS v LEFT JOIN u_miembros AS u ON u.user_id = v.vid_user LEFT JOIN w_historial AS h ON h.pofid = v.vid_id WHERE h.type = \'2\' AND h.action = \'2\' AND v.vid_status = \'2\''); list($total) = db_exec('fetch_row', $query); $data['pages'] = $tsCore->pageIndex($tsCore->settings['url'] . "/moderacion/vipelera?", $_GET['s'], $total, $max); // $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT u.user_id, u.user_name, h.*, v.vid_id, v.vid_title, v.vid_user FROM v_videos AS v LEFT JOIN u_miembros AS u ON u.user_id = v.vid_user LEFT JOIN w_historial AS h ON h.pofid = v.vid_id WHERE h.type = \'2\' AND h.action = \'2\' AND v.vid_status = \'2\' LIMIT ' . $limit); // DENUNCIAS include ("../ext/datos.php"); // while ($row = db_exec('fetch_assoc', $query)) { $row['mod_name'] = $tsUser->getUserName($row['mod']); $row['reason'] = (is_numeric($row['reason'])) ? $tsDenuncias['videos'][$row['reason']] : $tsCore->setSecure($row['reason']); // $data['datos'][] = $row; } // return $data; } En c.medals.php --> inc --> class --> c.medals.php Buscar: $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT u.user_id, u.user_name, a.*, p.post_id, p.post_title, c.c_nombre, c.c_seo, f.foto_id, f.f_title, w.* FROM w_medallas_assign AS a LEFT JOIN u_miembros AS u ON u.user_id = a.medal_for LEFT JOIN p_posts AS p ON p.post_id = a.medal_for LEFT JOIN p_categorias AS c ON c.cid = p.post_category LEFT JOIN f_fotos AS f ON f.foto_id = a.medal_for LEFT JOIN w_medallas AS w ON w.medal_id = a.medal_id ORDER BY a.medal_date DESC LIMIT '.$limit); $datos['asignaciones'] = result_array($query); Reemplazar por: $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT u.user_id, u.user_name, a.*, p.post_id, p.post_title, c.c_nombre, c.c_seo, f.foto_id, f.f_title, v.vid_id, v.vid_title, w.* FROM w_medallas_assign AS a LEFT JOIN u_miembros AS u ON u.user_id = a.medal_for LEFT JOIN p_posts AS p ON p.post_id = a.medal_for LEFT JOIN p_categorias AS c ON c.cid = p.post_category LEFT JOIN f_fotos AS f ON f.foto_id = a.medal_for LEFT JOIN v_videos AS v ON v.vid_id = a.medal_for LEFT JOIN w_medallas AS w ON w.medal_id = a.medal_id ORDER BY a.medal_date DESC LIMIT '.$limit); $datos['asignaciones'] = result_array($query); Buscar: public function editMedal(){ global $tsCore; // DATOS $medalla = array( 'titulo' => $tsCore->parseBadWords($_POST['med_title']), 'descripcion' => $tsCore->parseBadWords($_POST['med_desc']), 'imagen' => $_POST['med_img'], 'tipo' => $_POST['med_type'], 'cantidad' => $_POST['med_cant'], 'cond_user' => $_POST['med_cond_user'], 'cond_user_rango' => $_POST['med_cond_user_rango'], 'cond_post' => $_POST['med_cond_post'], 'cond_foto' => $_POST['med_cond_foto'], ); if(empty($medalla['titulo']) || empty($medalla['descripcion'])) return 'Debe introducir t&iacute;tulo y descripci&oacute;n'; // No campos vacíos if(is_numeric($medalla['tipo']) && is_numeric($medalla['cond_user']) && is_numeric($medalla['cond_user_rango']) && is_numeric($medalla['cond_post']) && is_numeric($medalla['cond_foto'])){ //COMPROBAMOS QUE NO EXISTA if($medalla['tipo'] == 1){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM `w_medallas` WHERE `m_type` = \'1\' AND `m_cant` = \''.(int)$medalla['cantidad'].'\' AND `m_cond_user` = \''.(int)$medalla['cond_user'].'\' AND `m_cond_user_rango` = \''.(int)$medalla['cond_user_rango'].'\' AND medal_id != \''.(int)$_GET['mid'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 2){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'2\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post = \''.(int)$medalla['cond_post'].'\' AND medal_id != \''.(int)$_GET['mid'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 3){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'3\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post = \''.(int)$medalla['cond_foto'].'\' AND medal_id != \''.(int)$_GET['mid'].'\''))) $continue = false; else $continue = true; } // ACTUALIZAR if($continue == true) { if(db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE w_medallas SET m_title = \''.$tsCore->setSecure($medalla['titulo'], true).'\', m_description = \''.$tsCore->setSecure($medalla['descripcion'], true).'\', m_image = \''.$tsCore->setSecure($medalla['imagen'], true).'\', m_cant = \''.(int)$medalla['cantidad'].'\', m_type = \''.(int)$medalla['tipo'].'\', m_cond_user = \''.(int)$medalla['cond_user'].'\', m_cond_user_rango = \''.(int)$medalla['cond_user_rango'].'\', m_cond_post = \''.(int)$medalla['cond_post'].'\', m_cond_foto = \''.(int)$medalla['cond_foto'].'\' WHERE medal_id = \''.(int)$_GET['mid'].'\'')) return true; }else return 'Ya existe una medalla con esas caracter&iacute;sticas'; }else return 'Introduzca valores num&eacute;ricos'; } Reemplazar por: public function editMedal(){ global $tsCore; // DATOS $medalla = array( 'titulo' => $tsCore->parseBadWords($_POST['med_title']), 'descripcion' => $tsCore->parseBadWords($_POST['med_desc']), 'imagen' => $_POST['med_img'], 'tipo' => $_POST['med_type'], 'cantidad' => $_POST['med_cant'], 'cond_user' => $_POST['med_cond_user'], 'cond_user_rango' => $_POST['med_cond_user_rango'], 'cond_post' => $_POST['med_cond_post'], 'cond_foto' => $_POST['med_cond_foto'], 'cond_video' => $_POST['med_cond_video'], ); if(empty($medalla['titulo']) || empty($medalla['descripcion'])) return 'Debe introducir t&iacute;tulo y descripci&oacute;n'; // No campos vacíos if(is_numeric($medalla['tipo']) && is_numeric($medalla['cond_user']) && is_numeric($medalla['cond_user_rango']) && is_numeric($medalla['cond_post']) && is_numeric($medalla['cond_video']) && is_numeric($medalla['cond_foto'])){ //COMPROBAMOS QUE NO EXISTA if($medalla['tipo'] == 1){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM `w_medallas` WHERE `m_type` = \'1\' AND `m_cant` = \''.(int)$medalla['cantidad'].'\' AND `m_cond_user` = \''.(int)$medalla['cond_user'].'\' AND `m_cond_user_rango` = \''.(int)$medalla['cond_user_rango'].'\' AND medal_id != \''.(int)$_GET['mid'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 2){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'2\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post = \''.(int)$medalla['cond_post'].'\' AND medal_id != \''.(int)$_GET['mid'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 3){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'3\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post = \''.(int)$medalla['cond_foto'].'\' AND medal_id != \''.(int)$_GET['mid'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 4){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'4\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post \''.(int)$medalla['cond_video'].'\' AND medal_id != \''.(int)$_GET['mid'].'\''))) $continue = false; else $continue = true; } // ACTUALIZAR if($continue == true) { if(db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE w_medallas SET m_title = \''.$tsCore->setSecure($medalla['titulo'], true).'\', m_description = \''.$tsCore->setSecure($medalla['descripcion'], true).'\', m_image = \''.$tsCore->setSecure($medalla['imagen'], true).'\', m_cant = \''.(int)$medalla['cantidad'].'\', m_type = \''.(int)$medalla['tipo'].'\', m_cond_user = \''.(int)$medalla['cond_user'].'\', m_cond_user_rango = \''.(int)$medalla['cond_user_rango'].'\', m_cond_post = \''.(int)$medalla['cond_post'].'\', m_cond_video = \''.(int)$medalla['cond_video'].'\', m_cond_foto = \''.(int)$medalla['cond_foto'].'\' WHERE medal_id = \''.(int)$_GET['mid'].'\'')) return true; }else return 'Ya existe una medalla con esas caracter&iacute;sticas'; }else return 'Introduzca valores num&eacute;ricos'; } Buscar: public function adNewMedal(){ global $tsUser, $tsCore; // DATOS $medalla = array( 'titulo' => $tsCore->parseBadWords($_POST['med_title']), 'descripcion' => $tsCore->parseBadWords($_POST['med_desc']), 'imagen' => $_POST['med_img'], 'tipo' => $_POST['med_type'], 'cantidad' => $_POST['med_cant'], 'cond_user' => $_POST['med_cond_user'], 'cond_user_rango' => $_POST['med_cond_user_rango'], 'cond_post' => $_POST['med_cond_post'], 'cond_foto' => $_POST['med_cond_foto'], ); if(empty($medalla['titulo']) || empty($medalla['descripcion'])) return 'Debe introducir t&iacute;tulo y descripci&oacute;n'; // No campos vacíos if(is_numeric($medalla['tipo']) && is_numeric($medalla['cond_user']) && is_numeric($medalla['cond_user_rango']) && is_numeric($medalla['cond_post']) && is_numeric($medalla['cond_foto'])){ //COMPROBAMOS QUE NO EXISTA if($medalla['tipo'] == 1){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM `w_medallas` WHERE `m_type` = \'1\' AND `m_cant` = \''.(int)$medalla['cantidad'].'\' AND `m_cond_user` = \''.(int)$medalla['cond_user'].'\' AND `m_cond_user_rango` = \''.(int)$medalla['cond_user_rango'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 2){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'2\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post = \''.(int)$medalla['cond_post'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 3){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'3\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post = \''.(int)$medalla['cond_foto'].'\''))) $continue = false; else $continue = true; } // INSERTAR if($continue == true) { if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_medallas` (`m_autor`, `m_title`, `m_description`, `m_image`, `m_cant`, `m_type`, `m_cond_user`, `m_cond_user_rango`, `m_cond_post`, `m_cond_foto`, `m_date`) VALUES (\''.$tsUser->uid.'\', \''.$tsCore->setSecure($medalla['titulo'], true).'\', \''.$tsCore->setSecure($medalla['descripcion'], true).'\', \''.$tsCore->setSecure($medalla['imagen'], true).'\', \''.(int)$medalla['cantidad'].'\', \''.(int)$medalla['tipo'].'\', \''.(int)$medalla['cond_user'].'\', \''.(int)$medalla['cond_user_rango'].'\', \''.(int)$medalla['cond_post'].'\', \''.(int)$medalla['cond_foto'].'\', \''.time().'\')')) return true; else return 'No se pudo insertar la medalla'; }else return 'Ya existe una medalla con esas caracter&iacute;sticas'; }else return 'Introduzca valores num&eacute;ricos'; } Reemplazar por: public function adNewMedal(){ global $tsUser, $tsCore; // DATOS $medalla = array( 'titulo' => $tsCore->parseBadWords($_POST['med_title']), 'descripcion' => $tsCore->parseBadWords($_POST['med_desc']), 'imagen' => $_POST['med_img'], 'tipo' => $_POST['med_type'], 'cantidad' => $_POST['med_cant'], 'cond_user' => $_POST['med_cond_user'], 'cond_user_rango' => $_POST['med_cond_user_rango'], 'cond_post' => $_POST['med_cond_post'], 'cond_foto' => $_POST['med_cond_foto'], 'cond_video' => $_POST['med_cond_video'], ); if(empty($medalla['titulo']) || empty($medalla['descripcion'])) return 'Debe introducir t&iacute;tulo y descripci&oacute;n'; // No campos vacíos if(is_numeric($medalla['tipo']) && is_numeric($medalla['cond_user']) && is_numeric($medalla['cond_user_rango']) && is_numeric($medalla['cond_post']) && is_numeric($medalla['cond_post']) && is_numeric($medalla['cond_foto']) && is_numeric($medalla['cond_video'])){ //COMPROBAMOS QUE NO EXISTA if($medalla['tipo'] == 1){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM `w_medallas` WHERE `m_type` = \'1\' AND `m_cant` = \''.(int)$medalla['cantidad'].'\' AND `m_cond_user` = \''.(int)$medalla['cond_user'].'\' AND `m_cond_user_rango` = \''.(int)$medalla['cond_user_rango'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 2){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'2\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post = \''.(int)$medalla['cond_post'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 3){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'3\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post = \''.(int)$medalla['cond_foto'].'\''))) $continue = false; else $continue = true; }elseif($medalla['tipo'] == 4){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE m_type = \'4\' && m_cant = \''.(int)$medalla['cantidad'].'\' && m_cond_post \''.(int)$medalla['cond_video'].'\''))) $continue = false; else $continue = true; } // INSERTAR if($continue == true) { if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_medallas` (`m_autor`, `m_title`, `m_description`, `m_image`, `m_cant`, `m_type`, `m_cond_user`, `m_cond_user_rango`, `m_cond_post`, `m_cond_foto`, `m_cond_video`, `m_date`) VALUES (\''.$tsUser->uid.'\', \''.$tsCore->setSecure($medalla['titulo'], true).'\', \''.$tsCore->setSecure($medalla['descripcion'], true).'\', \''.$tsCore->setSecure($medalla['imagen'], true).'\', \''.(int)$medalla['cantidad'].'\', \''.(int)$medalla['tipo'].'\', \''.(int)$medalla['cond_user'].'\', \''.(int)$medalla['cond_user_rango'].'\', \''.(int)$medalla['cond_post'].'\', \''.(int)$medalla['cond_foto'].'\', \''.(int)$medalla['cond_video'].'\', \''.time().'\')')) return true; else return 'No se pudo insertar la medalla'; }else return 'Ya existe una medalla con esas caracter&iacute;sticas'; }else return 'Introduzca valores num&eacute;ricos'; } Buscar: public function AsignarMedalla(){ global $tsUser, $tsCore; // DATOS $medalla = intval($_POST['mid']); $usuario = strtolower($_POST['m_usuario']); $post = intval($_POST['pid']); $foto = intval($_POST['fid']); $user_id = $tsUser->getUserID($usuario); if(!empty($medalla) && !empty($usuario) || !empty($post) || !empty($foto)){ if($usuario){ $yeltipo = 'AND m_type = \'1\''; }elseif($post){ $yeltipo = 'AND m_type = \'2\''; }elseif($foto){ $yeltipo = 'AND m_type = \'3\''; } if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE medal_id = \''.(int)$medalla.'\' '.$yeltipo.' LIMIT 1'))) { $_SERVER['REMOTE_ADDR'] = $_SERVER['X_FORWARDED_FOR'] ? $_SERVER['X_FORWARDED_FOR'] : $_SERVER['REMOTE_ADDR']; if(filter_var($_SERVER['REMOTE_ADDR'], FILTER_VALIDATE_IP)) { if($usuario){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT user_id FROM u_miembros WHERE LOWER(user_name) = \''.$tsCore->setSecure($usuario).'\' LIMIT 1'))) { if(!db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT id FROM w_medallas_assign WHERE medal_id = \''.(int)$medalla.'\' && medal_for = \''.(int)$user_id.'\' LIMIT 1'))) { if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_medallas_assign` (`medal_id`, `medal_for`, `medal_date`, `medal_ip`) VALUES (\''.(int)$medalla.'\', \''.(int)$user_id.'\', \''.time().'\', \''.$_SERVER['REMOTE_ADDR'].'\')') or die (show_error('Error al ejecutar la consulta de la l&iacute;nea '.__LINE__.' de '.__FILE__.'.', 'db'))){ if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO u_monitor (user_id, obj_uno, not_type, not_date) VALUES (\''.(int)$user_id.'\', \''.(int)$medalla.'\', \'15\', \''.time().'\')')){ $continuar = true; }else return 'Ocurri&oacute; un error al notificar al usuario'; }else return 'Ocurri&oacute; un error al asignar la medalla'; }else return '0: El usuario ya tiene esa medalla'; }else return '0: El usuario no existe'; }elseif($post){ if(db_exec('num_rows', $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT post_id, post_user FROM p_posts WHERE post_id = \''.(int)$post.'\' LIMIT 1'))){ $datosdelpost = db_exec('fetch_assoc', $query); if(!db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT id FROM w_medallas_assign WHERE medal_id = \''.(int)$medalla.'\' && medal_for = \''.(int)$post.'\' LIMIT 1'))) { if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_medallas_assign` (`medal_id`, `medal_for`, `medal_date`, `medal_ip`) VALUES (\''.(int)$medalla.'\', \''.(int)$post.'\', \''.time().'\', \''.$_SERVER['REMOTE_ADDR'].'\')') or die (show_error('Error al ejecutar la consulta de la l&iacute;nea '.__LINE__.' de '.__FILE__.'.', 'db'))){ if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO u_monitor (user_id, obj_uno, obj_dos, not_type, not_date) VALUES (\''.(int)$datosdelpost['post_user'].'\', \''.(int)$medalla.'\', \''.(int)$post.'\', \'16\', \''.time().'\')')){ $continuar = true; }else return 'Ocurri&oacute; un error al notificar al usuario'; }else return 'Ocurri&oacute; un error al asignar la medalla'; }else return '0: El post ya tiene esa medalla'; }else return '0: El post no existe'; }elseif($foto){ if(db_exec('num_rows', $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT foto_id, f_user FROM f_fotos WHERE foto_id = \''.(int)$foto.'\' LIMIT 1'))) { $datosdelafoto = db_exec('fetch_assoc', $query); if(!db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT id FROM w_medallas_assign WHERE medal_id = \''.(int)$medalla.'\' && medal_for = \''.(int)$foto.'\' LIMIT 1'))) { if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_medallas_assign` (`medal_id`, `medal_for`, `medal_date`, `medal_ip`) VALUES (\''.(int)$medalla.'\', \''.(int)$foto.'\', \''.time().'\', \''.$_SERVER['REMOTE_ADDR'].'\')') or die (show_error('Error al ejecutar la consulta de la l&iacute;nea '.__LINE__.' de '.__FILE__.'.', 'db'))){ if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO u_monitor (user_id, obj_uno, obj_dos, not_type, not_date) VALUES (\''.(int)$datosdelafoto['f_user'].'\', \''.(int)$medalla.'\', \''.(int)$foto.'\', \'17\', \''.time().'\')')){ $continuar = true; }else return 'Ocurri&oacute; un error al notificar al usuario'; }else return 'Ocurri&oacute; un error al asignar la medalla'; }else return '0: La foto ya tiene esa medalla'; }else return '0: La foto no existe'; }else{ return '0: No queda claro lo que quiere';} }else return '0: Su IP no se pudo validar'; }else return '0: La medalla no puede ser asignada porque no existe o no corresponde a este tipo de asignaci&oacute;n.'; }else return '0: Falta alg&uacute;n dato importante :R'; if($continuar) { if(db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE w_medallas SET m_total = m_total + 1 WHERE medal_id = \''.(int)$medalla.'\'')) return '1: Medalla asignada'; else return 'La medalla se asign&oacute;, pero hubo un problema y el contador no se alter&oacute;'; }else return 'Hubo problemas, chacho'; } Reemplazar por: public function AsignarMedalla(){ global $tsUser, $tsCore; // DATOS $medalla = intval($_POST['mid']); $usuario = strtolower($_POST['m_usuario']); $post = intval($_POST['pid']); $foto = intval($_POST['fid']); $video = intval($_POST['vid']); $user_id = $tsUser->getUserID($usuario); if(!empty($medalla) && !empty($usuario) || !empty($post) || !empty($foto)){ if($usuario){ $yeltipo = 'AND m_type = \'1\''; }elseif($post){ $yeltipo = 'AND m_type = \'2\''; }elseif($foto){ $yeltipo = 'AND m_type = \'3\''; }elseif($video){ $yeltipo = 'AND m_type = \'4\''; } if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT medal_id FROM w_medallas WHERE medal_id = \''.(int)$medalla.'\' '.$yeltipo.' LIMIT 1'))) { $_SERVER['REMOTE_ADDR'] = $_SERVER['X_FORWARDED_FOR'] ? $_SERVER['X_FORWARDED_FOR'] : $_SERVER['REMOTE_ADDR']; if(filter_var($_SERVER['REMOTE_ADDR'], FILTER_VALIDATE_IP)) { if($usuario){ if(db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT user_id FROM u_miembros WHERE LOWER(user_name) = \''.$tsCore->setSecure($usuario).'\' LIMIT 1'))) { if(!db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT id FROM w_medallas_assign WHERE medal_id = \''.(int)$medalla.'\' && medal_for = \''.(int)$user_id.'\' LIMIT 1'))) { if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_medallas_assign` (`medal_id`, `medal_for`, `medal_date`, `medal_ip`) VALUES (\''.(int)$medalla.'\', \''.(int)$user_id.'\', \''.time().'\', \''.$_SERVER['REMOTE_ADDR'].'\')') or die (show_error('Error al ejecutar la consulta de la l&iacute;nea '.__LINE__.' de '.__FILE__.'.', 'db'))){ if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO u_monitor (user_id, obj_uno, not_type, not_date) VALUES (\''.(int)$user_id.'\', \''.(int)$medalla.'\', \'15\', \''.time().'\')')){ $continuar = true; }else return 'Ocurri&oacute; un error al notificar al usuario'; }else return 'Ocurri&oacute; un error al asignar la medalla'; }else return '0: El usuario ya tiene esa medalla'; }else return '0: El usuario no existe'; }elseif($post){ if(db_exec('num_rows', $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT post_id, post_user FROM p_posts WHERE post_id = \''.(int)$post.'\' LIMIT 1'))){ $datosdelpost = db_exec('fetch_assoc', $query); if(!db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT id FROM w_medallas_assign WHERE medal_id = \''.(int)$medalla.'\' && medal_for = \''.(int)$post.'\' LIMIT 1'))) { if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_medallas_assign` (`medal_id`, `medal_for`, `medal_date`, `medal_ip`) VALUES (\''.(int)$medalla.'\', \''.(int)$post.'\', \''.time().'\', \''.$_SERVER['REMOTE_ADDR'].'\')') or die (show_error('Error al ejecutar la consulta de la l&iacute;nea '.__LINE__.' de '.__FILE__.'.', 'db'))){ if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO u_monitor (user_id, obj_uno, obj_dos, not_type, not_date) VALUES (\''.(int)$datosdelpost['post_user'].'\', \''.(int)$medalla.'\', \''.(int)$post.'\', \'16\', \''.time().'\')')){ $continuar = true; }else return 'Ocurri&oacute; un error al notificar al usuario'; }else return 'Ocurri&oacute; un error al asignar la medalla'; }else return '0: El post ya tiene esa medalla'; }else return '0: El post no existe'; }elseif($foto){ if(db_exec('num_rows', $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT foto_id, f_user FROM f_fotos WHERE foto_id = \''.(int)$foto.'\' LIMIT 1'))) { $datosdelafoto = db_exec('fetch_assoc', $query); if(!db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT id FROM w_medallas_assign WHERE medal_id = \''.(int)$medalla.'\' && medal_for = \''.(int)$foto.'\' LIMIT 1'))) { if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_medallas_assign` (`medal_id`, `medal_for`, `medal_date`, `medal_ip`) VALUES (\''.(int)$medalla.'\', \''.(int)$foto.'\', \''.time().'\', \''.$_SERVER['REMOTE_ADDR'].'\')') or die (show_error('Error al ejecutar la consulta de la l&iacute;nea '.__LINE__.' de '.__FILE__.'.', 'db'))){ if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO u_monitor (user_id, obj_uno, obj_dos, not_type, not_date) VALUES (\''.(int)$datosdelafoto['f_user'].'\', \''.(int)$medalla.'\', \''.(int)$foto.'\', \'17\', \''.time().'\')')){ $continuar = true; }else return 'Ocurri&oacute; un error al notificar al usuario'; }else return 'Ocurri&oacute; un error al asignar la medalla'; }else return '0: La foto ya tiene esa medalla'; }else return '0: La foto no existe'; }elseif($video){ if(!db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT vid_id, vid_user FROM v_videos WHERE vid_id = \''.(int)$video.'\' LIMIT 1'))) { $datosdelvideo = db_exec('fetch_assoc', $query); if(!db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT id FROM w_medallas_assign WHERE medal_id = \''.(int)$medalla.'\' && medal_for = \''.(int)$video.'\' LIMIT 1'))) { if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_medallas_assign` (`medal_id`, `medal_for`, `medal_date`, `medal_ip`) VALUES (\''.(int)$medalla.'\', \''.(int)$video.'\', \''.time().'\', \''.$_SERVER['REMOTE_ADDR'].'\')') or die (show_error('Error al ejecutar la consulta de la l&iacute;nea '.__LINE__.' de '.__FILE__.'.', 'db'))){ if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO u_monitor (user_id, obj_uno, obj_dos, not_type, not_date) VALUES (\''.(int)$datosdelvideo['vid_user'].'\', \''.(int)$medalla.'\', \''.(int)$video.'\', \'20\', \''.time().'\')')){ $continuar = true; }else return 'Ocurri&oacute; un error al notificar al usuario'; }else return 'Ocurri&oacute; un error al asignar la medalla'; }else return '0: El video ya tiene esa medalla'; }else return '0: El video no existe'; }else{ return '0: No queda claro lo que quiere';} }else return '0: Su IP no se pudo validar'; }else return '0: La medalla no puede ser asignada porque no existe o no corresponde a este tipo de asignaci&oacute;n.'; }else return '0: Falta alg&uacute;n dato importante :R'; if($continuar) { if(db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE w_medallas SET m_total = m_total + 1 WHERE medal_id = \''.(int)$medalla.'\'')) return '1: Medalla asignada'; else return 'La medalla se asign&oacute;, pero hubo un problema y el contador no se alter&oacute;'; }else return 'Hubo problemas, chacho'; } En c.cuenta.php --> inc --> class --> c.cuenta.php Buscar: // REAL STATS $data['stats'] = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT u.user_id, u.user_rango, u.user_puntos, u.user_posts, u.user_comentarios, u.user_seguidores, u.user_cache, r.r_name, r.r_color FROM u_miembros AS u LEFT JOIN u_rangos AS r ON u.user_rango = r.rango_id WHERE u.user_id = \''.(int)$user_id.'\'')); Después de: u.user_posts, Agregar: u.user_videos, Buscar: $q3 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(cid) AS c FROM p_comentarios WHERE c_user = \''.(int)$user_id.'\' && c_status = \'0\'')); Debajo agregar: $q4 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(vid_id) AS v FROM v_videos WHERE vid_user = \''.(int)$user_id.'\' && vid_status = \'0\'')); Buscar: $data['stats']['user_comentarios'] = $q3[0]; Debajo agregar: $data['stats']['user_videos'] = $q4[0]; Buscar: $q4 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(foto_id) AS f FROM f_fotos WHERE f_user = \''.(int)$user_id.'\' && f_status = \'0\'')); $data['stats']['user_fotos'] = $q4[0]; Debajo agregar: $q5 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(vid_id) AS v FROM v_videos WHERE vid_user = \''.(int)$user_id.'\' && vid_status = \'0\'')); $data['stats']['user_videos'] = $q5[0]; Buscar: // SIGUIENDO $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT f.follow_id, u.user_id, u.user_name FROM u_follows AS f LEFT JOIN u_miembros AS u ON f.f_id = u.user_id WHERE f.f_user = \''.(int)$user_id.'\' AND f.f_type = \'1\' && u.user_activo = \'1\' && u.user_baneado = \'0\' ORDER BY f.f_date DESC LIMIT 21'); $data['sigd']['data'] = result_array($query); $data['sigd']['total'] = count($data['sigd']['data']); Debajo agregar: // ULTIMOS VIDEOS if(empty($_GET['pid'])){ $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT vid_id, vid_title, vid_date, vid_url FROM v_videos WHERE vid_user = \''.(int)$user_id.'\' ORDER BY vid_date DESC LIMIT 10'); $data['videos'] = result_array($query); $total = count($data['videos']); $data['videos_total'] = $total; if($total < 6){ for($i = $total; $i <= 5; $i++){ $data['videos'][$i] = NULL; } } } Buscar: /* loadPosts($user_id) */ function loadPosts($user_id){ global $tsUser; // $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT p.post_id, p.post_title, p.post_puntos, c.c_seo, c.c_img FROM p_posts AS p LEFT JOIN p_categorias AS c ON c.cid = p.post_category WHERE p.post_status = \'0\' AND p.post_user = \''.(int)$user_id.'\' ORDER BY p.post_date DESC LIMIT 18'); $data['posts'] = result_array($query); $data['total'] = count($data['posts']); // USUARIO $data['username'] = $tsUser->getUserName($user_id); // return $data; } Debajo agregar: /* loadVideos($user_id) */ function loadVideos($user_id){ global $tsUser; // $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT v.vid_id, v.vid_title, v.vid_description, v.vid_url, v.vid_user FROM v_videos AS v WHERE v.vid_status = \'0\' AND v.vid_user = \''.(int)$user_id.'\' ORDER BY RAND() DESC LIMIT 10'); $data['videos'] = result_array($query); $data['total'] = count($data['videos']); // USUARIO $data['username'] = $tsUser->getUserName($user_id); // return $data; } En c.monitor.php --> inc --> class --> c.monitor.php Buscar: private function makeMonitor(){ $this->monitor = array( 1 => array('text' => 'agreg&oacute; a favoritos tu', 'ln_text' => 'post', 'css' => 'star'), 2 => array('text' => array('coment&oacute; tu','_REP_ nuevos comentarios en tu'), 'ln_text' => 'post', 'css' => 'comment_post'), 3 => array('text' => 'dej&oacute; _REP_ puntos en tu', 'ln_text' => 'post', 'css' => 'points'), 4 => array('text' => 'te est&aacute; siguiendo', 'ln_text' => 'Seguir a este usuario', 'css' => 'follow'), 5 => array('text' => 'cre&oacute; un nuevo', 'ln_text' => 'post', 'css' => 'post'), 6 => array('text' => array('te recomienda un', '_REP_ usuarios te recomiendan un'), 'ln_text' => 'post', 'css' => 'share'), 7 => array('text' => array('coment&oacute; en un', '_REP_ nuevos comentarios en el'), 'ln_text' => 'post', 'extra' => 'que sigues', 'css' => 'blue_ball'), 8 => array('text' => array('vot&oacute; _REP_ tu', '_REP_ nuevos votos a tu'), 'ln_text' => 'comentario', 'css' => 'voto_'), 9 => array('text' => array('respondi&oacute; tu', '_REP_ nuevas respuestas a tu'), 'ln_text' => 'comentario', 'css' => 'comment_resp'), 10 => array('text' => 'subi&oacute; una nueva', 'ln_text' => 'foto', 'css' => 'photo'), 11 => array('text' => array('coment&oacute; tu','_REP_ nuevos comentarios en tu'), 'ln_text' => 'foto', 'css' => 'photo'), 12 => array('text' => 'public&oacute; en tu', 'ln_text' => 'muro', 'css' => 'wall_post'), 13 => array('text' => array('coment&oacute; ', '_REP_ nuevos comentarios en'), 'ln_text' => 'publicaci&oacute;n', 'extra' => 'coment&oacute;', 'css' => 'w_comment'), 14 => array('text' => array('le gusta tu', 'A _REP_ personas les gusta tu'), 'ln_text' => array('publicaci&oacute;n','comentario'), 'css' => 'w_like'), 15 => array('text' => 'Recibiste una medalla', 'css' => 'medal'), 16 => array('text' => 'Tu post recibi&oacute; una medalla', 'css' => 'medal'), 17 => array('text' => 'Tu foto recibi&oacute; una medalla', 'css' => 'medal'), ); } Reemplazar por: private function makeMonitor(){ $this->monitor = array( 1 => array('text' => 'agreg&oacute; a favoritos tu', 'ln_text' => 'post', 'css' => 'star'), 2 => array('text' => array('coment&oacute; tu','_REP_ nuevos comentarios en tu'), 'ln_text' => 'post', 'css' => 'comment_post'), 3 => array('text' => 'dej&oacute; _REP_ puntos en tu', 'ln_text' => 'post', 'css' => 'points'), 4 => array('text' => 'te est&aacute; siguiendo', 'ln_text' => 'Seguir a este usuario', 'css' => 'follow'), 5 => array('text' => 'cre&oacute; un nuevo', 'ln_text' => 'post', 'css' => 'post'), 6 => array('text' => array('te recomienda un', '_REP_ usuarios te recomiendan un'), 'ln_text' => 'post', 'css' => 'share'), 7 => array('text' => array('coment&oacute; en un', '_REP_ nuevos comentarios en el'), 'ln_text' => 'post', 'extra' => 'que sigues', 'css' => 'blue_ball'), 8 => array('text' => array('vot&oacute; _REP_ tu', '_REP_ nuevos votos a tu'), 'ln_text' => 'comentario', 'css' => 'voto_'), 9 => array('text' => array('respondi&oacute; tu', '_REP_ nuevas respuestas a tu'), 'ln_text' => 'comentario', 'css' => 'comment_resp'), 10 => array('text' => 'subi&oacute; una nueva', 'ln_text' => 'foto', 'css' => 'photo'), 11 => array('text' => array('coment&oacute; tu','_REP_ nuevos comentarios en tu'), 'ln_text' => 'foto', 'css' => 'photo'), 12 => array('text' => 'public&oacute; en tu', 'ln_text' => 'muro', 'css' => 'wall_post'), 13 => array('text' => array('coment&oacute; ', '_REP_ nuevos comentarios en'), 'ln_text' => 'publicaci&oacute;n', 'extra' => 'coment&oacute;', 'css' => 'w_comment'), 14 => array('text' => array('le gusta tu', 'A _REP_ personas les gusta tu'), 'ln_text' => array('publicaci&oacute;n','comentario'), 'css' => 'w_like'), 15 => array('text' => 'Recibiste una medalla', 'css' => 'medal'), 16 => array('text' => 'Tu post recibi&oacute; una medalla', 'css' => 'medal'), 17 => array('text' => 'Tu foto recibi&oacute; una medalla', 'css' => 'medal'), 18 => array('text' => 'subi&oacute; el video', 'ln_text' => 'video', 'css' => 'video'), 20 => array('text' => 'Tu video recibi&oacute; una medalla', 'css' => 'medal'), 21 => array('text' => 'te recomienda el video', '_REP_ usuarios te recomiendan un', 'ln_text' => 'video', 'css' => 'share'), ); } Buscar: function makeConsulta($data){ # CON UN SWITCH ESCOGEMOS LA CONSULTA APROPIADA switch($data['not_type']){ // EN ESTOS CASOS SE NECESITA LO MISMO // $nombredeusuario ********** tu $titulodelpost; case 1: case 2: case 3: case 5: case 6: case 7: case 8: case 9: return 'SELECT p.post_id, p.post_user, p.post_title, c.c_seo FROM p_posts AS p LEFT JOIN p_categorias AS c ON p.post_category = c.cid WHERE p.post_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'; break; // FOLLOW case 4: global $tsUser; // CHECAR SI YA LO SEGUIMOS $i_follow = $tsUser->iFollow($data['obj_user']); return array('follow' => $i_follow); break; // PUBLICO EN TU MURO case 12: return 'SELECT p.pub_id, u.user_name FROM u_muro AS p LEFT JOIN u_miembros AS u ON p.p_user_pub = u.user_id WHERE p.pub_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'; break; case 13: global $tsUser; // HAY MAS DE UNA NOTIFICACION DEL MISMO TIPO $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT p.pub_id, p.p_user, p.p_user_pub, u.user_name FROM u_muro AS p LEFT JOIN u_miembros AS u ON p.p_user = u.user_id WHERE p.pub_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'); $dato = db_exec('fetch_assoc', $query); // $dato['p_user_resp'] = $data['obj_user']; $dato['p_user_name'] = $dato['user_name']; // // DUEÑO DEL MURO $dato['user_name'] = $tsUser->getUserName($data['obj_user']); // QUIEN PUBLICO // return $dato; break; case 14: if($data['obj_dos'] == 2) return 'SELECT pub_id AS obj_uno, c_body FROM u_muro_comentarios WHERE cid = \''.(int)$data['obj_uno'].'\''; else return array('value' => 'hack'); break; case 15: return 'SELECT medal_id, m_title, m_image FROM w_medallas WHERE medal_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'; break; case 16: return 'SELECT p.post_id, p.post_title, c.c_seo, m.medal_id, m.m_title, m.m_image, a.medal_for FROM w_medallas_assign AS a LEFT JOIN p_posts AS p ON p.post_id = a.medal_for LEFT JOIN p_categorias AS c ON c.cid = p.post_category LEFT JOIN w_medallas AS m ON m.medal_id = a.medal_id WHERE m.medal_id = \''.(int)$data['obj_uno'].'\' AND p.post_id = \''.(int)$data['obj_dos'].'\' LIMIT 1'; break; case 17: return 'SELECT f.foto_id, f.f_title, f.f_user, m.medal_id, m.m_title, m.m_image, a.medal_for, u.user_id, u.user_name FROM w_medallas_assign AS a LEFT JOIN f_fotos AS f ON f.foto_id = a.medal_for LEFT JOIN u_miembros AS u ON u.user_id = f.f_user LEFT JOIN w_medallas AS m ON m.medal_id = a.medal_id WHERE m.medal_id = \''.(int)$data['obj_uno'].'\' AND f.foto_id = \''.(int)$data['obj_dos'].'\' LIMIT 1'; break; } } Reemplazar por: function makeConsulta($data){ # CON UN SWITCH ESCOGEMOS LA CONSULTA APROPIADA switch($data['not_type']){ // EN ESTOS CASOS SE NECESITA LO MISMO // $nombredeusuario ********** tu $titulodelpost; case 1: case 2: case 3: case 5: case 6: case 7: case 8: case 9: return 'SELECT p.post_id, p.post_user, p.post_title, c.c_seo FROM p_posts AS p LEFT JOIN p_categorias AS c ON p.post_category = c.cid WHERE p.post_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'; break; // COMIENZO NOTI VIDEOS case 21: case 18: return 'SELECT vid_title, vid_url, vid_id, vid_user, u.user_name, u.user_id FROM v_videos AS v LEFT JOIN u_miembros AS u ON v.vid_user = u.user_id WHERE vid_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'; break; case 19: return 'SELECT vid_title, vid_url, vid_id, vid_user, u.user_name, u.user_id FROM v_videos LEFT JOIN v_comentarios AS c ON c.cid LEFT JOIN u_miembros AS u ON vid_user = u.user_id WHERE vid_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'; break; case 22: return 'SELECT vid_title, vid_url, vid_id, vid_user, u.user_name, u.user_id FROM v_videos LEFT JOIN u_miembros AS u ON vid_user = u.user_id WHERE vid_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'; break; // FIN NOTI VIDEOS // FOLLOW case 4: global $tsUser; // CHECAR SI YA LO SEGUIMOS $i_follow = $tsUser->iFollow($data['obj_user']); return array('follow' => $i_follow); break; // PUBLICO EN TU MURO case 12: return 'SELECT p.pub_id, u.user_name FROM u_muro AS p LEFT JOIN u_miembros AS u ON p.p_user_pub = u.user_id WHERE p.pub_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'; break; case 13: global $tsUser; // HAY MAS DE UNA NOTIFICACION DEL MISMO TIPO $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT p.pub_id, p.p_user, p.p_user_pub, u.user_name FROM u_muro AS p LEFT JOIN u_miembros AS u ON p.p_user = u.user_id WHERE p.pub_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'); $dato = db_exec('fetch_assoc', $query); // $dato['p_user_resp'] = $data['obj_user']; $dato['p_user_name'] = $dato['user_name']; // // DUEÑO DEL MURO $dato['user_name'] = $tsUser->getUserName($data['obj_user']); // QUIEN PUBLICO // return $dato; break; case 14: if($data['obj_dos'] == 2) return 'SELECT pub_id AS obj_uno, c_body FROM u_muro_comentarios WHERE cid = \''.(int)$data['obj_uno'].'\''; else return array('value' => 'hack'); break; case 15: return 'SELECT medal_id, m_title, m_image FROM w_medallas WHERE medal_id = \''.(int)$data['obj_uno'].'\' LIMIT 1'; break; case 16: return 'SELECT p.post_id, p.post_title, c.c_seo, m.medal_id, m.m_title, m.m_image, a.medal_for FROM w_medallas_assign AS a LEFT JOIN p_posts AS p ON p.post_id = a.medal_for LEFT JOIN p_categorias AS c ON c.cid = p.post_category LEFT JOIN w_medallas AS m ON m.medal_id = a.medal_id WHERE m.medal_id = \''.(int)$data['obj_uno'].'\' AND p.post_id = \''.(int)$data['obj_dos'].'\' LIMIT 1'; break; case 17: return 'SELECT f.foto_id, f.f_title, f.f_user, m.medal_id, m.m_title, m.m_image, a.medal_for, u.user_id, u.user_name FROM w_medallas_assign AS a LEFT JOIN f_fotos AS f ON f.foto_id = a.medal_for LEFT JOIN u_miembros AS u ON u.user_id = f.f_user LEFT JOIN w_medallas AS m ON m.medal_id = a.medal_id WHERE m.medal_id = \''.(int)$data['obj_uno'].'\' AND f.foto_id = \''.(int)$data['obj_dos'].'\' LIMIT 1'; break; case 20: return 'SELECT v.vid_id, v.vid_title, v.vid_user, m.medal_id, m.m_title, m.m_image, a.medal_for, u.user_id, u.user_name FROM w_medallas_assign AS a LEFT JOIN v_videos AS v ON v.vid_id = a.medal_for LEFT JOIN u_miembros AS u ON u.user_id = v.vid_user LEFT JOIN w_medallas AS m ON m.medal_id = a.medal_id WHERE m.medal_id = \''.(int)$data['obj_uno'].'\' AND v.vid_id = \''.(int)$data['obj_dos'].'\' LIMIT 1'; break; } } Buscar: private function makeOracion($data){ # GOBALES global $tsCore, $tsUser; # LOCALES $site_url = $tsCore->settings['url']; $no_type = $data['not_type']; $txt_extra = ($this->show_type == 1) ? '' : ' '.$this->monitor[$no_type]['ln_text']; $ln_text = $this->monitor[$no_type]['ln_text']; $ln_text = is_array($ln_text) ? $ln_text[$data['obj_dos']-1] : $ln_text; // $oracion['unread'] = ($this->show_type == 1) ? $data['not_menubar'] : $data['not_monitor']; $oracion['style'] = $this->monitor[$no_type]['css']; $oracion['date'] = $data['not_date']; $oracion['user'] = $data['usuario']; $oracion['avatar'] = $data['obj_user'].'_50.jpg'; $oracion['total'] = $data['not_total']; # CON UN SWITCH ESCOGEMOS QUE ORACION CONSTRUIR switch($no_type){ case 1: case 3: case 5: // $oracion['text'] = $this->monitor[$no_type]['text'].$txt_extra; if($no_type == 3) $oracion['text'] = str_replace('_REP_', '<b>'.$data['obj_dos'].'</b>', $oracion['text']); $oracion['link'] = $site_url.'/posts/'.$data['c_seo'].'/'.$data['post_id'].'/'.$tsCore->setSEO($data['post_title']).'.html'; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : $data['post_title']; $oracion['ltit'] = ($this->show_type == 1) ? $data['post_title'] : ''; break; // FOLLOW case 4: $oracion['text'] = $this->monitor[$no_type]['text']; if($data['follow'] != true && $this->show_type == 2) { $oracion['link'] = '#" onclick="notifica.follow(\'user\', '.$data['obj_user'].', notifica.userInMonitorHandle, this)'; $oracion['ltext'] = $this->monitor[$no_type]['ln_text']; } break; // PUEDEN SER MAS DE UNO case 2: case 6: case 7: case 8: case 9: // CUANTOS $no_total = $data['not_total']; // MAS DE UNA ACCION if($no_total > 1) { $text = $this->monitor[$no_type]['text'][1].$txt_extra; $oracion['text'] = str_replace('_REP_', "<b>{$no_total}</b>", $text); } else $oracion['text'] = $this->monitor[$no_type]['text'][0].$txt_extra; // ¿ES MI POST? if($data['post_user'] == $tsUser->uid) { $oracion['text'] = str_replace('te recomienda un', 'ha recomendado tu', $oracion['text']); } // ID COMMENT if($no_type == 8 || $no_type == 9){ $id_comment = '#div_cmnt_'.$data['obj_dos']; // EXTRAS if($no_type == 8){ $voto_type = ($data['obj_tres'] == 0) ? 'negativo' : 'positivo'; $oracion['text'] = str_replace('_REP_', '<b>'.$voto_type.'</b>', $oracion['text']); $oracion['style'] = 'voto_'.$voto_type; } } // $oracion['link'] = $site_url.'/posts/'.$data['c_seo'].'/'.$data['post_id'].'/'.$tsCore->setSEO($data['post_title']).'.html'.$id_comment; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : $data['post_title']; $oracion['ltit'] = ($this->show_type == 1) ? $data['post_title'] : ''; break; // PUBLICACION EN MURO case 12: $oracion['text'] = $this->monitor[$no_type]['text'].$txt_extra; $oracion['link'] = $site_url.'/perfil/'.$tsUser->nick.'/'.$data['obj_uno']; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : $tsUser->nick; $oracion['ltit'] = ($this->show_type == 1) ? $tsUser->nick : ''; break; case 13: // DE QUIEN? if($tsUser->uid == $data['p_user']) { $de = ' tu'; } elseif($data['p_user'] == $data['p_user_resp']) { $de = ' su'; } else { $de = ' la publicaci&oacute;n de'; //$data['link'][1] = ($typeDos == 1) ? array($array['p_user_name'], $array['p_user_name']) : $array['p_user_name']; } // CUANTOS $no_total = $data['not_total']; if($no_total > 1) { $text = $this->monitor[$no_type]['text'][1].$de.$txt_extra; $oracion['text'] = str_replace('_REP_', '<b>'.$no_total.'</b>', $text); } else $oracion['text'] = $this->monitor[$no_type]['text'][0].$de.$txt_extra; // //$oracion['text'] = $this->monitor[$no_type]['text'].$de.$txt_extra; $oracion['link'] = $site_url.'/perfil/'.$data['p_user_name'].'/'.$data['pub_id']; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : $tsUser->nick; $oracion['ltit'] = ($this->show_type == 1) ? $tsUser->nick : ''; break; case 14: // CUANTOS $no_total = $data['not_total']; // MAS DE UNA ACCION if($no_total > 1) { $text = $this->monitor[$no_type]['text'][1].' '.$ln_text; $oracion['text'] = str_replace('_REP_', '<b>'.$no_total.'</b>', $text); } else $oracion['text'] = $this->monitor[$no_type]['text'][0]; // $oracion['text'] = ($this->show_type == 1) ? $oracion['text'] : $oracion['text'].' '.$ln_text; $oracion['link'] = $site_url.'/perfil/'.$tsUser->nick.'/'.$data['obj_uno']; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : substr($data['c_body'],0,20).'...'; $oracion['ltit'] = ($this->show_type == 1) ? substr($data['c_body'],0,20).'...' : ''; break; case 15: $oracion['text'] = 'Recibiste una nueva <span class="qtip" title="'.$data['m_title'].'"><b>medalla</b> <img src="'.$site_url.'/themes/default/images/icons/med/'.$data['m_image'].'_16.png"/></span>'; break; case 16: $oracion['text'] = 'Tu <a href="'.$site_url.'/posts/'.$data['c_seo'].'/'.$data['post_id'].'/'.$tsCore->setSEO($data['post_title']).'.html" title="'.$data['post_title'].'"><b>post</b></a> tiene una nueva <span class="qtip" title="'.$data['m_title'].'"><b>medalla</b> <img src="'.$site_url.'/themes/default/images/icons/med/'.$data['m_image'].'_16.png"/></span>'; break; case 17: $oracion['text'] = 'Tu <a href="'.$site_url.'/fotos/'.$data['user_name'].'/'.$data['foto_id'].'/'.$tsCore->setSEO($data['f_title']).'.html" title="'.$data['f_title'].'"><b>foto</b></a> tiene una nueva <span class="qtip" title="'.$data['m_title'].'"><b>medalla</b> <img src="'.$site_url.'/themes/default/images/icons/med/'.$data['m_image'].'_16.png"/></span>'; break; } # RETORNAMOS return $oracion; } Reemplazar por: private function makeOracion($data){ # GOBALES global $tsCore, $tsUser; # LOCALES $site_url = $tsCore->settings['url']; $no_type = $data['not_type']; $txt_extra = ($this->show_type == 1) ? '' : ' '.$this->monitor[$no_type]['ln_text']; $ln_text = $this->monitor[$no_type]['ln_text']; $ln_text = is_array($ln_text) ? $ln_text[$data['obj_dos']-1] : $ln_text; // $oracion['unread'] = ($this->show_type == 1) ? $data['not_menubar'] : $data['not_monitor']; $oracion['style'] = $this->monitor[$no_type]['css']; $oracion['date'] = $data['not_date']; $oracion['user'] = $data['usuario']; $oracion['avatar'] = $data['obj_user'].'_50.jpg'; $oracion['total'] = $data['not_total']; # CON UN SWITCH ESCOGEMOS QUE ORACION CONSTRUIR switch($no_type){ case 1: case 3: case 5: // $oracion['text'] = $this->monitor[$no_type]['text'].$txt_extra; if($no_type == 3) $oracion['text'] = str_replace('_REP_', '<b>'.$data['obj_dos'].'</b>', $oracion['text']); $oracion['link'] = $site_url.'/posts/'.$data['c_seo'].'/'.$data['post_id'].'/'.$tsCore->setSEO($data['post_title']).'.html'; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : $data['post_title']; $oracion['ltit'] = ($this->show_type == 1) ? $data['post_title'] : ''; break; // FOLLOW case 4: $oracion['text'] = $this->monitor[$no_type]['text']; if($data['follow'] != true && $this->show_type == 2) { $oracion['link'] = '#" onclick="notifica.follow(\'user\', '.$data['obj_user'].', notifica.userInMonitorHandle, this)'; $oracion['ltext'] = $this->monitor[$no_type]['ln_text']; } break; // PUEDEN SER MAS DE UNO case 2: case 6: case 7: case 8: case 9: // CUANTOS $no_total = $data['not_total']; // MAS DE UNA ACCION if($no_total > 1) { $text = $this->monitor[$no_type]['text'][1].$txt_extra; $oracion['text'] = str_replace('_REP_', "<b>{$no_total}</b>", $text); } else $oracion['text'] = $this->monitor[$no_type]['text'][0].$txt_extra; // ¿ES MI POST? if($data['post_user'] == $tsUser->uid) { $oracion['text'] = str_replace('te recomienda un', 'ha recomendado tu', $oracion['text']); } // ID COMMENT if($no_type == 8 || $no_type == 9){ $id_comment = '#div_cmnt_'.$data['obj_dos']; // EXTRAS if($no_type == 8){ $voto_type = ($data['obj_tres'] == 0) ? 'negativo' : 'positivo'; $oracion['text'] = str_replace('_REP_', '<b>'.$voto_type.'</b>', $oracion['text']); $oracion['style'] = 'voto_'.$voto_type; } } // $oracion['link'] = $site_url.'/posts/'.$data['c_seo'].'/'.$data['post_id'].'/'.$tsCore->setSEO($data['post_title']).'.html'.$id_comment; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : $data['post_title']; $oracion['ltit'] = ($this->show_type == 1) ? $data['post_title'] : ''; break; // NOTI VIDEOS case 21: case 18: $oracion['text'] = $this->monitor[$no_type]['text']; $oracion['link'] = $site_url.'/videos/'.$data['user_name'].'/'.$data['vid_id'].'/'.$tsCore->setSEO($data['vid_title']).'.html'; $oracion['ltext'] = $data['vid_title']; break; case 19: // CUANTOS $no_total = $data['not_total']; // MAS DE UNA ACCION if($no_total > 1) { $text = $this->monitor[$no_type]['text'][1].$txt_extra; $oracion['text'] = str_replace('_REP_', "<b>{$no_total}</b>", $text); } else $oracion['text'] = $this->monitor[$no_type]['text'][0].$txt_extra; // $oracion['link'] = $site_url.'/videos/'.$data['user_name'].'/'.$data['vid_id'].'/'.$tsCore->setSEO($data['vid_title']).'.html'; $oracion['ltext'] = $data['vid_title']; break; case 22: $no_total = $data['not_total']; if($no_total > 1) { $text = $this->monitor[$no_type]['text'][1].$de.$txt_extra; $oracion['text'] = str_replace('_REP_', "<b>{$no_total}</b>", $text); }else $oracion['text'] = $this->monitor[$no_type]['text'][0].$txt_extra; $voto_type = ($data['obj_dos'] == 0) ? 'negativo' : 'positivo'; $oracion['text'] = str_replace('_REP_', '<b>'.$voto_type.'</b>', $oracion['text']); $oracion['style'] = 'voto_'.$voto_type; $oracion['link'] = $site_url.'/videos/'.$data['user_name'].'/'.$data['vid_id'].'/'.$tsCore->setSEO($data['vid_title']).'.html'; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : $data['vid_title']; $oracion['ltit'] = ($this->show_type == 1) ? $data['vid_title'] : ''; break; // NOTI VIDEOS // PUBLICACION EN MURO case 12: $oracion['text'] = $this->monitor[$no_type]['text'].$txt_extra; $oracion['link'] = $site_url.'/perfil/'.$tsUser->nick.'/'.$data['obj_uno']; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : $tsUser->nick; $oracion['ltit'] = ($this->show_type == 1) ? $tsUser->nick : ''; break; case 13: // DE QUIEN? if($tsUser->uid == $data['p_user']) { $de = ' tu'; } elseif($data['p_user'] == $data['p_user_resp']) { $de = ' su'; } else { $de = ' la publicaci&oacute;n de'; //$data['link'][1] = ($typeDos == 1) ? array($array['p_user_name'], $array['p_user_name']) : $array['p_user_name']; } // CUANTOS $no_total = $data['not_total']; if($no_total > 1) { $text = $this->monitor[$no_type]['text'][1].$de.$txt_extra; $oracion['text'] = str_replace('_REP_', '<b>'.$no_total.'</b>', $text); } else $oracion['text'] = $this->monitor[$no_type]['text'][0].$de.$txt_extra; // //$oracion['text'] = $this->monitor[$no_type]['text'].$de.$txt_extra; $oracion['link'] = $site_url.'/perfil/'.$data['p_user_name'].'/'.$data['pub_id']; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : $tsUser->nick; $oracion['ltit'] = ($this->show_type == 1) ? $tsUser->nick : ''; break; case 14: // CUANTOS $no_total = $data['not_total']; // MAS DE UNA ACCION if($no_total > 1) { $text = $this->monitor[$no_type]['text'][1].' '.$ln_text; $oracion['text'] = str_replace('_REP_', '<b>'.$no_total.'</b>', $text); } else $oracion['text'] = $this->monitor[$no_type]['text'][0]; // $oracion['text'] = ($this->show_type == 1) ? $oracion['text'] : $oracion['text'].' '.$ln_text; $oracion['link'] = $site_url.'/perfil/'.$tsUser->nick.'/'.$data['obj_uno']; $oracion['ltext'] = ($this->show_type == 1) ? $ln_text : substr($data['c_body'],0,20).'...'; $oracion['ltit'] = ($this->show_type == 1) ? substr($data['c_body'],0,20).'...' : ''; break; case 15: $oracion['text'] = 'Recibiste una nueva <span class="qtip" title="'.$data['m_title'].'"><b>medalla</b> <img src="'.$site_url.'/themes/default/images/icons/med/'.$data['m_image'].'_16.png"/></span>'; break; case 16: $oracion['text'] = 'Tu <a href="'.$site_url.'/posts/'.$data['c_seo'].'/'.$data['post_id'].'/'.$tsCore->setSEO($data['post_title']).'.html" title="'.$data['post_title'].'"><b>post</b></a> tiene una nueva <span class="qtip" title="'.$data['m_title'].'"><b>medalla</b> <img src="'.$site_url.'/themes/default/images/icons/med/'.$data['m_image'].'_16.png"/></span>'; break; case 17: $oracion['text'] = 'Tu <a href="'.$site_url.'/fotos/'.$data['user_name'].'/'.$data['foto_id'].'/'.$tsCore->setSEO($data['f_title']).'.html" title="'.$data['f_title'].'"><b>foto</b></a> tiene una nueva <span class="qtip" title="'.$data['m_title'].'"><b>medalla</b> <img src="'.$site_url.'/themes/default/images/icons/med/'.$data['m_image'].'_16.png"/></span>'; break; case 20: $oracion['text'] = 'Tu <a href="'.$site_url.'/videos/'.$data['user_name'].'/'.$data['vid_id'].'/'.$tsCore->setSEO($data['vid_title']).'.html" title="'.$data['vid_title'].'"><b>video</b></a> tiene una nueva <span class="qtip" title="'.$data['m_title'].'"><b>medalla</b> <img src="'.$site_url.'/themes/default/images/icons/med/'.$data['m_image'].'_16.png"/></span>'; break; } # RETORNAMOS return $oracion; } Buscar: public function setSpam(){ global $tsCore, $tsUser, $tsActividad; // $postid = $_POST['postid']; // TIENE SEGUIDORES? $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT follow_id FROM u_follows WHERE f_id = \''.$tsUser->uid.'\' AND f_type = \'1\' LIMIT 1'); $seguidores = db_exec('num_rows', $query); // YA LO HA RECOMENDADO? $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT follow_id FROM u_follows WHERE f_id = \''.(int)$postid.'\' AND f_user = \''.$tsUser->uid.'\' AND f_type = \'3\' LIMIT 1'); $recomendado = db_exec('num_rows', $query); if($seguidores < 1) return '0-Debes tener al menos un seguidor'; if($recomendado > 0) return '0-No puedes recomendar el mismo post m&aacute;s de una vez.'; // $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT post_user FROM p_posts WHERE post_id = \''.(int)$postid.'\' LIMIT 1'); $data = db_exec('fetch_assoc', $query); // if($tsUser->uid != $data['post_user']){ // GUARDAMOS EN FOLLOWS PUES ES LA RECOMENDACION PARA SU SEGUIDORES! xD db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO u_follows (f_id, f_user, f_type, f_date) VALUES (\''.(int)$postid.'\', \''.$tsUser->uid.'\', \'3\', \''.time().'\') '); // NOTIFICAR if($this->setFollowNotificacion(6, 1, $tsUser->uid, $postid)) { $tsActividad->setActividad(4, $postid); return '1-La recomendaci&oacute;n fue enviada.'; } } else return '0-No puedes recomendar tus posts.'; } Debajo agregar: /** * @name recomVid * @access public * @param none * @return string * @info ESTA FUNCION ES PARA REALIZAR RECOMENDACIONES EN VIDEOS OKSI */ public function recomVid(){ global $tsCore, $tsUser, $tsActividad; // $videoid = $_POST['videoid']; // YA LO HA RECOMENDADO? $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT follow_id FROM u_follows WHERE f_id = \''.(int)$videoid.'\' AND f_user = \''.$tsUser->uid.'\' AND f_type = \'3\' LIMIT 1'); $recomendado = db_exec('num_rows', $query); if($recomendado > 0) return '0-Ya haz recomendado este video.'; // $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT vid_user FROM v_videos WHERE vid_id = \''.(int)$videoid.'\' LIMIT 1'); $data = db_exec('fetch_assoc', $query); // if($tsUser->uid != $data['vid_user']){ // GUARDAMOS EN FOLLOWS PUES ES LA RECOMENDACION PARA SU SEGUIDORES! xD db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO u_follows (f_id, f_user, f_type, f_date) VALUES (\''.(int)$videoid.'\', \''.$tsUser->uid.'\', \'3\', \''.time().'\') '); // NOTIFICAR if($this->setFollowNotificacion(21, 1, $tsUser->uid, $videoid)) { $tsActividad->setActividad(4, $postid); return '1-La recomendaci&oacute;n fue enviada.'; } } else return '0-No puedes recomendar tus videos.'; } En c.tops.php --> inc --> class --> c.tops.php Buscar: /* getTopUsers() */ function getTopUsers($fecha, $cat){ // $data = $this->setTime($fecha); $category = empty($cat) ? '' : 'AND post_category = '.$cat; // PUNTOS $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT SUM(p.post_puntos) AS total, u.user_id, u.user_name FROM p_posts AS p LEFT JOIN u_miembros AS u ON p.post_user = u.user_id WHERE p.post_status = 0 AND p.post_date BETWEEN '.$data['start'].' AND '.$data['end'].' '.$category.' GROUP BY p.post_user ORDER BY total DESC LIMIT 10'); $array['puntos'] = result_array($query); // SEGUIDORES $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(f.follow_id) AS total, u.user_id, u.user_name FROM u_follows AS f LEFT JOIN u_miembros AS u ON f.f_id = u.user_id WHERE f.f_type = 1 AND f.f_date BETWEEN '.$data['start'].' AND '.$data['end'].' GROUP BY f.f_id ORDER BY total DESC LIMIT 10'); $array['seguidores'] = result_array($query); // MEDALLAS $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(m.medal_for) AS total, u.user_id, u.user_name, wm.medal_id FROM w_medallas_assign AS m LEFT JOIN u_miembros AS u ON m.medal_for = u.user_id LEFT JOIN w_medallas AS wm ON wm.medal_id = m.medal_id WHERE wm.m_type = \'1\' AND m.medal_date BETWEEN '.$data['start'].' AND '.$data['end'].' GROUP BY m.medal_for ORDER BY total DESC LIMIT 10'); $array['medallas'] = result_array($query); // return $array; } Debajo agregar: /* getTopVideos() */ function getTopVideos($fecha, $desc){ // $data = $this->setTime($fecha); $desc = empty($desc) ? '' : 'AND vid_description = '.$desc; // VOTOS POSITIVOS $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT SUM(v.vid_votos_pos) AS total, u.user_id, u.user_name, vid_url, vid_user, vid_votos_pos, vid_title, vid_id FROM v_videos AS v LEFT JOIN u_miembros AS u ON v.vid_user = u.user_id WHERE v.vid_status = 0 AND v.vid_date BETWEEN '.$data['start'].' AND '.$data['end'].' '.$desc.' GROUP BY v.vid_user ORDER BY total DESC LIMIT 10'); $array['votos_pos'] = result_array($query); // VOTOS NEGATIVOS $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT SUM(v.vid_votos_neg) AS total, u.user_id, u.user_name, vid_url, vid_user, vid_votos_neg, vid_title, vid_id FROM v_videos AS v LEFT JOIN u_miembros AS u ON v.vid_user = u.user_id WHERE v.vid_status = 0 AND v.vid_date BETWEEN '.$data['start'].' AND '.$data['end'].' '.$desc.' GROUP BY v.vid_user ORDER BY total DESC LIMIT 10'); $array['votos_neg'] = result_array($query); // VISITAS $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT SUM(vid_visitas) AS total, u.user_id, u.user_name, vid_url, vid_user, vid_visitas, vid_title, vid_id FROM v_videos AS v LEFT JOIN u_miembros AS u ON v.vid_user = u.user_id WHERE v.vid_status = 0 AND v.vid_date BETWEEN '.$data['start'].' AND '.$data['end'].' '.$desc.' GROUP BY v.vid_user ORDER BY total DESC LIMIT 10'); $array['visitas'] = result_array($query); // MEDALLAS $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(m.medal_for) AS total, u.user_id, u.user_name, vid_url, vid_user, vid_title, vid_id, wm.medal_id FROM w_medallas_assign AS m LEFT JOIN v_videos AS v ON m.medal_for = v.vid_id LEFT JOIN u_miembros AS u ON v.vid_user = u.user_id LEFT JOIN w_medallas AS wm ON wm.medal_id = m.medal_id WHERE wm.m_type = \'4\' AND m.medal_date BETWEEN '.$data['start'].' AND '.$data['end'].' GROUP BY m.medal_for ORDER BY total DESC LIMIT 10'); $array['medallas'] = result_array($query); // return $array; } Buscar: /* getStats() : NADA QUE VER CON LA CLASE PERO BUENO PARA AHORRAR ESPACIO... : ESTADISTICAS DE LA WEB */ function getStats(){ global $tsCore; // OBTENEMOS LAS ESTADISTICAS $return = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT stats_max_online, stats_max_time, stats_time, stats_time_cache, stats_miembros, stats_posts, stats_fotos, stats_comments, stats_foto_comments FROM w_stats WHERE stats_no = \'1\'')); if($return['stats_time_cache'] < time()-($tsCore->settings['c_stats_cache']*60)){ $q1 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(user_id) AS u FROM u_miembros WHERE user_activo = \'1\' && user_baneado = \'0\'')); $q2 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(post_id) AS p FROM p_posts WHERE post_status = \'0\'')); $q3 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(foto_id) AS f FROM f_fotos WHERE f_status = \'0\'')); $q4 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(cid) AS c FROM p_comentarios WHERE c_status = \'0\'')); $q5 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(cid) AS fc FROM f_comentarios')); $return['stats_miembros'] = $q1[0]; $return['stats_posts'] = $q2[0]; $return['stats_fotos'] = $q3[0]; $return['stats_comments'] = $q4[0]; $return['stats_foto_comments'] = $q5[0]; $ndat = ', stats_time_cache = \''.time().'\', stats_miembros = \''.$return['stats_miembros'].'\', stats_posts = \''.$return['stats_posts'].'\', stats_fotos = \''.$return['stats_fotos'].'\', stats_comments = \''.$return['stats_comments'].'\', stats_foto_comments = \''.$return['stats_foto_comments'].'\''; } // PARA SABER SI ESTA ONLINE $is_online = (time() - ($tsCore->settings['c_last_active'] * 60)); // USUARIOS ONLINE - COMPROBAMOS SI CONTAMOS A TODOS LOS USUARIOS O SOLO A REGISTRADOS if(empty($tsCore->settings['c_count_guests'])){ $cueri = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(user_id) AS u FROM `u_miembros` WHERE `user_lastactive` > \''.$is_online.'\'')); }else{ $cueri = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(DISTINCT `session_ip`) AS s FROM `u_sessions` WHERE `session_time` > \''.$is_online.'\'')); } $return['stats_online'] = $cueri[0]; if($return['stats_online'] > $return['stats_max_online']) { $timen = ', stats_max_online = \''.$return['stats_online'].'\', stats_max_time = \''.time().'\''; } db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE w_stats SET stats_time = \''.time().'\' '.$ndat.' '.$timen); // return $return; } Reemplazar por: /* getStats() : NADA QUE VER CON LA CLASE PERO BUENO PARA AHORRAR ESPACIO... : ESTADISTICAS DE LA WEB */ function getStats(){ global $tsCore; // OBTENEMOS LAS ESTADISTICAS $return = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT stats_max_online, stats_max_time, stats_time, stats_time_cache, stats_miembros, stats_posts, stats_fotos, stats_comments, stats_foto_comments FROM w_stats WHERE stats_no = \'1\'')); if($return['stats_time_cache'] < time()-($tsCore->settings['c_stats_cache']*60)){ $q1 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(user_id) AS u FROM u_miembros WHERE user_activo = \'1\' && user_baneado = \'0\'')); $q2 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(post_id) AS p FROM p_posts WHERE post_status = \'0\'')); $q3 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(foto_id) AS f FROM f_fotos WHERE f_status = \'0\'')); $q4 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(cid) AS c FROM p_comentarios WHERE c_status = \'0\'')); $q5 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(cid) AS fc FROM f_comentarios')); $q6 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(vid_id) AS v FROM v_videos WHERE vid_status = \'0\'')); $q7 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(cid) AS vc FROM v_comentarios')); $return['stats_miembros'] = $q1[0]; $return['stats_posts'] = $q2[0]; $return['stats_fotos'] = $q3[0]; $return['stats_comments'] = $q4[0]; $return['stats_foto_comments'] = $q5[0]; $return['stats_videos'] = $q6[0]; $return['stats_video_comments'] = $q7[0]; $ndat = ', stats_time_cache = \''.time().'\', stats_miembros = \''.$return['stats_miembros'].'\', stats_posts = \''.$return['stats_posts'].'\', stats_fotos = \''.$return['stats_fotos'].'\' , stats_videos = \''.$return['stats_videos'].'\', stats_comments = \''.$return['stats_comments'].'\', stats_foto_comments = \''.$return['stats_foto_comments'].'\''; } // PARA SABER SI ESTA ONLINE $is_online = (time() - ($tsCore->settings['c_last_active'] * 60)); // USUARIOS ONLINE - COMPROBAMOS SI CONTAMOS A TODOS LOS USUARIOS O SOLO A REGISTRADOS if(empty($tsCore->settings['c_count_guests'])){ $cueri = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(user_id) AS u FROM `u_miembros` WHERE `user_lastactive` > \''.$is_online.'\'')); }else{ $cueri = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(DISTINCT `session_ip`) AS s FROM `u_sessions` WHERE `session_time` > \''.$is_online.'\'')); } $return['stats_online'] = $cueri[0]; if($return['stats_online'] > $return['stats_max_online']) { $timen = ', stats_max_online = \''.$return['stats_online'].'\', stats_max_time = \''.time().'\''; } db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE w_stats SET stats_time = \''.time().'\' '.$ndat.' '.$timen); // return $return; } En c.swat.php --> inc --> class --> c.swat.php Buscar: // MENSAJES case 'mensaje': Arriba agregar: case 'video': // ¿ES MI VIDEO O ESTÁ OCULTO? $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT `vid_id`, `vid_user`, `vid_status` FROM `v_videos` WHERE `vid_id` = \''.(int)$obj_id.'\' LIMIT 1') or die(mysql_error()); $my_video = db_exec('fetch_assoc', $query); if(empty($my_video['vid_id'])) return '0: Este video no existe'; if($my_video['vid_user'] == $tsUser->uid) return '0: No puedes denunciar tus propios videos.'; if($my_video['vid_status'] == '1') return '0: No puedes denunciar videos ocultos.'; // YA HA REPORTADO? $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT `did` FROM `w_denuncias` WHERE `obj_id` = \''.(int)$obj_id.'\' AND `d_user` = '.$tsUser->uid.' AND `d_type` = \'5\''); $denuncio = db_exec('num_rows', $query); if(!empty($denuncio)) return '0: Ya habías denunciado este video.'; // CUANTAS DENUNCIAS LLEVA? $denuncias = db_exec('num_rows', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT `did` FROM `w_denuncias` WHERE `obj_id` = \''.(int)$obj_id.'\'')); // OCULTAMOS EL VIDEO SI YA LLEVA MÁS DE 3 DENUNCIAS if($denuncias >= 2){ db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE `v_videos` SET `vid_status` = \'1\' WHERE `vid_id` = \''.(int)$obj_id.'\'') or die(mysql_error()); db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE `w_stats` SET `stats_videos` = stats_videos - \'1\' WHERE `stats_no` = \'1\''); } // INSERTAR NUEVA DENUNCIA if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `w_denuncias` (`obj_id`, `d_user`, `d_razon`, `d_extra`, `d_type`, `d_date`) VALUES (\''.(int)$obj_id.'\', \''.$tsUser->uid.'\', \''.$razon.'\', \''.$extras.'\', \'5\', \''.$date.'\')')){ return '1: La denuncia fue enviada.'; } else return '0: Error, inténtalo más tarde.'; break; En c.core.php --> inc --> class --> c.core.php Buscar: function getNovemods() { $datos = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT (SELECT count(post_id) FROM p_posts WHERE post_status = \'3\') as revposts, (SELECT count(cid) FROM p_comentarios WHERE c_status = \'1\' ) as revcomentarios, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'1\') as repposts, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'2\') as repmps, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'3\') as repusers, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'4\') as repfotos, (SELECT count(susp_id) FROM u_suspension) as suspusers, (SELECT count(post_id) FROM p_posts WHERE post_status = \'2\') as pospelera, (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'2\') as fospelera')); $datos['total'] = $datos['repposts'] + $datos['repfotos'] + $datos['repmps'] + $datos['repusers'] + $datos['revposts'] + $datos['revcomentarios']; return $datos; } Reemplazar por: function getNovemods() { $datos = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT (SELECT count(post_id) FROM p_posts WHERE post_status = \'3\') as revposts, (SELECT count(cid) FROM p_comentarios WHERE c_status = \'1\' ) as revcomentarios, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'1\') as repposts, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'2\') as repmps, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'3\') as repusers, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'4\') as repfotos, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'5\') as repvideos, (SELECT count(susp_id) FROM u_suspension) as suspusers, (SELECT count(post_id) FROM p_posts WHERE post_status = \'2\') as pospelera, (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'2\') as fospelera, (SELECT count(vid_id) FROM v_videos WHERE vid_status = \'2\') as vispelera')); $datos['total'] = $datos['repposts'] + $datos['repfotos'] + $datos['repvideos'] + $datos['repmps'] + $datos['repusers'] + $datos['revposts'] + $datos['revcomentarios']; return $datos; } En admin.php --> inc --> php --> admin.php Buscar: //FOTOS } elseif($action == 'fotos'){ if(!$act) { $smarty->assign("tsAdminFotos",$tsAdmin->GetAdminFotos()); } Debajo agregar: //VIDEOS } elseif($action == 'videos'){ if(!$act) { $smarty->assign("tsAdminVideos",$tsAdmin->GetAdminVideos()); } En moderacion.php --> inc --> php --> moderacion.php Buscar: // SUSPENSIONES elseif($action == 'banusers'){ $smarty->assign("tsSuspendidos",$tsMod->getSuspendidos()); } Arriba agregar: elseif($action == 'videos'){ include('../ext/datos.php'); if(empty($act)){ $smarty->assign("tsReports",$tsMod->getDenuncias($action)); $smarty->assign("tsDenuncias",$tsDenuncias[$action]); }elseif($act == 'info'){ $smarty->assign("tsDenuncia",$tsMod->getDenuncia($action)); $smarty->assign("tsDenuncias",$tsDenuncias[$action]); }elseif ($act == 'borrar'){ $tsMod->deleteVideo($vid_); header('location: /moderacion/videos'); } } Buscar: elseif($action == 'fopelera'){ $smarty->assign("tsFopelera",$tsMod->getFopelera()); } Debajo agregar: elseif($action == 'vipelera'){ $smarty->assign("tsVipelera",$tsMod->getVipelera()); } En tops.php --> inc --> php --> tops.php Buscar: switch($action){ case 'posts': $smarty->assign("tsTops",$tsTops->getTopPosts($fecha, $cat)); break; case 'usuarios': $smarty->assign("tsTops",$tsTops->getTopUsers($fecha, $cat)); break; } Debajo agregar: switch($action){ case 'posts': $smarty->assign("tsTops",$tsTops->getTopPosts($fecha, $cat)); break; case 'videos': $smarty->assign("tsTops",$tsTops->getTopVideos($fecha, $desc)); break; case 'fotos': $smarty->assign("tsTops",$tsTops->getTopFotos($fecha, $desc)); break; case 'usuarios': $smarty->assign("tsTops",$tsTops->getTopUsers($fecha, $cat)); break; } En ajax.admin.php --> inc --> php --> ajax --> ajax.admin.php Buscar: 'admin-badwords-delete' => array('n' => 4, 'p' => ''), Debajo agregar: 'admin-video-borrar' => array('n' => 4, 'p' => ''), 'admin-video-setOpenClosed' => array('n' => 4, 'p' => ''), 'admin-video-setShowHide' => array('n' => 4, 'p' => ''), Buscar: case 'admin-users-InActivo': Arriba agregar: case 'admin-video-borrar': //<--- echo $tsAdmin->DelVideo(); //---> break; case 'admin-video-setOpenClosed': //<--- echo $tsAdmin->setOpenClosedVideo(); //---> break; case 'admin-video-setShowHide': //<--- echo $tsAdmin->setShowHideVideo(); //---> break; En ajax.denuncia.php --> inc --> php --> ajax --> ajax.denuncia.php Buscar: 'denuncia-usuario' => array('n' => 2, 'p' => 'form'), Debajo agregar: 'denuncia-video' => array('n' => 2, 'p' => 'form'), Buscar: case 'denuncia-mensaje': Arriba agregar: case 'denuncia-video': // CREAR DENUNCIA if($_POST['razon']){ $tsAjax = 1; echo $tsSwat->setDenuncia($obj_id, 'video'); // FORMULARIO DE DENUNCIA } else { // VARS $tsData = array( 'obj_id' => $obj_id, 'obj_title' => $tsCore->setSecure($_POST['obj_title']), 'obj_user' => $tsCore->setSecure($_POST['obj_user']), ); // DATOS include("../ext/datos.php"); $smarty->assign("tsData",$tsData); $smarty->assign("tsDenuncias",$tsDenuncias['videos']); } break; En ajax.moderacion.php --> inc --> php --> ajax --> ajax.moderacion.php Buscar: 'moderacion-mps' => array('n' => 3, 'p' => 'main'), Debajo agregar: 'moderacion-videos' => array('n' => 3, 'p' => 'main'), Buscar: case 'moderacion-fotos': Arriba agregar: case 'moderacion-videos': //<-- $vid = (int)$_POST['vid']; // ACCIONES SECUNDARIAS switch($do){ case 'reboot': $tsAjax = 1; echo $tsMod->rebootVideo($_POST['id']); break; case 'borrar': if($_POST['razon']){ $tsAjax = 1; echo $tsMod->deleteVideo($vid); }else { include('../ext/datos.php'); $tsPage = 'php_files/p.videos.mod'; $smarty->assign("tsDenuncias",$tsDenuncias['videos']); } break; En ajax.notificaciones.php inc --> php --> ajax --> ajax.notificaciones.php Buscar: case 'unfollow': // <-- echo $tsMonitor->setUnFollow(); // --> break; Debajo agregar: case 'videor': // <-- echo $tsMonitor->recomVid(); // --> break; En ajax.perfil.php inc --> php --> ajax --> ajax.perfil.php Buscar: 'perfil-posts' => array('n' => 0, 'p' => 'posts'), Debajo agregar: 'perfil-videos' => array('n' => 0, 'p' => 'videos'), Buscar: case 'perfil-posts': //<--- $smarty->assign("tsGeneral",$tsCuenta->loadPosts($user_id)); //---> break; Debajo agregar: case 'perfil-videos': //<--- $smarty->assign("tsGeneral",$tsCuenta->loadVideos($user_id)); //---> break; En datos.php --> inc --> ext --> datos.php Buscar: 'fotos' => array( Arriba agregar: 'videos' => array( '', 'Ya está publicado', 'Se hace Spam', 'El video no anda', 'Es racista o irrespetuosa', 'Contiene información personal', 'Contiene pedofilia', 'Es gore o asquerosa', 'Otra razón (especificar)' ), En acciones.js --> themes --> default --> js --> acciones.js Buscar: spamPostHandle: function (r) { var x = r.split('-'); if (x.length == 2) mydialog.alert('Notificaciones', x[1]); else mydialog.close(); }, Debajo agregar: VideoHandle: function (r) { var x = r.split('-'); if (x.length == 2) mydialog.alert('Notificaciones', x[1]); else mydialog.close(); }, VideoHandle: function (r) { var x = r.split('-'); if (x.length == 2) mydialog.alert('Notificaciones', x[1]); else mydialog.close(); }, Buscar: spam: function (id, cb) { this.ajax(Array('action=spam', 'postid='+id), cb); }, Debajo agregar: videor: function (id, cb) { this.ajax(Array('action=videor', 'videoid='+id), cb); }, Buscar: sharePost: function (id) { mydialog.show(); mydialog.title('Recomendar'); mydialog.body('¿Quieres recomendar este post a tus seguidores?'); mydialog.buttons(true, true, 'Recomendar', 'notifica.spam('+id+', notifica.spamPostHandle)', true, true, true, 'Cancelar', 'close', true, false); mydialog.center(); }, Debajo agregar: shareVideo: function (id) { mydialog.show(); mydialog.title('Recomendar'); mydialog.body('¿Quieres recomendar este video a tus seguidores?'); mydialog.buttons(true, true, 'Recomendar', 'notifica.videor('+id+', notifica.VideoHandle)', true, true, true, 'Cancelar', 'close', true, false); mydialog.center(); }, Buscar: case 'fotoid': if(global_data.fotoid!='') return r+global_data.fotoid; break; Debajo agregar: case 'videoid': if(global_data.videoid!='') return r+global_data.videoid; break; En admin.js --> themes --> default --> js --> admin.js Buscar: medallas : { borrar:function(mid, gew){ Arriba agregar: videos : { borrar:function(vid, gew){ if(!gew){ mydialog.show(); mydialog.title('Borrar Video'); mydialog.body('&amp;#191;Quiere borrar este video permanentemente?'); mydialog.buttons(true, true, 'Sí', 'admin.videos.borrar(' + vid + ', 1)', true, false, true, 'No', 'close', true, true); mydialog.center(); }else{ $('#loading').fadeIn(250); $.post(global_data.url + '/admin-video-borrar.php', 'vid_id=' + vid, function(a){ mydialog.alert((a.charAt(0) == '0' ? 'Opps!' : 'Hecho'), a.substring(3), false); mydialog.center(); success: $('#video_' + vid).fadeOut(); $('#loading').fadeOut(350); }); } }, setOpenClosed:function(vid){ $('#loading').fadeIn(250); $.ajax({ type: 'POST', url: global_data.url +'/admin-video-setOpenClosed.php', data: 'vid=' + vid, success: function(h){ switch(h.charAt(0)){ case '0': //Error mydialog.alert('Error', h.substring(3)); break; case '1': // $('#comments_video_' + vid).html('<font color="red">Cerrados</font>'); break; case '2': // $('#comments_video_' + vid).html('<font color="green">Abiertos</font>'); break; } $('#loading').fadeOut(350); } }); }, setShowHide:function(vid){ $('#loading').fadeIn(250); $.ajax({ type: 'POST', url: global_data.url +'/admin-video-setShowHide.php', data: 'vid=' + vid, success: function(h){ switch(h.charAt(0)){ case '0': //Error mydialog.alert('Error', h.substring(3)); break; case '1': // $('#status_video_' + vid).html('<font color="purple">Oculto</font>'); break; case '2': // $('#status_video_' + vid).html('<font color="green">Visible</font>'); break; } $('#loading').fadeOut(350); } }); }, }, En moderacion.js --> themes --> default --> js --> moderacion.js Buscar: users: { Arriba agregar: videos : { // BORRAR borrar:function(vid, redirect, aceptar){ if(!aceptar){ $.ajax({ type: 'POST', url: global_data.url + '/moderacion-videos.php?do=borrar', success: function(h){ mydialog.show(); mydialog.title('Borrar Video'); mydialog.body(h); mydialog.buttons(true, true, 'Borrar', 'mod.videos.borrar(' + vid + ", '" + redirect + "', 1);", true, false, true, 'Cancelar', 'close', true, true); $('#modalBody').css('padding', '20px 10px 0'); mydialog.center(); return; } }); } else { mydialog.procesando_inicio('Eliminando...', 'Borrar Video'); var razon = $('#razon').val() var razon_desc = $('input[name=razon_desc]').val(); $('#loading').fadeIn(250); $.ajax({ type: 'POST', url: global_data.url + '/moderacion-videos.php?do=borrar', data: 'vid=' + vid + '&amp;razon=' + razon + '&amp;razon_desc=' + razon_desc, success: function(h){ switch(h.charAt(0)){ case '0': //Error mydialog.alert('Error', h.substring(3)); break; case '1': if(redirect == 'true') mod.redirect("/moderacion/videos", 1200); else if(redirect == 'videos') { mydialog.alert('Aviso', h.substring(3)); mod.redirect("/videos/", 2000); } else { mydialog.close(); $('#report_' + vid).slideUp(); } break; } $('#loading').fadeOut(350); }, complete: function(){ mydialog.procesando_fin(); $('#loading').fadeOut(350); } }); } }, }, En t.tops.tpl --> themes --> default --> templates --> t.tops.tpl Buscar: {elseif $tsAction == 'usuarios'} {include file='modules/m.top_users.tpl'} Debajo agregar: {elseif $tsAction == 'videos'} {include file='modules/m.top_videos.tpl'} En p.denuncia.form.tpl --> themes --> default --> templates --> t.php_files --> p.denuncia.form.tpl Buscar: {elseif $tsAction == 'denuncia-mensaje'} Arriba agregar: {elseif $tsAction == 'denuncia-video'} <div align="center" style="padding:10px 10px 0"> <b>Denunciar video:</b><br /> {$tsData.obj_title}<br /><br /> <b>Razón de la denuncia:</b><br /> <select name="razon"> {foreach from=$tsDenuncias key=i item=denuncia} {if $denuncia}<option value="{$i}">{$denuncia}</option>{/if} {/foreach} </select><br /> <b>Aclaración y comentarios:</b><br /> <textarea tabindex="6" rows="5" cols="40" name="extras"><textarea><br /> <span class="size9">Para atender tu caso rápidamente, adjunta pruebas de tu denuncia.<br /> (capturas de pantalla)</span> </div> En m.perfil_sidebar.tpl --> themes --> default --> templates --> modules --> m.perfil_sidebar.tpl Buscar: {if $tsInfo.visitas} <ul class="clearfix"> {foreach from=$tsInfo.visitas item=v} <li><a href="{$tsConfig.url}/perfil/{$v.user_name}" class="hovercard" uid="{$v.user_id}" style="display:inline-block;"><img src="{$tsConfig.url}/files/avatar/{$v.user_id}_50.jpg" class="vctip" title="{$v.date|hace:true}" width="32" height="32"/></a></li> {/foreach} </ul> {else} <div class="emptyData">No tiene visitas</div> {/if} </div> {/if} Debajo agregar: <div class="widget w-medallas clearfix"> <div class="title-w clearfix"> <h3>Videos</h3> <span>{$tsInfo.stats.user_videos}</span> </div> <ul class="clearfix"> {foreach from=$tsGeneral.videos item=v key=i} {if $v.vid_id}<a href="{$tsConfig.url}/videos/{$tsInfo.nick}/{$v.vid_id}/{$v.vid_title|seo}.html"> <img class=qtip title="{$v.vid_title}" src="http://img.youtube.com/vi/{$v.vid_url}/1.jpg" width="50" height="50">{else} <li><div class="foto"></div></li>{/if} {/foreach} </ul> </div> En m.perfil_headinfo.tpl --> themes --> default --> templates --> modules --> m.perfil_headinfo.tpl Buscar: <li><a href="#" onclick="perfil.load_tab('medallas', this); return false">Medallas</a></li> Debajo agregar: <li><a href="#" onclick="perfil.load_tab('videos', this); return false">Videos</a></li> Buscar: <li> <strong>{$tsInfo.stats.user_fotos}</strong> <span>Fotos</span> </li> Debajo agregar: <li style="float: right;"> <strong>{$tsInfo.stats.user_videos}</strong> <span>Videos</span> </li> En main_header.tpl --> themes --> default --> templates --> sections --> main_header.tpl Buscar: fotoid:'{$tsFoto.foto_id}', Debajo agregar: videoid:'{$tsVideo.vid_id}', En head_menu.tpl --> themes --> default --> templates --> sections --> head_menu.tpl Buscar: {if $tsConfig.c_fotos_private == '1' && !$tsUser->is_member}{else} <li class="tabbed {if $tsPage == 'fotos'}here{/if}" id="tabbedfotos"> <a title="Ir a Fotos" onclick="menu('fotos', this.href); return false;" href="{$tsConfig.url}/fotos/">Fotos <img alt="Drop Down" src="{$tsConfig.tema.t_url}/images/arrowdown.png"></a> </li> {/if} Debajo agregar: <li class="tabbed {if $tsPage == 'videos'}here{/if}" id="tabbedvideos"> <a title="Ir a Videos" onclick="menu('videos', this.href); return false;" href="{$tsConfig.url}/videos/">Videos <img alt="Drop Down" src="{$tsConfig.tema.t_url}/images/arrowdown.png"></a> </li> En head_submenu.tpl --> themes --> default --> templates --> sections --> head_submenu.tpl Buscar: <div id="subMenuTops" class="subMenu {if $tsPage == 'tops'}here{/if}"> Arriba agregar: <div id="subMenuVideos" class="subMenu {if $tsPage == 'videos'}here{/if}"> <ul class="floatL tabsMenu"> <li{if $tsAction == '' && $tsAction != 'agregar' && $tsAction != 'album' && $tsAction != 'favoritas' || $tsAction == 'ver'} class="here"{/if}><a href="{$tsConfig.url}/videos/">Inicio</a></li> {if $tsAction == 'album' && $tsVUser.0 != $tsUser->uid}<li class="here"><a href="{$tsConfig.url}/videos/{$tsVUser.1}">&Aacute;lbum de {$tsVUser.1}</a></li>{/if} {if $tsUser->is_admod}<li{if $tsAction == 'agregar'} class="here"{/if}><a href="{$tsConfig.url}/videos/agregar/">Agregar Video</a></li>{/if} {if $tsUser->is_member} <li{if $tsAction == 'album' && $tsVUser.0 == $tsUser->uid} class="here"{/if}><a href="{$tsConfig.url}/videos/album/{$tsUser->nick}">Mis Videos</a></li>{/if} <li><a href="{$tsConfig.url}/buscadorv/">Buscador</a></li> </ul> <div class="clearBoth"></div> </div> En t.admin.tpl --> themes --> default --> templates --> t.admin.tpl Buscar: {elseif $tsAction == 'afs'} {include file='admin_mods/m.admin_afiliados.tpl'} Arriba agregar: {elseif $tsAction == 'videos'} {include file='admin_mods/m.admin_videos.tpl'} En t.moderacion.tpl --> themes --> default --> templates --> t.moderacion.tpl Buscar: {elseif $tsAction == 'fotos'} {include file='admin_mods/m.mod_report_fotos.tpl'} Debajo agregar: {elseif $tsAction == 'videos'} {include file='admin_mods/m.mod_report_videos.tpl'} Buscar: {elseif $tsAction == 'fopelera'} {if $tsUser->is_admod || $tsUser->permisos.morf}{include file='admin_mods/m.mod_papelera_fotos.tpl'}{/if} Debajo agregar: {elseif $tsAction == 'vipelera'} {if $tsUser->is_admod}{include file='admin_mods/m.mod_papelera_videos.tpl'}{/if} En m.admin_sidemenu.tpl --> themes --> default --> templates --> admin_mods --> m.admin_sidemenu.tpl Buscar: <li id="a_cats"><span class="cat-title"><a href="{$tsConfig.url}/admin/cats">Categor&iacute;as</a></span></li> Debajo agregar: <li id="a_film"><span class="cat-title"><a href="{$tsConfig.url}/admin/videos">Todos los Videos</a></span></li> En m.mod_sidemenu.tpl --> themes --> default --> templates --> admin_mods --> m.mod_sidemenu.tpl Buscar: <li id="a_users"><span class="cat-title"><a onclick="$('#a_users').addClass('active');" href="{$tsConfig.url}/moderacion/users">Usuarios <span class="cadGe cadGe_{if $tsConfig.novemods.repusers > 15}red{elseif $tsConfig.novemods.repusers > 5}purple{else}green{/if}">{$tsConfig.novemods.repusers}</span></a></span></li> Debajo agregar: <li id="a_film"><span class="cat-title"><a onclick="$('#a_film').addClass('active');" href="{$tsConfig.url}/moderacion/videos">Videos <span class="cadGe cadGe_{if $tsConfig.novemods.repvideos > 15}red{elseif $tsConfig.novemods.repvideos > 5}purple{else}green{/if}">{$tsConfig.novemods.repvideos}</span></a></span></li> Buscar: {if $tsUser->is_admod || $tsUser->permisos.morf}<li id="a_fopelera"><span class="cat-title"><a onclick="$('#a_fopelera').addClass('active');" href="{$tsConfig.url}/moderacion/fopelera">Fotos eliminadas <span class="cadGe cadGe_{if $tsConfig.novemods.fospelera > 15}red{elseif $tsConfig.novemods.fospelera > 5}purple{else}green{/if}">{$tsConfig.novemods.fospelera}</span></a></span></li>{/if} Debajo agregar: {if $tsUser->is_admod}<li id="a_vipelera"><span class="cat-title"><a onclick="$('#a_vipelera').addClass('active');" href="{$tsConfig.url}/moderacion/vipelera">Videos eliminados <span class="cadGe cadGe_{if $tsConfig.novemods.vispelera > 15}red{elseif $tsConfig.novemods.vispelera > 5}purple{else}green{/if}">{$tsConfig.novemods.vispelera}</span></a></span></li>{/if} En admin.css --> themes --> default --> css --> admin.css Buscar: li#a_badwords {background-image: url(../images/icons/stop.png);} Debajo agregar: li#a_film {background-image: url(../images/film.png);} En moderacion.css --> themes --> default --> css --> moderacion.css Buscar: li#a_revposts {background-image: url(../images/icons/exclamation.png);} Debajo agregar: li#a_vipelera {background-image: url(../images/film.png);} li#a_film {background-image: url(../images/film.png);} En .htaccess Buscar: # ADMIN Arriba agregar: # VIDEOS RewriteRule ^videos/([A-Za-z0-9_-]+).php$ inc/php/videos.php?action=$1 [QSA,L] RewriteRule ^videos/album/([A-Za-z0-9_-]+)$ inc/php/videos.php?action=album&user=$1 [QSA,L] RewriteRule ^videos/album/([A-Za-z0-9_-]+)/([0-9]+)$ inc/php/videos.php?action=album&user=$1&page=$2 [QSA,L] RewriteRule ^videos/([A-Za-z0-9_-]+)/([0-9]+)/([A-Za-z0-9_-]+).html$ inc/php/videos.php?action=ver&user=$1&vid=$2 [QSA,L] RewriteRule ^admin/videos/([A-Za-z0-9_-]+)/([0-9]+)$ inc/php/admin.php?action=videos&act=$1&vid=$2 [QSA,L] RewriteRule ^videos/([A-Za-z0-9_-]+)/([0-9]+)$ inc/php/videos.php?action=$1&id=$2 [QSA,L] Y subir esta carpeta https://mega.nz/file/hBIyCRKQ#l8OQEmYQDAvyk-0vTXRt5l2XsFi0Fz0EPLVNXBUTYnw Creditos: Nico y Aperpen
  5. 4 points
    Hola a [email protected], os dejo el mod dinero por posts V4 actualizado a 1.3 , lo he probado en el tema default de risus pero tiene que funcionar en cualquier tema, lo que cambia es el diseño. DEMO Ejecutar estas consultas ALTER TABLE `p_posts` ADD `x_dinero` float NOT NULL DEFAULT '0', ADD `p_validate` int(1) NOT NULL DEFAULT '0'; ALTER TABLE `w_configuracion` ADD `dinerox` int(1) NOT NULL DEFAULT '0', ADD `dinerp` float NOT NULL DEFAULT '0'; ALTER TABLE `u_miembros` ADD `uid_act` int(6) NOT NULL , ADD `dinok` float NOT NULL DEFAULT '0' ; CREATE TABLE IF NOT EXISTS `u_pagos` ( `pid` int(11) NOT NULL AUTO_INCREMENT, `p_user_id` int(11) NOT NULL, `p_up` int(6) NOT NULL, `p_dinero` float NOT NULL, `p_secret` varchar(50) NOT NULL, `p_date` int(10) NOT NULL, `p_autor_ip` varchar(15) NOT NULL, `p_type` int(1) NOT NULL DEFAULT '0', PRIMARY KEY (`pid`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ; CREATE TABLE IF NOT EXISTS `u_cobros` ( `cid` int(11) NOT NULL AUTO_INCREMENT, `c_user_id` int(11) NOT NULL, `c_email` varchar(50) NOT NULL, `c_pais` varchar(50) NOT NULL, `c_dinero` float NOT NULL, `c_secret` varchar(50) NOT NULL, `c_coment` varchar(300) NOT NULL, `c_date` int(10) NOT NULL, `c_autor_ip` varchar(15) NOT NULL, `c_type` int(1) NOT NULL DEFAULT '0', PRIMARY KEY (`cid`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ; CREATE TABLE IF NOT EXISTS `u_registros` ( `rid` int(11) NOT NULL AUTO_INCREMENT, `r_user_id` int(11) NOT NULL, `r_dinero` float NOT NULL, `r_codigo` varchar(50) NOT NULL, `r_comentario` varchar(200) NOT NULL, `r_autor_ip` varchar(15) NOT NULL, `r_date` int(10) NOT NULL, `r_type` int(1) NOT NULL DEFAULT '0', PRIMARY KEY (`rid`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ; En c.admin.php --> inc --> class --> c.admin.php Buscar: 'gopfd' => $_POST['global-pointsforday']); Agregar arriba: 'gopxd' => $_POST['global-pointsxdinero'], Buscar: 'gopfd' => $_POST['global-pointsforday']); Agregar arriba: 'gopxd' => $_POST['global-pointsxdinero'], Buscar: 'offline_message' => $tsCore->setSecure($tsCore->parseBadWords($_POST['offline_message'])), Debajo agregar: 'dinerox' => empty($_POST['dinerox']) ? 0 : 1, 'dinerp' => $tsCore->setSecure($_POST['dinerp']), Buscar: , `offline_message` = \'' . $c['offline_message'] . '\' Agregar al lado: , `dinerox` = \'' . $c['dinerox'] .'\', `dinerp` = \'' . $c['dinerp'] . '\' Buscar al final: /*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/ } Agregar arriba: function setUserXdinero($user_id) { global $tsCore, $tsUser; $ipuser = $_SERVER['REMOTE_ADDR']; $din = (float)$tsCore->setSecure($_POST['dinero']); $csecret = $tsCore->setSecure($_POST['csecret']); $time = time(); $datinfo = 'Se h&aacute; enviado <b>$'.$din.'</b> ( Guarda este c&oacute;digo : '.$csecret.' )<br><a href="/dinero/confirma">Confirma desde Aqui</a>'; if($din!=0){ if (db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `u_avisos` (`user_id`, `av_subject`, `av_body`, `av_date`, `av_type`) VALUES (\''.(int)$user_id.'\', \'Confirmaci&oacute;n\', \'' . $datinfo . '\', \''.$time.'\', \'0\')')) if (db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `u_avisos` (`user_id`, `av_subject`, `av_body`, `av_date`, `av_type`) VALUES (\'1\', \'Se cambio el saldo \', \'</b> Se h&aacute; cambiado el saldo del usuario <a href="/perfil/'.$tsUser->getUserName($user_id).'">'.$tsUser->getUserName($user_id).'</a> <a href="/perfil/'.$tsUser->getUserName($user_id).'"><img class="hovercard" uid="'.(int)$user_id.'" style="width:16px; height:16px;margin:0 5px 0 5px;" src="'.$tsCore->settings['url'].'/files/avatar/'.(int)$user_id.'_50.jpg"></img></a><br/><span>Operaci&oacute;n realizada por <a href="/perfil/'.$tsUser->nick.'"><b>'.$tsUser->nick.'</b></a></span><br/>C&oacute;digo de la operaci&oacute;n : '.$csecret.'\', \''.$time.'\', \'0\')')) if (db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `u_pagos` (`p_user_id`, `p_up`,`p_dinero`,`p_secret`, `p_date`, `p_autor_ip`, `p_type`) VALUES (\'' .(int)$user_id . '\', \'' . $tsUser->uid .'\', \'' . $din . '\', \'' . $csecret . '\', \'' . $time .'\', \'' . $ipuser .'\', \'0\')')) db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE u_cobros SET c_type = \'1\' WHERE c_user_id = \''.$user_id.'\' && c_secret = \''.$csecret.'\' LIMIT 1'); return '<div style="width:655px;" class="dinerok">Operaci&oacute;n Exitosa.</div>'; }else return '<div style="width:655px;" class="errorsol">No seleccionaste el dinero</div>'; } function getPostUserD($user_id) { global $tsCore; // $data['dinero'] = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT u.user_id, u.user_name, u.user_rango, u.user_posts, u.user_baneado, u.uid_act, v.post_user, v.x_dinero, v.post_status, v.p_validate, c.c_user_id, c.c_email, c.c_pais, c.c_secret, c.c_dinero, c.c_coment, c.c_date, c.c_autor_ip, c.c_type, r.rango_id, r.r_name, r.r_color FROM u_miembros AS u LEFT JOIN p_posts AS v ON v.post_user = u.user_id LEFT JOIN u_cobros AS c ON c.c_user_id = u.user_id LEFT JOIN u_rangos AS r ON r.rango_id = u.user_rango WHERE u.user_id = \''.(int)$user_id.'\' && c.c_type = 0 GROUP BY user_id')); $q1 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT CAST(SUM(x_dinero) as DECIMAL(5,2)) FROM p_posts WHERE post_user = \''.(int)$user_id.'\' && post_status = \'0\' && p_validate = \'1\'')); $q2 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(post_id) as p FROM p_posts WHERE post_user = \''.(int)$user_id.'\' && post_status = \'0\' && p_validate = \'1\'')); $q3 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT SUM(post_puntos) as ps FROM p_posts WHERE post_user = \''.(int)$user_id.'\' && post_status = \'0\' && p_validate = \'1\'')); $q4 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(p_validate) as r FROM p_posts WHERE post_user = \''.(int)$user_id.'\' && post_status = \'0\' && p_validate = \'2\'')); $data['dinero']['x_dinero'] = $q1[0]; $data['dinero']['post_id'] = $q2[0]; $data['dinero']['post_puntos'] = $q3[0]; $data['dinero']['p_validate'] = $q4[0]; return $data; } function getSolprim($user_id) { global $tsCore; // $user_id = $tsCore->setSecure($_GET['uid']); $data['datainfo'] = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT u.user_id, u.user_name, u.user_posts, u.user_baneado, u.uid_act, p.post_user, p.x_dinero, p.post_status, p.p_validate FROM u_miembros AS u LEFT JOIN p_posts AS p ON p.post_user = u.user_id WHERE u.user_id = \''.(int)$user_id.'\' GROUP BY user_id')); $q1 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT CAST(SUM(x_dinero) as DECIMAL(5,2)) FROM p_posts WHERE post_user = \''.(int)$user_id.'\' && post_status = \'0\' && p_validate = \'1\'')); $data['datainfo']['x_dinero'] = $q1[0]; return $data; } En c.cuenta.php --> inc --> class --> c.cuenta.php Buscar: // REAL STATS $data['stats'] = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT u.user_id, u.user_rango, u.user_puntos, u.user_posts, u.user_comentarios, u.user_seguidores, u.user_cache, r.r_name, r.r_color FROM u_miembros AS u LEFT JOIN u_rangos AS r ON u.user_rango = r.rango_id WHERE u.user_id = \''.(int)$user_id.'\'')); Antes de: FROM Agregar: , u.uid_act, u.dinok, v.post_user, v.x_dinero, v.post_status, v.p_validate En la misma linea buscar: WHERE Agregar antes: LEFT JOIN p_posts AS v ON v.post_user = u.user_id Buscar: $q3 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(cid) AS c FROM p_comentarios WHERE c_user = \''.(int)$user_id.'\' && c_status = \'0\'')); Debajo agregar: $q5 = db_exec('fetch_row', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT CAST(SUM(x_dinero) as DECIMAL(5,2)) FROM p_posts WHERE post_user = \''.(int)$user_id.'\' && post_status = \'0\' && p_validate = \'1\'')); Buscar: $data['stats']['user_comentarios'] = $q3[0]; Debajo agregar: $data['stats']['x_dinero'] = $q5[0]; En c.modeacion.php --> inc --> class --> c.modeacion.php Antes de la última } agregar arriba: public function getDineroP() { global $tsUser, $tsCore; $max = 10; // MAXIMO A MOSTRAR $limit = $tsCore->setPageLimit($max, true); // PAGINAS $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT COUNT(post_id) FROM p_posts WHERE post_status = \'0\' && x_dinero > \'0\' && p_validate = \'0\''); list($total) = db_exec('fetch_row', $query); $data['pages'] = $tsCore->pageIndex($tsCore->settings['url'] . "/moderacion/dinero?", $_GET['s'], $total, $max); // $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT p.post_id, p.post_user, p.post_category, p.post_title, p.post_date, p.post_puntos, p.x_dinero, p.post_ip, p.post_status, p.p_validate, c.cid, c.c_seo, u.user_id, u.user_name FROM `p_posts` AS p LEFT JOIN p_categorias AS c ON c.cid = p.post_category LEFT JOIN u_miembros AS u ON u.user_id = p.post_user WHERE post_status = \'0\' && x_dinero > \'0\' && p_validate = \'0\' ORDER BY post_id DESC LIMIT ' . $limit); $data['datos'] = result_array($query); // return $data; } /* DineroA() */ public function DineroA($id) { // filtramos // $id = (int) $id; $activ = 1; db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE `p_posts` SET `p_validate` = \''.$activ.'\' WHERE post_id = '.$id); } /* DineroR() */ public function DineroR($id) { // filtramos // $id = (int) $id; $rech = (int) 0; db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE p_posts SET p_validate = 2 WHERE post_id = '.$id); db_exec(array(__FILE__, __LINE__), 'query', 'UPDATE `p_posts` SET `x_dinero` = \''.$rech.'\' WHERE post_id = '.$id); } En moderacion.php --> inc --> php --> moderacion.php Buscar: //PAPELERAS elseif($action == 'pospelera'){ $smarty->assign("tsPospelera",$tsMod->getPospelera()); } Debajo agregar: //CONTROL DE DINERO elseif($action == 'dinero'){ $smarty->assign("tsDinero",$tsMod->getDineroP()); if(isset($_GET['link'])) { $tsMod->DineroA($_GET['link']); } if(isset($_GET['link'])) {$tsCore->redirectTo($tsCore->settings['url'].'/moderacion/dinero/');} if(isset($_GET['reac'])) { $tsMod->DineroR($_GET['reac']); } if(isset($_GET['reac'])) {$tsCore->redirectTo($tsCore->settings['url'].'/moderacion/dinero/');} } En c.core.php --> inc --> class --> c.core.php Buscar: function getNovemods() { $datos = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT (SELECT count(post_id) FROM p_posts WHERE post_status = \'3\') as revposts, (SELECT count(cid) FROM p_comentarios WHERE c_status = \'1\' ) as revcomentarios, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'1\') as repposts, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'2\') as repmps, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'3\') as repusers, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'4\') as repfotos, (SELECT count(susp_id) FROM u_suspension) as suspusers, (SELECT count(post_id) FROM p_posts WHERE post_status = \'2\') as pospelera, (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'2\') as fospelera')); $datos['total'] = $datos['repposts'] + $datos['repfotos'] + $datos['repmps'] + $datos['repusers'] + $datos['revposts'] + $datos['revcomentarios']; return $datos; } Reemplazar por: function getNovemods() { $datos = db_exec('fetch_assoc', db_exec(array(__FILE__, __LINE__), 'query', 'SELECT (SELECT count(post_id) FROM p_posts WHERE post_status = \'3\') as revposts, (SELECT count(cid) FROM p_comentarios WHERE c_status = \'1\' ) as revcomentarios, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'1\') as repposts, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'2\') as repmps, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'3\') as repusers, (SELECT count(DISTINCT obj_id) FROM w_denuncias WHERE d_type = \'4\') as repfotos, (SELECT count(susp_id) FROM u_suspension) as suspusers, (SELECT count(post_id) FROM p_posts WHERE post_status = \'2\') as pospelera, (SELECT count(foto_id) FROM f_fotos WHERE f_status = \'2\') as fospelera, (SELECT count(post_id) FROM p_posts WHERE post_status = \'0\' && x_dinero > \'0\' && p_validate = \'0\') as dineromod')); $datos['total'] = $datos['repposts'] + $datos['repfotos'] + $datos['repmps'] + $datos['repusers'] + $datos['revposts'] + $datos['revcomentarios'] + $datos['dineromod']; return $datos; } En admin.php --> inc --> php --> admin.php Buscar: case 8: if(!empty($_POST['save'])){ $update = $tsAdmin->setUserFirma($user_id); if($update == 'OK') $tsCore->redirectTo($tsCore->settings['url'].'/admin/users?act=show&uid='.$user_id.'&save=true'); else $smarty->assign("tsError",$update); } $smarty->assign("tsUserF",$tsAdmin->getUserData()); break; Debajo agregar: case 9: if(!empty($_POST['save'])){ $update = $tsAdmin->setUserXdinero($user_id); if($update == 'OK') $tsCore->redirectTo($tsCore->settings['url'].'/admin/users?act=show&uid='.$user_id.'&save=true'); else $smarty->assign("tsError",$update); } $smarty->assign("tsPostU",$tsAdmin->getPostUserD($user_id)); $smarty->assign("tsSolprim",$tsAdmin->getSolprim($user_id)); break; En c.posts.php --> inc --> class --> c.posts.php Buscar: if(db_exec(array(__FILE__, __LINE__), 'query', 'INSERT INTO `p_posts` (post_user, post_category, post_title, post_body, post_date, post_tags, post_ip, post_private, post_block_comments, post_sponsored, post_sticky, post_smileys, post_visitantes, post_status) VALUES (\''.$tsUser->uid.'\', \''.(int)$postData['category'].'\', \''.$postData['title'].'\', \''.$postData['body'].'\', \''.$postData['date'].'\', \''.$postData['tags'].'\', \''.$_SERVER['REMOTE_ADDR'].'\', \''.(int)$postData['private'].'\', \''.(int)$postData['block_comments'].'\', \''.(int)$postData['sponsored'].'\', \''.(int)$postData['sticky'].'\', \''.(int)$postData['smileys'].'\', \''.(int)$postData['visitantes'].'\', '.(!$tsUser->is_admod && ($tsCore->settings['c_desapprove_post'] == 1 || $tsUser->permisos['gorpap'] == true) ? '\'3\'' : '\'0\'').')')) { $postID = db_exec('insert_id'); Agregar arriba: if($tsCore->settings['dinerox'] == 1 && $tsUser->info['uid_act']==0){$dinerox = (float)$tsUser->permisos['gopxd'];}else $dinerox = 0; En la linea buscada buscar: , post_status ( o el último campo que tengan agregado ) Agregar al lado: , x_dinero Al final de la misma linea buscar: ? '\'3\'' : '\'0\'').')')) { Reemplazar por: ? '\'3\'' : '\'0\'').', \''.$dinerox.'\')')) { En agregar.php --> inc --> php --> agregar.php Buscar: $smarty->assign("tsAviso",array('titulo' => 'Bien!', 'mensaje' => 'El post <b>'.$_POST['titulo'].'</b> fue agregado. '.(!$tsUser->is_admod && ($tsUser->permisos['gorpap'] == true || $tsCore->settings['c_desapprove_posts'] == 1) ? 'Deber&aacute; esperar su aprobaci&oacute;n' : '').' ', 'but' => 'Acceder al post', 'link' => "{$tsCore->settings['url']}/posts/{$tsCat['c_seo']}/$tsPost/{$tsCore->setSEO($_POST['titulo'])}.html")); Reemplazar por: if($tsCore->settings['dinerox'] == 1 && $tsUser->info['uid_act']==0){$smarty->assign("tsAviso",array('titulo' => 'Bien!', 'mensaje' => "El post <font color='#0099ff'><b>{$_POST['titulo']}</b></font> fue agregado.<i>Sumaste: $ </i><blink><font color='greenlima'><b>{$tsUser->permisos['gopxd']}</b></font></blink> de Dinero.".(!$tsUser->is_admod && ($tsUser->permisos['gorpap'] == true || $tsCore->settings['c_desapprove_posts'] == 1) ? 'Deber&aacute; esperar su aprobaci&oacute;n' : '').' ', 'but' => 'Acceder al post', 'link' => "{$tsCore->settings['url']}/posts/{$tsCat['c_seo']}/$tsPost/{$tsCore->setSEO($_POST['titulo'])}.html"));} else{ $smarty->assign("tsAviso",array('titulo' => 'Bien!', 'mensaje' => 'El post <b>'.$_POST['titulo'].'</b> fue agregado. '.(!$tsUser->is_admod && ($tsUser->permisos['gorpap'] == true || $tsCore->settings['c_desapprove_posts'] == 1) ? 'Deber&aacute; esperar su aprobaci&oacute;n' : '').' ', 'but' => 'Acceder al post', 'link' => "{$tsCore->settings['url']}/posts/{$tsCat['c_seo']}/$tsPost/{$tsCore->setSEO($_POST['titulo'])}.html")); } En m.admin_rangos.tpl --> themes --> default --> templates --> admin_mods --> m.admin_rangos.tpl Buscar: <dl> <dt><label for="goaf">Anti-flood</label><br /><span>Tiempo que deben esperar entre acci&oacute;n.</span></dt> <dd><input type="text" id="goaf" name="global-antiflood" value="{$tsRango.permisos.goaf}" style="width:30%"/></dd> </dl> Agregar arriba: <dl> <dt><label for="gopxd">Dinero por Posts</label><br /><span>Cantidad de dinero por posts creado</span></dt> <dd><input type="text" id="gopxd" name="global-pointsxdinero" value="{$tsRango.permisos.gopxd}" style="width:30%"/></dd> </dl> En m.admin_users.tpl --> themes --> default --> templates --> admin_mods --> m.admin_users.tpl Buscar: <option value="8"{if $tsType == 8} selected="true"{/if}>Firma</option> Debajo agregar: <option value="9"{if $tsType == 9} selected="true"{/if}>Dinero</option> Buscar: {elseif $tsType == 8} <legend>Modificar firma de usuario</legend> <textarea name="firma" rows="3" cols="50">{$tsUserF.user_firma}</textarea> {else} <div class="phpostAlfa">Pendiente</div> {/if} <p><input type="submit" name="save" value="Enviar Cambios" class="btn_g"/></p> </fieldset> Reemplazar por: {elseif $tsType == 8} <div style="overflow: hidden;clear: both;margin-bottom: 20px;"> <textarea class="searchBar autogrow markItUpEditor" name="firma" rows="3" cols="50" style="font-size: 14px;width: 570px;margin: 0;">{$tsUserF.user_firma}</textarea> </div> {elseif $tsType == 9} <legend>Dinero Disponible</legend> <a href="/perfil/{$tsSolprim.datainfo.user_name}">{$tsSolprim.datainfo.user_name}</a> acumula de saldo<b>&nbsp;${if $tsSolprim.datainfo.x_dinero!=''}{$tsSolprim.datainfo.x_dinero}{else}0.00{/if}</b><br/><br/> <br/>{if $tsSave}Cuando confirme su Dinero recibido le sera descontado el Importe.{/if} {if $tsSolprim.datainfo.uid_act == 0} No h&aacute; solicitado su pago. {/if} {if $tsPostU.dinero.uid_act==1} <div class="solicitud-user"> <h3>Informacion:</h3> <ul> <li>Usuario: <b> {$tsPostU.dinero.user_name}</b></li> <li>Rango: <b style="color:#{$tsPostU.dinero.r_color};"> {$tsPostU.dinero.r_name}</b></li> <li>H&aacute; solicitado: <b>$ {$tsPostU.dinero.c_dinero}</b></li> <li>Posts Aprobados: <b>{$tsPostU.dinero.post_id}</b></li> <li>Posts Rechazados: <b>{$tsPostU.dinero.p_validate}</b></li> <li>Puntos Recibidos: <b>{$tsPostU.dinero.post_puntos}</b></li> </ul> <h3>Datos Ofrecidos:</h3> <ul> <li>Enviado: {$tsPostU.dinero.c_date|hace}</li> <li>Paypal: {$tsPostU.dinero.c_email}</li> <li>Pa&iacute;s: {$tsPostU.dinero.c_pais}</li> <li>C&oacute;digo: {$tsPostU.dinero.c_secret}</li> <li>Comentario: {$tsPostU.dinero.c_coment}</li> <li>Ip: <a href="/moderacion/buscador/1/1/{$tsPostU.dinero.c_autor_ip }" target="_blank">{$tsPostU.dinero.c_autor_ip }</a></li> </ul> <br/> <input type="hidden" name="csecret" value="{$tsPostU.dinero.c_secret}"/> <select id="dinero" name="dinero" style="width: 120px;"> <option value="0" {if $tsPostU.dinero.x_dinero > 0}selected{/if} >Seleccionar dinero</option> <option value="{$tsPostU.dinero.x_dinero}" >Disponible $ {$tsPostU.dinero.x_dinero}</option> </select> <br/><br/><h4>El dinero Disponible le sera Descontado de su Saldo.<br/>Al enviar los cambios el usuario queda a disposici&oacute;n para la recepcion del dinero.</h4> </div> {/if} {else} <div class="phpostAlfa">Pendiente</div> {/if} {if $tsType == 9 && (($tsPostU.dinero.x_dinero >= $tsConfig.dinerp) && $tsPostU.dinero.uid_act == 1)} <p><input type="submit" name="save" value="Enviar Cambios" class="btn_g"/></p> {else} {if $tsType == 9 && $tsPostU.dinero.c_type == 0} {else} <p><input type="submit" name="save" value="Enviar Cambios" class="btn_g"/></p> {/if}{/if} </fieldset> En m.admin_configs.tpl --> themes --> default --> templates --> admin_mods --> m.admin_configs.tpl Buscar: <dl> <dt><label for="ai_chat">Chatango ID:</label><br /><span>Por defecto puedes agregar un chat de <a href="http://chatango.com">Chatango</a> para tu web, solo crea tu grupo he ingresa el nombre. (Dejar vac&iacute;o para usar xat)</span></dt> <dd><input type="text" id="ai_chat" name="chat" maxlength="20" value="{$tsConfig.chat_id}" class="searchBar" style="width: 280px;"/> </dd> </dl> Agregar arriba: <hr> <dl> <dt><label for="dinerox">Activar Dinero por posts.</label><br /><span>Aqu&iacute; podras activar el pago de dinero por posts creados. Desea activarlo?</span></dt> <dd> <label><input name="dinerox" type="radio" id="dinerox" value="1" {if $tsConfig.dinerox == 1}checked="checked"{/if} class="radio"/> S&iacute;</label> <label><input name="dinerox" type="radio" id="dinerox" value="0" {if $tsConfig.dinerox != 1}checked="checked"{/if} class="radio"/> No</label> </dd> </dl> <dl> <dt><label for="dinerp">Cantidad Dinero</label><br /><span>Indique la cantidad m&iacute;nima de dinero que el usuario necesita para poder cobrar.</span></dt> <dd><input type="text" id="dinerp" name="dinerp" style="width:10%" maxlength="5" value="{$tsConfig.dinerp}" /> </dd> </dl> <hr> En m.perfil_headinfo.tpl --> themes --> default --> templates --> modules --> m.perfil_headinfo.tpl Buscar: <li> <strong>{$tsInfo.stats.user_fotos}</strong> <span>Fotos</span> </li> Debajo agregar: <li id="xdin"> <strong>${if $tsInfo.stats.x_dinero!=''}{$tsInfo.stats.x_dinero}{else}0{/if}</strong> <span>Dinero Acumulado</span> </li> <li id="xdin"> <strong>${$tsInfo.stats.dinok}</strong> <span>Dinero Pagado</span> </li> En t.moderacion.tpl --> themes --> default --> templates --> t.moderacion.tpl Buscar: {elseif $tsAction == 'users'} {include file='admin_mods/m.mod_report_users.tpl'} Debajo agregar: {elseif $tsAction == 'dinero'} {include file='admin_mods/m.mod_dinero_posts.tpl'} En m.mod_sidemenu.tpl --> themes --> default --> templates --> admin_mods --> m.mod_sidemenu.tpl Buscar: {if $tsUser->is_admod || $tsUser->permisos.mocc}<li id="a_comentarios"><span class="cat-title"><a onclick="$('#a_comentarios').addClass('active');" href="{$tsConfig.url}/moderacion/comentarios">Comentarios <span class="cadGe cadGe_{if $tsConfig.novemods.revcomentarios > 15}red{elseif $tsConfig.novemods.revcomentarios > 5}purple{else}green{/if}">{$tsConfig.novemods.revcomentarios}</span></a></span></li>{/if} Debajo agregar: {if $tsUser->is_admod || $tsUser->permisos.mocc}<li id="a_dinero"><span class="cat-title"><a onclick="$('#a_dinero').addClass('active');" href="{$tsConfig.url}/moderacion/dinero">Dinero <span class="cadGe cadGe_{if $tsConfig.novemods.dineromod > 15}red{elseif $tsConfig.novemods.dineromod > 5}purple{else}green{/if}">{$tsConfig.novemods.dineromod}</span></a></span></li>{/if} En head_menu.tpl --> themes --> default --> templates --> sections --> head_menu.tpl Buscar: $tsPage != 'fotos' Agregar al lado: && $tsPage != 'dinero' Buscar: <li class="tabbed {if $tsPage == 'tops'}here{/if}" id="tabbedtops"> <a title="Ir a TOPs" onclick="menu('tops', this.href); return false;" href="{$tsConfig.url}/top/">TOPs <img alt="Drop Down" src="{$tsConfig.tema.t_url}/images/arrowdown.png"></a> </li> Debajo agregar: {if $tsUser->is_member} <li class="tabbed {if $tsPage == 'dinero'}here{/if}" id="tabbedtops"> <a title="Ir l Panel" onclick="menu('dinero', this.href); return false;" href="{$tsConfig.url}/dinero/">Dinero <img alt="Drop Down" src="{$tsConfig.tema.t_url}/images/arrowdown.png"></a> </li> {/if} En head_submenu.tpl --> themes --> default --> templates --> sections --> head_submenu.tpl Buscar: <div id="subMenuTops" class="subMenu {if $tsPage == 'tops'}here{/if}"> Agregar arriba: <div id="subMenuPosts" class="subMenu {if $tsPage == 'dinero'}here{/if}"> <ul class="floatL tabsMenu"> <li{if $tsAction != 'rec' && $tsAction != 'rev'} class="here"{/if}><a href="{$tsConfig.url}/dinero/">Inicio</a></li> <li {if $tsAction == 'rec'}class="here"{/if}><a href="{$tsConfig.url}/dinero/rec">Rechazados</a></li> <li{if $tsAction == 'rev'} class="here"{/if}><a href="{$tsConfig.url}/dinero/rev">Revision</a></li> {if $tsDiner.dinero.x_dinero >= $tsConfig.dinerp}<li{if $tsAction == 'pagos'} class="here"{/if}><a href="{$tsConfig.url}/dinero/pagos">Solicitar</a></li>{/if} </ul> <div class="clearBoth"></div> </div> En moderacion.css --> themes --> default --> moderacion.css Buscar: li#a_comentarios {background-image: url(../images/icons/comment.png);} Debajo agregar: li#a_dinero {background-image: url(../images/icons/currency.png);} En estilo.css --> themes --> default --> estilo.css Al final agregar: .dinerok{background:#0f0;color:#fff;width:590px;border:5px solid #0c0;font-size:14px;font-weight:700;margin-bottom:10px;padding:10px;text-align:center} .errorsol{background:#d90000;color:#fff;width:590px;border:5px solid orange;font-size:14px;font-weight:700;margin-bottom:10px;padding:10px;text-align:center} .errorlog{background:orange;color:#fff;width:590px;border:5px solid orange;font-size:14px;font-weight:700;margin-bottom:10px;padding:10px;text-align:center} .solicitud-user{background:#eee;width:660px;height:auto;padding:10px;border:1px solid #ccc} .solicitud-user ul li{background:#fff;display:block;border:1px solid #ccc;padding:5px;margin:5px 0} #panel-userD{width:100%;height:auto;font-family:Helvetica,Arial;background:#fff url(images/sidebar.png);overflow:hidden;border:1px solid #dfdfd0} .prindu{background:#eee;border-bottom:1px solid #dfdfd0;width:620px;height:115px;overflow:hidden} .prindu a img{width:100px;height:100px;padding:1px;border:1px solid #ccc;margin:5px} .prindu a img:hover{opacity:.7;background:#fff;border:1px solid #fff} .prindu span{float:right;width:480px;margin:5px;font-size:12px;padding:5px;color:#666} .list-du{background:#eee;float:left;width:610px;margin:5px 0 5px 0;font-size:12px;padding:5px} .din_table{background:#fff;border:1px solid #ddd;border-width:1px 0 0 1px}.din_table thead{background:#f4f4f4} .din_table td,.din_table th{padding:3px 4px;border:1px solid #ddd;border-width:0 1px 1px 0;vertical-align:middle;text-align:center} .panelud{background:#fff;float:right;width:300px;margin-bottom:20px;height:auto;overflow:hidden} .panelud span{text-align:left}.panelud span p{font-size:12px;text-align:center;margin-top:20px;color:#666} .panelud span p b{background:url(images/coins.png) no-repeat left;padding:4px 3px 4px 30px;margin-top:15px;font-size:26px;color:#000} .regd{background:#eee;width:620px;height:auto;margin-top:5px;border-bottom:1px solid #e7e7da} .regd span p{padding:0 10px 0 10px}.dinx{margin-right:5px;margin-top:-3px} .dinx img{width:16px;height:16px;margin-right:3px;margin-left:8px} #xdin{background:#eceae1 url(images/coins.png) no-repeat;background-position:110px 5px} #xdin:hover{background:#fff url(images/coins.png) no-repeat;background-position:110px 5px} .postsrev{width:620px;height:auto}.postsrev ul{margin:5px;border-bottom:1px solid #e0e0e0} .postsrev ul li{display:block;padding:5px;background:#fff;color:#666} .postsrev ul li:nth-child(2n+1){border-top:1px solid #e0e0e0;background:#f5f5f5} .postsrev ul li a{font-size:12px;font-weight:700;color:#005ca5} .pag-din{overflow:hidden;clear:both;color:transparent;margin:10px 0 10px 25px} .pag-din b{-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;color:#fff;background:#65d43b;background:-moz-linear-gradient(top,#88e64f 0,#5ed037 100%);background:-webkit-gradient(linear,0 0,0 100%,from(#88e64f),to(#5ed037));border:1px solid #53a32e;padding:4px 10px;display:inline-block;text-shadow:0 -1px 1px #6acb3c} .pag-din a{padding:5px 10px;display:inline-block;font-weight:700;border:1px solid #bbb;color:#555!important;text-shadow:0 1px 0 #eee;background:#e4e4e4;background:-moz-linear-gradient(top,#fcfcfc 0,#eee 100%);background:-webkit-gradient(linear,0 0,0 100%,from(#fcfcfc),to(#eee));-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px} .pag-din a:hover{color:#888!important;text-shadow:0 1px 0 #eee;background:#e4e4e4!important;text-decoration:none;background:-moz-linear-gradient(top,#fcfcfc 0,#ddd 100%)!important;background:-webkit-gradient(linear,0 0,0 100%,from(#fcfcfc),to(#ddd))!important} .solicitud-pago{width:620px;height:auto}.solicitud-pago ul{padding:10px} .solicitud-pago ul li{display:block;margin-bottom:10px;border:1px solid #ccc;padding:15px 10px;color:#00468c;font-weight:600} .input-opc{border:solid 1px #cecece;box-shadow:0 0 1px #d3d3d3;-moz-box-shadow:0 0 1px #d3d3d3;-webkit-box-shadow:0 0 1px #d3d3d3;color:#999;font-weight:700;width:280px;padding:5px 10px;float:right;margin-right:100px;margin-top:-7px;border-radius:2px} .input-opc:hover{box-shadow:0 0 5px 0 #b5dff1;-moz-box-shadow:0 0 5px 0 #b5dff1;-webkit-box-shadow:0 0 5px 0 #b5dff1;border:1px solid #38b2e5} .input-opc:focus{box-shadow:0 0 5px 0 #b5dff1;-moz-box-shadow:0 0 5px 0 #b5dff1;-webkit-box-shadow:0 0 5px 0 #b5dff1;border:1px solid #38b2e5;color:#00a3d9} .recitext{border:solid 1px #cecece;box-shadow:0 0 1px #d3d3d3;-moz-box-shadow:0 0 1px #d3d3d3;-webkit-box-shadow:0 0 1px #d3d3d3;color:#999;font-weight:700;width:280px;padding:5px;margin-right:100px;margin-top:-2px;border-radius:5px;-moz-border-radius:5px;-webkit-border-radius:5px} .recitext:hover{box-shadow:0 0 5px 0 #b5dff1;-moz-box-shadow:0 0 5px 0 #b5dff1;-webkit-box-shadow:0 0 5px 0 #b5dff1;border:1px solid #38b2e5} .recitext:focus{box-shadow:0 0 5px 0 #b5dff1;-moz-box-shadow:0 0 5px 0 #b5dff1;-webkit-box-shadow:0 0 5px 0 #b5dff1;border:1px solid #38b2e5;color:#00a3d9} Y subir esta carpeta https://mega.nz/file/JFp0xIbA#Ogaj1-X2odoYgzULzD_qnJT2Tx4UmPO6mLxMIbpto-Q Creditos: Vellenger
  6. 4 points
  7. 3 points
    Hola a [email protected], os dejo el tema identi actualizado y fixeado a la versión 1.3 Demo En c.cuenta.php --> inc --> class --> c.cuenta.php Buscar: if($data['p_configs']['hits'] == 0){ Arriba agregan: $data['pais'] = array('icon' => strtolower($data['user_pais']),'name' => $tsPaises[$data['user_pais']]); Buscar: , r.r_name, Reemplazar por: , r.r_name, r.r_image, En c.posts.php --> inc --> class --> c.posts.php Buscar: /* lalala */ Arriba agregar: /* Top Categorias*/ function topcat(){ global $tsUser, $tsCore; $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT c.cid, c.c_nombre,c.c_seo, c.c_img, COUNT(p.post_id) AS total, p.post_category FROM p_categorias AS c LEFT JOIN p_posts AS p ON p.post_category = c.cid WHERE post_status = 0 GROUP BY c.c_nombre ORDER BY c.c_nombre ASC'); $data = result_array($query); return $data; } Buscar: // ACTUALES $total = explode(',',$data['pages']['limit']); $data['total'] = ($total[0]) + count($data['data']); // return $data; } Debajo agregar: //TAGS RELEVANTES function getTags() { $limit_tags = 15; $query = db_exec(array(__FILE__, __LINE__), 'query', 'SELECT p.post_tags FROM p_posts AS p LEFT JOIN u_miembros AS u ON p.post_user = u.user_id WHERE p.post_status = \'0\' && u.user_activo = \'1\' && u.user_baneado = \'0\' ORDER BY RAND() LIMIT '.$limit_tags); $data = result_array($query); // foreach($data as $i => $val) { $tags = explode(',', $val['post_tags']); $data[$i]['name'] = $tags[rand(0, count($tags))]; $data[$i]['size'] = rand(1,5); } return $data; } En posts.php --> inc --> php --> posts.php Buscar: // DO <= PARA EL MENU $smarty->assign("tsDo",$_GET['do']); Debajo agregar: $smarty->assign("tsTopcat",$tsPosts->topcat()); Buscar: $smarty->assign("tsStats",$tsTops->getStats()); Debajo agregar: // TAGS RELEVANTES $smarty->assign("tsTags",$tsPosts->getTags()); Instalación de las comunidades Editar solo los archivos de la carpeta inc y ejecutar las consultas de las comunidades, lo demás ya lo tiene instalado, también dejo los archivos ya editados de esa carpeta de la última versión de Risus (1.3), solo tendrías que subir la carpeta y ejecutar las consultas y ya lo tienes instalado. Si tu web esta funcionando y tienes mods instalados no puedes sustituir los archivos por la carpeta que dejo, tienes que instalarlo manualmente, si la sustituyes y tienes mods instalado o modificaciones te van a dejar de funcionar, tendrías que volver a instalar esas modificaciones. Tutorial Instalación carpeta inc comunidades Identi 1.3 https://mega.nz/file/MEJgQD6S#otA_iirrgDVuTPv4Ss0LAyNd-WrMuvuIvrf_ZaawF2g Carpeta inc archivos comunidades https://mega.nz/file/RURSFJLR#3eazqgCv73P2jCNpeOwwtn01qANLkKkcrBJnPl2B6fw Archivos de la carpeta inc ya editados (Versión 1.3) https://mega.nz/file/0MZASTyA#gY2HMN4-k9B-yqU3yuJtvZnQ8rLFeBZuyWJfuVXodJM Tema Identi (Act/Fix 1.3), se instala con el nombre de identi https://mega.nz/file/lNgC3SDA#yca7OyGaCFuxVUCYp_USl0zksNVELHdoZKo-ZRxldD8 Demo
  8. 3 points
    Hola a [email protected], se está desarrollando el diseño de Taringa V7 totalmente actualizado, pueden opinar que cosas u otras funciones les gustaría. Aparte se ha actualizado Risus 1.3 a PHPost cerberus 3.0.0, ya funcionando con PHP 8. Y si necesitan otro tema o mods pueden pedir información en el enlace que dejo. Para más información aquí https://discord.gg/WJe4wDBBqy Demo
  9. 3 points
    Hola, os dejo el tema V6 Dark actualizado y corregido con los errores que se han publicado y otros que he encontrado. Al final de la instalación ejecutar y subir las consultas que están en el archivo, y para que funcione el chat tiene que ir a https://www.tuweb.com/installchat/index.php y darle en instalar. Demo https://pruev6.lucky-forum.com/ Demo 2 https://v621pruebas.lucky-forum.com/ Descargar Mega https://mega.nz/file/xMJhHAyJ#9aeI3Hyt-d...gipH3C3Ofw
  10. 3 points
    Es buena idea, sabiendo lo que está tocando después se hace las cosas solo, puede crear, modificar... con lo que ha aprendido, pero creo que hay que hacerlo en un orden, no enseñarle directamente el script. Si quieres hacerlo aquí yo te ayudo, en mi foro lo tengo creado, e iré añadiendo más tutoriales y manuales. El script lo he actualizado entre un compañero y yo, pronto lo voy a subir aquí y en mi foro.
  11. 3 points
    Hola, aquí tienes algunos multidiomas. https://www.readspeaker.com/ https://ttsreader.com/ https://www.ispeech.org/text.to.speech https://notevibes.com/ https://www.naturalreaders.com/ http://www.fromtexttospeech.com/ https://www.text2speech.org/ https://wideo.co/text-to-speech/
  12. 2 points
    Muy pronto podrán recibir recompensas en cryptomonedas por acciones en el foro.. a estar atentos!!
  13. 2 points
    le voy a contar la historia de los script clon taringa con el tiempo ya con el script voxed la historia es diferente..... primer script clon taringa fue el que creo miguelitox que fue el script tripiante de ahí sale la web que fue conocida como competencia de taringa llamada casita web, si pudieron descargar el script de casita web se van a dar cuenta que el desarrollador del script es miguelitox, porque muestra los crédito, después de ese script vino otro un clon de taringa que estaba bastante bien llamado zinfinal era un script que tiene un shell que nunca nadie lo pudo fixear que te hackean la web, el foro se llamaba tambien zinfinal y el administrador era harold pacha.... depues vino el script spirate, según el que lo libero al script lo había comprado y como no tuvo éxito en las venta lo libero y creo el foro de spirate creo que el administrador de ese foro era un tal rancitis, luego vino phpost donde el administrador era jnetrune que en su apodo también se lo conocia como el conejo, me acuerdo que jnetrune había hecho un script que te pasaba la base del script spirate a la de phpost, cosa que a lo del foro spirate no le gusto nada la idea..... después de todo esto vino lo ultimo que es el script de voxed, una web que no tiene nada que ver con taringa donde ni si quiera necesitas registrarte y todo se hace anonimamente... el script que se libero para hacer este tipo de web se llama rozed.. la instalacion no es la conocida por php ya que esta programado como los programa de computadoras en programacion en C
  14. 2 points
    Hola a [email protected], como dije en otro tema se estaba desarrollando la V7 (PHP 8.0.3), pues entre esta tarde noche o mañana la vamos a liberar, se ha subido en una nueva demo y podéis probar su funcionamiento, dejo también un video. Y nada, esperamos que todo vaya bien. Saludos. Video https://www.youtube.com/watch?v=2IfxbvfHXUE Demos https://newluckies.com/ https://cerberus.phpost.es/
  15. 2 points
    Hola, Camila, lo acabo de crear con imágenes y en la vista previa y publicando lo hace sin problemas y rápido, es mucho tiempo el que dices que tardas en publicar tu un post. Prueba en crear un post en la demo con imágenes que no sean xxx. https://cerberus.phpost.es/posts/imagenes/16/Wallpapers.html
  16. 2 points
    Hola, te mando MP. Nota: Que yo sepa aquí la que se ha compartido es la V6, V7 no se ha compartido, y el tema que te voy hacer es desde cero sin usar nada de la V6, código nuevo.
  17. 2 points
    Nos estas trolleando?, espero que si, porque si no, no es normal lo tuyo. Yo me juego lo que sea, que hay una calle con un cartel de precaución no pasar que hay un pozo y tú eres el único que se cae en el pozo. Esta es la última versión que dices que es un desastre, pero se sabe muy bien quien es el desastre, pruébala y comenta aquí porque crees que a esa le funciona lo que dices. https://risuspruebas.lucky-forum.com/
  18. 2 points
    Hola amigos, me percate que los comentarios de los post no se pueden editar, les dejo un pequeño fix por si les molesta este problema. Vamos a funciones.js ubicado en themes/default/js y buscamos: var text = textarea.bbcode(); Lo reemplazamos con esto: var text = (type == 'new') ? textarea.bbcode() : textarea.val(); Listo, ahora podremos editar comentarios, espero les funciones. Saludos
  19. 2 points
    Hola, que versión de PHP tienes en tu hosting? Los errores que tienes son por la versión de jQuery. Haz una instalación nueva, pero con este script, es el mismo que el de aquí, pero actualizado, borra todos los archivos que has subido y deja la base de datos limpia antes de hacer de nuevo la instalación. Revisa también el certificado ssl. Si sigues con problemas después de hacer eso, si quieres me pasas los datos por MP y te lo instalo. Demo Descarga
  20. 2 points
    Hola, Lelo, bienvenido al foro, cualquier duda o lo que sea lo comentas que seguro que habrá alguien para ayudarte. Saludos.
  21. 2 points
    Hola enzom, perdona por tardar en contestar, en mi foro te he respondido, copio el mensaje y lo publico aquí. Hola @"enzom" , el error es que te falta ejecutar las consultas, para ese error tendrías que ejecutar esta consulta en tu base de datos ALTER TABLE u_muro ADD p_favoritos int(4) NOT NULL; En el archivo que te descargas hay una carpeta que te dice ejecutar estas consultas después de la instalación El archivo comunidades sql lo subes desde la pestaña importar y las consultas Taringa V6 abres el archivo y tienes que ejecutar una por una en la pestaña SQL Estas son las consultas que estan dentro del archivo TaringaV6 ALTER TABLE u_muro ADD p_favoritos int(4) NOT NULL; ALTER TABLE u_muro ADD p_compa ENUM( '0', '1' ) NOT NULL DEFAULT '0'; ALTER TABLE u_muro ADD p_user_shared int(4) NOT NULL; ALTER TABLE u_muro ADD p_shared int(4) NOT NULL; ALTER TABLE u_muro_likes ADD like_fecha varchar(35) NOT NULL; ALTER TABLE u_muro ADD p_privacidad int(1) NOT NULL DEFAULT '0'; ALTER TABLE `p_comentarios` ADD `c_resp` INT( 11 ) NOT NULL DEFAULT '0'; ALTER TABLE p_posts ADD post_portada text NOT NULL; ALTER TABLE p_borradores ADD b_portada text NOT NULL; ALTER TABLE `u_miembros` ADD `user_vips` INT( 1 ) NOT NULL DEFAULT '0'; Haciendo eso te tiene que desaparecer ese error y dejarte publicar bien videos, imágenes... prueba en hacer eso y cualquier cosa me lo comentas. Aquí en la demo lo puedes probar https://pruev6.lucky-forum.com/
  22. 2 points
  23. 2 points
    Jajajaja, ojalá fuera una maquina, no funciona el migrador y lo hago todo manual y escrito para aprender y practicar, tardo un montón en actualizarlo si es muy grande el mod o el tema y después probarlo. Tengo actualizado hasta el tema TARINGRA, le he creado un instalador para que se instale desde cero como el script risus, ya lo tengo en un subdominio subido probándolo, le voy a arreglar los sitios que necesitan interacción que no los veo en localhost y cuando todo este bien la comparto. Gracias y un saludo.
  24. 2 points
  25. 2 points
    esta bueno el mod men, que buen aporte +1
  • Patrocinador



    ×