mirror of
https://codeberg.org/grunfink/snac2.git
synced 2024-11-22 21:35:04 +00:00
Added hints to web UI buttons.
This commit is contained in:
parent
106791ff6b
commit
6f2e407692
1 changed files with 31 additions and 26 deletions
57
html.c
57
html.c
|
@ -218,7 +218,7 @@ xs_str *html_msg_icon(snac *snac, xs_str *os, const xs_dict *msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
d_char *html_user_header(snac *snac, d_char *s, int local)
|
xs_str *html_user_header(snac *snac, xs_str *s, int local)
|
||||||
/* creates the HTML header */
|
/* creates the HTML header */
|
||||||
{
|
{
|
||||||
char *p, *v;
|
char *p, *v;
|
||||||
|
@ -397,7 +397,7 @@ d_char *html_user_header(snac *snac, d_char *s, int local)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
d_char *html_top_controls(snac *snac, d_char *s)
|
xs_str *html_top_controls(snac *snac, xs_str *s)
|
||||||
/* generates the top controls */
|
/* generates the top controls */
|
||||||
{
|
{
|
||||||
char *_tmpl =
|
char *_tmpl =
|
||||||
|
@ -423,7 +423,7 @@ d_char *html_top_controls(snac *snac, d_char *s)
|
||||||
"<details><summary>%s</summary>\n" /** poll **/
|
"<details><summary>%s</summary>\n" /** poll **/
|
||||||
"<p>%s:<br>\n"
|
"<p>%s:<br>\n"
|
||||||
"<textarea class=\"snac-textarea\" name=\"poll_options\" "
|
"<textarea class=\"snac-textarea\" name=\"poll_options\" "
|
||||||
"rows=\"6\" wrap=\"virtual\" placeholder=\"Option 1...\nOption 2...\nOption 3...\n....\"></textarea>\n"
|
"rows=\"6\" wrap=\"virtual\" placeholder=\"Option 1...\nOption 2...\nOption 3...\n...\"></textarea>\n"
|
||||||
"<p><select name=\"poll_multiple\">\n"
|
"<p><select name=\"poll_multiple\">\n"
|
||||||
"<option value=\"off\">%s</option>\n"
|
"<option value=\"off\">%s</option>\n"
|
||||||
"<option value=\"on\">%s</option>\n"
|
"<option value=\"on\">%s</option>\n"
|
||||||
|
@ -449,7 +449,7 @@ d_char *html_top_controls(snac *snac, d_char *s)
|
||||||
"</form><p>\n"
|
"</form><p>\n"
|
||||||
|
|
||||||
"<form autocomplete=\"off\" method=\"post\" action=\"%s/admin/action\">\n" /** boost **/
|
"<form autocomplete=\"off\" method=\"post\" action=\"%s/admin/action\">\n" /** boost **/
|
||||||
"<input type=\"text\" name=\"id\" required=\"required\" placeholder=\"https://fedi.example.com/bob/....\">\n"
|
"<input type=\"text\" name=\"id\" required=\"required\" placeholder=\"https://fedi.example.com/bob/...\">\n"
|
||||||
"<input type=\"submit\" name=\"action\" value=\"%s\"> %s\n"
|
"<input type=\"submit\" name=\"action\" value=\"%s\"> %s\n"
|
||||||
"</form><p>\n"
|
"</form><p>\n"
|
||||||
"</details>\n"
|
"</details>\n"
|
||||||
|
@ -465,7 +465,7 @@ d_char *html_top_controls(snac *snac, d_char *s)
|
||||||
"<p>%s: <input type=\"file\" name=\"avatar_file\"></p>\n"
|
"<p>%s: <input type=\"file\" name=\"avatar_file\"></p>\n"
|
||||||
|
|
||||||
"<p>%s:<br>\n"
|
"<p>%s:<br>\n"
|
||||||
"<textarea name=\"bio\" cols=\"40\" rows=\"4\" placeholder=\"Write about yourself here....\">%s</textarea></p>\n"
|
"<textarea name=\"bio\" cols=\"40\" rows=\"4\" placeholder=\"Write about yourself here...\">%s</textarea></p>\n"
|
||||||
|
|
||||||
"<p><input type=\"checkbox\" name=\"cw\" id=\"cw\" %s>\n"
|
"<p><input type=\"checkbox\" name=\"cw\" id=\"cw\" %s>\n"
|
||||||
"<label for=\"cw\">%s</label></p>\n"
|
"<label for=\"cw\">%s</label></p>\n"
|
||||||
|
@ -601,12 +601,12 @@ d_char *html_top_controls(snac *snac, d_char *s)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
d_char *html_button(d_char *s, char *clss, char *label)
|
xs_str *html_button(xs_str *s, const char *clss, const char *label, const char *hint)
|
||||||
{
|
{
|
||||||
xs *s1 = xs_fmt(
|
xs *s1 = xs_fmt(
|
||||||
"<input type=\"submit\" name=\"action\" "
|
"<input type=\"submit\" name=\"action\" "
|
||||||
"class=\"snac-btn-%s\" value=\"%s\">\n",
|
"class=\"snac-btn-%s\" value=\"%s\" title=\"%s\">\n",
|
||||||
clss, label);
|
clss, label, hint);
|
||||||
|
|
||||||
return xs_str_cat(s, s1);
|
return xs_str_cat(s, s1);
|
||||||
}
|
}
|
||||||
|
@ -690,37 +690,38 @@ xs_str *html_entry_controls(snac *snac, xs_str *os, const xs_dict *msg, const ch
|
||||||
if (!xs_startswith(id, snac->actor)) {
|
if (!xs_startswith(id, snac->actor)) {
|
||||||
if (xs_list_in(likes, snac->md5) == -1) {
|
if (xs_list_in(likes, snac->md5) == -1) {
|
||||||
/* not already liked; add button */
|
/* not already liked; add button */
|
||||||
s = html_button(s, "like", L("Like"));
|
s = html_button(s, "like", L("Like"), L("Say you like this post"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (is_pinned(snac, id))
|
if (is_pinned(snac, id))
|
||||||
s = html_button(s, "unpin", L("Unpin"));
|
s = html_button(s, "unpin", L("Unpin"), L("Unpin this post from your timeline"));
|
||||||
else
|
else
|
||||||
s = html_button(s, "pin", L("Pin"));
|
s = html_button(s, "pin", L("Pin"), L("Pin this post to the top of your timeline"));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_msg_public(snac, msg)) {
|
if (is_msg_public(snac, msg)) {
|
||||||
if (strcmp(actor, snac->actor) == 0 || xs_list_in(boosts, snac->md5) == -1) {
|
if (strcmp(actor, snac->actor) == 0 || xs_list_in(boosts, snac->md5) == -1) {
|
||||||
/* not already boosted or us; add button */
|
/* not already boosted or us; add button */
|
||||||
s = html_button(s, "boost", L("Boost"));
|
s = html_button(s, "boost", L("Boost"), L("Announce this post to your followers"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strcmp(actor, snac->actor) != 0) {
|
if (strcmp(actor, snac->actor) != 0) {
|
||||||
/* controls for other actors than this one */
|
/* controls for other actors than this one */
|
||||||
if (following_check(snac, actor)) {
|
if (following_check(snac, actor)) {
|
||||||
s = html_button(s, "unfollow", L("Unfollow"));
|
s = html_button(s, "unfollow", L("Unfollow"), L("Stop following this user's activity"));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
s = html_button(s, "follow", L("Follow"));
|
s = html_button(s, "follow", L("Follow"), L("Start following this user's activity"));
|
||||||
}
|
}
|
||||||
|
|
||||||
s = html_button(s, "mute", L("MUTE"));
|
s = html_button(s, "mute", L("MUTE"),
|
||||||
|
L("Block any activity from this user forever"));
|
||||||
}
|
}
|
||||||
|
|
||||||
s = html_button(s, "delete", L("Delete"));
|
s = html_button(s, "delete", L("Delete"), L("Delete this post"));
|
||||||
s = html_button(s, "hide", L("Hide"));
|
s = html_button(s, "hide", L("Hide"), L("Hide this post and its children"));
|
||||||
|
|
||||||
s = xs_str_cat(s, "</form>\n");
|
s = xs_str_cat(s, "</form>\n");
|
||||||
|
|
||||||
|
@ -1433,7 +1434,7 @@ xs_str *html_timeline(snac *snac, const xs_list *list, int local, int skip, int
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
d_char *html_people_list(snac *snac, d_char *os, d_char *list, const char *header, const char *t)
|
xs_str *html_people_list(snac *snac, xs_str *os, xs_list *list, const char *header, const char *t)
|
||||||
{
|
{
|
||||||
xs *s = xs_str_new(NULL);
|
xs *s = xs_str_new(NULL);
|
||||||
xs *es1 = encode_html(header);
|
xs *es1 = encode_html(header);
|
||||||
|
@ -1488,18 +1489,22 @@ d_char *html_people_list(snac *snac, d_char *os, d_char *list, const char *heade
|
||||||
s = xs_str_cat(s, s1);
|
s = xs_str_cat(s, s1);
|
||||||
|
|
||||||
if (following_check(snac, actor_id))
|
if (following_check(snac, actor_id))
|
||||||
s = html_button(s, "unfollow", L("Unfollow"));
|
s = html_button(s, "unfollow", L("Unfollow"),
|
||||||
|
L("Stop following this user's activity"));
|
||||||
else {
|
else {
|
||||||
s = html_button(s, "follow", L("Follow"));
|
s = html_button(s, "follow", L("Follow"),
|
||||||
|
L("Start following this user's activity"));
|
||||||
|
|
||||||
if (follower_check(snac, actor_id))
|
if (follower_check(snac, actor_id))
|
||||||
s = html_button(s, "delete", L("Delete"));
|
s = html_button(s, "delete", L("Delete"), L("Delete this user"));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_muted(snac, actor_id))
|
if (is_muted(snac, actor_id))
|
||||||
s = html_button(s, "unmute", L("Unmute"));
|
s = html_button(s, "unmute", L("Unmute"),
|
||||||
|
L("Stop blocking activities from this user"));
|
||||||
else
|
else
|
||||||
s = html_button(s, "mute", L("MUTE"));
|
s = html_button(s, "mute", L("MUTE"),
|
||||||
|
L("Block any activity from this user"));
|
||||||
|
|
||||||
s = xs_str_cat(s, "</form>\n");
|
s = xs_str_cat(s, "</form>\n");
|
||||||
|
|
||||||
|
@ -1537,9 +1542,9 @@ d_char *html_people_list(snac *snac, d_char *os, d_char *list, const char *heade
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
d_char *html_people(snac *snac)
|
xs_str *html_people(snac *snac)
|
||||||
{
|
{
|
||||||
d_char *s = xs_str_new(NULL);
|
xs_str *s = xs_str_new(NULL);
|
||||||
xs *wing = following_list(snac);
|
xs *wing = following_list(snac);
|
||||||
xs *wers = follower_list(snac);
|
xs *wers = follower_list(snac);
|
||||||
|
|
||||||
|
@ -1870,7 +1875,7 @@ int html_get_handler(const xs_dict *req, const char *q_path,
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
if (strcmp(p_path, ".rss") == 0) { /** public timeline in RSS format **/
|
if (strcmp(p_path, ".rss") == 0) { /** public timeline in RSS format **/
|
||||||
d_char *rss;
|
xs_str *rss;
|
||||||
xs *elems = timeline_simple_list(&snac, "public", 0, 20);
|
xs *elems = timeline_simple_list(&snac, "public", 0, 20);
|
||||||
xs *bio = not_really_markdown(xs_dict_get(snac.config, "bio"), NULL);
|
xs *bio = not_really_markdown(xs_dict_get(snac.config, "bio"), NULL);
|
||||||
char *p, *v;
|
char *p, *v;
|
||||||
|
|
Loading…
Reference in a new issue