Užití PHP v kanceláři - generování sťítků

V tomto článku si popíšeme, jak je možné v PHP vytvořit generování štítků pro export zboží.

14.5.2013 20:00 | Josef Candiess Ryzí | přečteno 6338×

Jmenuji se Jan Novák, a jsem průměrně pracovitou osobou v kanceláři pana Flaminga v Olomouci. Mou výhodou je, že skvěle ovládám PHP a znám spousty knihoven pro kancelářské využití. Když za mnou dnes odpoledne přišel pan Flaming, a požádal mě, abych do 24h připravil štítky k exportu zboží, šel jsem na to po svém, pomocí PHP. Pojďte se se mnou podívat, jak jsem si s tím poradil, svou aplikaci jsem rozdělil do několika bodů :

Pro ještě náročnější uživatele doporučuji navštívit stránku mpdf1.com a pročíst si možnosti, které mPDF nabízí. Nyní vám ukážu, jak udělat jednoduchou aplikaci. Tento postup má své mouchy, ale určitě něco do sebe. Není totiž nic hezčího, než si lehce pozměnit konfiguraci místo dvou hodin rýpaní v kódu a hledat chybu. Pro psaní tohoto skriptu budeme potřebovat mPDF knihovnu, kterou stáhnete zde.

Krok 1 - Konfigurace dokumentu

(doporučuji dělat v kódování UTF-8)
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
<?php
// Nejdříve si rozvrhneme, co a jak vlastně chceme tisknout.
// Ve většině případů se bude jednat o štítky na A4, tomu zasvětíme první část konfigurace.
 
$page_w = 210; // šířka A4 v mm
$page_h = 297; // výška A4 v mm
 
// Dále si rozvrhneme štítkovací papír, kolik na kolik.
 
$cols = 4; // počet sloupců
$rows = 10; //počet řádků
$tags_on_page = $cols*$rows; // výsledný počet štítků na stránce
 
// A zajistíme si rozměry štítku.
 
$tag_w = ($page_w/$cols)."mm"; // výsledná šířka štítku
$tag_h = ($page_h/$rows)."mm"; // výsledná výška štítku
$tags = array(); // prázdné pole štítků
 
// Abychom si zajistili naprostou nadvládu nad naším dokumentem, musíme si nastavit i je.
 
$html = "
<style>
body {
font-size: 11px;
text-align: center;
}
</style>
"; // nastavíme si HTML dokument
 
?>

Krok 2 - Tvorba štítku

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
<?php
 
// Musíme štítkům nastavit pevné rozměry.
 
$tag_style = "
width: $tag_w;
height: $tag_h;
float: left;
";
 
// A vytvoříme štítek.
 
$tag_body = "
<div style=".$tag_style.">
<b>Moje firma</b> <br>
Tel.: +420 777 777 777 <br>
IČO: 22233444 <br>
ČP, město, PSČ <br>
www.firma.cz
</div>
";
 
//A vložíme všechny štítky do pole.
 
for($i=1; $i <= $tags_on_page; $i++) {
$tags[] = $tag_body;
}
 
?>

Krok 3 – Export do PDF

1
2
3
4
5
6
7
8
9
10
<?php
 
$html .= implode("", $tags); // spojíme štítky s tělem dokumentu
 
require "mpdf.php"; // zavoláme knihovnu
$mpdf = new mPDF('','',0,'',0,0,0,0,0,0,'L'); // nastavíme PDF dokument
$mpdf->WriteHTML($html); // načteme dokument do mPDF
$mpdf->Output(); // a zavoláme výstup
 
?>

A výsledek?

Tato ukázka je úpouze demonstrace efektivního využití takového nástroje. Chybové ošetření si každý zřídí dle implementování do svého projektu. Za obrovskou výhodu považuji například to, že si takto můžete vyexportovat téměř jakýkoliv druh štítku s jakýmkoliv obsahem. Zdá se to jako samozřejmost, ale je spousta programů, které toto neumožňují a nebo vám tam hodí vodoznak, či jinak zamezí účelu výsledného dokumentu.

Pokud vás tento výsledek neuspokojuje, můžeme si naší mini-aplikaci rozšířit třeba o možnost vícestránkového exportu. To zajišťuje metoda AddPage(), takže tady se meze nekladou. Stačí přihodit podmínku, která nám zjistí, jestli počet štítku je větší, než počet štítku, které se vejdou na jednu stranu.

1
2
3
4
5
6
7
8
<?php
 
$tags_config = 60;
if($tags_config > $tags_on_page) {
$mpdf->AddPage();
}
 
?>
Pro ještě náročnější uživatele doporučuji navštívit stránku mpdf1.com a pročíst si možnosti, které mPDF nabízí.
Soubory ke stažení:
Online verze článku: http://www.linuxsoft.cz/article.php?id_article=1976