<html>
<head>
<title>Buildings</title>
<link rel="stylesheet" href="css/style.css" />
</head>
<body>
<div id="intro"></div>
</div>
<!-- Templates -->
<script type="text/template" id="tpl-intro-list">
<h1>Welcome to the Building List thing.</h1>
<ul class="intro-list"></ul>
</script>
<script type="text/template" id="building-template">
<span class="building-name"><a href='#<%= url %>'><%= name %></a></span>
<span class="building-url"><%= url %></span>
<ol class="floors">
<% _.each(floors, function(floor) { %>
<li><%= floor.name %></li>
<% }); %>
</ol>
</script>
<!-- Libraries -->
<script type="text/javascript" src="lib/jquery.min.js"></script>
<script type="text/javascript" src="lib/underscore-1.3.1.min.js"></script>
<script type="text/javascript" src="lib/backbone-0.9.1.min.js"></script>
<!-- App init -->
<script type="text/javascript" src="aecc-data.js"></script>
<script type="text/javascript" src="aecc.js"></script>
<script type="text/javascript">
jQuery(function () {
window.introList.fetch();
});
</script>
</body>
</html>
body {
padding: 0;
margin: 0;
background: #3FA8C6;
background-image: linear-gradient(top, #3fa8c6 0%, #3fa8c6 0%, #399ab2 100%);
background-image: gradient(linear, left top, left bottom, color-stop(0%,#3fa8c6), color-stop(0%,#3fa8c6), color-stop(100%,#399ab2));
background-image: linear-gradient(top, #3fa8c6 0%,#3fa8c6 0%,#399ab2 100%);
background-image: linear-gradient(top, #3fa8c6 0%,#3fa8c6 0%,#399ab2 100%);
background-image: linear-gradient(top, #3fa8c6 0%,#3fa8c6 0%,#399ab2 100%);
background-image: linear-gradient(to bottom, #3fa8c6 0%,#3fa8c6 0%,#399ab2 100%);
color: #fff;
font-family: 'Doppio One', sans-serif;
text-shadow: 0 1px 0 rgba(0,0,0,.3);
line-height: 1.5;
font-smoothing: antialiased;
}
.wrapper {
width: 50%;
margin: 0 auto;
}
h1, h2, h3, h4, h5, h6 {
letter-spacing: -0.03em;
font-size: 2em;
}
a {
border-bottom: 1px solid #fff;
border-bottom: 1px solid rgba(255,255,255,0.7);
padding-bottom: 0.15em;
position: relative;
color: white;
text-decoration: none;
}
a:after {
content: '';
position: absolute;
height: 1px;
left: 0;
right: 0;
bottom: -2px;
background: rgba(0,0,0,.1);
}
a:hover {
color: #C0E3EC;
}
h1 {
margin: 0.667em 0 0;
padding-left: 0.5em;
text-align: left;
}
h2 {
font-size: 1.5em;
}
small {
margin-top: 1em;
display: block;
font-style: italic;
font-size: 0.667em;
}
p em {
font-style: none;
}
#welcome {
position: relative;
overflow: hidden;
padding-bottom: 1em;
padding-left: 20px;
}
#welcome > div {
padding-top: 1px;
}
#dave {
float: left;
margin-top: 3em
}
#welcome > h2 {
margin-top: 0.5em;
padding-left: 0.5em;
margin-bottom: 0;
}
.bubble p {
line-height: 22px;
}
.bubble {
background: rgba(255, 255, 255, 0.1);
border-color: rgba(255, 255, 255, 0.1);
padding: 0.667em 1em;
position: relative;
}
.bubble:after {
content: "";
position: absolute;
width: 0;
height: 0;
border-top: 20px solid transparent;
border-bottom: 20px solid transparent;
border-right: 20px solid white;
border-right-color: inherit;
top: 50px;
left: -20px;
}
#features {
margin: 0.444em 0 0;
clear: both;
}
#features > h2 {
margin: 0;
}
#features ol {
position: relative;
padding: 1em 0 1.5em;
background: rgba(0,0,0,.1);
border-color: rgba(0,0,0,.1);
margin: 0;
overflow: hidden;
list-style: none;
counter-reset: item;
}
#features li {
width: 30%;
padding: 0 1.5%;
float: left;
text-align: center;
margin-bottom: 1em;
}
#features li h2 {
display: block;
padding: 1em;
margin: 0.667em auto 1em;
font-size: 1em;
line-height: 1em;
text-align: center;
background: rgba(0,0,0,.1);
border-radius: 2em;
box-shadow: inset 0 0 1em rgba(0,0,0,.1), 0 2px 2px rgba(255,255,255,.1);
}
#next > div {
width: 45%;
float: left;
padding: 0 2.5%;
}
img {
z-index: 1;
transition: transform 2s ease-in-out;
transition: transform 2s ease-in-out;
transition: transform 2s ease-in-out;
transition: transform 2s ease-in-out;
transition: transform 2s ease-in-out;
position: relative;
}
img:active {
transform: rotate(1440deg) scale(1.2);
transform: rotate(1440deg) scale(1.2);
transform: rotate(1440deg) scale(1.2);
transform: rotate(1440deg) scale(1.2);
transform: rotate(1440deg) scale(1.2);
}
@media screen and (max-width: 1200px) {
.wrapper {
width: 80%;
}
}
@media screen and (max-width: 768px) {
.wrapper {
width: auto;
margin: 0;
}
#welcome {
margin-right: 2.5%;
}
}
@media screen and (max-width: 500px) {
.wrapper {
text-align: center;
}
#dave {
float: none;
}
#welcome {
padding: 0 1.5em;
margin: 0;
}
h1 {
text-align: center;
margin-bottom: 0;
padding-left: 0;
font-size: 1.8em;
}
#welcome > h2 {
margin-bottom: 0.667em;
}
.bubble {
text-align: center;
}
.bubble:after {
display: none;
}
#features li {
width: 47%;
}
#features li:last-child {
float: none;
clear: both;
margin: 0 auto;
}
#next > div {
float none;
width: auto;
}
}
(function($) {
// Models ///////////////////////////////////////////////
window.Building = Backbone.Model.extend({
initialize: function () {
this.floors = new Floors();
this.floors.parent = this;
}
});
window.Floor = Backbone.Model.extend({
initialize: function () {
this.rooms = new Rooms();
this.rooms.parent = this;
}
});
// The lowest level of hierarchy.
window.Room = Backbone.Model.extend({
});
// Collections //////////////////////////////////////////
window.Buildings = Backbone.Collection.extend({
model : Building,
url : function(){
return "/data.json"
}
});
window.Floors = Buildings.extend({
model: Floor
});
window.Rooms = Buildings.extend({
model: Room
});
// represents intro list of buildings
window.introList = new Buildings();
window.BuildingView = Backbone.View.extend({
className: 'building-list',
initialize: function () {
_.bindAll(this, 'render');
this.model.bind('change', this.render);
this.template = _.template($('#building-template').html());
},
render: function () {
var renderedContent = this.template(this.model.toJSON());
$(this.el).html(renderedContent);
return this;
}
});
// view specific to the intro panel
window.IntroBuilding = BuildingView.extend({
});
window.IntroBuildingList = Backbone.View.extend({
tagName: 'section',
className: 'intro-list',
initialize: function () {
_.bindAll(this, 'render');
this.template = _.template($('#tpl-intro-list').html());
this.collection.bind('reset', this.render);
},
render: function () {
var $introList,
collection = this.collection;
$(this.el).html(this.template({ }));
$introList = this.$('.intro-list');
collection.each(function (building) {
var view = new IntroBuilding({
model: building,
collection: collection
});
$introList.append(view.render().el)
});
return this;
}
});
window.BuildingsApp = Backbone.Router.extend({
routes: {
'': 'intro',
':id': 'blank'
},
initialize: function () {
this.introView = new IntroBuildingList({
collection: window.introList
});
},
intro: function () {
var $intro = $('#intro');
$intro.empty();
$intro.append(this.introView.render().el);
},
blank: function () {
var $intro = $('#intro');
$intro.empty();
$intro.text('hello');
}
});
$(function () {
window.App = new BuildingsApp();
Backbone.history.start();
});
})(jQuery);
Output
You can jump to the latest bin by adding /latest
to your URL
Keyboard Shortcuts
Shortcut | Action |
---|---|
ctrl + [num] | Toggle nth panel |
ctrl + 0 | Close focused panel |
ctrl + enter | Re-render output. If console visible: run JS in console |
Ctrl + l | Clear the console |
ctrl + / | Toggle comment on selected lines |
ctrl + ] | Indents selected lines |
ctrl + [ | Unindents selected lines |
tab | Code complete & Emmet expand |
ctrl + shift + L | Beautify code in active panel |
ctrl + s | Save & lock current Bin from further changes |
ctrl + shift + s | Open the share options |
ctrl + y | Archive Bin |
Complete list of JS Bin shortcuts |
JS Bin URLs
URL | Action |
---|---|
/ | Show the full rendered output. This content will update in real time as it's updated from the /edit url. |
/edit | Edit the current bin |
/watch | Follow a Code Casting session |
/embed | Create an embeddable version of the bin |
/latest | Load the very latest bin (/latest goes in place of the revision) |
/[username]/last | View the last edited bin for this user |
/[username]/last/edit | Edit the last edited bin for this user |
/[username]/last/watch | Follow the Code Casting session for the latest bin for this user |
/quiet | Remove analytics and edit button from rendered output |
.js | Load only the JavaScript for a bin |
.css | Load only the CSS for a bin |
Except for username prefixed urls, the url may start with http://jsbin.com/abc and the url fragments can be added to the url to view it differently. |