Compare commits
No commits in common. "e35fafb18e2894a97489e73f28cafcf2729661cf" and "a00a53612e771e998d5a464d45835406e42db622" have entirely different histories.
e35fafb18e
...
a00a53612e
@ -530,12 +530,6 @@ def render_results_block(element, acc, headline, graph):
|
|||||||
if len(content.strip()) > 0:
|
if len(content.strip()) > 0:
|
||||||
render_block(content, acc, _class='results lang-text', is_code=False)
|
render_block(content, acc, _class='results lang-text', is_code=False)
|
||||||
|
|
||||||
def render_generic_drawer_block(element, acc, headline, graph):
|
|
||||||
items = [e.get_raw() for e in element.children]
|
|
||||||
content = '\n'.join(items)
|
|
||||||
if len(content.strip()) > 0:
|
|
||||||
render_block(content, acc, _class='generic-drawer {}-drawer lang-text'.format(element.drawer_name), is_code=False)
|
|
||||||
|
|
||||||
def render_org_text(element, acc, headline, graph):
|
def render_org_text(element, acc, headline, graph):
|
||||||
as_dom = org_rw.text_to_dom(element.contents, element)
|
as_dom = org_rw.text_to_dom(element.contents, element)
|
||||||
render_text_tokens(as_dom, acc, headline, graph)
|
render_text_tokens(as_dom, acc, headline, graph)
|
||||||
@ -668,7 +662,6 @@ def render_tag(element, acc, headline, graph):
|
|||||||
dom.CodeBlock: render_code_block,
|
dom.CodeBlock: render_code_block,
|
||||||
dom.Text: render_text,
|
dom.Text: render_text,
|
||||||
dom.ResultsDrawerNode: render_results_block,
|
dom.ResultsDrawerNode: render_results_block,
|
||||||
dom.GenericDrawerNode: render_generic_drawer_block,
|
|
||||||
org_rw.Text: render_org_text,
|
org_rw.Text: render_org_text,
|
||||||
}[type(element)](element, acc, headline, graph)
|
}[type(element)](element, acc, headline, graph)
|
||||||
|
|
||||||
|
@ -12,4 +12,4 @@ cd ../../_gen/notes/
|
|||||||
|
|
||||||
set -x
|
set -x
|
||||||
|
|
||||||
exec docker run -it --rm -p $PORT:80 -e SNIPPET_SIZE=256 -e PORT=80 -e DB_PATH=/db.sqlite3 -v `pwd`/db.sqlite3:/db.sqlite3:ro search-server
|
exec docker run -it --rm -p $PORT:80 -e PORT=80 -e DB_PATH=/db.sqlite3 -v `pwd`/db.sqlite3:/db.sqlite3:ro search-server
|
||||||
|
@ -33,22 +33,6 @@ func main() {
|
|||||||
port = port_num
|
port = port_num
|
||||||
}
|
}
|
||||||
|
|
||||||
snippet_size := 128
|
|
||||||
snippet_size_str, ok := os.LookupEnv("SNIPPET_SIZE")
|
|
||||||
if ok {
|
|
||||||
snippet_size_num, err := strconv.Atoi(snippet_size_str)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
if (snippet_size_num < 64) {
|
|
||||||
log.Fatal("Environment variale $SNIPPET_SIZE must be >= 64.")
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
snippet_size = snippet_size_num
|
|
||||||
}
|
|
||||||
|
|
||||||
db, err := sql.Open("sqlite3", database_path)
|
db, err := sql.Open("sqlite3", database_path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
@ -79,23 +63,8 @@ func main() {
|
|||||||
c.Writer.Header().Set("Access-Control-Allow-Methods", "GET, OPTIONS")
|
c.Writer.Header().Set("Access-Control-Allow-Methods", "GET, OPTIONS")
|
||||||
|
|
||||||
query := c.Query("q")
|
query := c.Query("q")
|
||||||
body_type := c.Query("body")
|
|
||||||
|
|
||||||
if ((body_type != "all") && (body_type != "none") && (body_type != "snippet")) {
|
|
||||||
body_type = "none"
|
|
||||||
}
|
|
||||||
|
|
||||||
var stm *sql.Stmt
|
|
||||||
var err error
|
|
||||||
|
|
||||||
if (body_type == "snippet") {
|
|
||||||
stm, err = db.Prepare("SELECT note_id, highlight(note_search, 1, '<span class=\"match\">', '</span>'), top_level_title, is_done, is_todo, snippet(note_search, 2, '<span class=\"match\">', '</span>', '<span class=\"search-result-break\"></span>', ?) FROM note_search(?)")
|
|
||||||
} else if (body_type == "all") {
|
|
||||||
stm, err = db.Prepare("SELECT note_id, highlight(note_search, 1, '<span class=\"match\">', '</span>'), top_level_title, is_done, is_todo, highlight(note_search, 2, '<span class=\"match\">', '</span>') FROM note_search(?)")
|
|
||||||
} else if (body_type == "none") {
|
|
||||||
stm, err = db.Prepare("SELECT note_id, highlight(note_search, 1, '<span class=\"match\">', '</span>'), top_level_title, is_done, is_todo FROM note_search(?)")
|
|
||||||
}
|
|
||||||
|
|
||||||
|
stm, err := db.Prepare("SELECT note_id, title, top_level_title, is_done, is_todo FROM note_search(?)")
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
@ -107,13 +76,8 @@ func main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
results := make([]map[string]string, 0)
|
results := make([]map[string]string, 0)
|
||||||
var rows *sql.Rows
|
|
||||||
|
|
||||||
if (body_type == "snippet") {
|
rows, err := stm.Query(query)
|
||||||
rows, err = stm.Query(snippet_size, query)
|
|
||||||
} else {
|
|
||||||
rows, err = stm.Query(query)
|
|
||||||
}
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
c.JSON(500, gin.H{
|
c.JSON(500, gin.H{
|
||||||
@ -130,31 +94,13 @@ func main() {
|
|||||||
var note_is_done string
|
var note_is_done string
|
||||||
var note_is_todo string
|
var note_is_todo string
|
||||||
|
|
||||||
item := make(map[string]string)
|
err = rows.Scan(
|
||||||
|
¬e_id,
|
||||||
if (body_type != "none") {
|
¬e_title,
|
||||||
var note_highlight string
|
¬e_top_level_title,
|
||||||
|
¬e_is_done,
|
||||||
err = rows.Scan(
|
¬e_is_todo,
|
||||||
¬e_id,
|
)
|
||||||
¬e_title,
|
|
||||||
¬e_top_level_title,
|
|
||||||
¬e_is_done,
|
|
||||||
¬e_is_todo,
|
|
||||||
¬e_highlight,
|
|
||||||
)
|
|
||||||
if (body_type != "none") {
|
|
||||||
item["highlight"] = note_highlight
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
err = rows.Scan(
|
|
||||||
¬e_id,
|
|
||||||
¬e_title,
|
|
||||||
¬e_top_level_title,
|
|
||||||
¬e_is_done,
|
|
||||||
¬e_is_todo,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
c.JSON(500, gin.H{
|
c.JSON(500, gin.H{
|
||||||
@ -164,6 +110,7 @@ func main() {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
item := make(map[string]string)
|
||||||
item["id"] = note_id
|
item["id"] = note_id
|
||||||
item["title"] = note_title
|
item["title"] = note_title
|
||||||
item["top_level_title"] = note_top_level_title
|
item["top_level_title"] = note_top_level_title
|
||||||
|
@ -1,9 +1,4 @@
|
|||||||
function _codigoparallevar_enable_search_box(selector, options) {
|
function _codigoparallevar_enable_search_box(selector, options) {
|
||||||
const unescape = (str, tag) => {
|
|
||||||
const prev = tag.replaceAll('<', '<').replaceAll('>', '>');
|
|
||||||
return str.replaceAll(prev, tag);
|
|
||||||
}
|
|
||||||
|
|
||||||
const element = document.querySelector(selector);
|
const element = document.querySelector(selector);
|
||||||
if ('placeholder' in options) {
|
if ('placeholder' in options) {
|
||||||
element.setAttribute('placeholder', options.placeholder);
|
element.setAttribute('placeholder', options.placeholder);
|
||||||
@ -74,7 +69,7 @@ function _codigoparallevar_enable_search_box(selector, options) {
|
|||||||
lastVal = val;
|
lastVal = val;
|
||||||
resultsBox.classList.add('loading');
|
resultsBox.classList.add('loading');
|
||||||
|
|
||||||
const uri = SEARCH_ENDPOINT + '?q=' + encodeURIComponent(val) + '&body=snippet';
|
const uri = SEARCH_ENDPOINT + '?q=' + encodeURIComponent(val);
|
||||||
let query = fetch(uri);
|
let query = fetch(uri);
|
||||||
currentQuery = query;
|
currentQuery = query;
|
||||||
query
|
query
|
||||||
@ -99,32 +94,14 @@ function _codigoparallevar_enable_search_box(selector, options) {
|
|||||||
|
|
||||||
const resultTitle = document.createElement('h2');
|
const resultTitle = document.createElement('h2');
|
||||||
resultTitle.innerText = `${note.title} (${note.top_level_title})`;
|
resultTitle.innerText = `${note.title} (${note.top_level_title})`;
|
||||||
resultTitle.innerHTML = unescape(unescape(
|
|
||||||
resultTitle.innerHTML,
|
|
||||||
'</span>'), '<span class="match">'
|
|
||||||
);
|
|
||||||
if (note.is_todo === "1") {
|
if (note.is_todo === "1") {
|
||||||
resultCard.setAttribute('class', 'is-todo');
|
resultTitle.setAttribute('class', 'is-todo');
|
||||||
}
|
}
|
||||||
else if (note.is_done === "1") {
|
else if (note.is_done === "1") {
|
||||||
resultCard.setAttribute('class', 'is-done');
|
resultTitle.setAttribute('class', 'is-done');
|
||||||
}
|
}
|
||||||
|
|
||||||
resultContents.appendChild(resultTitle);
|
resultContents.appendChild(resultTitle);
|
||||||
|
|
||||||
if (note.highlight) {
|
|
||||||
const resultBody = document.createElement('p');
|
|
||||||
resultBody.innerText = note.highlight;
|
|
||||||
resultBody.innerHTML = unescape(
|
|
||||||
unescape(
|
|
||||||
unescape(
|
|
||||||
resultBody.innerHTML,
|
|
||||||
'</span>'),
|
|
||||||
'<span class="search-result-break">'),
|
|
||||||
'<span class="match">');
|
|
||||||
resultContents.appendChild(resultBody);
|
|
||||||
}
|
|
||||||
|
|
||||||
resultCard.appendChild(resultContents);
|
resultCard.appendChild(resultContents);
|
||||||
resultsList.appendChild(resultCard);
|
resultsList.appendChild(resultCard);
|
||||||
}
|
}
|
||||||
|
@ -126,30 +126,13 @@ body nav input {
|
|||||||
box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.25);
|
box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.25);
|
||||||
}
|
}
|
||||||
|
|
||||||
.results-box ul li a {
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
.results-box ul li h2 {
|
.results-box ul li h2 {
|
||||||
font-size: 110%;
|
font-size: 110%;
|
||||||
padding: 1.25ex;
|
padding: 1.25ex;
|
||||||
display: block;
|
display: block;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
text-decoration: underline;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.results-box ul li p {
|
|
||||||
padding: 1.25ex;
|
|
||||||
color: black;
|
|
||||||
}
|
|
||||||
|
|
||||||
.results-box ul li span.match {
|
|
||||||
background: yellow;
|
|
||||||
}
|
|
||||||
|
|
||||||
.results-box ul li .search-result-break::before {
|
|
||||||
content: '…';
|
|
||||||
color: #777;
|
|
||||||
}
|
|
||||||
.results-box li h2.is-todo::before {
|
.results-box li h2.is-todo::before {
|
||||||
content: 'TODO';
|
content: 'TODO';
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
@ -676,19 +659,10 @@ tr.__table-separator {
|
|||||||
.results-box ul li h2 {
|
.results-box ul li h2 {
|
||||||
color: white;
|
color: white;
|
||||||
}
|
}
|
||||||
.results-box ul li p {
|
|
||||||
padding: 1.25ex;
|
|
||||||
color: white;
|
|
||||||
}
|
|
||||||
|
|
||||||
.results-box-container .results-box input:focus {
|
.results-box-container .results-box input:focus {
|
||||||
border-bottom: 1px solid #fff;
|
border-bottom: 1px solid #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
.results-box ul li span.match {
|
|
||||||
background: #886600;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Code blocks */
|
/* Code blocks */
|
||||||
.highlight pre {
|
.highlight pre {
|
||||||
padding: 1ex;
|
padding: 1ex;
|
||||||
|
Loading…
Reference in New Issue
Block a user