Wednesday, November 14, 2007

Project Proposal

Class 12 Project Proposal - Rene Bartosh

Background

For many years my family has owned a share in a small private ski lodge (40 shareholders) in the town of Ohakune. For many of those years my parents have been the "booking officers" for the lodge. This has involved members telephoning to book and us recording their bookings on a paper-based system. They also have to telephone us again on a Thursday night to confirm bookings and check if any amendmants have been made. As dad works on a Thursday night, I often have to take or confirm these bookings.

About a year ago we were asked if we could take bookings via e-mail, but as this is an ineffective and unsuitable system to use for this purpose, we said this would not be possible. I then figured that the only way to make this work would be if it was web-based, with members being able to make the bookings themselves and us as the booking officers able to confirm these and re-shuffle if needed. At the same time, we could eliminate the confusing system of people filling out a form for payment. With a fully automated electronic system, we could generate invoices automatically and send them via e-mail, minimising costs.

Practical

Goals:

  1. To create a web-based booking and billing system for a small private ski lodge my family are members in.
  2. To gain the skills required to undertake goal 1, including but not limited to application design, planning and project management, database design (MySQL), web programming (PHP) and basic web design (XHTML/CSS)

At this stage I plan to implement to following features in the booking system:

Core features:

* Bookings based on room number, dates and member name

* Record number of members and guests staying (seperately, as per tax requirements)

* User/pass-based authentication system, or it could be based on access key code if that is easier. The same ID can be used as a reference for electronic payments

* Keep member database/addressbook up-to-date electronically, this is tied into authentication data in the database table

Finance features:

* On a set day of the week generate invoices from all bookings for that week and e-mail them to members. Record invoice in database against member

* Ability to check-off payments against member from internet banking, cheque etc.

* Block bookings from members with outstanding payments

Theoretical

  1. An account of the process undertaken for my practical component
  2. Background history on the Internet, the World Wide web and associated techonologies
  3. A look at how these "disruptive" technologies have changed our lives and the way we entertain and inform ourselves, communicate, manage our lives and conduct business.
  4. My predictions on what emerging technologies will have a significant inpact in the next 10 years

Steps Already Taken

  1. I have attended the AGM for the ski lodge and they have acknowledged my proposal to investigate an electronic booking and billing system.
  2. Talked with Mr. Stonehouse, he has agreed to be my supervisor.
  3. Discussed the project with two friends of mine, Daniel Faulknor (student from Taradale High School who is starting a Bachelor of Computing Systems at EIT next year) and Steven Gilberd (an ex-student from Raphael House). They have both designed and built web applications using the methods I wish to utilise and have agreed to assist me with my project. It is good to have an ex-Steiner student (Steve) to help me as he has an understanding of the Class 12 project having completed one himself.
  4. Started a blog (online journal) to keep a track of my progress, for both me and those assisting me.

Next Steps

  1. Find an advisor, a local professional in the web application developement field, who is prepared to help me with designing and planning my developement project, and to assist me along the way
  2. To buy or borrow books on the topics I need to learn (PHP, MySQL, project management and planning etc)
  3. To begin to plan and design the application with Steve, Dan and my advisors help
  4. To extend on my limited existing knowlege by beginning to work on my practical.

Sunday, November 4, 2007

Ideas on features

Just come home from the AGM. I have some ideas re: features now.

Core features:
  • Bookings based on room number, dates and member name
  • Record number of members and guests staying (seperately, as per tax requirements)
  • User/pass-based authentication system, or it could be based on access key code if that is easier. The same ID can be used as a reference for electronic payments
  • Keep member database/addressbook up-to-date electronically, this is tied into authentication data in the database table
Finance features:
  • On a set day of the week generate invoices from all bookings for that week and e-mail them to members. Record invoice in database against member
  • Ability to check-off payments against member from internet banking, cheque etc.
  • Block bookings from members with outstanding payments
That's all I can think of now, will add more things as I think of them.

Friday, November 2, 2007

Humble beginnings

So yesterday I choose Mr. Stonehouse as my supervisor. I have Daniel and Steve already for support but also want to find a local professional as a mentor.
Tomorrow I am heading to the Sunshine Ski Lodge AGM where hopefully I will be able to suss out what people actually want from an online booking system.

I have been talking to Steve tonight and he has set me up with a SVN repository which is a way of keeping track of all your code and the various versions you have. I have been reading about relational databases and normal form and am having a go at designing a database structure. I am still using 1NF (first normal form) and will use 2NF (second normal form) once I can see a use for a relational table. This is all with MySQL for the record. The book I have been reading is "PHP and MySQL For Dynamic Websites" by Larry Ullman, Peachpit Press.

Hey there

Welcome to my blog for my Class 12 Project. Hopefully I will keep a record of my progress here so I will have something to start with when it comes to writing my theory component.

My aim for this project is to design and create an online booking, membership management and invoicing system for a private ski lodge. My family has been the booking officers since forever and worked a paper-based system previously and the goal is to make the job easier and to tighten things up with regards to payment tracking, while giving people the ability to book online rather than though the phone.