You are on page 1of 12

/*

* To change this template, choose Tools | Templates


* and open the template in the editor.
*/
package penjualan;
import java.awt.Color;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.sql.*;
import java.util.HashMap;
import java.util.Map;
import javax.swing.JOptionPane;
import javax.swing.table.DefaultTableModel;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.view.JasperViewer;
/**
*
* @author User
*/
public class frmBarang extends javax.swing.JFrame {
Connection con;
ResultSet rs;
Statement stm;
private Object[][] dataTable = null;
private String [] header ={"kode_barang","nama_barang","satuan","harga","sto
k","stok_minimal"};
boolean edit=false;
boolean add=false;
boolean delete=false;

/**
* Creates new form frmBarang
*/
public frmBarang() {
initComponents();
open_db();
disable_button(true);
disable_Text(false);
baca_data();
textVisible();

jdelete.setEnabled(false);
//disable_Text(false);
//disable_button(false);
}
private void open_db(){
try {
Koneksi kon = new Koneksi("localhost", "root", "", "penjualan");
con = kon.getConnection();
}catch(Exception e){
System.out.println("Error : "+e);
}
}
private void disable_button(boolean x){
jadd.setEnabled(x);
jkoreksi.setEnabled(x);
jsave.setEnabled(!x);
jcancel.setEnabled(!x);
}
private void disable_Text (boolean x){
kd_brg.setEnabled(x);
nm_brg.setEnabled(x);
sts.setEnabled(x);
jharga.setEnabled(x);
}
private void tampil_data(){
try{
stm = con.createStatement();
rs = stm.executeQuery("select * from barang where kode_barang='"+kd_brg.
getText()+"'");
rs.beforeFirst();
while (rs.next()){
kd_brg.setText(""+rs.getString("kode_barang"));
nm_brg.setText(""+rs.getString("nama_barang"));
jTextField1.setText(""+rs.getString("satuan"));
jharga.setText(""+rs.getString("harga"));
jstok.setText(""+rs.getString("stok"));
sm.setText(""+rs.getString("stok_minimal"));
}
}catch(Exception e){
JOptionPane.showMessageDialog(null, e);
}
}
private void bersih(){
kd_brg.setText("");
nm_brg.setText("");
jTextField1.setText("");
jharga.setText("");
jstok.setText("");
sm.setText("");
kd_brg.requestFocus();
}
private void textVisible(){
jTextField1.setVisible(false);
}
private void baca_data(){ // Digunakan untuk membaca data yang akan dimasuk
an ke dalam tabel
try{
stm = con.createStatement();
rs = stm.executeQuery("select * from barang");
ResultSetMetaData meta = rs.getMetaData();
int col = meta.getColumnCount();
int baris =0;
while (rs.next()){
baris = rs.getRow();
}
dataTable = new Object[baris][col];
int x=0;
rs.beforeFirst();
while (rs.next()){
dataTable[x][0]= rs.getString("kode_barang");
dataTable[x][1]= rs.getString("nama_barang");
dataTable[x][2]= rs.getString("satuan");
dataTable[x][3]= rs.getString("harga");
dataTable[x][4]= rs.getString("stok");
dataTable[x][5]= rs.getString("stok_minimal");
x++;
}
jTable1.setModel(new DefaultTableModel(dataTable,header));
}catch(Exception e){
JOptionPane.showMessageDialog(null, e);
}
}

private void cetak_barang(){
try{
String path="src/penjualan/report_barang.jasper";
Map parameter = new HashMap();
Class.forName("com.mysql.jdbc.Driver");
Connection con=null;
con = DriverManager.getConnection("jdbc:mysql://localhost:3306/penju
alan","root","");
JasperPrint jasperprint = JasperFillManager.fillReport(path, paramet
er, con);
JasperViewer.viewReport(jasperprint,false);
}catch(Exception e){
JOptionPane.showMessageDialog(null, e);
}
}

/**
* This method is called from within the constructor to initialize the form.
* WARNING: Do NOT modify this code. The content of this method is always
* regenerated by the Form Editor.
*/
@SuppressWarnings("unchecked")
// <editor-fold defaultstate="collapsed" desc="Generated Code">

private void initComponents() {
jLabel1 = new javax.swing.JLabel();
jLabel2 = new javax.swing.JLabel();
jLabel3 = new javax.swing.JLabel();
jLabel4 = new javax.swing.JLabel();
jLabel5 = new javax.swing.JLabel();
jLabel6 = new javax.swing.JLabel();
jLabel7 = new javax.swing.JLabel();
kd_brg = new javax.swing.JTextField();
nm_brg = new javax.swing.JTextField();
jTextField1 = new javax.swing.JTextField();
jharga = new javax.swing.JTextField();
jstok = new javax.swing.JTextField();
sm = new javax.swing.JTextField();
sts = new javax.swing.JComboBox();
jScrollPane1 = new javax.swing.JScrollPane();
jTable1 = new javax.swing.JTable();
jadd = new javax.swing.JButton();
jsave = new javax.swing.JButton();
jkoreksi = new javax.swing.JButton();
jdelete = new javax.swing.JButton();
jexit = new javax.swing.JButton();
jcancel = new javax.swing.JButton();
jprint = new javax.swing.JButton();
setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
jLabel1.setFont(new java.awt.Font("Segoe Script", 0, 18)); // NOI18N
jLabel1.setText("Data Barang");
jLabel2.setText("Kode Barang");
jLabel3.setText("Nama Barang");
jLabel4.setText("Satuan");
jLabel5.setText("Harga");
jLabel6.setText("Stok");
jLabel7.setText("Stok Minimal");
sts.setModel(new javax.swing.DefaultComboBoxModel(new String[] { "Piliha
n", "Liter", "Kg", "Kwintal", "Pack", "Dus", "Lainnya" }));
sts.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
stsActionPerformed(evt);
}
});
jTable1.setModel(new javax.swing.table.DefaultTableModel(
new Object [][] {
{null, null, null, null, null, null},
{null, null, null, null, null, null},
{null, null, null, null, null, null},
{null, null, null, null, null, null}
},
new String [] {
"kode_barang", "nama_barang", "satuan", "harga", "stok", "stok_m
inimal"
}
) {
Class[] types = new Class [] {
java.lang.String.class, java.lang.String.class, java.lang.String
.class, java.lang.String.class, java.lang.String.class, java.lang.String.class
};
public Class getColumnClass(int columnIndex) {
return types [columnIndex];
}
});
jTable1.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
jTable1MouseClicked(evt);
}
});
jScrollPane1.setViewportView(jTable1);
jadd.setText("ADD");
jadd.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jaddActionPerformed(evt);
}
});
jsave.setText("SAVE");
jsave.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jsaveActionPerformed(evt);
}
});
jkoreksi.setText("EDIT");
jkoreksi.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jkoreksiActionPerformed(evt);
}
});
jdelete.setText("DELETE");
jdelete.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jdeleteActionPerformed(evt);
}
});
jexit.setText("EXIT");
jexit.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jexitActionPerformed(evt);
}
});
jcancel.setText("CANCEL");
jcancel.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jcancelActionPerformed(evt);
}
});
jprint.setText("PRINT");
jprint.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jprintActionPerformed(evt);
}
});
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentP
ane());
getContentPane().setLayout(layout);
layout.setHorizontalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING
)
.addGroup(layout.createSequentialGroup()
.addGap(23, 23, 23)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Ali
gnment.LEADING)
.addGroup(layout.createSequentialGroup()
.addComponent(jadd)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addComponent(jsave)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addComponent(jkoreksi)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addComponent(jdelete)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addComponent(jexit)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addComponent(jcancel)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addComponent(jprint)
.addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, S
hort.MAX_VALUE))
.addGroup(layout.createSequentialGroup()
.addGroup(layout.createParallelGroup(javax.swing.GroupLa
yout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addGroup(layout.createParallelGroup(javax.swing
.GroupLayout.Alignment.LEADING)
.addComponent(jLabel7)
.addComponent(jLabel2)
.addComponent(jLabel3))
.addGap(39, 39, 39)
.addGroup(layout.createParallelGroup(javax.swing
.GroupLayout.Alignment.LEADING)
.addGroup(layout.createParallelGroup(javax.s
wing.GroupLayout.Alignment.LEADING, false)
.addGroup(layout.createSequentialGroup()
.addGap(1, 1, 1)
.addComponent(sm))
.addComponent(nm_brg, javax.swing.GroupL
ayout.PREFERRED_SIZE, 90, javax.swing.GroupLayout.PREFERRED_SIZE)
.addComponent(kd_brg, javax.swing.GroupL
ayout.PREFERRED_SIZE, 90, javax.swing.GroupLayout.PREFERRED_SIZE))
.addGroup(layout.createSequentialGroup()
.addGap(1, 1, 1)
.addGroup(layout.createParallelGroup(jav
ax.swing.GroupLayout.Alignment.LEADING)
.addComponent(sts, 0, javax.swing.Gr
oupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
.addComponent(jharga)
.addComponent(jstok)))))
.addGroup(layout.createSequentialGroup()
.addGroup(layout.createParallelGroup(javax.swing
.GroupLayout.Alignment.LEADING)
.addComponent(jLabel1, javax.swing.GroupLayo
ut.PREFERRED_SIZE, 130, javax.swing.GroupLayout.PREFERRED_SIZE)
.addComponent(jLabel4)
.addComponent(jLabel5)
.addComponent(jLabel6))
.addGap(0, 0, Short.MAX_VALUE)))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addComponent(jTextField1, javax.swing.GroupLayout.PREFE
RRED_SIZE, 61, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addComponent(jScrollPane1, javax.swing.GroupLayout.PREF
ERRED_SIZE, 540, javax.swing.GroupLayout.PREFERRED_SIZE)
.addGap(33, 33, 33))))
);
layout.setVerticalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING
)
.addGroup(layout.createSequentialGroup()
.addGap(19, 19, 19)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Ali
gnment.LEADING, false)
.addGroup(layout.createSequentialGroup()
.addComponent(jLabel1, javax.swing.GroupLayout.PREFERRED
_SIZE, 21, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.UNRELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLa
yout.Alignment.BASELINE)
.addComponent(jLabel2)
.addComponent(kd_brg, javax.swing.GroupLayout.PREFER
RED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRE
D_SIZE))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLa
yout.Alignment.BASELINE)
.addComponent(jLabel3)
.addComponent(nm_brg, javax.swing.GroupLayout.PREFER
RED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRE
D_SIZE))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLa
yout.Alignment.BASELINE)
.addComponent(jLabel4)
.addComponent(jTextField1, javax.swing.GroupLayout.P
REFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PRE
FERRED_SIZE)
.addComponent(sts, javax.swing.GroupLayout.PREFERRED
_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_S
IZE))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLa
yout.Alignment.BASELINE)
.addComponent(jLabel5)
.addComponent(jharga, javax.swing.GroupLayout.PREFER
RED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRE
D_SIZE))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLa
yout.Alignment.BASELINE)
.addComponent(jLabel6)
.addComponent(jstok, javax.swing.GroupLayout.PREFERR
ED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED
_SIZE))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacem
ent.RELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLa
yout.Alignment.BASELINE)
.addComponent(jLabel7)
.addComponent(sm, javax.swing.GroupLayout.PREFERRED_
SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SI
ZE)))
.addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRE
D_SIZE, 0, Short.MAX_VALUE))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELA
TED, 29, Short.MAX_VALUE)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Ali
gnment.BASELINE)
.addComponent(jadd)
.addComponent(jsave)
.addComponent(jkoreksi)
.addComponent(jdelete)
.addComponent(jexit)
.addComponent(jcancel)
.addComponent(jprint))
.addGap(24, 24, 24))
);
pack();
}// </editor-fold>
private void jaddActionPerformed(java.awt.event.ActionEvent evt) {

// TODO add your handling code here:
disable_Text(true);
disable_button(false);
jdelete.setEnabled(false);
jsave.setText("Simpan");
add=true;
if (add==true){
edit=false;
add=true;
}
bersih();
jsave.setText("Simpan");
kode();
}
public void kode(){
kd_brg.setText("b-0"+(Integer.valueOf(jTable1.getRowCount())+1));
}

private void jTable1MouseClicked(java.awt.event.MouseEvent evt) {

// TODO add your handling code here:
edit=true;
disable_Text(true);
disable_button(false);
jdelete.setEnabled(true);
if (edit==true){
add=false;
edit=true;
}
jsave.setText("Update");
kd_brg.setText(jTable1.getValueAt(jTable1.getSelectedRow(), 0).toString(
));
nm_brg.setText(jTable1.getValueAt(jTable1.getSelectedRow(), 1).toString(
));
sts.setSelectedItem(jTable1.getValueAt(jTable1.getSelectedRow(), 2).toSt
ring());
jharga.setText(jTable1.getValueAt(jTable1.getSelectedRow(), 3).toString(
));
jstok.setText(jTable1.getValueAt(jTable1.getSelectedRow(), 4).toString()
);
sm.setText(jTable1.getValueAt(jTable1.getSelectedRow(), 5).toString());

// tampil_data();
}
private void jsaveActionPerformed(java.awt.event.ActionEvent evt) {

// TODO add your handling code here:
try{
if (kd_brg.getText().isEmpty()){
JOptionPane.showMessageDialog(null, " Kode Barang Belum diIsi !!
", "Warning Message",JOptionPane.WARNING_MESSAGE);
}else if (add==true){
stm.executeUpdate("INSERT INTO barang VALUES('"+kd_brg.getText()
+"','"+nm_brg.getText()+"','"+jTextField1.getText()+"','"+jharga.getText()+"','"
+jstok.getText()+"','"+sm.getText()+"')" );
baca_data();
JOptionPane.showMessageDialog(null, " Data Berhasil Disimpan !!
", "Warning Message",JOptionPane.WARNING_MESSAGE);
bersih();
}else if (edit==true){
stm.executeUpdate("UPDATE barang set nama_barang='"+nm_brg.getTe
xt()+"',satuan='"+jTextField1.getText()+"',harga='"+jharga.getText()+"',stok='"+
jstok.getText()+"',stok_minimal='"+sm.getText()+"' WHERE kode_barang='"+kd_brg.g
etText()+"'");
baca_data();
JOptionPane.showMessageDialog(null, " Data Berhasil Diupdate !!
", "Warning Message",JOptionPane.WARNING_MESSAGE);
bersih();
}
jTable1.setModel(new DefaultTableModel(dataTable,header));
baca_data();
}catch(Exception e){

JOptionPane.showMessageDialog(null,e);
}
jdelete.setEnabled(false);
}
private void jkoreksiActionPerformed(java.awt.event.ActionEvent evt) {

// TODO add your handling code here:
edit=true;
disable_Text(true);
disable_button(false);
if (edit==true){
add=false;
edit=true;
}
bersih();
jsave.setText("Update");
}
private void jdeleteActionPerformed(java.awt.event.ActionEvent evt) {

// TODO add your handling code here:
try{
stm.executeUpdate("DELETE FROM barang where kode_barang='"+kd_brg.ge
tText()+"'");
baca_data();
JOptionPane.showMessageDialog(null, " Data Behasil Dihapus !! ", "Wa
rning Message",JOptionPane.WARNING_MESSAGE);
bersih();
}catch(Exception e){
JOptionPane.showMessageDialog(null, e);
}
}
private void jexitActionPerformed(java.awt.event.ActionEvent evt) {

// TODO add your handling code here:
dispose();
}
private void jcancelActionPerformed(java.awt.event.ActionEvent evt) {

// TODO add your handling code here:
disable_Text(false);
disable_button(true);
bersih();
jdelete.setEnabled(false);
}
private void stsActionPerformed(java.awt.event.ActionEvent evt) {

// TODO add your handling code here:
if (sts.getSelectedItem().equals("Kg")){
jTextField1.setText("Kg");
}else if (sts.getSelectedItem().equals("Liter")){
jTextField1.setText("Liter");
}else if (sts.getSelectedItem().equals("KM")){
jTextField1.setText("KM");
}else if (sts.getSelectedItem().equals("Gram")){
jTextField1.setText("Gram");
}else if (sts.getSelectedItem().equals("Newton")){
jTextField1.setText("Newton");
}else if(sts.getSelectedItem().equals("Ton")){
jTextField1.setText("Ton");
}else if (sts.getSelectedItem().equals("Kwintal")){
jTextField1.setText("Kwintal");
}else if (sts.getSelectedItem().equals("Abad")){
jTextField1.setText("Abad");
}else{
jTextField1.setText("Lainnya");
}
}
private void jprintActionPerformed(java.awt.event.ActionEvent evt) {

// TODO add your handling code here:
cetak_barang();
}
/**
* @param args the command line arguments
*/
public static void main(String args[]) {
/* Set the Nimbus look and feel */
//<editor-fold defaultstate="collapsed" desc=" Look and feel setting cod
e (optional) ">
/* If Nimbus (introduced in Java SE 6) is not available, stay with the d
efault look and feel.
* For details see http://download.oracle.com/javase/tutorial/uiswing/lo
okandfeel/plaf.html
*/
try {
for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIMana
ger.getInstalledLookAndFeels()) {
if ("Nimbus".equals(info.getName())) {
javax.swing.UIManager.setLookAndFeel(info.getClassName());
break;
}
}
} catch (ClassNotFoundException ex) {
java.util.logging.Logger.getLogger(frmBarang.class.getName()).log(ja
va.util.logging.Level.SEVERE, null, ex);
} catch (InstantiationException ex) {
java.util.logging.Logger.getLogger(frmBarang.class.getName()).log(ja
va.util.logging.Level.SEVERE, null, ex);
} catch (IllegalAccessException ex) {
java.util.logging.Logger.getLogger(frmBarang.class.getName()).log(ja
va.util.logging.Level.SEVERE, null, ex);
} catch (javax.swing.UnsupportedLookAndFeelException ex) {
java.util.logging.Logger.getLogger(frmBarang.class.getName()).log(ja
va.util.logging.Level.SEVERE, null, ex);
}
//</editor-fold>
/* Create and display the form */
java.awt.EventQueue.invokeLater(new Runnable() {
public void run() {
new frmBarang().setVisible(true);
}
});
}

// Variables declaration - do not modify
private javax.swing.JLabel jLabel1;
private javax.swing.JLabel jLabel2;
private javax.swing.JLabel jLabel3;
private javax.swing.JLabel jLabel4;
private javax.swing.JLabel jLabel5;
private javax.swing.JLabel jLabel6;
private javax.swing.JLabel jLabel7;
private javax.swing.JScrollPane jScrollPane1;
private javax.swing.JTable jTable1;
private javax.swing.JTextField jTextField1;
private javax.swing.JButton jadd;
private javax.swing.JButton jcancel;
private javax.swing.JButton jdelete;
private javax.swing.JButton jexit;
private javax.swing.JTextField jharga;
private javax.swing.JButton jkoreksi;
private javax.swing.JButton jprint;
private javax.swing.JButton jsave;
private javax.swing.JTextField jstok;
private javax.swing.JTextField kd_brg;
private javax.swing.JTextField nm_brg;
private javax.swing.JTextField sm;
private javax.swing.JComboBox sts;
// End of variables declaration
}

You might also like