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
Property | Type | Required | Readonly | Description |
---|---|---|---|---|
name | string | yes | no | The name of the report template. |
description | string | no | no | A brief description of the report template. |
body | string | yes | no | The body content of the report template. |
header | string | yes | no | The header content of the report template. |
filename_pattern | string | no | no | The pattern for the report's filename. |
footer | string | yes | no | The footer content of the report template. |
styles | string | yes | no | The styles applied to the report template. |
script | string | yes | no | The script used in the report template. |
status | string | yes | no | The status of the report template (e.g., active). |
type | string | yes | no | The type of the report template (e.g., advanced). |
id | string | no | yes | The unique identifier for the report template. |
created_at | string | no | yes | Timestamp when the report template was created. |
updated_at | string | no | yes | Timestamp when the report template was last updated. |
created_by | string | no | yes | The name of the user who created the report template. |
created_by_id | string | no | yes | The ID of the user who created the report template. |
updated_by | string | no | yes | The name of the user who last updated the report template. |
updated_by_id | string | no | yes | The ID of the user who last updated the report template. |
Config Properties
Property | Type | Required | Readonly | Description |
---|---|---|---|---|
size | string | yes | no | The size of the report (e.g., Letter). |
landscape | boolean | yes | no | Whether the report is in landscape orientation. |
margin_top | number | yes | no | The top margin of the report. |
margin_right | number | yes | no | The right margin of the report. |
margin_bottom | number | yes | no | The bottom margin of the report. |
margin_left | number | yes | no | The left margin of the report. |
output | string | yes | no | The output format of the report (e.g., pdf). |
hidden_fields | array | no | no | The list of fields to be hidden in the report. |
field.empty_value | string | no | no | The value to display for empty fields. |
header.enabled | boolean | yes | no | Whether the header is enabled. |
header.form.name | boolean | yes | no | Whether the form name is included in the header. |
header.record.id | boolean | yes | no | Whether the record ID is included in the header. |
footer.enabled | boolean | yes | no | Whether the footer is enabled. |
footer.timestamp | boolean | yes | no | Whether the timestamp is included in the footer. |
footer.organization_image | boolean | yes | no | Whether the organization image is included in the footer. |
footer.organization_info | boolean | yes | no | Whether the organization info is included in the footer. |
footer.page_number | boolean | yes | no | Whether the page number is included in the footer. |
cover_page.enabled | boolean | yes | no | Whether the cover page is enabled. |
cover_page.form.name | boolean | yes | no | Whether the form name is included on the cover page. |
cover_page.form.description | boolean | yes | no | Whether the form description is included on the cover page. |
cover_page.form.image | boolean | yes | no | Whether the form image is included on the cover page. |
cover_page.title | boolean | yes | no | Whether the cover page title is included. |
cover_page.timestamp | boolean | yes | no | Whether the timestamp is included on the cover page. |
cover_page.image.enabled | boolean | yes | no | Whether images are enabled on the cover page. |
cover_page.image.caption | boolean | yes | no | Whether captions are included for images on the cover page. |
cover_page.map.enabled | boolean | yes | no | Whether maps are enabled on the cover page. |
cover_page.map.repeatables | boolean | yes | no | Whether repeatable items are included on the cover page map. |
cover_page.map.type | string | yes | no | The type of map to use on the cover page (e.g., roadmap). |
cover_page.map.size | string | yes | no | The size of the map on the cover page. |
cover_page.metadata.enabled | boolean | yes | no | Whether metadata is enabled on the cover page. |
cover_page.metadata.created | boolean | yes | no | Whether the creation metadata is included on the cover page. |
cover_page.metadata.updated | boolean | yes | no | Whether the update metadata is included on the cover page. |
cover_page.metadata.status | boolean | yes | no | Whether the status metadata is included on the cover page. |
cover_page.metadata.location | boolean | yes | no | Whether the location metadata is included on the cover page. |
cover_page.metadata.project | boolean | yes | no | Whether the project metadata is included on the cover page. |
cover_page.metadata.assigned | boolean | yes | no | Whether the assigned metadata is included on the cover page. |
parameters | array | yes | no | The 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"
}
}