AEM Touch UI page property field validation by Debal Das
I have used Coral 3 — Granite UI NumberField as resourceType to achieve this functionality and JCR property structure associated with that Touch UI field has been shown below -
data:image/s3,"s3://crabby-images/604fb/604fb1e0f1f8443b59848f55a71e268735acdc1a" alt="DEBAL_DAS_0-1700045552289.png DEBAL_DAS_0-1700045552289.png"
It has helped to stop entering values like -1, 0 , 1.9 , 5.6 and 7.999 but still authors were able to input 1.0 , 2.0 , 7.0 , 12.0.
Then I came to know about content structure : validation, that I can use to restrict authors to input values like 1.0 , 2.0 , 7.0 , 12.0
To understand the implementation of validation , I have referred two great documents and I will share those links at end of this blog.
Let me share the implementation steps associated with validation -
- Created a client-library folder with categories: demo.integer.validator and written a JS to set the validation so that author can’t make input like 1.0 , 2.0 , 7.0 , 12.0 via NumberField -
data:image/s3,"s3://crabby-images/a7832/a7832a48a49d742c933caea4932d405ed7eb367f" alt="DEBAL_DAS_1-1700045613581.png DEBAL_DAS_1-1700045613581.png"
(function ($, window, document) {
var registry = $(window).adaptTo("foundation-registry");
registry.register("foundation.validation.validator", {
selector: "[data-validation=integer-number]",
validate: function (el) {
var element = $(el);
var pattern = element.data('pattern');
var value = element.val();
if (value.length == 0) {
value = 0;
}
patterns = {
integer: /^\d+$/
}
if (pattern) {
if (patterns[pattern]) {
error = !patterns[pattern].test(value);
} else {
error = !(new RegExp(pattern)).test(value);
}
if (error) {
return "The field must match the pattern: " + pattern;
}
}
}
});
})
($, window, document);
2. Added client-library category against extraClientLibs property at cq:dialog node of page component as shown below -
data:image/s3,"s3://crabby-images/e870e/e870e6850b1b2f2470b19f1d96fba10f6881915f" alt="DEBAL_DAS_2-1700045686672.png DEBAL_DAS_2-1700045686672.png"
3. Added property named “validation” with the value registered with foundation.validation.validator in numberfieldValidation.js file i.e. integer-number as shown below -
data:image/s3,"s3://crabby-images/acbfd/acbfd896e08ad9d13f407410f6c458860b2120be" alt="DEBAL_DAS_3-1700045727392.png DEBAL_DAS_3-1700045727392.png"
4. Created “granite:data” node (nt:unstructured) under node where I need to set validation and added additional attribute as property that is required for validation as shown below -
data:image/s3,"s3://crabby-images/6fc42/6fc424e86eaaacc514c5f43099e13674e512804f" alt="DEBAL_DAS_4-1700045758453.png DEBAL_DAS_4-1700045758453.png"
Finally I was able to restrict authors to enter value like 1.0 , 2.0 , 7.0 , 12.0 as shown below -
data:image/s3,"s3://crabby-images/c7178/c717837ecc9787793fcd5d6303e72c1f6244e381" alt="DEBAL_DAS_5-1700045788227.png DEBAL_DAS_5-1700045788227.png"
Wow! That’s really great but wait a second. Did I test this during page creation?
Unfortunately it was unable restrict authors to enter value like 1.0 , 2.0 , 7.0 , 12.0 during page creation as shown below -
data:image/s3,"s3://crabby-images/80b33/80b33511546f05ff228fffce62d5f77eecd8664f" alt="DEBAL_DAS_9-1700046038339.png DEBAL_DAS_9-1700046038339.png"
Do we have any AEM capability to achieve this one also?
Earlier we have identified one OOTB client-library category named: cq.sites.validations plays crucial role during page creation as shown below -
data:image/s3,"s3://crabby-images/f10a7/f10a7526de0608001d4346838cd337c1c37fe181" alt="DEBAL_DAS_7-1700045863157.png DEBAL_DAS_7-1700045863157.png"
We have added cq.sites.validations as categories at our client-library and now we were able to restrict authors to enter value like 1.0 , 2.0 , 7.0 , 12.0 during page creation -
data:image/s3,"s3://crabby-images/e5c8b/e5c8b5a0886a1a80722335d647db650f03280d42" alt="DEBAL_DAS_8-1700045903415.png DEBAL_DAS_8-1700045903415.png"
Please refer the following link: https://medium.com/@debal.india2014/aem-touch-ui-page-property-field-validation-1117556d8a46 to read the blog