Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: easter egg #469

Closed
wants to merge 1 commit into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions main/http_server/axe-os/src/app/app-routing.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import { SettingsComponent } from './components/settings/settings.component';
import { NetworkComponent } from './components/network/network.component';
import { SwarmComponent } from './components/swarm/swarm.component';
import { AppLayoutComponent } from './layout/app.layout.component';
import { GenesisBlockComponent } from './components/genesis-block/genesis-block.component';

const routes: Routes = [
{
Expand All @@ -32,6 +33,10 @@ const routes: Routes = [
{
path: 'swarm',
component: SwarmComponent
},
{
path: 'genesis-block',
component: GenesisBlockComponent
}
]
},
Expand Down
4 changes: 3 additions & 1 deletion main/http_server/axe-os/src/app/app.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import { LogsComponent } from './components/logs/logs.component';
import { NetworkComponent } from './components/network/network.component';
import { SettingsComponent } from './components/settings/settings.component';
import { SwarmComponent } from './components/swarm/swarm.component';
import { GenesisBlockComponent } from './components/genesis-block/genesis-block.component';
import { AppLayoutModule } from './layout/app.layout.module';
import { ANSIPipe } from './pipes/ansi.pipe';
import { DateAgoPipe } from './pipes/date-ago.pipe';
Expand All @@ -33,7 +34,8 @@ const components = [
LoadingComponent,
NetworkComponent,
SettingsComponent,
LogsComponent
LogsComponent,
GenesisBlockComponent
];

@NgModule({
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
<div class="genesis-container">
<div class="hex-block">
<pre *ngFor="let line of displayedHexData">{{ line }}</pre>
</div>

<div class="genesis-message" [class.visible]="currentHexIndex === rawHexData.length + 1">
Genesis Block Decoded - Bitcoin's Beginning
</div>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
:host {
display: block;
background-color: #000;
color: var(--primary-color);
font-family: 'Courier New', monospace;
padding: 2rem;
border-radius: 8px;
box-shadow: 0 0 20px rgba(255, 0, 0, 0.2);
position: relative;
overflow: hidden;
}

.genesis-container {
position: relative;
min-height: 350px;

&::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 2px;
background: linear-gradient(90deg, transparent, var(--primary-color), transparent);
animation: scan 9.5s linear forwards;
}
}

.data-line {
margin: 4px 0;
opacity: 0;
transform: translateX(-20px);
animation: fadeIn 0.5s ease forwards;

&::before {
content: '>';
margin-right: 10px;
color: var(--primary-color);
}
}

@keyframes scan {
0% {
transform: translateY(0);
opacity: 1;
}
99% {
opacity: 1;
}
100% {
transform: translateY(310px);
opacity: 0;
}
}

.hex-block {
font-family: monospace;
white-space: pre;
margin-top: 20px;

pre {
font-family: monospace;
transform: translateX(-20px);
margin: 0;
line-height: 1.2;

&::before {
content: '>';
margin-right: 10px;
color: var(--primary-color);
}
}
}

.genesis-message {
text-align: center;
margin-top: 20px;
font-size: 1.5em;
opacity: 0;
transform: translateY(20px);
transition: all 0.8s ease-out;
// color: #f7931a; /* Bitcoin orange */
text-shadow: 0 0 10px rgba(255, 0, 0, 0.2);
}

.genesis-message.visible {
opacity: 1;
transform: translateY(0);
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import { ComponentFixture, TestBed } from '@angular/core/testing';

import { GenesisBlockComponent } from './genesis-block.component';

describe('GenesisBlockComponent', () => {
let component: GenesisBlockComponent;
let fixture: ComponentFixture<GenesisBlockComponent>;

beforeEach(async () => {
await TestBed.configureTestingModule({
imports: [GenesisBlockComponent]
})
.compileComponents();

fixture = TestBed.createComponent(GenesisBlockComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});

it('should create', () => {
expect(component).toBeTruthy();
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
import { Component, OnInit } from '@angular/core';

@Component({
selector: 'app-genesis-block',
templateUrl: './genesis-block.component.html',
styleUrl: './genesis-block.component.scss'
})
export class GenesisBlockComponent implements OnInit {

rawHexData: string[] = [
'00000000 01 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................',
'00000010 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................',
'00000020 00 00 00 00 3B A3 ED FD 7A 7B 12 B2 7A C7 2C 3E ....;£íýz{.²zÇ,>',
'00000030 67 76 8F 61 7F C8 1B C3 88 8A 51 32 3A 9F B8 AA gv.a.È.ÈŠQ2:Ÿ¸ª',
'00000040 4B 1E 5E 4A 29 AB 5F 49 FF FF 00 1D 1D AC 2B 7C K.^J)«_Iÿÿ...¬+|',
'00000050 01 01 00 00 00 01 00 00 00 00 00 00 00 00 00 00 ................',
'00000060 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................',
'00000070 00 00 00 00 00 00 FF FF FF FF 4D 04 FF FF 00 1D ..........M.ÿÿ..',
'00000080 01 04 45 54 68 65 20 54 69 6D 65 73 20 30 33 2F ..EThe Times 03/',
'00000090 4A 61 6E 2F 32 30 30 39 20 43 68 61 6E 63 65 6C Jan/2009 Chancel',
'000000A0 6C 6F 72 20 6F 6E 20 62 72 69 6E 6B 20 6F 66 20 lor on brink of ',
'000000B0 73 65 63 6F 6E 64 20 62 61 69 6C 6F 75 74 20 66 second bailout f',
'000000C0 6F 72 20 62 61 6E 6B 73 FF FF FF FF 01 00 F2 05 or banksÿÿÿÿ..ò. ',
'000000D0 2A 01 00 00 00 43 41 04 67 8A FD B0 FE 55 48 27 *....CA.gŠý°þUH',
'000000E0 19 67 F1 A6 71 30 B7 10 5C D6 A8 28 E0 39 09 A6 .gñ¦q0·.\Ö¨(à9.¦',
'000000F0 79 62 E0 EA 1F 61 DE B6 49 F6 BC 3F 4C EF 38 C4 ybàê.aÞ¶Iö¼?Lï8Ä',
'00000100 F3 55 04 E5 1E C1 12 DE 5C 38 4D F7 BA 0B 8D 57 óU.å.Á.Þ\\8M÷º..W',
'00000110 8A 4C 70 2B 6B F1 1D 5F AC 00 00 00 00 ŠLp+kñ._¬....',
];

displayedHexData: string[] = [];
currentHexIndex = 0;

ngOnInit() {
this.startHexAnimation();
}

private startHexAnimation() {
const interval = setInterval(() => {
if (this.currentHexIndex < this.rawHexData.length) {
this.displayedHexData.push(this.rawHexData[this.currentHexIndex]);
this.currentHexIndex++;
} else {
this.currentHexIndex++;
clearInterval(interval);
}
}, 500);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,8 @@
<p-button (click)="restart()" id="restart" label="Restart" severity="primary"></p-button>
</li>

<li class="absolute bottom-0 left-0">
<a class="text-xs text-gray-900" routerLink="/genesis-block">0</a>
</li>

</ul>