ContactEditor.qml Example File

qmlcontactslistview/ContactEditor.qml
/****************************************************************************
**
** Copyright (C) 2012 Digia Plc and/or its subsidiary(-ies).
** Contact: http://www.qt-project.org/legal
**
** This file is part of the documentation of the Qt Pim Module.
**
** $QT_BEGIN_LICENSE:FDL$
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and Digia.  For licensing terms and
** conditions see http://qt.digia.com/licensing.  For further information
** use the contact form at http://qt.digia.com/contact-us.
**
** GNU Free Documentation License Usage
** Alternatively, this file may be used under the terms of the GNU Free
** Documentation License version 1.3 as published by the Free Software
** Foundation and appearing in the file included in the packaging of
** this file.  Please review the following information to ensure
** the GNU Free Documentation License version 1.3 requirements
** will be met: http://www.gnu.org/copyleft/fdl.html.
** $QT_END_LICENSE$
**
****************************************************************************/
import QtQuick 2.0

Rectangle {
    width: parent.width
    color: "pink"
    property variant contact // contact that is shown in editView

    // ![Widgets for manipulating contact details]
    Column {
        spacing: 8
        anchors {
            fill: parent
            leftMargin: 10
            topMargin: 10
        }
        DetailEditWidget {
            id: nameField
            label: "Name "
            value: contact ? contact.name.firstName : " "
        }
        DetailEditWidget {
            id: emailField
            label: "Email Address "
            value: contact ? contact.email.emailAddress : " "
            showPreferredField: true
            isPreferred: contact ? contact.isPreferredDetail("MESSAGE", contact.email) : false
        }
        DetailEditWidget {
            id: phoneField
            label: "Phone Number "
            value: contact ? contact.phoneNumber.number : " "
            showPreferredField: true
            isPreferred: contact ? contact.isPreferredDetail("CALL", contact.phoneNumber) : false
        }
    }
    // ![Widgets for manipulating contact details]

    function deleteContact() {
        contactsModel.removeContact(contactEditor.contact.contactId)
        statusBar.updateMsg("contact successfully deleted")
     }

    function updateContact() {
        // read in values from the input fields
        var values = [nameField.value,
                      emailField.value, emailField.requestPreferred || emailField.isPreferred,
                      phoneField.value, phoneField.requestPreferred || phoneField.isPreferred]
        if (!contact) { // create new contact
            var newContact = Qt.createQmlObject("import QtContacts 5.0; Contact{ }", contactEditor)
            setDetailValues(newContact, values)
            newContact.save()
            contactsModel.saveContact(newContact)
            statusBar.updateMsg("new contact successfully created")
        } else { // update existing contact
            setDetailValues(contact, values)
            if (contact.modified) {
                contact.save()
                statusBar.updateMsg("contact successfully updated")
            } else {
                statusBar.updateMsg("nothing to update, contact already is up-to-date")
            }
        }
    }

    function setDetailValues(c, values) {
        c.name.firstName = values[0]
        c.email.emailAddress = values[1]
        c.phoneNumber.number = values[3]
        if (values[2]) {
            c.setPreferredDetail("MESSAGE", c.email)
        }

        if (values[4]) {
            c.setPreferredDetail("CALL", c.phoneNumber)
        }
    }

    function cancel() {
        contact = ""
    }

    function resetToDefaults() {
        nameField.inputFocus = false
        emailField.inputFocus = false
        phoneField.inputFocus = false
        emailField.requestPreferred = false
        phoneField.requestPreferred = false
        nameField.color = "black"
        emailField.color = "black"
        phoneField.color = "black"
    }
}