/*
- * Copyright (C) 2016 Roland Haeder
+ * Copyright (C) 2016 - 2024 Free Software Foundation
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
*/
package org.mxchange.jjobs.beans.country;
-import java.util.Iterator;
-import java.util.List;
import java.util.Objects;
+import javax.ejb.EJB;
import javax.enterprise.context.RequestScoped;
import javax.enterprise.event.Event;
import javax.enterprise.inject.Any;
-import javax.faces.view.facelets.FaceletException;
+import javax.faces.FacesException;
import javax.inject.Inject;
import javax.inject.Named;
-import javax.naming.Context;
-import javax.naming.InitialContext;
-import javax.naming.NamingException;
-import org.mxchange.jcountry.data.Country;
-import org.mxchange.jcountry.data.CountryData;
-import org.mxchange.jcountry.data.CountrySingletonBeanRemote;
-import org.mxchange.jcountry.events.AdminAddedCountryEvent;
-import org.mxchange.jcountry.events.AdminEventCountryAdded;
+import org.mxchange.jcountry.events.added.AdminAddedCountryEvent;
+import org.mxchange.jcountry.events.added.ObservableAdminAddedCountryEvent;
import org.mxchange.jcountry.exceptions.CountryAlreadyAddedException;
+import org.mxchange.jcountry.model.data.AdminCountrySessionBeanRemote;
+import org.mxchange.jcountry.model.data.Country;
+import org.mxchange.jcountry.model.data.CountryData;
+import org.mxchange.jjobs.beans.BaseJobsBean;
+import org.mxchange.jjobs.beans.country.list.JobsCountryListWebViewController;
/**
* An administrative country bean
* <p>
- * @author Roland Haeder<roland@mxchange.org>
+ * @author Roland Hรคder<roland@mxchange.org>
*/
@Named ("adminCountryController")
@RequestScoped
-public class JobsAdminCountryWebRequestBean implements JobsAdminCountryWebRequestController {
+public class JobsAdminCountryWebRequestBean extends BaseJobsBean implements JobsAdminCountryWebRequestController {
/**
* Serial number
*/
@Inject
@Any
- private Event<AdminAddedCountryEvent> addedCountryEvent;
+ private Event<ObservableAdminAddedCountryEvent> addedCountryEvent;
/**
- * Abroad dial prefix
+ * Remote country EJB
*/
- private String countryAbroadDialPrefix;
+ @EJB (lookup = "java:global/jjobs-ejb/adminCountry!org.mxchange.jcountry.model.data.AdminCountrySessionBeanRemote")
+ private AdminCountrySessionBeanRemote adminCountryBean;
/**
- * Remote country EJB
+ * Abroad dial prefix
*/
- private CountrySingletonBeanRemote countryBean;
+ private String countryAbroadDialPrefix;
/**
* 2-letter country code
*/
private String countryCode;
- /**
- * Regular country controller
- */
- @Inject
- private JobsCountryWebApplicationController countryController;
-
/**
* Local dial prefix
*/
*/
private Boolean countryIsLocalPrefixRequired;
+ /**
+ * Regular country controller
+ */
+ @Inject
+ private JobsCountryListWebViewController countryListController;
+
/**
* Phone code
*/
* Default constructor
*/
public JobsAdminCountryWebRequestBean () {
- // Try this
- try {
- // Get initial context
- Context context = new InitialContext();
-
- // Try to lookup the bean
- this.countryBean = (CountrySingletonBeanRemote) context.lookup("java:global/jjobs-ejb/country!org.mxchange.jcountry.data.CountrySingletonBeanRemote"); //NOI18N
- } catch (final NamingException ex) {
- // Continue to throw
- throw new FaceletException(ex);
- }
+ // Call super constructor
+ super();
}
- @Override
- public String addCountry () {
+ /**
+ * Adds country to all relevant beans and sends it to the EJB. A redirect
+ * should happen after successful creation.
+ * <p>
+ * @todo Add field validation
+ */
+ public void addCountry () {
// Create new country object
- Country country = new CountryData();
-
- // Add all data
- country.setCountryAbroadDialPrefix(this.getCountryAbroadDialPrefix());
- country.setCountryCode(this.getCountryCode());
- country.setCountryExternalDialPrefix(this.getCountryExternalDialPrefix());
- country.setCountryI18nkey(this.getCountryI18nKey());
- country.setCountryIsLocalPrefixRequired(this.getCountryIsLocalPrefixRequired());
- country.setCountryPhoneCode(this.getCountryPhoneCode());
+ final Country country = new CountryData(
+ this.getCountryAbroadDialPrefix(),
+ this.getCountryCode(),
+ this.getCountryExternalDialPrefix(),
+ this.getCountryI18nKey(),
+ this.getCountryIsLocalPrefixRequired(),
+ this.getCountryPhoneCode()
+ );
// Does it already exist?
if (this.isCountryAdded(country)) {
// Yes, then abort here
- throw new FaceletException(new CountryAlreadyAddedException(country));
+ throw new FacesException(new CountryAlreadyAddedException(country));
}
// Init variable
- Country updatedCountry = null;
+ final Country updatedCountry;
try {
// Send country to bean
- updatedCountry = this.countryBean.addCountry(country);
+ updatedCountry = this.adminCountryBean.addCountry(country);
} catch (final CountryAlreadyAddedException ex) {
// Throw again
- throw new FaceletException(ex);
+ throw new FacesException(ex);
}
// Fire event
- this.addedCountryEvent.fire(new AdminEventCountryAdded(updatedCountry));
-
- // Redirect to list
- return "admin_list_country"; //NOI18N
- }
+ this.addedCountryEvent.fire(new AdminAddedCountryEvent(updatedCountry));
- @Override
- public List<Country> allCountries () {
- // Return "cached" version
- return this.countryController.allCountries();
+ // Clear this bean
+ this.clear();
}
- @Override
+ /**
+ * Getter for abroad dial prefix
+ * <p>
+ * @return Abroad dial prefix
+ */
public String getCountryAbroadDialPrefix () {
return this.countryAbroadDialPrefix;
}
- @Override
+ /**
+ * Setter for abroad dial prefix
+ * <p>
+ * @param countryAbroadDialPrefix Abroad dial prefix
+ */
public void setCountryAbroadDialPrefix (final String countryAbroadDialPrefix) {
this.countryAbroadDialPrefix = countryAbroadDialPrefix;
}
- @Override
+ /**
+ * Getter for 2-characters country code
+ * <p>
+ * @return Country code
+ */
public String getCountryCode () {
return this.countryCode;
}
- @Override
+ /**
+ * Setter for 2-characters country code
+ * <p>
+ * @param countryCode Country code
+ */
public void setCountryCode (final String countryCode) {
this.countryCode = countryCode;
}
- @Override
+ /**
+ * Getter for external dial prefix
+ * <p>
+ * @return External dial prefix
+ */
public String getCountryExternalDialPrefix () {
return this.countryExternalDialPrefix;
}
- @Override
+ /**
+ * Setter for external dial prefix
+ * <p>
+ * @param countryExternalDialPrefix External dial prefix
+ */
public void setCountryExternalDialPrefix (final String countryExternalDialPrefix) {
this.countryExternalDialPrefix = countryExternalDialPrefix;
}
- @Override
+ /**
+ * Getter for i18n key for country name
+ * <p>
+ * @return i18n key for country name
+ */
public String getCountryI18nKey () {
return this.countryI18nKey;
}
- @Override
+ /**
+ * Setter for i18n key for country name
+ * <p>
+ * @param countryI18nKey i18n key for country name
+ */
public void setCountryI18nKey (final String countryI18nKey) {
this.countryI18nKey = countryI18nKey;
}
- @Override
+ /**
+ * Getter for whether the local dial prefix is required for local calls
+ * <p>
+ * @return Whether the local dial prefix is required
+ */
public Boolean getCountryIsLocalPrefixRequired () {
return this.countryIsLocalPrefixRequired;
}
- @Override
+ /**
+ * Setter for whether the local dial prefix is required for local calls
+ * <p>
+ * @param countryIsLocalPrefixRequired Whether the local dial prefix is
+ * required
+ */
public void setCountryIsLocalPrefixRequired (final Boolean countryIsLocalPrefixRequired) {
this.countryIsLocalPrefixRequired = countryIsLocalPrefixRequired;
}
- @Override
+ /**
+ * Getter for country code (example: 49 for Germany, 63 for Philippines)
+ * <p>
+ * @return Dial number without prefix
+ */
public Short getCountryPhoneCode () {
return this.countryPhoneCode;
}
- @Override
+ /**
+ * Setter for country code (example: 49 for Germany, 63 for Philippines)
+ * <p>
+ * @param countryPhoneCode Country code
+ */
public void setCountryPhoneCode (final Short countryPhoneCode) {
this.countryPhoneCode = countryPhoneCode;
}
- @Override
- public boolean hasCountries () {
- return (!this.allCountries().isEmpty());
+ /**
+ * Clears this bean's data. This should be called after a form has been
+ * submitted and the processing of the form was successful.
+ */
+ private void clear () {
+ // Clear fields
+ this.setCountryAbroadDialPrefix(null);
+ this.setCountryCode(null);
+ this.setCountryExternalDialPrefix(null);
+ this.setCountryI18nKey(null);
+ this.setCountryIsLocalPrefixRequired(null);
+ this.setCountryPhoneCode(null);
}
/**
// Default is not found
boolean isAdded = false;
- // Now get whole ist
- List<Country> countries = this.countryController.allCountries();
-
- // Get iterator from it
- Iterator<Country> iterator = countries.iterator();
-
// Check whole list
- while (iterator.hasNext()) {
- // Get next country
- Country next = iterator.next();
-
+ for (final Country currentCountry : this.countryListController.getAllCountries()) {
// Is country code or i18n the same?
- if ((Objects.equals(country.getCountryCode(), next.getCountryCode())) || (Objects.equals(country.getCountryI18nkey(), next.getCountryI18nkey()))) {
+ if ((Objects.equals(country.getCountryCode(), currentCountry.getCountryCode())) || (Objects.equals(country.getCountryI18nKey(), currentCountry.getCountryI18nKey()))) {
// Yes, then abort search
isAdded = true;
break;