mirror of
https://github.com/Paul-Houser/StartTree.git
synced 2024-11-21 15:03:08 +01:00
updating dockerize branch
This commit is contained in:
commit
933c16ac7e
45
README.md
45
README.md
@ -2,24 +2,37 @@
|
||||
A terminal-style home page replicating the tree command.
|
||||
|
||||
<p align="center">
|
||||
<img src="/StartTree.png", title="StartTree"/>
|
||||
<img src="/images/StartTree.png", title="StartTree"/>
|
||||
</p>
|
||||
|
||||
## TODO
|
||||
- [x] Add screenshot to README.md
|
||||
- [x] add install script
|
||||
- [ ] Should allow selection of search engine
|
||||
- [x] Should allow for multiple columns
|
||||
- [x] User makes a 'config.yaml' file that is parsed and translated into the HTML
|
||||
- [ ] Allow setting the font size in the config
|
||||
- [ ] Install the update script into a `$PATH` directory
|
||||
<div align="center">
|
||||
<h1>
|
||||
<a href="https://gideonwolfe.com/">
|
||||
<img style="vertical-align:middle" src="/images/forest.png", width="400", />
|
||||
</a>
|
||||
<span style="">
|
||||
<img style="vertical-align:middle" src="/images/void.png", width="400", />
|
||||
</a>
|
||||
</span>
|
||||
</h1>
|
||||
</div>
|
||||
|
||||
|
||||
```yaml
|
||||
Tree_1:
|
||||
General:
|
||||
Google: "https://www.google.com/"
|
||||
Youtube: "https://www.youtube.com/"
|
||||
Reddit:
|
||||
Homepage: "https://www.reddit.com/"
|
||||
Unixporn: "https://www.reddit.com/r/unixporn/"
|
||||
font_size: 15
|
||||
theme: void
|
||||
|
||||
tree_1:
|
||||
general:
|
||||
google: "https://www.google.com/"
|
||||
youtube: "https://www.youtube.com/"
|
||||
reddit:
|
||||
homepage: "https://www.reddit.com/"
|
||||
unixporn: "https://www.reddit.com/r/unixporn/"
|
||||
```
|
||||
|
||||
# Themes
|
||||
|
||||
A variety of themes can be found in the `themes` directory.
|
||||
|
||||
If one wishes to dynamically theme from `pywal`, they may select `pywal` as their chosen theme in `config.yaml`.
|
||||
|
17
config.yaml
17
config.yaml
@ -1,22 +1,15 @@
|
||||
Tree_1:
|
||||
font_size: 22
|
||||
theme: void
|
||||
tree_1:
|
||||
general:
|
||||
nextcloud: "https://cloud.paulhouser.xyz/"
|
||||
github: "https://www.github.com/Paul-Houser/"
|
||||
wwu-gitlab: "https://gitlab.cs.wwu.edu/"
|
||||
github: "https://www.github.com/"
|
||||
gmail: "https://mail.google.com/"
|
||||
reddit:
|
||||
frontpage:
|
||||
- "https://www.reddit.com/"
|
||||
- "front page"
|
||||
profile: "https://www.reddit.com/u/P_swizzles/"
|
||||
unixporn: "https://www.reddit.com/r/unixporn/"
|
||||
archlinux: "https://www.reddit.com/r/archlinux/"
|
||||
Tree_2:
|
||||
school:
|
||||
canvas: "https://wwu.instructure.com/"
|
||||
degreeworks: "https://dw.wwu.edu/Dashboard/dashboard"
|
||||
outlook: "https://outlook.office.com"
|
||||
web4u: "https://admin.wwu.edu/pls/wwis/twbkwbis.P_GenMenu?name=bmenu.P_MainMnu"
|
||||
tree_2:
|
||||
other:
|
||||
archwiki:
|
||||
- "https://archlinux.org/"
|
||||
|
@ -56,17 +56,18 @@ def gen_col_headers(html_file, file_dict):
|
||||
|
||||
def gen_columns(html_file, file_dict):
|
||||
for key in file_dict:
|
||||
html_file.write("<div class=\"column\">\n")
|
||||
html_file.write(" <div class=\"tree\">\n")
|
||||
html_file.write(" <h1>.</h1>\n")
|
||||
html_file.write(" <ul>\n")
|
||||
if key.split("_")[0] == "tree":
|
||||
html_file.write("<div class=\"column\">\n")
|
||||
html_file.write(" <div class=\"tree\">\n")
|
||||
html_file.write(" <h1>.</h1>\n")
|
||||
html_file.write(" <ul>\n")
|
||||
|
||||
# generate the column headers
|
||||
gen_col_headers(html_file, file_dict[key])
|
||||
# generate the column headers
|
||||
gen_col_headers(html_file, file_dict[key])
|
||||
|
||||
html_file.write(" </ul>\n")
|
||||
html_file.write(" </div>\n")
|
||||
html_file.write("</div>\n")
|
||||
html_file.write(" </ul>\n")
|
||||
html_file.write(" </div>\n")
|
||||
html_file.write("</div>\n")
|
||||
|
||||
|
||||
def gen_html(file_dict):
|
||||
@ -98,8 +99,36 @@ def gen_html(file_dict):
|
||||
|
||||
print("Done!")
|
||||
|
||||
def gen_style(file_dict):
|
||||
skeleton_style = open('./skeletons/style.css', 'r')
|
||||
cache_style = open(cache_dir + '/styles/style.css', 'w')
|
||||
|
||||
# find style attributes in file_dict
|
||||
font_size = 20
|
||||
theme = "void"
|
||||
for key in file_dict:
|
||||
if key == "font_size":
|
||||
font_size = file_dict[key]
|
||||
if key == "theme":
|
||||
theme = file_dict[key]
|
||||
|
||||
if theme == "pywal":
|
||||
theme = home + '/.cache/wal/colors.css'
|
||||
else:
|
||||
theme = '../themes/' + theme + '.css'
|
||||
|
||||
cache_style.write("@import url('" + theme + "');\n")
|
||||
|
||||
lines = skeleton_style.readlines()
|
||||
for line in lines:
|
||||
if line == "/* font-size */\n":
|
||||
cache_style.write("font-size: " + str(font_size) + "px;\n")
|
||||
else:
|
||||
cache_style.write(line)
|
||||
|
||||
def main():
|
||||
file_dict = parse_yaml()
|
||||
gen_style(file_dict)
|
||||
gen_html(file_dict)
|
||||
|
||||
if __name__ == '__main__':
|
Before Width: | Height: | Size: 730 KiB After Width: | Height: | Size: 730 KiB |
BIN
images/forest.png
Normal file
BIN
images/forest.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.9 MiB |
BIN
images/void.png
Normal file
BIN
images/void.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.6 MiB |
8
init.py
8
init.py
@ -21,11 +21,6 @@ config_path = home + '/.config/StartTree/config.yaml'
|
||||
# get cache path
|
||||
cache_dir = home + '/.cache/StartTree'
|
||||
|
||||
def prettifyHTML(html):
|
||||
soup = BeautifulSoup(html, 'html.parser')
|
||||
prettyHTML = soup.prettify()
|
||||
return prettyHTML
|
||||
|
||||
def setup():
|
||||
# check if .config path exists
|
||||
if not os.path.isdir(home + '/.config'):
|
||||
@ -57,6 +52,9 @@ def setup():
|
||||
print("Creating '" + cache_dir + "'...")
|
||||
os.mkdir(cache_dir)
|
||||
|
||||
print("symlinking themes")
|
||||
os.symlink(os.getcwd() + '/themes', home + '/.cache/StartTree/themes')
|
||||
|
||||
print("Creating '" + cache_dir + "/styles'")
|
||||
os.mkdir(cache_dir + '/styles')
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
@import url('/home/paul/.cache/wal/colors.css');
|
||||
@font-face {
|
||||
font-family: "Roboto Mono";
|
||||
src: url("./Hack.ttf");
|
||||
@ -16,7 +15,7 @@
|
||||
}
|
||||
|
||||
html {
|
||||
font-size: 22px;
|
||||
/* font-size */
|
||||
}
|
||||
|
||||
body {
|
||||
|
24
themes/black-ice.css
Normal file
24
themes/black-ice.css
Normal file
@ -0,0 +1,24 @@
|
||||
:root {
|
||||
/* Special */
|
||||
--background: #000000;
|
||||
--foreground: #9a9c9f;
|
||||
--cursor: #9a9c9f;
|
||||
|
||||
/* Colors */
|
||||
--color0: #000000;
|
||||
--color1: #04294d;
|
||||
--color2: #2d2d2d;
|
||||
--color3: #094c57;
|
||||
--color4: #176485;
|
||||
--color5: #585a5a;
|
||||
--color6: #62909b;
|
||||
--color7: #9a9c9f;
|
||||
--color8: #36393f;
|
||||
--color9: #04294d;
|
||||
--color10: #2d2d2d;
|
||||
--color11: #094c57;
|
||||
--color12: #176485;
|
||||
--color13: #585a5a;
|
||||
--color14: #62909b;
|
||||
--color15: #9a9c9f;
|
||||
}
|
24
themes/forest.css
Normal file
24
themes/forest.css
Normal file
@ -0,0 +1,24 @@
|
||||
:root {
|
||||
/* Special */
|
||||
--background: #020303;
|
||||
--foreground: #9da0a0;
|
||||
--cursor: #9da0a0;
|
||||
|
||||
/* Colors */
|
||||
--color0: #020303;
|
||||
--color1: #2b3d30;
|
||||
--color2: #424a55;
|
||||
--color3: #405642;
|
||||
--color4: #5b6a55;
|
||||
--color5: #7f8d76;
|
||||
--color6: #82908c;
|
||||
--color7: #9da0a0;
|
||||
--color8: #3b4242;
|
||||
--color9: #2b3d30;
|
||||
--color10: #424a55;
|
||||
--color11: #405642;
|
||||
--color12: #5b6a55;
|
||||
--color13: #7f8d76;
|
||||
--color14: #82908c;
|
||||
--color15: #9da0a0;
|
||||
}
|
24
themes/void.css
Normal file
24
themes/void.css
Normal file
@ -0,0 +1,24 @@
|
||||
:root {
|
||||
/* Special */
|
||||
--background: #06070A;
|
||||
--foreground: #79c4c6;
|
||||
--cursor: #79c4c6;
|
||||
|
||||
/* Colors */
|
||||
--color0: #06070A;
|
||||
--color1: #175564;
|
||||
--color2: #066C71;
|
||||
--color3: #414255;
|
||||
--color4: #0E7587;
|
||||
--color5: #64468F;
|
||||
--color6: #8D419F;
|
||||
--color7: #79c4c6;
|
||||
--color8: #54898a;
|
||||
--color9: #175564;
|
||||
--color10: #066C71;
|
||||
--color11: #414255;
|
||||
--color12: #0E7587;
|
||||
--color13: #64468F;
|
||||
--color14: #8D419F;
|
||||
--color15: #79c4c6;
|
||||
}
|
Loading…
Reference in New Issue
Block a user