Compare commits
5 Commits
a0133e0981
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5470ba1298 | ||
|
|
13fae1c23f | ||
|
|
21719a6cf7 | ||
| addaade269 | |||
|
|
6ee6c9c8d9 |
@@ -55,9 +55,9 @@ air dev
|
|||||||
|
|
||||||
## TODO
|
## TODO
|
||||||
|
|
||||||
|
- implement templating for every one of the frontend files
|
||||||
- implement functionality to clear and clean cache
|
- implement functionality to clear and clean cache
|
||||||
- implement fetching in intervals
|
- host this website on a demo page
|
||||||
- host this website on a demo page
|
|
||||||
- implement ctl
|
- implement ctl
|
||||||
- implement autocomplete with a nice go backend and fast communication. Since it all runs locally nobody should have privacy concerns NEEDS TO BE ABLE TO TOGGLED OFF FOR DEMO PAGE
|
- implement autocomplete with a nice go backend and fast communication. Since it all runs locally nobody should have privacy concerns NEEDS TO BE ABLE TO TOGGLED OFF FOR DEMO PAGE
|
||||||
|
|
||||||
|
|||||||
17
demo.toml
Normal file
17
demo.toml
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
[Server]
|
||||||
|
Port = 1312
|
||||||
|
|
||||||
|
[DiyHrt]
|
||||||
|
FetchIntervals = 60
|
||||||
|
|
||||||
|
[Template]
|
||||||
|
ActiveCard = "listings"
|
||||||
|
PageTitle = "TransfemStartpage demo"
|
||||||
|
HeaderPhrases = [
|
||||||
|
"GirlJuice.Inject();",
|
||||||
|
"You.Cute = true;",
|
||||||
|
"You.Gay = true;",
|
||||||
|
"Nazi.Punch();",
|
||||||
|
"Dolls.GiveGuns();",
|
||||||
|
"Firefox > Chrome"
|
||||||
|
]
|
||||||
@@ -49,16 +49,6 @@ body {
|
|||||||
color: black;
|
color: black;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (max-height: 300px) {
|
|
||||||
.search-grid {
|
|
||||||
grid-template-rows: 4em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.search-logo {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.cards {
|
.cards {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
@@ -70,6 +60,20 @@ body {
|
|||||||
overflow: auto;
|
overflow: auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@media (max-height: 500px) {
|
||||||
|
.search-grid {
|
||||||
|
grid-template-rows: 4em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.search-logo {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cards {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.card {
|
.card {
|
||||||
background-color: rgba(255, 255, 255, 0.5);
|
background-color: rgba(255, 255, 255, 0.5);
|
||||||
width: 10em;
|
width: 10em;
|
||||||
@@ -97,7 +101,6 @@ body {
|
|||||||
margin: 0;
|
margin: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
.card-image {
|
.card-image {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
aspect-ratio: 1/1;
|
aspect-ratio: 1/1;
|
||||||
|
|||||||
@@ -4,45 +4,49 @@ const form = document.getElementById("search-form");
|
|||||||
const input = document.getElementById("search-input");
|
const input = document.getElementById("search-input");
|
||||||
|
|
||||||
// https://stackoverflow.com/a/3809435/16804841
|
// https://stackoverflow.com/a/3809435/16804841
|
||||||
const expression = /https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_\+.~#?&//=]*)/gi;
|
const expression =
|
||||||
|
/https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_\+.~#?&//=]*)/gi;
|
||||||
const urlRegex = new RegExp(expression);
|
const urlRegex = new RegExp(expression);
|
||||||
|
|
||||||
const searchEngines = {
|
const searchEngines = {
|
||||||
"g": {
|
g: {
|
||||||
action: "https://www.google.com/search",
|
action: "https://www.google.com/search",
|
||||||
name: "q",
|
name: "q",
|
||||||
},
|
},
|
||||||
"d": {
|
d: {
|
||||||
action: "https://duckduckgo.com/",
|
action: "https://duckduckgo.com/",
|
||||||
name: "q",
|
name: "q",
|
||||||
},
|
},
|
||||||
"y": {
|
y: {
|
||||||
|
action: "https://www.youtube.com/results",
|
||||||
|
name: "search_query",
|
||||||
|
},
|
||||||
|
ya: {
|
||||||
action: "https://yandex.com/search/",
|
action: "https://yandex.com/search/",
|
||||||
name: "text",
|
name: "text",
|
||||||
},
|
},
|
||||||
"lure": {
|
lure: {
|
||||||
action: "https://lure.sh/pkgs",
|
action: "https://lure.sh/pkgs",
|
||||||
name: "q",
|
name: "q",
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
const translationPrefixes = [
|
const translationPrefixes = ["t", "translation"];
|
||||||
"t",
|
|
||||||
"translation",
|
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
function getDeepLUrl(s) {
|
function getDeepLUrl(s) {
|
||||||
const parts = s.split("-")
|
const parts = s.split("-");
|
||||||
if (parts.length != 3) {
|
if (parts.length != 3) {
|
||||||
return undefined
|
return undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
return `https://www.deepl.com/en/translator?/#${encodeURIComponent(parts[0].trim())}/${encodeURIComponent(parts[1].trim())}/${encodeURIComponent(parts[2].trim())}`;
|
return `https://www.deepl.com/en/translator?/#${encodeURIComponent(
|
||||||
|
parts[0].trim()
|
||||||
|
)}/${encodeURIComponent(parts[1].trim())}/${encodeURIComponent(
|
||||||
|
parts[2].trim()
|
||||||
|
)}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
form.addEventListener("submit", (event) => {
|
||||||
form.addEventListener("submit", event => {
|
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
|
|
||||||
s = input.value;
|
s = input.value;
|
||||||
@@ -50,7 +54,7 @@ form.addEventListener("submit", event => {
|
|||||||
// check if url
|
// check if url
|
||||||
if (s.match(urlRegex)) {
|
if (s.match(urlRegex)) {
|
||||||
window.open(s, "_self");
|
window.open(s, "_self");
|
||||||
return
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// deepl translations
|
// deepl translations
|
||||||
|
|||||||
@@ -2,6 +2,8 @@ package diyhrt
|
|||||||
|
|
||||||
type DiyHrtConfig struct {
|
type DiyHrtConfig struct {
|
||||||
ApiKey string
|
ApiKey string
|
||||||
|
FetchIntervals int
|
||||||
|
|
||||||
StoreFilter StoreFilter
|
StoreFilter StoreFilter
|
||||||
ListingFilter ListingFilter
|
ListingFilter ListingFilter
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -64,6 +64,7 @@ func NewConfig() Config {
|
|||||||
},
|
},
|
||||||
DiyHrt: diyhrt.DiyHrtConfig{
|
DiyHrt: diyhrt.DiyHrtConfig{
|
||||||
ApiKey: os.Getenv("API_KEY"),
|
ApiKey: os.Getenv("API_KEY"),
|
||||||
|
FetchIntervals: 60, // fetch every hour
|
||||||
StoreFilter: diyhrt.StoreFilter{
|
StoreFilter: diyhrt.StoreFilter{
|
||||||
Limit: 0,
|
Limit: 0,
|
||||||
IncludeIds: []int{7},
|
IncludeIds: []int{7},
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import (
|
|||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
"time"
|
||||||
|
|
||||||
"gitea.elara.ws/Hazel/transfem-startpage/internal/cache"
|
"gitea.elara.ws/Hazel/transfem-startpage/internal/cache"
|
||||||
"gitea.elara.ws/Hazel/transfem-startpage/internal/rendering"
|
"gitea.elara.ws/Hazel/transfem-startpage/internal/rendering"
|
||||||
@@ -12,12 +13,26 @@ import (
|
|||||||
|
|
||||||
var Config = rendering.NewConfig()
|
var Config = rendering.NewConfig()
|
||||||
|
|
||||||
|
func StartFetching() {
|
||||||
|
for {
|
||||||
|
log.Println("Fetch DiyHrt data...")
|
||||||
|
Config.FetchDiyHrt()
|
||||||
|
time.Sleep(time.Duration(Config.DiyHrt.FetchIntervals) * time.Second)
|
||||||
|
|
||||||
|
if Config.DiyHrt.FetchIntervals == 0 {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func Start(profile string) error {
|
func Start(profile string) error {
|
||||||
err := Config.ScanForConfigFile(profile)
|
err := Config.ScanForConfigFile(profile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
go StartFetching()
|
||||||
|
|
||||||
err = Config.FetchDiyHrt()
|
err = Config.FetchDiyHrt()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println(err)
|
log.Println(err)
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1
|
exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1exit status 1
|
||||||
Reference in New Issue
Block a user