updating dockerize branch

This commit is contained in:
gideonwolfe 2020-08-24 16:29:25 -07:00
commit 933c16ac7e
11 changed files with 148 additions and 44 deletions

View File

@ -2,24 +2,37 @@
A terminal-style home page replicating the tree command. A terminal-style home page replicating the tree command.
<p align="center"> <p align="center">
<img src="/StartTree.png", title="StartTree"/> <img src="/images/StartTree.png", title="StartTree"/>
</p> </p>
## TODO <div align="center">
- [x] Add screenshot to README.md <h1>
- [x] add install script <a href="https://gideonwolfe.com/">
- [ ] Should allow selection of search engine <img style="vertical-align:middle" src="/images/forest.png", width="400", />
- [x] Should allow for multiple columns </a>
- [x] User makes a 'config.yaml' file that is parsed and translated into the HTML <span style="">
- [ ] Allow setting the font size in the config <img style="vertical-align:middle" src="/images/void.png", width="400", />
- [ ] Install the update script into a `$PATH` directory </a>
</span>
</h1>
</div>
```yaml ```yaml
Tree_1: font_size: 15
General: theme: void
Google: "https://www.google.com/"
Youtube: "https://www.youtube.com/" tree_1:
Reddit: general:
Homepage: "https://www.reddit.com/" google: "https://www.google.com/"
Unixporn: "https://www.reddit.com/r/unixporn/" 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`.

View File

@ -1,22 +1,15 @@
Tree_1: font_size: 22
theme: void
tree_1:
general: general:
nextcloud: "https://cloud.paulhouser.xyz/" github: "https://www.github.com/"
github: "https://www.github.com/Paul-Houser/"
wwu-gitlab: "https://gitlab.cs.wwu.edu/"
gmail: "https://mail.google.com/" gmail: "https://mail.google.com/"
reddit: reddit:
frontpage: frontpage:
- "https://www.reddit.com/" - "https://www.reddit.com/"
- "front page" - "front page"
profile: "https://www.reddit.com/u/P_swizzles/"
unixporn: "https://www.reddit.com/r/unixporn/" unixporn: "https://www.reddit.com/r/unixporn/"
archlinux: "https://www.reddit.com/r/archlinux/" tree_2:
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"
other: other:
archwiki: archwiki:
- "https://archlinux.org/" - "https://archlinux.org/"

View File

@ -56,17 +56,18 @@ def gen_col_headers(html_file, file_dict):
def gen_columns(html_file, file_dict): def gen_columns(html_file, file_dict):
for key in file_dict: for key in file_dict:
html_file.write("<div class=\"column\">\n") if key.split("_")[0] == "tree":
html_file.write(" <div class=\"tree\">\n") html_file.write("<div class=\"column\">\n")
html_file.write(" <h1>.</h1>\n") html_file.write(" <div class=\"tree\">\n")
html_file.write(" <ul>\n") html_file.write(" <h1>.</h1>\n")
html_file.write(" <ul>\n")
# generate the column headers # generate the column headers
gen_col_headers(html_file, file_dict[key]) gen_col_headers(html_file, file_dict[key])
html_file.write(" </ul>\n") html_file.write(" </ul>\n")
html_file.write(" </div>\n") html_file.write(" </div>\n")
html_file.write("</div>\n") html_file.write("</div>\n")
def gen_html(file_dict): def gen_html(file_dict):
@ -98,8 +99,36 @@ def gen_html(file_dict):
print("Done!") 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(): def main():
file_dict = parse_yaml() file_dict = parse_yaml()
gen_style(file_dict)
gen_html(file_dict) gen_html(file_dict)
if __name__ == '__main__': if __name__ == '__main__':

View File

Before

Width:  |  Height:  |  Size: 730 KiB

After

Width:  |  Height:  |  Size: 730 KiB

BIN
images/forest.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 MiB

BIN
images/void.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.6 MiB

View File

@ -21,11 +21,6 @@ config_path = home + '/.config/StartTree/config.yaml'
# get cache path # get cache path
cache_dir = home + '/.cache/StartTree' cache_dir = home + '/.cache/StartTree'
def prettifyHTML(html):
soup = BeautifulSoup(html, 'html.parser')
prettyHTML = soup.prettify()
return prettyHTML
def setup(): def setup():
# check if .config path exists # check if .config path exists
if not os.path.isdir(home + '/.config'): if not os.path.isdir(home + '/.config'):
@ -57,6 +52,9 @@ def setup():
print("Creating '" + cache_dir + "'...") print("Creating '" + cache_dir + "'...")
os.mkdir(cache_dir) os.mkdir(cache_dir)
print("symlinking themes")
os.symlink(os.getcwd() + '/themes', home + '/.cache/StartTree/themes')
print("Creating '" + cache_dir + "/styles'") print("Creating '" + cache_dir + "/styles'")
os.mkdir(cache_dir + '/styles') os.mkdir(cache_dir + '/styles')

View File

@ -1,4 +1,3 @@
@import url('/home/paul/.cache/wal/colors.css');
@font-face { @font-face {
font-family: "Roboto Mono"; font-family: "Roboto Mono";
src: url("./Hack.ttf"); src: url("./Hack.ttf");
@ -16,7 +15,7 @@
} }
html { html {
font-size: 22px; /* font-size */
} }
body { body {

24
themes/black-ice.css Normal file
View 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
View 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
View 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;
}