================================================================
 Preferences for the person list when using user defined fields
================================================================

The person list can be customized using preferences, even user defined
fields are displayed:

Set up
======

We need a browser to access the address book:

>>> from icemac.addressbook.testing import Browser
>>> browser = Browser()
>>> browser.login('mgr')
>>> browser.open('http://localhost/ab')

And some user definded fields:

>>> from icemac.addressbook.testing import create_field
>>> ab = layer['addressbook']
>>> _ = create_field(ab, 'icemac.addressbook.person.Person',
...                u'Bool', u'photo permission?')
>>> _ = create_field(ab, 'icemac.addressbook.person.Person',
...                  u'Datetime', u'last seen')
>>> _ = create_field(ab, 'icemac.addressbook.address.PostalAddress',
...                  u'Choice', u'state',
...                  values=[u'Sachsen', u'Sachsen-Anhalt', u'Brandenburg'])
>>> _ = create_field(ab, 'icemac.addressbook.address.PostalAddress',
...                  u'Int', u'number of letters')
>>> _ = create_field(ab, 'icemac.addressbook.address.PostalAddress',
...                  u'Date', u'last time verified')
>>> _ = create_field(ab, 'icemac.addressbook.address.PhoneNumber',
...                  u'Decimal', u'cost per minute')
>>> _ = create_field(ab, 'icemac.addressbook.address.PhoneNumber',
...                  u'Text', u'mail box text')
>>> _ = create_field(ab, 'icemac.addressbook.address.HomePageAddress',
...                  u'URI', u'company home page')
>>> _ = create_field(ab, 'icemac.addressbook.address.HomePageAddress',
...                  u'TextLine', u'home page provider')

And some data in the fields:

>>> from icemac.addressbook.testing import get_messages
>>> browser.getLink('person').click()
>>> browser.getControl('last name').value = 'Tester'
>>> browser.getControl('yes').click()
>>> browser.getControl('number of letters').value = '42'
>>> browser.getControl('state').displayValue = ['Brandenburg']
>>> browser.getControl('cost per minute').value = '1.45'
>>> browser.getControl('mail box text').value = (
...     'Hi, I do not like the boring texts of the answering machines ...')
>>> browser.getControl('company home page').value = 'http://www.mycompany.de'
>>> browser.getControl('home page provider').value = 'mycomp'
>>> browser.getControl('Add').click()
>>> get_messages(browser)
['"Tester" added.']
>>> browser.url
'http://localhost/ab/person-list.html'

>>> browser.getLink('person').click()
>>> browser.getControl('last name').value = 'Utzer'
>>> browser.getControl('last time verified').value = '01/01/08'
>>> browser.getControl('last seen').value = '10/08/09 20:15'
>>> browser.getControl('Add').click()
>>> get_messages(browser)
['"Utzer" added.']


Selecting columns
=================

The user defined fields show up in the columns list in the preferences:

>>> from pprint import pprint
>>> browser.getLink('Preferences').click()
>>> pprint(browser.getControl('order by').displayOptions)
['person -- first name',
 'person -- last name',
 'person -- birth date',
 'person -- keywords',
 'person -- notes',
 'person -- photo permission?',
 'person -- last seen',
 'postal address -- address prefix',
 'postal address -- street',
 'postal address -- city',
 'postal address -- zip',
 'postal address -- country',
 'postal address -- number of letters',
 'postal address -- last time verified',
 'postal address -- state',
 'phone number -- number',
 'phone number -- cost per minute',
 'phone number -- mail box text',
 'e-mail address -- e-mail address',
 'home page address -- URL',
 'home page address -- company home page',
 'home page address -- home page provider']

Selecting columns shows them in the person list:

>>> from icemac.addressbook.testing import in_out_widget_select
>>> in_out_widget_select(browser, 'form.widgets.columns',
...     [browser.getControl('person -- photo permission?', index=0),
...      browser.getControl('person -- last seen', index=0),
...      browser.getControl('postal address -- number of letters', index=0),
...      browser.getControl('postal address -- last time verified', index=0),
...      browser.getControl('postal address -- state', index=0),
...      browser.getControl('phone number -- cost per minute', index=0),
...      browser.getControl('phone number -- mail box text', index=0),
...      browser.getControl('home page address -- company home page', index=0),
...      browser.getControl('home page address -- home page provider', index=0),
...      browser.getControl('person -- last name', index=0)])
>>> browser.getControl('Apply').click()
>>> get_messages(browser)
['Data successfully updated.']
>>> print browser.contents
<!DOCTYPE ...
  <tbody>
    <tr class="table-even-row">
      <td>yes</td>
      <td></td>
      <td>Brandenburg</td>
      <td>Hi, I do not like the …</td>
      <td><a href="http://www.mycompany.de" target="_blank">http://www.mycompany.de</a></td>
      <td></td>
      <td>1.45</td>
      <td>mycomp</td>
      <td>42</td>
      <td><a href="http://localhost/ab/Person">Tester</a></td>
    </tr>
    <tr class="table-odd-row">
      <td></td>
      <td>2001 1 8 </td>
      <td></td>
      <td></td>
      <td></td>
      <td>2010 8 9  20:15:00 </td>
      <td></td>
      <td></td>
      <td></td>
      <td><a href="http://localhost/ab/Person-2">Utzer</a></td>
    </tr>
  </tbody>
  ...

Deleted column which was selected for display
=============================================

When the user has deleted a user defined column which was selected for
display, neither the person list nor the perferences form are breaking.

Deleting column
---------------

Let's delete the "photo permission?" column:

>>> browser.getLink('Master data').click()
>>> browser.getLink('Entities').click()
>>> browser.getLink('Edit fields', index=1).click()
>>> browser.url
'http://localhost/.../++attribute++entities/icemac.addressbook.person.Person'
>>> browser.getLink('Delete').click()
>>> print browser.contents
<!DOCTYPE ...
...photo permission?...
>>> browser.getControl('Yes, delete').click()
>>> get_messages(browser)
['"photo permission?" deleted.']


Person list
-----------

Deleted columns are omitted from the person list. The sort order is kept as
set in preferences:

>>> browser.getLink('Person list').click()
>>> print browser.contents
<!DOCTYPE ...
  <tbody>
    <tr class="table-even-row">
      <td></td>
      <td>Brandenburg</td>
      <td>Hi, I do not like the …</td>
      <td><a href="http://www.mycompany.de" target="_blank">http://www.mycompany.de</a></td>
      <td></td>
      <td>1.45</td>
      <td>mycomp</td>
      <td>42</td>
      <td><a href="http://localhost/ab/Person">Tester</a></td>
    </tr>
    <tr class="table-odd-row">
      <td>2001 1 8 </td>
      <td></td>
      <td></td>
      <td></td>
      <td>2010 8 9  20:15:00 </td>
      <td></td>
      <td></td>
      <td></td>
      <td><a href="http://localhost/ab/Person-2">Utzer</a></td>
    </tr>
  </tbody>
  ...


Preferences form
----------------

Deleted columns are omitted in the preferences form:

>>> browser.getLink('Preferences').click()
>>> pprint(browser.getControl('order by').displayOptions)
['person -- first name',
 'person -- last name',
 'person -- birth date',
 'person -- keywords',
 'person -- notes',
 'person -- last seen',
 'postal address -- address prefix',
 'postal address -- street',
 'postal address -- city',
 'postal address -- zip',
 'postal address -- country',
 'postal address -- number of letters',
 'postal address -- last time verified',
 'postal address -- state',
 'phone number -- number',
 'phone number -- cost per minute',
 'phone number -- mail box text',
 'e-mail address -- e-mail address',
 'home page address -- URL',
 'home page address -- company home page',
 'home page address -- home page provider']


Deleted order-by column
=======================

When the user has deleted a user defined column which was selected as
order-by column, neither the person list nor the perferences form are
breaking.

Selecting column
----------------

Let's select the "person -- last seen" column for order by:

>>> browser.getLink('Preferences').click()
>>> in_out_widget_select(browser, 'form.widgets.columns',
...     [browser.getControl('person -- last seen', index=0),
...      browser.getControl('person -- last name', index=0)])
>>> browser.getControl('order by').displayValue = ['person -- last seen']
>>> browser.getControl('Apply').click()
>>> get_messages(browser)
['Data successfully updated.']
>>> print browser.contents
<!DOCTYPE ...
  <tbody>
    <tr class="table-even-row">
      <td>2010 8 9  20:15:00 </td>
      <td><a href="http://localhost/ab/Person-2">Utzer</a></td>
    </tr>
    <tr class="table-odd-row">
      <td></td>
      <td><a href="http://localhost/ab/Person">Tester</a></td>
    </tr>
  </tbody>
  ...


Deleting column
---------------

Let's delete the currently selected order-by column "last seen" on "person":

>>> browser.getLink('Master data').click()
>>> browser.getLink('Entities').click()
>>> browser.getLink('Edit fields', index=1).click()
>>> browser.url
'http://localhost/.../++attribute++entities/icemac.addressbook.person.Person'
>>> browser.getLink('Delete').click()
>>> print browser.contents
<!DOCTYPE ...
...last seen...
>>> browser.getControl('Yes, delete').click()


Person list
-----------

When the order-by column gets deleted, the results are sorted by the first
column:

>>> browser.getLink('Person list').click()
>>> print browser.contents
<!DOCTYPE ...
  <tbody>
    <tr class="table-even-row">
      <td><a href="http://localhost/ab/Person">Tester</a></td>
    </tr>
    <tr class="table-odd-row">
      <td><a href="http://localhost/ab/Person-2">Utzer</a></td>
    </tr>
  </tbody>
  ...


Preferences form
----------------

Deleted columns are omitted in the preferences form:

>>> browser.getLink('Preferences').click()
>>> pprint(browser.getControl('order by').displayOptions)
['person -- first name',
 'person -- last name',
 'person -- birth date',
 'person -- keywords',
 'person -- notes',
 'postal address -- address prefix',
 'postal address -- street',
 'postal address -- city',
 'postal address -- zip',
 'postal address -- country',
 'postal address -- number of letters',
 'postal address -- last time verified',
 'postal address -- state',
 'phone number -- number',
 'phone number -- cost per minute',
 'phone number -- mail box text',
 'e-mail address -- e-mail address',
 'home page address -- URL',
 'home page address -- company home page',
 'home page address -- home page provider']

The first entry of the list is selected which means that no value is selected:

>>> browser.getControl('order by').displayValue
['person -- first name']
