update .ignores, projects work

This commit is contained in:
Edward Shen 2020-11-28 15:50:20 -05:00
parent df5abad06d
commit 275f58b1df
Signed by: edward
GPG key ID: 19182661E818369F
10 changed files with 107 additions and 21 deletions

View file

@ -1,6 +1,5 @@
# don't ever lint node_modules node_modules/
node_modules public/
# don't lint build output (make sure it's set to your correct build folder name) .cache/
dist
# don't lint nyc coverage output # don't lint nyc coverage output
coverage coverage

View file

@ -1,4 +1,5 @@
.cache .cache/
package.json package.json
package-lock.json package-lock.json
public public/
node_modules/

View file

@ -92,7 +92,7 @@ exports.createPages = async ({ actions, graphql, reporter }) => {
'**/src/notes/*', '**/src/notes/*',
'/notes', '/notes',
'./src/templates/notes.tsx', './src/templates/notes.tsx',
'./src/templates/note.tsx' './src/templates/note.tsx',
); );
await generatePages( await generatePages(
createPage, createPage,
@ -101,7 +101,7 @@ exports.createPages = async ({ actions, graphql, reporter }) => {
'**/src/projects/*', '**/src/projects/*',
'/projects', '/projects',
'./src/templates/projects.tsx', './src/templates/projects.tsx',
'./src/templates/note.tsx' './src/templates/project.tsx',
); );
}; };
@ -114,7 +114,8 @@ exports.createSchemaCustomization = ({ actions: { createTypes } }) => {
type CommonFrontmatter { type CommonFrontmatter {
hidden: Boolean, hidden: Boolean,
lang: String, lang: String,
tags: [String] tags: [String],
subtitle: String,
} }
`); `);
}; };

View file

@ -1,6 +1,7 @@
.project-item { .project-item {
display: flex; display: flex;
align-items: baseline; align-items: baseline;
justify-content: space-between;
} }
.project-title { .project-title {

View file

@ -9,8 +9,10 @@ interface ItemProps {
} }
export default (props: ItemProps): JSX.Element => ( export default (props: ItemProps): JSX.Element => (
<Link to={props.to} className={style.projectItem}> <article className={style.projectItem}>
<Link to={props.to}>
<h3 className={style.projectTitle}>{props.title}</h3> <h3 className={style.projectTitle}>{props.title}</h3>
<p className={style.projectSubtitle}>{props.subtitle}</p>
</Link> </Link>
<p className={style.projectSubtitle}>{props.subtitle}</p>
</article>
); );

50
src/projects/bunbun.mdx Normal file
View file

@ -0,0 +1,50 @@
---
title: "Bunbun"
subtitle: "Cross-browser search commands"
path: "bunbun"
date: 2020-01-01
lang: "rust"
tags: []
---
[Bunbun][1] is a search delegation service and my first project in Rust. It's a
implementation of [bunny1][bunny1] that offers a simple config file as well as
an extensible plugin system.
An interesting note about the project is that [I've submitted a patch][hotwatch]
to an library to fix a bug where the file descriptor for watching the config
file would get stale.
For me, it solves a lot of problems I have, particularly in the sense that it
lets me write shortcuts that I know will always work, instead of relying on
browsers to remember for me.
Yes, existing solutions exist, such as DuckDuckGo's [bang!][ddg-bangs] as well
as FireFox's shortcuts, but I believe this has a niche particularly for
self-hosted or enterprise environments. As it allows for plugins to run, it can
offer a uniform experience for employees or users to access common resources.
Honestly, this idea didn't sell me at first, but after using a similar variant
at my past work, I was completely dependent on it in only 12 weeks.
I've been living on this project for months now, so I can guarantee that it
works. From a privacy and security perspective, I find it to be satisfactory for
my needs:
1. It only logs to `stdout` with the option to completely disable logging.
2. It's built in Rust without any `unsafe` usage, which guarantees that my code
should be sound.
3. It uses `actix`, a well respected HTTP server library that is relatively
receptive of security concerns.
4. Its plugin system is as private and secure as the host it's running on, and
fails safe on improperly defined inputs.
5. It has meaningful tests!
_Caveat emptor_[^1], of course. You should audit the code yourself, but I'm
happy with the work I've made (and always receptive of feedback).
[1]: https://github.com/edward-shen/bunbun
[bunny1]: http://www.bunny1.org/
[hotwatch]: https://github.com/francesca64/hotwatch/pull/4
[ddg-bangs]: https://duckduckgo.com/bang
[^1]: https://en.wikipedia.org/wiki/Caveat_emptor

View file

@ -1,8 +1,10 @@
--- ---
title: "Shlink"
subtitle: "1-click link shortening"
path: "shlink" path: "shlink"
date: 2020-01-01 date: 2020-01-01
title: "Shlink"
lang: "js" lang: "js"
tags: []
--- ---
Hello World Shlink

View file

@ -4,8 +4,7 @@ import { graphql } from 'gatsby';
import { MDXRenderer } from 'gatsby-plugin-mdx'; import { MDXRenderer } from 'gatsby-plugin-mdx';
export default ({ data }) => { export default ({ data }) => {
const { frontmatter, body } = data.mdx; const { frontmatter, tableOfContents, body } = data.mdx;
return ( return (
<> <>
<Navbar /> <Navbar />

31
src/templates/project.tsx Normal file
View file

@ -0,0 +1,31 @@
import React from 'react';
import Navbar from '../components/navbar';
import { graphql } from 'gatsby';
import { MDXRenderer } from 'gatsby-plugin-mdx';
export default ({ data }) => {
const { frontmatter, body } = data.mdx;
return (
<>
<Navbar />
<main>
<h1>{frontmatter.title}</h1>
<h5>{frontmatter.subtitle}</h5>
<MDXRenderer>{body}</MDXRenderer>
</main>
</>
);
};
export const query = graphql`
query ProjectsItemQuery($id: String!) {
mdx(id: { eq: $id }) {
frontmatter {
title
subtitle
}
tableOfContents
body
}
}
`;

View file

@ -11,14 +11,14 @@ export default ({ data, pageContext }): JSX.Element => {
return ( return (
<> <>
<Navbar /> <Navbar />
{posts.map(({ node }) => { {posts.map(({ node: { id, frontmatter } }) => {
const frontmatter = node.frontmatter;
return ( return (
<Item <Item
key={id}
title={frontmatter.title} title={frontmatter.title}
subtitle={frontmatter.lang} subtitle={frontmatter.subtitle}
to={rootPath + '/' + frontmatter.path} to={rootPath + '/' + frontmatter.path}
></Item> />
); );
})} })}
<PaginationNav <PaginationNav
@ -48,7 +48,7 @@ export const query = graphql`
title title
date(formatString: "YYYY-MM-DD") date(formatString: "YYYY-MM-DD")
path path
lang subtitle
} }
id id
} }