Reports API

Reports allow you to export your record data in easily-readable formats, like PDFs. You can read more about creating custom PDF reports here.

This endpoint can be helpful if you need to update multiple CSS classes across several reports, or if you want to move reports from one app to another.

You can find which reports are associated with which forms by using the forms endpoints or by adding the query parameter ?form_id={your_form_id} to the Get All Reports endpoints.

Properties

PropertyTypeRequiredReadonlyDescription
namestringyesnoThe name of the report template.
descriptionstringnonoA brief description of the report template.
bodystringyesnoThe body content of the report template.
headerstringyesnoThe header content of the report template.
filename_patternstringnonoThe pattern for the report's filename.
footerstringyesnoThe footer content of the report template.
stylesstringyesnoThe styles applied to the report template.
scriptstringyesnoThe script used in the report template.
statusstringyesnoThe status of the report template (e.g., active).
typestringyesnoThe type of the report template (e.g., advanced).
idstringnoyesThe unique identifier for the report template.
created_atstringnoyesTimestamp when the report template was created.
updated_atstringnoyesTimestamp when the report template was last updated.
created_bystringnoyesThe name of the user who created the report template.
created_by_idstringnoyesThe ID of the user who created the report template.
updated_bystringnoyesThe name of the user who last updated the report template.
updated_by_idstringnoyesThe ID of the user who last updated the report template.

Config Properties

PropertyTypeRequiredReadonlyDescription
sizestringyesnoThe size of the report (e.g., Letter).
landscapebooleanyesnoWhether the report is in landscape orientation.
margin_topnumberyesnoThe top margin of the report.
margin_rightnumberyesnoThe right margin of the report.
margin_bottomnumberyesnoThe bottom margin of the report.
margin_leftnumberyesnoThe left margin of the report.
outputstringyesnoThe output format of the report (e.g., pdf).
hidden_fieldsarraynonoThe list of fields to be hidden in the report.
field.empty_valuestringnonoThe value to display for empty fields.
header.enabledbooleanyesnoWhether the header is enabled.
header.form.namebooleanyesnoWhether the form name is included in the header.
header.record.idbooleanyesnoWhether the record ID is included in the header.
footer.enabledbooleanyesnoWhether the footer is enabled.
footer.timestampbooleanyesnoWhether the timestamp is included in the footer.
footer.organization_imagebooleanyesnoWhether the organization image is included in the footer.
footer.organization_infobooleanyesnoWhether the organization info is included in the footer.
footer.page_numberbooleanyesnoWhether the page number is included in the footer.
cover_page.enabledbooleanyesnoWhether the cover page is enabled.
cover_page.form.namebooleanyesnoWhether the form name is included on the cover page.
cover_page.form.descriptionbooleanyesnoWhether the form description is included on the cover page.
cover_page.form.imagebooleanyesnoWhether the form image is included on the cover page.
cover_page.titlebooleanyesnoWhether the cover page title is included.
cover_page.timestampbooleanyesnoWhether the timestamp is included on the cover page.
cover_page.image.enabledbooleanyesnoWhether images are enabled on the cover page.
cover_page.image.captionbooleanyesnoWhether captions are included for images on the cover page.
cover_page.map.enabledbooleanyesnoWhether maps are enabled on the cover page.
cover_page.map.repeatablesbooleanyesnoWhether repeatable items are included on the cover page map.
cover_page.map.typestringyesnoThe type of map to use on the cover page (e.g., roadmap).
cover_page.map.sizestringyesnoThe size of the map on the cover page.
cover_page.metadata.enabledbooleanyesnoWhether metadata is enabled on the cover page.
cover_page.metadata.createdbooleanyesnoWhether the creation metadata is included on the cover page.
cover_page.metadata.updatedbooleanyesnoWhether the update metadata is included on the cover page.
cover_page.metadata.statusbooleanyesnoWhether the status metadata is included on the cover page.
cover_page.metadata.locationbooleanyesnoWhether the location metadata is included on the cover page.
cover_page.metadata.projectbooleanyesnoWhether the project metadata is included on the cover page.
cover_page.metadata.assignedbooleanyesnoWhether the assigned metadata is included on the cover page.
parametersarrayyesnoThe list of parameters for the report.

Validations

Example validation response when respective required fields are not included:

{
    "report_template": {
        "errors": {
            "status": [
                "must be either active or inactive"
            ],
            "body": [
                "must be a string"
            ],
            "header": [
                "must be a string"
            ],
            "footer": [
                "must be a string"
            ],
            "styles": [
                "must be a string"
            ],
            "script": [
                "must be a string"
            ],
            "config": [
                "must be an object"
            ]
        }
    }
}

Sample Response

{
    "report_template": {
        "name": "Report",
        "description": "",
        "body": "<div class='root'>\n  <% if (SETTING('cover_page.enabled')) { %>\n    <div class='cover page-break-before page-break-after'>\n      <%\n      const formEnabled = SETTING('cover_page.form.name') ||\n                          SETTING('cover_page.form.description') ||\n                          SETTING('cover_page.form.image');\n      %>\n\n      <% if (formEnabled) { %>\n        <div class='title'>\n          <div class='title-label'>\n            <% if (SETTING('cover_page.form.name')) { %>\n              <h1><%= form.name %></h1>\n            <% } %>\n            <% if (SETTING('cover_page.form.description') && form.description) { %>\n              <hr>\n              <h2><%= form.description %></h2>\n            <% } %>\n          </div>\n          <% if (SETTING('cover_page.form.image') && form.imageSmall) { %>\n            <div class='title-image'>\n              <img src='<%= form.imageSmall %>' />\n            </div>\n          <% } %>\n        </div>\n      <% } %>\n\n      <% if (SETTING('cover_page.title')) { %>\n        <h1 class='field-section metadata'><%= record.displayValue %></h1>\n      <% } %>\n\n      <% if (SETTING('cover_page.timestamp')) { %>\n        <h4 class='field-section metadata'><%= FORMATDATE(record.clientUpdatedAt) %></h4>\n      <% } %>\n\n      <% if (SETTING('cover_page.image.enabled')) { %>\n        <%\n          const firstPhotoField = form.elementsOfType('PhotoField', false)[0]\n          const value = firstPhotoField && record.formValues.get(firstPhotoField.key);\n        %>\n        <% if (firstPhotoField && value) { %>\n          <div style='display: flex;'>\n            <div style='flex: 1 1 auto;'>\n              <figure class='cover-photo-container' style='margin-inline-start: 0px; margin-inline-end: 0px; margin-block-start: 0px; margin-block-end: 0px'>\n                <img class='<%= IMAGE_SIZE() %>' style='width: 100%;' src='<%= PHOTOURL(value.items[0].mediaID) %>' />\n\n                <% if (SETTING('cover_page.image.caption') && value.items[0].caption) { %>\n                  <figcaption><%= value.items[0].caption %></figcaption>\n                <% } %>\n              </figure>\n            </div>\n          </div>\n        <% } %>\n      <% } %>\n      <div class='meta-wrapper'>\n        <% if (record.hasCoordinate) { %>\n          <% let statusColor = null; %>\n          <% if (SETTING('cover_page.map.enabled')) { %>\n            <div class='meta-map'>\n              <div class='field'>\n                <div class='field-label-full'>\n                  <%\n                  const markerColor = (statusColor || 'e00606').replace('#', '');\n\n                  const markers = [\n                    `size:medium|color:0x${markerColor}|label:|${record.latitude},${record.longitude}`\n                  ];\n\n                  if (SETTING('cover_page.map.repeatables')) {\n                    const items = record.formValues.repeatableItems.filter(item => item.hasCoordinate);\n\n                    for (const item of items) {\n                      markers.push(`size:tiny|color:0xe00606|label:|${item.latitude},${item.longitude}`);\n                    }\n                  }\n                  %>\n\n                  <img class='<%= SET_MAP_CLASS() %>' src='<%= STATICMAP({markers, ...SET_MAP_OPTIONS()}) %>' />\n\n                </div>\n              </div>\n            </div>\n          <% } %>\n        <% } %>\n\n        <% if (SETTING('cover_page.metadata.enabled')) { %>\n          <div class=\"meta-fields-container\" style='margin-top: 20px; <% if (!SETTING('cover_page.map.enabled') || (!record.hasCoordinate)) { %>margin-left: 0;<% } %>'>\n            <% if (SETTING('cover_page.metadata.created')) { %>\n              <div class='meta-fields'>\n                <div class='meta-field-label'>Created</div>\n                <div class='meta-field-value flex-align-center'>\n                  <svg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'><path d='M7 0C3.13359 0 0 3.13359 0 7C0 10.8664 3.13359 14 7 14C10.8664 14 14 10.8664 14 7C14 3.13359 10.8664 0 7 0ZM11.3313 11.3313C10.2758 12.3867 8.90859 13.0047 7.4375 13.1086V12.6875C7.4375 12.4469 7.24063 12.25 7 12.25C6.75938 12.25 6.5625 12.4469 6.5625 12.6875V13.1086C5.09141 13.0047 3.72422 12.3813 2.66875 11.3313C1.61328 10.2758 0.995312 8.90859 0.891406 7.4375H1.3125C1.55313 7.4375 1.75 7.24063 1.75 7C1.75 6.75938 1.55313 6.5625 1.3125 6.5625H0.891406C0.995312 5.09141 1.61875 3.72422 2.66875 2.66875C3.72422 1.61328 5.09141 0.995312 6.5625 0.891406V1.3125C6.5625 1.55313 6.75938 1.75 7 1.75C7.24063 1.75 7.4375 1.55313 7.4375 1.3125V0.891406C8.90859 0.995312 10.2758 1.61875 11.3313 2.66875C12.3867 3.72422 13.0047 5.09141 13.1086 6.5625H12.6875C12.4469 6.5625 12.25 6.75938 12.25 7C12.25 7.24063 12.4469 7.4375 12.6875 7.4375H13.1086C13.0047 8.90859 12.3867 10.2758 11.3313 11.3313Z' fill='#7D7D7D'/><path d='M7.43203 3.46172C7.41016 3.2375 7.22422 3.0625 6.99453 3.0625C6.76484 3.0625 6.57891 3.2375 6.55703 3.45625L6.20703 6.24531L4.33672 6.5625C4.1125 6.58438 3.9375 6.77031 3.9375 7C3.9375 7.22969 4.1125 7.41563 4.33125 7.4375L6.81406 7.85859L6.88516 7.86953C6.89063 7.86953 6.89609 7.86953 6.90156 7.86953C7.15313 7.89688 7.41563 7.81484 7.6125 7.61797C7.83672 7.39375 7.91328 7.08203 7.84219 6.79219L7.43203 3.46172Z' fill='#7D7D7D'/></svg>\n                  <%= FORMATDATE(record.clientCreatedAt) %>\n                </div>\n                <div class='meta-field-value flex-align-center'>\n                  <svg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'><path d='M0 7C0 5.14348 0.737499 3.36301 2.05025 2.05025C3.36301 0.737499 5.14348 0 7 0C8.85652 0 10.637 0.737499 11.9497 2.05025C13.2625 3.36301 14 5.14348 14 7C14 8.85652 13.2625 10.637 11.9497 11.9497C10.637 13.2625 8.85652 14 7 14C5.14348 14 3.36301 13.2625 2.05025 11.9497C0.737499 10.637 0 8.85652 0 7ZM9.30163 5.49735V6.20178C9.30163 6.5228 9.19067 7.02253 8.36751 8.29484C8.33966 8.33778 8.3119 8.38033 8.28423 8.42248C9.7971 8.77734 11.0882 9.2884 12.1285 10.3524C12.7817 9.35658 13.1282 8.19092 13.125 7C13.1272 6.19531 12.9699 5.39816 12.662 4.6547C12.3541 3.91124 11.9018 3.23624 11.3312 2.66875C10.7638 2.09822 10.0888 1.64592 9.3453 1.33802C8.60184 1.03012 7.80469 0.872745 7 0.875C6.19531 0.872757 5.39817 1.03014 4.65471 1.33803C3.91125 1.64593 3.23624 2.09823 2.66875 2.66875C2.09823 3.23624 1.64593 3.91124 1.33803 4.6547C1.03014 5.39816 0.872754 6.19531 0.875 7C0.871987 8.16028 1.20078 9.29724 1.82263 10.2768C2.86573 9.20374 4.15232 8.78319 5.69024 8.42248C5.66253 8.3804 5.63473 8.33786 5.60684 8.29484C4.78368 7.02253 4.67272 6.52296 4.67272 6.20178V5.49735C4.67272 3.94373 5.43359 2.67974 6.9872 2.67974C8.54082 2.67974 9.30169 3.94368 9.30169 5.49735H9.30163Z' fill='#7D7D7D'/></svg>\n                  by <%= record.createdByName %>\n                </div>\n              </div>\n            <% } %>\n\n            <% if (SETTING('cover_page.metadata.updated')) { %>\n              <div class='meta-fields'>\n                <div class='meta-field-label'>Updated</div>\n                <div class='meta-field-value flex-align-center'>\n                  <svg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'><path d='M7 0C3.13359 0 0 3.13359 0 7C0 10.8664 3.13359 14 7 14C10.8664 14 14 10.8664 14 7C14 3.13359 10.8664 0 7 0ZM11.3313 11.3313C10.2758 12.3867 8.90859 13.0047 7.4375 13.1086V12.6875C7.4375 12.4469 7.24063 12.25 7 12.25C6.75938 12.25 6.5625 12.4469 6.5625 12.6875V13.1086C5.09141 13.0047 3.72422 12.3813 2.66875 11.3313C1.61328 10.2758 0.995312 8.90859 0.891406 7.4375H1.3125C1.55313 7.4375 1.75 7.24063 1.75 7C1.75 6.75938 1.55313 6.5625 1.3125 6.5625H0.891406C0.995312 5.09141 1.61875 3.72422 2.66875 2.66875C3.72422 1.61328 5.09141 0.995312 6.5625 0.891406V1.3125C6.5625 1.55313 6.75938 1.75 7 1.75C7.24063 1.75 7.4375 1.55313 7.4375 1.3125V0.891406C8.90859 0.995312 10.2758 1.61875 11.3313 2.66875C12.3867 3.72422 13.0047 5.09141 13.1086 6.5625H12.6875C12.4469 6.5625 12.25 6.75938 12.25 7C12.25 7.24063 12.4469 7.4375 12.6875 7.4375H13.1086C13.0047 8.90859 12.3867 10.2758 11.3313 11.3313Z' fill='#7D7D7D'/><path d='M7.43203 3.46172C7.41016 3.2375 7.22422 3.0625 6.99453 3.0625C6.76484 3.0625 6.57891 3.2375 6.55703 3.45625L6.20703 6.24531L4.33672 6.5625C4.1125 6.58438 3.9375 6.77031 3.9375 7C3.9375 7.22969 4.1125 7.41563 4.33125 7.4375L6.81406 7.85859L6.88516 7.86953C6.89063 7.86953 6.89609 7.86953 6.90156 7.86953C7.15313 7.89688 7.41563 7.81484 7.6125 7.61797C7.83672 7.39375 7.91328 7.08203 7.84219 6.79219L7.43203 3.46172Z' fill='#7D7D7D'/></svg>\n                  <%= FORMATDATE(record.clientUpdatedAt) %>\n                </div>\n                <div class='meta-field-value flex-align-center'>\n                  <svg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'><path d='M0 7C0 5.14348 0.737499 3.36301 2.05025 2.05025C3.36301 0.737499 5.14348 0 7 0C8.85652 0 10.637 0.737499 11.9497 2.05025C13.2625 3.36301 14 5.14348 14 7C14 8.85652 13.2625 10.637 11.9497 11.9497C10.637 13.2625 8.85652 14 7 14C5.14348 14 3.36301 13.2625 2.05025 11.9497C0.737499 10.637 0 8.85652 0 7ZM9.30163 5.49735V6.20178C9.30163 6.5228 9.19067 7.02253 8.36751 8.29484C8.33966 8.33778 8.3119 8.38033 8.28423 8.42248C9.7971 8.77734 11.0882 9.2884 12.1285 10.3524C12.7817 9.35658 13.1282 8.19092 13.125 7C13.1272 6.19531 12.9699 5.39816 12.662 4.6547C12.3541 3.91124 11.9018 3.23624 11.3312 2.66875C10.7638 2.09822 10.0888 1.64592 9.3453 1.33802C8.60184 1.03012 7.80469 0.872745 7 0.875C6.19531 0.872757 5.39817 1.03014 4.65471 1.33803C3.91125 1.64593 3.23624 2.09823 2.66875 2.66875C2.09823 3.23624 1.64593 3.91124 1.33803 4.6547C1.03014 5.39816 0.872754 6.19531 0.875 7C0.871987 8.16028 1.20078 9.29724 1.82263 10.2768C2.86573 9.20374 4.15232 8.78319 5.69024 8.42248C5.66253 8.3804 5.63473 8.33786 5.60684 8.29484C4.78368 7.02253 4.67272 6.52296 4.67272 6.20178V5.49735C4.67272 3.94373 5.43359 2.67974 6.9872 2.67974C8.54082 2.67974 9.30169 3.94368 9.30169 5.49735H9.30163Z' fill='#7D7D7D'/></svg>\n                  by <%= record.updatedByName %>\n                </div>\n              </div>\n            <% } %>\n\n            <% if (SETTING('cover_page.metadata.status') && record.isStatusFieldEnabled) { %>\n              <div class='meta-fields'>\n                <div class='meta-field-label'>Status</div>\n                <div class='meta-field-value'>\n                  <% let choice = record.statusValue.element.statusForValue(record.statusValue.textValue); %>\n                  <% if (choice) { %>\n                    <% statusColor = choice.color %>\n                    <div class='status-color' style='background-color: <%= choice.color %>'></div>\n                    <div class='status-value'><%= choice.label %></div>\n                  <% } %>\n                </div>\n              </div>\n            <% } %>\n\n            <% if (SETTING('cover_page.metadata.location') && record.hasCoordinate) { %>\n              <div class='meta-fields'>\n                <div class='meta-field-label'>Location</div>\n                <div class='meta-field-value'>\n                  <svg width='11' height='14' viewBox='0 0 11 14' fill='none' xmlns='http://www.w3.org/2000/svg'><path d='M4.9222 13.7649C4.06642 12.9409 3.27342 12.054 2.54986 11.1117C0.916769 8.98449 0.0600533 7.0766 0.0035948 5.44105C-0.0219469 4.75139 0.0888192 4.06347 0.329546 3.41669C0.570272 2.7699 0.936229 2.17696 1.40646 1.67183C1.87669 1.16669 2.44196 0.759286 3.06988 0.472943C3.6978 0.1866 4.37605 0.0269469 5.06577 0.00312654C5.75549 -0.0206938 6.44313 0.0917845 7.08931 0.334125C7.73549 0.576465 8.32752 0.943909 8.83148 1.4154C9.33544 1.88689 9.74143 2.45317 10.0262 3.08181C10.311 3.71044 10.4689 4.38908 10.491 5.07886C10.5475 6.71451 9.82425 8.67689 8.3419 10.9117C7.68506 11.9016 6.95512 12.8411 6.15817 13.7221C6.07991 13.8062 5.9858 13.874 5.88125 13.9216C5.77671 13.9692 5.66379 13.9956 5.54899 13.9995C5.53878 13.9998 5.5286 14 5.51843 14C5.29704 14.0002 5.08387 13.9162 4.9222 13.7649ZM5.09644 0.89016C4.52259 0.909972 3.95827 1.04262 3.43568 1.28053C2.9131 1.51844 2.44249 1.85694 2.05072 2.27673C1.65896 2.69651 1.35371 3.18935 1.15242 3.7271C0.95112 4.26485 0.857711 4.83698 0.877525 5.41083C0.998258 8.90666 5.51892 13.1256 5.51892 13.1256C5.51892 13.1256 9.73784 8.60491 9.61711 5.10913C9.57803 3.97675 9.1009 2.90376 8.28626 2.11626C7.47161 1.32875 6.38308 0.888238 5.25002 0.887538C5.19914 0.887538 5.14771 0.888357 5.09644 0.89016ZM2.62386 5.20423C2.62386 4.68536 2.77772 4.17815 3.06599 3.74673C3.35425 3.31531 3.76398 2.97906 4.24335 2.7805C4.72272 2.58193 5.2502 2.52998 5.7591 2.63121C6.26799 2.73244 6.73545 2.98229 7.10234 3.34919C7.46923 3.71608 7.71909 4.18353 7.82031 4.69243C7.92154 5.20132 7.86959 5.72881 7.67103 6.20818C7.47246 6.68755 7.13621 7.09727 6.70479 7.38554C6.27337 7.67381 5.76616 7.82766 5.24729 7.82766C4.55176 7.82687 3.88494 7.55022 3.39312 7.0584C2.90131 6.56658 2.62465 5.89976 2.62386 5.20423ZM3.55299 5.20423C3.55299 5.85921 4.03986 6.89853 5.24729 6.89853C6.45473 6.89853 6.94159 5.90737 6.94159 5.20423C6.94159 4.5011 6.45473 3.50993 5.24729 3.50993C4.03986 3.50993 3.55299 4.54941 3.55299 5.20423Z' fill='#7D7D7D'/></svg>\n                  <%= record.latitude.toFixed(6) %>, <%= record.longitude.toFixed(6) %>\n                </div>\n              </div>\n            <% } %>\n\n            <% if (SETTING('cover_page.metadata.project') && form.isProjectEnabled) { %>\n              <div class='meta-fields'>\n                <div class='meta-field-label'>Project</div>\n                <div class='meta-field-value'>\n                  <svg width='14' height='13' viewBox='0 0 14 13' fill='none' xmlns='http://www.w3.org/2000/svg'><path d='M13.125 2.625H10.5V1.75C10.5 0.7875 9.7125 0 8.75 0H5.25C4.2875 0 3.5 0.7875 3.5 1.75V2.625H0.875C0.39375 2.625 0 3.01875 0 3.5V11.375C0 11.8563 0.39375 12.25 0.875 12.25H13.125C13.6062 12.25 14 11.8563 14 11.375V3.5C14 3.01875 13.6062 2.625 13.125 2.625ZM4.375 1.75C4.375 1.26875 4.76875 0.875 5.25 0.875H8.75C9.23125 0.875 9.625 1.26875 9.625 1.75V2.625H4.375V1.75ZM13.125 11.375H0.875V3.5H13.125V11.375Z\" fill=\"#7D7D7D\"/><path d=\"M7 4.8125L3.98672 9.1875H10.0133L7 4.8125Z' fill='#7D7D7D'/></svg>\n                  <%= PROJECTNAME() ? PROJECTNAME() : 'No Project' %>\n                </div>\n              </div>\n            <% } %>\n\n            <% if (SETTING('cover_page.metadata.assigned') && form.isAssignmentEnabled) { %>\n              <div class='meta-fields'>\n                <div class='meta-field-label'>Assigned to</div>\n                <div class='meta-field-value'>\n                  <svg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'><path d='M0 7C0 5.14348 0.737499 3.36301 2.05025 2.05025C3.36301 0.737499 5.14348 0 7 0C8.85652 0 10.637 0.737499 11.9497 2.05025C13.2625 3.36301 14 5.14348 14 7C14 8.85652 13.2625 10.637 11.9497 11.9497C10.637 13.2625 8.85652 14 7 14C5.14348 14 3.36301 13.2625 2.05025 11.9497C0.737499 10.637 0 8.85652 0 7ZM9.30163 5.49735V6.20178C9.30163 6.5228 9.19067 7.02253 8.36751 8.29484C8.33966 8.33778 8.3119 8.38033 8.28423 8.42248C9.7971 8.77734 11.0882 9.2884 12.1285 10.3524C12.7817 9.35658 13.1282 8.19092 13.125 7C13.1272 6.19531 12.9699 5.39816 12.662 4.6547C12.3541 3.91124 11.9018 3.23624 11.3312 2.66875C10.7638 2.09822 10.0888 1.64592 9.3453 1.33802C8.60184 1.03012 7.80469 0.872745 7 0.875C6.19531 0.872757 5.39817 1.03014 4.65471 1.33803C3.91125 1.64593 3.23624 2.09823 2.66875 2.66875C2.09823 3.23624 1.64593 3.91124 1.33803 4.6547C1.03014 5.39816 0.872754 6.19531 0.875 7C0.871987 8.16028 1.20078 9.29724 1.82263 10.2768C2.86573 9.20374 4.15232 8.78319 5.69024 8.42248C5.66253 8.3804 5.63473 8.33786 5.60684 8.29484C4.78368 7.02253 4.67272 6.52296 4.67272 6.20178V5.49735C4.67272 3.94373 5.43359 2.67974 6.9872 2.67974C8.54082 2.67974 9.30169 3.94368 9.30169 5.49735H9.30163Z' fill='#7D7D7D'/></svg>\n                  <%= record.assignedToName ? record.assignedToName : 'No Assignment' %>\n                </div>\n              </div>\n            <% } %>\n          </div>\n        <% } %>\n      </div>\n    </div>\n  <% } %>\n\n  <%\n\n  const defaultFormatter = (element, value) => {\n    const isEmpty = value == null || value.isEmpty;\n\n    if (isEmpty) {\n      return SETTING('field.empty_value');\n    }\n\n    return value.displayValue;\n  }\n\n  const formatter = typeof formatValue === 'function' ? formatValue : defaultFormatter;\n\n  %>\n\n  <% RENDER(record, null, ({element, value, renderSection, renderRepeatableItems, container, index, feature, parent, allValues}) => { %>\n    <%\n      const hidden = SETTING('hidden_fields').indexOf(element.dataName) !== -1;\n\n      if (hidden || !ISVISIBLE(element, record, allValues)) {\n        return;\n      }\n    %>\n\n    <% if (element.isSectionElement) { %>\n      <div class='field-section'>\n        <h1 class='field-section-title'><%= element.label %></h1>\n        <div class='field-section-content'>\n          <% renderSection() %>\n        </div>\n      </div>\n    <% } else if (element.isRepeatableElement) { %>\n      <div class='field-repeatable'>\n        <h1 class='field-repeatable-title'><%= element.label %> <%= value && `(${value.displayValue})` %></h1>\n        <div class='field-repeatable-content'>\n          <% const tables = SETTING('tables'); %>\n\n          <% if (tables && tables[element.dataName]) { %>\n            <%\n              const tableFields = tables[element.dataName].fields;\n              const { compact } = LIBS.lodash;\n              let tableElements = element.allElements;\n              if (tableFields.length) {\n                tableElements = compact(tableFields.map(field => tableElements.find(e => e.dataName == field)));\n              }\n            %>\n            <table class='field-repeatable-table' cellpadding='0' cellspacing='0'>\n              <thead>\n                <tr>\n                  <% for (const childElement of tableElements) { %>\n                    <th><%= childElement.label %></th>\n                  <% } %>\n                </tr>\n              </thead>\n              <tbody>\n              <% renderRepeatableItems(({feature, element, renderItem, container, index, parent, allValues}) => { %>\n                <tr>\n                  <% for (const childElement of tableElements) { %>\n                    <% const formValue = feature.formValues.get(childElement.key) %>\n                    <% if (childElement.isPhotoElement) { %>\n                      <% if (formValue && formValue.items) { %>\n                        <td>\n                        <% formValue && formValue.items.forEach((item, index) => { %>\n                          <img class='photo' width='100px' src='<%= PHOTOURL(item.mediaID) %>' />\n                        <% }); %>\n                        </td>\n                      <% } else { %>\n                        <td><%= formValue && formValue.displayValue %></td>\n                      <% } %>\n                    <% } else { %>\n                      <td><%= formValue && formValue.displayValue %></td>\n                    <% } %>\n                  <% } %>\n                </tr>\n              <% }); %>\n              </tbody>\n            </table>\n          <% } else { %>\n            <% renderRepeatableItems(({element, value, renderItem, container, index, feature, parent, allValues}) => { %>\n                <% if (SETTING('repeatable_break')) { %>\n                  <div class='field-repeatable-item page-break-before page-break-after'>\n                <% } else { %>\n                  <div class='field-repeatable-item'>\n                <% } %>\n                  <h2><%= `${element.label} - ${index+1}. ${value.displayValue}` %></h2>\n                  <% renderItem() %>\n                </div>\n            <% }); %>\n          <% } %>\n        </div>\n      </div>\n    <% } else if (element.isPhotoElement) { %>\n      <div class='field photo-field'>\n        <h2 class='field-label'><%= element.label %></h2>\n        <div class='field-label-full'>\n          <% if (value && !value.isEmpty) { %>\n            <div class='photo-row'>\n              <% value.items.forEach((item, index) => { %>\n                <div class='photo-column'>\n                  <figure>\n                    <img class=\"<%= IMAGE_SIZE() %>\" src='<%= PHOTOURL(item.mediaID) %>' />\n                    <% if (item.caption) { %>\n                      <figcaption><%= item.caption %></figcaption>\n                    <% } %>\n                  </figure>\n                </div>\n              <% }); %>\n            </div>\n          <% } else { %>\n            <p><%= SETTING('field.empty_value') %></p>\n          <% } %>\n        </div>\n      </div>\n    <% } else if (element.isSignatureElement) { %>\n      <div class='field'>\n        <h2 class='field-label'><%= element.label %></h2>\n        <div class='field-value'>\n          <% if (value && !value.isEmpty) { %>\n            <img class='signature' src='<%= SIGNATUREURL(value.id) %>' />\n            <p><%= element.agreementText %></p>\n            <p>Signed <%= FORMATDATE(value.timestamp) %></p>\n          <% } else { %>\n            <%= SETTING('field.empty_value') %>\n          <% } %>\n        </div>\n      </div>\n    <% } else if (element.isRecordLinkElement) { %>\n      <div class=\"field\">\n        <h2 class=\"field-label\"><%= element.label %></h2>\n        <div class=\"field-value\">\n          <% if (value && !value.isEmpty) { %>\n            <%\n              const labels = value.items.map(item => {\n                return item.record ? ESC(defaultFormatter(element, item)) : '<i>Not Available</i>';\n              }).join(', ');\n            %>\n            <%- labels %>\n          <% } else { %>\n            <%= SETTING('field.empty_value') %>\n          <% } %>\n        </div>\n      </div>\n    <% } else if (element.isLabelElement) { %>\n      <div class='field'>\n        <h2 class='field-label-full'><%= element.label %></h2>\n      </div>\n    <% } else { %>\n      <div class='field'>\n        <h2 class='field-label'><%= element.label %></h2>\n        <div class='field-value pre'><%= formatter(element, value, {defaultFormatter, container, index, feature, parent, allValues}) %></div>\n      </div>\n    <% } %>\n  <% }) %>\n</div>",
        "header": "<% if (SETTING('header.enabled')) { %>\n  <div class=\"header\">\n    <div class=\"header-title\">\n      <%if (SETTING('header.form.name')) {%><%= form.name %><%}%>\n    </div>\n    <div class=\"header-record\">\n      <%if (SETTING('header.record.id')) {%><%= record.id %><%}%>\n    </div>\n  </div>\n<% } %>",
        "filename_pattern": "",
        "footer": "<%\n  function formatAddress() {\n    let line1 = '';\n    let line2 = '';\n\n    if (organization.address1) {\n      line1 += organization.address1;\n    }\n\n    if (organization.address2) {\n      line1 += `, ${organization.address2}`;\n    }\n\n    if (organization.city) {\n      line2 += organization.city;\n    }\n\n    if (organization.state) {\n      line2 += `, ${organization.state}`;\n    }\n\n    if (organization.postalCode) {\n      line2 += ` ${organization.postalCode}`;\n    }\n\n    return { line1, line2 };\n  }\n%>\n\n<div class=\"footer\">\n  <% if (SETTING('footer.enabled')) { %>\n    <div class=\"footer-company\">\n      <% if (SETTING('footer.organization_image') && organization.image) { %>\n        <div class=\"footer-logo\">\n          <img src=\"<%= IMAGEURL(organization.image) %>\" />\n        </div>\n      <% } %>\n      <div class=\"footer-company-info\">\n        <% if (SETTING('footer.organization_info')) { %>\n          <div>\n            <strong><%= organization.name %></strong><br>\n            <div class=\"footer-address\">\n              <%= formatAddress().line1 %><br>\n              <%= formatAddress().line2 %>\n            </div>\n          </div>\n        <% } %>\n      </div>\n    </div>\n  <% } %>\n\n  <% if (SETTING('footer.enabled')) { %>\n    <div class=\"footer-meta\">\n      <div style=\"margin-left: auto;\">\n        <% if (SETTING('footer.page_number')) { %>\n          Page <span class=\"pageNumber\"></span> of <span class=\"totalPages\"></span><br>\n        <% } %>\n        <% if (SETTING('footer.timestamp')) { %>\n          <%= FORMATDATE(new Date()) %>\n        <% } %>\n      </div>\n    </div>\n  <% } %>\n\n  <div class=\"footer-branding\">\n    <img src=\"\"/>\n  </div>\n</div>",
        "styles": "h1, h2, h3, h4, h5, h6 {\n  margin: 0;\n  padding: 0;\n}\n\n.flex-align-center {\n  display: flex;\n  align-items: center;\n}\n\n.field {\n  padding: 5px 0;\n  border-bottom: 1px solid #e1e1e1;\n  page-break-inside: avoid;\n  display: flex;\n}\n\n.photo-field {\n  display: block;\n  page-break-inside: auto;\n}\n\n.field:last-of-type {\n  border-bottom: none;\n}\n\n.meta-field {\n  border-bottom: 1px solid #ddd;\n  margin-bottom: 5px;\n  padding-bottom: 5px;\n}\n\n.meta-field-group .meta-field:first-of-type  {\n  border-bottom: none;\n}\n\n.field-label {\n  font-weight: 900;\n  width: 30%;\n  font-size: 12px;\n  box-sizing: border-box;\n}\n\n.meta-field-label {\n  box-sizing: border-box;\n  color: #41403b;\n  font-size: 13px;\n  font-weight: 900;\n  margin-bottom: 10px;\n  text-transform: uppercase;\n  width: 30%;\n}\n\n.field-label-full {\n  font-weight: normal;\n  width: 100%;\n  box-sizing: border-box;\n  font-size: 12px;\n}\n\n.field-value {\n  width: 70%;\n  box-sizing: border-box;\n  border-left: 1px solid #e1e1e1;\n  padding-left: 10px;\n}\n\n.meta-field-value {\n  color: #7d7d7d;\n  padding-bottom: 3px;\n  font-size: 14px;\n}\n\n.meta-field-value.flex-align-center svg {\n  padding-right: 5px;\n}\n\n.meta-field-value-large {\n  font-size: 18px;\n}\n\n.cover-photo-container, .photo-column figure {\n  position: relative;\n}\n\n.cover-photo-container img {\n  height: 300px;\n  object-fit: cover;\n}\n\n.cover-photo-container figcaption, .photo-column figcaption {\n  position: absolute;\n  bottom: 18px;\n  margin: 0;\n  padding: 10px;\n  background: rgba(255,255,255,.85);\n  border-radius: 0 7px 7px 0;\n  border: 1px dashed #bbb;\n  border-left: none;\n  margin-right: 15px;\n  left: 0;\n}\n\n\n.cover-photo-container img.photo-landscape { height: 500px; }\n.cover-photo-container img.photo-legal { height: 560px; }\n.cover-photo-container img.photo-legal-ls { height: 498px; }\n.cover-photo-container img.photo-tabloid { height: 740px; }\n.cover-photo-container img.photo-tabloid-ls { height: 740px; }\n.cover-photo-container img.photo-ledger { height: 740px; }\n.cover-photo-container img.photo-ledger-ls { height: 740px; }\n.cover-photo-container img.photo-a4 { height: 380px; }\n.cover-photo-container img.photo-a4-ls { height: 470px; }\n.cover-photo-container img.photo-a3 { height: 840px; }\n.cover-photo-container img.photo-a3-ls { height: 790px; }\n\n.pre {\n  white-space: pre-wrap;\n}\n\n.page-break-before {\n  page-break-before: always;\n}\n\n.page-break-after {\n  page-break-after: always;\n}\n\n.field-value .photo {\n  max-width: 470px;\n  max-height: 470px;\n  margin-top: 6px;\n}\n\n.field-value .signature {\n  max-width: 470px;\n  max-height: 470px;\n  margin-top: 6px;\n}\n\n.field-value .status-color {\n  width: 14px;\n  height: 14px;\n  border-radius: 3px;\n  margin-right: 8px;\n  position: relative;\n  float: left;\n  top: 0px;\n}\n\n.meta-field-value .status-color {\n  width: 14px;\n  height: 14px;\n  border-radius: 3px;\n  margin-right: 8px;\n  position: relative;\n  float: left;\n  top: 0px;\n}\n\n.field-section {\n  border-bottom: 2px solid #e1e1e1;\n  border-right: 2px solid #e1e1e1;\n  margin-bottom: 8px;\n}\n\n.field-section.metadata {\n  color: #41403b;\n  margin: 10px 0;\n  border: none;\n}\n\n.field-section-title {\n  background: #f4f4f4;\n  font-weight: bold;\n  font-size: 18px;\n  border-left: 3px solid #000;\n  margin-top: 20px;\n  margin-bottom: 8px;\n  padding: 7px 12px;\n}\n\n.field-repeatable-title {\n  background: #f4f4f4;\n  font-weight: bold;\n  font-size: 18px;\n  border-left: 3px solid #000;\n  margin-top: 20px;\n  margin-bottom: 8px;\n  padding: 7px 12px;\n}\n\n.field-repeatable-item {\n  padding: 10px 0;\n}\n\n.field-repeatable-item .field-section-title,\n.field-repeatable-item .field-repeatable-title {\n  font-size: 16px;\n  border-color: #ddd;\n  background: #f9f9f9;\n}\n\n.field-repeatable-item > h2 {\n  background: #f9f9f9;\n  border-left: 3px solid #ddd;\n  border-bottom: 2px solid #ddd;\n  font-size: 16px;\n  padding: 7px 12px;\n  margin: 10px 0;\n}\n\n.field-repeatable-table {\n  border-collapse: collapse;\n  width: 100%;\n  margin: 10px 0;\n}\n\n.field-repeatable-table thead {\n  display: table-header-group;\n  break-inside: avoid;\n}\n\n.field-repeatable-table td, .field-repeatable-table th {\n  border: 1px solid #ccc;\n  padding: 4px;\n  text-align: left;\n}\n\n.field-repeatable-table th {\n  background: #eee;\n}\n\n.field-repeatable-table tr {\n  page-break-inside: avoid;\n}\n\n.field-repeatable-table tr:nth-child(even) {\n  background-color: #f4f4f4;\n}\n\n.photo-row {\n  padding-top: 4px;\n}\n\n.photo-column {\n  max-width: 49.76%;\n  display: inline-flex;\n  max-height: 49%;\n}\n\n.photo-column figure {\n  max-width: 96%;\n  margin: auto;\n}\n\n.photo-column figure img {\n  vertical-align: middle;\n  width: 100%;\n  object-fit: cover;\n}\n\n.photo-column figure img.photo-landscape { max-height: 760px; max-width: 47%; }\n.photo-column figure img.photo-legal-ls { max-height: 680px; }\n.photo-column figure img.photo-tabloid { max-height: 960px; }\n.photo-column figure img.photo-tabloid-ls { max-height: 960px; }\n.photo-column figure img.photo-ledger { max-height: 960px; }\n.photo-column figure img.photo-ledger-ls { max-height: 740px; }\n.photo-column figure img.photo-a4-ls { max-height: 760px; }\n.photo-column figure img.photo-a3 { max-height: 960px; }\n.photo-column figure img.photo-a3-ls { max-height: 960px; }\n\n\n.footer {\n  display: flex;\n  justify-content: space-between;\n  color: #7d7d7d;\n}\n\n.footer-logo {\n  display: flex;\n  align-items: center;\n}\n\n.footer-logo img, .footer-branding img {\n  height: 40px;\n  padding-right: 10px;\n}\n\n.footer-company-info, .footer-meta, .footer-branding {\n  display: flex;\n  align-items: center;\n}\n\n.footer-company {\n  display: flex;\n  align-items: center;\n  color: #41403b;\n}\n\n.footer-meta {\n  text-align: center;\n}\n\n.footer-address, .footer-meta {\n  font-size: 11px;\n}\n\n.page-info {\n  width: 300px;\n  float: right;\n  text-align: right;\n  margin-top: 15px;\n}\n\n.title {\n  padding: 15px 0px 0px 0px;\n  page-break-inside: avoid;\n  display: flex;\n  padding-right: 5px;\n}\n\n.title hr {\n  margin: 6px 0px 12px;\n  display: block;\n  height: 1px;\n  border: 0;\n  border-top: 1px solid #ddd;\n  padding: 0;\n}\n\n.title h1 {\n  color: #41403b;\n  font-size: 3em;\n  font-weight: 300;\n}\n\n.title h2 {\n  font-weight: 400;\n  color: #7d7d7d;\n  font-size: 14px;\n}\n\n.title-label {\n  flex: 4 1;\n}\n\n.title-image  {\n  flex: 1 1;\n  text-align: right;\n}\n\n.title-image img {\n  width: 100px;\n  border-radius: 5px;\n  border: 10px solid #fff;\n  box-shadow: 0 0 3px #ccc;\n}\n\n.meta-wrapper {\n  display: flex;\n  align-items: flex-start;\n}\n\n.meta-map {\n  margin-top: 20px;\n}\n\n.meta-map img {\n  width: auto;\n  height: 400px;\n}\n\n.meta-map img.ls-nometa {\n  width: 100%;\n  height: auto;\n}\n\n.meta-map img.letter-ls { height: 440px; }\n.meta-map img.legal-ls { height: 440px; }\n.meta-map img.tabloid-ls { height: 440px; }\n.meta-map img.ledger-pt { height: 440px; }\n.meta-map img.a4-ls { height: 440px; }\n\n.meta-map .field {\n  border: none;\n  padding-top: 0;\n}\n\n.meta-fields-container {\n  display: flex;\n  flex-direction: column;\n  flex: 1;\n  margin-left: 20px;\n}\n\n.meta-fields {\n  flex: 1;\n  margin-bottom: 8px;\n  padding-bottom: 8px;\n  border-bottom: 1px solid #f4f4f4;\n}\n\n.meta-fields:last-of-type {\n  border-bottom: none;\n}\n\n.header {\n  display: flex;\n  justify-content: space-between;\n  margin-top: 15px;\n  color: #7d7d7d;\n}\n\n.header-title, .header-record {\n  align-items: center;\n  font-style: italic;\n}\n",
        "script": "DATA.config.advanced = true;\n\nconst REPORT_CONFIG = {\n  'hidden_fields': [],\n  'field.empty_value': '',\n  'header.enabled': true,\n  'header.form.name': true,\n  'header.record.id': true,\n  'footer.enabled': true,\n  'footer.timestamp': true,\n  'footer.organization_image': true,\n  'footer.organization_info': true,\n  'footer.page_number': true,\n  'cover_page.enabled': true,\n  'cover_page.form.name': true,\n  'cover_page.form.description': true,\n  'cover_page.form.image': true,\n  'cover_page.title': true,\n  'cover_page.timestamp': true,\n  'cover_page.image.enabled': true,\n  'cover_page.image.caption': true,\n  'cover_page.map.enabled': true,\n  'cover_page.map.repeatables': true,\n  'cover_page.map.type': 'roadmap',\n  'cover_page.map.size': '360x400',\n  'cover_page.metadata.enabled': true,\n  'cover_page.metadata.created': true,\n  'cover_page.metadata.updated': true,\n  'cover_page.metadata.status': true,\n  'cover_page.metadata.location': true,\n  'cover_page.metadata.project': true,\n  'cover_page.metadata.assigned': true\n};\n\nif (DATA.config.advanced) {\n  DATA.config = { ...DATA.config, ...REPORT_CONFIG };\n}\n\nconst SETTING = (setting, defaultValue) => {\n  return DATA.config[setting] != null ? DATA.config[setting] : defaultValue;\n};\n\nconst { landscape, size } = DATA.config;\n\nconst IMAGE_SIZE = () => {\n  const data = landscape ? '-ls' : '';\n  const default_class = landscape ? 'photo-landscape' : '';\n\n  switch (size) {\n    case 'Legal':\n      return `photo-legal${data}`;\n    case 'Tabloid':\n      return `photo-tabloid${data}`;\n    case 'Ledger':\n      return `photo-ledger${data}`;\n    case 'A4':\n      return `photo-a4${data}`;\n    case 'A3':\n      return `photo-a3${data}`;\n    default:\n      return default_class;\n  }\n};\n\nconst MAP_OPTIONS = (mapSize) => {\n  const options = {\n    maptype: SETTING('cover_page.map.type'),\n    size: mapSize\n  };\n\n  return options;\n};\n\nconst SET_MAP_CLASS = () => {\n  if (!SETTING('cover_page.metadata.enabled')) {\n    return 'ls-nometa';\n  }\n\n  switch (size) {\n    case 'Legal':\n      return landscape ? 'legal-ls' : '';\n    case 'Tabloid':\n      return landscape ? 'tabloid-ls' : '';\n    case 'A4':\n      return landscape ? 'a4-ls' : '';\n    case 'Letter':\n      return landscape ? 'letter-ls' : '';\n    case 'Ledger':\n      return landscape ? '' : 'ledger-pt';\n    default:\n      return '';\n  }\n};\n\nconst SET_MAP_OPTIONS = () => {\n  const ledger_options = landscape ? MAP_OPTIONS('400x400') : MAP_OPTIONS('600x400');\n\n  if (!SETTING('cover_page.metadata.enabled')) {\n    return MAP_OPTIONS('800x400');\n  }\n\n  if (size === 'Ledger') {\n    return ledger_options;\n  } else if (!landscape) {\n    return MAP_OPTIONS('360x400');\n  }\n\n  switch (size) {\n    case 'Letter':\n    case 'A4':\n      return MAP_OPTIONS('400x400');\n    case 'Legal':\n    case 'Tabloid':\n      return MAP_OPTIONS('600x400');\n    case 'A3':\n      return MAP_OPTIONS('800x400');\n    default:\n      return MAP_OPTIONS('360x400');\n  }\n};\n\nfunction initialize() {\n  // validate parameters and initialize report data\n}\n\nfunction formatValue(element, value, { defaultFormatter }) {\n  // special case logic here\n  return defaultFormatter(element, value);\n}",
        "config": {
            "size": "Letter",
            "landscape": false,
            "margin_top": 0.5,
            "margin_right": 0.5,
            "margin_bottom": 0.5,
            "margin_left": 0.5,
            "output": "pdf",
            "hidden_fields": [],
            "field.empty_value": "",
            "header.enabled": true,
            "header.form.name": true,
            "header.record.id": true,
            "footer.enabled": true,
            "footer.timestamp": true,
            "footer.organization_image": true,
            "footer.organization_info": true,
            "footer.page_number": true,
            "cover_page.enabled": true,
            "cover_page.form.name": true,
            "cover_page.form.description": true,
            "cover_page.form.image": true,
            "cover_page.title": true,
            "cover_page.timestamp": true,
            "cover_page.image.enabled": true,
            "cover_page.image.caption": true,
            "cover_page.map.enabled": true,
            "cover_page.map.repeatables": true,
            "cover_page.map.type": "roadmap",
            "cover_page.map.size": "360x400",
            "cover_page.metadata.enabled": true,
            "cover_page.metadata.created": true,
            "cover_page.metadata.updated": true,
            "cover_page.metadata.status": true,
            "cover_page.metadata.location": true,
            "cover_page.metadata.project": true,
            "cover_page.metadata.assigned": true,
            "parameters": [
                {
                    "name": "record_id",
                    "label": "Record",
                    "type": "record_id",
                    "required": true,
                    "multiple": false,
                    "options": null,
                    "query": null,
                    "default": []
                }
            ]
        },
        "status": "active",
        "type": "advanced",
        "id": "bec301b5-22f3-4009-93f5-6df3ef4c44af",
        "created_at": "2024-07-11T14:24:14Z",
        "updated_at": "2024-07-11T14:24:14Z",
        "created_by": "Vince Lauffer",
        "created_by_id": "9d64eea9-3d7d-427b-8a12-32458d6b5b2a",
        "updated_by": "Vince Lauffer",
        "updated_by_id": "9d64eea9-3d7d-427b-8a12-32458d6b5b2a"
    }
}