define('FNAME_VARS', 'ordersatz_vars.tex');
define('FNAME_ITEMS', 'ordersatz_items.tex');
define('FAXNUMBER','2002-364');
+define('ERROR_SAFT','joey@finlandia');
+define('ERROR_MAIL','joey@finlandia.infodrom.org');
+
+function is_done($id)
+{
+ global $db;
+
+ $query = sprintf('SELECT count(*) AS count FROM metro_ordersatz WHERE id = %d AND done IS NULL', $id);
+ $sth = $db->query($query);
+ $row = $sth->fetch();
+ return $row['count'] == 0;
+}
function mk_tempdir()
{
system(sprintf("rm -rf %s", $dir));
}
+function latexspecialchars($string)
+{
+ return preg_replace_callback("/([\^\%~\\\\#\$%&_\{\}])/",
+ function($matches) {
+ $map = array(
+ "#"=>"\\#",
+ "$"=>"\\$",
+ "%"=>"\\%",
+ "&"=>"\\&",
+ "~"=>"\\~{}",
+ "_"=>"\\_",
+ "^"=>"\\^{}",
+ "\\"=>"\\textbackslash",
+ "{"=>"\\{",
+ "}"=>"\\}",
+ );
+ return $map[$matches[0]];
+ },
+ $string);
+}
+
function latex_encode($text)
{
- return str_replace(array("\\",'%'),
- array('\\','\%'),
- utf8_decode($text));
+ return latexspecialchars(utf8_decode($text));
}
function ordersatz_archive($id, $title, $filename)
{
global $db;
+ $weekdays = array('Sonntag','Montag','Dienstag','Mittwoch','Donnerstag','Freitag','Samstag');
+
$fname = sprintf("%smasks/%s/%s",
$_SESSION['sys']['basedir'],
MODULE,
fwrite($f, sprintf('\newcommand{\uhrzeit}{%s}'."\n", latex_encode($satz[0]['uhrzeit'])));
$d = explode('-', $satz[0]['datum']);
- fwrite($f, sprintf('\newcommand{\datum}{%d.%d.%d}'."\n", $d[2], $d[1], $d[0]));
+ $time = mktime(10,0,0,$d[1], $d[2], $d[0]);
+ fwrite($f, sprintf('\newcommand{\datum}{%s, %d.%d.%d}'."\n", $weekdays[date('w', $time)], $d[2], $d[1], $d[0]));
fclose($f);
- $sql = sprintf("SELECT artnr,gang,metro_vpe.short AS vpname,menge,bezeichnung,hersteller,anzahl " .
+ $sql = sprintf("SELECT artnr,gang,metro_vpe.short AS vpname,menge,bezeichnung,hinweis,hersteller,anzahl " .
"FROM metro_ordersatz_pos " .
"JOIN metro_artikel ON artikel = metro_artikel.id " .
"JOIN metro_abteilung ON abteilung = metro_abteilung.id " .
"JOIN metro_vpe ON vpe = metro_vpe.id " .
"WHERE ordersatz = %d AND anzahl IS NOT NULL " .
- "ORDER BY gang,metro_abteilung.name",
+ "ORDER BY sort,gang,menge,bezeichnung",
$id);
$result = query_db($sql);
$f = fopen(FNAME_ITEMS, 'w');
- foreach ($result as $row) {
- $bez = $row['bezeichnung'];
+ $i = -1;
+ while (++$i < count($result)) {
+ $row = $result[$i];
+
+ $bez = latex_encode($row['bezeichnung']);
+ if (strlen($row['menge']))
+ $bez = latex_encode($row['menge']) . ' ' . $bez;
if (strlen($row['hersteller']))
- $bez .= ' (' . $row['hersteller'] . ')';
+ $bez .= ' (' . latex_encode($row['hersteller']) . ')';
+ if (strlen($row['hinweis']))
+ $bez .= sprintf("\\newline\\textbf{%s}", latex_encode($row['hinweis']));
- fwrite($f, sprintf('\order{%d}{%d}{%s %s}{%s}'."\n",
+ fwrite($f, sprintf('\order%s{%d}{%s}{%s}{%s}{%s}'."\n",
+ ($i+1 < count($result) && $result[$i+1]['gang'] != $row['gang']) ? '[l]' : '',
$row['anzahl'],
- $row['artnr'],
- $row['menge'],
- latex_encode($bez),
- latex_encode($row['vpname'])));
+ ($row['artnr'] && $row['artnr'] != 4711) ? (int)$row['artnr'] : '',
+ $bez,
+ latex_encode($row['vpname']),
+ latex_encode($row['gang'])));
}
fclose($f);
- system("latex ordersatz > ordersatz.out 2>&1 && dvips ordersatz >> ordersatz.out 2>&1 && ps2pdf ordersatz.ps", $ret);
+ system("latex ordersatz > ordersatz.out 2>&1 && dvips ordersatz >> ordersatz.out 2>&1 && pdflatex ordersatz >> ordersatz.out", $ret);
- if ($ret !== 0)
+ if ($ret !== 0) {
+ $fname = sprintf("ordersatz-%d-%d.tar.bz2", $id, time());
+ $cmd = sprintf("tar cfj %s ordersatz.tex ordersatz_vars.tex ordersatz_items.tex ordersatz.out && " .
+ "mpack -s 'Probleme beim Compilieren des Ordersatzes %d' -d ordersatz.out %s %s && " .
+ "sendfile -Q -c='Probleme beim Compilieren des Ordersatzes %d' %s %s",
+ $fname,
+ $id, $fname, ERROR_MAIL,
+ $id, $fname, ERROR_SAFT);
+ system($cmd);
return "Probleme beim Compilieren des Ordersatzes";
+ }
if (!file_exists('ordersatz.ps'))
return "Postscript-Datei nicht erstellt";
'ordersatz.ps');
system($cmd);
- $message = sprintf("Hallo %s!\n\nDer angehängte Ordersatz wurde gerade an Metro Oldenburg verschickt.\n" .
- "Eine Bestätigung über den Versand kommt per Mail.\n\n",
+ $message = utf8_decode(sprintf("Hallo %s!\n\nDer angehängte Ordersatz wurde gerade an Metro Oldenburg verschickt.\n" .
+ "Eine Bestätigung über den Versand kommt per Mail.\n\n",
$satz[0]['koch']);
mail_attach($satz[0]['email'],
- 'Ordersatz ' . $satz[0]['name'],
+ mb_encode_mimeheader('Ordersatz ' . $satz[0]['name'],'latin1'),
$satz[0]['email'],
- 'Infodrom ' . $satz[0]['koch'],
+ mb_encode_mimeheader('Infodrom ' . $satz[0]['koch'],'latin1'),
array($dir . '/ordersatz.pdf'),
$message);
return true;
}
-?>
\ No newline at end of file
+?>