add socials command
This commit is contained in:
parent
8d841a6bff
commit
21908f395d
|
@ -5,13 +5,10 @@ div#resume_js_app {
|
||||||
border: 1px solid #e1e1e1;
|
border: 1px solid #e1e1e1;
|
||||||
font-family: monospace;
|
font-family: monospace;
|
||||||
box-shadow: 0 2px 4px #30303060;
|
box-shadow: 0 2px 4px #30303060;
|
||||||
/* padding: 10px 8px;*/
|
|
||||||
color: #e1e1e1;
|
color: #e1e1e1;
|
||||||
}
|
}
|
||||||
div#resume_js_app * {
|
|
||||||
padding: 0; margin: 0;
|
|
||||||
}
|
|
||||||
div#resume_js_app p.js_loading_indicator {
|
div#resume_js_app p.js_loading_indicator {
|
||||||
|
padding: 0; margin: 0;
|
||||||
position: relative;
|
position: relative;
|
||||||
top: 50%; left: 50%;
|
top: 50%; left: 50%;
|
||||||
transform: translate(-50%, -50%);
|
transform: translate(-50%, -50%);
|
||||||
|
|
|
@ -2,37 +2,50 @@ import React, { Component } from 'react';
|
||||||
import Terminal from 'react-console-emulator';
|
import Terminal from 'react-console-emulator';
|
||||||
import Files from './emulation/files';
|
import Files from './emulation/files';
|
||||||
import commands from './emulation/commands';
|
import commands from './emulation/commands';
|
||||||
|
import Colored from './helpers/color';
|
||||||
|
|
||||||
const welcome = `
|
const welcome = <pre>
|
||||||
Welcome to my resume!
|
Welcome to my resume!<br/>
|
||||||
Type 'help' for list of commands.
|
Type
|
||||||
`;
|
<Colored color='#156ea4'> help </Colored>
|
||||||
|
for a list of commands.
|
||||||
|
</pre>;
|
||||||
|
|
||||||
const inputStyle = { color: '#2e8b7e', fontWeight: 'bold' };
|
const inputStyle = { color: '#2e8b7e', fontWeight: 'bold' };
|
||||||
|
|
||||||
export class Base extends Component {
|
export class Base extends Component {
|
||||||
|
constructor(props) {
|
||||||
|
super(props);
|
||||||
|
this.terminal = React.createRef();
|
||||||
|
}
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<Terminal
|
<Terminal
|
||||||
commands={commands}
|
ref={this.terminal}
|
||||||
|
commands={commands(this.terminal)}
|
||||||
welcomeMessage={welcome}
|
welcomeMessage={welcome}
|
||||||
promptLabel={
|
promptLabel={
|
||||||
<pre>
|
/*<pre>
|
||||||
user@blek.codes
|
user@blek.codes
|
||||||
<span style={{color: '#2968ac'}}> ~/resume </span>
|
<span style={{color: '#2968ac'}}> ~/resume </span>
|
||||||
<span style={{color: '#ff5092'}}>(
|
<span style={{color: '#ff5092'}}>(
|
||||||
<span style={{color:'limegreen'}}>master</span>
|
<span style={{color:'limegreen'}}>master</span>
|
||||||
) </span>
|
) </span>
|
||||||
$
|
$
|
||||||
</pre>
|
</pre>*/
|
||||||
|
'$ '
|
||||||
}
|
}
|
||||||
|
|
||||||
|
errorText={'zsh: command not found: [command]'}
|
||||||
|
|
||||||
style={{height:'100%'}}
|
style={{height:'100%'}}
|
||||||
|
|
||||||
promptLabelStyle={inputStyle}
|
promptLabelStyle={inputStyle}
|
||||||
inputTextStyle={{...inputStyle, color: '#5ba2b0', transform: 'translateY(2px)'}}
|
inputTextStyle={{...inputStyle, color: '#5ba2b0', transform: 'translateY(2px)'}}
|
||||||
|
|
||||||
styleEchoBack={'fullInherit'}
|
styleEchoBack={'fullInherit'}
|
||||||
|
noDefaults
|
||||||
|
noAutoScroll
|
||||||
/>
|
/>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,8 @@ import Files from '../files';
|
||||||
|
|
||||||
import Colored from '../../helpers/color';
|
import Colored from '../../helpers/color';
|
||||||
|
|
||||||
module.exports = {
|
const commands = (terminal) => {
|
||||||
|
const commands = {
|
||||||
cat: {
|
cat: {
|
||||||
description: 'Show contents of a file',
|
description: 'Show contents of a file',
|
||||||
fn: require('./cat')
|
fn: require('./cat')
|
||||||
|
@ -18,5 +19,46 @@ module.exports = {
|
||||||
skills: {
|
skills: {
|
||||||
description: 'My skills data',
|
description: 'My skills data',
|
||||||
fn: require('./skills')
|
fn: require('./skills')
|
||||||
|
},
|
||||||
|
|
||||||
|
clear: {
|
||||||
|
description: 'Clear the terminal.',
|
||||||
|
fn: () => {
|
||||||
|
terminal.current.setState({stdout: []});
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
socials: {
|
||||||
|
description: 'View my social links',
|
||||||
|
fn: require('./social')
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
commands.help = {
|
||||||
|
fn: () => {
|
||||||
|
return (
|
||||||
|
<pre>
|
||||||
|
Commands list:
|
||||||
|
<table>
|
||||||
|
<tbody>
|
||||||
|
{
|
||||||
|
Object.keys(commands).map((cmd, i) => {
|
||||||
|
if (cmd == 'help') return;
|
||||||
|
return <tr key={i}>
|
||||||
|
<td style={{color: 'violet'}}>{cmd}</td>
|
||||||
|
<td style={{padding: '0 8px'}}> : </td>
|
||||||
|
<td>{commands[cmd].description}</td>
|
||||||
|
</tr>
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</pre>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return commands;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
module.exports = commands;
|
|
@ -0,0 +1,9 @@
|
||||||
|
module.exports = () => {
|
||||||
|
return <p>
|
||||||
|
<a href='https://blek.codes'>My website</a><br/>
|
||||||
|
<a href='https://github.com/b1ek'>Github page</a><br/>
|
||||||
|
<a href='https://git.blek.codes/b1ek'>Gitea page</a><br/>
|
||||||
|
<a href='mailto:me@blek.codes'>Email</a><br/>
|
||||||
|
<a href='https://t.me/bleki42'>Telegram</a><br/>
|
||||||
|
</p>;
|
||||||
|
}
|
Loading…
Reference in New Issue