TwitterCounter for @bigclick_dean

dBlog.com.au

My Development Blog

Posts Tagged ‘ web design ’

I have been working on a clients project recently and really didn’t like the way the standard selects looked on the page and as we all know they are impossible to style consistently across all browsers. Being a jQuery fan I knew that there must have been an existing plugin to help…but alas there were many plugins that kind of worked, some of them didn’t include a full feature set, some didn’t work in all browsers and some didn’t degrade back to regular selects when needed (e.g. GoogleBot, Screen Readers, no JavaScript, etc).

I did however manage to find a reasonable good custom select over at http://www.adelaidewebdesigns.com/2008/08/01/adelaide-web-designs-releases-customselect-with-icons (even happened to be a fellow aussie!). It wasn’t perfect and it wouldn’t allow for multiple selects on the one page and the icons weren’t really what I needed. Reading through the comments I found that someone else (http://www.ildavid.com/dblog/selectcustomizer/) had made some modifications to allow for multiple selects on the one page. This was great I was getting closer to the solution that I needed, but there were still some issues like keyboard navigation and the ability to click anywhere in the window to close the select just like a regular select.

So I set out to further modify the code and put in some of my own requirements and then re-share it, I have managed to get the drop-down to close when you click outside it, I have also introduced keyboard navigation (up, down and enter). To get the keyboard navigation working I needed to use the scrollTo plugin to allow smooth scrolling up and down in the select.

There are still a few minor bugs that need to be fixed but it works enough for me, one bug is that in IE you need to click in the drop-down area if you don’t want the page to jump when using the keys.

I would also like to get the menu to activate when a user is tabbing around the site, but that’s a job for another rainy day!

$.fn.SelectCustomizer = function(){
    // Select Customizer jQuery plug-in
	// based on customselect by Ace Web Design http://www.adelaidewebdesigns.com/2008/08/01/adelaide-web-designs-releases-customselect-with-icons/
	// modified by David Vian http://www.ildavid.com/dblog
	// and then modified AGAIN be Dean Collins http://www.dblog.com.au
    return this.each(function(){
        var obj = $(this);
		var name = obj.attr('id');
		var id_slc_options = name+'_options';
		var id_icn_select = name+'_iconselect';
		var id_holder = name+'_holder';
		var custom_select = name+'_customselect';
        obj.after("<div id=\""+id_slc_options+"\" class=\"optionswrapper\"> </div>");
        obj.find('option').each(function(i){
            $("#"+id_slc_options).append("<div title=\"" + $(this).attr("value") + "\" class=\"selectitems\"><span>" + $(this).html() + "</span></div>");
        });
        obj.before("<input type=\"hidden\" value =\"\" name=\"" + this.name + "\" id=\""+custom_select+"\"/><div id=\""+id_icn_select+"\">" + this.title + "</div><div id=\""+id_holder+"\" class=\"selectwrapper\"> </div>").remove();
        $("#"+id_icn_select).click(function(a){
			if($("#"+id_holder).css('display') == 'none') {
				$("#"+id_holder).fadeIn(200);
				$("#"+id_holder).focus();
				a.stopPropagation();
				$(document).keypress(function(e) {
					if(!e) var e = window.event;
					e.cancelBubble = true;
					e.returnValue = false;
					if (e.stopPropagation) {
						e.stopPropagation();
						e.preventDefault();
					}
				});
				$(document).keyup(function(e) {

					if(e.which == 40) {
						var lastSelected = $("#"+id_holder+" .selectedclass");
						if(lastSelected.size() == 0) {
							var nextSelected =  $("#"+id_slc_options+" div:first:");
						} else {
							var nextSelected = lastSelected.next(".selectitems");
						}
						if(nextSelected.size() == 1) {
							lastSelected.removeClass("selectedclass");
							nextSelected.addClass("selectedclass");
							$("#"+custom_select).val(nextSelected.title);
           					$("#"+id_icn_select).html(nextSelected.html());
							var rowOffset = (nextSelected.offset().top - $("#"+id_holder).offset().top);
							if(rowOffset > 130) {
								$("#"+id_slc_options).scrollTo(($("#"+id_slc_options).scrollTop() + 27) +  "px");
							}
						}

					} else if(e.which == 38) {
						var lastSelected = $("#"+id_holder+" .selectedclass");
						var nextSelected = lastSelected.prev(".selectitems");
						if(nextSelected.size() == 1) {
							lastSelected.removeClass("selectedclass");
							nextSelected.addClass("selectedclass");
							$("#"+custom_select).val(nextSelected.title);
           					$("#"+id_icn_select).html(nextSelected.html());
							var rowOffset = (nextSelected.offset().top - $("#"+id_holder).offset().top);
							if(rowOffset > 0) {
								$("#"+id_slc_options).scrollTo(($("#"+id_slc_options).scrollTop() - 27) +  "px");
							}
						}
					} else if(e.which == 13) {
						$("#"+id_holder).fadeOut(250);
						$(document).unbind('keyup');
						$(document).unbind('keypress');
						$('body').unbind('click');
					}

				});
				$('body').click(function(){
					$("#"+id_holder).fadeOut(200);
					$('body').unbind('click');
					$(document).unbind('keyup');
					$(document).unbind('keypress');
				});
			} else {
				$("#"+id_holder).fadeOut(200);
				$('body').unbind('click');
				$(document).unbind('keyup');
				$(document).unbind('keypress');
			}

        });
        $("#"+id_holder).append($("#"+id_slc_options)[0]);
		$("#"+id_holder).append("<div class=\"selectfooter\"></div>");
		$("#"+id_slc_options+" > div:last").addClass("last");
        $("#"+id_holder+ " .selectitems").mouseover(function(){
            $(this).addClass("hoverclass");
        });
        $("#"+id_holder+" .selectitems").mouseout(function(){
            $(this).removeClass("hoverclass");
        });
        $("#"+id_holder+" .selectitems").click(function(){
            $("#"+id_holder+" .selectedclass").removeClass("selectedclass");
            $(this).addClass("selectedclass");
            var thisselection = $(this).html();
            $("#"+custom_select).val(this.title);
            $("#"+id_icn_select).html(thisselection);
            $("#"+id_holder).fadeOut(250);
			$(document).unbind('keyup');
			$(document).unbind('keypress');
			$('body').unbind('click');
        });
    });
}


You can see a working demo here

You can also download a full working example here

Popularity: 2% [?]

TDG Building came to Big Click Studios needing a new and fresh corporate identity and a website to promote their business on the Central Coast.

We started from scratch by creating a friendly/fun corporate identity encompassing different themes from within the industry (Technical Drawing, related colours, etc). Once we had our ideas down we continued to create a layout for the website along with a full stationary pack and designs for their work vehicle.

The client requested that they be able to update the content on the site and they also wanted to be able to easily add/edit projects that they had completed and also the ability to add a randomized testimonial section. As the client was coming from a non-technical background we had to ensure that the processes were easy to follow and that they were fail proof.

Our custom in-house CMS sat behind the website with ease and it allowed the client to easily manage their site and content while allowing us to offer an affordable solution with ease of maintenance for us.

In the end we delivered a complete corporate identity at an affordable price and the client had this to say:

“Karen and I would like to thank Big Click Studios for all their efforts in creating the website for TDG Building, we are extremely happy with the outcome.

Justin & Dean went the extra mile when asked to assist us with the design work for our business logo, office stationary and signage for the company ute, we gave the guys our ideas and requests for the designs and they were executed perfectly without delay. We also found the guys to be very helpful and patient with us considering that we were not very computer savvy when it came to website & design work!

We wanted to lift the profile of TDG Building and we feel that we have accomplished this through the assistance of Big Click Studios.

Many Thanks,

Troy & Karen Gruden
TDG Building. “

Here are some photos of the finished ute:

TDG Ute 1TDG Ute 2

Another happy customer!

Popularity: 1% [?]

Today is the day that Booksaround, an Australian Online Second hand bookstore is launched.

The CMS for BooksAround was written from scratch and utilises the CakePHP 1.2 framework for everything from inventory management through to payment processing and order fulfillment.

Why CakePHP you ask? Well CakePHP offers a strong yet flexible PHP framework to kickstart application development allowing for a shorter build time and a more affordable project for the client.

The BooksAround CMS allows staff to Add, Edit and Remove books from the database with the ease of integrated Barcode Scanning and automated lookups to ISBN databases such as Amazon and Book Finder. The CMS also allows staff to assign a book source (or Vendor) to each entry in the database and a commission percent, upon sale of a book the application will automatically calculate how much is oweing to the vendor from that sale and apply it to their account.

Payments are processed in real-time through PayPal with their Websites Payments Standard product and the items purchased are automatically marked as sold and Order/Shipping information is sent through to a designated staff member who deals with shipping fulfilment. By using PayPal we were able to completely automate the whole order process from start to finish to ensure that the end-user feels confident in placing an order and that the Site Owner can rest assured that the funds will be cleared before the order is processed.

Nearly every aspect of the site can be modified through the CMS allowing the Site Owner to take complete control of the site and its contents, adding/removing a book, changing vendor details, generating sales reports and even editing page content in real-time are available at their fingertips.

All in all the project was a pleasure to work on and the end result surpassed my expectations on the limited budget, CakePHP once again ame to the party by offering an amazing framework to start with and followed through with a solid, speedy and self contained end product.

So go on over and check out BooksAround.com, there are currently nearly 1,000 books available at a great price and you even receive a 10% discount by ordering online!

-Dean

Popularity: 1% [?]