Compare commits

..

No commits in common. "a974a492357c71cbe3d9f613c3bd11f1775ab3da" and "0397f8d2d63b50a3669284dee4a203eb045b72b1" have entirely different histories.

5 changed files with 27 additions and 100 deletions

View File

@ -1,2 +0,0 @@
name = "gaisen"
data_path = "./data"

View File

@ -1,6 +1,7 @@
#!/usr/bin/env python3 #!/usr/bin/env python3
import traceback import traceback
import os
import posixpath import posixpath
from flask import Flask, render_template, request from flask import Flask, render_template, request

View File

@ -2,9 +2,6 @@ import os
import posixpath import posixpath
from typing import Self from typing import Self
# TODO: Cut any dependency of DocumentNode on the backend implementation
# Maybe use some king of "yield" to achieve this?
class DocumentNode(): class DocumentNode():
def __init__(self, name: str, children: list): def __init__(self, name: str, children: list):
@ -64,12 +61,9 @@ class DocumentNode():
if file.endswith('.md'): if file.endswith('.md'):
file = file[:-3] file = file[:-3]
if file not in [x.name for x in children]: if file not in children:
children.append(DocumentNode(file, [])) children.append(DocumentNode(file, []))
# With this algorithm they're not properly sorted
children.sort(key=lambda x: x.name)
return DocumentNode(path.split('/')[-1], children) return DocumentNode(path.split('/')[-1], children)
@ -81,18 +75,13 @@ class DocumentTree():
def get_node(self, path: str) -> DocumentNode | None: def get_node(self, path: str) -> DocumentNode | None:
return self.root.get_child(path) return self.root.get_child(path)
def reload(self) -> bool:
# TODO: Instead of doing this, actually reload
self.root = DocumentNode.get_tree(self.base, '')
return True
# ----- Document Operations ----- # ----- Document Operations -----
# Split and remerge for Windows # Split and remerge for Windows
def document_read(self, path: str) -> str | None: def document_read(self, path: str) -> str | None:
internal_path = os.path.join(self.base, *path.split('/')) + '.md' internal_path = os.path.join(self.base, *path.split('/')) + '.md'
if os.path.exists(internal_path): if os.path.exists(internal_path):
return open(internal_path, 'r').read() return open(internal_path).read()
# File doesn't exist # File doesn't exist
return None return None
@ -100,11 +89,8 @@ class DocumentTree():
def document_write(self, path: str, text: str) -> None: def document_write(self, path: str, text: str) -> None:
internal_path = os.path.join(self.base, *path.split('/')) + '.md' internal_path = os.path.join(self.base, *path.split('/')) + '.md'
# TODO: Probably add some sort of confirmation beforehand? # TODO: Check if the directory exists before writing
os.makedirs(os.path.dirname(internal_path), exist_ok=True) with open(internal_path) as file:
with open(internal_path, 'w') as file:
file.write(text) file.write(text)
self.reload()
# ------------------------------- # -------------------------------

View File

@ -1,15 +1,18 @@
html {
min-height: 100%;
}
body { body {
/*padding: 20px;*/ padding: 20px;
background-color: #191919; background-color: #191919;
color: white; color: white;
font-family: monospace; font-family: monospace;
/*margin-bottom: 100px;*/ margin-bottom: 100px;
min-height: 100vh;
margin: 0px;
} }
h1, h2 { color: orange; } h1, h2, h3, h4, h5, h6 {
h3, h4 { color: gray; } color: orange;
}
a { a {
text-decoration: none; text-decoration: none;
@ -20,18 +23,12 @@ a {
background-color: orange; background-color: orange;
} }
hr {
border: none;
border-bottom: 1px solid #444;
margin: 0px;
}
input { input {
border: 1px solid black; border: 1px solid black;
background-color: white; background-color: white;
} }
body > footer { footer {
background-color: black; background-color: black;
position: fixed; position: fixed;
left: 0; left: 0;
@ -43,57 +40,28 @@ body > footer {
} }
ul { ul {
margin: 0px; padding-left: 20px;
padding-left: 10px;
padding-bottom: 0px; padding-bottom: 0px;
}
ul p {
margin: 0px;
}
li {
margin-top: -2px;
margin-bottom: -1px;
}
body > main {
display: flex;
min-height: 100vh;
}
body > main > * > *:not(hr) {
padding: 20px;
}
body > main hr {
width: 100%;
}
body > main > nav {
background-color: black;
flex-shrink: 0;
}
body > main > nav ul {
list-style-type: none; list-style-type: none;
} }
body > main > article ul { main {
margin-bottom: 10px; display: flex;
} gap: 20px;
min-height: 80vh;
}
nav { nav {
padding-right: 10px;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
border-right: 1px solid #444; border-right: 1px solid orange;
width: 200px; width: 200px;
} }
article { article {
flex-grow: 1; flex-grow: 1;
display: flex;
flex-direction: column;
} }
article > main {
flex-grow: 1;
}
pre { pre {
background-color: #000; background-color: #000;

View File

@ -2,20 +2,12 @@
{% block title %}{{ path }}{% endblock %} {% block title %}{{ path }}{% endblock %}
{% macro render_tree(tree, root='') %} {% macro render_tree(tree, root='/') %}
<ul> <ul>
{% for entry in tree %} {% for entry in tree %}
<li> <li>
{% set url = path_join(root, entry.name) %} {% set url = path_join(root, entry.name) %}
<a href="{{ url }}">{{ entry.name }}</a>
{#{% if loop.last or entry.children|length > 0 %}#}
{% if entry.children|length > 0 %}
{% else %}
·
{% endif %}
<a href="{{ path_join('/', url ) }}">{{ entry.name }}</a>
{{ render_tree(entry.children, url) }} {{ render_tree(entry.children, url) }}
</li> </li>
{% endfor %} {% endfor %}
@ -24,19 +16,11 @@
{% block body %} {% block body %}
<main> <main>
<nav> <nav>
<div>
&gt; <a href="/">index</a>/{{ path }}
</div>
<hr/>
{{ render_tree(document_tree.root.children) }} {{ render_tree(document_tree.root.children) }}
</nav> </nav>
<article> <article>
<main>
{% if not edit %} {% if not edit %}
{% if path != '' %} {% if path != '' %}
<a href="/{{ path }}?edit">Edit</a> <a href="/{{ path }}?edit">Edit</a>
@ -51,11 +35,7 @@
{% endif %} {% endif %}
{% else %} {% else %}
<form method="POST" action="/{{ path }}"> <form method="POST" action="/{{ path }}">
{% set edit_content = content %} <textarea id="markdown-textarea" name="text">{{ content }}</textarea>
{% if content is none %}
{% set edit_content = '# Title\n\nContent' %}
{% endif %}
<textarea id="markdown-textarea" name="text">{{ edit_content }}</textarea>
<input type="submit" value="Save"/> <input type="submit" value="Save"/>
<form> <form>
<script> <script>
@ -81,22 +61,16 @@
}); });
</script> </script>
{% endif %} {% endif %}
</main>
<hr/> <hr/>
{% for child in document_tree.get_node(path).children %} {% for child in document_tree.get_node(path).children %}
{% if loop.first %} {% if loop.first %}
<footer>
<h1>Children</h1> <h1>Children</h1>
{% endif %}
<a href="{{ path_join(path, child.name) }}">{{child.name}}</a>{% if not loop.last %},{% endif %}
{% if loop.last %}
</footer>
{% endif %} {% endif %}
<a href="{{ path_join(path, child.name) }}">{{child.name}}</a>{% if not loop.last %},{% endif %}
{% endfor %} {% endfor %}
</article> </article>