Thursday, 26 September 2013
How to embed a Bootstrap carousel within another Bootstrap Carousel
As I type this, I can almost hear you asking, why on earth would anyone want to do this? Well, in my defence, I was working to a design and it makes sense in the context. We had a number of different features (the outer carousel) with a number of different images and videos associated with each feature (the inner carousel). Unfortunately, the normal Bootstrap carousel has naming conflicts if you try to do this, so I had to write a different version of the carousel that prevented these conflicts.
Just in case anyone else has to work with a sadistic designer, I have made the source code available on GitHub at https://github.com/littleowllabs/nested_boostrap_carousel
Enjoy!
Tuesday, 24 September 2013
Recruiting front-enders
My personal preference is for full-stack development. I always try and keep abreast of emerging technologies in whatever area of programming they might arise. However, full-stack developers tend to come with a premium in terms of their cost, so at the company I am currently working, they are looking for a front-end developer who has the ability to take some crazy designs and turn them into reality. Unfortunately, we are struggling to find this person. There are 2 problems we are encountering. One is the location - we are in the middle of the countryside, but near enough to London to have many potential candidates sucked that way. The other is the type of people we are seeing. They tend to be people with big corporate backgrounds who have used a framework religiously for the last 5-6 years and now want to go contracting. Unfortunately, that kind of background and mindset doesn't show an aptitude for implementing the kind of cutting edge designs we are working on.
I was asked to come up with a description of the person we wanted and I came up with the following:
I think that for the specific projects we are looking for we would ideally like someone with the following experience:What do you think? Can I improve upon that as a description? Will it attract the right type of people? Most importantly, do you know anyone who might be willing to come and work in the Oxfordshire countryside who has those types of skills? Please get in touch if you do!
I doubt that we will find a candidate who has experience in all these areas, particularly as some of them are quite new and emerging, but if they have strong demonstrable experience (either professional or personal) in some of these or in other cutting-edge front-end technologies (e.g. angular/ember, websockets or other HTML5 stuff) then that would show the kind of willingness to experiment that I think we are going to need for projects such as this.
- Working with video in HTML5
- CSS animations/transitions
- Using canvas in HTML5
- Creating pixel-perfect layouts
Thursday, 5 September 2013
Tuesday, 13 August 2013
Heroku pipelines
After an incident this morning when I did a
git push staging
instead of a
git push development
I decided it was time to look in more depth at the heroku pipelines lab feature, and after a quick look I am very pleased I did. It allows me to just have one heroku remote which I have at the bottom of the pipeline, with staging and (eventually) production further downstream. When we are ready to release to the client for user acceptance testing then we can simply call:
heroku pipeline:promote
which sends the development version to staging. No need to retain separate development and staging branches in git now, we can just have the one which we promote.
Tuesday, 6 August 2013
Bootstrap dropdowns with checkboxes
I needed to put some checkboxes in a dropdown (we're using Bootstrap so I based it on that) but I didn't want it to close when one was clicked and I wanted the button to update to reflect the values given so I came up with the following:
Works nicely!
Works nicely!
Friday, 2 August 2013
Chrome preloading webpages
I am probably very late to this particular party, but I just noticed that as I typed in my local web server address into Chrome that a hit was appearing on my web server before I clicked enter, and before any content was loaded onto my screen. It appears that this is a setting in Chrome (Settings > Advanced settings > Predict network actions to improve page load performance).
I was very impressed, but I did wonder if it might have some effect on analytics if the user starts typing in an address but changes their mind - does it run javascript on the page prior to load? Can analytics tell if it is a pre-render or a full render?
I was very impressed, but I did wonder if it might have some effect on analytics if the user starts typing in an address but changes their mind - does it run javascript on the page prior to load? Can analytics tell if it is a pre-render or a full render?
Tuesday, 30 July 2013
Switching between Mongoid and ActiveRecord
I have recently been working on 2 projects, one using Mongoid with MongoDB and one using ActiveRecord with Postgres. Working so closely with the two pretty much alongside each other I have come to the following conclusions:
- MongoDB should not be used for relational systems. It might seem obvious, but even if the min body of an application is not relational, there are often relational parts to it, and that can really counteract the benefits. Such relations might include user ownership, tagging, etc.
- I like the declaration of fields within the model - no need to make external schemas.
- Having said the above, I also like the discipline that creating migrations forces on you. You can really check each change you make to models and refine them, whereas the flexibility of Mongoid can allow indiscipline.
I think that, for the moment, in most projects I would still stick to a RDBMS unless there was an obvious document-style structure to the whole data that could really benefit from MongoDB.
Monday, 29 July 2013
default_url_options[:host] fails with http://
This is something that gets me every single time. If you set up your code as follows (in the config/environments/development.rb file:
config.action_mailer.default_url_options = {host: 'http://localhost:3000'}
then any links you have in there will not work correctly as they will be pointing to http://http://localhost:3000, which will break email clients. Instead you have to do it without the protocol and it all works fine:
config.action_mailer.default_url_options = {host: 'localhost:3000'}
config.action_mailer.default_url_options = {host: 'http://localhost:3000'}
then any links you have in there will not work correctly as they will be pointing to http://http://localhost:3000, which will break email clients. Instead you have to do it without the protocol and it all works fine:
config.action_mailer.default_url_options = {host: 'localhost:3000'}
Wednesday, 17 July 2013
IE7 and IE8 text rendering problem
We recently changed the design of an internal site I was working on for BMW and suddenly the text started rendering less clearly in IE7 and IE8. We were using a webfont, but that had not changed at all between the designs. After much investigation I realised that we had introduced a gradient behind the text. This was implemented in IE using:
filter: progid:DXImageTransform.Microsoft.gradient
Turning these gradients off fixed the rendering problem. We therefore reverted back to using images for IE:
background-image: url( 'background_image.png' );
So, it appears it is not a good idea to place text using a webfont over gradients created using the gradient filter in Internet Explorer.
filter: progid:DXImageTransform.Microsoft.gradient
Turning these gradients off fixed the rendering problem. We therefore reverted back to using images for IE:
background-image: url( 'background_image.png' );
So, it appears it is not a good idea to place text using a webfont over gradients created using the gradient filter in Internet Explorer.
Tuesday, 16 July 2013
Hash default array
Trying to do something in Ruby on Rails I just encountered the following problem:
I just had this:
hash = Hash.new([])
for...
hash[key] << value
end
to make the default value a new array. I have since realised that this does not work as it uses the same array for each key in the hash. Meaning that every key returns the same array with all the values.
The way I worked round it was as follows:
hash = {}
for...
arr = hash[group._id] || []
arr << value
hash[group._id] = arr
end
I just had this:
hash = Hash.new([])
for...
hash[key] << value
end
to make the default value a new array. I have since realised that this does not work as it uses the same array for each key in the hash. Meaning that every key returns the same array with all the values.
The way I worked round it was as follows:
hash = {}
for...
arr = hash[group._id] || []
arr << value
hash[group._id] = arr
end
Friday, 12 July 2013
Rspec route testing with Mongoid
This may be obvious to others, but I have just been having a lot of frustration trying to test routes with a rails application written using Mongoid.
The problem was that the id of the object being created is not a string. The id therefore needs to converted to a string to make it work.
The problem was that the id of the object being created is not a string. The id therefore needs to converted to a string to make it work.
Thursday, 6 June 2013
FilePicker.io
I have been mainly using Heroku for hosting recently. For some reason it seems that a lot of my recent projects have required an image gallery, file uploads or some combination of the two. I have usually used a combination of Carrierwave and Fog for things like that in the past, but it does not work very well on Heroku as it has a 30 second timeout, so if you need to upload large files or process images once you have uploaded them (e.g. Carrierwave versions) then it will time out more often than not.
To get over this problem I have been experimenting with FilePicker.io, and up to this point I am favourably impressed. Initially I was a bit concerned about having to use a FilePicker.io address for images, but the application uses S3 for storage so it is possible to get round that by specifying your own file path and filename in the storage options, then using CloudFront to serve up those images to your page.
The service also allows for conversion, which is done via a request to their services, so it is possible to create and store a number of different versions if, for example, you need a thumbnail, a carousel image and a large image.
No problems thus far, and the team seems very responsive. I have had a couple of support questions to which the CEO responded personally and very quickly.
My major concern with relying on a service like this is that it may eventually be "acquihired", and that all the effort we put into developing for it will be wasted, but, to be honest, the service is so easy to use that I am not very concerned about the effort involved.
To get over this problem I have been experimenting with FilePicker.io, and up to this point I am favourably impressed. Initially I was a bit concerned about having to use a FilePicker.io address for images, but the application uses S3 for storage so it is possible to get round that by specifying your own file path and filename in the storage options, then using CloudFront to serve up those images to your page.
The service also allows for conversion, which is done via a request to their services, so it is possible to create and store a number of different versions if, for example, you need a thumbnail, a carousel image and a large image.
No problems thus far, and the team seems very responsive. I have had a couple of support questions to which the CEO responded personally and very quickly.
My major concern with relying on a service like this is that it may eventually be "acquihired", and that all the effort we put into developing for it will be wasted, but, to be honest, the service is so easy to use that I am not very concerned about the effort involved.
Tuesday, 4 June 2013
Introduction to me
Having been an avid reader of blogs for many years, I have always had an interest in doing my own, but I have never really felt I had a lot to say. I now realise that I would find it useful as an aide-memoire, but if anyone else gets any benefit from my ramblings then I will be very happy.
This blog will focus on my professional life, but may have some random posts on other things I find interesting.
I am currently the lead (and usually only) developer at Little Owl Labs, where I develop web applications and websites both for myself and for an ever-increasing list of clients.
In addition to my private work, I also hawk myself out as a developer for hire, and have worked for a number of clients ranging from digital and marketing agencies such as Juice (where I am currently working) and The Raft, as well as some public sector organisations (most recently Reigate and Banstead Borough Council).
The technologies I use most regularly these days are Ruby on Rails, Javascript, Postgres/MySQL or Mongoid, and obviously HTML and CSS. I host mainly on Heroku, but have also used both EC2 and Linux servers I have provisioned myself.
Prior to my new life as an internet applications developer I worked for a company called Visokio where we wrote desktop application software. I joined the company when it began in 2001 and stayed there until 2010 - being part of the company going from a bunch of four guys in the corner of someone else's office to a company that was supplying many blue chip companies in a range of sectors. I started as a Java developer, but later on became responsible for the Flash/Actionscript side of the development - work that was recognised with the Internet World Innovator of the Year Award in 2006.
Finally, I should probably also mention StudentProofreading.co.uk, which began many years ago (in 2006) as a little side project, but which is now the leading provider of academic proofreading services in the UK. I am still managing director of the company, and am currently undertaking a rewrite of the back-end systems.
Given my fairly diverse professional life, this blog will probably jump from topic to topic, from business matters to deep technical issues. I hope that doesn't put you off!
This blog will focus on my professional life, but may have some random posts on other things I find interesting.
I am currently the lead (and usually only) developer at Little Owl Labs, where I develop web applications and websites both for myself and for an ever-increasing list of clients.
In addition to my private work, I also hawk myself out as a developer for hire, and have worked for a number of clients ranging from digital and marketing agencies such as Juice (where I am currently working) and The Raft, as well as some public sector organisations (most recently Reigate and Banstead Borough Council).
The technologies I use most regularly these days are Ruby on Rails, Javascript, Postgres/MySQL or Mongoid, and obviously HTML and CSS. I host mainly on Heroku, but have also used both EC2 and Linux servers I have provisioned myself.
Prior to my new life as an internet applications developer I worked for a company called Visokio where we wrote desktop application software. I joined the company when it began in 2001 and stayed there until 2010 - being part of the company going from a bunch of four guys in the corner of someone else's office to a company that was supplying many blue chip companies in a range of sectors. I started as a Java developer, but later on became responsible for the Flash/Actionscript side of the development - work that was recognised with the Internet World Innovator of the Year Award in 2006.
Finally, I should probably also mention StudentProofreading.co.uk, which began many years ago (in 2006) as a little side project, but which is now the leading provider of academic proofreading services in the UK. I am still managing director of the company, and am currently undertaking a rewrite of the back-end systems.
Given my fairly diverse professional life, this blog will probably jump from topic to topic, from business matters to deep technical issues. I hope that doesn't put you off!
Subscribe to:
Posts (Atom)