2 * Copyright (C) 2015 Roland Haeder
\r
4 * This program is free software: you can redistribute it and/or modify
\r
5 * it under the terms of the GNU General Public License as published by
\r
6 * the Free Software Foundation, either version 3 of the License, or
\r
7 * (at your option) any later version.
\r
9 * This program is distributed in the hope that it will be useful,
\r
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
\r
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
\r
12 * GNU General Public License for more details.
\r
14 * You should have received a copy of the GNU General Public License
\r
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
\r
17 package org.mxchange.addressbook.manager.contact;
\r
19 import java.util.ArrayList;
\r
20 import java.util.Iterator;
\r
21 import java.util.List;
\r
22 import org.mxchange.addressbook.client.Client;
\r
23 import org.mxchange.addressbook.contact.Contact;
\r
24 import org.mxchange.addressbook.contact.user.UserContact;
\r
25 import org.mxchange.addressbook.manager.BaseManager;
\r
28 * A manager for contacts
\r
30 * @author Roland Haeder
\r
34 public class ContactManager extends BaseManager implements ManageableContact {
\r
39 private final List<Contact> contacts;
\r
42 * @param maxContacts Maximum allowed contacts
\r
43 * @param client Client instance to use
\r
45 public ContactManager (final int maxContacts, final Client client) {
\r
46 // Always call super constructor first
\r
50 this.contacts = new ArrayList<>(maxContacts);
\r
53 //* NOISY-DEBUG: */ this.getLogger().debug("client=" + client);
\r
56 this.setClient(client);
\r
60 * Adds given contact to address book
\r
62 * @param contact Contact being added
\r
63 * @todo Add check for book size
\r
66 public void addContact (final Contact contact) {
\r
67 // Check if contact is found
\r
68 if (this.isContactAlreadyAdded(contact)) {
\r
69 // Contact already added
\r
70 // @todo Do something here
\r
71 } else if ((contact.isOwnContact()) && (this.isOwnContactAdded())) {
\r
72 // Own contact already added
\r
73 // @todo Do something
\r
77 /* NOISY-DEBUG: */ this.getLogger().debug("Adding '" + contact.getSurname() + "' '" + contact.getFamilyName() + "' at pos '" + this.size () + "' ...");
\r
80 this.contacts.add(contact);
\r
84 * Let the user add a new other address
\r
87 public void addOtherAddress () {
\r
88 throw new UnsupportedOperationException("Not supported yet.");
\r
92 * Let the user change other address
\r
95 public void changeOtherAddress () {
\r
96 throw new UnsupportedOperationException("Not supported yet.");
\r
100 * Allows the user to change his/her own data
\r
103 public void changeOwnData () {
\r
105 * First check if the user has registered own contact, before that
\r
106 * nothing can be changed.
\r
108 if (!this.isOwnContactAdded()) {
\r
110 this.getClient().displayMessage("Sie haben noch nicht Ihre Daten eingegeben.");
\r
112 // Skip any below code
\r
117 Contact contact = this.getOwnContact();
\r
119 // It must be found
\r
120 assert(contact instanceof Contact);
\r
122 // @TODO Unfinished
\r
123 throw new UnsupportedOperationException("Method is not finished.");
\r
127 * Let the user delete other address
\r
130 public void deleteOtherAddress () {
\r
131 throw new UnsupportedOperationException("Not supported yet.");
\r
135 * Asks user for own data
\r
138 public void enterOwnData () {
\r
139 // First ask for gender
\r
140 char gender = this.enterOwnGender();
\r
143 String surname = this.enterOwnSurname();
\r
145 // And 3rd for family name
\r
146 String familyName = this.enterOwnFamilyName();
\r
148 // Construct UserContact instance
\r
149 Contact contact = new UserContact(gender, surname, familyName);
\r
151 // Mark contact as own
\r
152 contact.enableFlagOwnContact();
\r
154 // Add it to contact "book"
\r
155 this.addContact(contact);
\r
161 * @return size of contact "book"
\r
164 public int size () {
\r
165 return this.contacts.size();
\r
169 * Asks the user for family name
\r
170 * @return Family name of the user
\r
172 private String enterOwnFamilyName () {
\r
173 return this.getClient().enterString(2, 50, "Bitte geben Sie Ihren Nachnamen ein: ");
\r
177 * Asks the user for gender, until a valid has been entered
\r
178 * @return Gender of the user
\r
180 private char enterOwnGender () {
\r
181 return this.getClient().enterChar(new char[] {'M', 'F', 'C'}, "Bitte geben Sie die Anrede ein: (M=Herr, F=Frau, C=Firma): ");
\r
185 * Asks the user for surname
\r
186 * @return Surname of the user
\r
188 private String enterOwnSurname () {
\r
189 return this.getClient().enterString(2, 50, "Bitte geben Sie Ihren Vornamen ein: ");
\r
193 * "Getter" for own contact instance or null if not found
\r
195 * @return Contact instance or null
\r
197 private Contact getOwnContact () {
\r
198 // Now get it back from address book, first get an iterator
\r
199 Iterator<Contact> iterator = this.contacts.iterator();
\r
202 Contact contact = null;
\r
204 // Search all contact
\r
205 while (iterator.hasNext()) {
\r
206 // Get next instance
\r
207 Contact next = iterator.next();
\r
209 // Is this own contact?
\r
210 if (next.isOwnContact()) {
\r
218 // Return instance or null
\r
223 * Checks whether given contact was found in "address book"
\r
225 * @param checkContact Contact to be checked
\r
226 * @return TRUE if found, FALSE if not found
\r
228 private boolean isContactAlreadyAdded (final Contact checkContact) throws NullPointerException {
\r
229 // Default is not found
\r
230 boolean isFound = false;
\r
233 //* NOISY-DEBUG: */ this.getLogger().debug("Checking '" + this.contacts.length + "' entries...");
\r
235 // Now get it back from address book, first get an iterator
\r
236 Iterator<Contact> iterator = this.contacts.iterator();
\r
239 while (iterator.hasNext()) {
\r
241 Contact contact = iterator.next();
\r
244 //* NOISY-DEBUG: */ this.getLogger().debug("contact=" + contact + ",checkContent=" + checkContact);
\r
247 if ((contact instanceof Contact) && ((contact.equals(checkContact)))) {
\r
248 // Found matching entry
\r
259 * Checks whether own contact is already added by checking all entries for isOwnContact flag
\r
260 * @return Whether own contact is already added
\r
262 private boolean isOwnContactAdded () {
\r
263 // Default is not added
\r
264 boolean isAdded = false;
\r
266 // Now get it back from address book, first get an iterator
\r
267 Iterator<Contact> iterator = this.contacts.iterator();
\r
270 while (iterator.hasNext()) {
\r
272 Contact contact = iterator.next();
\r
275 if (contact instanceof Contact) {
\r
277 isAdded = contact.isOwnContact();
\r
279 // Is this own contact?
\r