Java swing實(shí)現(xiàn)酒店管理系統(tǒng)
今天給大家提供一個(gè)由今天給大家提供一個(gè)由Java swing實(shí)現(xiàn)的酒店管理系統(tǒng),數(shù)據(jù)庫(kù)采用sqlserver,我會(huì)貼上部分代碼,完整的代碼請(qǐng)看文章最下方下載,下面看代碼:
1.主框架代碼:
package 主框架窗口;
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JSplitPane;
import javax.swing.JToolBar;
import javax.swing.border.LineBorder;
import javax.swing.table.DefaultTableModel;
import com.sunshine.sunsdk.system.suntools;
import sunsdk.sql.Journal;
import sunsdk.sql.sunsql;
import sunsdk.swing.TJButton;
import 關(guān)于我們.About;
import 團(tuán)體開(kāi)單.Team;
import 客戶管理.Customer;
import 客房預(yù)定.Engage;
import 賓客結(jié)賬.CheckOut;
import 散客開(kāi)單.Individual;
import 系統(tǒng)設(shè)置.Setup;
import 網(wǎng)絡(luò)設(shè)置.NetSetup;
import 菜單事件窗口.ApartBill;
import 菜單事件窗口.Change;
import 菜單事件窗口.GoOn;
import 菜單事件窗口.Record;
import 菜單事件窗口.UniteBill;
import 營(yíng)業(yè)查詢(xún).Query;
//加入公共類(lèi)庫(kù)
//加入模塊類(lèi)庫(kù)
//散客開(kāi)單
//團(tuán)體開(kāi)單
//賓客結(jié)帳
//預(yù)訂房間
//營(yíng)業(yè)查詢(xún)
//客戶管理
//網(wǎng)絡(luò)設(shè)置
//系統(tǒng)設(shè)置
//關(guān)于我們
//下拉菜單中的功能庫(kù)
public class HotelFrame
extends JFrame
implements ActionListener, MouseListener, Runnable {
//用戶名,權(quán)限
public static String userid, puil;
public static JLabel lbA, lbB;
public static String clue = " 提 示 : ";
public static String face = " 當(dāng)前操作界面 : ";
//聲名與菜單相關(guān)的類(lèi)
private JMenuBar mb;
private JMenu m1, m2, m3, m4;
private JMenuItem mi11, mi12, mi13, mi14, mi15, mi16, mi17, mi18, mi19,
mi21, mi22, mi23, mi24, mi25,
mi31, mi32, mi33, mi34, mi35, mi36;
//工具欄
private JToolBar tb;
private JButton bt1, bt2, bt3, bt4, bt5, bt6, bt7, bt8, bt9, btA;
//分割面板
private JSplitPane spaneMain, spaneLeft, spaneRight;
//模塊接口
private JPanel panelMain, bott, jp2, jp3, jp4;
private LeftTopPanel jp1; //主窗口左邊面板
//功能提示
private String toolTip[] = {
"零散賓客入住登記 ",
"團(tuán)體入住登記 ",
"關(guān)于本軟件的支持信息 ",
"賓客退房結(jié)算 ",
"為賓客預(yù)訂房間 ",
"查詢(xún)營(yíng)業(yè)情況 ",
"為酒店固定客戶設(shè)置參數(shù) ",
"設(shè)置系統(tǒng)的網(wǎng)絡(luò)連接方式 ",
"設(shè)置系統(tǒng)參數(shù) ",
"返回Windows "
};
//功能模塊
/*#######################################################################*/
Individual idv = new Individual(this); //散客開(kāi)單
Team tm = new Team(this); //團(tuán)體開(kāi)單
CheckOut co = new CheckOut(this); //賓客結(jié)帳
Engage eg = new Engage(this); //客房預(yù)定
Query qr = new Query(this); //營(yíng)業(yè)查詢(xún)
Customer ct = new Customer(this); //客戶管理
NetSetup ns = new NetSetup(this); //網(wǎng)絡(luò)設(shè)置
Setup st = new Setup(this); //系統(tǒng)設(shè)置
About ab = new About(this); //關(guān)于我們
GoOn go = new GoOn(this); //賓客續(xù)住
Change cg = new Change(this); //更換房間
// Remind rm = new Remind(this); //電子提醒
UniteBill ub = new UniteBill(this); //合并帳單
ApartBill ap = new ApartBill(this); //拆分帳單
Record rc = new Record(this); //系統(tǒng)日志
/*#######################################################################*/
//構(gòu)造函數(shù)
public HotelFrame (String us, String pu) {
super ("陽(yáng)光酒店管理系統(tǒng) - ★★版");
userid = us; //獲得操作員名稱(chēng)
puil = pu; //獲得操作員權(quán)限
panelMain = new JPanel (new BorderLayout()); //主面板
//制作菜單
buildMenuBar ();
//制作工具欄
buildToolBar ();
//制作分割面板
buildSpaneMain ();
//制作窗口底端信息框
buildBott ();
//加入組件到主面板
panelMain.add ("North", tb); //加入工具欄
panelMain.add ("South", bott); //加入窗口底端信息框
panelMain.add ("Center", spaneMain); //加入分割面板
//加入菜單欄
this.setJMenuBar (mb);
//加事件監(jiān)聽(tīng)
addListener ();
this.addWindowListener (new WindowAdapter () {
public void windowClosing (WindowEvent we) {
quit ();
}//End windowClosing
});
this.setContentPane (panelMain);
this.setBounds (2, 2, 1020, 740);
this.setDefaultCloseOperation (JFrame.DO_NOTHING_ON_CLOSE);
this.setMinimumSize (new Dimension (1020, 740)); //設(shè)置窗口最小尺寸
this.setVisible (true);
(new Thread(this)).start(); //啟動(dòng)房間狀態(tài)檢查線程
}
//制作菜單
private void buildMenuBar () {
//實(shí)例菜單欄
mb = new JMenuBar ();
//實(shí)例菜單
m1 = new JMenu ("來(lái)賓登記 (B)");
m2 = new JMenu ("收銀結(jié)算 (S)");
m3 = new JMenu ("系統(tǒng)維護(hù) (W)");
//實(shí)例菜單項(xiàng)
mi11 = new JMenuItem ("散客開(kāi)單 (G)");
mi12 = new JMenuItem ("團(tuán)體開(kāi)單 (M)");
mi13 = new JMenuItem ("賓客續(xù)住 (Z)");
mi14 = new JMenuItem ("更換房間 (A)");
mi15 = new JMenuItem ("修改登記 (J)");
mi16 = new JMenuItem ("房間狀態(tài) (Z)");
mi17 = new JMenuItem ("預(yù)訂管理 (T)");
mi18 = new JMenuItem ("電子提醒 (L)");
mi19 = new JMenuItem ("退出系統(tǒng) (X)");
mi21 = new JMenuItem ("賓客結(jié)帳 (J)");
mi22 = new JMenuItem ("合并帳單 (E)");
mi23 = new JMenuItem ("折分帳單 (F)");
mi24 = new JMenuItem ("賓客消費(fèi)明細(xì)查詢(xún)");
mi25 = new JMenuItem ("賓客退單明細(xì)查詢(xún)");
mi31 = new JMenuItem ("網(wǎng)絡(luò)設(shè)置 (N)");
mi32 = new JMenuItem ("系統(tǒng)設(shè)置 (X)");
mi33 = new JMenuItem ("系統(tǒng)日志 (Z)");
mi34 = new JMenuItem ("數(shù)據(jù)備份 (R)");
mi35 = new JMenuItem ("軟件幫助 (H)");
mi36 = new JMenuItem ("關(guān)于我們 (A)");
///////////////////////////////////////////
mi16.setEnabled(false);//未開(kāi)發(fā)完畢的功能
mi18.setEnabled(false);
mi34.setEnabled(false);
////////////////////////////////////////////
//組織菜單
m1.add (mi11); //來(lái)賓登記
m1.add (mi12);
m1.add (mi13);
m1.add (mi14);
m1.add (mi15);
m1.add (mi16);
m1.addSeparator();
m1.add (mi17);
m1.add (mi18);
m1.addSeparator();
m1.add (mi19);
m2.add (mi21); //收銀結(jié)算
m2.add (mi22);
m2.add (mi23);
//m2.addSeparator();
//m2.add (mi24); //賓客消費(fèi)明細(xì)
//m2.add (mi25);
m3.add (mi31); //系統(tǒng)維護(hù)
m3.add (mi32);
m3.add (mi33);
m3.addSeparator();
m3.add (mi34);
m3.addSeparator();
m3.add (mi35);
m3.add (mi36);
mb.add (m1); //加入菜單欄
mb.add (m2);
mb.add (m3);
}
//制作工具欄
private void buildToolBar () {
tb = new JToolBar();
//制作按鍵
bt1 = new TJButton ("pic/ToolBar/m01.gif", " 散客開(kāi)單 ", "零散賓客入住登記", true);
bt2 = new TJButton ("pic/ToolBar/m02.gif", " 團(tuán)體開(kāi)單 ", "團(tuán)體入住登記", true);
bt3 = new TJButton ("pic/ToolBar/m03.gif", " 關(guān)于我們 ", "軟件信息", true);
bt4 = new TJButton ("pic/ToolBar/m04.gif", " 賓客結(jié)帳 ", "賓客退房結(jié)算", true);
bt5 = new TJButton ("pic/ToolBar/m05.gif", " 客房預(yù)訂 ", "為賓客預(yù)定房間", true);
bt6 = new TJButton ("pic/ToolBar/m06.gif", " 營(yíng)業(yè)查詢(xún) ", "查詢(xún)營(yíng)業(yè)情況", true);
bt7 = new TJButton ("pic/ToolBar/m07.gif", " 客戶管理 ", "為酒店固定客戶設(shè)置", true);
bt8 = new TJButton ("pic/ToolBar/m08.gif", " 網(wǎng)絡(luò)設(shè)置 ", "設(shè)置連接方式", true);
bt9 = new TJButton ("pic/ToolBar/m09.gif", " 系統(tǒng)設(shè)置 ", "設(shè)置系統(tǒng)參數(shù)", true);
btA = new TJButton ("pic/ToolBar/m10.gif", " 退出系統(tǒng) ", "返回Windows", true);
//把按鍵加入工具欄
tb.addSeparator ();
tb.add (bt1);
tb.add (bt2);
tb.addSeparator ();
tb.add (bt4);
tb.add (bt5);
tb.add (bt6);
tb.addSeparator ();
tb.add (bt7);
tb.add (bt8);
tb.add (bt9);
tb.addSeparator ();
tb.add (bt3);
tb.addSeparator ();
tb.add (btA);
//設(shè)置工具欄不可浮動(dòng)
tb.setFloatable(false);
}
//制作主面板
private void buildSpaneMain () {
jp1 = new LeftTopPanel (); //這四個(gè)面板為功能接口//////////////
jp2 = new LeftBottPanel(); //左下面板 快速通道
jp3 = new RightTopPanel(); ///////////////////////////////
jp4 = new RightBottPanel(); //右下面板 消費(fèi)信息表
//聲名分割面板
spaneLeft = new JSplitPane(JSplitPane.VERTICAL_SPLIT, true, jp1, jp2);
spaneRight = new JSplitPane(JSplitPane.VERTICAL_SPLIT, true, jp3, jp4);
spaneMain = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, true, spaneLeft, spaneRight);
//設(shè)置面板最小尺寸
jp1.setMinimumSize(new Dimension (157, 450));
jp2.setMinimumSize(new Dimension (157, 94));
jp3.setMinimumSize(new Dimension (875, 300));
jp4.setMinimumSize(new Dimension (875, 94));
spaneRight.setMinimumSize(new Dimension (875, 565));
//設(shè)置分割條是否有伸縮鍵
spaneMain.setOneTouchExpandable (true);
spaneRight.setOneTouchExpandable(true);
//設(shè)置各面板的初起尺寸
spaneMain.setDividerLocation (160);
spaneLeft.setDividerLocation (450);
spaneRight.setDividerLocation(450);
//設(shè)置分隔條寬度
spaneMain.setDividerSize (10);
spaneLeft.setDividerSize (23);
spaneRight.setDividerSize(23);
}
//制作bott欄
private void buildBott () {
JLabel lb1, lb2;
lb1 = new JLabel(" 陽(yáng) 光 酒 店 管 理 系 統(tǒng) ");
lb2 = new JLabel(" 當(dāng)前操作員 : " + userid + " ");
lbA = new JLabel(clue + "請(qǐng)選擇功能項(xiàng) ... ");
lbB = new JLabel(face + "陽(yáng) 光 酒 店 管 理 系 統(tǒng) - ★★ 版 ");
//加外框線
lbA.setBorder(new LineBorder(new Color(87, 87, 47)));
lbB.setBorder(new LineBorder(new Color(87, 87, 47)));
lb1.setBorder(new LineBorder(new Color(87, 87, 47)));
lb2.setBorder(new LineBorder(new Color(87, 87, 47)));
bott = new JPanel(new FlowLayout(FlowLayout.LEFT, 2, 2));
bott.add (lb1);
bott.add (lbA);
bott.add (lbB);
bott.add (lb2);
}
//加事件監(jiān)聽(tīng)
private void addListener () {
mi11.addActionListener (this); //來(lái)賓登記
mi12.addActionListener (this);
mi13.addActionListener (this);
mi14.addActionListener (this);
mi15.addActionListener (this);
mi16.addActionListener (this);
mi17.addActionListener (this);
mi18.addActionListener (this);
mi19.addActionListener (this);
mi21.addActionListener (this); //收銀結(jié)算
mi22.addActionListener (this);
mi23.addActionListener (this);
mi24.addActionListener (this);
mi25.addActionListener (this);
mi31.addActionListener (this); //系統(tǒng)維護(hù)
mi32.addActionListener (this);
mi33.addActionListener (this);
mi34.addActionListener (this);
mi35.addActionListener (this);
mi36.addActionListener (this);
bt1.addActionListener (this); //按鍵加動(dòng)作監(jiān)聽(tīng)
bt2.addActionListener (this);
bt3.addActionListener (this);
bt4.addActionListener (this);
bt5.addActionListener (this);
bt6.addActionListener (this);
bt7.addActionListener (this);
bt8.addActionListener (this);
bt9.addActionListener (this);
btA.addActionListener (this);
bt1.addMouseListener (this); //按鍵加鼠標(biāo)監(jiān)聽(tīng)
bt2.addMouseListener (this);
bt3.addMouseListener (this);
bt4.addMouseListener (this);
bt5.addMouseListener (this);
bt6.addMouseListener (this);
bt7.addMouseListener (this);
bt8.addMouseListener (this);
bt9.addMouseListener (this);
btA.addMouseListener (this);
}
/**=======================================================================**
* [## private void quit () {} ]: 系統(tǒng)退出
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :關(guān)閉系統(tǒng)函數(shù),僅類(lèi)內(nèi)使用
**=======================================================================**
*/
private void quit () {
int flag = 0;
String msg = "您 現(xiàn) 在 要 關(guān) 閉 系 統(tǒng) 嗎 ?";
flag = JOptionPane.showConfirmDialog (null, msg, "提示", JOptionPane.YES_NO_OPTION);
if(flag == JOptionPane.YES_OPTION) {
Journal.writeJournalInfo(userid, "退出本系統(tǒng)", Journal.TYPE_LG);//記錄操作日志
this.setVisible (false);
System.exit (0);
}//End if(flag == JOptionPane.YES_OPTION)
return;
}
//刷新左房間信息欄數(shù)據(jù)
private void initLeftData() {
jp1.title1.setText(""); //刷房間信息
for (int i = 0; i < 8; i++) {
jp1.lt[i].setText("");
}//Endfor
jp1.initRoomstate(); //刷新房間總狀態(tài)
}
//傳數(shù)據(jù)給散客開(kāi)單窗口
private boolean initIDV() {
try {
//從房間信息表里獲得當(dāng)前房間的狀態(tài)和房間類(lèi)型編號(hào)
ResultSet rs = sunsql.executeQuery("select state,r_type_id from roominfo " +
"where delmark=0 and id='" + LeftTopPanel.title1.getText() + "'");
if(!rs.next()) { //如果無(wú)結(jié)果集,提示用戶刷新房間數(shù)據(jù)
if(LeftTopPanel.title1.getText().length() == 0) {
JOptionPane.showMessageDialog(null,"請(qǐng)選定房間后,再為賓客開(kāi)設(shè)房間",
"提示", JOptionPane.INFORMATION_MESSAGE);
}else {
JOptionPane.showMessageDialog(null, "[ " + LeftTopPanel.title1.getText() +
" ] 房間信息已更改,請(qǐng)刷新房間信息,再為賓客開(kāi)設(shè)房間", "提示", JOptionPane.INFORMATION_MESSAGE);
}
return false;
}else {
if(!rs.getString(1).equals("可供")) { //只有狀態(tài)是可供房間,才能為賓客開(kāi)設(shè)
JOptionPane.showMessageDialog(null, "請(qǐng)選擇空房間,再為賓客開(kāi)設(shè)房間",
"提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}//Endif
//傳房間號(hào)到開(kāi)單窗口
Individual.lbA.setText(LeftTopPanel.title1.getText());
//傳房間類(lèi)型到開(kāi)單窗口
Individual.lbB.setText(LeftTopPanel.title0.getText().substring(0,
LeftTopPanel.title0.getText().length()-2));
//傳房間單價(jià)到開(kāi)單窗口
Individual.lbC.setText(LeftTopPanel.lt[1].getText());
//房間類(lèi)型編號(hào)
String clRoom = rs.getString(2);
//獲得此類(lèi)型房間是否可以開(kāi)設(shè)鐘點(diǎn)房
rs = sunsql.executeQuery("select cl_room from roomtype where " +
"delmark=0 and id='" + clRoom + "'");
rs.next();
if(rs.getString(1).equals("N")) { //不能開(kāi)設(shè),則開(kāi)單窗口的鐘點(diǎn)選項(xiàng)不可用
Individual.chk1.setSelected(false); //取消選中狀態(tài)
Individual.chk1.setEnabled(false); //設(shè)置不可用
}else {
Individual.chk1.setEnabled(true); //可用
}//Endif
//傳賓客類(lèi)型數(shù)據(jù)給開(kāi)單窗口
rs = sunsql.executeQuery("select distinct c_type from customertype where " +
"delmark = 0 and pk!=0");
int ct = sunsql.recCount(rs);
String cType[] = new String[ct];
for (int i = 0; i < ct; i++) {
rs.next();
cType[i] = rs.getString(1);
}//Endfor
Individual.cb2.removeAllItems();
for (int i = 0; i < ct; i++) {
Individual.cb2.addItem(cType[i]);
}//Endfor
Individual.cb2.setSelectedItem("普通賓客");
//初始化開(kāi)單房間表---------臨時(shí)表
sunsql.executeUpdate("delete from roomnum"); //清空臨時(shí)表
sunsql.executeUpdate("insert into roomnum(roomid) values('" +
LeftTopPanel.title1.getText() + "')"); //加入當(dāng)前房間信息
//初始化開(kāi)單窗口的開(kāi)單房間表
sunsql.initDTM(Individual.dtm2,"select roomid 房間編號(hào) from roomnum");
//初始化追加房間表---------當(dāng)前類(lèi)型的除當(dāng)前房間的所有可供房間
sunsql.executeUpdate("update roominfo set indimark=0"); //刷新所有房間的開(kāi)單狀態(tài)
sunsql.executeUpdate("update roominfo set indimark=1 where id='" +
LeftTopPanel.title1.getText() + "'"); //設(shè)置當(dāng)前房間為開(kāi)單狀態(tài)
//初始化開(kāi)單窗口的可供房間表
sunsql.initDTM(Individual.dtm1,"select a.id 房間編號(hào)1 from roominfo " +
"a,(select id from roomtype where r_type='" + Individual.lbB.getText() +
"') b where a.delmark=0 and a.indimark=0 and a.state='可供' and a.r_type_id=b.id");
}//Endif
}
catch (Exception ex) {
System.out.println ("HotelFrame.initIDV(): false");
}//End try
return true;
}
//傳數(shù)據(jù)給團(tuán)體開(kāi)單窗口
private boolean initTeam() {
try {
//初始化開(kāi)單房間表---------臨時(shí)表
sunsql.executeUpdate("delete from roomnums"); //清空臨時(shí)表
//初始化開(kāi)單窗口的開(kāi)單房間表
Team.initDTM2();
//初始化追加房間表---------當(dāng)前類(lèi)型的除當(dāng)前房間的所有可供房間
sunsql.executeUpdate("update roominfo set indimark=0"); //刷新所有房間的開(kāi)單狀態(tài)
//傳房間類(lèi)型數(shù)據(jù)給團(tuán)體開(kāi)單窗口
ResultSet rs = sunsql.executeQuery("select r_type from roomtype where delmark=0");
int ct = sunsql.recCount(rs);
String type[] = new String[ct];
//傳賓客房型數(shù)據(jù)給團(tuán)體開(kāi)單窗口
for (int i = 0; i < ct; i++) {
rs.next();
type[i] = rs.getString(1);
}//Endfor
Team.cb.removeAllItems();
for (int i = 0; i < ct; i++) {
Team.cb.addItem(type[i]);
}//Endfor
//傳賓客類(lèi)型數(shù)據(jù)給團(tuán)體開(kāi)單窗口
rs = sunsql.executeQuery("select distinct c_type from customertype where " +
"delmark = 0 and pk!=0");
ct = sunsql.recCount(rs);
for (int i = 0; i < ct; i++) {
rs.next();
type[i] = rs.getString(1);
}//Endfor
Team.cb2.removeAllItems();
for (int i = 0; i < ct; i++) {
Team.cb2.addItem(type[i]);
}//Endfor
Team.cb2.setSelectedItem("普通賓客");
}
catch (Exception ex) {
System.out.println ("HotelFrame.initTeam(): false");
}//Endtry
return true;
}
//傳數(shù)據(jù)給結(jié)算窗口
private boolean initCKO() {
try {
ResultSet rs = sunsql.executeQuery("select state,r_type_id from roominfo " +
"where delmark=0 and id='" + LeftTopPanel.title1.getText() + "'");
if(!rs.next()) { //如果無(wú)結(jié)果集,提示用戶刷新房間數(shù)據(jù)
if(LeftTopPanel.title1.getText().length() == 0) {
JOptionPane.showMessageDialog(null,"請(qǐng)選定賓客入住的房間后,再為賓客結(jié)算費(fèi)用",
"提示", JOptionPane.INFORMATION_MESSAGE);
}else {
JOptionPane.showMessageDialog(null, "[ " + LeftTopPanel.title1.getText() +
" ] 房間信息已更改,請(qǐng)刷新房間信息,再為賓客開(kāi)設(shè)房間", "提示", JOptionPane.INFORMATION_MESSAGE);
}//Endif
return false;
}else {
//只有狀態(tài)是占用或鐘點(diǎn)房間,才能為賓客結(jié)算
if(!rs.getString(1).equals("占用") && !rs.getString(1).equals("鐘點(diǎn)")) {
JOptionPane.showMessageDialog(null, "請(qǐng)選擇賓客正在消費(fèi)的房間進(jìn)行結(jié)算費(fèi)用操作",
"提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}//Endif
//傳結(jié)算單號(hào)給結(jié)算窗口
co.lbA.setText(suntools.getNumber(suntools.Number_JS));
//傳結(jié)算房間給結(jié)算窗口
co.lbB.setText(jp1.title1.getText());
//傳結(jié)算賓客名稱(chēng)給結(jié)算窗口
co.lbC.setText(jp1.lt[0].getText());
//傳押金給結(jié)算窗口
co.lbF.setText(jp1.lt[6].getText());
//清空結(jié)算中間表
sunsql.executeUpdate("delete from checkout_temp");
//獲得主房間號(hào)
rs = sunsql.executeQuery("select main_room,in_no from livein where " +
"delmark=0 and r_no='" + co.lbB.getText() + "' and statemark='正在消費(fèi)'");
if(!rs.next()) {
JOptionPane.showMessageDialog(null, "操作失敗,請(qǐng)檢查網(wǎng)絡(luò)情況",
"提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}//Endif
String mainRoom = rs.getString(1); //取出主房間號(hào)
co.inNo = rs.getString(2); //傳入住單號(hào)為結(jié)算窗口
//獲得主房間狀態(tài),看是普通住宿還是鐘點(diǎn)房
rs = sunsql.executeQuery("select state from roominfo where delmark=0 and id='" + mainRoom + "'");
rs.next();
int mrState = 0; //主房間狀態(tài) 0:普通入住 1:鐘點(diǎn)房
if(rs.getString(1).equals("鐘點(diǎn)")) {
mrState = 1;
}//Endif
DefaultTableModel ckoDTM = new DefaultTableModel(); //主房間下的所有房間信息
sunsql.initDTM(ckoDTM, "select pk,r_no,r_type_id,c_type_id,in_time,foregift from " +
"livein where delmark=0 and main_room='" + mainRoom + "'");
double total = 0; //消費(fèi)總金額
double shsh = 0; //實(shí)收金額
double youh = 0; //優(yōu)惠金額
for (int i = 0; i < ckoDTM.getRowCount(); i++) {
//取出當(dāng)前房間的標(biāo)準(zhǔn)單價(jià)
rs = sunsql.executeQuery("select price,cl_price from roomtype where delmark=0 and id='" +
ckoDTM.getValueAt(i, 2) + "'");
rs.next();
double rprice = 0;
double days = 0;
if(mrState == 0) {
rprice = rs.getDouble(1); //普通入住單價(jià)
//獲得入住天數(shù)
days = suntools.getConsumeFactor(ckoDTM.getValueAt(i, 4) + "", Journal.getNowDTime());
}else {
rprice = rs.getDouble(2); //鐘點(diǎn)房單價(jià)
days = suntools.getClockFactor(ckoDTM.getValueAt(i, 4) + "", Journal.getNowDTime());
}//Endif
double rd = rprice * days; //當(dāng)前房間的消費(fèi)總金額
total = total + rd; //累加總消費(fèi)
rs = sunsql.executeQuery("select discount from customertype where delmark=0 and " +
"id='" + ckoDTM.getValueAt(i, 3) + "' and dis_attr='" + ckoDTM.getValueAt(i, 2) + "'");
rs.next();
//取出賓客享受的折扣
int dst = rs.getInt(1);
double ddr = rd * dst/10; //當(dāng)前房間的打折后價(jià)格
shsh = shsh + ddr; //應(yīng)收金額累加
youh = youh + rd - ddr; //優(yōu)惠金額累加
//向結(jié)算中間表加入數(shù)據(jù)
sunsql.executeUpdate("insert into checkout_temp(pk,r_type_id,r_no,price," +
"discount,dis_price,account,money,in_time) values(" + ckoDTM.getValueAt(i, 0) +
",'" + ckoDTM.getValueAt(i, 2) + "','" + ckoDTM.getValueAt(i, 1) + "'," +
rprice + "," + dst + "," + rprice * dst / 10 + "," + days + "," + ddr + ",'" +
ckoDTM.getValueAt(i, 4) + "')");
}
//傳消費(fèi)金額給結(jié)算窗口
co.lbD.setText(total + "");
//傳應(yīng)收金額給結(jié)算窗口
co.lbE.setText(shsh + "");
//傳實(shí)收金額
co.tf1.setText(shsh + "");
//傳優(yōu)惠金額給結(jié)算窗口
co.lbG.setText(youh + "");
//傳找零金額給結(jié)算窗口
co.lbH.setText(Double.parseDouble(co.lbF.getText()) - shsh + "");
//刷新結(jié)算中間表數(shù)據(jù)
co.initDTM();
co.tf2.requestFocus(true); //給賓客支付焦點(diǎn)
}//Endif
}
catch (Exception ex) {
JOptionPane.showMessageDialog(null, "操作失敗,請(qǐng)檢查網(wǎng)絡(luò)情況",
"提示", JOptionPane.INFORMATION_MESSAGE);
ex.printStackTrace();
System.out.println ("HotelFrame.initCKO(): false");
return false;
}//End try
return true;
}
/**=======================================================================**
* ActionListener 監(jiān)聽(tīng)
**=======================================================================**
*/
public void actionPerformed (ActionEvent ae) {
Object o = ae.getSource ();
if(o == bt1 || o ==mi11) {//============================================
lbB.setText(face + "散 客 開(kāi) 單 -");
if(initIDV()) { //傳數(shù)據(jù)給散客開(kāi)單窗口
idv.show(); //散客開(kāi)單
initLeftData(); //刷新左房間信息欄數(shù)據(jù)
}//Endif
}else if(o == bt2 || o == mi12) {//=====================================
lbB.setText(face + "團(tuán) 體 開(kāi) 單 -");
if(initTeam()) { //傳賓客類(lèi)型數(shù)據(jù)給團(tuán)體開(kāi)單窗口
tm.show(); //團(tuán)體開(kāi)單
initLeftData(); //刷新左房間信息欄數(shù)據(jù)
}//Endif
}else if(o == bt3 || o == mi36) {//=====================================
lbB.setText(face + "關(guān) 于 我 們 -");
ab.show(); //關(guān)于我們
}else if(o == bt4 || o == mi21) {//=====================================
lbB.setText(face + "賓 客 結(jié) 帳 -");
if(initCKO()) { //傳數(shù)據(jù)給結(jié)算窗口
co.show(); //賓客結(jié)帳
initLeftData(); //刷新左房間信息欄數(shù)據(jù)
}//Endif
}else if(o == bt5 || o == mi17) {//=====================================
lbB.setText(face + "客 房 預(yù) 訂 -");
eg.show(); //客房預(yù)訂
initLeftData(); //刷新左房間信息欄數(shù)據(jù)
}else if(o == bt6) {//==================================================
lbB.setText(face + "營(yíng) 業(yè) 查 詢(xún) -");
qr.show(); //營(yíng)業(yè)查詢(xún)
}else if(o == bt7) {//==================================================
if(puil.equals("普通操作員")) { //客戶管理
String msg = "對(duì)不起,您的權(quán)限不能進(jìn)入 [ 客戶管理 ] 頁(yè)面,請(qǐng)用管理員ID登錄 ...";
JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE);
return;
}
lbB.setText(face + "客 戶 管 理 -");
ct.show();
}else if(o == bt8 || o == mi31) {//=====================================
if(puil.equals("普通操作員")) { //網(wǎng)絡(luò)設(shè)置
String msg = "對(duì)不起,您的權(quán)限不能進(jìn)入 [ 網(wǎng)絡(luò)設(shè)置 ] 頁(yè)面,請(qǐng)用管理員ID登錄 ...";
JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE);
return;
}
lbB.setText(face + "網(wǎng) 絡(luò) 設(shè) 置 -");
ns.show();
}else if(o == bt9 || o == mi32) {//=====================================
if(puil.equals("普通操作員")) { //系統(tǒng)設(shè)置
String msg = "對(duì)不起,您的權(quán)限不能進(jìn)入 [ 網(wǎng)絡(luò)設(shè)置 ] 頁(yè)面,請(qǐng)用管理員ID登錄 ...";
JOptionPane.showMessageDialog(null, msg, "提示", JOptionPane.INFORMATION_MESSAGE);
return;
}
lbB.setText(face + "系 統(tǒng) 設(shè) 置 -");
st.buildDTM12(""); //刷新房間信息表的房間狀態(tài)
st.show();
initLeftData(); //刷新左房間信息欄數(shù)據(jù)
}else if(o == btA || o == mi19) {//=====================================
quit (); //退出系統(tǒng)
}else if(o == mi13) {//=================================================
lbB.setText(face + "賓 客 續(xù) 住 -");
go.show(); //賓客續(xù)住
}else if(o == mi14) {//=================================================
lbB.setText(face + "更 換 房 間 -");
cg.show(); //更換房間
}else if(o == mi15) {//=================================================
lbB.setText(face + "修 改 登 記 -");
idv.show(); //修改登記-------還要修改
}else if(o == mi16) {//=================================================
//房間狀態(tài)
}else if(o == mi18) {//=================================================
//電子提醒
}else if(o == mi22) {//=================================================
lbB.setText(face + "合 并 帳 單 -");
ub.show(); //合并帳單
}else if(o == mi23) {//=================================================
lbB.setText(face + "折 分 帳 單 -");
ap.show(); //折分帳單
}else if(o == mi33) {//=================================================
lbB.setText(face + "系 統(tǒng) 日 志 -");
rc.initDTM(); //刷新日志列表
rc.show(); //系統(tǒng)日志
}else if(o == mi34) {//=================================================
//數(shù)據(jù)備份
}else if(o == mi35) {//=================================================
//軟件幫助
}
lbB.setText(face + "陽(yáng) 光 酒 店 管 理 系 統(tǒng) - ★★ 版 ");
}
/**=======================================================================**
* MouseListener 監(jiān)聽(tīng)
**=======================================================================**
*/
public void mouseClicked (MouseEvent me) {
}
public void mousePressed (MouseEvent me) {
}
public void mouseReleased(MouseEvent me) {
}
public void mouseEntered (MouseEvent me) { //鼠標(biāo)移進(jìn)提示
Object o = me.getSource ();
if(o == bt1) {
lbA.setText (clue + toolTip[0]);
}else if(o == bt2) {
lbA.setText (clue + toolTip[1]);
}else if(o == bt3) {
lbA.setText (clue + toolTip[2]);
}else if(o == bt4) {
lbA.setText (clue + toolTip[3]);
}else if(o == bt5) {
lbA.setText (clue + toolTip[4]);
}else if(o == bt6) {
lbA.setText (clue + toolTip[5]);
}else if(o == bt7) {
lbA.setText (clue + toolTip[6]);
}else if(o == bt8) {
lbA.setText (clue + toolTip[7]);
}else if(o == bt9) {
lbA.setText (clue + toolTip[8]);
}else if(o == btA) {
lbA.setText (clue + toolTip[9]);
}
}
public void mouseExited (MouseEvent me) {
lbA.setText (clue + "請(qǐng)選擇功能項(xiàng) ... ");
}
/**=======================================================================**
* [## public void run() {} ]:
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :public
* 功能 :結(jié)算后檢查房間狀態(tài)線程
**=======================================================================**
*/
public void run() {
try {
Statement ste1 = null;
Connection conn1 = null;
if(sunini.getIniKey ("Default_Link").equals ("1")) { //JDBC連接方式
String user1 = sunini.getIniKey ("UserID");
String pwd1 = sunini.getIniKey ("Password");
String ip1 = sunini.getIniKey ("IP");
String acc1 = sunini.getIniKey ("Access");
String dbf1 = sunini.getIniKey ("DBFname");
String url1 = "jdbc:microsoft:sqlserver://" + ip1 + ":" + acc1 + ";" + "databasename=" + dbf1;
//注冊(cè)驅(qū)動(dòng)
DriverManager.registerDriver (new com.microsoft.jdbc.sqlserver.SQLServerDriver());
//獲得一個(gè)連接
conn1 = DriverManager.getConnection (url1, user1, pwd1);
}
else {
//注冊(cè)驅(qū)動(dòng) //JDBCODBC連接方式
DriverManager.registerDriver (new sun.jdbc.odbc.JdbcOdbcDriver());
//獲得一個(gè)連接
conn1 = DriverManager.getConnection ("jdbc:odbc:" + sunini.getIniKey("LinkName"));
}
//建立高級(jí)載體
ste1 = conn1.createStatement (ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
while( true ) {
ste1.executeUpdate("update roominfo set statetime=statetime-1 where statetime>0");
ste1.executeUpdate("update roominfo set state='可供' where statetime=0 and state='臟房'");
Thread.sleep(30000);
}//End while
}
catch (Exception ex) {
JOptionPane.showMessageDialog (null, "數(shù)據(jù)庫(kù)連接失敗...", "錯(cuò)誤", JOptionPane.ERROR_MESSAGE);
System.exit(0);
//ex.printStackTrace();
}//End try
}
/*
public static void main (String sd[]) {
sunswing.setWindowStyle (sunini.getIniKey ("Sys_style").charAt (0));
new HotelFrame ("gujun", "管理員");
}*/
}
2.系統(tǒng)設(shè)置:
/**
*##############################################################################
*
* [ 項(xiàng)目名 ] : 陽(yáng)光酒店管理系統(tǒng)
* [ 公司名 ] : 清華IT
* [ 模塊名 ] : 系統(tǒng)設(shè)置模塊
* [ 文件名 ] : Setup.java
* [ 相關(guān)文件 ] :
* [ 文件實(shí)現(xiàn)功能] : 組織系統(tǒng)設(shè)置窗口
* [ 作者 ] : 董豐
* [ 版本 ] : 1.1
* ----------------------------------------------------------------------------
* [ 備注 ] :
* ----------------------------------------------------------------------------
* [ 修改記錄 ] :
*
* [ 日 期 ] [版本] [修改人] [修改內(nèi)容]
* 2006/04/19 1.0 董豐 創(chuàng)建
* 2006/04/22 1.1 顧俊 實(shí)現(xiàn)數(shù)據(jù)保存
* ##--------------------------------------------------------------------------
* 版權(quán)所有(c) 2006-2007, SunshineSOFT Corporation
* --------------------------------------------------------------------------##
*
* [ 函數(shù)說(shuō)明 ] : 看類(lèi)內(nèi)各函數(shù)開(kāi)頭
*
* [ 遺留問(wèn)題 ] :
*
*##############################################################################
*/
package com.sunshine.setup;
import javax.swing.*;
import javax.swing.border.*;
import javax.swing.table.*;
import java.awt.*;
import java.awt.event.*;
import java.sql.*;
import com.sunshine.sunsdk.sql.*; //公共類(lèi)庫(kù)
import com.sunshine.sunsdk.system.*;
import com.sunshine.sunsdk.swing.*;
import com.sunshine.mainframe.HotelFrame; //加載主窗口
public class Setup
extends JDialog
implements ActionListener, MouseListener {
private JLabel top,bott;
private JTabbedPane tp;
private JPanel panelMain;
//=========房間項(xiàng)目設(shè)置
private JTable tb11, tb12;
private DefaultTableModel dtm11, dtm12; //房間類(lèi)型列表//房間信息列表
private JScrollPane sp11,sp12;
private JComboBox cb11,cb12;
//房間類(lèi)型,可供/清理狀態(tài)
private JButton bt11, bt12, bt13, bt14, bt15, bt16, bt17, bt18, bt19, bt20;
//添加, 修改,刪除LX,折扣,單個(gè),批量添加,刪除,修改FJ,保存,篩選
private JTextField tf11;
//=========客戶類(lèi)型設(shè)置
private JTable tb21,tb22;
private DefaultTableModel dtm21,dtm22;
//客戶類(lèi)型列表,房間費(fèi)打折列表
private JScrollPane sp21,sp22;
private JButton bt21, bt22, bt23, bt24;
//添加, 修改,刪除LX,房費(fèi)打折
//=========操作員設(shè)置
private JTable tb31;
private DefaultTableModel dtm31;
//操作員列表
private JScrollPane sp31;
private JComboBox cb31;//用戶名
private JPasswordField tf31, tf32, tf33;
//原密碼,新密碼,確認(rèn)密碼
private JRadioButton rb31, rb32, rb33, rb34, rb35;
//新用戶登記, 修改密碼,刪除用戶,普通用戶,管理員
private JButton bt31, bt32, bt33;
// 登記, 修改, 刪除
//=========計(jì)費(fèi)設(shè)置
private JTextField tf41, tf42, tf43, tf44, tf45, tf46, tf47;
private JCheckBox ck;
private JButton bt41, bt42;
//提示信息
String msg0 = "您確定要?jiǎng)h除在表格中選中的資料條目嗎?";
String msg1 = "請(qǐng)?jiān)谙鄳?yīng)的表格中選定條目,再點(diǎn)刪除鍵 ...";
//日志信息
String journal;
//INI文件中的鍵名
String ini[] = { "[SOFTINFO]", "UserName", "CompName", "[CONFIG]", "Soft_First",
"Default_Link" , "Default_Page", "Sys_style", "[NUMBER]",
"LodgName", "LodgNumber", "EngaName", "EngaNumber", "ChouName",
"ChouNumber", "[HABITUS]", "Ck_Habitus", "Ck_Minute", "[PARTTIME]",
"In_Room", "Out_Room1", "Out_Room2", "InsuDay", "ClockRoom1",
"ClockRoom2", "InsuHour1", "InsuHour2", "[JDBC]", "DBFname",
"UserID", "Password", "IP", "Access", "[ODBC]", "LinkName" };
//實(shí)例化功能模塊
//========================================================================//
AddRoomType art = new AddRoomType (this); //添加房間類(lèi)型
ModiRoomType mrt = new ModiRoomType(this); //添加房間類(lèi)型
AddCustomerType act = new AddCustomerType(this); //添加客戶類(lèi)型
ModiCustomerType mct = new ModiCustomerType(this); //添加客戶類(lèi)型
Discount dis = new Discount(this); //折扣設(shè)置
AddRoomInfo ari = new AddRoomInfo(this); //單個(gè)添加房間
AddRoomInfos aris = new AddRoomInfos(this); //批量添加房間
ModiRoomInfo mri = new ModiRoomInfo(this); //修改房間信息
//========================================================================//
/**=======================================================================**
* [## public Setup(JFrame frame) {} ]: 構(gòu)造函數(shù)
* 參數(shù) :JDialog對(duì)象表示本對(duì)話框的父窗口
* 返回值 :無(wú)
* 修飾符 :public
* 功能 :組建系統(tǒng)設(shè)置模塊
**=======================================================================**
*/
public Setup(JFrame frame) {
super (frame, "系統(tǒng)設(shè)置", true);
top = new JLabel(); //假空格
panelMain = new JPanel(new BorderLayout(0,10));
tab(); //制作系統(tǒng)設(shè)置項(xiàng)目標(biāo)簽面板
addListener(); //加入事件監(jiān)聽(tīng)
panelMain.add("North",top);
panelMain.add("Center",tp);
this.setContentPane(panelMain);
this.setPreferredSize (new Dimension (718,508));
this.setMinimumSize (new Dimension (718,508));
this.setResizable(false); //不允許改變窗口大小
pack();
sunswing.setWindowCenter(this); //窗口屏幕居中
}
/**=======================================================================**
* [## private void addListener() {} ]: 加事件監(jiān)聽(tīng)
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :加事件監(jiān)聽(tīng)
**=======================================================================**
*/
private void addListener() {
bt11.addActionListener(this); //加動(dòng)作監(jiān)聽(tīng)
bt12.addActionListener(this);
bt13.addActionListener(this);
bt14.addActionListener(this);
bt15.addActionListener(this);
bt16.addActionListener(this);
bt17.addActionListener(this);
bt18.addActionListener(this);
bt19.addActionListener(this);
bt20.addActionListener(this);
bt21.addActionListener(this);
bt22.addActionListener(this);
bt23.addActionListener(this);
bt24.addActionListener(this);
bt31.addActionListener(this);
bt32.addActionListener(this);
bt33.addActionListener(this);
bt41.addActionListener(this);
bt42.addActionListener(this);
rb31.addActionListener(this); //操作員作操范圍監(jiān)聽(tīng)
rb32.addActionListener(this);
rb33.addActionListener(this);
tf41.addActionListener(this); //計(jì)費(fèi)設(shè)置文本框加監(jiān)聽(tīng)
tf42.addActionListener(this);
tf43.addActionListener(this);
tf44.addActionListener(this);
tf45.addActionListener(this);
tf46.addActionListener(this);
bt11.addMouseListener(this); //加鼠標(biāo)監(jiān)聽(tīng)
bt12.addMouseListener(this);
bt13.addMouseListener(this);
bt14.addMouseListener(this);
bt15.addMouseListener(this);
bt16.addMouseListener(this);
bt17.addMouseListener(this);
bt18.addMouseListener(this);
bt19.addMouseListener(this);
bt20.addMouseListener(this);
bt21.addMouseListener(this);
bt22.addMouseListener(this);
bt23.addMouseListener(this);
bt24.addMouseListener(this);
bt31.addMouseListener(this);
bt32.addMouseListener(this);
bt33.addMouseListener(this);
bt41.addMouseListener(this);
bt42.addMouseListener(this);
}
/**=======================================================================**
* [## private void tab() {} ]: 制作系統(tǒng)設(shè)置項(xiàng)目標(biāo)簽面板
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :制作系統(tǒng)設(shè)置項(xiàng)目標(biāo)簽面板
**=======================================================================**
*/
private void tab() {
JPanel jp1,jp2,jp3,jp4;
///////////////////////////////////////////////-------模塊面板接口
jp1 = fangjian(); //房間項(xiàng)目設(shè)置
jp2 = kehu(); //客戶類(lèi)型設(shè)置
jp3 = caozuo(); //操作員設(shè)置
jp4 = jiFei(); //計(jì)費(fèi)設(shè)置
//////////////////////////////////////////////////////////////////
tp = new JTabbedPane();
tp.addTab("房間項(xiàng)目設(shè)置", new ImageIcon("pic/u01.gif"), jp1);
tp.addTab("客戶類(lèi)型設(shè)置", new ImageIcon("pic/u02.gif"), jp2);
tp.addTab("操作員設(shè)置", new ImageIcon("pic/u03.gif"), jp3);
tp.addTab("計(jì)費(fèi)設(shè)置", new ImageIcon("pic/u04.gif"), jp4);
}
/**=======================================================================**
* [## private JPanel fangjian() {} ]:
* 參數(shù) :無(wú)
* 返回值 :JPanel
* 修飾符 :private
* 功能 :房間項(xiàng)目設(shè)置
**=======================================================================**
*/
private JPanel fangjian() {
dtm11 = new DefaultTableModel();
tb11 = new JTable(dtm11);
sp11 = new JScrollPane(tb11);
dtm12 = new DefaultTableModel();
tb12 = new JTable(dtm12);
sp12 = new JScrollPane(tb12);
JPanel pfangjian,pTop,pBott,pTn,pTc,pBn,pBc,pTcc,pTcs,pBcc,pBcs;
pfangjian = new JPanel(new GridLayout(2,1,0,5));
pTop = new JPanel(new BorderLayout());
pBott = new JPanel(new BorderLayout());
pTn = new JPanel(); //放置保存按鈕等...
pTc = new JPanel(new BorderLayout()); //放置房間類(lèi)型列表及四個(gè)按鈕
pBn = new JPanel(new FlowLayout(FlowLayout.LEFT,10,0));//放置下拉列表
pBc = new JPanel(new BorderLayout()); //放置房間信息列表及四個(gè)按鈕
pTcc = new JPanel(new GridLayout(1,1));//放置房間類(lèi)型列表
pTcs = new JPanel(new FlowLayout(FlowLayout.CENTER,20,5));//放置四個(gè)按鈕
pBcc = new JPanel(new GridLayout(1,1));//放置房間信息列表
pBcs = new JPanel(new FlowLayout(FlowLayout.CENTER,20,5));//放置四個(gè)按鈕
//保存按鈕等 ...
JLabel lb1,lb2,lb3;
lb1 = new JLabel("結(jié)帳后房間狀態(tài)變?yōu)? ");
lb2 = new JLabel(" 結(jié)帳后");
lb3 = new JLabel("分鐘后變?yōu)榭晒顟B(tài) ");
tf11 = new TJTextField(sunini.getIniKey(ini[17]),5); //根據(jù)INI文件給初值
tf11.setHorizontalAlignment(JTextField.RIGHT);
cb12 = new JComboBox();
cb12.addItem(" 可供狀態(tài) ");
cb12.addItem(" 清理狀態(tài) "); //根據(jù)INI文件給初值
cb12.setSelectedIndex(Integer.parseInt(sunini.getIniKey(ini[16])));
bt19 = new TJButton ("pic/save.gif", " 保 存 ", "保存設(shè)置");
pTn.add(lb1);
pTn.add(cb12);
pTn.add(lb2);
pTn.add(tf11);
pTn.add(lb3);
pTn.add(bt19);
pTn.setBorder(BorderFactory.createTitledBorder(""));
//房間類(lèi)型列表及四個(gè)按鈕
bt11 = new TJButton ("pic/new.gif", "添加類(lèi)型", "添加房間類(lèi)型");
bt12 = new TJButton ("pic/modi0.gif", "修改類(lèi)型", "修改房間類(lèi)型");
bt13 = new TJButton ("pic/del.gif", "刪除類(lèi)型", "刪除房間類(lèi)型");
bt14 = new TJButton ("pic/modi3.gif", "房費(fèi)打折", "設(shè)置房間費(fèi)折扣");
pTcc.add(sp11);
pTcs.add(bt11);
pTcs.add(bt12);
pTcs.add(bt13);
pTcs.add(bt14);
pTc.add(pTcc);
pTc.add("South",pTcs);
pTc.setBorder(BorderFactory.createTitledBorder("房間類(lèi)型"));
//完成上半部分
pTop.add("North",pTn);
pTop.add(pTc);
//下拉列表
JLabel lb0 = new JLabel("按包廂類(lèi)型過(guò)濾: ");
cb11 = new JComboBox();
bt20 = new TJButton ("pic/choose1.gif", "篩 選", "篩選房間信息");
bt20.setBorderPainted(false);
bt20.setFocusPainted(false);
pBn.add(lb0);
pBn.add(cb11);
pBn.add(bt20);
buildDTM11(); //初始化房間類(lèi)型列表和下拉列表的值
buildDTM12(""); //初始化房間號(hào)列表
//房間信息列表及四個(gè)按鈕
bt15 = new TJButton ("pic/new.gif", "單個(gè)添加", "添加單個(gè)房間信息");
bt16 = new TJButton ("pic/book.gif", "批量添加", "批量添加房間信息");
bt17 = new TJButton ("pic/del.gif", "刪除房間", "刪除某個(gè)房間信息");
bt18 = new TJButton ("pic/modi0.gif", "修改房間", "修改某個(gè)房間信息");
pBcc.add(sp12);
pBcs.add(bt15);
pBcs.add(bt16);
pBcs.add(bt17);
pBcs.add(bt18);
pBc.add(pBcc);
pBc.add("South",pBcs);
pBc.setBorder ( BorderFactory.createTitledBorder ("房間信息") );
//完成下半部分
pBott.add("North",pBn);
pBott.add(pBc);
//組合
pfangjian.add(pTop);
pfangjian.add(pBott);
return pfangjian;
}
//
/**=======================================================================**
* [## private void buildDTM11() {} ]:
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :房間類(lèi)型列表和ComboBox
**=======================================================================**
*/
private void buildDTM11() {
String sqlCode2 = "select pk,sysmark,id,foregift,r_type 房間類(lèi)型," +
"price 預(yù)設(shè)單價(jià),cl_price " + "'鐘點(diǎn)價(jià)格/小時(shí)'" + ",bed 床位數(shù)量,cl_room "+
"'能否按鐘點(diǎn)計(jì)費(fèi)(Y/N)' from roomtype where delmark = 0";
sunsql.initDTM(dtm11,sqlCode2);
tb11.removeColumn(tb11.getColumn("pk"));
tb11.removeColumn(tb11.getColumn("sysmark"));
tb11.removeColumn(tb11.getColumn("foregift"));
tb11.removeColumn(tb11.getColumn("id"));
String sqlCode1 = "select r_type from roomtype where delmark = 0";
sunsql.initJComboBox(cb11,sqlCode1);
cb11.addItem("顯示全部房間信息");
cb11.setSelectedIndex(cb11.getItemCount() - 1); //設(shè)置顯示全部
}
/**=======================================================================**
* [## private void buildDTM12(String rType) {} ]:
* 參數(shù) :String rType為刷新參數(shù)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :房間信息表
**=======================================================================**
*/
public void buildDTM12(String rType) {
String sqlCode = "select a.pk,a.r_type_id,a.id 房間號(hào),b.r_type 房間類(lèi)型," +
"a.state 房間狀態(tài),a.location 所在區(qū)域,a.r_tel 房間電話 from roominfo as a," +
"roomtype as b where a.r_type_id = b.id and a.delmark = 0 " + rType;
sunsql.initDTM(dtm12,sqlCode);
tb12.removeColumn(tb12.getColumn("pk"));
tb12.removeColumn(tb12.getColumn("r_type_id"));
}
/**=======================================================================**
* [## private JPanel kehu() {} ]:
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :客戶類(lèi)型設(shè)置
**=======================================================================**
*/
private JPanel kehu() {
dtm21 = new DefaultTableModel();
tb21 = new JTable(dtm21);
sp21 = new JScrollPane(tb21);
dtm22 = new DefaultTableModel();
tb22 = new JTable(dtm22);
sp22 = new JScrollPane(tb22);
JPanel pkehu,p1,p2,p1b,p2b;
p1 = new JPanel(new BorderLayout());//客戶類(lèi)型面板
p2 = new JPanel(new BorderLayout());//房間費(fèi)打折面板
p1b = new JPanel(new FlowLayout(FlowLayout.CENTER,30,5));//客戶類(lèi)型按鈕面板
p2b = new JPanel(); //房間費(fèi)打折按鈕面板
buildDTM21(); //初始化客戶類(lèi)型表
bt21 = new TJButton ("pic/new.gif", "添加類(lèi)型", "添加客戶類(lèi)型");
bt22 = new TJButton ("pic/modi0.gif", "修改類(lèi)型", "修改客戶類(lèi)型");
bt23 = new TJButton ("pic/del.gif", "刪除類(lèi)型", "刪除客戶類(lèi)型");
p1b.add(bt21);
p1b.add(bt22);
p1b.add(bt23);
p1.add(sp21);
p1.add("South",p1b);
p1.setBorder ( BorderFactory.createTitledBorder ("客戶類(lèi)型") );
buildDTM22(); //初始化房間打折表
bt24 = new TJButton ("pic/modi3.gif", " 房間費(fèi)打折 ", "設(shè)置房間費(fèi)折扣");
p2b.add(bt24);
p2.add(sp22);
p2.add("South",p2b);
p2.setBorder ( BorderFactory.createTitledBorder ("房間費(fèi)打折") );
pkehu = new JPanel(new GridLayout(2,1,0,10));
pkehu.add(p1);
pkehu.add(p2);
return pkehu;
}
/**=======================================================================**
* [## private JPanel caozuo() {} ]:
* 參數(shù) :無(wú)
* 返回值 :JPanel
* 修飾符 :private
* 功能 :操作員設(shè)置
**=======================================================================**
*/
private JPanel caozuo() {
JPanel panelMain,panelMain1,panelTop,panelBott1,panelBott2;
dtm31 = new DefaultTableModel();
tb31 = new JTable(dtm31);
sp31 = new JScrollPane(tb31);
panelMain = new JPanel(new GridLayout(2,1,0,5));
panelMain1 = new JPanel (new BorderLayout (0,3)); //下半面板
panelTop = new JPanel(new GridLayout(1,1)); //操作員列表面板
panelBott1 = new JPanel(new GridLayout (1, 2));//詳細(xì)信息,操作范圍,操作權(quán)限面板
panelBott2 = new JPanel(new FlowLayout (FlowLayout.CENTER,20,5));//按鈕面板
bt31 = new TJButton ("pic/new.gif", " 登 記 ", "保存當(dāng)前用戶信息", false);
bt32 = new TJButton ("pic/key.gif", " 修 改 ", "修改密碼", false);
bt33 = new TJButton ("pic/del.gif", " 刪 除 ", "刪除當(dāng)前用戶", false);
bt32.setEnabled(false);
bt33.setEnabled(false);
panelBott2.add (bt31);
panelBott2.add (bt32);
panelBott2.add (bt33);
//制作并加入Top_Left面板
panelBott1.add (bottLeft());
//制作并加入Top_Right面板
panelBott1.add (bottRight());
panelMain1.add ("Center", panelBott1);
panelMain1.add ("South", panelBott2);
buildDTM31(); //初始化操作員信息表
panelTop.add(sp31);
panelTop.setBorder(BorderFactory.createTitledBorder("操作員列表"));
panelMain.add(panelTop);
panelMain.add(panelMain1);
return panelMain;
}
/**=======================================================================**
* [## private JPanel topLeft () {} ]: 制作Top_Left面板
* 參數(shù) :無(wú)
* 返回值 :JPanel表示組織好的面板
* 修飾符 :private
* 功能 :組建對(duì)話框的用戶名和密碼面板
**=======================================================================**
*/
private JPanel bottLeft () {
JLabel lb1, lb2, lb3, lb4;
JPanel tl, jp1, jp2;
lb1 = new JLabel ("用 戶 名: ");
lb2 = new JLabel ("原 密 碼: ");
lb3 = new JLabel ("新 密 碼: ");
lb4 = new JLabel ("確認(rèn)密碼: ");
tf31 = new TJPasswordField (17);
tf32 = new TJPasswordField (17);
tf33 = new TJPasswordField (17);
tl = new JPanel ();
jp1 = new JPanel (new GridLayout (4, 1, 0, 18));
jp2 = new JPanel (new GridLayout (4, 1, 0, 9));
//初始化用戶名下拉框
cb31 = new JComboBox ();
cb31.setEditable (true);
tf31.setEditable (false);
//加入組件
jp1.add (lb1);
jp1.add (lb2);
jp1.add (lb3);
jp1.add (lb4);
jp2.add (cb31);
jp2.add (tf31);
jp2.add (tf32);
jp2.add (tf33);
tl.add (jp1);
tl.add (jp2);
tl.setBorder (BorderFactory.createTitledBorder (" 詳細(xì)信息 "));
return tl;
}
/**=======================================================================**
* [## private JPanel topRight () {} ]: 制作Top_Right面板
* 參數(shù) :無(wú)
* 返回值 :JPanel表示組織好的面板
* 修飾符 :private
* 功能 :組建對(duì)話框操作面板
**=======================================================================**
*/
private JPanel bottRight () {
JPanel tr, jp1, jp2;
ButtonGroup bg1,bg2;
rb31 = new JRadioButton ("新用戶登記", true);
rb32 = new JRadioButton ("修改密碼");
rb33 = new JRadioButton ("刪除用戶");
rb34 = new JRadioButton ("普通操作員", true);
rb35 = new JRadioButton ("管 理 員");
bg1 = new ButtonGroup ();
bg2 = new ButtonGroup ();
tr = new JPanel (new GridLayout (2, 1));
jp1 = new JPanel ();
jp2 = new JPanel ();
//加單選組 操作范圍
bg1.add (rb31);
bg1.add (rb32);
bg1.add (rb33);
//加單選組 操作權(quán)限
bg2.add (rb34);
bg2.add (rb35);
jp1.add (rb31);
jp1.add (rb32);
jp1.add (rb33);
jp2.add (rb34);
jp2.add (rb35);
jp1.setBorder (BorderFactory.createTitledBorder (" 操作范圍 "));
jp2.setBorder (BorderFactory.createTitledBorder (" 操作權(quán)限 "));
tr.add (jp1);
tr.add (jp2);
return tr;
}
/**=======================================================================**
* [## private void buildDTM21() {} ]:
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :初始化客戶類(lèi)型列表
**=======================================================================**
*/
private void buildDTM21() {
String sqlCode = "select pk,id 客戶類(lèi)型編號(hào),id,c_type 客戶類(lèi)型,discount " +
"打折比率 from customertype where delmark = 0 and dis_attr = '購(gòu)物折扣' and id!='SYSMARK'";
sunsql.initDTM(dtm21,sqlCode);
tb21.removeColumn(tb21.getColumn("pk"));
tb21.removeColumn(tb21.getColumn("id"));
}
/**=======================================================================**
* [## private void buildDTM22() {} ]:
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :初始化房間打折費(fèi)列表
**=======================================================================**
*/
private void buildDTM22() {
String sqlCode = "select pk,sysmark,id,foregift,r_type 房間類(lèi)型,price 預(yù)設(shè)單價(jià) from roomtype where delmark = 0";
sunsql.initDTM(dtm22,sqlCode);
tb22.removeColumn(tb22.getColumn("pk"));
tb22.removeColumn(tb22.getColumn("id"));
tb22.removeColumn(tb22.getColumn("sysmark"));
tb22.removeColumn(tb22.getColumn("foregift"));
}
/**=======================================================================**
* [## private void buildDTM31() {} ]:
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :初始化操作員列表
**=======================================================================**
*/
private void buildDTM31() {
String sqlCode = "select pk,userid 用戶登錄ID,puis 用戶權(quán)限 from pwd where delmark = 0";
sunsql.initDTM(dtm31,sqlCode);
tb31.removeColumn(tb31.getColumn("pk"));
sunsql.initJComboBox (cb31, "select userid from pwd where delmark=0");
}
/**=======================================================================**
* [## private JPanel jiFei() {} ]:
* 參數(shù) :無(wú)
* 返回值 :JPanel
* 修飾符 :private
* 功能 :計(jì)費(fèi)設(shè)置
**=======================================================================**
*/
private JPanel jiFei() {
JLabel lb1, lb2, lb3, lb4, lb5, lb6, lb7, lb8, lb9, lb10,
lb11, lb12, lb13, lb14, lb15, lb16;
//定義各方位面板
JPanel panelJF, jfTop, jfLeft, jfRight, jfBott;
JPanel jp1, jp2, jp3, jp4, jp5, jp6, jp7, jp8, jp9;
//定義標(biāo)簽
lb1 = new JLabel(" 客人開(kāi)房時(shí)間在");
lb2 = new JLabel("點(diǎn)之后按新的一天開(kāi)始計(jì)費(fèi)");
lb3 = new JLabel(" 客人退房時(shí)間在");
lb4 = new JLabel("點(diǎn)之后計(jì)價(jià)天數(shù)自動(dòng)追加半天");
lb5 = new JLabel(" 客人退房時(shí)間在");
lb6 = new JLabel("點(diǎn)之后計(jì)價(jià)天數(shù)自動(dòng)追加一天");
lb7 = new JLabel(" 開(kāi)房后");
lb8 = new JLabel("分鐘開(kāi)始計(jì)費(fèi)");
lb9 = new JLabel(" 最少按");
lb10 = new JLabel("小時(shí)計(jì)費(fèi),小于這個(gè)時(shí)間的按此時(shí)間計(jì)費(fèi)");
lb11 = new JLabel(" 若不足一小時(shí)但超過(guò)");
lb12 = new JLabel("分鐘的部分按1小時(shí)計(jì)費(fèi)");
lb13 = new JLabel(" 不足上面分鐘數(shù)但超過(guò)");
lb14 = new JLabel("分鐘的部分按半小時(shí)計(jì)費(fèi)");
lb15 = new JLabel("注:此設(shè)置僅限于標(biāo)準(zhǔn)計(jì)費(fèi)的鐘點(diǎn)房! ");
lb16 = new JLabel(" ");
lb15.setForeground(new Color(255, 138, 0));
//初始化計(jì)時(shí)計(jì)費(fèi)設(shè)置
tf41 = new TJTextField(sunini.getIniKey("In_Room"), 5);
tf42 = new TJTextField(sunini.getIniKey("Out_Room1"), 5);
tf43 = new TJTextField(sunini.getIniKey("Out_Room2"), 5);
tf44 = new TJTextField(sunini.getIniKey("ClockRoom1"), 5);
tf45 = new TJTextField(sunini.getIniKey("ClockRoom2"), 5);
tf46 = new TJTextField(sunini.getIniKey("InsuHour1"), 5);
tf47 = new TJTextField(sunini.getIniKey("InsuHour2"), 5);
//設(shè)置文本框右對(duì)齊
tf41.setHorizontalAlignment(JTextField.RIGHT);
tf42.setHorizontalAlignment(JTextField.RIGHT);
tf43.setHorizontalAlignment(JTextField.RIGHT);
tf44.setHorizontalAlignment(JTextField.RIGHT);
tf45.setHorizontalAlignment(JTextField.RIGHT);
tf46.setHorizontalAlignment(JTextField.RIGHT);
tf47.setHorizontalAlignment(JTextField.RIGHT);
//不足一天是否按一天計(jì)價(jià)
ck = new JCheckBox("入住時(shí)間不足一天的按一天計(jì)費(fèi)");
if(sunini.getIniKey("InsuDay").equals("1")) {
ck.setSelected(true);
}
bt41 = new TJButton ("pic/save.gif", " 保 存 ", "保存當(dāng)前設(shè)置");
bt42 = new TJButton ("pic/exit.gif", " 返 回 ", "返回主窗口");
panelJF = new JPanel(new BorderLayout()); //計(jì)費(fèi)主面板
jfTop = new JPanel(new GridLayout(2, 1)); //放左右面板
jfLeft = new JPanel(new GridLayout(4, 1)); //計(jì)費(fèi)左面板
jfRight = new JPanel(new GridLayout(5, 1)); //計(jì)費(fèi)右面板
jfBott = new JPanel(new FlowLayout(FlowLayout.RIGHT, 40, 4));//按鍵面板
jp1 = new JPanel(new FlowLayout(FlowLayout.LEFT)); //左邊的面板用到的
jp2 = new JPanel(new FlowLayout(FlowLayout.LEFT));
jp3 = new JPanel(new FlowLayout(FlowLayout.LEFT));
jp4 = new JPanel(new FlowLayout(FlowLayout.LEFT));
jp5 = new JPanel(new FlowLayout(FlowLayout.LEFT)); //右邊的面板用到的
jp6 = new JPanel(new FlowLayout(FlowLayout.LEFT));
jp7 = new JPanel(new FlowLayout(FlowLayout.LEFT));
jp8 = new JPanel(new FlowLayout(FlowLayout.LEFT));
jp9 = new JPanel(new FlowLayout(FlowLayout.RIGHT));
//制作左邊面板
jp1.add(lb1);
jp1.add(tf41);
jp1.add(lb2);
jp2.add(lb3);
jp2.add(tf42);
jp2.add(lb4);
jp3.add(lb5);
jp3.add(tf43);
jp3.add(lb6);
jp4.add(lb16); //假空格
jp4.add(ck);
jfLeft.add(jp1);
jfLeft.add(jp2);
jfLeft.add(jp3);
jfLeft.add(jp4);
//制作右邊面板
jp5.add(lb7);
jp5.add(tf44);
jp5.add(lb8);
jp6.add(lb9);
jp6.add(tf45);
jp6.add(lb10);
jp7.add(lb11);
jp7.add(tf46);
jp7.add(lb12);
jp8.add(lb13);
jp8.add(tf47);
jp8.add(lb14);
jp9.add(lb15);
jfRight.add(jp5);
jfRight.add(jp6);
jfRight.add(jp7);
jfRight.add(jp8);
jfRight.add(jp9);
//組織兩個(gè)表到一起
jfTop.add(jfLeft);
jfTop.add(jfRight);
//組織按鍵面板
jfBott.add(bt41);
jfBott.add(bt42);
//加入主面板
panelJF.add("Center", jfTop);
panelJF.add("South", jfBott);
jfLeft.setBorder(BorderFactory.createTitledBorder("普通房間標(biāo)準(zhǔn)計(jì)費(fèi)"));
jfRight.setBorder ( BorderFactory.createTitledBorder ("鐘點(diǎn)房標(biāo)準(zhǔn)計(jì)費(fèi)") );
return panelJF;
}
/**=======================================================================**
* [## private boolean initMrt() {} ]:
* 參數(shù) :無(wú)
* 返回值 :boolean
* 修飾符 :private
* 功能 :傳數(shù)據(jù)給修改房間類(lèi)型窗口
**=======================================================================**
*/
private boolean initMrt() {
int row = tb11.getSelectedRow();
if(row == -1) {
JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谏厦骖?lèi)型表中指定房間類(lèi)型," +
"才能執(zhí)行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}
ModiRoomType.tf0.setText(dtm11.getValueAt(row,2) + ""); //類(lèi)型編號(hào)
ModiRoomType.tf1.setText(dtm11.getValueAt(row,4) + ""); //類(lèi)型名稱(chēng)
ModiRoomType.tf2.setText(dtm11.getValueAt(row,7) + ""); //床位數(shù)量
ModiRoomType.tf3.setText(dtm11.getValueAt(row,5) + ""); //預(yù)設(shè)單價(jià)
ModiRoomType.tf4.setText(dtm11.getValueAt(row,3) + ""); //預(yù)設(shè)押金
ModiRoomType.tf5.setText(dtm11.getValueAt(row,6) + ""); //鐘點(diǎn)計(jì)費(fèi)
String cl_room = dtm11.getValueAt(row, 8) + "";
if(cl_room.equals("Y")) {
ModiRoomType.chk.setSelected(true); //允許提供鐘點(diǎn)服務(wù)
}
else {
ModiRoomType.chk.setSelected(false); //不允許提供鐘點(diǎn)服務(wù)
ModiRoomType.tf5.setEnabled(false); //設(shè)置鐘點(diǎn)計(jì)費(fèi)不可用
}
return true;
}
/**=======================================================================**
* [## private boolean initMri() {} ]:
* 參數(shù) :無(wú)
* 返回值 :boolean
* 修飾符 :private
* 功能 :傳數(shù)據(jù)給修改房間信息窗口
**=======================================================================**
*/
private boolean initMri() {
int row = tb12.getSelectedRow();
if(row == -1) {
JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谏厦娣块g信息表中指定房間號(hào)," +
"才能執(zhí)行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}
ModiRoomInfo.tf1.setText(dtm12.getValueAt(row, 2) + ""); //房間編號(hào)
ModiRoomInfo.tf2.setText(dtm12.getValueAt(row, 5) + ""); //所在區(qū)域
ModiRoomInfo.tf3.setText(dtm12.getValueAt(row, 6) + ""); //房間電話
ModiRoomInfo.pk = dtm12.getValueAt(row, 0) + ""; //獲得當(dāng)前行的PK
try {
ResultSet rs = sunsql.executeQuery("select r_type from roomtype " +
"where delmark=0 and id='" + dtm12.getValueAt(row,1) + "'");
rs.next();
ModiRoomInfo.cb1.setSelectedItem(rs.getString(1)); //房間類(lèi)型
}
catch (Exception ex) {
System.out.println ("ModiRoomInfo.initMri(): Modi false");
}//End try
return true;
}
/**=======================================================================**
* [## private boolean initMct() {} ]:
* 參數(shù) :無(wú)
* 返回值 :boolean
* 修飾符 :private
* 功能 :傳數(shù)據(jù)給修改客戶類(lèi)型窗口
**=======================================================================**
*/
private boolean initMct() {
int row = tb21.getSelectedRow();
if(row == -1) {
JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谏厦骖?lèi)型表中指定客戶類(lèi)型," +
"才能執(zhí)行修改操作", "提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}
ModiCustomerType.tf1.setText(dtm21.getValueAt(row,1) + ""); //客戶類(lèi)型編號(hào)
ModiCustomerType.tf2.setText(dtm21.getValueAt(row,3) + ""); //客戶類(lèi)型名稱(chēng)
ModiCustomerType.tf3.setText(dtm21.getValueAt(row,4) + ""); //客戶類(lèi)型折扣
ModiCustomerType.pk = dtm21.getValueAt(row, 0) + ""; //獲得當(dāng)前行的PK
return true;
}
/**=======================================================================**
* [## private boolean initDis(JTable dtb, DefaultTableModel ddtm) {} ]:
* 參數(shù) :JTable 與 DefaultTableModel 為項(xiàng)目與折扣中的表
* 返回值 :boolean
* 修飾符 :private
* 功能 :傳數(shù)據(jù)給打折設(shè)置窗口
**=======================================================================**
*/
private boolean initDis(JTable dtb, DefaultTableModel ddtm) {
int row = dtb.getSelectedRow();
if(row == -1) {
JOptionPane.showMessageDialog(null, "請(qǐng)?jiān)谙鄳?yīng)列表中指定房間類(lèi)型," +
"才能進(jìn)行打折設(shè)置操作", "提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}
try {
Discount.rt = ddtm.getValueAt(row, 2) + ""; //獲得房間編號(hào)
ResultSet rs = sunsql.executeQuery("select discount from customertype " +
"where id='SYSMARK' and dis_attr='" + ddtm.getValueAt(row, 2) + "'");
rs.next();
int temp = rs.getInt(1);
if(temp == 10){
Discount.cb1.setSelectedIndex(1); //普通賓客不打折選項(xiàng)
Discount.tf1.setEnabled(false);
}else {
Discount.cb1.setSelectedIndex(0); //普通賓客打折選項(xiàng)
Discount.tf1.setEnabled(true);
}//Endif
Discount.tf1.setText(temp + ""); //普通賓客的折扣
}
catch (Exception ex) {
}
Discount.lb1.setText(ddtm.getValueAt(row, 4) + ""); //房間類(lèi)型名稱(chēng)
Discount.lb2.setText(ddtm.getValueAt(row, 5) + ""); //房間價(jià)格
//初始化表格的DTM
sunsql.initDTM(Discount.dtm, "select c_type 客戶等級(jí),discount 享受折扣, " +
"dis_price 折扣價(jià)格 from customertype where delmark=0 and dis_attr='" +
ddtm.getValueAt(row, 2) + "' and id!='SYSMARK'");
//初始化會(huì)員等級(jí)ComboBox
sunsql.initJComboBox(Discount.cb2, "select c_type from customertype where " +
"delmark=0 and id!='SYSMARK' and dis_attr='" + ddtm.getValueAt(row, 2) + "'");
return true;
}
/**=======================================================================**
* [## private boolean delInfo (String tName, DefaultTableModel delDtm, int dr[], String m) {} ]:
* 參數(shù) :Sring tName 表示要執(zhí)行刪除的表名
* DTM delDtm 表示相關(guān)聯(lián)的DTM
* int dr[] 要被執(zhí)行刪除的行數(shù)
* String m 提示信息
* 返回值 :boolean
* 修飾符 :private
* 功能 :房間類(lèi)型、房間信息和客戶類(lèi)型的刪操作
**=======================================================================**
*/
private boolean delInfo (String tName, DefaultTableModel delDtm, int dr[], String m) {
int rowCount = dr.length;
int r =0; //DTM行指針
if(tName.equals ("roomtype")) { //如果刪除房間類(lèi)型,則刪除與房間類(lèi)型相關(guān)的房間信息與客戶折扣設(shè)置
rowCount = rowCount * 3;
}//Endif
if(rowCount > 0) { //判斷選擇記錄數(shù)
int isDel = JOptionPane.showConfirmDialog (null, m, "提示", JOptionPane.YES_NO_OPTION);
if(isDel == JOptionPane.YES_OPTION) {
String sqlCode[] = new String[rowCount];
//生成SQL語(yǔ)句
for (int i = 0; i < rowCount; i++) {
sqlCode[i] = "update " + tName +" set delmark=1 where pk=" + delDtm.getValueAt(dr[r], 0) + " and id='" + delDtm.getValueAt(dr[r],2) + "'";
if(tName.equals ("roomtype")) { //如果刪除房間類(lèi)型,則同時(shí)刪除相關(guān)房間信息
i++;
sqlCode[i] = "update roominfo set delmark=1 where id='sunhotel' or r_type_id='" + delDtm.getValueAt(dr[r],2) + "'";
i++;
sqlCode[i] = "update customertype set delmark=1 where id='sunhotel' or dis_attr='" + delDtm.getValueAt(dr[r],2) + "'";
}
r++; //DTM行指針加1
}//Endfor
//以事務(wù)模式執(zhí)行SQL語(yǔ)句組, 確保操作正確, 返回值為成功執(zhí)行SQL語(yǔ)句的條數(shù)
isDel = sunsql.runTransaction(sqlCode);
if(isDel != rowCount) { //如果成功執(zhí)行的條數(shù) = 數(shù)組長(zhǎng)度,則表示更新成功
String mm = "在執(zhí)行第 [ " + (isDel + 1) + " ] 條記錄的刪除操作時(shí)出錯(cuò),數(shù)據(jù)有可能被其它終端修改\n或者是網(wǎng)絡(luò)不通暢 ...";
JOptionPane.showMessageDialog(null, mm, "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
//更新失敗,返回false
return false;
}//Endif
return true; //更新成功,返回true
}//Endif
}
else //如果沒(méi)有選中記錄,則提示一下
JOptionPane.showMessageDialog(null, msg1, "提示",JOptionPane.INFORMATION_MESSAGE);
return false;
}
/**=======================================================================**
* [## private void umAdd () {} ]: 添加操作
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :添加新的用戶ID
**=======================================================================**
*/
private void umAdd () {
String pwd1 = String.valueOf(tf32.getPassword());
String pwd2 = String.valueOf(tf33.getPassword());
String pu = "普通操作員"; //用戶權(quán)限
if(!pwd1.equals (pwd2)) { //兩次密碼不相等
JOptionPane.showMessageDialog (null, "輸入錯(cuò)誤,[ 新密碼 ] 與 [ 確認(rèn)密碼 ] " +
"不正確,請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
return;
}//Endif
String umName = cb31.getEditor ().getItem () + "";//獲得用戶名
try {
ResultSet rs = sunsql.executeQuery ("select userid from pwd where delmark=0 " +
"and userid='" + umName + "'");
int isID = sunsql.recCount(rs);
if(isID > 0){ //當(dāng)前要加入的用戶名是否存在
JOptionPane.showMessageDialog (null, "管理員ID [ " + umName + " ] 已存在," +
"請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
return;
}//Endif
if(rb35.isSelected()) //獲得是否是管理員權(quán)限
pu = "管理員";
long pk = sunsql.getPrimaryKey();//從服務(wù)獲得主鍵
//記入數(shù)據(jù)庫(kù)
isID = sunsql.executeUpdate("insert into pwd(pk,userid,pwd,puis) values(" + pk +
",'" + umName + "','" + pwd1 + "','" + pu + "')");
if(isID == 0) {
JOptionPane.showMessageDialog (null, "添加操作失敗,請(qǐng)檢查網(wǎng)絡(luò)連接是否正常 " +
"...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
return;
}
tf32.setText(""); //清空密碼
tf33.setText("");
}
catch (Exception ex) {
System.out.println ("UserID.umAdd(): Add new ID error.");
}//End try
}
/**=======================================================================**
* [## private void umUpdate (int type) {} ]: 更新刪除操作
* 參數(shù) :int 變量表示操作類(lèi)型 0:表示修改密碼 1:表示刪除記錄
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :修改密碼和刪除用戶ID
**=======================================================================**
*/
private void umUpdate (int type) {
String umName = cb31.getSelectedItem() + ""; //獲得用戶名
String pwd0;
String pwd1 = String.valueOf (tf32.getPassword ());
String pwd2 = String.valueOf (tf33.getPassword ());
int isID = 0; //用戶是否存在
if(!pwd1.equals (pwd2)) { //兩次密碼不相等
JOptionPane.showMessageDialog (null, "輸入錯(cuò)誤,[ 新密碼 ] 與 [ 確認(rèn)密碼 ] " +
"不正確,請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
return;
}//Endif
if(type == 0)
pwd0 = String.valueOf (tf31.getPassword ());//取修改操作的密碼
else
pwd0 = String.valueOf (tf32.getPassword ());//取刪除操作的密碼
try {
ResultSet rs = sunsql.executeQuery ("select pwd from pwd where delmark=0 and " +
"userid='" + umName + "'");
rs.next();
if(!pwd0.equals(rs.getString(1))){ //判斷原密碼是否正確
JOptionPane.showMessageDialog (null, "管理員ID [ " + umName + " ] 的 [ 原" +
"密碼 ] 不正確,請(qǐng)重新輸入 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
return;
}//Endif
if(type == 0) { //執(zhí)行修改密碼操作
isID = sunsql.executeUpdate("update pwd set pwd='" + pwd1 + "' where " +
"delmark=0 and userid='" + umName + "'");
}else { //執(zhí)行刪除操作
isID = sunsql.executeUpdate("update pwd set delmark=1 where userid='" + umName + "'");
}//Endif
}
catch (Exception ex) {
}//End try
if(isID == 0) { //判斷操作是否成功
JOptionPane.showMessageDialog (null, "執(zhí)行操作失敗,請(qǐng)檢查網(wǎng)絡(luò)連接是否正常 ...", "錯(cuò)誤",JOptionPane.ERROR_MESSAGE);
}
tf31.setText(""); //清空密碼
tf32.setText("");
tf33.setText("");
return;
}
//檢查計(jì)費(fèi)設(shè)置是否合法
private boolean isValidity() {
if(!suntools.isNum(tf41.getText(), 1, 6, 9)) {
JOptionPane.showMessageDialog(null, "[ 計(jì)費(fèi)參數(shù) 1 ] 只能是數(shù)字,且范圍在 6-9 之間",
"提示", JOptionPane.INFORMATION_MESSAGE);
tf41.requestFocus(true);
return false;
}else if(!suntools.isNum(tf42.getText(), 2, 11, 13)) {
JOptionPane.showMessageDialog(null, "[ 計(jì)費(fèi)參數(shù) 2 ] 只能是數(shù)字,且范圍在 11-13 之間",
"提示", JOptionPane.INFORMATION_MESSAGE);
tf42.requestFocus(true);
return false;
}else if(!suntools.isNum(tf43.getText(), 2, 17, 19)) {
JOptionPane.showMessageDialog(null, "[ 計(jì)費(fèi)參數(shù) 3 ] 只能是數(shù)字,且范圍在 17-19 之間",
"提示", JOptionPane.INFORMATION_MESSAGE);
tf43.requestFocus(true);
return false;
}else if(!suntools.isNum(tf44.getText(), 1, 0, 5)) {
JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 1 ] 只能是數(shù)字,且范圍在 0-5 之間",
"提示", JOptionPane.INFORMATION_MESSAGE);
tf44.requestFocus(true);
return false;
}else if(!suntools.isNum(tf45.getText(), 1, 1, 5)) {
JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 2 ] 只能是數(shù)字,且范圍在 1-5 之間",
"提示", JOptionPane.INFORMATION_MESSAGE);
tf45.requestFocus(true);
return false;
}else if(!suntools.isNum(tf46.getText(), 2, 20, 40)) {
JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 3 ] 只能是數(shù)字,且范圍在 20-40 之間",
"提示", JOptionPane.INFORMATION_MESSAGE);
tf46.requestFocus(true);
return false;
}else if(!suntools.isNum(tf47.getText(), 2, 5, 15)) {
JOptionPane.showMessageDialog(null, "[ 鐘點(diǎn)計(jì)費(fèi)參數(shù) 4 ] 只能是數(shù)字,且范圍在 5-15 之間",
"提示", JOptionPane.INFORMATION_MESSAGE);
tf47.requestFocus(true);
return false;
}//endif
return true;
}
/**=======================================================================**
* [## private boolean isState(int aRow[]) {} ]:
* 參數(shù) :int aRom[] 表示要執(zhí)行刪除操作的行號(hào)
* 返回值 :boolean
* 修飾符 :private
* 功能 :檢查房間的狀態(tài)是否可以刪除
**=======================================================================**
*/
private boolean isState(int aRow[]) {
int ar = aRow.length;
ResultSet rs = null;
String aState = "";
try {
for (int i = 0; i < ar; i++) {
rs = sunsql.executeQuery("select state from roominfo where " +
"delmark=0 and pk='" + dtm12.getValueAt(aRow[i], 0) + "'");
rs.next();
aState = rs.getString(1);
if(aState.equals("占用")) {
JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) +
" ] 房間正處于占用狀態(tài),無(wú)法執(zhí)行刪除操作,系統(tǒng)取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}else if(aState.equals("鐘點(diǎn)")) {
JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) +
" ] 房間正處于鐘點(diǎn)房狀態(tài),無(wú)法執(zhí)行刪除操作,系統(tǒng)取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}else if(aState.equals("預(yù)訂")) {
JOptionPane.showMessageDialog(null, "[ " + dtm12.getValueAt(aRow[i], 2) +
" ] 房間正處于預(yù)訂狀態(tài),無(wú)法執(zhí)行刪除操作,系統(tǒng)取消了所有刪除操作", "提示", JOptionPane.INFORMATION_MESSAGE);
return false;
}//Endif
}//Endif
}
catch (Exception ex) {
ex.printStackTrace();
System.out.println ("Setup.isState(): false");
}//End try
return true;
}
/**=======================================================================**
* ActionListener 監(jiān)聽(tīng)
**=======================================================================**
*/
public void actionPerformed(ActionEvent ae) {
Object o = ae.getSource();
if(o == bt11) {//=======================================================
art.show(true); //添加房間類(lèi)型
buildDTM11(); //刷新表數(shù)據(jù)
buildDTM12(""); //刷新表數(shù)據(jù)
buildDTM22(); //刷新表數(shù)據(jù)
}else if(o == bt12) {//=================================================
if(initMrt()) { //傳數(shù)據(jù)給窗口
mrt.show(true); //修改房間類(lèi)型
buildDTM11(); //刷新表數(shù)據(jù)
buildDTM12(""); //刷新表數(shù)據(jù)
buildDTM22(); //刷新表數(shù)據(jù)
}//Endif
}else if(o == bt13) {//=================================================
int rRow[] = tb11.getSelectedRows(); //刪除房間類(lèi)型
int sysmark;
for (int i = 0; i < rRow.length; i++) {
//獲得得記錄的屬性標(biāo)志,并轉(zhuǎn)成整型
sysmark = Integer.parseInt(dtm11.getValueAt(rRow[i], 1) + "");
if(sysmark == 1) {
JOptionPane.showMessageDialog(null, "[ " + dtm11.getValueAt(rRow[i], 4) +
" ] 類(lèi)型為系統(tǒng)級(jí)設(shè)置,不允許被刪除,系統(tǒng)終止了刪除操作 ...", "提示",
JOptionPane.INFORMATION_MESSAGE);
return; //不執(zhí)行刪除返回窗口
}//Endif
}//Endfor
String msg = "注意,刪除 [ 房間類(lèi)型 ] 操作會(huì)將與 [ 房間類(lèi)型 ] 相關(guān)" +
"的所有 [ 房間信息 ] 一并刪除。\n您確定要?jiǎng)h除在表格中選中的類(lèi)型條目嗎?";
if(delInfo ("roomtype", dtm11, rRow, msg)) { //執(zhí)行刪除操作
buildDTM11(); //刷新類(lèi)型表數(shù)據(jù)
buildDTM12(""); //刷新房間表數(shù)據(jù)
buildDTM22(); //刷新類(lèi)型表數(shù)據(jù)
journal = "執(zhí)行了刪除房間類(lèi)型的操作--刪除數(shù)量:" + rRow.length;
Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_RT);//記錄操作日志
}//Endif
}else if(o == bt14) {//=================================================
if(initDis(tb11, dtm11)) { //房間費(fèi)打折
dis.show(true);
}//Endif
}else if(o == bt15) {//=================================================
sunsql.initJComboBox(AddRoomInfo.cb1, "select r_type from roomtype where delmark = 0");
ari.show(true); //單個(gè)添加房間信息
buildDTM12(""); //刷新表數(shù)據(jù)
}else if(o == bt16) {//=================================================
sunsql.initJComboBox(AddRoomInfos.cb, "select r_type from roomtype where delmark = 0");
aris.show(true); //批量添加房間信息
buildDTM12(""); //刷新表數(shù)據(jù)
}else if(o == bt18) {//=================================================
sunsql.initJComboBox(ModiRoomInfo.cb1, "select r_type from roomtype where delmark = 0");
if(initMri()) { //傳數(shù)據(jù)給窗口
mri.show(true); //修改房間信息
buildDTM12(""); //刷新表數(shù)據(jù)
}//Endif
}else if(o == bt17) {//=================================================
int rRow[] = tb12.getSelectedRows(); //刪除房間信息
if(isState(rRow)) { //判斷房間的狀態(tài)是否可以刪除
if(delInfo ("roominfo", dtm12, rRow, msg0)) { //執(zhí)行刪除操作
buildDTM12(""); //刷新房間表數(shù)據(jù)
journal = "執(zhí)行了刪除房間信息的操作--刪除數(shù)量:" + rRow.length;
Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_RI);//記錄操作日志
}//Endif
}
}else if(o == bt19) {//=================================================
if(!suntools.isNum(tf11.getText(),2 ,5 ,30)) { //保存退房后房間狀態(tài)
JOptionPane.showMessageDialog(null, "結(jié)算后更改房間狀態(tài)的時(shí)間框只能為數(shù)字,且范圍在 5 - 30 之間",
"提示", JOptionPane.INFORMATION_MESSAGE);
tf11.requestFocus(true);
return;
}
sunini.setIniKey(ini[16], cb12.getSelectedIndex() + ""); //將設(shè)置保存至緩沖區(qū)
sunini.setIniKey(ini[17], tf11.getText());
sunini.saveIni(ini); //將緩沖區(qū)的設(shè)置保存至INI文件
}else if(o == bt20) {//=================================================
int cbIndex = cb11.getSelectedIndex(); //篩選信息
if(cbIndex == cb11.getItemCount() - 1) { //顯示全部房間
buildDTM12(""); //刷新房間表數(shù)據(jù)
}else {
String rt = "and a.r_type_id = '" + dtm11.getValueAt(cbIndex, 2) + "'";
buildDTM12(rt); //根據(jù)指定房間類(lèi)型刷新表數(shù)據(jù)
}//Endif
}else if(o == bt21) {//=================================================
act.show(true); //添加客戶類(lèi)型
buildDTM21();
}else if(o == bt22) {//=================================================
if(initMct()) { //傳數(shù)據(jù)給窗口
mct.show(true); //修改客戶類(lèi)型
buildDTM21(); //刷新表數(shù)據(jù)
}//Endif
}else if(o == bt23) {//=================================================
int rRow[] = tb21.getSelectedRows(); //刪除客戶類(lèi)型
if(delInfo ("customertype", dtm21, rRow, msg0)) { //執(zhí)行刪除操作
buildDTM21(); //刷新房間表數(shù)據(jù)
journal = "執(zhí)行了刪除客戶類(lèi)型的操作--刪除數(shù)量:" + rRow.length;
Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_US);//記錄操作日志
}//Endif
}else if(o == bt24) {//=================================================
if(initDis(tb22, dtm22)) { //房間費(fèi)打折
dis.show(true);
}//Endif
}else if(o == bt31) {//===================================//登記操作員信息
if(String.valueOf(tf32.getPassword()).length() == 0) {
JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示",
JOptionPane.INFORMATION_MESSAGE);
return;
}else if(String.valueOf(tf33.getPassword()).length() == 0) {
JOptionPane.showMessageDialog(null, " [ 確認(rèn)密碼 ] 不能為空", "提示",
JOptionPane.INFORMATION_MESSAGE);
return;
}//Endif
umAdd (); //執(zhí)行添加操作
buildDTM31(); //刷新表數(shù)據(jù)
journal = "添加了新的操作員信息-- [ " + cb31.getEditor ().getItem () + " ]";
Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志
}else if(o == bt32) {//==================================//修改操作員信息
if(String.valueOf(tf31.getPassword()).length() == 0) {
JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示",
JOptionPane.INFORMATION_MESSAGE);
return;
}else if(String.valueOf(tf32.getPassword()).length() == 0) {
JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示",
JOptionPane.INFORMATION_MESSAGE);
return;
}else if(String.valueOf(tf33.getPassword()).length() == 0) {
JOptionPane.showMessageDialog(null, " [ 確認(rèn)密碼 ] 不能為空", "提示",
JOptionPane.INFORMATION_MESSAGE);
return;
}//Endif
umUpdate (0); //執(zhí)行修改密碼操作
journal = "修改了操作員 [ " + cb31.getEditor ().getItem () + " ] 的設(shè)置";
Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志
}else if(o == bt33) {//=================================================//刪除操作員信息
if(String.valueOf(tf32.getPassword()).length() == 0) {
JOptionPane.showMessageDialog(null, " [ 新密碼 ] 不能為空", "提示",
JOptionPane.INFORMATION_MESSAGE);
return;
}else if(String.valueOf(tf33.getPassword()).length() == 0) {
JOptionPane.showMessageDialog(null, " [ 確認(rèn)密碼 ] 不能為空", "提示",
JOptionPane.INFORMATION_MESSAGE);
return;
}//Endif
int wi = JOptionPane.showConfirmDialog(null,"您確認(rèn)要?jiǎng)h除當(dāng)前的用戶ID嗎?",
"提示", JOptionPane.YES_NO_OPTION);
if(wi == JOptionPane.YES_OPTION) {
umUpdate (1); //執(zhí)行刪除用戶ID操作
buildDTM31(); //刷新表數(shù)據(jù)
journal = "刪除了操作員 [ " + cb31.getEditor ().getItem () + " ] 的設(shè)置";
Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_CZ);//記錄操作日志
}//Endif
}else if(o == bt41) {//=================================================
if(isValidity()) {
int saveJf = JOptionPane.showConfirmDialog(null, "您 確 實(shí) 要 保 存 " +
"當(dāng) 前 的 計(jì) 費(fèi) 設(shè) 置 嗎 ?","保存設(shè)置",JOptionPane.YES_NO_OPTION);
if(saveJf == JOptionPane.YES_OPTION) { //保存計(jì)費(fèi)設(shè)置
sunini.setIniKey("In_Room", tf41.getText()); //將設(shè)置保存至緩沖區(qū)
sunini.setIniKey("Out_Room1", tf42.getText());
sunini.setIniKey("Out_Room2", tf43.getText());
sunini.setIniKey("ClockRoom1", tf44.getText());
sunini.setIniKey("ClockRoom2", tf45.getText());
sunini.setIniKey("InsuHour1", tf46.getText());
sunini.setIniKey("InsuHour2", tf47.getText());
if(ck.isSelected()) { //不足一天按一天收費(fèi)
sunini.setIniKey("InsuDay","1");
}else {
sunini.setIniKey("InsuDay","0");
}//Endif
sunini.saveIni(ini); //將緩沖區(qū)的設(shè)置保存至INI文件
journal = "修改了系統(tǒng)的計(jì)費(fèi)設(shè)置";
Journal.writeJournalInfo(HotelFrame.userid, journal, Journal.TYPE_JF);//記錄操作日志
}//Endif
}//Endif
}else if(o == bt42) {//=================================================
this.setVisible(false); //返回主窗口
}else if(o == tf41) {
tf42.requestFocus(true);
}else if(o == tf42) {
tf43.requestFocus(true);
}else if(o == tf43) {
tf44.requestFocus(true);
}else if(o == tf44) {
tf45.requestFocus(true);
}else if(o == tf45) {
tf46.requestFocus(true);
}else if(o == tf46) {
tf47.requestFocus(true);
}else if(o == rb31) {//=================================================
bt31.setEnabled (true); //操作范圍--添加新操作員
bt32.setEnabled (false);
bt33.setEnabled (false);
rb34.setEnabled (true);
rb35.setEnabled (true);
tf31.setEditable(false);
tf32.setEditable(true);
tf33.setEditable(true);
cb31.setEditable (true);
}else if(o == rb32) { //操作范圍--操作員修改密碼
bt31.setEnabled (false);
bt32.setEnabled (true);
bt33.setEnabled (false);
rb34.setEnabled (false);
rb35.setEnabled (false);
tf31.setEditable(true);
tf32.setEditable(true);
tf33.setEditable(true);
cb31.setEditable (false);
}else if(o == rb33) { //操作范圍--刪除操作員
bt31.setEnabled (false);
bt32.setEnabled (false);
bt33.setEnabled (true);
rb34.setEnabled (false);
rb35.setEnabled (false);
tf31.setEditable(false);
tf32.setEditable(true);
tf33.setEditable(true);
cb31.setEditable (false);
}//Endif
}//End actionPerformed
/**=======================================================================**
* MouseListener 監(jiān)聽(tīng)
**=======================================================================**
*/
public void mouseClicked (MouseEvent me) {
}
public void mousePressed (MouseEvent me) {
}
public void mouseReleased(MouseEvent me) {
}
public void mouseEntered (MouseEvent me) { //鼠標(biāo)移進(jìn)提示
Object o = me.getSource ();
if(o == bt11) {
HotelFrame.lbA.setText (HotelFrame.clue +
"添加新的房間類(lèi)型 ");
}else if(o == bt12) {
HotelFrame.lbA.setText (HotelFrame.clue +
"修改指定的房間類(lèi)型 ");
}else if(o == bt13) {
HotelFrame.lbA.setText (HotelFrame.clue +
"刪除指定的房間類(lèi)型 ");
}else if(o == bt14) {
HotelFrame.lbA.setText (HotelFrame.clue +
"設(shè)置指定房間類(lèi)型的消費(fèi)折扣 ");
}else if(o == bt15) {
HotelFrame.lbA.setText (HotelFrame.clue +
"為指定的房間類(lèi)型添加新的客房 ");
}else if(o == bt16) {
HotelFrame.lbA.setText (HotelFrame.clue +
"為指定的房間類(lèi)型一次添加多個(gè)新客房 ");
}else if(o == bt17) {
HotelFrame.lbA.setText (HotelFrame.clue +
"修改指定客房信息設(shè)置 ");
}else if(o == bt18) {
HotelFrame.lbA.setText (HotelFrame.clue +
"刪除指定的客房 ");
}else if(o == bt19) {
HotelFrame.lbA.setText (HotelFrame.clue +
"保存房間退房后的狀態(tài) ");
}else if(o == bt20) {
HotelFrame.lbA.setText (HotelFrame.clue +
"以左邊指定的類(lèi)型顯示房間信息 ");
} if(o == bt21) {
HotelFrame.lbA.setText (HotelFrame.clue +
"添加新的客戶類(lèi)型 ");
}else if(o == bt22) {
HotelFrame.lbA.setText (HotelFrame.clue +
"修改指定的客戶資料 ");
}else if(o == bt23) {
HotelFrame.lbA.setText (HotelFrame.clue +
"刪除指定的客戶資料 ");
}else if(o == bt24) {
HotelFrame.lbA.setText (HotelFrame.clue +
"設(shè)置指定房間類(lèi)型的消費(fèi)折扣 ");
}else if(o == bt31) {
HotelFrame.lbA.setText (HotelFrame.clue +
"添加新的操作員 ");
}else if(o == bt32) {
HotelFrame.lbA.setText (HotelFrame.clue +
"修改指定的操作員密碼 ");
}else if(o == bt33) {
HotelFrame.lbA.setText (HotelFrame.clue +
"刪除指定的操作員 ");
}else if(o == bt41) {
HotelFrame.lbA.setText (HotelFrame.clue +
"保存當(dāng)前的計(jì)費(fèi)設(shè)置至INI配置文件 ");
}else if(o == bt42) {
HotelFrame.lbA.setText (HotelFrame.clue +
"返回主窗口 ");
}
}
public void mouseExited (MouseEvent me) {
HotelFrame.lbA.setText (HotelFrame.clue +
"請(qǐng)選擇功能項(xiàng) ... ");
}
}
3.登錄窗口:
/**
*##############################################################################
*
* [ 項(xiàng)目名 ] : 陽(yáng)光酒店管理系統(tǒng)
* [ 公司名 ] : 清華IT
* [ 模塊名 ] : 系統(tǒng)登陸窗口
* [ 文件名 ] : Login.java
* [ 相關(guān)文件 ] :
* [ 文件實(shí)現(xiàn)功能] : 系統(tǒng)登陸窗口
* [ 作者 ] : 顧俊
* [ 版本 ] : 1.1
* ----------------------------------------------------------------------------
* [ 備注 ] :
* ----------------------------------------------------------------------------
* [ 修改記錄 ] :
*
* [ 日 期 ] [版本] [修改人] [修改內(nèi)容]
* 2006/04/02 1.0 顧俊 創(chuàng)建
* 2006/04/06 1.1 顧俊 增加注釋
* 2006/04/19 1.2 顧俊 自動(dòng)記錄登錄日志
* ##--------------------------------------------------------------------------
* 版權(quán)所有(c) 2006-2007, SunshineSOFT Corporation
* --------------------------------------------------------------------------##
*
* [ 函數(shù)說(shuō)明 ] :
*
* [## public Login() {} ]:
* 功能: 構(gòu)造函數(shù) 組建登錄窗口
*
* [## private void buildCenter() {} ]:
* 功能: 組建用戶名密碼面板,僅類(lèi)內(nèi)使用
*
* [## private void quit() {} ]:
* 功能: 關(guān)閉系統(tǒng)函數(shù),僅類(lèi)內(nèi)使用
*
* [## private void dengLu() {} ]:
* 功能: 密碼驗(yàn)證通過(guò),進(jìn)入主操作界面,僅類(lèi)內(nèi)使用
*
* [ 遺留問(wèn)題 ] :
*
*##############################################################################
*/
//package com.sunshine.login;
import javax.swing.*;
import javax.swing.border.*;
import java.awt.*;
import java.awt.event.*;
import java.sql.*;
import com.sunshine.sunsdk.sql.*;
import com.sunshine.sunsdk.swing.*;
import com.sunshine.sunsdk.system.*;
import com.sunshine.mainframe.*;
public class Login extends JFrame
implements ActionListener, KeyListener, ItemListener, FocusListener {
JLabel top, bott;
JComboBox cb;
JPasswordField pf;
JButton bt1, bt2;
JPanel panelMain, panelInfo;
String clue = " 提 示 : ";
int flag = 0; //登記次數(shù)記數(shù)器
/**=======================================================================**
* [## public Login() {} ]: 構(gòu)造函數(shù)
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :public
* 功能 :組建登錄窗口
**=======================================================================**
*/
public Login() {
super("系 統(tǒng) 登 錄");
top = new JLabel (new ImageIcon("pic/login_top.gif"));
bott = new JLabel();
panelMain = new JPanel(new BorderLayout(10, 10));
bott.setBorder(new LineBorder (new Color(184, 173, 151)));
buildCenter();
panelMain.add("North", top);
panelMain.add("South", bott);
panelMain.add(panelInfo);
//加事件監(jiān)聽(tīng)
bt1.addActionListener(this);
bt2.addActionListener(this);
bt1.addFocusListener (this);
bt2.addFocusListener (this);
bt1.addKeyListener (this);
bt2.addKeyListener (this);
cb.addItemListener (this);
cb.addFocusListener(this);
pf.addFocusListener(this);
cb.addKeyListener (this);
pf.addKeyListener (this);
//加窗口監(jiān)聽(tīng) new WindowAdapter適配器類(lèi)
this.addWindowListener(new WindowAdapter() {
public void windowClosing(WindowEvent we) {
quit();
}//End windowClosing
});
this.setContentPane(panelMain); //設(shè)置窗口面板
this.setSize(350, 235);
this.setResizable (false); //設(shè)置窗口不可放大縮小
this.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);
sunswing.setWindowCenter(this);
this.setVisible(true);
pf.requestFocus(true); //設(shè)置焦點(diǎn)給密碼框
}
/**=======================================================================**
* [## private void buildCenter() {} ]: 制作用戶名密碼面板
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :組建用戶名密碼面板,僅類(lèi)內(nèi)使用
**=======================================================================**
*/
private void buildCenter() {
JLabel lb1, lb2;
JPanel pa1, pa2, pa3;
lb1 = new JLabel("用 戶 名 :");
lb2 = new JLabel("登錄密碼 :");
cb = new JComboBox();
pf = new TJPasswordField (15);
bt1 = new TJButton ("pic/key.gif", "登 錄", "登錄系統(tǒng)");
bt2 = new TJButton ("pic/exit.gif", "退 出", "關(guān)閉系統(tǒng)");
sunsql.initJComboBox (cb, "select userid from pwd where delmark=0");
//定義面板為無(wú)部局
panelInfo = new JPanel(null);
//加入組件
panelInfo.add(lb1);
panelInfo.add(lb2);
panelInfo.add(cb);
panelInfo.add(pf);
panelInfo.add(bt1);
panelInfo.add(bt2);
lb1.setBounds(50,14,60,20);
lb2.setBounds(50,48,60,20);
bt1.setBounds(68,77,86,28);
bt2.setBounds(186,77,86,28);
cb.setBounds (115,12,168,23);
pf.setBounds (115,46,170,23);
//設(shè)定邊框線
panelInfo.setBorder(BorderFactory.createTitledBorder(""));
}
/**=======================================================================**
* [## private void quit() {} ]: 系統(tǒng)退出
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :關(guān)閉系統(tǒng)函數(shù),僅類(lèi)內(nèi)使用
**=======================================================================**
*/
private void quit() {
int flag = 0;
String msg = "您 現(xiàn) 在 要 關(guān) 閉 系 統(tǒng) 嗎 ?";
flag = JOptionPane.showConfirmDialog(null, msg, "提示", JOptionPane.YES_NO_OPTION);
if(flag == JOptionPane.YES_OPTION) {
this.setVisible(false);
System.exit(0);
}//End if(flag == JOptionPane.YES_OPTION)
return;
}
/**=======================================================================**
* [## private void dengLu() {} ]: 系統(tǒng)登錄
* 參數(shù) :無(wú)
* 返回值 :無(wú)
* 修飾符 :private
* 功能 :密碼驗(yàn)證通過(guò),進(jìn)入主操作界面,僅類(lèi)內(nèi)使用
**=======================================================================**
*/
private void dengLu() {
String user = cb.getSelectedItem() + "";
String pwd = String.valueOf(pf.getPassword());
String code = "select pwd,puis from pwd where delmark=0 and userid='" + user + "'";
ResultSet rs = sunsql.executeQuery (code);
try {
if(rs.next()) { //用戶名存在
if(pwd.equals(rs.getString(1))) {
bott.setText(clue + "登錄成功,正在進(jìn)入系統(tǒng) ...");
String puis = rs.getString(2); //獲得操作員權(quán)限
boolean flag = Journal.writeJournalInfo(user, "登錄本系統(tǒng)", Journal.TYPE_LG);
if(flag) { //記錄日志
new com.sunshine.mainframe.HotelFrame(user, puis); //進(jìn)入主程序窗口(用戶名, 權(quán)限)
this.setVisible(false);
}else {
String msg = "寫(xiě)日志錯(cuò)誤,請(qǐng)與系統(tǒng)管理員聯(lián)系 ...";
JOptionPane.showMessageDialog(null, msg, "錯(cuò)誤", JOptionPane.ERROR_MESSAGE);
System.exit(0);
}
}
else {
bott.setText(clue + "用戶 [ " + user + " ] 的密碼不正確,請(qǐng)重新輸入 ...");
flag++;
if(flag == 3) { //三次密碼驗(yàn)證
JOptionPane.showMessageDialog(null, "您不是本系統(tǒng)的管理員,系統(tǒng)關(guān)閉 ...", "警告", JOptionPane.ERROR_MESSAGE);
System.exit(0);
}//End if(flag == 3)
return;
}//End if(pwd.equals(rs.getString(1)))
}
else {
bott.setText(clue + "用戶ID [ " + user + " ] 不存在 ...");
}//End if(rs.next())
}
catch (Exception ex) {
ex.printStackTrace();
}//End try
}
/**=======================================================================**
* ActionListener 監(jiān)聽(tīng)
**=======================================================================**
*/
public void actionPerformed (ActionEvent ae) {
//動(dòng)作監(jiān)聽(tīng)
if(ae.getSource() == bt1) { //登錄按鍵
dengLu();
}
else {
quit();
}//End if(ae.getSource() == bt1)
}
/**=======================================================================**
* ItemListener 監(jiān)聽(tīng)
**=======================================================================**
*/
public void itemStateChanged (ItemEvent ie) {
pf.requestFocus(true);
}
/**=======================================================================**
* KeyListener 監(jiān)聽(tīng)
**=======================================================================**
*/
public void keyPressed (KeyEvent ke) {
//鍵盤(pán)按下監(jiān)聽(tīng)
int key = ke.getKeyCode();
if(key == KeyEvent.VK_ENTER) {
if(ke.getSource() == cb)
pf.requestFocus(true); //將焦點(diǎn)從用戶名給密碼
if(pf.getPassword().length > 0)
dengLu(); //按Enter鍵登錄系統(tǒng)
}
else if(key == KeyEvent.VK_ESCAPE) { //按ESC鍵退出系統(tǒng)
quit();
}//End if
}
public void keyReleased (KeyEvent ke) {
//鍵盤(pán)釋放監(jiān)聽(tīng)
}
public void keyTyped (KeyEvent ke) {
//按鍵型監(jiān)聽(tīng)
}
/**=======================================================================**
* FocusListener 監(jiān)聽(tīng)
**=======================================================================**
*/
public void focusGained (FocusEvent fe) {
//焦點(diǎn)監(jiān)聽(tīng)
if(fe.getSource() == cb) //窗口最下方的功能提示
bott.setText(clue + "請(qǐng)選擇操作員名稱(chēng) ...");
else
if(fe.getSource() == pf)
bott.setText(clue + "請(qǐng)輸入登錄密碼 ...");
else
if(fe.getSource() == bt1)
bott.setText(clue + "登錄系統(tǒng) ...");
else
if(fe.getSource() == bt2)
bott.setText(clue + "退出系統(tǒng) ...");
}
public void focusLost (FocusEvent fe) {
//失去焦點(diǎn)監(jiān)聽(tīng)
}
/**=======================================================================**
* [## public static void main(String sd[]) {} ]: 主函數(shù)
* 參數(shù) :String sd[]
* 返回值 :無(wú)
* 修飾符 :public static
* 功能 :程序入口
**=======================================================================**
*/
public static void main(String sd[]) {
sunswing.setWindowStyle(sunini.getIniKey("Sys_style").charAt(0));
new FStartWindow ("pic/Login.gif", new Frame(), 1200);
new Login();
}
}
獲取地址:Java swing實(shí)現(xiàn)酒店管理系統(tǒng)
更多學(xué)習(xí)資料請(qǐng)關(guān)注專(zhuān)題《管理系統(tǒng)開(kāi)發(fā)》。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Java代碼實(shí)現(xiàn)酒店管理系統(tǒng)
- Java實(shí)現(xiàn)簡(jiǎn)單酒店管理系統(tǒng)
- Java實(shí)戰(zhàn)之酒店人事管理系統(tǒng)的實(shí)現(xiàn)
- Java 實(shí)戰(zhàn)練手項(xiàng)目之酒店管理系統(tǒng)的實(shí)現(xiàn)流程
- 基于JavaSwing設(shè)計(jì)和實(shí)現(xiàn)的酒店管理系統(tǒng)
- Java實(shí)現(xiàn)簡(jiǎn)單的酒店管理系統(tǒng)
- java實(shí)現(xiàn)酒店管理系統(tǒng)
- Java實(shí)現(xiàn)酒店客房管理系統(tǒng)
- Java代碼實(shí)現(xiàn)簡(jiǎn)單酒店管理系統(tǒng)
相關(guān)文章
Java日期工具類(lèi)時(shí)間校驗(yàn)實(shí)現(xiàn)
一般項(xiàng)目中需要對(duì)入?yún)⑦M(jìn)行校驗(yàn),比如必須是一個(gè)合法的日期,本文就來(lái)介紹一下Java日期工具類(lèi)時(shí)間校驗(yàn)實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-12-12
讓Java后臺(tái)MySQL數(shù)據(jù)庫(kù)能夠支持emoji表情的方法
最近開(kāi)發(fā)的iOS項(xiàng)目因?yàn)樾枰脩粑谋镜拇鎯?chǔ),自然就遇到了emoji等表情符號(hào)如何被mysql DB支持的問(wèn)題。下面這篇文章主要介紹了關(guān)于讓Java后臺(tái)MySQL數(shù)據(jù)庫(kù)能夠支持emoji表情的方法,需要的朋友可以參考下。2017-03-03
Java事件處理機(jī)制(自定義事件)實(shí)例詳解
這篇文章主要介紹了Java事件處理機(jī)制(自定義事件)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2016-12-12
Java日期時(shí)間格式化操作DateUtils 的整理
這篇文章主要介紹了Java日期時(shí)間格式化操作DateUtils 的整理的相關(guān)資料,這里總結(jié)了java日期格式化的操作,需要的朋友可以參考下2017-07-07
java自定義驗(yàn)證器的實(shí)現(xiàn)示例
在對(duì)外暴露接口中,我們通常會(huì)對(duì)入?yún)⑦M(jìn)行驗(yàn)證,比如一些字符串非空判斷等,本文主要介紹了java自定義驗(yàn)證器的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01
自己手寫(xiě)Mybatis通用batchInsert問(wèn)題
這篇文章主要介紹了自己手寫(xiě)Mybatis通用batchInsert問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11
Java HelloWorld原理分析_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
我們初學(xué)java的第一個(gè)程序是"hello world"。下面通過(guò)實(shí)例代碼給大家講解Java HelloWorld原理分析,感興趣的朋友一起學(xué)習(xí)吧2017-05-05

