121 lines
3.8 KiB
PHP
121 lines
3.8 KiB
PHP
<?php
|
|
// api_kds.php
|
|
header('Content-Type: application/json; charset=utf-8');
|
|
|
|
require_once __DIR__ . '/../config/database.php';
|
|
require_once __DIR__ . '/get_table_name.php';
|
|
|
|
$hashParam = isset($_GET['h']) ? trim($_GET['h']) : '';
|
|
$myTable = getTableNameByHash($conn, $hashParam);
|
|
$myTable = strtolower($myTable);
|
|
|
|
$isKitchen = (isset($_GET['kds_secret']) && $_GET['kds_secret'] === 'karczma_kuchnia');
|
|
|
|
if (empty($myTable) && !$isKitchen) {
|
|
die(json_encode(['status' => 'success', 'count' => 0, 'data' => []]));
|
|
}
|
|
|
|
if (!$conn) {
|
|
die(json_encode([
|
|
'status' => 'error',
|
|
'message' => 'Błąd połączenia z bazą danych.',
|
|
'errors' => sqlsrv_errors()
|
|
]));
|
|
}
|
|
|
|
$tableParam = $myTable;
|
|
|
|
// Zapytanie SQL wyciągające aktywne pozycje (StatusRealizacji < 4)
|
|
// Łączymy NGastroDTRachunekPozycja z NGastroDTRachunek (żeby mieć stolik) i z NGastroTowar (żeby mieć nazwę)
|
|
$tsql = "
|
|
SELECT
|
|
r.StolikID,
|
|
s.Nazwa AS NazwaStolika,
|
|
r.Numer AS NumerRachunku,
|
|
r.Opis,
|
|
r.NumerReczny AS NumerRecznyRachunku,
|
|
rp.ID AS PozycjaID,
|
|
rp.StatusRealizacji,
|
|
rp.Ilosc,
|
|
rp.DataDodania,
|
|
rp.Notatka,
|
|
CASE
|
|
WHEN rp.NazwaDanieOtwarte != '' THEN rp.NazwaDanieOtwarte
|
|
ELSE ISNULL(NULLIF(t.NazwaNaZamowieniu, ''), t.NazwaTowaru)
|
|
END AS NazwaTowaru,
|
|
ISNULL(NULLIF(tz.NazwaNaZamowieniu, ''), tz.NazwaTowaru) AS NazwaZestawu,
|
|
rp.GrupaZestawuID,
|
|
rp.TowarID
|
|
FROM dbo.NGastroDTRachunekPozycja rp
|
|
INNER JOIN dbo.NGastroDTRachunek r ON r.ID = rp.DTRachunekID
|
|
LEFT JOIN dbo.NGastroTowar t ON t.ID = rp.TowarID
|
|
LEFT JOIN dbo.NGastroTowar tz ON tz.ID = rp.ZestawID
|
|
LEFT JOIN dbo.NGastroStolik s ON s.ID = r.StolikID
|
|
LEFT JOIN dbo.NGastroKonfiguracjaDrukowaniaZamowien kdz ON kdz.ID = ISNULL(rp.KonfiguracjaDrukowaniaZamowienID, t.KonfiguracjaDrukowaniaZamowienID)
|
|
WHERE r.Status = 0
|
|
AND rp.StatusRealizacji > 0
|
|
AND rp.StatusRealizacji < 4
|
|
AND kdz.ID IS NOT NULL
|
|
AND CAST(rp.DataDodania AS DATE) = CAST(GETDATE() AS DATE)
|
|
AND rp.DataUsuniecia = '1900-01-01'
|
|
ORDER BY rp.DataDodania ASC
|
|
";
|
|
|
|
$stmt = sqlsrv_query($conn, $tsql);
|
|
|
|
if ($stmt === false) {
|
|
die(json_encode([
|
|
'status' => 'error',
|
|
'message' => 'Błąd podczas wykonywania zapytania SQL.',
|
|
'errors' => sqlsrv_errors()
|
|
]));
|
|
}
|
|
|
|
$pozycje = [];
|
|
while ($row = sqlsrv_fetch_array($stmt, SQLSRV_FETCH_ASSOC)) {
|
|
$stolikNazwa = strtolower($row['NazwaStolika'] ?? '');
|
|
$opis = strtolower($row['Opis'] ?? '');
|
|
|
|
$normalizedTableParam = str_replace('o', '0', $tableParam);
|
|
$normalizedStolikNazwa = str_replace('o', '0', $stolikNazwa);
|
|
$normalizedOpis = str_replace('o', '0', $opis);
|
|
|
|
$isMatched = false;
|
|
if (!$tableParam) {
|
|
$isMatched = true;
|
|
} else {
|
|
$pattern = '/\b' . preg_quote($normalizedTableParam, '/') . '\b/i';
|
|
if (
|
|
$normalizedStolikNazwa === $normalizedTableParam ||
|
|
$normalizedOpis === $normalizedTableParam ||
|
|
preg_match($pattern, $normalizedStolikNazwa) ||
|
|
preg_match($pattern, $normalizedOpis)
|
|
) {
|
|
$isMatched = true;
|
|
}
|
|
}
|
|
|
|
if ($isMatched) {
|
|
if ($row['DataDodania'] instanceof DateTime) {
|
|
$row['DataDodania'] = $row['DataDodania']->format('Y-m-d H:i:s');
|
|
}
|
|
$row['StolikID'] = $row['StolikID'] ? strtoupper($row['StolikID']) : null;
|
|
$row['PozycjaID'] = strtoupper($row['PozycjaID']);
|
|
$row['TowarID'] = strtoupper($row['TowarID']);
|
|
|
|
$pozycje[] = $row;
|
|
}
|
|
}
|
|
|
|
// Zwracamy czysty JSON
|
|
echo json_encode([
|
|
'status' => 'success',
|
|
'count' => count($pozycje),
|
|
'tableName' => strtoupper($myTable),
|
|
'data' => $pozycje
|
|
], JSON_UNESCAPED_UNICODE);
|
|
|
|
sqlsrv_free_stmt($stmt);
|
|
sqlsrv_close($conn);
|
|
?>
|