mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-29 18:22:41 +01:00
Do something cooler
Summary: It seemed like a good idea at the time. Test Plan: Uh huh. Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin Differential Revision: https://secure.phabricator.com/D3352
This commit is contained in:
parent
1b7f6655c9
commit
f8e28fae01
4 changed files with 214 additions and 0 deletions
|
@ -469,6 +469,13 @@ celerity_register_resource_map(array(
|
|||
'disk' => '/rsrc/image/menu_texture.png',
|
||||
'type' => 'png',
|
||||
),
|
||||
'/rsrc/image/nyan.gif' =>
|
||||
array(
|
||||
'hash' => '03c40be4e004e6468d62b503756a587e',
|
||||
'uri' => '/res/03c40be4/rsrc/image/nyan.gif',
|
||||
'disk' => '/rsrc/image/nyan.gif',
|
||||
'type' => 'gif',
|
||||
),
|
||||
'/rsrc/image/search.png' =>
|
||||
array(
|
||||
'hash' => 'ff7da044e6f923b8f569dec11f97e5e5',
|
||||
|
@ -1328,6 +1335,17 @@ celerity_register_resource_map(array(
|
|||
),
|
||||
'disk' => '/rsrc/js/application/herald/herald-rule-editor.js',
|
||||
),
|
||||
'javelin-behavior-konami' =>
|
||||
array(
|
||||
'uri' => '/res/4f9442c2/rsrc/js/application/core/behavior-konami.js',
|
||||
'type' => 'js',
|
||||
'requires' =>
|
||||
array(
|
||||
0 => 'javelin-behavior',
|
||||
1 => 'javelin-stratcom',
|
||||
),
|
||||
'disk' => '/rsrc/js/application/core/behavior-konami.js',
|
||||
),
|
||||
'javelin-behavior-line-chart' =>
|
||||
array(
|
||||
'uri' => '/res/1aa5ac88/rsrc/js/application/maniphest/behavior-line-chart.js',
|
||||
|
|
|
@ -159,6 +159,7 @@ final class PhabricatorStandardPageView extends AphrontPageView {
|
|||
|
||||
Javelin::initBehavior('workflow', array());
|
||||
Javelin::initBehavior('toggle-class', array());
|
||||
Javelin::initBehavior('konami', array());
|
||||
Javelin::initBehavior(
|
||||
'refresh-csrf',
|
||||
array(
|
||||
|
|
BIN
webroot/rsrc/image/nyan.gif
Normal file
BIN
webroot/rsrc/image/nyan.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 58 KiB |
195
webroot/rsrc/js/application/core/behavior-konami.js
Normal file
195
webroot/rsrc/js/application/core/behavior-konami.js
Normal file
|
@ -0,0 +1,195 @@
|
|||
/**
|
||||
* @provides javelin-behavior-konami
|
||||
* @requires javelin-behavior
|
||||
* javelin-stratcom
|
||||
*/
|
||||
|
||||
JX.behavior('konami', function() {
|
||||
var sequence = [ 38, 38, 40, 40, 37, 39, 37, 39, 66, 65, 13 ];
|
||||
var seen = [];
|
||||
|
||||
JX.Stratcom.listen('keyup', null, function(e) {
|
||||
if (!sequence)
|
||||
return;
|
||||
seen.push(e.getRawEvent().keyCode);
|
||||
while (seen.length) {
|
||||
var mismatch = false;
|
||||
for (var i = 0; i < seen.length; ++i) {
|
||||
if (seen[i] != sequence[i]) {
|
||||
mismatch = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (!mismatch) {
|
||||
break;
|
||||
}
|
||||
seen.shift();
|
||||
}
|
||||
if (seen.length == sequence.length) {
|
||||
sequence = seen = null;
|
||||
activate();
|
||||
}
|
||||
});
|
||||
|
||||
var prefixes = { '-webkit-': 1, '-moz-': 1, '-o-': 1, '-ms-': 1, '': 1 };
|
||||
var body_rule, all_rule, top_rule;
|
||||
|
||||
function generateCSS(selector, props) {
|
||||
var ret = selector + '{';
|
||||
for (var key in props) {
|
||||
ret += key + ':' + props[key] + ';';
|
||||
}
|
||||
return ret + '}';
|
||||
}
|
||||
function generateAllCSS(selector, props) {
|
||||
var more_props = {};
|
||||
for (var key in props) {
|
||||
for (var prefix in prefixes) {
|
||||
more_props[prefix + key] = props[key];
|
||||
}
|
||||
}
|
||||
return generateCSS(selector, more_props);
|
||||
}
|
||||
function modifyCSS(rule, key, value) {
|
||||
rule.setProperty(key, value, '');
|
||||
}
|
||||
function modifyAllCSS(rule, key, value) {
|
||||
for (var prefix in prefixes) {
|
||||
modifyCSS(rule, prefix + key, value);
|
||||
}
|
||||
}
|
||||
|
||||
var characters = [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 ];
|
||||
for (var i = 0x3041; i < 0x3097; ++i) {
|
||||
characters.push(String.fromCharCode(i));
|
||||
}
|
||||
|
||||
function spawnText() {
|
||||
if (Math.random() > 0.10) {
|
||||
return;
|
||||
}
|
||||
|
||||
var text = [];
|
||||
var length = parseInt(Math.random() * 16) + 10;
|
||||
for (var i = 0; i < length; ++i) {
|
||||
text.push(characters[parseInt(Math.random() * characters.length)]);
|
||||
}
|
||||
text = text.join(' ');
|
||||
|
||||
var element = document.createElement('div');
|
||||
var z = Math.random() * 400 - 40;
|
||||
element.className = 'matrix';
|
||||
element.textContent = text;
|
||||
modifyCSS(element.style, 'left',
|
||||
Math.random() * document.body.clientWidth + 'px');
|
||||
modifyAllCSS(element.style, 'transform', 'translateZ(' + z + 'px)');
|
||||
document.body.appendChild(element);
|
||||
|
||||
var height = element.clientHeight;
|
||||
var y = -height;
|
||||
modifyCSS(element.style, 'top', y + 'px');
|
||||
|
||||
var timer = setInterval(function() {
|
||||
y += 5;
|
||||
modifyCSS(element.style, 'top', y + 'px');
|
||||
if (y > document.body.clientHeight) {
|
||||
clearInterval(timer);
|
||||
document.body.removeChild(element);
|
||||
}
|
||||
}, 20);
|
||||
}
|
||||
|
||||
function spawnCat() {
|
||||
if (Math.random() > 0.05) {
|
||||
return;
|
||||
}
|
||||
|
||||
var element = document.createElement('img');
|
||||
var z = Math.random() * 400 - 40;
|
||||
element.setAttribute('src', '/rsrc/image/nyan.gif');
|
||||
element.className = 'nyan';
|
||||
modifyCSS(element.style, 'top',
|
||||
Math.random() * document.body.clientHeight + 'px');
|
||||
modifyAllCSS(element.style, 'transform', 'translateZ(' + z + 'px)');
|
||||
document.body.appendChild(element);
|
||||
|
||||
var width = Math.random() * 200 + 100;
|
||||
var x = -width;
|
||||
modifyCSS(element.style, 'width', width + 'px');
|
||||
modifyCSS(element.style, 'left', x + 'px');
|
||||
|
||||
var timer = setInterval(function() {
|
||||
x += 3;
|
||||
modifyCSS(element.style, 'left', x + 'px');
|
||||
if (x > document.body.clientWidth) {
|
||||
clearInterval(timer);
|
||||
document.body.removeChild(element);
|
||||
}
|
||||
}, 20);
|
||||
}
|
||||
|
||||
var counter = 0;
|
||||
var body_translate = '';
|
||||
var body_rotate = '';
|
||||
|
||||
function zoomOut() {
|
||||
if (counter >= 20) {
|
||||
return;
|
||||
}
|
||||
++counter;
|
||||
|
||||
body_translate = 'translateZ(' + (-16 * counter) + 'px)';
|
||||
modifyAllCSS(body_rule, 'transform', body_translate + ' ' + body_rotate);
|
||||
modifyAllCSS(all_rule, 'transform', 'translateZ(' + counter + 'px)');
|
||||
modifyAllCSS(top_rule, 'transform', 'translateZ(' + (counter * 15) + 'px)');
|
||||
modifyCSS(document.documentElement.style, 'background-color',
|
||||
'rgba(0,0,0,' + (counter / 20) + ')', '');
|
||||
modifyCSS(document.getElementById('base-page').style, 'background-color',
|
||||
'rgba(255,255,255,' + (1 - counter / 20) + ')', '');
|
||||
setTimeout(zoomOut, 20 + counter * 3);
|
||||
}
|
||||
|
||||
function activate() {
|
||||
var matrix = document.createElement('style');
|
||||
matrix.textContent = [
|
||||
generateAllCSS('html', {
|
||||
perspective: '500px'
|
||||
}),
|
||||
generateAllCSS('body', {
|
||||
transform: 'translateZ(0px)'
|
||||
}),
|
||||
generateAllCSS('*', {
|
||||
'transform-style': 'preserve-3d'
|
||||
}),
|
||||
generateAllCSS('body>[class|=jx],.phabricator-notification-menu', {
|
||||
transform: 'translateZ(0px)'
|
||||
}),
|
||||
generateCSS('.matrix', {
|
||||
position: 'fixed',
|
||||
width: '0',
|
||||
'font-size': '20pt',
|
||||
color: 'chartreuse',
|
||||
'text-shadow': '0 0 1em limegreen,0 0 1em limegreen,0 0 1em limegreen'
|
||||
}),
|
||||
generateCSS('.nyan', {
|
||||
position: 'fixed'
|
||||
})
|
||||
].join('\n');
|
||||
document.head.appendChild(matrix);
|
||||
|
||||
body_rule = matrix.sheet.cssRules[1].style;
|
||||
all_rule = matrix.sheet.cssRules[2].style;
|
||||
top_rule = matrix.sheet.cssRules[3].style;
|
||||
|
||||
document.addEventListener('mousemove', function(e) {
|
||||
var x = e.screenX / window.innerWidth - 0.5;
|
||||
var y = -e.screenY / window.innerHeight + 0.5;
|
||||
body_rotate = 'rotateY(' + x + 'rad) rotateX(' + y + 'rad)';
|
||||
modifyAllCSS(body_rule, 'transform', body_translate + ' ' + body_rotate);
|
||||
}, false);
|
||||
|
||||
zoomOut();
|
||||
setInterval(spawnText, 100);
|
||||
setInterval(spawnCat, 250);
|
||||
}
|
||||
});
|
Loading…
Reference in a new issue