Please enable JavaScript!
Bitte aktiviere JavaScript!
S'il vous plaît activer JavaScript!
Por favor,activa el JavaScript!
antiblock.org

 |  |  | 
Anda ingin membuat website?
Untuk Anda yang sedang mencari orang untuk jasa pembuatan website, Saya akan bantu buatkan aplikasi sesuai kebutuhan Anda. Segera hubungi : mail@rizaldimaulidia.com. Selengkapnya tentang profil saya klik www.rizaldimaulidia.com.

PHP Tips and Trick

Cara Membuat Laporan PDF Plus Filter Tanggal dengan PHP dan MySQL

img-responsive

Pada saat membuat sebuah laporan, sering kali kita diharuskan untuk memfilter data yang akan di tampilkan pada laporan tersebut. Sebagai contoh pada data transaksi penjualanan, biasanya kita akan diminta untuk membuat laporan per hari, per bulan dan per tahun. Itulah kenapa kita memerlukan fitur untuk memfilter data-data transaksi tadi agar bisa di tampilkan per hari / per bulan / per tahun sesuai dengan kebutuhan si pengguna.

Dalam tutorial / catatan ini kita akan bahas cara membuat laporan pdf dengan ditambah filter data Per Hari, Per Bulan dan Per tahun. Mari simak langkah-langkah dan penjelasannya berikut ini.


DEMO
Sebelum masuk ke tutorialnya. Mungkin ada yang mau lihat demonya terlebih dahulu. Silahkan klik link berikut untuk melihat demonya : Lihat Demo.


STEP 1 – PERSIAPAN

Kita akan mempersiapkan terlebih dahulu hal-hal yang diperlukan.

  1. Download Plugin HTML2PDF nya, klik link berikut ini : Download.
  2. Download plugin jQuery, klik link berikut : Download.
  3. Download plugin jQuery-ui, klik link berikut : Download. jQuery-ui ini nantinya kita perlukan untuk datepicker.
  4. Buat sebuah folder baru dengan nama latihan_pdf, lalu simpan di xampp/htdocs/
  5. Buat sebuah folder dengan nama plugin, lalu simpan di xampp/htdocs/latihan_pdf.
  6. Buat sebuah folder dengan nama js, lalu simpan di xampp/htdocs/latihan_pdf.
  7. Ekstrak dan Copy plugin HTML2PDF yang sudah didownload ke dalam folder xampp/htdocs/latihan_pdf/plugin/.
  8. Copy and paste file jquery.min.js yang telah di download tadi ke dalam folder xampp/htdocs/latihan_pdf/js/.
  9. Ekstrak dan Copy plugin jQuery-ui yang sudah didownload ke dalam folder xampp/htdocs/latihan_pdf/plugin/.

STEP 2 – DATABASE

Buat sebuah database dengan nama mynotescode, lalu buat tabel transaksi dengan struktur tabel seperti gambar berikut ini :

Struktur Tabel - Cara Membuat Laporan PDF plus Filter Tanggal dengan PHP dan MySQL

CREATE TABLE `transaksi` (
 `id` int(11) NOT NULL,
 `kode` varchar(10) NOT NULL,
 `barang` varchar(100) NOT NULL,
 `jumlah` int(11) NOT NULL,
 `total_harga` double NOT NULL,
 `tgl` datetime NOT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

STEP 3 – KONEKSI DATABASE

Pada tahap ini, kita akan membuat sebuah file php yang berfungsi untuk koneksi ke database MySQL. Buat sebuah file dengan nama koneksi.php lalu simpan di folder xampp/htdocs/latihan_pdf/. Berikut ini isi dari file tersebut :

<?php
$host = "localhost"; // Nama hostnya
$user = "root"; // Username
$pass = ""; // Password (Isi jika menggunakan password)
$connect = mysqli_connect($host, $user, $pass, "mynotescode"); // Koneksi ke MySQL
?>


STEP 4 – TAMPILAN AWAL
Selanjutnya kita akan membuat halaman / tampilan awal website kita. Buat sebuah file php dengan nama index.php dan simpan di folder xampp/htdocs/latihan_pdf. Berikut ini kodenya :

View - Cara Membuat Laporan PDF plus Filter Tanggal dengan PHP dan MySQL

<?php
// Load file koneksi.php
include "koneksi.php";
?>

<html>
<head>
    <title>Data Transaksi</title>
    <link rel="stylesheet" href="plugin/jquery-ui/jquery-ui.min.css" /> <!-- Load file css jquery-ui -->
    <script src="js/jquery.min.js"></script> <!-- Load file jquery -->
</head>
<body>
    <h2>Data Transaksi</h2><hr>

    <form method="get" action="">
        <label>Filter Berdasarkan</label><br>
        <select name="filter" id="filter">
            <option value="">Pilih</option>
            <option value="1">Per Tanggal</option>
            <option value="2">Per Bulan</option>
            <option value="3">Per Tahun</option>
        </select>
        <br /><br />

        <div id="form-tanggal">
            <label>Tanggal</label><br>
            <input type="text" name="tanggal" class="input-tanggal" />
            <br /><br />
        </div>

        <div id="form-bulan">
            <label>Bulan</label><br>
            <select name="bulan">
                <option value="">Pilih</option>
                <option value="1">Januari</option>
                <option value="2">Februari</option>
                <option value="3">Maret</option>
                <option value="4">April</option>
                <option value="5">Mei</option>
                <option value="6">Juni</option>
                <option value="7">Juli</option>
                <option value="8">Agustus</option>
                <option value="9">September</option>
                <option value="10">Oktober</option>
                <option value="11">November</option>
                <option value="12">Desember</option>
            </select>
            <br /><br />
        </div>

        <div id="form-tahun">
            <label>Tahun</label><br>
            <select name="tahun">
                <option value="">Pilih</option>
                <?php
                $query = "SELECT YEAR(tgl) AS tahun FROM transaksi GROUP BY YEAR(tgl)"; // Tampilkan tahun sesuai di tabel transaksi
                $sql = mysqli_query($connect, $query); // Eksekusi/Jalankan query dari variabel $query

                while($data = mysqli_fetch_array($sql)){ // Ambil semua data dari hasil eksekusi $sql
                    echo '<option value="'.$data['tahun'].'">'.$data['tahun'].'</option>';
                }
                ?>
            </select>
            <br /><br />
        </div>

        <button type="submit">Tampilkan</button>
        <a href="index.php">Reset Filter</a>
    </form>
    <hr />

    <?php
    if(isset($_GET['filter']) && ! empty($_GET['filter'])){ // Cek apakah user telah memilih filter dan klik tombol tampilkan
        $filter = $_GET['filter']; // Ambil data filder yang dipilih user

        if($filter == '1'){ // Jika filter nya 1 (per tanggal)
            $tgl = date('d-m-y', strtotime($_GET['tanggal']));

            echo '<b>Data Transaksi Tanggal '.$tgl.'</b><br /><br />';
            echo '<a href="print.php?filter=1&tanggal='.$_GET['tanggal'].'">Cetak PDF</a><br /><br />';

            $query = "SELECT * FROM transaksi WHERE DATE(tgl)='".$_GET['tanggal']."'"; // Tampilkan data transaksi sesuai tanggal yang diinput oleh user pada filter
        }else if($filter == '2'){ // Jika filter nya 2 (per bulan)
            $nama_bulan = array('', 'Januari','Februari','Maret','April','Mei','Juni','Juli','Agustus','September','Oktober','November','Desember');

            echo '<b>Data Transaksi Bulan '.$nama_bulan[$_GET['bulan']].' '.$_GET['tahun'].'</b><br /><br />';
            echo '<a href="print.php?filter=2&bulan='.$_GET['bulan'].'&tahun='.$_GET['tahun'].'">Cetak PDF</a><br /><br />';

            $query = "SELECT * FROM transaksi WHERE MONTH(tgl)='".$_GET['bulan']."' AND YEAR(tgl)='".$_GET['tahun']."'"; // Tampilkan data transaksi sesuai bulan dan tahun yang diinput oleh user pada filter
        }else{ // Jika filter nya 3 (per tahun)
            echo '<b>Data Transaksi Tahun '.$_GET['tahun'].'</b><br /><br />';
            echo '<a href="print.php?filter=3&tahun='.$_GET['tahun'].'">Cetak PDF</a><br /><br />';

            $query = "SELECT * FROM transaksi WHERE YEAR(tgl)='".$_GET['tahun']."'"; // Tampilkan data transaksi sesuai tahun yang diinput oleh user pada filter
        }
    }else{ // Jika user tidak mengklik tombol tampilkan
        echo '<b>Semua Data Transaksi</b><br /><br />';
        echo '<a href="print.php">Cetak PDF</a><br /><br />';

        $query = "SELECT * FROM transaksi ORDER BY tgl"; // Tampilkan semua data transaksi diurutkan berdasarkan tanggal
    }
    ?>

    <table border="1" cellpadding="8">
    <tr>
        <th>Tanggal</th>
        <th>Kode Transaksi</th>
        <th>Barang</th>
        <th>Jumlah</th>
        <th>Total Harga</th>
    </tr>

    <?php
    $sql = mysqli_query($connect, $query); // Eksekusi/Jalankan query dari variabel $query
    $row = mysqli_num_rows($sql); // Ambil jumlah data dari hasil eksekusi $sql

    if($row > 0){ // Jika jumlah data lebih dari 0 (Berarti jika data ada)
        while($data = mysqli_fetch_array($sql)){ // Ambil semua data dari hasil eksekusi $sql
            $tgl = date('d-m-Y', strtotime($data['tgl'])); // Ubah format tanggal jadi dd-mm-yyyy

            echo "<tr>";
            echo "<td>".$tgl."</td>";
            echo "<td>".$data['kode']."</td>";
            echo "<td>".$data['barang']."</td>";
            echo "<td>".$data['jumlah']."</td>";
            echo "<td>".$data['total_harga']."</td>";
            echo "</tr>";
        }
    }else{ // Jika data tidak ada
        echo "<tr><td colspan='5'>Data tidak ada</td></tr>";
    }
    ?>
    </table>

    <script>
    $(document).ready(function(){ // Ketika halaman selesai di load
        $('.input-tanggal').datepicker({
            dateFormat: 'yy-mm-dd' // Set format tanggalnya jadi yyyy-mm-dd
        });

        $('#form-tanggal, #form-bulan, #form-tahun').hide(); // Sebagai default kita sembunyikan form filter tanggal, bulan & tahunnya

        $('#filter').change(function(){ // Ketika user memilih filter
            if($(this).val() == '1'){ // Jika filter nya 1 (per tanggal)
                $('#form-bulan, #form-tahun').hide(); // Sembunyikan form bulan dan tahun
                $('#form-tanggal').show(); // Tampilkan form tanggal
            }else if($(this).val() == '2'){ // Jika filter nya 2 (per bulan)
                $('#form-tanggal').hide(); // Sembunyikan form tanggal
                $('#form-bulan, #form-tahun').show(); // Tampilkan form bulan dan tahun
            }else{ // Jika filternya 3 (per tahun)
                $('#form-tanggal, #form-bulan').hide(); // Sembunyikan form tanggal dan bulan
                $('#form-tahun').show(); // Tampilkan form tahun
            }

            $('#form-tanggal input, #form-bulan select, #form-tahun select').val(''); // Clear data pada textbox tanggal, combobox bulan & tahun
        })
    })
    </script>
    <script src="plugin/jquery-ui/jquery-ui.min.js"></script> <!-- Load file plugin js jquery-ui -->
</body>
</html>

Pada halaman ini, kita membuat sebuah form untuk filter data transaksinya. Dimana isi dari combo box filter adalah Per Tanggal, Per Bulan dan Per Tahun. Khusus untuk combo box Tahun, kita isi sesuai dengan data transaksi yang ada didatbase. Jadi nanti pilihan tahunnya menyesuaikan dengan data transaksi di database ada pada tahun berapa saja.

$tgl = date(‘d-m-y‘, strtotime($_GET[‘tanggal’]));
Kode ini untuk mengubah format tanggal menjadi dd-mm-yyyy. Disini terdapat 2 fungsi yakni date() dan strtotime(). Fungsi date berfungsi untuk menentukan format waktu yang kita ingin kan, isi dari parameter 1 adalah format yang kita inginkan, disini kita isi dengan d-m-y. Lebih lengkapnya soal isi dari parameter 1 di fungsi date() bisa anda lihat disini : Dokumentasi Fungsi Date(). Untuk strtotime() adalah sebuah kode yang berguna untuk mengubah string menjadi time. Karna paramater 2 dari fungsi date() adalah waktu yang akan diubah formatnya (dalam bentuk time). Sehingga disini kita akan mengubah data tanggal dari form filter yang formatnya yyyy-mm-dd dan tipenya string menjadi tipe time agar bisa di ubah formatnya dengan fungsi date().

$nama_bulan = array(”, ‘Januari’,’Februari’,…..
Kode ini akan kita gunakan untuk mengubah data bulan dari form filter manjadi nama bulan itu sendiri dalam bahasa indonesia. Bisa di lihat pada form filter untuk combo box bulan, disitu ada tag option dimana isinya adalah angka dimulai dari 1 untuk januari, 2 untuk februari, dan seterusnya. Nah angka dari value tadi akan kita ubah menjadi nama bulan sesuai dengan value nya dan kita panggil pada variabel $nama_bulan[value_bulannya]. Untuk informasi, index array dimulai dari 0, sehingga bisa kita lihat pada variabel $nama_bulan isi array pertama sengaja saya kosongkan karna index 0 tidak kita pakai soalnya bulan januari dimulai dari 1.

$sql = mysqli_query($connect, $query);
Untuk mengeksekusi / menjalankan query sql. struktur dasar penulisannya adalah sebagai berikut :

mysqli_query($connect, $query);

/*
Keterangan :
- $connect : diisi dengan koneksi ke mysql. hasil dari mysqli_connect
- $query : diisi dengan Query SQL yang diinginkan
*/

mysqli_num_rows($sql);
Untuk mengambil jumlah data dari hasil eksekusi suatu query sql. Struktur dasar penulisannya adalah sebagai berikut :

mysqli_num_rows($sql);

/*
Keterangan :
- $sql : diisi dengan hasil eksekusi query sql(mysql_query())
*/

mysqli_fetch_array($sql);
Untuk mengambil data dari hasil eksekusi suatu query sql. Struktur dasar penulisannya adalah sebagai berikut :

mysqli_fetch_array($sql);

/*
Keterangan :
- $sql : diisi dengan hasil eksekusi query sql(mysql_query())
*/

Kode diatas saya simpan didalam looping while berfungsi untuk melakukan proses perulangan sampai data terkahir dengan tujuan agar kita bisa menampilkan datanya satu per satu.

echo "<td>".$data['kode']."</td>";
echo "<td>".$data['barang']."</td>";
echo "<td>".$data['jumlah']."</td>";
echo "<td>".$data['total_harga']."</td>";

Pada kode diatas terdapat variabel $data digunakan untuk mengambil isi dari field-field yang ada pada tabel transaksi di database latihan. Pada kode diatas juga ada kode yang berada di dalam tanda [‘…..’], kode tersebut harus sama dengan nama field yang ada pada tabel transaksi.


STEP 5 – PROSES CETAK (PRINT)
Sesuai judul dari step 5 ini, kita akan masuk ke inti dari catatan ini yakni membuat proses cetak ke file pdf. Pertama-tama buat dulu sebuah file baru dan beri nama print.php, lalu simpan file tersebut di folder xampp/htdocs/latihan_pdf/. Berikut ini isi / skrip dari file tersebut :

<?php ob_start(); ?>
<html>
<head>
  <title>Cetak PDF</title>
  <style>
    table {
      border-collapse:collapse;
      table-layout:fixed;width: 630px;
    }
    table td {
      word-wrap:break-word;
      width: 20%;
    }
  </style>
</head>
<body>
  <?php
  // Load file koneksi.php
  include "koneksi.php";

  if(isset($_GET['filter']) && ! empty($_GET['filter'])){ // Cek apakah user telah memilih filter
    $filter = $_GET['filter']; // Ambil data filder yang dipilih user

    if($filter == '1'){ // Jika filter nya 1 (per tanggal)
      $tgl = date('d-m-y', strtotime($_GET['tanggal']));

      echo '<b>Data Transaksi Tanggal '.$tgl.'</b><br /><br />';

      $query = "SELECT * FROM transaksi WHERE DATE(tgl)='".$_GET['tanggal']."'"; // Tampilkan data transaksi sesuai tanggal yang diinput oleh user pada filter
    }else if($filter == '2'){ // Jika filter nya 2 (per bulan)
      $nama_bulan = array('', 'Januari','Februari','Maret','April','Mei','Juni','Juli','Agustus','September','Oktober','November','Desember');

      echo '<b>Data Transaksi Bulan '.$nama_bulan[$_GET['bulan']].' '.$_GET['tahun'].'</b><br /><br />';

      $query = "SELECT * FROM transaksi WHERE MONTH(tgl)='".$_GET['bulan']."' AND YEAR(tgl)='".$_GET['tahun']."'"; // Tampilkan data transaksi sesuai bulan dan tahun yang diinput oleh user pada filter
    }else{ // Jika filter nya 3 (per tahun)
      echo '<b>Data Transaksi Tahun '.$_GET['tahun'].'</b><br /><br />';

      $query = "SELECT * FROM transaksi WHERE YEAR(tgl)='".$_GET['tahun']."'"; // Tampilkan data transaksi sesuai tahun yang diinput oleh user pada filter
    }
  }else{ // Jika user tidak memilih filter
    echo '<b>Semua Data Transaksi</b><br /><br />';

    $query = "SELECT * FROM transaksi ORDER BY tgl"; // Tampilkan semua data transaksi diurutkan berdasarkan tanggal
  }
  ?>
  <table border="1" cellpadding="8">
  <tr>
    <th>Tanggal</th>
    <th>Kode Transaksi</th>
    <th>Barang</th>
    <th>Jumlah</th>
    <th>Total Harga</th>
  </tr>

  <?php
  $sql = mysqli_query($connect, $query); // Eksekusi/Jalankan query dari variabel $query
  $row = mysqli_num_rows($sql); // Ambil jumlah data dari hasil eksekusi $sql

  if($row > 0){ // Jika jumlah data lebih dari 0 (Berarti jika data ada)
    while($data = mysqli_fetch_array($sql)){ // Ambil semua data dari hasil eksekusi $sql
      $tgl = date('d-m-Y', strtotime($data['tgl'])); // Ubah format tanggal jadi dd-mm-yyyy

      echo "<tr>";
      echo "<td>".$tgl."</td>";
      echo "<td>".$data['kode']."</td>";
      echo "<td>".$data['barang']."</td>";
      echo "<td>".$data['jumlah']."</td>";
      echo "<td>".$data['total_harga']."</td>";
      echo "</tr>";
    }
  }else{ // Jika data tidak ada
    echo "<tr><td colspan='5'>Data tidak ada</td></tr>";
  }
  ?>
  </table>
</body>
</html>
<?php
$html = ob_get_contents();
ob_end_clean();

require 'plugin/html2pdf/autoload.php';
$pdf = new Spipu\Html2Pdf\Html2Pdf('P','A4','en');
$pdf->WriteHTML($html);
$pdf->Output('Data Transaksi.pdf', 'D');
?>

 

Sebenarnya skrip diatas hampir sama dengan isi dari file index.php. Hanya saja pada print.php tidak ada link cetak pdf nya dan juga pada skrip diatas terdapat skrip berikut ini :

<?php ob_start(); ?>
// …..
// skrip html
// …..
<?php
$html = ob_get_contents();
ob_end_clean();

Pada skrip print.php, Skrip yang berfungsi untuk menampilkan data transaksi pada tabel diapit oleh skrip yang saya beri tanda merah. Skrip tersebut berfungsi untuk mengambil tampilan tabel data transaksi dan memasukkannya ke dalam variabel $html. Variabel $html ini akan digunakan sebagai output yang kita inginkan pada file pdfnya. Lihat skrip berikut ini :

require ‘html2pdf/autoload.php’;
$pdf = new Spipu\Html2Pdf\Html2Pdf(‘P’,’A4′,’en’);
$pdf->WriteHTML($html);
$pdf->Output(‘Data Transaksi.pdf’, ‘D’);

Skrip diatas digunakan untuk mengkonversi skrip html menjadi pdf. Dimulai dari skrip require ‘html2pdf/autoload.php’;, skrip ini berfungsi untuk memuat (meload) plugin html2pdfnya. Lalu skrip $pdf = new Spipu\Html2Pdf\Html2Pdf(‘P’,’A4′,’en’);, skrip ini berfungsi memanggil fungsi __construct pada plugin html2pdf. Berikut ini adalah fungsi __construct yang kita panggil pada plugin html2pdfnya :

/**
* Constructeur
*
* @param string $sens - orientasinya : landscape atau portrait
* @param string $format - format kertasnya : A4, A5, dan lain-lain
* @param string $langue - Bahasanya : en, fr, dan lain-lain
* @param boolean $unicode - TRUE means clustering the input text IS unicode (default = true)
* @param String $encoding - charset encoding; Default is UTF-8
* @param array $marges - margins by default, in order (left, top, right, bottom)
* @return null
*/
public function __construct($sens = 'P', $format = 'A4', $langue='en', $unicode=true, $encoding='UTF-8', $marges = array(5, 5, 5, 8))

Lalu skrip $pdf->WriteHTML($html);, skrip ini berfungsi untuk menentukan apa yang ingin ditampilkan pada pdfnya. Struktur dasar penulisannya yaitu $pdf->WriteHTML(‘kode_htmlnya’);. Pada kasus ini, kita memasukan kode htmlnya kedalam variabel $html. Yang terakhir skrip $pdf->Output(‘Data Transaksi.pdf’, ‘D’);, kode tersebut berfungsi untuk menentukan nama file pdf yang kita buat. dan juga untuk menentukan mode apa yang ingin dilakukan ketika skrip tersebut dipanggil. Contohnya disitu ada skrip …,’D’);, Huruf D disitu berarti ketika skrip dipanggil, maka lakukan proses download pada file pdfnya. sebenarnya ada banyak mode yang bisa kita lakukan, seperti tampilkan pdfnya dibrowser ketika skrip itu dipanggil dan lain-lain (untuk lebih detailnya, ).


Mungkin sekian untuk catatan kali ini. Semoga bisa bermanfaat. Jika ada yang kurang dipahami, langsung tanyakan pada form komentar dibawah ini. Jangan lupa LIKE dan SHARE nya, Terimakasih banyak.

Happy Coding ^_^


SOURCE CODE
Untuk mengunduh source code nya, klik salah satu link dibawah ini
– Download versi MySQLi : Link download yang sesuai tutorial ini yakni menggunakan fungsi MySQLi untuk query ke databasenya
– Download versi PDO : Link download untuk Anda yang ingin source code versi PDO dari tutorial ini


SUMBER & REFERENSI
http://wiki.spipu.net/doku.php?id=html2pdf:en:v4:Accueil
Cara mudah membuat laporan pdf plus filter tanggal bulan tahun dengan php dan mysql, tutorial lengkap membuat laporan pdf dengan filter tanggal bulan tahun menggunakan php dan mysql, laporan pdf plus filter per hari, per bulan, per tahun denagn php dan database mysql

Laporan PDF

(Total : 35,680 viewers, 2 viewers today)
laporan-pdf-plus-filter-tanggal-php

ABOUT THE AUTHOR

Interested in android programming, long time focused on web development. Visit My Profile Site at www.rizaldimaulidia.com

POST YOUR COMMENTS

Your email address will not be published. Required fields are marked *

Name *

Email *

Website

55 Comments

  1. Suyud dyo

    terima kasih bro tank you alias syukron semoga Allah semakin sayang kepada saudara ku ini

  2. Nave Zen

    Error kyak gini kenapa ya?

    Notice: Trying to access array offset on value of type null in C:\xampp\htdocs\latihan_pdf\plugin\html2pdf\spipu\html2pdf\src\Html2Pdf.php on line 1756

    Fatal error: Uncaught Exception: TCPDF ERROR: Some data has already been output, can’t send PDF file in C:\xampp\htdocs\latihan_pdf\plugin\html2pdf\tecnickcom\tcpdf\tcpdf.php:2950 Stack trace: #0 C:\xampp\htdocs\latihan_pdf\plugin\html2pdf\tecnickcom\tcpdf\tcpdf.php(7676): TCPDF->Error(‘Some data has a…’) #1 C:\xampp\htdocs\latihan_pdf\plugin\html2pdf\spipu\html2pdf\src\Html2Pdf.php(575): TCPDF->Output(‘Data_Transaksi….’, ‘D’) #2 C:\xampp\htdocs\latihan_pdf\print.php(87): Spipu\Html2Pdf\Html2Pdf->output(‘Data Transaksi….’, ‘D’) #3 {main} thrown in C:\xampp\htdocs\latihan_pdf\plugin\html2pdf\tecnickcom\tcpdf\tcpdf.php on line 2950

  3. Arief, ST

    Mau tanya bang : kalau kita mau membuat file PDF yang isinya transaksi dengan tanggal yang sama dalam satu halaman, kemudian halaman berikutnya untuk tanggal yang berbeda pula itu bagaimana scriptnya ya ? (jadi dalam satu file PDF nya terdiri dari banyak halaman yang masing-masing halaman berisi transaksi dengan tanggal yang sama).Terima kasih sebelumnya.

    • mungkin saya kasih tau logicnya aja ya.
      1. om harus tentukan laporan akan di cetak dari tgl berapa sampa tanggal berapa
      2. looping dari start date – end date
      3. di dalam looping, om buat query untuk mengambil datanya per tanggal yg di loop

      lalu gimana caranya buat page halaman berbeda? caranya gunakan tag <page>
      jadi disini om udah ga perlu pake tag <html><head><body>, ke 3 tag itu di hilangkan saja. contoh penggunaan tag <page> :

      <page>
      Ini adalah isi halaman 1
      </page>
      <page>
      ini adalah isi halaman 2
      </page>

      dan seterusnya..
      semoga dapat pencerahan

  4. irvanriz

    mau tanya klo error ini kenapa ya?

    Fatal error: Uncaught Error: Class ‘spipu\Html2Pdf\src\Html2Pdf’ not found in C:\xampp\htdocs\helpdesk-jec\print.php:25 Stack trace: #0 {main} thrown in C:\xampp\htdocs\helpdesk-jec\print.php on line 25

    struktur folder sudah di samakan

    print.php nya itu

    Cetak PDF

    table {
    border-collapse:collapse;
    table-layout:fixed;width: 630px;
    }
    table td {
    word-wrap:break-word;
    width: 20%;
    }

    WriteHTML($html);
    $pdf->Output(‘Data Transaksi.pdf’, ‘D’);
    ?>

    terimakasih

  5. Reza Fahlefi

    Bang gimana caranya kalau menampilkan 3 tabel di database ke dlm bentuk 1 laporan yg sudah di filter ?

  6. Joko Purnomo

    Mas ini saya error di gema “” ; dibagian looping itu semua tr td yang didalem kutip dua pada error apa bener kodingan nya begini mas🙏

  7. Joko purnama

    Bang mana tutornya ya maaf

  8. syarief fauzi

    bang bikin yang excelnya dong dengan filter tanggal 🙂

    • Ashiapp om. waiting list kok. insya allah secepatnya ketika saya ada waktu luang saya buatkan versi excelnya 🙂

  9. syuhada ahmad

    ini errornya dmn ya pak pada saat mau cetak malah muncul ini :
    Warning: require(html2pdf/autoload.php): failed to open stream: No such file or directory in C:\xampp\htdocs\latihan_pdf\print.php on line 83

    Fatal error: require(): Failed opening required ‘html2pdf/autoload.php’ (include_path=’C:\xampp\php\PEAR’) in C:\xampp\htdocs\latihan_pdf\print.php on line 83

    salam,

  10. ZEMI MUSFANDANI

    saya ingin bertanya koding yang saya buat di bawah ini kesalahannya apa ya pak.saya hanya ingin memisahkan laporan/bln.per hari dan pertahun jadi itu saya pisahkan pak .masalahnya nimbul error ini di html2pdf. itu yang bikin saya bingung.
    ini koding yang error yang saya dapatkan pak.
    Fatal error: Uncaught ERROR n°4File : C:\xampp\htdocs\prpenjualan\templetehome\data\dataprint\plugin\html2pdf\_class\parsingHtml.class.phpLine : 119HTML code invalid, the tags are not closed in an orderly fashion.Status : Array ( [0] => page [1] => table ) HTML : …line <b>58</b><br /> <td></td></tr></table> </page>… thrown in C:\xampp\htdocs\prpenjualan\templetehome\data\dataprint\plugin\html2pdf\_class\parsingHtml.class.php on line 119
    mohon bantuannya pak

    • dari errornya “the tags are not closed”. ini artinya ada tag html yang belum di tutup atau diberi close tag om. silahkan periksa kembali dengan teliti kode htmlnya. yang memang membutuhkan close tag harus di kasih close tag

  11. Afif afif

    gan, cara pas nge jadiin pdf, ada kolom total keseluruhan harga dan total keseluruhan jumlah bagaimana ya gan? misalkan dari tgl 01 jan 2019 hingga 31 jan 2019 saya punya total_harga : 25jt, 15jt, 60jt. total keseluruhan harga : 100jt , total jumlah : 50.

    Versi MySqli ya gan

    • sebelum looping while, tambahkan variabel total nya :

      $total = 0;
      while($data = mysqli_fetch_array($sql)){
      $total += $data['totaldaridatabase'];
      }

      echo $total; // Nah ini total keseluruhan

  12. cecep1911

    misalkan saya memasukan nya di dalam sub folder yg sdh ada index nya bagaimana? Cth : D:\xampp\htdocs\pelayanan\pages\room
    …., karena pas saya terapkan ada link yg miss atau tdk tampil, contoh saya pilih 1 aka tampil ke tampilan dashboard….
    Mohon solusi, terima kasih.

    • disesuaikan om link nya. kalau di dalam subfolder ya tinggal arahin “namasubfolder/namafile.php”

  13. lee123221213

    untuk kasus saya tanggal bulan tahunnya muncul semua kenapa ya?

    • coba periksa console browsernya om, kemungkinan ada error pada javascriptnya / file jquerynya belum di load

  14. Muhamad Pandu

    mas file jqury.ui nya salah link,, upload ulang yang asli please

  15. Ardiansyah Rizki

    Bro kalo rekap nya misalnya hari sabtu s.d hari minggu atau yang lain saya merubah bagian mana nya ??
    thx bro sebelum nya

    • mungkin maksudnya filter tanggal nya jadi antara tanggal1 s/d tanggal2 ya?
      Kalau iya bisa dengan modif pada bagian query nya jadi pakai BETWEEN.

      contoh querynya : SELECT * FROM namatabel WHERE field_tgl BETWEEN tgl1 AND tgl2

      tgl1 dan tgl2 diatas itu ngambil dari form pencarian yang di input user

      • Ardiansyah Rizki

        mas saya sudah coba pakek beetwen tapi di table malah tidak tampil apa apa error massage juga ngak ada jadi gimana mas ?

        • Ardiansyah Rizki

          trus btw itu field_tgl apa ya gan ?

          • Ardiansyah Rizki

            ini source code saya gan
            if($filter == '1'){ // Jika filter nya 1 (per tanggal)
            $tgl = date('d-m-y', strtotime($_GET['tanggal']));

            echo '<b>Data Transaksi Tanggal '.$tgl.'</b>';
            echo '<a href="print.php?filter=1&amp;tanggal='.$_GET['tanggal'].'" rel="nofollow">Cetak PDF</a>';

            $query = " SELECT * FROM transaksi WHERE field_tgl BETWEEN tgl1 AND tgl2='".$_GET['tanggal']."'";

          • tanggal yg keduanya mana?
            kan bukannya mau menampilkan data berdasarkan range tanggal? (tanggal1 s/d tanggal2)

          • field_tgl itu maksudnya kolom tgl yg mau dijadikan acuan buat filter nya om. cek database yg om. kalau di tutorial ini field_tgl = tgl pada tabel transaksi

          • Ardiansyah Rizki

            itu tgl1 dan tgl2 gan

          • Ardiansyah Rizki

            yang filter nya di tambahin 1 lagi ya atau gimana ??

          • iyaa kan om nya mau filter berdasarkan 2 tanggal, ya harus di tambah di form filternya juga lalu kirim ke file proses pdf nya

          • Ardiansyah Rizki

            bisa di buatkan query nya gan ?

          • iya masalahnya bukan cuma query saja yang harus di ubah om. tapi pada form juga. lebih baik coba om pahami dulu alur kerja dari tutorial ini. kalau sudah paham pasti bisa menambahkan kasus om.

            Atau kalau mau nunggu nanti saya akan buatkan tutorialnya untuk filter 2 tanggal, karena banyak juga yang bertanya ke saya bagaimana cara buat itu. Tapi saya tidak bisa menjanjikan cepat hehe

          • Ardiansyah Rizki

            ok lah saya tunggu gan yang pakek beetwen soalnya lagi butuh banget sekarang hehe thx u gan btw

  16. JuliaPutri

    Mas, kalo cara mendesign di print.php nya bagaimana yaa ?? Soalnya saya pake bahasa html tdk bisa (muncul error)

  17. umar said naimuddin

    gan untuk mengubah ukuran kertas dimana ya

    • tinggal ubah “A4” jadi ukuran kertas yg diinginkan pada skrip dibawah :

      $pdf = new HTML2PDF('P','A4','en');

  18. Rifqi s.

    Mas kalo bikin perminggu gmana mas? Apa ada contohnya

  19. Tri Hadi

    Senang rasanya bisa berkunjung di situs ini, cukup banyak yang dapat saya pelajari kembangkan terus artikelx gan saya bakal sering2 mampir nih . . . bxk bnget ilmu dsini

    • Alhamdulillah om terimakasih banyak, senang bisa membantu 🙂

      siap pasti akan selalu saya update hehe

  20. Tania Merdiana

    Nice Info buat pemula.
    Mohon maaf sebelumnya Min, izinkan saya share informasi kompetisi. Terima kasih atas perhatiannya.

    Peluang emas untuk kamu yang bergelut di ranah IT!

    Kamu seorang Web Designer? IT Developer? Penulis Konten? Blogger? Memiliki kreativitas mengolah website? Jangan lewatkan kesempatan ini! Kini WarungSSL membuka kompetisi untuk menunjukkan bakat kalian di hadapan publik.

    Websitemu menjadi daya tarik user? Puluhan juta berada di tanganmu!

    Untuk informasi selengkapnya silakan kunjungi link berikut:
    https://goo.gl/VkyZS9

    atau bisa hubungi saya via email: tania.merdiana17@gmail.com

    Terimakasih.

NOTE ARCHIVES