Answered step by step
Verified Expert Solution
Link Copied!

Question

1 Approved Answer

I have to do a file in Java called Ticketsgui.file TICKETSGUI .java file Run thru some of the menus that have event handling put in

I have to do a file in Java called Ticketsgui.file

TICKETSGUI.java file

Run thru some of the menus that have event handling put in place already for various sub menus. For example Open a ticket and View a ticket. Then exit. These should all work. But wait.

Should a regular user for example see everyones tickets or just there own? Adjust for that.

Also should a regular user see the Admin menu or its sub menu features? Not at all. Adjust for that as well.

A quick and simple suggestion to at least block out the views of regular users would be to set the visibility off if the user is not an admin.

Finish the sub menus in the actionPerformed event where you see comments towards the end of the event handler namely where it says

/*

* continue implementing any other desired sub menu items (like

* forupdate and delete sub menus for example) with similar

* syntax &logic as shown above*

*/

Note coding sub menu items in the event handler can follow any order. Order in other words does not matter, what matters how you handle events fired by a menu selection.

The main thing when coding any menu items is to just use the name of your sub menu object youcreate or that has been created already in code

ex. for the following

elseif (e.getSource() == someMenuItem)

you would include for someMenuItem your sub menu object name and code in your action for when the user chooses that particular menu item.

Finally a nice little goodie or easter egg has been provided in the file. The code below

retrieves the id of any id that was just auto incremented as a result of an insert!! Very cool and useful indeed. You can show the auto generated id to the console or via a dialog message box and/or use it for some query.

Example: take the ticket id number generated and add that id on some insert to some other table along with any data for later referencing.

// retrieve ticket id number newly auto generated upon record insertion

ResultSet resultSet = null;

resultSet = statement.getGeneratedKeys();

intid = 0;

if (resultSet.next()) {

id = resultSet.getInt(1); // retrieve first field in table

}

// display results if successful or not to console / dialog box

if (result != 0) {

System.out.println("Ticket ID : " + id + " created successfully!!!");

JOptionPane.showMessageDialog(null, "Ticket id: " + id + " created");

} else {

System.out.println("Ticket cannot be created!!!");

}

Started code for TicketsGUI:

ticketsGUI:

import java.awt.Color;

import java.awt.event.ActionEvent;

import java.awt.event.ActionListener;

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.SQLException;

import java.sql.Statement;

import javax.swing.JFrame;

import javax.swing.JMenu;

import javax.swing.JMenuBar;

import javax.swing.JMenuItem;

import javax.swing.JOptionPane;

import javax.swing.JScrollPane;

import javax.swing.JTable;

public class ticketsGUI implements ActionListener {

// class level member objects

Dao dao = new Dao(); // for CRUD operations

String chkIfAdmin = null;

private JFrame mainFrame;

JScrollPane sp = null;

// Main menu object items

private JMenu mnuFile = new JMenu("File");

private JMenu mnuAdmin = new JMenu("Admin");

private JMenu mnuTickets = new JMenu("Tickets");

/* add any more Main menu object items below */

// Sub menu item objects for all Main menu item objects

JMenuItem mnuItemExit;

JMenuItem mnuItemUpdate;

JMenuItem mnuItemDelete;

JMenuItem mnuItemOpenTicket;

JMenuItem mnuItemViewTicket;

/* add any more Sub object items below */

// constructor

public ticketsGUI(String verifyRole) {

chkIfAdmin = verifyRole;

JOptionPane.showMessageDialog(null, "Welcome " + verifyRole);

if (chkIfAdmin.equals("Admin"))

dao.createTables(); // fire up table creations (tickets / user

// tables)

/*

* else do something else if you like

*

*/

createMenu();

prepareGUI();

}

private void createMenu() {

/* Initialize sub menu items **************************************/

// initialize sub menu item for File main menu

mnuItemExit = new JMenuItem("Exit");

// add to File main menu item

mnuFile.add(mnuItemExit);

// initialize first sub menu items for Admin main menu

mnuItemUpdate = new JMenuItem("Update Ticket");

// add to Admin main menu item

mnuAdmin.add(mnuItemUpdate);

// initialize second sub menu items for Admin main menu

mnuItemDelete = new JMenuItem("Delete Ticket");

// add to Admin main menu item

mnuAdmin.add(mnuItemDelete);

// initialize first sub menu item for Tickets main menu

mnuItemOpenTicket = new JMenuItem("Open Ticket");

// add to Ticket Main menu item

mnuTickets.add(mnuItemOpenTicket);

// initialize second sub menu item for Tickets main menu

mnuItemViewTicket = new JMenuItem("View Ticket");

// add to Ticket Main menu item

mnuTickets.add(mnuItemViewTicket);

// initialize any more desired sub menu items below

/* Add action listeners for each desired menu item *************/

mnuItemExit.addActionListener(this);

mnuItemUpdate.addActionListener(this);

mnuItemDelete.addActionListener(this);

mnuItemOpenTicket.addActionListener(this);

mnuItemViewTicket.addActionListener(this);

// add any more listeners for any additional sub menu items if desired

}

private void prepareGUI() {

// initialize frame object

mainFrame = new JFrame("Tickets");

// create jmenu bar

JMenuBar bar = new JMenuBar();

bar.add(mnuFile); // add main menu items in order, to JMenuBar

bar.add(mnuAdmin);

bar.add(mnuTickets);

// add menu bar components to frame

mainFrame.setJMenuBar(bar);

mainFrame.addWindowListener(new WindowAdapter() {

// define a window close operation

public void windowClosing(WindowEvent wE) {

System.exit(0);

}

});

// set frame options

mainFrame.setSize(400, 400);

mainFrame.getContentPane().setBackground(Color.LIGHT_GRAY);

mainFrame.setLocationRelativeTo(null);

mainFrame.setVisible(true);

}

/*

* action listener fires up items clicked on from sub menus with one action

* performed event handler!

*/

@Override

public void actionPerformed(ActionEvent e) {

// TODO Auto-generated method stub

// implement actions for sub menu items

if (e.getSource() == mnuItemExit) {

System.exit(0);

} else if (e.getSource() == mnuItemOpenTicket) {

try {

// get ticket information

String ticketName = JOptionPane.showInputDialog(null, "Enter your name");

String ticketDesc = JOptionPane.showInputDialog(null, "Enter a ticket description");

// insert ticket information to database

Connection dbConn = DriverManager

.getConnection("jdbc:mysql://www.papademas.net/tickets?autoReconnect=true&useSSL=false"

+ "&user=fp411&password=411");

Statement statement = dbConn.createStatement();

int result = statement

.executeUpdate("Insert into jpapa_tickets(ticket_issuer, ticket_description) values(" + " '"

+ ticketName + "','" + ticketDesc + "')", Statement.RETURN_GENERATED_KEYS);

// retrieve ticket id number newly auto generated upon record

// insertion

ResultSet resultSet = null;

resultSet = statement.getGeneratedKeys();

int id = 0;

if (resultSet.next()) {

id = resultSet.getInt(1); // retrieve first field in table

}

// display results if successful or not to console / dialog box

if (result != 0) {

System.out.println("Ticket ID : " + id + " created successfully!!!");

JOptionPane.showMessageDialog(null, "Ticket id: " + id + " created");

} else {

System.out.println("Ticket cannot be created!!!");

}

} catch (SQLException ex) {

// TODO Auto-generated catch block

ex.printStackTrace();

}

} else if (e.getSource() == mnuItemViewTicket) {

// retrieve ticket information for viewing in JTable

try {

Connection dbConn = DriverManager

.getConnection("jdbc:mysql://www.papademas.net/tickets?autoReconnect=true&useSSL=false"

+ "&user=fp411&password=411");

Statement statement = dbConn.createStatement();

ResultSet results = statement.executeQuery("SELECT * FROM jpapa_tickets");

// Use JTable built in functionality to build a table model and

// display the table model off your result set!!!

JTable jt = new JTable(ticketsJTable.buildTableModel(results));

jt.setBounds(30, 40, 200, 300);

sp = new JScrollPane(jt);

mainFrame.add(sp);

mainFrame.setVisible(true); // refreshes or repaints frame on

// screen

statement.close();

How do I finish coding the code from above to fit stated from above?

Step by Step Solution

There are 3 Steps involved in it

Step: 1

blur-text-image

Get Instant Access to Expert-Tailored Solutions

See step-by-step solutions with expert insights and AI powered tools for academic success

Step: 2

blur-text-image_2

Step: 3

blur-text-image_3

Ace Your Homework with AI

Get the answers you need in no time with our AI-driven, step-by-step assistance

Get Started

Recommended Textbook for

More Books

Students also viewed these Databases questions

Question

2. What efforts are countries making to reverse the brain drain?

Answered: 1 week ago