/* * Copyright (C) 2009 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.contacts.editor; import android.provider.ContactsContract.Data; import com.android.contacts.model.RawContactDelta; import com.android.contacts.model.ValuesDelta; import com.android.contacts.model.dataitem.DataKind; /** * Generic definition of something that edits a {@link Data} row through an * {@link ValuesDelta} object. */ public interface Editor { public interface EditorListener { /** * Called when the given {@link Editor} is requested to be deleted by the user. */ public void onDeleteRequested(Editor editor); /** * Called when the given {@link Editor} has a request, for example it * wants to select a photo. */ public void onRequest(int request); public static final int REQUEST_PICK_PRIMARY_PHOTO = 0; public static final int REQUEST_PICK_PHOTO = 1; public static final int FIELD_CHANGED = 2; public static final int FIELD_TURNED_EMPTY = 3; public static final int FIELD_TURNED_NON_EMPTY = 4; // The editor has switched between different representations of the same // data, e.g. from full name to structured name public static final int EDITOR_FORM_CHANGED = 5; // Focus has changed inside the editor. public static final int EDITOR_FOCUS_CHANGED = 6; } /** * Returns whether or not all the fields are empty in this {@link Editor}. */ public boolean isEmpty(); /** * Prepares this editor for the given {@link ValuesDelta}, which * builds any needed views. Any changes performed by the user will be * written back to that same object. */ public void setValues(DataKind kind, ValuesDelta values, RawContactDelta state, boolean readOnly, ViewIdGenerator vig); public void setDeletable(boolean deletable); /** * Add a specific {@link EditorListener} to this {@link Editor}. */ public void setEditorListener(EditorListener listener); /** * Called internally when the contents of a specific field have changed, * allowing advanced editors to persist data in a specific way. */ public void onFieldChanged(String column, String value); /** * Update the phonetic field with the specified character string. */ public void updatePhonetic(String column, String value); /** * Returns the phonetic field string of the specified column. */ public String getPhonetic(String column); /** * Marks the underlying ValuesDelta as deleted, but does not update the view. */ public void markDeleted(); /** * Performs the delete operation for this {@link Editor}, which involves both * marking the underlying ValuesDelta as deleted and updating the view. */ public void deleteEditor(); /** * Clears all fields in this {@link Editor}. */ public void clearAllFields(); /** * Called internally when the user has added a new field. This * allows the appropriate editor UI to be presented immediately. * For example, if a new "event" is added, a date-picker will * immediately pop up. */ public void editNewlyAddedField(); /** * Marks the Editor field as a legacy field. Legacy fields are deprecated MIME types * which are not fully supported in the editor. * Adding or editing legacy field are not supported. */ void setLegacyField(boolean isLegacyField); }