3 "zavai" is a word of the Bolognese language which means "useless thing of no
4 value". The idea that I'm trying to do what I can with what I have.
6 It is written with the purpose of working for me; everything else is optional.
7 Feature requests for things that I don't need will likely be ignored unless
8 of course they come with patches.
12 * Install dependencies
15 apt-get install valac libglib2.0-dev libdbus-glib-1-dev libgee-dev libgtk2.0-dev libwnck-dev libdevkit-power-gobject-dev
18 apt-get install devicekit-power
21 apt-get install polygen polygen-data
27 * Install dbus.d configuration file
29 cp conf/zavai.conf /etc/dbus-1/system.d/
31 * Copy the .desktop files of the applications you use more often in ~/.zavai
36 cp /usr/share/applications/tangogps.desktop ~/.zavai
37 cp /usr/share/applications/navit.desktop ~/.zavai
38 cp /usr/share/applications/vala-terminal.desktop ~/.zavai
39 cp /usr/share/applications/midori.desktop ~/.zavai
40 cp /usr/share/applications/zhone.desktop ~/.zavai
41 cp /usr/share/applications/FBReader.desktop ~/.zavai
42 cp conf/satmon.desktop ~/.zavai
44 * Copy accessory scripts in ~/.zavai
46 cp hooks/display ~/.zavai
47 cp hooks/keyboard ~/.zavai
49 * Update the information about the polygen grammars installed in the system
52 src/update-polygen-info
58 This will run zavai and restart it if it quits/crashes. If you want to
59 restart zavai (for example after you build a new version) just choose
66 Push the power button to get the power menu, with options to
67 suspend/shutdown/reboot, lock the screen and keep the backlight always on
68 (useful if you are using the openmoko as a satellite navigator in the car)
72 Hold the power button longer to lock / unlock the screen. If the screen is
73 locked you see a lock icon in the traybar.
75 A short push of the power button while locked will turn on the backlight for a
76 bit, which is useful if you want to check the map for a moment. Another short
77 push will show the main zavai window, which is useful if you want to see the
78 time. Another short push will hide the main zavai window.
82 In the main window you see the time. If your GPS has a fix, the time comes
85 In the top left there is a gps icon. Push it to toggle the GPS to be always on
86 (useful to restart tangogps or navit without needing to reacquire a fix).
88 In the bottom there is a button to access the main menu.
92 Zavai shows several tray bar buttons. One kills the current application (or
93 goes back in the menu if the current application is zavai).
95 One hides and shows zavai.
97 One hides and shows the keyboard.
99 One shows the status of the battery.
103 The menu should be self-explanatory. It has options for simple GPS management
104 tasks, setting an alarm, running applications, a task switcher, and a polygen
109 It is possible to set an alarm, which will be shown in the alarm window. When
110 the alarm expires, the phone wakes up if it is suspended, and zavai vibrates
113 It is planned to use the AUX button to acknowledge the alarm and stop the
114 vibration; when this will happen, vibration can go on for more than 5 seconds.
116 When I'll implement some audio playing infrastructure, I'll implement playing
117 an audio file as well.
119 Also missing are a popup that tells that an alarm is ringing, and a notifier
120 for unacknowledged popups.
124 Details: the alarms are scheduled with at(1). Please see omhacks for simple
125 suspend hooks that will wake up the phone to run scheduled at jobs.
129 You can reach the calendar from the menu or by clicking on the date in the
132 The calendar shows notes on every day. You can add notes just by typing on the
133 white space below the calendar.
135 The notes are saved in ~/.zavai/cal/YEAR/MONTH/DAY.txt, feel free to:
136 - sync it with your main computer;
137 - create a tool that populates it using the information from your
138 favourite calendar system;
139 - interface zavai with a proper calendar system, without making the interface
140 harder to use (if you can).
144 Zavai currently focuses on the interface side, trying to make it easy for me
145 to reach the functions that I need. I try not to focus on hardware details
146 (yet) (when I can), so I build it on the freesmartphone framework, which is
147 unstable, underdocumented and sometimes untested, whose developers so far have
148 never answered my questions and whose API tends to change every now and again.
150 This said, I'm surprised it works for me so far.
152 TODO list / wish list
154 * FSO API "documentation":
155 http://git.freesmartphone.org/?p=specs.git;a=blob_plain;f=html/index.html;hb=HEAD
159 + use a TreeStore as a backend (precaching the elements in an array)
160 + draw something outside of focus area
161 + ensure that the first and last items are selectable
162 + rename in FisheyeListView
163 - Split polygen applet in a separate app, ran via a .desktop file
164 (faster zavai startup time, can then integrate a browser in the polygen
165 applet, makes more sense altogether)
166 - polygen applet with FisheyeListView
168 - contacts: show as a fancy focus+context list (see prefuse)
169 - vcard on e-vcard.{h,c}
170 - ical on libical-dev
174 - vibrate at alarm trigger
175 - play sound at alarm trigger
176 - acknowledge alarms with AUX button
177 - then, vibrate and play sound for longer
178 - popup that tells that an alarm is ringing
179 - leave expired alarm on screen until acknowledged
180 (alarm status icon that also brings to alarm menu)
181 - remember alarm names (on request, maybe with an add feature) and how
182 often they are triggered, and show them most frequent first
183 - remember unexpired alarms persistently (again, a table in sqlite?) so
184 that they can be reinstated if zavai is restarted
185 - show active alarms and allow to delete them
187 + power on/off the gps and start/stop gpsd
188 + set to keep the GPS on during suspend
189 - use the gpsd protocol
190 - suspend/resume hooks to put the GPS into low power mode
191 - next30: don't update if not shown currently on the notebook
192 - gtk_calendar_set_detail_func
193 - GSM power and network
194 - link to open SHR-dialer
195 - icon to show if there are new messages
196 - link to open SHR-messages
197 - switch backlight keep mode when on power/recharging
198 - the button changes the default for the current power mode
199 - unlock screen when receiving phone calls
200 - GPX status icon (off, waiting for fix, recording)
201 - GPX waypoint using AUX button
203 - track EPV (and similar) in gpx and kill trackpoints with bad accuracy
205 - shortcut icon in main screen
209 - start/stop wicd-client
210 - Simple wireless scanner (code from guessnet)
211 - Suspend phone if not calling and gps is not on and backlight is not on
212 (maybe with idle notifier?)
213 - Phone from kapula (or just running kapula)
214 - Is there a way to lock the screen completely turning off the touchscreen, so
215 that interrupts are not even generated?
217 - Location aware (show timezones in order of distance from current
219 - Show timezone in clock
222 - Why sometimes the phone will stop acting normal and will completely ignore
223 the screen for the purpose of screen dimming, that is, it will dim the
224 screen even if I'm using the touchscreen?
226 * Not quite needed yet:
227 - GPX log with more features (quality, course, speed, ...)
228 - Take a waypoint then show a menu with a timeout
229 - Add a scribbled note
231 - Add a text note (tickling the text input method thing)
232 If timeout expires, leave the waypoint with the automatic name
234 (also on dbus fuckup)
235 (can be done by just quitting and let the runner script restart it)
236 - get fix events without requesting the GPX resource (and then? gpx log all the time? what for?)