-
Notifications
You must be signed in to change notification settings - Fork 0
/
salvar_pedido.php
86 lines (75 loc) · 3.62 KB
/
salvar_pedido.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<?php
session_start();
if (!isset($_SESSION['id_usuario'])) {
header('location: login.php');
exit();
}
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
$host = 'localhost';
$db = 'essentia';
$user = 'root';
$pass = 'Unida010!';
try {
$conexao = new PDO("mysql:host=$host;dbname=$db;charset=utf8", $user, $pass);
$conexao->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
// Obter dados do formulário
$id_cliente = $_POST['cliente'];
$observacao = $_POST['observacao'];
$subtotal = !empty($_POST['subtotal']) ? str_replace(',', '.', $_POST['subtotal']) : 0.00;
$desconto = !empty($_POST['desconto']) ? str_replace(',', '.', $_POST['desconto']) : 0.00;
$total = !empty($_POST['total']) ? str_replace(',', '.', $_POST['total']) : 0.00;
// Verificar se o cliente existe
$stmt = $conexao->prepare("SELECT COUNT(*) FROM cliente WHERE id_cliente = :id_cliente");
$stmt->bindParam(':id_cliente', $id_cliente);
$stmt->execute();
$clienteExiste = $stmt->fetchColumn();
if (!$clienteExiste) {
$_SESSION['mensagem'] = "Cliente não encontrado.";
header('Location: novo-pedido.php');
exit();
}
// Inserir o pedido na tabela de pedidos
$sql = "INSERT INTO pedidos (id_cliente, observacao, subtotal, desconto, total, id_usuario) VALUES (:id_cliente, :observacao, :subtotal, :desconto, :total, :id_usuario)";
$stmt = $conexao->prepare($sql);
$stmt->bindParam(':id_cliente', $id_cliente);
$stmt->bindParam(':observacao', $observacao);
$stmt->bindParam(':subtotal', $subtotal);
$stmt->bindParam(':desconto', $desconto);
$stmt->bindParam(':total', $total);
$stmt->bindParam(':id_usuario', $_SESSION['id_usuario']);
if ($stmt->execute()) {
$id_pedido = $conexao->lastInsertId(); // ID do pedido inserido
// Inserir produtos do pedido
$produtos = $_POST['produto'];
$quantidades = $_POST['quantidade'];
$valores = $_POST['valor'];
foreach ($produtos as $index => $id_produto) {
$quantidade = $quantidades[$index];
$valor = str_replace(',', '.', $valores[$index]);
$sql_produto = "INSERT INTO pedido_produtos (id_pedido, id_produto, quantidade, valor) VALUES (:id_pedido, :id_produto, :quantidade, :valor)";
$stmt_produto = $conexao->prepare($sql_produto);
$stmt_produto->bindParam(':id_pedido', $id_pedido);
$stmt_produto->bindParam(':id_produto', $id_produto);
$stmt_produto->bindParam(':quantidade', $quantidade);
$stmt_produto->bindParam(':valor', $valor);
$stmt_produto->execute();
$sql_atualiza = "UPDATE produto SET quantidade = quantidade - :quantidade WHERE id_produto = :id_produto";
$stmt_atualiza = $conexao->prepare($sql_atualiza);
$stmt_atualiza->bindParam(':quantidade', $quantidade);
$stmt_atualiza->bindParam(':id_produto', $id_produto);
$stmt_atualiza->execute();
}
$_SESSION['mensagem'] = "Pedido salvo com sucesso!";
header('Location: novo-pedido.php');
exit();
} else {
$_SESSION['mensagem'] = "Erro ao salvar o pedido.";
header('Location: novo-pedido.php');
exit();
}
} catch (PDOException $e) {
$_SESSION['mensagem'] = "Erro: " . $e->getMessage();
header('Location: novo-pedido.php');
exit();
}
}