Monday, December 5, 2016

5 Ruby Resources for the Hour of Code

hour-of-code-logo

Over the last couple of years, I've been an active participant in the Hour of Code. If you're unfamiliar with the Hour of Code, here's a blurb from its site:

The Hour of Code is a global movement reaching tens of millions of students in 180+ countries. Anyone, anywhere can organize an Hour of Code event. One-hour tutorials are available in over 45 languages. No experience needed. Ages 4 to 104.

In a nutshell, the HoC is a week in December where nerds like you and me have a chance to go into a classroom and lead a programming-related event. It is incredibly fulfilling. I cherish the times I've had in the classroom and I look forward to doing it again this week. I strongly encourage you to find a local school and offer up some of your time. Often, you don't even have to go to the school, as they can set up Hangouts or Skype calls with the class. I've gone the hangout route before, and while it wasn't as much fun as being in the classroom, it is still enjoyable and greatly appreciated by the teachers and students.

Continue reading %5 Ruby Resources for the Hour of Code%


by Glenn Goodrich via SitePoint

Launchday

opl-small

Tidy little One Pager previewing a new product landing page builder called Launchday. I quite enjoy this minimal approach to announcing a new product - brief overview, Beta Signup button links to MailChimp, About button links to Medium (to also increase social engagement) and a very clear demo video. No need to scroll on this One Pager:)

by Rob Hope via One Page Love

Get Started With Google Play Games Services

The “Most Loved” One Page Websites from November 2016

one-page-love-hosting-reviews-bh-unlimitedNovember’s “Most Loved” One Page website round-up is brought to you by hosting provider, Bluehost.

Bluehost is the most affordable hosting option to host your One Page websites. They have an incredible $2.95/month deal exclusive to One Page Readers where you can host your website with 50GB diskspace and unlimited bandwidth. They also throw in a free domain!

If you want to receive these “Most Loved” awards in your inbox each month, subscribe to our Inspiration Newsletter.

Below are the 9 One Page websites we awarded “Most Loved” in November – hope you enjoy!


Rogie (Portfolio)

Dazzling One Page portfolio literally bursting with color for designer/dev, Rogie. The Single Page website has so much flavor including an intro confetti animation, a colorful background wavy gradient (that moves!) and a beautifully slick portfolio arrangement that slides projects into a central device. Easy contender for One Pager of the year. Final little shout-out to this awesome use of an .ie domain:)

Launch Website
Full Review


Senz & Senz Wifi (Landing Page, Product)

Impressive parallax scrolling Landing Page promoting ‘Senz & Senz Wifi’ – a new range of floor heating thermostats by Pentair. Such a brilliant first impression how you scroll and the header animation “swipes” the actual product along with the background parallax “product waterfall”. Also a nice touch how the product color changes as you scroll to the second section. It lacks a store location map in the footer (vs the email request they have) but a stellar landing page no doubt.

Launch Website
Full Review


Jason Briscoe (Case Study, Personal, Portfolio)

Beautiful and unique One Page website for designer, Jason Briscoe. Each link in his bio zooms to a deeper level case-study layout with big imagery and clean typography. That Noe Display font is gorgeous. Great to see this is built on WordPress too!

Launch Website
Full Review


Lionel Durimel (Portfolio)

Impressive AJAX-loading One Page portfolio for French Art Director, Lionel Durimel. Once you load up a project you can continue to scroll through his entire fleet of work. Projects also feature a unique “angled” screenshot animation that is scroll-sensitive. Make sure you check out the other quality One Pagers by Lionel we’ve featured in the past.

Launch Website
Full Review


Grim London (Informational)

Discover the dark side of ‘Grim London’ in this fascinating, interactive One Page website. They have packed an impressive about of facts and folk stories in a large map on London. Lovely touch with the spooky mist flowing over the dark color scheme.

Launch Website
Full Review


Enod (Restaurant)

Lovely One Pager for French restaurant ‘Enod’ featuring big typography and good whitespace. Nice little touch with the sonar effect in the section mentioning all ingredients are local sourced within a 50km radius.

Launch Website
Full Review


Election Rewind (Informational)

Election Rewind is a bite-sized recap of key moments throughout the election – all presented is a slick One Pager. An excellent reference to presenting a ton of information in a Single Page website using cards correlated with a timeline. Cheers for the build notes, Middleman looks solid!

Launch Website
Full Review


Recess in Varanasi (Experimental, Photography)

Wonderful, interactive One Pager by Tapan Babbar where he takes us up the river Ganges to explore the sights and sounds of Varanasi, India. Each stop has a video of the games he played with the locals, really capturing the mood of the location. Lovely touch allowing visitors to choose row or motor as their journey preference:)

Launch Website
Full Review


7 Tests for Gaucher Disease Management (Informational)

Gorgeously designed informational One Pager to educate patients and physicians about Gaucher Disease management best practices. Awesome addition providing a PDF checklist for users to download, as well as email sign up functionality for annual reminders. Respect.

Launch Website
Full Review


Hope you enjoyed these beautiful One Pagers from November! Big love to hosting provider Bluehost for sponsoring the round up:)


by Rob Hope via One Page Love

Let's Go: Golang Concurrency, Part 2

Overview

One of the unique features of Go is the use of channels to communicate safely between goroutines. In this article, you'll learn what channels are, how to use them effectively, and some common patterns. 

What Is a Channel?

A channel is a synchronized in-memory queue that goroutines and regular functions can use to send and receive typed values. Communication is serialized through the channel.

You create a channel using make() and specify the type of values the channel accepts:

ch := make(chan int)

Go provides a nice arrow syntax for sending and receiving to/from channels:

You don't have to consume the value. It's OK just to pop up a value from a channel:

<-ch

Channels are blocking by default. If you send a value to a channel, you'll block until someone receives it. Similarly, if you receive from a channel, you'll block until someone sends a value to the channel.  

The following program demonstrates this. The main() function makes a channel and starts a go routine called that prints "start", reads a value from the channel, and prints too. Then main() starts another goroutine that just prints a dash ("-") every second. Then, it sleeps for 2.5 seconds, sends a value to the channel and sleeps 3 more seconds to let all goroutines finish.

This program demonstrates very well the blocking nature of the channel. The first goroutine prints "start" right away, but then is blocked on trying to receive from the channel until the main() function, which sleeps for 2.5 seconds and sends the value. The other goroutine just provides a visual indication of the flow of time by printing a dash regularly every second. 

Here is the output:

Buffered Channels

This behavior tightly couples senders to receivers and sometimes is not what you want. Go provides several mechanisms to address that.

Buffered channels are channels that can hold a certain (predefined) number of values so that senders don't block until the buffer is full, even if no one is receiving. 

To create a buffered channel, just add a capacity as a second argument:

ch := make(chan int, 5)

The following program illustrates the behavior of buffered channels. The main() program defines a buffered channel with a capacity of 3. Then it starts one goroutine that reads a buffer from the channel every second and prints, and another goroutine that just prints a dash every second to give a visual indication of the progress of time. Then, it sends five values to the channel. 

What happens at runtime? The first three values are buffered by the channel immediately, and the main() function blocks. After a second, a value is received by the goroutine, and the main() function can push another value. Another second goes by, the goroutine receives another value, and the main() function can push the last value. At this point, the goroutine keeps receiving values from the channel every second. 

Here is the output:

Select

Buffered channels (as long as the buffer is big enough) can address the issue of temporary fluctuations where there aren't enough receivers to process all the sent messages. But there is also the opposite problem of blocked receivers waiting for messages to process. Go has got you covered. 

What if you want your goroutine to do something else when there are no messages to process in a channel? A good example is if your receiver is waiting for messages from multiple channels. You don't want to block on channel A if channel B has messages right now. The following program attempts to compute the sum of 3 and 5 using the full power of the machine. 

The idea is to simulate a complex operation (e.g. a remote query to a distributed DB) with redundancy. The sum() function (note how it's defined as nested function inside main()) accepts two int parameters and returns an int channel. An internal anonymous goroutine sleeps some random time up to one second and then writes the sum to the channel, closes it, and returns it.

Now, main calls sum(3, 5) four times and stores the resulting channels in variables ch1 to ch4. The four calls to sum() return immediately because the random sleeping happens inside the goroutine that each sum() function invokes.

Here comes the cool part. The select statement lets the main() function wait on all channels and respond to the first one that returns. The select statement operates a little like the switch statement.

Sometimes you don't want the main() function to block waiting even for the first goroutine to finish. In this case, you can add a default case that will execute if all channels are blocked.

A Web Crawler Example

In my previous article, I showed a solution to the web crawler exercise from the Tour of Go. I've used goroutines and a synchronized map. I also solved the exercise using channels. The complete source code for both solutions is available on GitHub.

Let's look at the relevant parts. First, here is a struct that will be sent to a channel whenever a goroutine parses a page. It contains the current depth and all URLs found on the page.

The fetchURL() function accepts a URL, a depth, and an output channel. It uses the fetcher (provided by the exercise) to get the URLs of all the links on the page. It sends the list of URLs as a single message to the candidate's channel as a links struct with a decremented depth. The depth represents how much further should we crawl. When depth reaches 0, no further processing should take place.

The ChannelCrawl() function coordinates everything. It keeps track of all the URLs that were already fetched in a map. There is no need to synchronize access because no other function or goroutine is touching. It also defines a candidate channel that all the goroutines will write their results to.

Then, it starts invoking parseUrl as goroutines for each new URL. The logic keeps track of how many goroutines were launched by managing a counter. Whenever a value is read from the channel, the counter is decremented (because the sending goroutine exits after sending), and whenever a new goroutine is launched, the counter is incremented. If the depth gets to zero then no new goroutines will be launched, and the main function will keep reading from the channel until all goroutines are done.

Conclusion

Go's channels provide a lot of options for safe communication between goroutines. The syntax support is both concise and illustrative. It's a real boon for expressing concurrent algorithms. There is much more to channels than I presented here. I encourage you to dive in and get familiar with the various concurrency patterns they enable.


by Gigi Sayfan via Envato Tuts+ Code

50 Years of Rudolf Heltzel

opl-small

Minimal One Pager promoting a past event celebrating 50 years of incredible work by gold and silversmith, Rudolf Heltzel. The Single Page website features an interesting info icon that appears (bottom-left) once you scroll a bit. When clicked it simply provides a useful detail overview about the event.

by Rob Hope via One Page Love

How to Use Offline Events Ads From Facebook

ag-facebook-offline-events-ads-600

Do you use Facebook ads to promote your physical store or event? Want to know if your ads are driving foot traffic? Facebook now lets you track in-store or live event visits that occur after people see or engage with your Facebook ads. In this article, you’ll discover how to track conversions on Facebook ads [...]

This post How to Use Offline Events Ads From Facebook first appeared on .
- Your Guide to the Social Media Jungle


by Ana Gotter via