2 * Copyright (C) 2016 - 2024 Free Software Foundation
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU Affero General Public License as
6 * published by the Free Software Foundation, either version 3 of the
7 * License, or (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU Affero General Public License for more details.
14 * You should have received a copy of the GNU Affero General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 package org.mxchange.addressbook.beans.contact.phone;
19 import java.text.MessageFormat;
20 import java.util.LinkedList;
21 import java.util.List;
22 import java.util.Objects;
23 import javax.enterprise.context.RequestScoped;
24 import javax.enterprise.event.Observes;
25 import javax.inject.Inject;
26 import javax.inject.Named;
27 import org.mxchange.addressbook.beans.BaseAddressbookBean;
28 import org.mxchange.addressbook.beans.contact.list.AddressbookContactListWebViewController;
29 import org.mxchange.jcontacts.events.contact.add.ObservableAdminAddedContactEvent;
30 import org.mxchange.jcontacts.events.contact.update.ObservableAdminUpdatedContactEvent;
31 import org.mxchange.jcontacts.events.contact.update.ObservableUpdatedContactEvent;
32 import org.mxchange.jcontacts.model.contact.Contact;
33 import org.mxchange.jphone.events.fax.created.ObservableCreatedFaxNumberEvent;
34 import org.mxchange.jphone.events.landline.created.ObservableCreatedLandLineNumberEvent;
35 import org.mxchange.jphone.model.phonenumbers.fax.DialableFaxNumber;
36 import org.mxchange.jphone.model.phonenumbers.landline.DialableLandLineNumber;
37 import org.mxchange.jusercore.events.user.add.ObservableAdminAddedUserEvent;
40 * A general contact bean (controller)
42 * @author Roland Häder<roland@mxchange.org>
44 @Named ("contactPhoneController")
46 public class AddressbookContactPhoneWebRequestBean extends BaseAddressbookBean implements AddressbookContactPhoneWebRequestController {
51 private static final long serialVersionUID = 542_145_355_001L;
54 * An instance of a contact-list controller
57 private AddressbookContactListWebViewController contactListController;
62 private DialableFaxNumber faxNumber;
67 private DialableLandLineNumber landLineNumber;
72 public AddressbookContactPhoneWebRequestBean () {
73 // Call super constructor
78 * Observes events being fired when an administrator has added a new
81 * @param event Event being fired
83 public void afterAdminAddedContactEvent (@Observes final ObservableAdminAddedContactEvent event) {
84 // The event must be valid
87 throw new NullPointerException("event is null"); //NOI18N
88 } else if (event.getAddedContact() == null) {
90 throw new NullPointerException("event.addedContact is null"); //NOI18N
91 } else if (event.getAddedContact().getContactId() == null) {
93 throw new NullPointerException("event.addedContact.contactId is null"); //NOI18N
94 } else if (event.getAddedContact().getContactId() < 1) {
96 throw new IllegalArgumentException(MessageFormat.format("event.addedContact.contactId={0} is not valid", event.getAddedContact().getContactId())); //NOI18N
104 * Event observer for newly added users by administrator
106 * @param event Event being fired
108 public void afterAdminAddedUserEvent (@Observes final ObservableAdminAddedUserEvent event) {
109 // Event and contained entity instance should not be null
112 throw new NullPointerException("event is null"); //NOI18N
113 } else if (event.getAddedUser() == null) {
115 throw new NullPointerException("event.addedUser is null"); //NOI18N
116 } else if (event.getAddedUser().getUserId() == null) {
118 throw new NullPointerException("event.addedUser.userId is null"); //NOI18N
119 } else if (event.getAddedUser().getUserId() < 1) {
121 throw new IllegalArgumentException(MessageFormat.format("userId of user={0} is not valid: {1}", event.getAddedUser(), event.getAddedUser().getUserId())); //NOI18N
129 * Event observer for updated contact data by administrators
131 * @param event Updated contact data event
133 public void afterAdminUpdatedContactDataEvent (@Observes final ObservableAdminUpdatedContactEvent event) {
134 // Event and contained entity instance should not be null
137 throw new NullPointerException("event is null"); //NOI18N
138 } else if (event.getUpdatedContact() == null) {
140 throw new NullPointerException("event.updatedContact is null"); //NOI18N
141 } else if (event.getUpdatedContact().getContactId() == null) {
143 throw new NullPointerException("event.updatedContact.contactId is null"); //NOI18N
144 } else if (event.getUpdatedContact().getContactId() < 1) {
146 throw new IllegalArgumentException(MessageFormat.format("contactId of contact={0} is not valid: {1}", event.getUpdatedContact(), event.getUpdatedContact().getContactId())); //NOI18N
154 * Observes events being fired when a bean helper has successfully created a
155 * fax number instance.
157 * @param event Event being fired
159 public void afterCreatedFaxNumberEvent (@Observes final ObservableCreatedFaxNumberEvent event) {
160 // The event instance must be valid
163 throw new NullPointerException("event is null"); //NOI18N
164 } else if (event.getFaxNumber() == null) {
166 throw new NullPointerException("event.faxNumber is null"); //NOI18N
167 } else if (event.getFaxNumber().getPhoneId() == null) {
168 // Throw NPE yet again
169 throw new NullPointerException("event.faxNumber.phoneId is null"); //NOI18N
170 } else if (event.getFaxNumber().getPhoneId() < 1) {
171 // Throw NPE yet again
172 throw new NullPointerException(MessageFormat.format("event.faxNumber.phoneId={0} is invalid", event.getFaxNumber().getPhoneId())); //NOI18N
176 this.setFaxNumber(event.getFaxNumber());
180 * Observes events being fired when a bean helper has successfully created a
181 * land-line number instance.
183 * @param event Event being fired
185 public void afterCreatedLandLineNumberEvent (@Observes final ObservableCreatedLandLineNumberEvent event) {
186 // The event instance must be valid
189 throw new NullPointerException("event is null"); //NOI18N
190 } else if (event.getLandLineNumber() == null) {
192 throw new NullPointerException("event.landLineNumber is null"); //NOI18N
193 } else if (event.getLandLineNumber().getPhoneId() == null) {
194 // Throw NPE yet again
195 throw new NullPointerException("event.landLineNumber.phoneId is null"); //NOI18N
196 } else if (event.getLandLineNumber().getPhoneId() < 1) {
197 // Throw NPE yet again
198 throw new NullPointerException(MessageFormat.format("event.landLineNumber.phoneId={0} is invalid", event.getLandLineNumber().getPhoneId())); //NOI18N
202 this.setLandLineNumber(event.getLandLineNumber());
206 * Event observer for updated contact data by the user
208 * @param event Updated contact data event
210 public void afterUpdatedContactDataEvent (@Observes final ObservableUpdatedContactEvent event) {
211 // Event and contained entity instance should not be null
214 throw new NullPointerException("event is null"); //NOI18N
215 } else if (event.getUpdatedContact() == null) {
217 throw new NullPointerException("event.updatedContact is null"); //NOI18N
218 } else if (event.getUpdatedContact().getContactId() == null) {
220 throw new NullPointerException("event.updatedContact.contactId is null"); //NOI18N
221 } else if (event.getUpdatedContact().getContactId() < 1) {
223 throw new IllegalArgumentException(MessageFormat.format("contactId of contact={0} is not valid: {1}", event.getUpdatedContact(), event.getUpdatedContact().getContactId())); //NOI18N
231 * Getter for all contacts having current fax number linked
233 * @return List of all linked contacts
235 public List<Contact> allCurrentFaxNumberContacts () {
237 final DialableFaxNumber number = this.getFaxNumber();
240 final List<Contact> contacts = new LinkedList<>();
242 // "Walk" through all contacts
243 for (final Contact contact : this.contactListController.getAllContacts()) {
244 // Is mobile instance the same?
245 if (Objects.equals(contact.getContactFaxNumber(), number)) {
247 contacts.add(contact);
251 // Return now-cached list
256 * Getter for all contacts having current land-line number linked
258 * @return List of all linked contacts
260 public List<Contact> allCurrentLandLineNumberContacts () {
262 final DialableLandLineNumber number = this.getLandLineNumber();
265 final List<Contact> contacts = new LinkedList<>();
267 // "Walk" through all contacts
268 for (final Contact contact : this.contactListController.getAllContacts()) {
269 // Is mobile instance the same?
270 if (Objects.equals(contact.getContactLandLineNumber(), number)) {
272 contacts.add(contact);
276 // Return now-cached list
281 * Getter for chosen fax number
285 public DialableFaxNumber getFaxNumber () {
286 return this.faxNumber;
290 * Setter for chosen fax number
292 * @param faxNumber fax number
294 public void setFaxNumber (final DialableFaxNumber faxNumber) {
295 this.faxNumber = faxNumber;
299 * Getter for chosen land-line number
301 * @return land-line number
303 public DialableLandLineNumber getLandLineNumber () {
304 return this.landLineNumber;
308 * Setter for chosen land-line number
310 * @param landLineNumber land-line number
312 public void setLandLineNumber (final DialableLandLineNumber landLineNumber) {
313 this.landLineNumber = landLineNumber;
319 private void clear () {