summaryrefslogtreecommitdiff
path: root/patch/bar_fancybar.c
diff options
context:
space:
mode:
authorBear <bear@bengtsson.win>2021-12-27 09:29:58 +0000
committerBear <bear@bengtsson.win>2021-12-27 09:29:58 +0000
commit69262b01ced79c2d776fab9b889926d1816a1e7a (patch)
treef304cd6fa8734e83a7772d07dc9b484781565155 /patch/bar_fancybar.c
Added DWM
Diffstat (limited to 'patch/bar_fancybar.c')
-rw-r--r--patch/bar_fancybar.c88
1 files changed, 88 insertions, 0 deletions
diff --git a/patch/bar_fancybar.c b/patch/bar_fancybar.c
new file mode 100644
index 0000000..10bac83
--- /dev/null
+++ b/patch/bar_fancybar.c
@@ -0,0 +1,88 @@
+int
+width_fancybar(Bar *bar, BarArg *a)
+{
+ return a->w;
+}
+
+int
+draw_fancybar(Bar *bar, BarArg *a)
+{
+ int ftw, mw, ew = 0, n = 0;
+ unsigned int i;
+ Client *c;
+ Monitor *m = bar->mon;
+
+ #if BAR_TITLE_LEFT_PAD_PATCH && BAR_TITLE_RIGHT_PAD_PATCH
+ int x = a->x + lrpad / 2, w = a->w - lrpad;
+ #elif BAR_TITLE_LEFT_PAD_PATCH
+ int x = a->x + lrpad / 2, w = a->w - lrpad / 2;
+ #elif BAR_TITLE_RIGHT_PAD_PATCH
+ int x = a->x, w = a->w - lrpad / 2;
+ #else
+ int x = a->x, w = a->w;
+ #endif // BAR_TITLE_LEFT_PAD_PATCH | BAR_TITLE_RIGHT_PAD_PATCH
+
+ for (c = m->clients; c; c = c->next) {
+ if (ISVISIBLE(c))
+ n++;
+ }
+
+ if (n > 0) {
+ ftw = TEXTW(m->sel->name);
+ #if BAR_WINICON_PATCH
+ if (m->sel->icon)
+ ftw += m->sel->icon->width + ICONSPACING;
+ #endif // BAR_WINICON_PATCH
+ mw = (ftw >= w || n == 1) ? 0 : (w - ftw) / (n - 1);
+
+ i = 0;
+
+ for (c = m->clients; c; c = c->next) {
+ if (!ISVISIBLE(c) || c == m->sel)
+ continue;
+ ftw = TEXTW(c->name);
+ #if BAR_WINICON_PATCH
+ if (c->icon)
+ ftw += c->icon->width + ICONSPACING;
+ #endif // BAR_WINICON_PATCH
+ if (ftw < mw)
+ ew += (mw - ftw);
+ else
+ i++;
+ }
+
+ if (i > 0)
+ mw += ew / i;
+
+ for (c = m->clients; c; c = c->next) {
+ if (!ISVISIBLE(c))
+ continue;
+ ftw = MIN(m->sel == c ? w : mw, TEXTW(c->name));
+ drw_setscheme(drw, scheme[m->sel == c ? SchemeTitleSel : SchemeTitleNorm]);
+ if (ftw > 0) { /* trap special handling of 0 in drw_text */
+
+ drw_text(drw, x, a->y, ftw, a->h, lrpad / 2, c->name, 0, False);
+
+ #if BAR_WINICON_PATCH
+ drw_text(drw, x, a->y, ftw, a->h, lrpad / 2 + (c->icon ? c->icon->width + ICONSPACING : 0), c->name, 0, False);
+ if (c->icon)
+ drw_img(drw, x + lrpad / 2, a->y + (a->h - c->icon->height) / 2, c->icon, tmpicon);
+ #else
+ drw_text(drw, x, a->y, ftw, a->h, lrpad / 2, c->name, 0, False);
+ #endif // BAR_WINICON_PATCH
+
+ }
+ drawstateindicator(c->mon, c, 1, x, a->y, ftw, a->h, 0, 0, c->isfixed);
+ x += ftw;
+ w -= ftw;
+ }
+ }
+ return n;
+}
+
+int
+click_fancybar(Bar *bar, Arg *arg, BarArg *a)
+{
+ return ClkWinTitle;
+}
+