Shafe Shifter Just another guy on the internet.

9Nov/110

Time Tracking

A number of times clients ask how I track my time.  And each time I have to explain that I built some software specifically to meet my needs.    The software is a continual work in progress, the codebase is ancient and I hate working with it, although I still actively use it to track my time.   But, for those who are wondering here is a quick demo of what we use here at TNL Total Solutions.

I'm also going to make it available for download.  Just keep in mind, this was never intended for public consumption, some buttons don't do anything, there are annoying bugs that no one has gotten around to fixing and there is no documentation.  The demo above does explain how everything works (mostly).   Nonetheless, here is a copy of the current build for you to check out.

Download Link: Download TimeTrac v1.6

Cheers!
Brian

20Sep/110

Twitter Reacts To Facebook Upgrades.


This evening Facebook rolled out the latest in their upgrades.  Ever since Google Plus launched a few months ago Facebook has been rushing updates out the door, almost twice a week.  While we all know that people hate change and will complain about any change to anything they are used to, but CONSTANT change may be worst to the demise of the largest site on the internet.

Users want a good experience.  Users DO NOT want to have to go through pages of settings a few times a week because Facebook has changed them.  People visit their favorite social network to kill time and see what their friends are up to, NOT to spend extra time updating their settings or learning a completely new UI.  Previously I don't think this would have hurt Facebook.  People would complain and get used to it.  However this time, it has become apparent that this is a kneejerk reaction to Google+, and with as easy as Google+ is to use and how clean the Google+ UI is, I wouldn't be surprised if we start seeing a drop-off in Facebook usage.

In April 2008, Facebook overtook Myspace on Alexa, marking the beginnings of the end for the once top site on the internet.   Myspace responded by constantly rolling out new features that had obviously not been tested in all browsers, and outraging users.  During this time Facebook was busy staying consistent.  During that time the evolution of Facebook was happening on the developer side of things.  Facebook was fine-tuning their APIs and developers abilities to create apps for their platform.

The current state of Facebook feels like Myspace in the months following April 2008 and now with the new player on the block, it will be interesting to see how things play out.   Only time will tell.

It was pretty entertaining tonight watching people tweet about the Facebook updates, some real gems... Here are a few:

1Apr/110

12 Tips To Help You Communicate With Your Developers

This could be Your Developer

This could be your developer!

I Don't usually blog just to reproduce another thing I already saw, hense the slowness in new post. But I keep going back to this one.. It could be because I haven't slept in two days or maybe I keep going back because it's perfect...

The article is here: http://blogs.sitepoint.com/12-tips-for-better-developer-communication/
I'll Feel bad for reprinting it all but here is the best of it:

As an internet business owner you’ll need to face your developers. Yes, it’s scary — they probably look odd and speak a weird language. But you can’t avoid it. Here are my 12 tips to help you communicate with your development team…

1. Know Your Requirements…
How can you explain your requirements if you don’t know what they are? Developers are often faced with vague, wishy-washy briefs such as “it needs to be just like Facebook, only — er — like, different”.

A good developer will immediately begin to analyze your idea. They’ll ask questions. They’ll pose “what-if” scenarios. No one will expect you to have all the answers, but you should be able to discuss the majority of problems. If you can’t, you haven’t thought the project through. It’ll fail.

2. …and Document Them
Putting your requirements on paper may not be fun, but it’s necessary. Interface sketches and flowcharts will help you identify functionality, understand the technicalities and explain issues.

Consider hiring a systems analyst if you can’t do this yourself. They’ll ask identical questions, though.

3. Don’t Use Pseudo Code
If you’re not a programmer, please, please don’t attempt to write pseudo code — it won’t help. You’ll almost certainly over-complicate the easy stuff and gloss over the complexities. Your developer will need to reverse engineer your ‘code’ to determine what you actually wanted to achieve.

Pseudo code is useful when developers discuss algorithms with each other. There are few other reasons to use it.

4. Agile Programming is Not an Excuse for Poor Planning
Don’t think that rapid, agile software development excuses requirements analysis. It may reduce some of the up-front planning, but you’ll still need to make just as many decisions — if not more.

5. Be Clear and Decisive
Programmers make thousands of decisions on your behalf. However, they will inevitably have questions during the development process and failing to providing a definitive answer will halt progress.

As good manager, you’ll take responsibility, make a prompt decision, stick with it, and face the consequences if it’s wrong. Bad managers are unavailable, avoid answering the question, seek opinions from 57 other (disinterested) colleagues, then blame the developer for delays or bad decisions.

6. Stay Ahead of Your Developers
Good programming teams will have a development plan — components and features will be implemented in order. Understand that plan and prepare accordingly:
know what decisions need to be made prior to implementation
prepare dummy data or test cases
organize the production of content, graphics, videos or other media.

7. Avoid Scope Changes
Changing scope can destroy a project and put a deadline at risk. You may have seen a cool feature elsewhere, but it doesn’t need to be implemented immediately.
By all means, have an informal discussion with your developer. State it’s something you’re considering for a later version — don’t distract them from the agreed tasks or demand immediate attention.

8. Don’t Assume Anything
One of the worst statements made by non-developers is: “Hey, we should implement feature X. It’s easy, right — it’ll only take a few hours.”
It might take a few minutes. It might take months. It might be impractical. It might be technically impossible. You don’t know — if you did, you wouldn’t require a developer to implement it for you.

9. Set Realistic Deadlines
Like anyone, developers work best when they have an agreed deadline. However, those deadlines should be set by the developer themselves or someone with programming abilities and in-depth technical knowledge of the system.  Setting an arbitrary or unrealistic deadline will result in a bug-ridden monstrosity which takes far longer to fix.

10. Alter Your Schedule When Necessary
Application development is complex. Development estimates are just that — estimates. Programmers will encounter unforeseen problems and changes to the project scope (no matter how hard you try to avoid them).

The schedule will inevitably change as the project progresses. Do not be afraid to modify the completion date accordingly.

11. Test Your Own Application
Don’t rely on your developers or other people to test your application. It’s your vision: test it yourself at every opportunity.

That said, be aware you may be running unfinished code and check progress against the development schedule. Don’t send emails ranting about feature Y not working when that code hasn’t been started.

12. Stay Involved and Keep Communicating
Most people lose interest in their own projects as time goes on. If you can’t remain enthusiastic, don’t expect it from others.

Contact your developers on a regular basis. You don’t necessarily need to organize formal progress meetings — just show your face and ask how things are going.

That said, avoid pestering them. Your project won’t be completed quicker if you call your developer every 10 minutes to ask “are we there yet?” Let your developer do their job.

Ok maybe that is all of it but it is awesome, and you should read all of Craig Buckler's other stuff...

::Awaiting DMCA takedown notices::

26Jan/110

Yahoo Branding Fail

yahoo

The brand managers at Yahoo are genius... (sarcasm). I just got an email from Yahoo that started out like this:

Dear Yahoo! Calendar and Yahoo! Notepad Customer,
Yahoo! Calendar Beta will soon be renamed "All-New Yahoo! Calendar," and Yahoo! Notepad Beta will soon be renamed "All-New Yahoo! Notepad."....

Seems worthy of a mass email, don't ya think?

30Apr/100

Bad Translations

A friend of mine bought an ipod clone online. He got it from http://www.mp3playerbuying.com (which isn't loading for me now)..

The place was in china. The paypal account he paid to was a US account from a different company, the confirmation came from yet a different company and it was shipped from yet another company.

This thing is very cool for the cheap price tag, but it goes overboard trying to be a clone. In fact when you turn it on it has a slightly altered apple logo that pops up on the screen.

The the most awesome part was the instruction booklet. This has to be the funniest thing I've seen in quite some time. The translation is so incredibly funny I had to scan it and post it up.. So check it out

Front:
http://www.brian-shaffer.com/pics/front-small.png

Back:
http://www.brian-shaffer.com/pics/back-small.png

If you want the full resolution scans they are here: http://www.brian-shaffer.com/pics/

Do check these out.. they had me laughing for hours...

Stop SOPA