Gui progress

Version 134 (Adrian Georgescu, 07/21/2009 07:16 pm)

1 1 Adrian Georgescu
[[TOC(gui_progress, depth=3)]]
2 1 Adrian Georgescu
3 74 Adrian Georgescu
= Audio sessions =
4 1 Adrian Georgescu
5 115 Adrian Georgescu
 1. ~~ Incoming sessions do not display '''session information''' and the control buttons are missing~~
6 113 Adrian Georgescu
  1. Not getting a SessionDidStart notification from middleware on incoming sessions
7 115 Adrian Georgescu
 1. ~~ When '''rejecting a session''' it creates an entry in the drawer~~
8 1 Adrian Georgescu
 1. '''Cancel''' is not handled for incoming sessions, the pop-up remains active 
9 115 Adrian Georgescu
 1. ~~'''Maximize drawer''' when it opens the first time, it seem to open only 80% now ~~
10 76 Adrian Georgescu
 1. Play '''ringtones'''
11 115 Adrian Georgescu
 1. ~~ A terminated session must '''disappear from the drawer''' automatically after 5 seconds ~~
12 115 Adrian Georgescu
 1. ~~ Remaining sessions must '''shuffle to the top''' when a session ends~~
13 115 Adrian Georgescu
 1. ~~ Toggle hold does not change hold '''button color''' ~~
14 115 Adrian Georgescu
 1. ~~ Update session audio information with '''Hold by remote''' when held by remote party ~~
15 115 Adrian Georgescu
 1. ~~ Only one audio session can be '''active at a time''', all other existing audio sessions must be put on hold~~
16 115 Adrian Georgescu
 1. ~~ Highlight the '''active session''' with a bold border, click on a session to select it as the active session~~
17 75 Adrian Georgescu
 1. When the active session is selected, what is typed on the keyboard must be transmitted as '''DTMF tones'''
18 115 Adrian Georgescu
 1. ~~ When a call is connected move keyboard focus to it ~~
19 115 Adrian Georgescu
 1. ~~ When a session has ended, display it for '''5 more seconds''' then hide it and shuffle the deck  ~~
20 115 Adrian Georgescu
 1. ~~ Add an item '''Show audio sessions''' to the '''Session menu''' to show the drawer, if it was closed  (activated the View -> Toggle Sessions Drawer) ~~
21 117 Adrian Georgescu
 1. Remove the '''i''' icon, display a black triangle instead (black triangle?). Maybe is beter to just click on audio info to get a pop up with more information?
22 115 Adrian Georgescu
 1. ~~ '''Scroll bar''' appears as result of multiple sessions, but it does not disappear when the number of session decreases~~
23 115 Adrian Georgescu
 1. ~~ '''Hangup All''' is not implemented~~
24 119 Adrian Georgescu
 1. Display icon with lock when sRTP is active
25 123 Adrian Georgescu
 1. Disable Hangup All button if no session is active
26 123 Adrian Georgescu
 1. Disable Conference button if less than two sessions active
27 123 Adrian Georgescu
28 131 Adrian Georgescu
= Chat sessions =
29 131 Adrian Georgescu
30 131 Adrian Georgescu
 1. Display the full From and To headers
31 133 Adrian Georgescu
 1. Display timestamp in HH:MM:ss format to the right side of the window, same lin as From/To header
32 134 Adrian Georgescu
 1. Display the number of '''un-read messages''' in non-visible tabs in a red circle over the tab name
33 133 Adrian Georgescu
 1. Add a status bar below recipient tab and display connection progress and information in the status bar
34 134 Adrian Georgescu
35 131 Adrian Georgescu
 1. Add a '''+''' button (add contact) in the window toolbar
36 131 Adrian Georgescu
 1. Add show history button on toolbar
37 133 Adrian Georgescu
 1. Add '''File transfer''' button on toolbar
38 134 Adrian Georgescu
 1. Add a '''history drawer''' to the chat window and list the days in format YYYY-MM-dd in the drawer
39 134 Adrian Georgescu
 1. When close the window or clcik on close button call session.end() if the session has no other stream or session.remove_stream() if session has other streams. Do not prompt the user.
40 1 Adrian Georgescu
 1. Append chat messages to '''chat.history_directory/sip_account/YYYYMMDD-recipient.txt'''
41 131 Adrian Georgescu
 1. Play an audible message when a message is received, based on '''silent''' and '''general.message_received_sound''' settings
42 131 Adrian Georgescu
 1. Play an audible message when a message is sent, based on silent and '''general.message_sent_sound''' settings
43 131 Adrian Georgescu
 1. '''Throttle playback''' of audible notifications to maximum one every 3 seconds 
44 131 Adrian Georgescu
 1. When dragging a recipient tab outside of the window '''spawn a new chat window''' and move the session into it
45 134 Adrian Georgescu
 1. Make the horizontal delimiter drag-able
46 131 Adrian Georgescu
 1. When start typing send '''is-composing'''. This requires implementing the is-composing payload parser, see http://sipsimpleclient.com/ticket/40. If user has deleted the typed text before sending it update is-composing. 
47 131 Adrian Georgescu
48 131 Adrian Georgescu
= Main interface =
49 131 Adrian Georgescu
50 131 Adrian Georgescu
 1. When selecting a different account, mark it as '''default''' using the settings api
51 131 Adrian Georgescu
 1. '''Remove account''' from list when is disabled in preferences  
52 131 Adrian Georgescu
 1. On startup, '''select the default account''' in the account list
53 131 Adrian Georgescu
 1. The SIP accounts are '''not de-registered''' on quit
54 131 Adrian Georgescu
 1. Add a '''minimize button''' to collapse the buddy list
55 131 Adrian Georgescu
 1. Hide the Add button + sign when the interface is collapsed
56 131 Adrian Georgescu
 1. Mute button is not implemented 
57 131 Adrian Georgescu
 1. If red button is pressed the main window disappears and is no option to bring it back
58 131 Adrian Georgescu
 1. No dock icon available
59 131 Adrian Georgescu
60 32 Adrian Georgescu
= History sessions =
61 128 Adrian Georgescu
62 120 Adrian Georgescu
 1. Use the same session drawer to display previous sessions
63 1 Adrian Georgescu
 1. Keep same layout as active session with the following changes:
64 1 Adrian Georgescu
   1. Instead of audio session information display the negotiated streams (Audio|Chat|Audio+Chat etc...)
65 1 Adrian Georgescu
   1. Instead of duration display '''YYYY-MM-DD HH:MM  Duration: HH:MM:SS''' 
66 84 Adrian Georgescu
   1. Add a button to call back in place of current session buttons
67 56 Adrian Georgescu
 1. Add a Session menu item to toggle the drawer content between active session and history sessions
68 1 Adrian Georgescu
 1. Show most recent sessions on top
69 1 Adrian Georgescu
70 132 Adrian Georgescu
= Contacts =
71 132 Adrian Georgescu
72 132 Adrian Georgescu
 1. When add contact without domain part always append curent domain
73 132 Adrian Georgescu
 1. '''Delete the contact''' when pressing delete
74 132 Adrian Georgescu
 1. After dialing a found contact, display back the buddy list
75 132 Adrian Georgescu
 1. Show search results from the system address book
76 132 Adrian Georgescu
 1. Add right click for contact:
77 132 Adrian Georgescu
  1. Start audio session
78 132 Adrian Georgescu
  1. Start chat session
79 132 Adrian Georgescu
  1. Transfer file
80 132 Adrian Georgescu
  1. Offer local desktop
81 132 Adrian Georgescu
  1. Request remote desktop
82 132 Adrian Georgescu
  1. Edit contact
83 132 Adrian Georgescu
  1. Delete contact
84 132 Adrian Georgescu
85 1 Adrian Georgescu
= Conferencing =
86 48 Adrian Georgescu
87 1 Adrian Georgescu
Only one conference is possible to make the interface easy to use.
88 41 Adrian Georgescu
89 84 Adrian Georgescu
To start a conference: 
90 84 Adrian Georgescu
91 1 Adrian Georgescu
 1. Send a re-INVITE to a) take each call off hold and b) set the is-focus attribute of the Contact header
92 1 Adrian Georgescu
 1. Set the conference bridge to mix audio between all parties
93 125 Adrian Georgescu
 1. Disable the hold buttons, they do not operate while in conference
94 59 Adrian Georgescu
 1. Draw the selection rectangle around the sessions part of the conference
95 59 Adrian Georgescu
96 1 Adrian Georgescu
To stop a conference
97 63 Adrian Georgescu
98 6 Adrian Georgescu
 1. Send a re-INVITE to a) take each call an leave only one off hold and b) disable is-focus attribute of the Contact header
99 111 Adrian Georgescu
 1. Set the conference bridge to stop mixing audio
100 111 Adrian Georgescu
 1. Enable the hold buttons
101 121 Adrian Georgescu
 1. Draw the selection rectangle around the selected session
102 121 Adrian Georgescu
103 121 Adrian Georgescu
New sessions while in a conference
104 121 Adrian Georgescu
105 121 Adrian Georgescu
 1. New sessions are added bellow the conference
106 121 Adrian Georgescu
 1. A session can be dragged in and out of the conference
107 121 Adrian Georgescu
 1. When switching from a conference to another single session, do not use hold
108 121 Adrian Georgescu
109 21 Adrian Georgescu
110 41 Adrian Georgescu
= Preferences =
111 41 Adrian Georgescu
112 122 Adrian Georgescu
 1. '''Change audio devices''' does not enter effect unless rebooting, call set_devices() to activate the new settings
113 42 Adrian Georgescu
 1. '''Stun server''' addresses cannot be set, they seem to inherit the results found in DNS  
114 42 Adrian Georgescu
 1. '''general.rtp.local_ip''': Can't set option local_ip illegal local IP address value: auto
115 42 Adrian Georgescu
 1. '''general.rtp.port_range''': (AttributeError: 'PortRangeOption' object has no attribute 'save')
116 42 Adrian Georgescu
 1. '''general.sip.transports''' cannot be saved
117 42 Adrian Georgescu
 1. '''general.audio.codec_list''' cannot be saved and displays duplicate codecs
118 42 Adrian Georgescu
 1. '''account.audio.codec_list''' cannot be saved and displays duplicate codecs
119 42 Adrian Georgescu
 1. '''account.msrp.relay''' cannot be set: global name 'MSRPRelayAddres' is not defined
120 42 Adrian Georgescu
 1. When '''disable account''' in preferences, it does not get removed from the main interface account lists
121 41 Adrian Georgescu
 1. Properly '''align''' horizontally the Advanced settings
122 41 Adrian Georgescu
 1. Display text to the '''left of the checkbox''' instead of the right
123 41 Adrian Georgescu
 1. '''Delete account Enabled checkbox''', leave only the checkbox in the account list
124 41 Adrian Georgescu
 1. '''De-register''' the account and remove it from the account list in main interface when disable the account
125 41 Adrian Georgescu
 1. When '''enable an account''', select it in the main interface account list
126 41 Adrian Georgescu
 1. Add a '''Reset option''' to reset advanced settings to default values
127 41 Adrian Georgescu
 1. Display the '''bonjour account''' always at the end of the list
128 94 Adrian Georgescu
 1. '''bonjour account''' has only Display name as main property.  There is not sip address or password
129 108 Adrian Georgescu
 1. Cannot '''delete Bonjour''' account: (TypeError: cannot delete BonjourAccount instance with default id). Do  not allow the user to attempt to delete it. Bonjour can only be enabled/disabled but not deleted.
130 41 Adrian Georgescu
 1. For '''account.ringtone''' advanced setting, the default setting must be inherited from '''general.ringtone.inbound'''
131 41 Adrian Georgescu
 1. '''general.message_received_sound''' does not fit in window
132 41 Adrian Georgescu
 1. Allow ordering of accounts in the account list
133 96 Adrian Georgescu
 1. While clicking on account I got this (cannot reproduce): (TypeError: 'NSAutoreleasePool' object is not iterable)
134 118 Adrian Georgescu
 1. Check if the wav file is in the right format before saving the settings related to ringtones
135 118 Adrian Georgescu
 1. Check if the TLS options set by the user are valid before saving them (by loading them outside the engine using gnutls library)
136 55 Adrian Georgescu
137 29 Adrian Georgescu
Display SIP registration state in '''account.advanced.registration''' section.
138 29 Adrian Georgescu
139 41 Adrian Georgescu
= Engine =
140 1 Adrian Georgescu
141 116 Adrian Georgescu
 1. Set User Agent name to blink-version
142 122 Adrian Georgescu
 1. If '''engine is dead''', the message  '''no sip account is active''' is displayed but is unclear what the real reason is. An engine stop must be logged to general debug window. Not clear how to restart the engine, maybe we should restart the application until a good solution is found
143 41 Adrian Georgescu
 1. If the engine has stopped (because of some crash) the preferences do not show anymore:
144 29 Adrian Georgescu
145 29 Adrian Georgescu
{{{
146 29 Adrian Georgescu
Blink[26992:10b] <type 'exceptions.AttributeError'>: 'Engine' object has no attribute 'output_devices'
147 29 Adrian Georgescu
}}}
148 29 Adrian Georgescu
149 29 Adrian Georgescu
By setting the wrong TLS certificate files, the middleware does not start anymore:
150 29 Adrian Georgescu
151 29 Adrian Georgescu
{{{
152 29 Adrian Georgescu
[Session started at 2009-07-19 10:37:39 +0200.]
153 29 Adrian Georgescu
Traceback (most recent call last):
154 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/BlinkAppDelegate.py", line 40,
155 29 Adrian Georgescu
   in applicationDidFinishLaunching_
156 29 Adrian Georgescu
    self.backend.init(options)
157 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/SIPManager.py", line 108, in init
158 29 Adrian Georgescu
    self._app.start(config_backend=config_be)
159 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/api.py", line 85, in start
160 29 Adrian Georgescu
    trace_sip=settings.logging.trace_sip,
161 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/engine.py", line 75, in start
162 41 Adrian Georgescu
    self._ua = PJSIPUA(self._handle_event, 1.1.init_options)
163 29 Adrian Georgescu
  File "core.ua.pxi", line 66, in sipsimple.core.PJSIPUA.__init__ (sipsimple/core.c:23189)
164 29 Adrian Georgescu
  File "core.lib.pxi", line 106, in sipsimple.core.PJSIPEndpoint.__cinit__ (sipsimple/core.c:6231)
165 29 Adrian Georgescu
  File "core.lib.pxi", line 167, in sipsimple.core.PJSIPEndpoint._start_tls_transport (sipsimple/core.c:6884)
166 29 Adrian Georgescu
PJSIPError: Could not create TLS transport: Error loading/verifying SSL CA list file (PJSIP_TLS_ECACERT)
167 29 Adrian Georgescu
None
168 1 Adrian Georgescu
}}}
169 34 Adrian Georgescu
170 1 Adrian Georgescu
= Presence bar =
171 1 Adrian Georgescu
172 1 Adrian Georgescu
Make it as high as the contacts (two rows high).
173 1 Adrian Georgescu
174 129 Adrian Georgescu
 1. Show '''own photo''' to the left, align photo and size with buddy list photos
175 41 Adrian Georgescu
 1. Show '''Display name''' next to the photo on top row
176 129 Adrian Georgescu
 1. Show '''Presence activity''' next to name on top row
177 129 Adrian Georgescu
 1. Show '''Presence activity note''' on second row, editable text
178 7 Adrian Georgescu
179 7 Adrian Georgescu
= Debug window =
180 1 Adrian Georgescu
181 7 Adrian Georgescu
 1. Display all traces in a '''debug window''' with tabs for each debug type
182 41 Adrian Georgescu
 1. Add a '''General messages''' window to the Debug menu, first item
183 41 Adrian Georgescu
184 1 Adrian Georgescu
= GUI settings =
185 1 Adrian Georgescu
186 1 Adrian Georgescu
Remember the following settings between restarts:
187 1 Adrian Georgescu
188 79 Adrian Georgescu
 1. '''Debug window''' and the selected tab
189 41 Adrian Georgescu
 1. Status of '''contact groups''' - colapsed/expanded and their order
190 41 Adrian Georgescu
 1. SIP '''accounts order''' list
191 41 Adrian Georgescu
192 100 Adrian Georgescu
= Middleware =
193 14 Adrian Georgescu
194 47 Adrian Georgescu
 1. On startup, check if the audio device from the preferences '''is available''' in the detected devices list. If not, set the device to the system default device and display a warning to the user to set the devices in the preferences
195 102 Adrian Georgescu
 1. Check the validity of the '''TLS''' settings/files before starting the engine
196 102 Adrian Georgescu
 1. It seems that the '''stun servers''' are learned from the DNS and cannot be overwritten in settings, they show up automatically
197 102 Adrian Georgescu
 1. If I set the relay to abcd.com standard '''port 2855''' must be used, now is set to zero: relay = abcd.com:0;transport=tls
198 102 Adrian Georgescu
 1. Append '''dummy''' to the lists of available audio devices
199 41 Adrian Georgescu
 1. We need a solution to accept a session without a 180- ringing. For instance we can have automatic answer based on various preferences.
200 41 Adrian Georgescu
 1. Move '''general.audio.codec_list''' to '''general.rtp.audio_codecs'''
201 41 Adrian Georgescu
 1. Move '''account.audio.codec_list''' to '''account.rtp.audio_codecs'''
202 1 Adrian Georgescu
 1. Move '''account.audio.srtp_encryption''' to '''account.rtp.srtp_encryption'''
203 1 Adrian Georgescu
 1. Delete '''general.audio.playback_dtmf''' setting
204 1 Adrian Georgescu
 1. Add '''general.audio.mute''' setting
205 1 Adrian Georgescu
 1. Delete '''account.audio''' section
206 1 Adrian Georgescu
 1. Add '''account.sip''' section
207 66 Adrian Georgescu
 1. Move '''account.outbound_proxy''' to '''account.sip.outbound_proxy'''
208 66 Adrian Georgescu
 1. Move '''account.presence.publish_interval''' to '''account.sip.publish_interval'''
209 66 Adrian Georgescu
 1. Move '''account.presence.subscribe_interval''' to '''account.sip.subscribe_interval'''
210 66 Adrian Georgescu
 1. Move '''account.registration.interval''' to '''account.sip.register_interval'''
211 66 Adrian Georgescu
 1. Delete '''account.ice.use_stun''', it is always true
212 66 Adrian Georgescu
 1. Rename '''account.ice''' to '''account.nat_traversal'''
213 68 Adrian Georgescu
 1. Rename '''account.ice.enabled''' to '''account.nat_traversal.enable_ice'''
214 109 Adrian Georgescu
 1. Delete global.chat.accept_types
215 109 Adrian Georgescu
 1. Delete global.chat.accept_wrapped_types