# 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));
          });
    });
});