Index: /trunk/grails-app/controllers/AddressDetailedController.groovy
===================================================================
--- /trunk/grails-app/controllers/AddressDetailedController.groovy	(revision 397)
+++ /trunk/grails-app/controllers/AddressDetailedController.groovy	(revision 397)
@@ -0,0 +1,111 @@
+import org.codehaus.groovy.grails.plugins.springsecurity.Secured
+
+@Secured(['ROLE_AppAdmin', 'ROLE_Manager'])
+class AddressDetailedController extends BaseController {
+
+    def addressService
+
+    @Secured(['ROLE_AppAdmin', 'ROLE_Manager', 'ROLE_AppUser'])
+    def index = { redirect(action:list,params:params) }
+
+    // the delete, save and update actions only accept POST requests
+    static allowedMethods = [delete:'POST', save:'POST', update:'POST']
+
+    @Secured(['ROLE_AppAdmin', 'ROLE_Manager', 'ROLE_AppUser'])
+    def list = {
+        params.max = Math.min( params.max ? params.max.toInteger() : 10,  100)
+        [ addressInstanceList: Address.list( params ), addressInstanceTotal: Address.count() ]
+    }
+
+    @Secured(['ROLE_AppAdmin', 'ROLE_Manager', 'ROLE_AppUser'])
+    def show = {
+        def addressInstance = Address.get( params.id )
+
+        if(!addressInstance) {
+            flash.message = "Address not found with id ${params.id}"
+            redirect(action:list)
+        }
+        else { return [ addressInstance : addressInstance ] }
+    }
+
+    def delete = {
+        def addressInstance = Address.get( params.id )
+        if(addressInstance) {
+            try {
+                addressInstance.delete(flush:true)
+                flash.message = "Address ${params.id} deleted"
+                redirect(action:list)
+            }
+            catch(org.springframework.dao.DataIntegrityViolationException e) {
+                flash.message = "Address ${params.id} could not be deleted"
+                redirect(action:show,id:params.id)
+            }
+        }
+        else {
+            flash.message = "Address not found with id ${params.id}"
+            redirect(action:list)
+        }
+    }
+
+    def edit = {
+        def addressInstance = Address.get( params.id )
+
+        if(!addressInstance) {
+            flash.message = "Address not found with id ${params.id}"
+            redirect(action:list)
+        }
+        else {
+            return [ addressInstance : addressInstance ]
+        }
+    }
+
+    def update = {
+        def addressInstance = Address.get( params.id )
+        if(addressInstance) {
+            if(params.version) {
+                def version = params.version.toLong()
+                if(addressInstance.version > version) {
+                    
+                    addressInstance.errors.rejectValue("version", "address.optimistic.locking.failure", "Another user has updated this Address while you were editing.")
+                    render(view:'edit',model:[addressInstance:addressInstance])
+                    return
+                }
+            }
+            addressInstance.properties = params
+            if(!addressInstance.hasErrors() && addressInstance.save(flush: true)) {
+                flash.message = "Address ${params.id} updated"
+                redirect(action:show,id:addressInstance.id)
+            }
+            else {
+                render(view:'edit',model:[addressInstance:addressInstance])
+            }
+        }
+        else {
+            flash.message = "Address not found with id ${params.id}"
+            redirect(action:list)
+        }
+    }
+
+    def create = {
+        def result = addressService.create(params)
+
+        if(!result.error)
+            return [addressInstance: result.addressInstance]
+
+        flash.errorMessage = g.message(code: result.error.code, args: result.error.args)
+        redirect(action: list)
+    }
+
+    def save = {
+        def result = addressService.save(params)
+
+        if(!result.error) {
+            flash.message = g.message(code: "default.create.success", args: ["Address", result.addressInstance.id])
+            redirect(action:show, id: result.addressInstance.id)
+            return
+        }
+
+        render(view:'create', model:[addressInstance: result.addressInstance])
+    }
+
+}
Index: /trunk/grails-app/domain/Address.groovy
===================================================================
--- /trunk/grails-app/domain/Address.groovy	(revision 397)
+++ /trunk/grails-app/domain/Address.groovy	(revision 397)
@@ -0,0 +1,38 @@
+class Address {
+
+    AddressType addressType
+
+    Manufacturer manufacturer
+    Supplier supplier
+    Person person
+    Site site
+
+    String street1 = ''
+    String street2 = ''
+    String city = ''
+    String state = ''
+    String postCode = ''
+    String country = ''
+
+//     hasMany = []
+
+    static belongsTo = [Manufacturer, Supplier, Person, Site]
+
+    static constraints = {
+        street1(blank:false,maxSize:50)
+        street2(maxSize:50)
+        city(blank:false,maxSize:50)
+        state(blank:false,maxSize:50)
+        postCode(blank:false,maxSize:50)
+        country(blank:false,maxSize:50)
+        manufacturer(nullable:true)
+        supplier(nullable:true)
+        person(nullable:true)
+        site(nullable:true)
+    }
+
+    String toString() {
+        "${this.addressType}: ${this.street1}, ${this.city}"
+    }
+
+}
Index: /trunk/grails-app/domain/AddressType.groovy
===================================================================
--- /trunk/grails-app/domain/AddressType.groovy	(revision 397)
+++ /trunk/grails-app/domain/AddressType.groovy	(revision 397)
@@ -0,0 +1,16 @@
+class AddressType {
+    String name
+    String description = ""
+    boolean isActive = true
+
+//     static hasMany = [ : ]
+
+    static constraints = {
+        name(maxSize:50,unique:true,blank:false)
+        description(maxSize:100)
+    }
+
+    String toString() {
+        "${this.name}"
+    }
+}
Index: /trunk/grails-app/domain/Manufacturer.groovy
===================================================================
--- /trunk/grails-app/domain/Manufacturer.groovy	(revision 396)
+++ /trunk/grails-app/domain/Manufacturer.groovy	(revision 397)
@@ -5,5 +5,5 @@
     boolean isActive = true
 
-    static hasMany = [inventoryItems: InventoryItem]
+    static hasMany = [inventoryItems: InventoryItem, addresses: Address]
 
     static belongsTo = [InventoryItem]
Index: /trunk/grails-app/domain/Person.groovy
===================================================================
--- /trunk/grails-app/domain/Person.groovy	(revision 396)
+++ /trunk/grails-app/domain/Person.groovy	(revision 397)
@@ -5,5 +5,6 @@
                         taskModifications: TaskModification,
                         entries: Entry,
-                        tasks: Task]
+                        tasks: Task,
+                        addresses: Address]
 
     static belongsTo = [Authority]
Index: /trunk/grails-app/domain/Site.groovy
===================================================================
--- /trunk/grails-app/domain/Site.groovy	(revision 396)
+++ /trunk/grails-app/domain/Site.groovy	(revision 397)
@@ -8,5 +8,6 @@
     static hasMany = [sections: Section,
                                 siteExtendedAttributes: SiteExtendedAttribute,
-                                inventoryStores: InventoryStore]
+                                inventoryStores: InventoryStore,
+                                addresses: Address]
 
 //     static belongsTo = []
Index: /trunk/grails-app/domain/Supplier.groovy
===================================================================
--- /trunk/grails-app/domain/Supplier.groovy	(revision 396)
+++ /trunk/grails-app/domain/Supplier.groovy	(revision 397)
@@ -5,5 +5,5 @@
     boolean isActive = true
 
-    static hasMany = [inventoryItems: InventoryItem]
+    static hasMany = [inventoryItems: InventoryItem, addresses: Address]
 
     static belongsTo = [InventoryItem]
Index: /trunk/grails-app/i18n/messages.properties
===================================================================
--- /trunk/grails-app/i18n/messages.properties	(revision 396)
+++ /trunk/grails-app/i18n/messages.properties	(revision 397)
@@ -1,2 +1,4 @@
+address.owner.not.found=An owner (Person, Site, Manufacturer or Supplier) must be supplied to create an address.
+
 asset.tree.import.success=Asset tree imported.
 asset.tree.import.failure=Could not create asset tree from supplied file, failed on line {0}.
Index: /trunk/grails-app/services/AddressService.groovy
===================================================================
--- /trunk/grails-app/services/AddressService.groovy	(revision 397)
+++ /trunk/grails-app/services/AddressService.groovy	(revision 397)
@@ -0,0 +1,79 @@
+/**
+ * Provides a service class with methods to interact with Address domain class.
+ * Address stores the address for various objects in the database.
+ */
+class AddressService {
+
+    boolean transactional = false
+
+    def getAddress() {
+        """${this.street1}
+        ${this.street2}
+        ${this.city}
+        ${this.state}
+        ${this.postCode}
+        ${this.country}"""
+
+    }
+
+    def create(params) {
+        def result = [:]
+        def fail = { Map m ->
+            result.error = [ code: m.code, args: ["Address", params.id] ]
+            return result
+        }
+
+        if(!checkForOwner(params))
+            return fail(code:"address.owner.not.found")
+
+        result.addressInstance = new Address()
+        result.addressInstance.properties = params
+
+        // success
+        return result
+    }
+
+    def save(params) {
+        def result = [:]
+        def fail = { Map m ->
+            if(result.addressInstance && m.field)
+                result.addressInstance.errors.rejectValue(m.field, m.code)
+            result.error = [ code: m.code, args: ["Address", params.id] ]
+            return result
+        }
+
+        if(!checkForOwner(params))
+            return fail(code:"address.owner.not.found")
+
+        result.addressInstance = new Address(params)
+
+        if(result.addressInstance.hasErrors() || !result.addressInstance.save(flush: true))
+            return fail(code:"default.create.failure")
+
+        // success
+        return result
+    }
+
+    private checkForOwner(params) {
+        def manufacturerInstance
+        def supplierInstance
+        def personInstance
+        def siteInstance
+
+        if(params.manufacturer?.id)
+            manufacturerInstance = Manufacturer.get(params.manufacturer.id)
+        if(params.supplier?.id)
+            supplierInstance = Supplier.get(params.supplier.id)
+        if(params.person?.id)
+            personInstance = Person.get(params.person.id)
+        if(params.site?.id)
+            siteInstance = Site.get(params.site?.id)
+
+        if(!manufacturerInstance && !supplierInstance && !personInstance && !siteInstance)
+            return false
+
+        return true
+    }
+
+
+} // end of class
Index: /trunk/grails-app/services/CreateDataService.groovy
===================================================================
--- /trunk/grails-app/services/CreateDataService.groovy	(revision 396)
+++ /trunk/grails-app/services/CreateDataService.groovy	(revision 397)
@@ -58,6 +58,7 @@
         createBaseUnitsOfMeasure()
         createBasePeriods()
-        createBaseSupplierType()
-        createBaseManufacturerType()
+        createBaseSupplierTypes()
+        createBaseManufacturerTypes()
+        createBaseAddressTypes()
 
         // Tasks
@@ -470,5 +471,5 @@
     }
 
-    def createBaseSupplierType() {
+    def createBaseSupplierTypes() {
 
         // SupplierType
@@ -486,5 +487,5 @@
     }
 
-    def createBaseManufacturerType() {
+    def createBaseManufacturerTypes() {
 
         // ManufacturerType
@@ -501,4 +502,35 @@
         saveAndTest(manufacturerTypeInstance)
 
+    }
+
+    def createBaseAddressTypes() {
+
+        // AddressType
+        def addressTypeInstance
+
+        // AddressType #1
+        addressTypeInstance = new AddressType(name: "Postal",
+                                                                                description: "A postal address.")
+        saveAndTest(addressTypeInstance)
+
+        // AddressType #2
+        addressTypeInstance = new AddressType(name: "Physical",
+                                                                                description: "A physical address.")
+        saveAndTest(addressTypeInstance)
+
+        // AddressType #3
+        addressTypeInstance = new AddressType(name: "Postal & Physical",
+                                                                                description: "An address that is both the postal and physical address.")
+        saveAndTest(addressTypeInstance)
+
+        // AddressType #4
+        addressTypeInstance = new AddressType(name: "Invoice",
+                                                                                description: "An address to send invoices to.")
+        saveAndTest(addressTypeInstance)
+
+        // AddressType #5
+        addressTypeInstance = new AddressType(name: "Delivery",
+                                                                                description: "An address to send deliveries to.")
+        saveAndTest(addressTypeInstance)
     }
 
Index: /trunk/grails-app/views/addressDetailed/create.gsp
===================================================================
--- /trunk/grails-app/views/addressDetailed/create.gsp	(revision 397)
+++ /trunk/grails-app/views/addressDetailed/create.gsp	(revision 397)
@@ -0,0 +1,155 @@
+
+
+<html>
+    <head>
+        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+        <meta name="layout" content="main" />
+        <title>Create Address</title>
+    </head>
+    <body>
+        <div class="nav">
+            <h1>Create Address</h1>
+        </div>
+        <div class="body">
+            <g:if test="${flash.message}">
+            <div class="message">${flash.message}</div>
+            </g:if>
+            <g:hasErrors bean="${addressInstance}">
+            <div class="errors">
+                <g:renderErrors bean="${addressInstance}" as="list" />
+            </div>
+            </g:hasErrors>
+            <g:form action="save" method="post" >
+                <div class="dialog">
+                    <table>
+                        <tbody>
+
+                            <g:if test="${addressInstance.manufacturer}">
+                                <g:hiddenField name="manufacturer.id" value="${addressInstance.manufacturer.id}"/>
+                                <tr class="prop">
+                                    <td valign="top" class="name">
+                                        <label for="manufacturer">Manufacturer:</label>
+                                    </td>
+                                    <td valign="top" class="value">
+                                        <g:link controller="manufacturerDetailed" action="show" id="${addressInstance.manufacturer.id}">
+                                            ${addressInstance.manufacturer.encodeAsHTML()}
+                                        </g:link>
+                                    </td>
+                                </tr>
+                            </g:if>
+                            
+                            <g:if test="${addressInstance.supplier}">
+                                <g:hiddenField name="supplier.id" value="${addressInstance.supplier.id}"/>
+                                <tr class="prop">
+                                    <td valign="top" class="name">
+                                        <label for="supplier">Supplier:</label>
+                                    </td>
+                                    <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'supplier','errors')}">
+                                        <g:link controller="supplierDetailed" action="show" id="${addressInstance.supplier.id}">
+                                            ${addressInstance.supplier.encodeAsHTML()}
+                                        </g:link>
+                                    </td>
+                                </tr>
+                            </g:if>
+                            
+                            <g:if test="${addressInstance.person}">
+                                <g:hiddenField name="person.id" value="${addressInstance.person.id}"/>
+                                <tr class="prop">
+                                    <td valign="top" class="name">
+                                        <label for="person">Person:</label>
+                                    </td>
+                                    <td valign="top" class="value">
+                                        <g:link controller="person" action="show" id="${addressInstance.person.id}">
+                                            ${addressInstance.person.encodeAsHTML()}
+                                        </g:link>
+                                    </td>
+                                </tr> 
+                            </g:if>
+                            
+                            <g:if test="${addressInstance.site}">
+                                <g:hiddenField name="site.id" value="${addressInstance.site.id}"/>
+                                <tr class="prop">
+                                    <td valign="top" class="name">
+                                        <label for="site">Site:</label>
+                                    </td>
+                                    <td valign="top" class="value">
+                                        <g:link controller="siteDetailed" action="show" id="${addressInstance.site.id}">
+                                            ${addressInstance.site.encodeAsHTML()}
+                                        </g:link>
+                                    </td>
+                                </tr> 
+                            </g:if>
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="addressType">Address Type:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'addressType','errors')}">
+                                    <g:select optionKey="id" from="${AddressType.list()}" name="addressType.id" value="${addressInstance?.addressType?.id}" ></g:select>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="street1">Street 1:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'street1','errors')}">
+                                    <input type="text" maxlength="50" id="street1" name="street1" value="${fieldValue(bean:addressInstance,field:'street1')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="street2">Street 2:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'street2','errors')}">
+                                    <input type="text" maxlength="50" id="street2" name="street2" value="${fieldValue(bean:addressInstance,field:'street2')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="city">City:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'city','errors')}">
+                                    <input type="text" maxlength="50" id="city" name="city" value="${fieldValue(bean:addressInstance,field:'city')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="state">State:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'state','errors')}">
+                                    <input type="text" maxlength="50" id="state" name="state" value="${fieldValue(bean:addressInstance,field:'state')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="postCode">Post Code:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'postCode','errors')}">
+                                    <input type="text" maxlength="50" id="postCode" name="postCode" value="${fieldValue(bean:addressInstance,field:'postCode')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="country">Country:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'country','errors')}">
+                                    <input type="text" maxlength="50" id="country" name="country" value="${fieldValue(bean:addressInstance,field:'country')}"/>
+                                </td>
+                            </tr> 
+                        
+                        </tbody>
+                    </table>
+                </div>
+                <div class="buttons">
+                    <span class="button"><input class="save" type="submit" value="Create" /></span>
+                </div>
+            </g:form>
+        </div>
+    </body>
+</html>
Index: /trunk/grails-app/views/addressDetailed/edit.gsp
===================================================================
--- /trunk/grails-app/views/addressDetailed/edit.gsp	(revision 397)
+++ /trunk/grails-app/views/addressDetailed/edit.gsp	(revision 397)
@@ -0,0 +1,153 @@
+
+
+<html>
+    <head>
+        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+        <meta name="layout" content="main" />
+        <title>Edit Address</title>
+    </head>
+    <body>
+        <div class="nav">
+            <h1>Edit Address</h1>
+        </div>
+        <div class="body">
+            <g:render template="/shared/messages" />
+            <g:hasErrors bean="${addressInstance}">
+            <div class="errors">
+                <g:renderErrors bean="${addressInstance}" as="list" />
+            </div>
+            </g:hasErrors>
+            <g:form method="post" >
+                <input type="hidden" name="id" value="${addressInstance?.id}" />
+                <input type="hidden" name="version" value="${addressInstance?.version}" />
+                <div class="dialog">
+                    <table>
+                        <tbody>
+                        
+                            <g:if test="${addressInstance.manufacturer}">
+                                <tr class="prop">
+                                    <td valign="top" class="name">
+                                        <label for="manufacturer">Manufacturer:</label>
+                                    </td>
+                                    <td valign="top" class="value">
+                                        <g:link controller="manufacturerDetailed" action="show" id="${addressInstance.manufacturer.id}">
+                                            ${addressInstance.manufacturer.encodeAsHTML()}
+                                        </g:link>
+                                    </td>
+                                </tr> 
+                            </g:if>
+                            
+                            <g:if test="${addressInstance.supplier}">
+                                <tr class="prop">
+                                    <td valign="top" class="name">
+                                        <label for="supplier">Supplier:</label>
+                                    </td>
+                                    <td valign="top" class="value">
+                                        <g:link controller="supplierDetailed" action="show" id="${addressInstance.supplier.id}">
+                                            ${addressInstance.supplier.encodeAsHTML()}
+                                        </g:link>
+                                    </td>
+                                </tr> 
+                            </g:if>
+                            
+                            <g:if test="${addressInstance.person}">
+                                <tr class="prop">
+                                    <td valign="top" class="name">
+                                        <label for="person">Person:</label>
+                                    </td>
+                                    <td valign="top" class="value">
+                                        <g:link controller="person" action="show" id="${addressInstance.person.id}">
+                                            ${addressInstance.person.encodeAsHTML()}
+                                        </g:link>
+                                    </td>
+                                </tr> 
+                            </g:if>
+                            
+                            <g:if test="${addressInstance.site}">
+                                <tr class="prop">
+                                    <td valign="top" class="name">
+                                        <label for="site">Site:</label>
+                                    </td>
+                                    <td valign="top" class="value">
+                                        <g:link controller="siteDetailed" action="show" id="${addressInstance.site.id}">
+                                            ${addressInstance.site.encodeAsHTML()}
+                                        </g:link>
+                                    </td>
+                                </tr> 
+                            </g:if>
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="addressType">Address Type:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'addressType','errors')}">
+                                    <g:select optionKey="id" from="${AddressType.list()}" name="addressType.id" value="${addressInstance?.addressType?.id}" ></g:select>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="street1">Street1:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'street1','errors')}">
+                                    <input type="text" maxlength="50" id="street1" name="street1" value="${fieldValue(bean:addressInstance,field:'street1')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="street2">Street2:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'street2','errors')}">
+                                    <input type="text" maxlength="50" id="street2" name="street2" value="${fieldValue(bean:addressInstance,field:'street2')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="city">City:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'city','errors')}">
+                                    <input type="text" maxlength="50" id="city" name="city" value="${fieldValue(bean:addressInstance,field:'city')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="state">State:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'state','errors')}">
+                                    <input type="text" maxlength="50" id="state" name="state" value="${fieldValue(bean:addressInstance,field:'state')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="postCode">Post Code:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'postCode','errors')}">
+                                    <input type="text" maxlength="50" id="postCode" name="postCode" value="${fieldValue(bean:addressInstance,field:'postCode')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="country">Country:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:addressInstance,field:'country','errors')}">
+                                    <input type="text" maxlength="50" id="country" name="country" value="${fieldValue(bean:addressInstance,field:'country')}"/>
+                                </td>
+                            </tr> 
+                        
+                        </tbody>
+                    </table>
+                </div>
+                <div class="buttons">
+                    <span class="button"><g:actionSubmit class="save" value="Update" /></span>
+                    <span class="button"><g:actionSubmit class="cancel" value="Cancel" action="Show"/></span>
+                    <span class="button"><g:actionSubmit class="delete" onclick="return confirm('Are you sure?');" value="Delete" /></span>
+                </div>
+            </g:form>
+        </div>
+    </body>
+</html>
Index: /trunk/grails-app/views/addressDetailed/list.gsp
===================================================================
--- /trunk/grails-app/views/addressDetailed/list.gsp	(revision 397)
+++ /trunk/grails-app/views/addressDetailed/list.gsp	(revision 397)
@@ -0,0 +1,68 @@
+
+
+<html>
+    <head>
+        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+        <meta name="layout" content="main" />
+        <title>Address List</title>
+    </head>
+    <body>
+        <div class="nav">
+            <h1>Address List</h1>
+        </div>
+        <div class="body">
+            <g:render template="/shared/messages" />
+            <div class="list">
+                <table>
+                    <thead>
+                        <tr>
+                        
+                   	        <g:sortableColumn property="id" title="Id" />
+                        
+                   	        <g:sortableColumn property="street1" title="Street1" />
+                        
+                   	        <g:sortableColumn property="street2" title="Street2" />
+                        
+                   	        <g:sortableColumn property="city" title="City" />
+                        
+                   	        <g:sortableColumn property="state" title="State" />
+                        
+                   	        <g:sortableColumn property="postCode" title="Post Code" />
+
+                            <th></th>
+                        
+                        </tr>
+                    </thead>
+                    <tbody>
+                    <g:each in="${addressInstanceList}" status="i" var="addressInstance">
+                        <tr class="${(i % 2) == 0 ? 'clickableOdd' : 'clickableEven'}" onclick='window.location = "${request.getContextPath()}/addressDetailed/show/${addressInstance.id}"'/>
+                        
+                            <td>${fieldValue(bean:addressInstance, field:'id')}</td>
+                        
+                            <td>${fieldValue(bean:addressInstance, field:'street1')}</td>
+                        
+                            <td>${fieldValue(bean:addressInstance, field:'street2')}</td>
+                        
+                            <td>${fieldValue(bean:addressInstance, field:'city')}</td>
+                        
+                            <td>${fieldValue(bean:addressInstance, field:'state')}</td>
+                        
+                            <td>${fieldValue(bean:addressInstance, field:'postCode')}</td>
+
+                            <td>
+                                <g:link action="show" id="${addressInstance.id}">
+                                    <img  src="${resource(dir:'images/skin',file:'database_go.png')}" alt="Show" />
+                                </g:link>
+                            </td>
+                        
+                        </tr>
+                    </g:each>
+                    </tbody>
+                </table>
+            </div>
+            <div class="paginateButtons">
+                <g:paginate total="${addressInstanceTotal}" />
+            </div>
+        </div>
+    </body>
+</html>
Index: /trunk/grails-app/views/addressDetailed/show.gsp
===================================================================
--- /trunk/grails-app/views/addressDetailed/show.gsp	(revision 397)
+++ /trunk/grails-app/views/addressDetailed/show.gsp	(revision 397)
@@ -0,0 +1,124 @@
+
+
+<html>
+    <head>
+        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+        <meta name="layout" content="main" />
+        <title>Show Address</title>
+    </head>
+    <body>
+        <div class="nav">
+            <h1>Show Address</h1>
+        </div>
+        <div class="body">
+            <g:render template="/shared/messages" />
+            <div class="dialog">
+                <table>
+                    <tbody>
+
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Id:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:addressInstance, field:'id')}</td>
+                            
+                        </tr>
+                    
+                            <g:if test="${addressInstance.manufacturer}">
+                                <tr class="prop">
+                                    <td valign="top" class="name">Manufacturer:</td>
+                                    
+                                    <td valign="top" class="value"><g:link controller="manufacturerDetailed" action="show" id="${addressInstance.manufacturer.id}">${addressInstance.manufacturer.encodeAsHTML()}</g:link></td>
+                                    
+                                </tr>
+                            </g:if>
+                            
+                            <g:if test="${addressInstance.supplier}">
+                                <tr class="prop">
+                                    <td valign="top" class="name">Supplier:</td>
+                                    
+                                    <td valign="top" class="value"><g:link controller="supplierDetailed" action="show" id="${addressInstance.supplier.id}">${addressInstance.supplier.encodeAsHTML()}</g:link></td>
+                                    
+                                </tr>
+                            </g:if>
+                            
+                            <g:if test="${addressInstance.person}">
+                                <tr class="prop">
+                                    <td valign="top" class="name">Person:</td>
+                                    
+                                    <td valign="top" class="value"><g:link controller="person" action="show" id="${addressInstance.person.id}">${addressInstance.person.encodeAsHTML()}</g:link></td>
+                                    
+                                </tr>
+                            </g:if>
+                            
+                            <g:if test="${addressInstance.site}">
+                                <tr class="prop">
+                                    <td valign="top" class="name">Site:</td>
+                                    
+                                    <td valign="top" class="value"><g:link controller="siteDetailed" action="show" id="${addressInstance.site.id}">${addressInstance.site.encodeAsHTML()}</g:link></td>
+                                    
+                                </tr>
+                            </g:if>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Address Type:</td>
+                            
+                            <td valign="top" class="value">${addressInstance?.addressType?.encodeAsHTML()}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Street1:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:addressInstance, field:'street1')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Street2:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:addressInstance, field:'street2')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">City:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:addressInstance, field:'city')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">State:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:addressInstance, field:'state')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Post Code:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:addressInstance, field:'postCode')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Country:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:addressInstance, field:'country')}</td>
+                            
+                        </tr>
+                    
+                    </tbody>
+                </table>
+            </div>
+            <div class="buttons">
+                <g:form>
+                    <input type="hidden" name="id" value="${addressInstance?.id}" />
+                    <span class="button"><g:actionSubmit class="edit" value="Edit" /></span>
+                    <span class="button"><g:actionSubmit class="delete" onclick="return confirm('Are you sure?');" value="Delete" /></span>
+                </g:form>
+            </div>
+        </div>
+    </body>
+</html>
Index: /trunk/grails-app/views/manufacturerDetailed/edit.gsp
===================================================================
--- /trunk/grails-app/views/manufacturerDetailed/edit.gsp	(revision 396)
+++ /trunk/grails-app/views/manufacturerDetailed/edit.gsp	(revision 397)
@@ -63,4 +63,20 @@
                                 </td>
                             </tr> 
+
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="addresses">Addresses:</label>
+                                </td>
+                                <td valign="top" class="value">
+                                    <ul>
+                                    <g:each var="i" in="${manufacturerInstance?.addresses?}">
+                                        <li><g:link controller="manufacturerDetailed" action="show" id="${i.id}">
+                                            ${i?.encodeAsHTML()}
+                                        </g:link></li>
+                                    </g:each>
+                                    </ul>
+                                    <g:link controller="addressDetailed" params="['manufacturer.id':manufacturerInstance?.id]" action="create">Add Address</g:link>
+                                </td>
+                            </tr>
                     
                         <tr class="prop">
Index: /trunk/grails-app/views/manufacturerDetailed/show.gsp
===================================================================
--- /trunk/grails-app/views/manufacturerDetailed/show.gsp	(revision 396)
+++ /trunk/grails-app/views/manufacturerDetailed/show.gsp	(revision 397)
@@ -57,4 +57,17 @@
                     
                         <tr class="prop">
+                            <td valign="top" class="name">Addresses:</td>
+                            
+                            <td  valign="top" class="value">
+                                <ul>
+                                <g:each var="i" in="${manufacturerInstance.addresses}">
+                                    <li><g:link controller="addressDetailed" action="show" id="${i.id}">${i?.encodeAsHTML()}</g:link></li>
+                                </g:each>
+                                </ul>
+                            </td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
                             <td valign="top" class="name">Inventory Items:</td>
                             
Index: /trunk/grails-app/views/person/edit.gsp
===================================================================
--- /trunk/grails-app/views/person/edit.gsp	(revision 396)
+++ /trunk/grails-app/views/person/edit.gsp	(revision 397)
@@ -98,4 +98,20 @@
 
                     <tr class="prop">
+                        <td valign="top" class="name">
+                            <label for="addresses">Addresses:</label>
+                        </td>
+                        <td valign="top" class="value">
+                            <ul>
+                            <g:each var="i" in="${person?.addresses?}">
+                                <li><g:link controller="addressDetailed" action="show" id="${i.id}">
+                                    ${i?.encodeAsHTML()}
+                                </g:link></li>
+                            </g:each>
+                            </ul>
+                            <g:link controller="addressDetailed" params="['person.id':person?.id]" action="create">Add Address</g:link>
+                        </td>
+                    </tr>
+
+                    <tr class="prop">
                         <td valign="top" class="name"><label for="employeeID">employee ID:</label></td>
                         <td valign="top" class="value ${hasErrors(bean:person,field:'employeeID','errors')}">
Index: /trunk/grails-app/views/person/show.gsp
===================================================================
--- /trunk/grails-app/views/person/show.gsp	(revision 396)
+++ /trunk/grails-app/views/person/show.gsp	(revision 397)
@@ -60,4 +60,17 @@
 
                 <tr class="prop">
+                    <td valign="top" class="name">Addresses:</td>
+
+                    <td  valign="top" class="value">
+                        <ul>
+                        <g:each var="i" in="${person.addresses}">
+                            <li><g:link controller="addressDetailed" action="show" id="${i.id}">${i?.encodeAsHTML()}</g:link></li>
+                        </g:each>
+                        </ul>
+                    </td>
+
+                </tr>
+
+                <tr class="prop">
                     <td valign="top" class="name">Employee ID:</td>
                     <td valign="top" class="value">${person.employeeID}</td>
Index: /trunk/grails-app/views/siteDetailed/edit.gsp
===================================================================
--- /trunk/grails-app/views/siteDetailed/edit.gsp	(revision 396)
+++ /trunk/grails-app/views/siteDetailed/edit.gsp	(revision 397)
@@ -73,5 +73,21 @@
 </g:each>
 </ul>
-<g:link controller="inventoryStoreDetailed" params="['site.id':siteInstance?.id]" action="create">Add InventoryStore</g:link>
+<g:link controller="inventoryStoreDetailed" params="['site.id':siteInstance?.id]" action="create">Add Inventory Store</g:link>
+
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="addresses">Addresses:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:siteInstance,field:'addresses','errors')}">
+                                    
+<ul>
+<g:each var="i" in="${siteInstance?.addresses?}">
+    <li><g:link controller="addressDetailed" action="show" id="${i.id}">${i?.encodeAsHTML()}</g:link></li>
+</g:each>
+</ul>
+<g:link controller="addressDetailed" params="['site.id':siteInstance?.id]" action="create">Add Address</g:link>
 
                                 </td>
Index: /trunk/grails-app/views/siteDetailed/show.gsp
===================================================================
--- /trunk/grails-app/views/siteDetailed/show.gsp	(revision 396)
+++ /trunk/grails-app/views/siteDetailed/show.gsp	(revision 397)
@@ -68,4 +68,17 @@
                     
                         <tr class="prop">
+                            <td valign="top" class="name">Addresses:</td>
+                            
+                            <td  valign="top" class="value">
+                                <ul>
+                                <g:each var="i" in="${siteInstance.addresses}">
+                                    <li><g:link controller="addressDetailed" action="show" id="${i.id}">${i?.encodeAsHTML()}</g:link></li>
+                                </g:each>
+                                </ul>
+                            </td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
                             <td valign="top" class="name">Sections:</td>
                             
Index: /trunk/grails-app/views/supplierDetailed/edit.gsp
===================================================================
--- /trunk/grails-app/views/supplierDetailed/edit.gsp	(revision 396)
+++ /trunk/grails-app/views/supplierDetailed/edit.gsp	(revision 397)
@@ -63,5 +63,21 @@
                                 </td>
                             </tr> 
-                    
+
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="addresses">Addresses:</label>
+                                </td>
+                                <td valign="top" class="value">
+                                    <ul>
+                                    <g:each var="i" in="${supplierInstance?.addresses?}">
+                                        <li><g:link controller="supplierDetailed" action="show" id="${i.id}">
+                                            ${i?.encodeAsHTML()}
+                                        </g:link></li>
+                                    </g:each>
+                                    </ul>
+                                    <g:link controller="addressDetailed" params="['supplier.id':supplierInstance?.id]" action="create">Add Address</g:link>
+                                </td>
+                            </tr>
+                            
                             <tr class="prop">
                                 <td valign="top" class="name">Inventory Items:</td>
Index: /trunk/grails-app/views/supplierDetailed/show.gsp
===================================================================
--- /trunk/grails-app/views/supplierDetailed/show.gsp	(revision 396)
+++ /trunk/grails-app/views/supplierDetailed/show.gsp	(revision 397)
@@ -57,4 +57,17 @@
                     
                         <tr class="prop">
+                            <td valign="top" class="name">Addresses:</td>
+                            
+                            <td  valign="top" class="value">
+                                <ul>
+                                <g:each var="i" in="${supplierInstance.addresses}">
+                                    <li><g:link controller="addressDetailed" action="show" id="${i.id}">${i?.encodeAsHTML()}</g:link></li>
+                                </g:each>
+                                </ul>
+                            </td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
                             <td valign="top" class="name">Inventory Items:</td>
                             
