# core.customizeAllInstances
Extend all definition instances viewer capabilities by implement a range of customizations, such as controlling the instance's display, determining field visibility, adjusting box sizes, and more.
# Usage:
core.customizeAllInstances(function(instance, presenter) {
...
})
Arguments:
Argument | Description | Required |
---|---|---|
function | Callback function responsible to implement the new functionality | YES |
Function arguments:
Argument | Description |
---|---|
instance | The instance model. |
presenter | The instance presenter |
# Examples:
In the code snippet below, we'll present a file preview exclusively for image files
cob.custom.customize.push(function(core, utils, ui) {
core.customizeAllInstances(function(instance, presenter) {
const supportedExtensions = /\.(gif|jpg|png|webp)/i;
const questionB64 = "";
const classImgPreview = "js-img-preview";
/**
* Add dom element that allows to preview an image
* @param instance the instance model
* @param fp the field presenter
*/
function showImagePreview(instance, fp) {
const fpHtml = fp.content()[0];
// remove previous preview if existing
const previousPreview = fpHtml.querySelector(`.${classImgPreview}`);
if (previousPreview) previousPreview.remove();
// add new preview pointing to the image
if (fp.getValue()) {
const url = `/recordm/recordm/instances/${instance.getId()}/files/${fp.field.fieldDefinition.id}/${fp.getValue()}`;
fpHtml.insertAdjacentHTML("beforeend",
supportedExtensions.test(fp.getValue())
? `<div class="${classImgPreview} mt-2"><img src="${url}" alt="picture non-editable" style="max-width: 200px;"></div>`
: `<div class="${classImgPreview} mt-2"><img src="${questionB64}" alt="unknown" width="50"></div>`,
);
}
}
/**
* Extract all fields from the presenter that are of type $file and show the preview
*/
presenter
.findFieldPs((fp) => /\$file/.test(fp.field.fieldDefinition.description) && fp.getValue() !== null)
.forEach(fp => {
showImagePreview(instance, fp);
presenter.onFieldChange(fp, () => showImagePreview(instance, fp));
});
});
});
