Skip to content

Instantly share code, notes, and snippets.

@timjb
Forked from frostney/achievements.css
Created April 19, 2011 17:01
Show Gist options
  • Save timjb/928835 to your computer and use it in GitHub Desktop.
Save timjb/928835 to your computer and use it in GitHub Desktop.
/* You may want to style this to your personal need */
.achievement.status {
display: none;
position: absolute;
left: 50%;
bottom: -120px;
margin-left: -160px;
}
.achievement {
opacity: 1;
-moz-opacity: 1;
-webkit-opacity: 1;
-khtml-opacity: 1;
filter: alpha(opacity=100);
-ms-filter: "alpha(opacity=100)";
border: 1px solid #fff;
background-color: #000;
color: #ddd;
border-radius: 18px 18px 18px 18px;
-moz-border-radius: 18px;
-webkit-border-radius: 18px;
-moz-box-shadow: 0px 0px 8px #cccccc;
-webkit-box-shadow: 0px 0px 8px #cccccc;
-ms-box-shadow: 0px 0px 8px #cccccc;
box-shadow: 0px 0px 8px #cccccc;
background-image: url();
background-size: 64px;
background-repeat: no-repeat;
background-position: 6px 6px;
margin-left: 0px;
width: 320px;
height: 64px;
padding-left: 80px;
padding-bottom: 8px;
padding-right: 12px;
padding-top: 8px;
z-index: 30000001;
}
.achievement.locked {
background-color: #ccc;
color: #444;
}
.achievement h5 {
color: #fff;
font-weight: bold;
text-shadow: 0px 0px 8px #eee;
margin: 0;
}
.achievement.locked h5 {
color: #444;
font-weight: bold;
text-shadow: 0px 0px 4px #888;
}
.achievement p {
margin: 0;
}
var Achievement = function(text, description, icon) {
this.active = false;
this.text = text;
this.description = description;
this.icon = icon;
};
Achievement.prototype.render = function() {
return '<div class="achievement ' + (this.active ? '' : 'locked') + '">'
+ '<h5>' + i + '</h5>'
+ '<p>' + this.description + '</p>'
+ '</div>';
};
Achievement.prototype.unlock = function() {
this.active = true;
this.show();
};
Achievement.prototype.show = function() {
var el = $('<div class="achievement status">'
+ '<h5>Achievement unlocked</h5>'
+ '<p>' + this.text + '</p>'
+ '</div>');
// Bug: #achievement_box isn't defined in index.html
//if (this.icon) {
// $('#achievement_box').css('background-image', 'url('+achievement.icon+')');
//}
el
.appendTo(document.body)
.show()
.animate({ opacity: 1, bottom: '8px' }, 750)
.delay(5000)
.animate({ opacity: 0, bottom: '-120px' }, 750, 'linear', function() {
el.hide();
});
};
Achievement.fromJSON = function(obj) {
var neww = new Achievement();
for (var key in obj) {
neww[key] = obj[key];
}
return neww;
};
Achievement.prototype.toJSON = function() {
return this;
};
// Just-A-Normal-JavaScript-Object-Pattern
var AchievementsManager = {
storage: window.localStorage,
initialize: function(storageKey) {
this.storageKey = storageKey;
if (this.storage && this.storage[storageKey]) {
this.store = JSON.parse(this.storage[storageKey]);
for (var i in this.store) {
this.store[i] = Achievement.fromJSON(this.store[i]);
}
} else {
this.store = {};
}
},
register: function(achievement) {
if (!this.store[achievement.text]) {
this.store[achievement.text] = achievement;
}
},
getCount: function() {
var count = 0;
for (var i in this.store) count++;
return count;
},
getUnlockedCount: function() {
var count = 0;
for (var i in this.store) {
if (this.store[i].active) count++;
}
return count;
},
clear: function() {
// Reset active achievements
for (var i in this.store) {
this.store[i].active = false;
}
this.save();
},
list: function() {
// Locked achievements will be shown in a grey-ish color
var result = [];
for (var i in this.store) {
result.push(this.store[i].render());
}
return result.join('<br /><br />');
},
unlock: function(text) {
var achievement = this.store[text];
if (!achievement || achievement.active) return;
achievement.unlock();
this.save();
},
save: function() {
if (!this.storage) return;
var jsonStore = {};
for (var i in this.store) {
jsonStore[i] = this.store[i].toJSON();
}
this.storage[this.storageKey] = JSON.stringify(jsonStore);
}
};
<!doctype html>
<html>
<head>
<title>Achievements example</title>
<link rel="stylesheet" href="achievements.css" />
<style>
html { overflow: hidden; }
body { font-family: Verdana,Arial,Helvetica; }
#list {
display: none;
background-color: #eee;
height: 240px;
width: 100%;
}
</style>
</head>
<body>
<p>
<input type="button" id="achievement-button-1" value="Click for Achievement One" /><br />
<input type="button" id="achievement-button-2" value="Click for Achievement Two" />
</p>
<p><input type="button" id="clear-button" value="Clear achievements" /></p>
<p><input type="button" id="list-button" value="List achievements" /></p>
<div id="list"></div>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.1/jquery.min.js"></script>
<script src="achievements.js"></script>
<script>
$(document).ready(function() {
AchievementsManager.initialize('myGame');
AchievementsManager.register(new Achievement('I clicked a button', '...and I liked it'));
$('#achievement-button-1').click(function () {
AchievementsManager.unlock('I clicked a button');
});
AchievementsManager.register(new Achievement('Second button', 'This button is just for show.'));
$('#achievement-button-2').click(function () {
AchievementsManager.unlock('Second button');
});
$('#clear-button').click(function() {
AchievementsManager.clear();
})
$('#list-button').click(function() {
$('#list').toggle('slow');
$('#list').html(AchievementsManager.list());
})
});
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment