453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
|
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
|
-
+
-
+
-
+
|
** is a leaf without a "closed" tag.
**
** Query parameters:
**
** all Show all leaves
** closed Show only closed leaves
** ng No graph
** hide Hide check-ins with "hidden" tag
** nohidden Hide check-ins with "hidden" tag
** onlyhidden Show only check-ins with "hidden" tag
** brbg Background color by branch name
** ubg Background color by user name
*/
void leaves_page(void){
Blob sql;
Stmt q;
int showAll = P("all")!=0;
int showClosed = P("closed")!=0;
int fNg = PB("ng")!=0; /* Flag for the "ng" query parameter */
int fHide = PB("hide")!=0; /* Flag for the "hide" query parameter */
int fNoHidden = PB("nohidden")!=0; /* "nohidden" query parameter */
int fOnlyHidden = PB("onlyhidden")!=0; /* "onlyhidden" query parameter */
int fBrBg = PB("brbg")!=0; /* Flag for the "brbg" query parameter */
int fUBg = PB("ubg")!=0; /* Flag for the "ubg" query parameter */
HQuery url; /* URL to /leaves plus query parameters */
int tmFlags; /* Timeline display flags */
login_check_credentials();
if( !g.perm.Read ){ login_needed(g.anon.Read); return; }
url_initialize(&url, "leaves");
if( fNg ) url_add_parameter(&url, "ng", "");
if( fHide ) url_add_parameter(&url, "hide", "");
if( fNoHidden ) url_add_parameter(&url, "nohidden", "");
if( fOnlyHidden ) url_add_parameter(&url, "onlyhidden", "");
if( fBrBg ) url_add_parameter(&url, "brbg", "");
if( fUBg ) url_add_parameter(&url, "ubg", "");
if( !showAll ){
style_submenu_element("All", "%s", url_render(&url, "all", "", 0, 0));
}
if( !showClosed ){
|
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
|
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
|
-
-
+
+
|
blob_append(&sql, timeline_query_for_www(), -1);
blob_append_sql(&sql, " AND blob.rid IN leaf");
if( showClosed ){
blob_append_sql(&sql," AND %z", leaf_is_closed_sql("blob.rid"));
}else if( !showAll ){
blob_append_sql(&sql," AND NOT %z", leaf_is_closed_sql("blob.rid"));
}
if( fHide || fOnlyHidden ){
const char* zUnaryOp = fHide ? "NOT" : "";
if( fNoHidden || fOnlyHidden ){
const char* zUnaryOp = fNoHidden ? "NOT" : "";
blob_append_sql(&sql,
" AND %s EXISTS(SELECT 1 FROM tagxref"
" WHERE tagid=%d AND tagtype>0 AND rid=blob.rid)\n",
zUnaryOp/*safe-for-%s*/, TAG_HIDDEN);
}
db_prepare(&q, "%s ORDER BY event.mtime DESC", blob_sql_text(&sql));
blob_reset(&sql);
|