Ir para conteúdo
Fórum Script Brasil

wash

Membros
  • Total de itens

    404
  • Registro em

  • Última visita

2 Seguidores

Sobre wash

Perfil

  • Gender
    Male
  • Location
    MG
  • Interests
    Telegram: @washalbano

Últimos Visitantes

O bloco dos últimos visitantes está desativado e não está sendo visualizado por outros usuários.

wash's Achievements

0

Reputação

  1. Testei assim e funciou tb: connection.php <?php // defina as variáveis de conexão $config = [ 'db_host' => 'localhost', 'db_user' => 'root', 'db_pass' => 'my-secret-pw', 'db_name' => 'scriptbrasil', ]; // tenta estabelecer conexão: try { $sqli = new mysqli($config['db_host'], $config['db_user'], $config['db_pass']); // define o padrão de caracteres $sqli->set_charset('utf8'); // selecionar/abrir o banco de dados para trabalhar $sqli->select_db($config['db_name']); } catch (Exception $e) { // se não conseguir estabelecer conexão, exibe erro exit('<p><b>Falha na conexão</b>: ' . $e->getMessage() . '</p>'); } return $sqli; database.sql drop schema if exists scriptbrasil; create schema scriptbrasil; use scriptbrasil; -- -- -- create table users( id int(9) AUTO_INCREMENT PRIMARY KEY, username varchar(255), `password` varchar(255), created_at timestamp default current_timestamp ) Engine = InnoDB; -- insert into users(username, `password`) values ( 'user@email.com', '$2y$10$DQMbURH5W/29aw7gA59Rdu9DpC0Vk3Qfzkjc1DcWvN.wtoUXwODiK' ), ( 'admin@email.com', '$2y$10$DQMbURH5W/29aw7gA59Rdu9DpC0Vk3Qfzkjc1DcWvN.wtoUXwODiK' ); -- -- -- create table tasks( id int(9) AUTO_INCREMENT PRIMARY KEY, title varchar(255), description varchar(255), user_id int(9), author varchar(255), start_date datetime, end_date datetime, created_at timestamp default current_timestamp, constraint foreign key(user_id) references users(id) ) Engine = InnoDB; -- insert into tasks(user_id, title, description, author, start_date, end_date) values ( 1, 'Task 1', 'lorem ipsum dolor sit amet', 'Author 1', '2024-01-01 00:00:00', '2025-01-01 00:00:00' ), ( 1, 'Task 2', 'consectetur adipisicing elit', 'Author 2', '2024-08-01 00:00:00', '2025-10-01 00:00:00' ), ( 2, 'Task 3', 'sed do eiusmod tempor incididunt', 'Author 3', '2024-08-30 00:00:00', '2024-09-05 00:00:00' ), ( 2, 'Task 4', 'ut labore et dolore magna aliqua', 'Author 4', '2024-09-02 00:00:00', '2024-09-05 00:00:00' ); index.php <?php session_start(); ?> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Tasks Login</title> <style> label { display: block; } .mb-3 { margin-bottom: 1rem; } .my-3 { margin-top: 1rem; margin-bottom: 1rem; } .text-danger { color: brown; } </style> </head> <body> <div class="container"> <h3>System</h3> <form action="login.php" method="post"> <div class="row"> <div class="col"> <label>Login</label> <input type="email" name="email" required /> </div> <div class="col my-3"> <label>Password</label> <input type="password" name="password" required /> </div> <div class="col text-danger mb-3"> <?php if (isset($_SESSION['flash'])) { echo $_SESSION['flash']; unset($_SESSION['flash']); session_write_close(); } ?> </div> <div class="col"> <button>Login</button> </div> </div> </form> </div> </body> </html> login.php <?php function redirectWithFlash(string $message) { $_SESSION['flash'] = $message; header('Location: ./'); exit(); } if ($_SERVER['REQUEST_METHOD'] == 'POST') { session_start(); // Include database connection $conn = include 'connection.php'; $username = filter_input(INPUT_POST, 'email', FILTER_SANITIZE_EMAIL); $password = filter_input(INPUT_POST, 'password', FILTER_SANITIZE_SPECIAL_CHARS); // Check credentials $query = "SELECT * FROM users WHERE username = '$username'"; $result = $conn->query($query); if (!$result->num_rows) { redirectWithFlash('user not found'); } $user = $result->fetch_assoc(); if (password_verify($password, $user['password'])) { unset($user['password']); $_SESSION['user'] = $user; header('Location: tasks.php'); exit(); } redirectWithFlash('Invalid credentials!'); } header('Location: ./'); exit(); tasks.php <?php // tasks.php session_start(); // check if user is logged in if (!isset($_SESSION['user'])) { header('Location: ./'); exit(); } $conn = include 'connection.php'; // Fetch tasks for the logged-in user $query = 'SELECT * FROM tasks WHERE user_id = ' . $_SESSION['user']['id']; $result = $conn->query($query); $tasks = $result->fetch_all(MYSQLI_ASSOC); ?> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="styles.css"> <title>Task List</title> </head> <body> <h1>Task List</h1> <div class="task-container"> <?php foreach ($tasks as $task) { ?> <div class="task"> <h2><?= $task['title'] ?></h2> <p><?= $task['description'] ?></p> <p>Start: <?= $task['start_date'] ?> | End: <?= $task['end_date'] ?></p> <p>Author: <?= $task['author'] ?></p> <a href="edit_task.php?id=<?= $task['id'] ?>">Edit</a> <a href="delete_task.php?id=<?= $task['id'] ?>">Delete</a> </div> <?php } ?> </div> <a href="new_task.php">Create New Task</a> </body> </html>
  2. A) abra o devtools, e altere o valor do input#pontos para que seja feita a request ajax B) abra a aba network C) clique na requisição D) clique em preview
  3. Boa tarde! Tem que acompanhar pela aba network do devtools
  4. Olá! Não tenho código com novo formato, mas podemos reescrever! Topa colaborar no desenvolvimento?
  5. Quando o seu javascript foi executado o input ainda não existia na DOM tente asssim: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Autofill</title> </head> <body> <input type="text" id="codigo"> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.1/jquery.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.30.1/moment.min.js"></script> <script type="text/javascript"> const agora = moment(); var ano = (agora.format("YYYY")); var dia = (agora.format("DD")); var mes = (agora.format("MM")); var res = (ano + "/" + "sigla" + dia + mes + "_01") $('#codigo').val(res); </script> </body> </html>
  6. Olá! Verifique se seria assim: import { useState } from 'react' function Buttons(props) { return ( <button className="verde" onClick={props.clicar}> verde </button> ) } const imagens = [ 'https://github.com/fernandoleonid/mini-projetos-js/blob/master/02-semaforo/img/desligado.png?raw=true', 'https://github.com/fernandoleonid/mini-projetos-js/blob/master/02-semaforo/img/verde.png?raw=true', 'https://github.com/fernandoleonid/mini-projetos-js/blob/master/02-semaforo/img/vermelho.png?raw=true', 'https://github.com/fernandoleonid/mini-projetos-js/blob/master/02-semaforo/img/amarelo.png?raw=true' ] let timeInterval = () => {} export default function App() { const [imageIndex, setImageIndex] = useState(0) const TrocarImagem = (novaImagem) => { clearInterval(timeInterval) setImageIndex(novaImagem) } const Automatico = () => { console.log('automatico :>> ') timeInterval = setInterval( () => setImageIndex((old) => { const nextImage = old + 1 return nextImage >= imagens.length ? 1 : nextImage }), 1000 ) } return ( <div className="App"> <div style={{ marginTop: '15px' }}> <Buttons clicar={() => TrocarImagem(1)} /> <button onClick={() => TrocarImagem(2)}>vermelho</button> <button onClick={() => TrocarImagem(3)}>amarelo</button> <button onClick={Automatico}>automatico</button> <img src={imagens[imageIndex]} style={{ width: '20%' }} /> </div> </div> ) }
  7. Olá! Segue sugestão. Considerando que sua $string seja um json válido: // decodificar a string como array $phpArray = json_decode($string, true); // data to record $dataToRecord = []; foreach($phpArray['results'] as $v) { // desestrutura as variáveis desejadas ['id' => $id, 'reason' => $reason, 'auto_recurring' => ['transaction_amount' => $transactionAmount]] = $v; // guarda em $dataToRecord $dataToRecord[] = "('$id','$reason',$transactionAmount)"; } // prepara a query de inserção $queryToInsert = 'INSERT INTO plano (id, reason, transaction_amount) VALUES '.implode(', ', $dataToRecord); // exibe na tela var_dump($queryToInsert);
  8. O sr. acompanhou a doc? text-overflow não funciona sozinho. É necessário setar pelo menos outras duas regras css.
  9. Se puder fixar a largura do container do texto, talvez seja possível resolver com text-overflow: https://developer.mozilla.org/pt-BR/docs/Web/CSS/text-overflow https://codepen.io/washalbano/pen/xxMrPLL?editors=1100
  10. Você tem um único elemento a? O conteúdo da modal foi gerado em tempo de execução ou já existia quando a página ficou pronta?
  11. O php é backend (é interpretado/funciona no servidor) Esse tipo de javascript é frontend (é interpretado/funciona no browser) Logo, não faz sentido misturar javascript no meio do php nem criar vários blocos <script></script> Pode-se definir esse trecho javascript uma única vez, depois do html, pois a intenção é que o javascript "rode" depois que todo o html estiver carregado. Costuma-se definir o trecho javascript logo antes de fechar a tag body. Ex.: ... <script src='/assets/app.js'></script> <script> // javascript code here </script> </body> </html>
  12. é mesmo estranho. Sugiro que tente ao máximo deixar o ambiente local tal e qual o ambiente em produção. E tb investigar esses erros e corrigí-los Afinal, eles não são bem vindos em ambiente algum. Mas são erros mesmo ou apenas warnings?
  13. A parte engraçada foi que ele adicionou um sinal de igual e disse que minha sugestão não funciona.
×
×
  • Criar Novo...