<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/rss2full.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.feedburner.com/~d/styles/itemcontent.css"?><rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" version="2.0">

<channel>
	<title>Marvel Internet Group blog » marvelsites</title>
	
	<link>http://blog.marvelig.com</link>
	<description>Just another WordPress weblog</description>
	<pubDate>Tue, 05 Jan 2010 03:06:36 +0000</pubDate>
	<generator>http://wordpress.org/?v=2.7.1</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/rss+xml" href="http://feeds.feedburner.com/marvelsitesBlog" /><feedburner:info uri="marvelsitesblog" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><item>
		<title>Coding JustRosters - Day 1 - Setting up CakePHP</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/uUDGwLQOPM4/206</link>
		<comments>http://blog.marvelig.com/coding-justrosters-day-1-setting-up-cakephp/206#comments</comments>
		<pubDate>Thu, 19 Mar 2009 00:25:12 +0000</pubDate>
		<dc:creator>Paul Chiu</dc:creator>
		
		<category><![CDATA[marvelsites]]></category>

		<category><![CDATA[bazaar]]></category>

		<category><![CDATA[cakephp]]></category>

		<category><![CDATA[code]]></category>

		<category><![CDATA[database]]></category>

		<category><![CDATA[justrosters.com]]></category>

		<category><![CDATA[startup]]></category>

		<category><![CDATA[version control]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=206</guid>
		<description><![CDATA[From this week I will be starting a multi-part series on the coding of JustRosters, touching specifically on the challenges and lessons learnt throughout the experience. Our journey starts on a February afternoon (02/02/2009) at 3pm. The first task that needed to be completed was the installation of a basic CakePHP install.
Installing CakePHP is quite [...]]]></description>
			<content:encoded><![CDATA[<p>From this week I will be starting a multi-part series on the coding of <a href="http://www.justrosters.com/">JustRosters</a>, touching specifically on the challenges and lessons learnt throughout the experience. Our journey starts on a February afternoon (02/02/2009) at 3pm. The first task that needed to be completed was the installation of a basic CakePHP install.</p>
<p>Installing CakePHP is quite a simple process and simply involves downloading it from the <a href="http://cakephp.org/">CakePHP </a>page, after a donation, then uploading it on to the server. In our case it is our dedicated U.S. server that will host this application to ensure maximum load capacity and lowest latency for our target demographic. After CakePHP is extracted to a desired location we commit it into version control using <a href="http://bazaar-vcs.org/">Bazaar Version Control</a> (bzr). Bzr is a distributed VCS similar to Git, however it is cross platform and has a much simpler command set.</p>
<p>Once we were able to see the CakePHP default page it was time to analyze the database models. Aulay, being the founder of JustRosters had the best idea of what the application should do and designed the database by himself. My job was to just make sure the table and column names matched the CakePHP conventions so that extra configuration settings would not need to be set on the CakePHP generated models. I also took the time to change any columns whose data types could be improved (int to tinyint) as well as start indexing foreign keys.</p>
<p>With only one hour our project foundation had been laid. Although it is not an exciting event our use of RAD frameworks makes it a much more relaxing process than previous projects where at least a week had to be spent gathering together various pieces of software that managed our database access, email access, templating, etc.</p>
<p>The next post will focus on setting up user registration, validation, as well as user logging in and out. Stay tuned for more.</p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/uUDGwLQOPM4" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/coding-justrosters-day-1-setting-up-cakephp/206/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/coding-justrosters-day-1-setting-up-cakephp/206</feedburner:origLink></item>
		<item>
		<title>JustRosters - Launched and taking sign ups!</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/Xbkh6PJOktc/196</link>
		<comments>http://blog.marvelig.com/justrosters-launched-and-taking-sign-ups/196#comments</comments>
		<pubDate>Tue, 03 Mar 2009 03:38:37 +0000</pubDate>
		<dc:creator>Aulay Macaulay</dc:creator>
		
		<category><![CDATA[justrosters.com]]></category>

		<category><![CDATA[marvelig]]></category>

		<category><![CDATA[marvelpromote]]></category>

		<category><![CDATA[marvelsites]]></category>

		<category><![CDATA[webhostingmarvel]]></category>

		<category><![CDATA[launch]]></category>

		<category><![CDATA[rostering]]></category>

		<category><![CDATA[schedule]]></category>

		<category><![CDATA[startup]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=196</guid>
		<description><![CDATA[Just a quick post to let everyone know Marvel Internet Group&#8217;s first in-house web start-up, JustRosters, has  officially launched!
JustRosters is  a web application developed to make the creation and distribution of staff  rosters easier, faster and more accurate. For a full list of features and a  free trial, head over the [...]]]></description>
			<content:encoded><![CDATA[<p>Just a quick post to let everyone know Marvel Internet Group&#8217;s first in-house web start-up, <a href="http://www.justrosters.com/">JustRosters</a>, has  officially launched!</p>
<p><a href="http://www.justrosters.com/">JustRosters</a> is  a web application developed to make the creation and distribution of staff  rosters easier, faster and more accurate. For a full list of features and a  free trial, head over the <a href="http://www.justrosters.com/">JustRosters  website</a>.</p>
<p><strong>Huge thanks</strong> to Alan, (lead designer) and Paul, (lead  developer) for helping make this happen. </p>
<p>For those following the <a href="http://blog.marvelig.com/building-our-first-web-start-up/18">8 part build</a>,  I will write part 6 and 7 soon.</p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/Xbkh6PJOktc" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/justrosters-launched-and-taking-sign-ups/196/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/justrosters-launched-and-taking-sign-ups/196</feedburner:origLink></item>
		<item>
		<title>Part 5.5 - Educating clients on how to use a new application</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/iz95H1VDxFY/188</link>
		<comments>http://blog.marvelig.com/educating-clients-on-how-to-use-a-new-application/188#comments</comments>
		<pubDate>Sun, 01 Mar 2009 23:57:31 +0000</pubDate>
		<dc:creator>Aulay Macaulay</dc:creator>
		
		<category><![CDATA[marvelsites]]></category>

		<category><![CDATA[contact]]></category>

		<category><![CDATA[help]]></category>

		<category><![CDATA[howto]]></category>

		<category><![CDATA[justrosters.com]]></category>

		<category><![CDATA[questions]]></category>

		<category><![CDATA[support]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=188</guid>
		<description><![CDATA[Users on free trials will quickly dismiss an application  when they are presented with a problem they cannot figure out for themselves.  They do this because the only investment they have made by using a free trial  is time, and the thought wasting more time is too much for most. 
For most [...]]]></description>
			<content:encoded><![CDATA[<p>Users on <a href="http://www.justrosters.com/pages/pricing">free trials</a> will quickly dismiss an application  when they are presented with a problem they cannot figure out for themselves.  They do this because the only investment they have made by using a free trial  is time, and the thought wasting more time is too much for most. </p>
<p>For most developers, they solve this issue by writing how-tos  and FAQs. FAQ pages are one thing I have never quite understood&#8230; if a question  is being asked <em>frequently</em>, why isn’t it  explained where the client first needed the answer?</p>
<p><strong>Anyway, the approach  to help / training that we find works:</strong></p>
<ul>
<li>Build a simple, easy-to-use application in the  first place.
</li>
<li>  Fill your sales copy with print screens and screen  casts of the actual application. This way the user is becoming familiar with  the interface before they have even signed up.
</li>
<li>  Add a small ‘?’ icon with a <strong>brief</strong> help text on mouse over, next to <strong>every</strong> input box. They are  easily accessed and indentified by confused users, and ignored by others.</li>
<li>Create a screen cast walkthrough of the entire system;  present it to new users when they login for the first time.</li>
<li>In the early days, look at every support request  as if it is a FAQ; tweak the &#8216;?&#8217; texts and screen casts where needed.</li>
</ul>
<p>All the steps above can never completely replace the need  for a <a href="http://www.justrosters.com/contact">good old contact page</a>; but they can sure reduce its need.</p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/iz95H1VDxFY" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/educating-clients-on-how-to-use-a-new-application/188/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/educating-clients-on-how-to-use-a-new-application/188</feedburner:origLink></item>
		<item>
		<title>Customer service email management with Gmail</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/enLuInUhYPM/172</link>
		<comments>http://blog.marvelig.com/customer-service-email-management-with-gmail/172#comments</comments>
		<pubDate>Tue, 17 Feb 2009 23:07:22 +0000</pubDate>
		<dc:creator>Paul Chiu</dc:creator>
		
		<category><![CDATA[marvelig]]></category>

		<category><![CDATA[marvelsites]]></category>

		<category><![CDATA[customer service]]></category>

		<category><![CDATA[email]]></category>

		<category><![CDATA[gmail]]></category>

		<category><![CDATA[support]]></category>

		<category><![CDATA[ticket]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=172</guid>
		<description><![CDATA[Customer service email management can often be problematic for companies that offer email based support for their clients. Marvel Internet Group is responsible for handling customer service email messages of some applications that we have developed for clients. One such application has over 1400 user&#8217;s support request to manage; we do this with just two [...]]]></description>
			<content:encoded><![CDATA[<p>Customer service email management can often be problematic for companies that offer email based support for their clients. <a href="http://www.marvelig.com">Marvel Internet Group</a> is responsible for handling customer service email messages of some applications that we have developed for clients. One such application has over 1400 user&#8217;s support request to manage; we do this with just two staff, before it is even time for lunch.</p>
<p>For some it can be difficult to co-ordinate efforts to ensure that a customer&#8217;s inbound enquiries are resolved as quickly as possible. Using a highly structured system  for so few staff members will lead to increased cost per response and slow down overall response time. A system that is too simple will mean co-ordination failures leading to confused or neglected customers. </p>
<p><a href="http://www.marvelig.com">Marvel Internet Group</a>&#8217;s solution to this problem is to use a <a href="http://www.gmail.com">Gmail</a> account for customer service email management. This is achieved by creating a single Gmail address for all customer service support requests. With <a href="http://mail.google.com/support/bin/answer.py?answer=118708&amp;hl=en">Gmail&#8217;s labelling feature</a> we can quickly label emails based on source so that the support person can be focused on supporting a single application or all applications&#8217; customers. The general work flow that prevents neglect of customers as well as ensuring a streamlined support process is to check, label, and action. This involves having the first person to view the mail account go through all mail and either archive, label another staff&#8217;s name, or take action on an email. Then as other staff members check the account they can see which items require their attention.</p>
<p>Prior to implementation of this customer service email management system we had difficulties delegating and following through with customer enquiries that fell out of the support staff&#8217;s field of expertise. Using labels such as &#8220;waiting&#8221;, &#8220;todo&#8221;, and &#8220;complete&#8221; each request can be delegated and tracked with ease with staff members in and out of the company. The result of utilizing this customer service system is greatly reduced time spent on support as items are either actioned, delegated, or waiting. Finally an end-of-week or end-of-month review of all incomplete messages prevents any request from falling through the cracks.  </p>
<p>To try this for yourself simply create or forward your support emails to a free Gmail account and let your staff understand the simple work flow of: <strong>check, label, action</strong>. Having your support request come from <a href="http://blog.marvelig.com/the-benefits-of-custom-support-forms/72">custom support forms</a> will also save you even more time!</p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/enLuInUhYPM" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/customer-service-email-management-with-gmail/172/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/customer-service-email-management-with-gmail/172</feedburner:origLink></item>
		<item>
		<title>Part 5: Building the front-end website</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/bivAzobUL8U/132</link>
		<comments>http://blog.marvelig.com/part-5-building-the-front-end-website/132#comments</comments>
		<pubDate>Mon, 16 Feb 2009 23:51:40 +0000</pubDate>
		<dc:creator>Aulay Macaulay</dc:creator>
		
		<category><![CDATA[justrosters.com]]></category>

		<category><![CDATA[marvelig]]></category>

		<category><![CDATA[marvelsites]]></category>

		<category><![CDATA[front-end]]></category>

		<category><![CDATA[web design]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=132</guid>
		<description><![CDATA[It is about 1month since we started building JustRosters,  and what a month it has been! Paul, Alan and I are working on it full time at  the moment, and hope to have it complete launched in around 2weeks. The  original plan shows building the front-end website as step 6, but in [...]]]></description>
			<content:encoded><![CDATA[<p>It is about 1month since we started building <a href="http://www.justrosters.com/">JustRosters</a>,  and what a month it has been! Paul, Alan and I are working on it full time at  the moment, and hope to have it <span style="text-decoration: line-through;">complete</span> launched in around 2weeks. The  original plan shows building the front-end website as step 6, but in reality  this was happening at the same time as the code writing. We finished the  front-end ‘store front’ first, so it’s time to share some of our experience and  results (<strong>print screens can be found after the fold</strong>).</p>
<p>We had already established a basic look and feel while  designing the back-end mock-ups, so the front-end needed to become an extension  of that. Like any web entrepreneur, I spent <span style="text-decoration: line-through;">a few hours</span> half my life  looking at other ‘successful’ sites with a similar target market, noting down design  and navigation elements I liked. I built a basic sitemap in notepad, and  started writing copy for each page. <strong>The sitemap went like this:</strong></p>
<ul>
<li>Homepage</li>
<li>Why JustRosters?</li>
<li>Pricing and signup</li>
<li>Order pages (linked from pricing and signup page)</li>
<li>Affiliate program</li>
<li>Login page x 3 (for administrators, staff, affiliates)</li>
<li>Contact us page</li>
<li>Any legal pages I needed + a sitemap, 404 page etc.</li>
</ul>
<p>If you take out all the ‘standard’ web application pages  I was left with 4. The homepage, the ‘why’ page, the pricing page and the  affiliate program page. These had to be ‘conversion kings’, so I was intent on  making them perfect.</p>
<p>It’s funny, most people think a designer is responsible for  what <span style="text-decoration: line-through;">a website</span> ANY type of interface ends up looking like, but I think the  copy writer has an equal part in the end product. The words we chose ultimately  decide how each page can fit together. After what felt like an eternity of writing  and re-writing sales copy, (ok, it was only about 4days), I got Alan onto the  designs.</p>
<p>Nothing builds excitement quite like watching a front-end  site come together in front of you. I was extremely impressed by how it was  unfolding, and found it hard to stop hitting the refresh button every 5mins  Alan was working on it. <strong>Here are some  screen shots of what we came up with:</strong></p>
<table class="content-table" border="0" width="100%">
<tbody>
<tr>
<td><a title="Front page" rel="lightbox[screens]" href="http://blog.marvelig.com/wp-content/uploads/2009/02/front-big.jpg"><img class="alignnone size-medium wp-image-144" title="Front page" src="http://blog.marvelig.com/wp-content/uploads/2009/02/front-thumb1.png" alt="" width="200" height="125" /></a></td>
<td><a title="Pricing page" rel="lightbox[screens]" href="http://blog.marvelig.com/wp-content/uploads/2009/02/price-big.jpg"><img class="alignnone size-medium wp-image-146" title="price-thumb" src="http://blog.marvelig.com/wp-content/uploads/2009/02/price-thumb.png" alt="" width="200" height="125" /></a></td>
<td><a title="Order page" rel="lightbox[screens]" href="http://blog.marvelig.com/wp-content/uploads/2009/02/order-big.jpg"><img class="alignnone size-medium wp-image-148" title="order-thumb" src="http://blog.marvelig.com/wp-content/uploads/2009/02/order-thumb.png" alt="" width="200" height="125" /></a></td>
</tr>
<tr>
<td><a title="Affiliate program page" rel="lightbox[screens]" href="http://blog.marvelig.com/wp-content/uploads/2009/02/affiliate-big.jpg"><img class="alignnone size-medium wp-image-150" title="affiliate-thumb" src="http://blog.marvelig.com/wp-content/uploads/2009/02/affiliate-thumb.png" alt="" width="200" height="125" /></a></td>
<td><a title="Login page" rel="lightbox[screens]" href="http://blog.marvelig.com/wp-content/uploads/2009/02/login.png"><img class="alignnone size-medium wp-image-152" title="login-thumb" src="http://blog.marvelig.com/wp-content/uploads/2009/02/login-thumb.png" alt="" width="200" height="125" /></a></td>
<td><a title="Contact us page" rel="lightbox[screens]" href="http://blog.marvelig.com/wp-content/uploads/2009/02/contact-big.jpg"><img class="alignnone size-medium wp-image-154" title="contact-thumb" src="http://blog.marvelig.com/wp-content/uploads/2009/02/contact-thumb.png" alt="" width="200" height="125" /></a></td>
</tr>
</tbody>
</table>
<p>There is still a lot to do between scripting the  home-page demo movie, having the legal guys go over the legal stuff and getting  all the copy re-checked by <a href="http://www.editeam.com.au/">a cool little Aussie start-up called Editeam</a>.  The semi-completion of the front-end has provided a huge psychological  boost for the team and an opportunity to go get some feedback from some of  the people I contacted way back in <a href="http://blog.marvelig.com/justrosters-brainstorming-research/32">stage 1</a>.</p>
<p>Hour logs show about 40 hours spent on copy writing and  75 on design. It might sound like a lot for a 15 page site, but I figure the difference between a 4%  conversion rate and a 2% conversion rate could be the difference between becoming a millionaire or just a 500thousandaire <img src='http://blog.marvelig.com/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/bivAzobUL8U" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/part-5-building-the-front-end-website/132/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/part-5-building-the-front-end-website/132</feedburner:origLink></item>
		<item>
		<title>JustRosters - Rapid development through the use of a company code library</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/cQdSkSqgjm0/125</link>
		<comments>http://blog.marvelig.com/justrosters-rapid-development-through-the-use-of-a-company-code-library/125#comments</comments>
		<pubDate>Wed, 11 Feb 2009 23:26:20 +0000</pubDate>
		<dc:creator>Paul Chiu</dc:creator>
		
		<category><![CDATA[marvelsites]]></category>

		<category><![CDATA[api]]></category>

		<category><![CDATA[cakephp]]></category>

		<category><![CDATA[jquery]]></category>

		<category><![CDATA[justrosters.com]]></category>

		<category><![CDATA[libraries]]></category>

		<category><![CDATA[programming]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=125</guid>
		<description><![CDATA[JustRosters is an internal project for us here at Marvel Internet Group. It is a side project that is commercially unproven and therefore a risky investment for the company. With that in mind it is crucial for us to be able to complete the project as quickly as possible in terms of both man hours [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.justrosters.com/" target="_blank">JustRosters</a> is an internal project for us here at <a href="http://www.marvelig.com/">Marvel Internet Group</a>. It is a side project that is commercially unproven and therefore a risky investment for the company. With that in mind it is crucial for us to be able to complete the project as quickly as possible in terms of both man hours and actual calendar days. To help us achieve this we decided to comb through our previous  work and build a reusable PHP library of our most commonly used functions. This collection of loosely coupled functions allows us to easily enhance any code base; belonging to either a client or Marvel Internet Group.</p>
<p>Our code library is split into three parts. One library contains global functions that are included in <a href="http://book.cakephp.org/view/48/Bootstrapping-CakePHP">Cake PHP&#8217;s bootstrap file</a>, which is loaded right after the configuration file and before everything else. We currently place debugging and some custom date/time manipulation functions in here so that it does not have to be duplicated elsewhere. Another part of the library is converted into a <a href="http://book.cakephp.org/view/64/Creating-Custom-Components">Cake PHP component</a>. The custom component allows us to reuse convenience functions that are needed inside our controllers, such as permissions management, emailing with <a href="http://phpmailer.codeworxtech.com/">PHPMailer</a>, <a href="http://www.digitaljunkies.ca/dompdf/">PDF generation</a>, etc. The remaining parts of our library are turned into a custom helper that performs view related formatting. </p>
<p>In total we have reused about 700 lines of code with the three files combined. Using the general rule of thumb that a programmer will produce about 100 lines of quality code per day we practically <strong>shaved seven days off our development time before we even started</strong>. The cycle of library building will continue and expand with <a href="http://www.justrosters.com/">JustRosters</a>. Being one of our most Javascript heavy projects we are also writing a substantial amount of reusable Javascript code that can be combined into another library, or into jQuery plugins, that can be used by the development community as well as our future clients.</p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/cQdSkSqgjm0" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/justrosters-rapid-development-through-the-use-of-a-company-code-library/125/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/justrosters-rapid-development-through-the-use-of-a-company-code-library/125</feedburner:origLink></item>
		<item>
		<title>Delivering more for our clients in less time by utilizing the CakePHP framework</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/p92EYNzXndQ/115</link>
		<comments>http://blog.marvelig.com/more-for-less-using-cakephp/115#comments</comments>
		<pubDate>Mon, 09 Feb 2009 04:24:34 +0000</pubDate>
		<dc:creator>Paul Chiu</dc:creator>
		
		<category><![CDATA[marvelsites]]></category>

		<category><![CDATA[cakephp]]></category>

		<category><![CDATA[development]]></category>

		<category><![CDATA[framework]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=115</guid>
		<description><![CDATA[The process of conceptualizing, designing, and implementing web applications is a complex one. It requires both the client and the development company to come together and share enough domain knowledge to enable constructive communications about the project. To reduce the impact of mis-communicated ideas developers need to be agile, which involves being able to quickly [...]]]></description>
			<content:encoded><![CDATA[<p>The process of conceptualizing, designing, and implementing <a href="http://www.marvelsites.com/products-services/custom-development.html" target="_blank">web applications</a> is a complex one. It requires both the client and the development company to come together and share enough domain knowledge to enable constructive communications about the project. To reduce the impact of mis-communicated ideas developers need to be agile, which involves being able to quickly confirm, implement, and get feedback on ideas. Therefore, any tool that helps us reduce the time required to implementing common functionality helps our clients greatly. It is with this in mind that Marvel Internet Group decided to standardize all projects on a development framework. That framework is <a href="http://www.cakephp.org/">CakePHP</a>.</p>
<p>CakePHP is a framework started in 2005 that is compatible with PHP, a ubiquitous web development programming language that is used by more than <a href="http://www.php.net/usage.php">20 million websites</a>, that follows the &#8220;model, view, controller&#8221; <a href="http://st-www.cs.uiuc.edu/users/smarch/st-docs/mvc.html">design pattern</a>. CakePHP allows us to implement client-specific features using common functions that have been heavily tested and debugged by the entire CakePHP community. CakePHP offers polished database abstraction, templating, AJAX, caching, testing, and security features that can be implemented in client applications. <strong>Those pre-built features allows us to have a solid foundation from which we can quickly realize our clients&#8217; vision in the form of a working prototype</strong>. </p>
<p>The productivity gains that comes with CakePHP would not be so great if a lot of time had to be invested in learning it. That is why CakePHP&#8217;s excellent <a href="http://book.cakephp.org/">documentation</a> and active <a href="http://bakery.cakephp.org/">developer community</a> means that we can quickly train programmers to become familiar with and productive with CakePHP in a matter weeks. </p>
<p>A real world case demonstrating the benefits of CakePHP comes from our experience with ICEF Online 2.0&#8217;s development. For this project we managed to take the version 1.0 program, which was developed without a framework, and re-code it from the ground up with 20+ additional core features in three months using one full time and one part time programmer. The part time programmer had never used CakePHP before and was able to implement our ordering system with less than one week training. </p>
<p>The product delivery time was a great improvement over version 1.0, which took well over six months using the same amount of human resources. We also saw improvement in the size of the code base, shrinking it from 137 megabytes to just under 50 megabytes. <strong>With all things being equal we have basically managed to half  quoted times in our client application development and create a much higher quality application.</strong> This was possible because we were able to focus on what was important to the client, instead of worrying about the low level mechanics of the application.</p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/p92EYNzXndQ" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/more-for-less-using-cakephp/115/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/more-for-less-using-cakephp/115</feedburner:origLink></item>
		<item>
		<title>Fixed headers and columns</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/NqFaB8D6Vbs/100</link>
		<comments>http://blog.marvelig.com/fixed-headers-and-columns/100#comments</comments>
		<pubDate>Fri, 06 Feb 2009 01:39:56 +0000</pubDate>
		<dc:creator>Alan Attwater</dc:creator>
		
		<category><![CDATA[marvelsites]]></category>

		<category><![CDATA[css]]></category>

		<category><![CDATA[grid]]></category>

		<category><![CDATA[html]]></category>

		<category><![CDATA[table]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=100</guid>
		<description><![CDATA[Recently I started creating the mock-ups for the JustRosters application. Part of this application is a calendar table that needed fixed headers and columns, with scrollable content area to fit in a restricted space. This concept can be seen in programs like in Microsoft Excel or similar spreadsheet programs, how the row and column numbers [...]]]></description>
			<content:encoded><![CDATA[<p>Recently I started creating the mock-ups for the <a href="http://www.justrosters.com/" target="_blank">JustRosters</a> application. Part of this application is a calendar table that needed fixed headers and columns, with scrollable content area to fit in a restricted space. This concept can be seen in programs like in Microsoft Excel or similar spreadsheet programs, how the row and column numbers remain along the top and side at all times. After a bit of research, we found out that this hasn’t been done in HTML / CSS before, only full JavaScript applications with big budgets (like Google Spreadsheet). Since this wasn’t our case, we were after an open source solution, but this wasn’t easy to find or achieve.</p>
<p>After what felt like a million Google searches, we finally came across a script that would have done exactly what we wanted it to do, only to find out that it was incomplete. It had some of the features we needed, fixed header, fixed columns and scrolling of the inner data cells while remaining lined up. It just wasn&#8217;t cross browser compatible, did not support fluid width columns or row heights. I installed the script and after fixing it up for a few days, I got it to work&#8230;.. sort of. </p>
<p>What we needed was to have the data table take up maximum width and height of the browser content area, but doing this broke the script or the cells didn’t line up. After a lot of trial and error, tweaking the JavaScript and the css, I was finally able to create a fixed header and column table with dynamic resizing based on browser window size, row count and column count. The resulting table can be <a href="http://www.justrosters.com/new.php">viewed here for now</a>, and will be integrated into the finished <a href="http://www.justrosters.com/" target="_blank">JustRosters staff scheduling application</a>. When I get a chance I will post code snippets.</p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/NqFaB8D6Vbs" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/fixed-headers-and-columns/100/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/fixed-headers-and-columns/100</feedburner:origLink></item>
		<item>
		<title>The benefits of custom support forms over simple email forms or direct email links</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/4luyB6VEoGg/72</link>
		<comments>http://blog.marvelig.com/the-benefits-of-custom-support-forms/72#comments</comments>
		<pubDate>Wed, 28 Jan 2009 23:59:12 +0000</pubDate>
		<dc:creator>Paul Chiu</dc:creator>
		
		<category><![CDATA[marvelig]]></category>

		<category><![CDATA[marvelsites]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=72</guid>
		<description><![CDATA[With any web application there is usually a learning curved involved for the end users before they are familiar enough with the concepts and work flow to explore the application on their own. Especially when a new system is introduced to replace an existing one it can be very difficult for the end user to [...]]]></description>
			<content:encoded><![CDATA[<p>With any <a href="http://www.marvelsites.com/">web application</a> there is usually a learning curved involved for the end users before they are familiar enough with the concepts and work flow to explore the application on their own. Especially when a new system is introduced to replace an existing one it can be very difficult for the end user to adjust. That is when support requests start flowing in.</p>
<p>In our experience support emails can become rather difficult when the user does not provide adequate detail about what they are doing, or who they are. The lack of information means a lot of time is spent waiting on user clarification. The time spent identifying the problem often takes longer than providing the solution. This is where investing the time needed to create a custom support form comes in.</p>
<p style="center;">In a custom support form that we implemented for <a href="http://www.icefonline.com/">ICEF Online</a> (1,500+ people use it almost daily), the form auto-embed hidden values identifying the user&#8217;s account, the page they were on before they loaded the support form, as well as browser information and screen size; all of which help us diagnose problems far quicker than if we just relied on plain email, or even an &#8216;off the shelf&#8217; support ticket system.</p>
<p><a rel="lightbox" href="http://blog.marvelig.com/wp-content/uploads/2009/01/header1.png"><img class="size-full wp-image-85 aligncenter" src="http://blog.marvelig.com/wp-content/uploads/2009/01/header1.png" alt="" width="500" height="115" /></a></p>
<p>For common cases where the reply just requires usage instructions, a custom support form can completely eliminate the need to wait for a user to reply with details of what they were trying to achieve. For more complex scenarios we are able to completely re-create the user experience for testing by reproducing user results with the same browser, operating system, and input values. The limits of how much information your support staff have access to diminishes to almost zero once the basic system is put in place, which is a very low cost given the customer satisfaction returns that can be achieved.</p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/4luyB6VEoGg" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/the-benefits-of-custom-support-forms/72/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/the-benefits-of-custom-support-forms/72</feedburner:origLink></item>
		<item>
		<title>Hello world</title>
		<link>http://feedproxy.google.com/~r/marvelsitesBlog/~3/-jXdMmSqttM/68</link>
		<comments>http://blog.marvelig.com/hello-world/68#comments</comments>
		<pubDate>Wed, 28 Jan 2009 23:29:10 +0000</pubDate>
		<dc:creator>Alan Attwater</dc:creator>
		
		<category><![CDATA[marvelig]]></category>

		<category><![CDATA[marvelsites]]></category>

		<guid isPermaLink="false">http://blog.marvelig.com/?p=68</guid>
		<description><![CDATA[Hi, I&#8217;m Alan Attwater, the lead designer for Marvel Internet Group. I&#8217;ll be posting general information about the design and development of our online projects, as well tips and tricks on technologies like Typo3 and CSS.
I work on a variety of projects at any one time, designing both shop front websites and web applications. I [...]]]></description>
			<content:encoded><![CDATA[<p>Hi, I&#8217;m Alan Attwater, the lead designer for <a href="http://www.marvelig.com/">Marvel Internet Group</a>. I&#8217;ll be posting general information about the design and development of our online projects, as well tips and tricks on technologies like Typo3 and CSS.</p>
<p>I work on a variety of projects at any one time, designing both <a href="http://www.marvelsites.com/products-services/typical-websites.html">shop front websites</a> and <a href="http://www.marvelsites.com/products-services/custom-development.html">web applications</a>. I recently completing the design and development of the new Marvel websites in the Typo3 CMS, <strong>only 4,000+ lines of CSS!</strong></p>
<p>I&#8217;ve also started on the interface designs for a new in-house project called JustRosters.com, turning <strong>VERY VERY</strong> <a href="http://blog.marvelig.com/part-2-sketches-and-feature-refinement/53">rough sketches</a> into attractive, working interface mockups. The biggest challenge so far has been getting the main interface to fit dynamically on any screen size, whilst maintaining it&#8217;s main functionality and useability. Sounds easy, but calendars never seem easy to work with. I&#8217;ve made good use of the Javascript user interface library jQuery, to provide the main interface functionality, while maintaining fast page load times.</p>
<p>Anyway, better get back into it, after all, those <a href="http://blog.marvelig.com/part-2-sketches-and-feature-refinement/53">interface sketches</a> are very rough, and <a href="http://blog.marvelig.com/blogging-for-marvel/26">Paul</a> is hanging out to start coding!</p>
<img src="http://feeds.feedburner.com/~r/marvelsitesBlog/~4/-jXdMmSqttM" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://blog.marvelig.com/hello-world/68/feed</wfw:commentRss>
		<feedburner:origLink>http://blog.marvelig.com/hello-world/68</feedburner:origLink></item>
	</channel>
</rss>

