From cc77e839d86fda9871f5fde89350d51465ec208b Mon Sep 17 00:00:00 2001
From: Frederic Culot <calcurse@culot.org>
Date: Sun, 21 Mar 2010 09:21:06 +0000
Subject: More work on sidebar customization.

---
 src/calcurse.h |  13 ++++++--
 src/calendar.c |   9 ++---
 src/custom.c   |  20 +++++++----
 src/io.c       |   7 +++-
 src/wins.c     | 104 +++++++++++++++++++++++++++++++++++++++++++++++----------
 5 files changed, 123 insertions(+), 30 deletions(-)

(limited to 'src')

diff --git a/src/calcurse.h b/src/calcurse.h
index ce335eb..fa18b56 100644
--- a/src/calcurse.h
+++ b/src/calcurse.h
@@ -1,4 +1,4 @@
-/*	$Id: calcurse.h,v 1.2 2010/03/20 13:29:47 culot Exp $	*/
+/*	$Id: calcurse.h,v 1.3 2010/03/21 09:21:07 culot Exp $	*/
 
 /*
  * Calcurse - text-based organizer
@@ -133,6 +133,10 @@
 /* Maximum number of colors available. */
 #define NBUSERCOLORS	6
 
+/* Side bar width acceptable boundaries. */
+#define SBARMINWIDTH     32
+#define SBARMAXWIDTHPERC 50
+
 /* Related to date manipulation. */
 #define DAYINSEC        86400
 #define HOURINSEC       3600
@@ -893,9 +897,13 @@ void vars_init (struct conf *);
 
 /* wins.c */
 extern struct window win[NBWINS];
-extern unsigned sbarwidth;
 int       wins_layout (void);
 void      wins_set_layout (int);
+unsigned  wins_sbar_width (void);
+unsigned  wins_sbar_wperc (void);
+void      wins_set_sbar_width (unsigned);
+void      wins_sbar_winc (void);
+void      wins_sbar_wdec (void);
 void      wins_slctd_init (void);
 enum win  wins_slctd (void);
 void      wins_slctd_set (enum win);
@@ -907,6 +915,7 @@ void      wins_scrollwin_display (struct scrollwin *);
 void      wins_scrollwin_up (struct scrollwin *, int);
 void      wins_scrollwin_down (struct scrollwin *, int);
 void      wins_reinit (void);
+void      wins_reinit_panels (void);
 void      wins_show (WINDOW *, char *);
 void      wins_get_config (void);
 void      wins_update_border (void);
diff --git a/src/calendar.c b/src/calendar.c
index ae3f4ac..c129ec5 100755
--- a/src/calendar.c
+++ b/src/calendar.c
@@ -1,4 +1,4 @@
-/*	$calcurse: calendar.c,v 1.34 2010/03/20 13:29:48 culot Exp $	*/
+/*	$calcurse: calendar.c,v 1.35 2010/03/21 09:21:07 culot Exp $	*/
 
 /*
  * Calcurse - text-based organizer
@@ -306,17 +306,18 @@ draw_monthly_view (struct window *cwin, struct date *current_day,
                    unsigned sunday_first)
 {
   const int OFFY = 2 + (CALHEIGHT - 9) / 2;
-  const int OFFX = (sbarwidth - 27) / 2;
   struct date check_day;
   int c_day, c_day_1, day_1_sav, numdays, j;
   unsigned yr, mo;
-  int ofs_x, ofs_y;
+  int OFFX, SBAR_WIDTH, ofs_x, ofs_y;
   int item_this_day = 0;
 
   mo = slctd_day.mm;
   yr = slctd_day.yyyy;
 
   /* offset for centering calendar in window */
+  SBAR_WIDTH = wins_sbar_width ();
+  OFFX = (SBAR_WIDTH - 27) / 2;
   ofs_y = OFFY;
   ofs_x = OFFX;
 
@@ -334,7 +335,7 @@ draw_monthly_view (struct window *cwin, struct date *current_day,
   /* Write the current month and year on top of the calendar */
   custom_apply_attr (cwin->p, ATTR_HIGHEST);
   mvwprintw (cwin->p, ofs_y,
-             (sbarwidth - (strlen (_(monthnames[mo - 1])) + 5)) / 2,
+             (SBAR_WIDTH - (strlen (_(monthnames[mo - 1])) + 5)) / 2,
 	     "%s %d", _(monthnames[mo - 1]), slctd_day.yyyy);
   custom_remove_attr (cwin->p, ATTR_HIGHEST);
   ++ofs_y;
diff --git a/src/custom.c b/src/custom.c
index 053d30f..007c71b 100755
--- a/src/custom.c
+++ b/src/custom.c
@@ -1,4 +1,4 @@
-/*	$calcurse: custom.c,v 1.47 2010/03/20 13:29:48 culot Exp $	*/
+/*	$calcurse: custom.c,v 1.48 2010/03/21 09:21:07 culot Exp $	*/
 
 /*
  * Calcurse - text-based organizer
@@ -43,7 +43,7 @@
 #include "calcurse.h"
 
 /* Available configuration variables. */
-enum {
+enum conf_var {
   CUSTOM_CONF_NOVARIABLE,
   CUSTOM_CONF_AUTOSAVE,
   CUSTOM_CONF_PERIODICSAVE,
@@ -55,6 +55,7 @@ enum {
   CUSTOM_CONF_WEEKBEGINSONMONDAY,
   CUSTOM_CONF_COLORTHEME,
   CUSTOM_CONF_LAYOUT,
+  CUSTOM_CONF_SBAR_WIDTH,
   CUSTOM_CONF_NOTIFYBARSHOW,
   CUSTOM_CONF_NOTIFYBARDATE,
   CUSTOM_CONF_NOTIFYBARCLOCK,
@@ -242,7 +243,7 @@ custom_load_conf (struct conf *conf, int background)
   char *mesg_line1 = _("Failed to open config file");
   char *mesg_line2 = _("Press [ENTER] to continue");
   char buf[BUFSIZ], e_conf[BUFSIZ];
-  int var;
+  enum conf_var var;
 
   data_file = fopen (path_conf, "r");
   if (data_file == NULL)
@@ -311,6 +312,10 @@ custom_load_conf (struct conf *conf, int background)
 	  wins_set_layout (atoi (e_conf));
 	  var = 0;
 	  break;
+        case CUSTOM_CONF_SBAR_WIDTH:
+          wins_set_sbar_width (atoi (e_conf));
+          var = 0;
+          break;
 	case CUSTOM_CONF_NOTIFYBARSHOW:
 	  nbar.show = fill_config_var (e_conf);
 	  var = 0;
@@ -375,6 +380,8 @@ custom_load_conf (struct conf *conf, int background)
 	var = CUSTOM_CONF_COLORTHEME;
       else if (strncmp (e_conf, "layout=", 7) == 0)
 	var = CUSTOM_CONF_LAYOUT;
+      else if (strncmp (e_conf, "side-bar_width=", 15) == 0)
+        var = CUSTOM_CONF_SBAR_WIDTH;
       else if (strncmp (e_conf, "notify-bar_show=", 16) == 0)
 	var = CUSTOM_CONF_NOTIFYBARSHOW;
       else if (strncmp (e_conf, "notify-bar_date=", 16) == 0)
@@ -605,6 +612,7 @@ custom_sidebar_config (void)
 
   keys_display_bindings_bar (win[STA].p, binding, 0, binding_size);
   doupdate ();
+
   while ((ch = keys_getch (win[STA].p)) != KEY_GENERIC_QUIT)  
     {
       unsigned need_update;
@@ -613,11 +621,11 @@ custom_sidebar_config (void)
       switch (ch)
         {
         case KEY_MOVE_UP:
-          sbarwidth++;
+          wins_sbar_winc ();
           need_update = 1;
           break;
         case KEY_MOVE_DOWN:
-          sbarwidth--;
+          wins_sbar_wdec ();
           need_update = 1;
           break;
         case KEY_GENERIC_HELP:
@@ -629,7 +637,7 @@ custom_sidebar_config (void)
 
       if (need_update)
         {
-          wins_reinit ();
+          wins_reinit_panels ();
           wins_update_border ();
           wins_update_panels ();
           keys_display_bindings_bar (win[STA].p, binding, 0, binding_size);
diff --git a/src/io.c b/src/io.c
index 28b6bdb..79ca3c0 100755
--- a/src/io.c
+++ b/src/io.c
@@ -1,4 +1,4 @@
-/*	$calcurse: io.c,v 1.81 2010/03/20 10:54:46 culot Exp $	*/
+/*	$calcurse: io.c,v 1.82 2010/03/21 09:21:07 culot Exp $	*/
 
 /*
  * Calcurse - text-based organizer
@@ -887,6 +887,11 @@ io_save_conf (struct conf *conf)
   (void)fprintf (fp, "\n# This is the layout of the calendar :\n");
   (void)fprintf (fp, "layout=\n");
   (void)fprintf (fp, "%d\n", wins_layout ());
+
+  (void)fprintf (fp, "\n# Width (in percentage, 0 being minimun width) "
+                 "of the side bar :\n");
+  (void)fprintf (fp, "side-bar_width=\n");
+  (void)fprintf (fp, "%d\n", wins_sbar_wperc ());
   
   if (ui_mode == UI_CURSES)
     pthread_mutex_lock (&nbar.mutex);
diff --git a/src/wins.c b/src/wins.c
index 91a7640..8cdd9da 100755
--- a/src/wins.c
+++ b/src/wins.c
@@ -1,4 +1,4 @@
-/*	$calcurse: wins.c,v 1.30 2010/03/20 13:29:48 culot Exp $	*/
+/*	$calcurse: wins.c,v 1.31 2010/03/21 09:21:07 culot Exp $	*/
 
 /*
  * Calcurse - text-based organizer
@@ -46,7 +46,7 @@
 struct window win[NBWINS];
 
 /* User-configurable side bar width. */
-unsigned sbarwidth = 30;
+static unsigned sbarwidth;
 
 static enum win slctd_win;
 static int layout;
@@ -55,7 +55,7 @@ static int layout;
 int
 wins_layout (void)
 {
-  return (layout);
+  return layout;
 }
 
 /* Set the current layout. */
@@ -65,6 +65,63 @@ wins_set_layout (int nb)
   layout = nb;
 }
 
+/* Get the current side bar width. */
+unsigned
+wins_sbar_width (void)
+{
+  return sbarwidth ? sbarwidth : SBARMINWIDTH;
+}
+
+/*
+ * Return the side bar width in percentage of the total number of columns
+ * available in calcurse's screen.
+ */
+unsigned
+wins_sbar_wperc (void)
+{
+  unsigned perc;
+
+  perc = col ? (unsigned)(100 * sbarwidth / col + 1): 0;
+  
+  return perc > SBARMAXWIDTHPERC ? SBARMAXWIDTHPERC : perc;
+}
+
+/*
+ * Set side bar width (unit: number of characters) given a width in percentage
+ * of calcurse's screen total width.
+ * The side bar could not have a width representing more than 50% of the screen,
+ * and could not be less than SBARMINWIDTH characters.
+ */
+void
+wins_set_sbar_width (unsigned perc)
+{
+  if (perc > SBARMAXWIDTHPERC)
+    sbarwidth = col * SBARMAXWIDTHPERC / 100;
+  else if (perc <= 0)
+    sbarwidth = SBARMINWIDTH;
+  else
+    {
+      sbarwidth = (unsigned)(col * perc / 100);
+      if (sbarwidth < SBARMINWIDTH)
+        sbarwidth = SBARMINWIDTH;
+    }
+}
+
+/* Change the width of the side bar within acceptable boundaries. */
+void
+wins_sbar_winc (void)
+{
+  if (sbarwidth < SBARMAXWIDTHPERC * col / 100)
+    sbarwidth++;
+}
+
+void
+wins_sbar_wdec (void)
+{
+  if (sbarwidth > SBARMINWIDTH)
+    sbarwidth--;
+}
+
 /* Initialize the selected window in calcurse's interface. */
 void
 wins_slctd_init (void)
@@ -96,17 +153,12 @@ wins_slctd_next (void)
     slctd_win++;
 }
 
-/* Create all the windows. */
-void
-wins_init (void)
+static void
+wins_init_panels (void)
 {
   char label[BUFSIZ];
-
-  /* 
-   * Create the three main windows plus the status bar and the pad used to
-   * display appointments and event. 
-   */
-  win[CAL].p = newwin (CALHEIGHT, sbarwidth, win[CAL].y, win[CAL].x);
+  
+  win[CAL].p = newwin (CALHEIGHT, wins_sbar_width (), win[CAL].y, win[CAL].x);
   (void)snprintf (label, BUFSIZ, _("Calendar"));
   wins_show (win[CAL].p, label);
 
@@ -120,12 +172,19 @@ wins_init (void)
   (void)snprintf (label, BUFSIZ, _("ToDo"));
   wins_show (win[TOD].p, label);
 
-  win[STA].p = newwin (win[STA].h, win[STA].w, win[STA].y, win[STA].x);
-
-  /* Enable function keys (i.e. arrow keys) in those windows */
+  /* Enable function keys (i.e. arrow keys) in those windows */  
   keypad (win[CAL].p, TRUE);
   keypad (win[APP].p, TRUE);
   keypad (win[TOD].p, TRUE);
+}
+
+/* Create all the windows. */
+void
+wins_init (void)
+{
+  wins_init_panels ();
+  win[STA].p = newwin (win[STA].h, win[STA].w, win[STA].y, win[STA].x);
+
   keypad (win[STA].p, TRUE);
 
   /* Notify that the curses mode is now launched. */
@@ -195,6 +254,17 @@ wins_scrollwin_down (struct scrollwin *sw, int amount)
     sw->first_visible_line += amount;
 }
 
+void
+wins_reinit_panels (void)
+{
+  delwin (win[CAL].p);
+  delwin (win[APP].p);
+  delwin (apad.ptrwin);
+  delwin (win[TOD].p);
+  wins_get_config ();
+  wins_init_panels ();
+}
+
 /* 
  * Delete the existing windows and recreate them with their new
  * size and placement.
@@ -202,11 +272,11 @@ wins_scrollwin_down (struct scrollwin *sw, int amount)
 void
 wins_reinit (void)
 {
-  delwin (win[STA].p);
   delwin (win[CAL].p);
   delwin (win[APP].p);
   delwin (apad.ptrwin);
   delwin (win[TOD].p);
+  delwin (win[STA].p);
   wins_get_config ();
   wins_init ();
   if (notify_bar ())
@@ -260,7 +330,7 @@ wins_get_config (void)
       win[NOT].x = 0;
     }
 
-  win[CAL].w = sbarwidth;
+  win[CAL].w = wins_sbar_width ();
   win[CAL].h = CALHEIGHT;
   
   if (layout <= 4)
-- 
cgit v1.2.3-70-g09d2