...
Code Block |
---|
entity.getBelongsToField(PluginNameFields.ORDER); |
or even better:
Code Block |
---|
import static com.qcadoo.mes.pluginName.constants.PluginNameFields;
entity.getBelongstoField(ORDER); |
I know it's something new, and refactoring the whole system will be a horror. Let's just use it from now on, ok?You should avoid static importing such constants or you loose their namespace and the probability to make mistake increase dramatically.
It is important especially for field names, which often has the same (or at least very similar) names.
Java enums
For every enum field of a model we create, we should create corresponding Java enum in constants package.
...
Code Block | ||
---|---|---|
| ||
public enum BatchNumberUniqueness { GLOBALLY("01globally"), MANUFACTURER("02manufacturer"); private final String stringValue; private BatchNumberUniqueness(final String stringValue) { this.stringValue = stringValue; } public String getStringValue() { return stringValue; } public static final BatchNumberUniqueness parseString(final String string) { if ("01globally".equals(stringBatchNumberUniqueness parsedEnum = null; for (BatchNumberUniqueness value : BatchNumberUniqueness.values()) { return GLOBALLY; } else if ("02manufacturer"(value.getStringValue().equals(string)) { return MANUFACTURER;parsedEnum = value; break; } else { } throw new IllegalStateException(Preconditions.checkArgument(parsedEnum != null, "Couldn't parse BatchNumberUniquenessenum from string '" + string + "'"); return parsedEnum; } @Override public String toString() { return stringValue; } } |
Naming conventions
Naming literals:
...
- constants - we hold here classes like AwesomePluginConstants AwesomePluginConstants.java and maybe some model enums that are plugin specific.
- hooks - model and view hooks like: ViewNameViewHooks ViewNameHooks.java, ModelNameHooks ModelNameHooks.java. If the hook class is meant to extend (on a business level) an other plugin it should have plugin abbreviation for ex. ModelNameHooksAP.java
- validators - model validators like: ModelNameValidators ModelNameValidators.java, SomeOtherModelNameValidators SomeOtherModelNameValidators.java or ModelNameValidatorsAP.java (like with the hooks)
- listeners - view listeners like: ViewNameListeners.javastates - if there is some logic regarding model states (I consider enum state model field as something that common to write it here), for ex. ModelNameStatesService.java ViewNameListeners.java, ViewNameListenersAP.java (like with the hooks)
- workPlansColumnExtension - http://wiki.qcadoo.org/display/QCDMESDOC/WorkPlans+column+extension
...