A critical vulnerability was discovered in React Server Components (Next.js). Our systems remain protected but we advise to update packages to newest version. Learn More

Sigve Fast
Mar 25, 2014
  1840
(0 votes)

The physical Publish Button

What do you do when you are in between projects and got nothing to do? You build a physical publish button using an Arduino of course!


The Arduino is an Open Source electronics prototyping platform (http://www.arduino.cc/). It basically enables you to program the physical world through sensors, buttons or anything else your heart desires. So using this I am proud to announce that the gap between the physical world and EPiServer is bridged!

I recommend checking out the official arduino blog for more cool projects this wonderful platform has been used for. http://blog.arduino.cc/

See it in action!


Inspired by the “AWSOME button” at Makezine: http://makezine.com/2011/04/08/the-awesome-button/

20130910_104845

Communication between the Arduino and javascript


The Arduino comes with a USB to Serial converter, which means you can communicate with it through the COM port. But how to execute javascript on a webpage every time the button is pressed?


I decided to make a Chrome extension and after some googeling I found this cross platform browser plugin for serial port communication from JavaScript https://github.com/billhsu/jUART

Chrome Extension
So the way this works is that the background page of the extension opens a connection to the COM port to listen for commands from the Arduino. Every time a command is received it passes it on to the contentscript in the tab that is currently open. The content script receives the command, and if the command is “Publish” it finds the publish button and simulate a click.

Just having the page published was kind of boring. So to give it a little more flare I added some fireworks to celebrate the birth/rebirth of a page. The fireworks code is just an adaptation of the code I found here: http://thecodeplayer.com/walkthrough/canvas-fireworks-tutorial


End notes
This was just the simplest and cheapest way of achieving the goal. This could have been done in many other fashions. There are Arduino boards small enough to fit inside the button or the communication could have been done with wifi, ethernet, bluetooth, infrared. You could also make it completely wireless by using batteries as a power source instead of getting power from the arduino board. Only the imagination sets a limit.

Hope you enjoyed this as much as I did making it.

Download full source code here: https://db.tt/x0JD21qC

For a more comprehensive walkthrough of the process download the complete guide here: https://db.tt/s67eUnnD

Mar 25, 2014

Comments

Please login to comment.
Latest blogs
A day in the life of an Optimizely OMVP: Learning Optimizely Just Got Easier: Introducing the Optimizely Learning Centre

On the back of my last post about the Opti Graph Learning Centre, I am now happy to announce a revamped interactive learning platform that makes...

Graham Carr | Jan 31, 2026

Scheduled job for deleting content types and all related content

In my previous blog post which was about getting an overview of your sites content https://world.optimizely.com/blogs/Per-Nergard/Dates/2026/1/sche...

Per Nergård (MVP) | Jan 30, 2026

Working With Applications in Optimizely CMS 13

💡 Note:  The following content has been written based on Optimizely CMS 13 Preview 2 and may not accurately reflect the final release version. As...

Mark Stott | Jan 30, 2026

Experimentation at Speed Using Optimizely Opal and Web Experimentation

If you are working in experimentation, you will know that speed matters. The quicker you can go from idea to implementation, the faster you can...

Minesh Shah (Netcel) | Jan 30, 2026