-
-
Save timjb/928835 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* 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; | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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); | |
} | |
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!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