@verdocs/web-sdk 5.0.17 → 5.0.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/dist/cjs/verdocs-field-attachment_13.cjs.entry.js +4 -5
  2. package/dist/cjs/verdocs-field-attachment_13.cjs.entry.js.map +1 -1
  3. package/dist/collection/components/fields/verdocs-field-date/verdocs-field-date.js +3 -1
  4. package/dist/collection/components/fields/verdocs-field-date/verdocs-field-date.js.map +1 -1
  5. package/dist/collection/components/fields/verdocs-field-signature/verdocs-field-signature.js +0 -1
  6. package/dist/collection/components/fields/verdocs-field-signature/verdocs-field-signature.js.map +1 -1
  7. package/dist/collection/components/fields/verdocs-field-textbox/verdocs-field-textbox.js +1 -3
  8. package/dist/collection/components/fields/verdocs-field-textbox/verdocs-field-textbox.js.map +1 -1
  9. package/dist/components/{p-c76fab71.js → p-13260b9f.js} +4 -4
  10. package/dist/components/{p-c76fab71.js.map → p-13260b9f.js.map} +1 -1
  11. package/dist/components/{p-c1159428.js → p-43fa069d.js} +2 -4
  12. package/dist/components/p-43fa069d.js.map +1 -0
  13. package/dist/components/{p-a55f08ad.js → p-8a76ec8a.js} +5 -5
  14. package/dist/components/{p-a55f08ad.js.map → p-8a76ec8a.js.map} +1 -1
  15. package/dist/components/{p-0ed0ac8b.js → p-aa59fa42.js} +5 -5
  16. package/dist/components/{p-0ed0ac8b.js.map → p-aa59fa42.js.map} +1 -1
  17. package/dist/components/{p-5e378f0e.js → p-bcc8771f.js} +1 -2
  18. package/dist/components/p-bcc8771f.js.map +1 -0
  19. package/dist/components/{p-176a07b2.js → p-c9bed8f7.js} +4 -2
  20. package/dist/components/{p-176a07b2.js.map → p-c9bed8f7.js.map} +1 -1
  21. package/dist/components/verdocs-build.js +6 -6
  22. package/dist/components/verdocs-field-date.js +1 -1
  23. package/dist/components/verdocs-field-signature.js +1 -1
  24. package/dist/components/verdocs-field-textbox.js +1 -1
  25. package/dist/components/verdocs-preview.js +1 -1
  26. package/dist/components/verdocs-template-document-page.js +1 -1
  27. package/dist/components/verdocs-template-fields.js +1 -1
  28. package/dist/esm/verdocs-field-attachment_13.entry.js +4 -5
  29. package/dist/esm/verdocs-field-attachment_13.entry.js.map +1 -1
  30. package/dist/esm-es5/verdocs-field-attachment_13.entry.js +1 -1
  31. package/dist/esm-es5/verdocs-field-attachment_13.entry.js.map +1 -1
  32. package/dist/types/components/fields/verdocs-field-signature/verdocs-field-signature.d.ts +2 -2
  33. package/dist/verdocs-web-sdk/{p-277a93d5.entry.js → p-27416916.entry.js} +2 -2
  34. package/dist/verdocs-web-sdk/p-27416916.entry.js.map +1 -0
  35. package/dist/verdocs-web-sdk/{p-8bdd951b.system.entry.js → p-37fa9d00.system.entry.js} +2 -2
  36. package/dist/verdocs-web-sdk/p-37fa9d00.system.entry.js.map +1 -0
  37. package/dist/verdocs-web-sdk/p-e2b70dfb.system.js +1 -1
  38. package/dist/verdocs-web-sdk/verdocs-web-sdk.esm.js +1 -1
  39. package/package.json +1 -1
  40. package/dist/components/p-5e378f0e.js.map +0 -1
  41. package/dist/components/p-c1159428.js.map +0 -1
  42. package/dist/custom-elements.json +0 -2156
  43. package/dist/verdocs-web-sdk/p-277a93d5.entry.js.map +0 -1
  44. package/dist/verdocs-web-sdk/p-8bdd951b.system.entry.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"names":["verdocsFieldAttachmentCss","VerdocsFieldAttachmentStyle0","PaperclipIcon","AttachedIcon","VerdocsFieldAttachment","this","handleUploadNext","e","console","log","dialogOpen","selectedFile","detail","_a","attached","emit","handleUploadRemove","preventDefault","stopPropagation","deleted","fieldName","fieldname","VerdocsEndpoint","getDefault","focusField","focused","setTimeout","showSettingsPanel","settingsPanel","document","getElementById","showPanel","hideSettingsPanel","hidePanel","handleShow","render","source","sourceid","editable","done","disabled","xscale","yscale","index","field","Store","getField","required","value","label","settings","backgroundColor","getRGBA","hasFile","h","Host","class","innerHTML","style","onClick","Fragment","id","transform","Math","floor","SettingsIcon","showingProperties","anchor","onClickAway","templateId","onClose","onDelete","onSettingsChanged","settingsChanged","helpText","existingFile","onNext","onRemove","onExit","verdocsFieldCheckboxCss","VerdocsFieldCheckboxStyle0","VerdocsFieldCheckbox","checked","htmlFor","name","type","t","module","exports","d","i","s","o","Object","defineProperty","enumerable","get","prototype","hasOwnProperty","call","default","R","days","months","years","day","month","year","eventChangeViewDate","eventChangeCurrentView","eventChangeFocusDate","eventChangeSelectedDate","eventChangeTime","eventChangeLastSelectedDate","actionSelectDate","actionUnselectDate","cssClassWeekend","classes","inline","locale","daysShort","daysMin","monthsShort","today","clear","dateFormat","timeFormat","firstDay","startDate","Date","weekends","altField","altFieldDateFormat","toggleSelected","keyboardNav","selectedDates","container","isMobile","visible","position","offset","view","minView","showOtherMonths","selectOtherMonths","moveToOtherMonthsOnSelect","showOtherYears","selectOtherYears","moveToOtherYearsOnSelect","minDate","maxDate","disableNavWhenOutOfRange","multipleDates","multipleDatesSeparator","range","dynamicRange","buttons","monthsField","showEvent","autoClose","fixedHeight","prevHtml","nextHtml","navTitles","timepicker","onlyTimepicker","dateTimeSeparator","minHours","maxHours","minMinutes","maxMinutes","hoursStep","minutesStep","onSelect","onChangeViewDate","onChangeView","onRenderCell","onShow","onHide","onClickDayName","a","arguments","length","querySelector","n","tagName","className","innerHtml","attrs","createElement","classList","add","split","r","entries","setAttribute","getFullYear","getMonth","getDate","getHours","hours","dayPeriod","l","fullMonth","date","fullDate","getDay","fullHours","hours12","fullHours12","minutes","getMinutes","fullMinutes","c","u","Array","forEach","push","join","p","m","g","getTime","v","setHours","D","addEventListener","y","DocumentFragment","matches","parentNode","f","w","filter","toString","isArray","b","test","isNaN","k","RegExp","$","Symbol","toPrimitive","TypeError","String","configurable","writable","C","constructor","dp","opts","body","$cell","remove","selected","isDisabled","_handleSelectedStatus","_handleRangeStatus","removeFocus","focus","_getHtml","_handleClasses","singleType","slice","customData","init","cellType","datepicker","_createElement","_bindDatepickerEvents","disableDate","on","onChangeSelectedDate","onChangeFocusDate","unbindDatepickerEvents","off","adpCell","_getClassName","isDateDisabled","_isOutOfMinMaxRange","isWeekend","isOtherMonth","isOtherDecade","html","destroy","focusDate","rangeDateTo","rangeDateFrom","_checkIfDateIsSelected","select","removeSelect","_handleInitialFocusStatus","hasSelectedDates","_","M","S","T","target","closest","isMinViewReached","down","_handleAlreadySelectedDates","selectDate","getAttribute","dayIndex","Number","hide","show","setFocusDate","handleClick","handleDayNameClick","pressed","rangeFromFocused","rangeToFocused","setMinutes","replaceDate","isVisible","currentView","destroyCells","_generateCells","cells","$cells","appendChild","$el","_buildBaseHtml","renderDayNames","_bindEvents","onMouseOverCell","onMouseOutCell","onClickBody","onMouseDown","onMouseMove","window","onMouseUp","onChangeCurrentView","$names","_getDayNamesHtml","_generateCell","getDatesFunction","getDaysDates","viewDate","getMonthsDates","parsedViewDate","getYearsDates","F","V","dataset","action","_resetNavStatus","handleNavStatus","isFinalView","up","$prev","$next","$title","_getTitle","_defineDOM","onClickNav","onClickNavTitle","isNavIsFunction","renderDelay","formatDate","_disableNav","querySelectorAll","keys","find","x","content","setViewDate","H","removeChild","clearHtml","generateButtons","createButton","attachEventToButton","E","L","timepickerIsActive","updateTime","setMinMaxTime","setCurrentTime","addTimeToDate","setTime","updateText","trigger","$minutesText","$hoursText","toggle","toggleTimepickerIsActive","match","ampm","lastSelectedDate","buildHtml","defineDOM","bindDatepickerEvents","bindDOMEvents","onChangeLastSelectedDate","navigator","userAgent","$ranges","onChangeInputRange","onMouseEnterLeave","onFocus","onBlur","displayHours","$hours","$minutes","$ampm","setMinMaxTimeFromOptions","setMinTimeFromMinDate","setMaxTimeFromMaxDate","updateSliders","min","max","_hours","O","A","Set","Map","hotKeys","getInitialFocusDate","getClampedDate","viewDateTransition","pressedKeys","size","has","every","key","which","registerKey","isHotKeyPressed","handleHotKey","isArrow","focusNextCell","removeKey","bindKeyboardEvents","onKeyDown","onKeyUp","removeEventListener","delete","N","__events","removeAllEvents","I","P","j","B","buildGlobalContainer","hideAnimation","_destroyComponents","$container","$datepicker","customHide","$target","$pointer","isViewChange","_finishHide","getBoundingClientRect","offsetParent","scrollY","scrollX","cssText","top","offsetTop","left","offsetLeft","width","height","offsetHeight","$altField","_getInputValue","map","some","_cancelScheduledCall","_onTransitionEnd","once","decade","curDecade","viewIndexes","includes","elIsInput","setPosition","views","shouldUpdateDOM","$content","silent","isDestroyed","_onFocus","_onBlur","_onResize","_removeMobileAttributes","nav","$customContainer","treatAsInline","_createMinMaxDates","_limitViewDateByMaxMinDates","_handleLocale","setCurrentView","_setInputValue","$timepicker","_addTimepicker","_addButtons","$buttons","_createMobileOverlay","_addMobileAttributes","_showMobileOverlay","update","disabledDates","getCell","currentViewSingular","_triggerOnSelect","isOtherYear","inFocus","nodeName","inited","initialReadonly","contains","defaultGlobalContainerId","_bindSubEvents","_createComponents","_setPositionClasses","$nav","_onClickOverlay","removeAttribute","_onChangeSelectedDate","_onChangeFocusedDate","_onChangeTime","insertBefore","nextSibling","JSON","parse","stringify","_onMouseDown","_onMouseUp","replacer","mm","hh","HH","aa","AA","toUpperCase","EEEE","dd","MM","MMM","MMMM","yy","yyyy","yyyy1","yyyy2","_handleUpDownActions","onBeforeSelect","Promise","resolve","_updateLastSelectedDate","unselectDate","splice","indexOf","_scheduleCallAfterTransition","_hasTransition","blur","formattedDate","Boolean","viewIndex","getComputedStyle","getPropertyValue","reduce","parseFloat","replace","K","assign","en","default_1","_default","verdocsFieldDateCss","VerdocsFieldDateStyle0","VerdocsFieldDate","picker","random","substring","componentDidLoad","containerId","AirDatepicker","localeEn","event","CustomEvent","hostEl","dispatchEvent","placeholder","formattedValue","format","FORMAT_DATE","verdocsFieldDropdownCss","VerdocsFieldDropdownStyle0","VerdocsFieldDropdown","selectEl","showPicker","handleChange","fieldChange","options","onChange","ref","el","option","verdocsFieldInitialCss","VerdocsFieldInitialStyle0","VerdocsFieldInitial","hideDialog","dialog","handleAdopt","tempInitials","initials","append","base64","src","alt","verdocsFieldRadioCss","VerdocsFieldRadioStyle0","RadioIconUnselected","RadioIconSelected","VerdocsFieldRadio","group","maxWidth","verdocsFieldSignatureCss","VerdocsFieldSignatureStyle0","VerdocsFieldSignature","tempSignature","verdocsFieldTextareaCss","VerdocsFieldTextareaStyle0","VerdocsFieldTextarea","inputEl","componentDidRender","interact","dynamicDrop","resizable","edges","bottom","right","listeners","start","handleResizeStart","bind","move","handleResize","end","handleResizeEnd","rect","deltaRect","translateX","translateY","round","updateField","endpoint","then","catch","verdocsFieldTextboxCss","VerdocsFieldTextboxStyle0","VerdocsFieldTextbox","modifiers","restrictSize","dX","dY","currentLeft","currentBottom","multiline","async","updatedField","template","getTemplate","newTemplate","fieldIndex","fields","findIndex","updateTemplate","maxlength","verdocsFieldTimestampCss","VerdocsFieldTimestampStyle0","VerdocsFieldTimestamp","formatted","toISOString","FORMAT_TIMESTAMP","verdocsInitialDialogCss","VerdocsInitialDialogStyle0","VerdocsInitialDialog","componentWillLoad","enteredInitials","ds","FontFace","load","font","fonts","fontLoaded","redrawSignature","componentDidUpdate","canvasElement","canvasWidth","context","getContext","clearRect","fontSize","measureText","textAlign","textBaseline","fillText","handleNameChange","handleCancel","exit","data","toDataURL","next","onInput","display","variant","verdocsSignatureDialogCss","VerdocsSignatureDialogStyle0","VerdocsSignatureDialog","enteredName","verdocsUploadDialogCss","VerdocsUploadDialogStyle0","TrashIcon","VerdocsUploadDialog","handleDismiss","handleDone","selectedFiles","handleDragOver","draggingOver","handleDragLeave","handleDrop","handleSetSelected","from","dataTransfer","files","handleRemoveAttachment","newFiles","errorMessage","totalSize","acc","file","maxSize","handleDeleteAttachment","confirmDelete","handleSelectFile","fileInput","click","handleFileChange","marginTop","onDragOver","onDragLeave","onDrop","accept","heading","message","showCancel"],"sources":["src/components/fields/verdocs-field-attachment/verdocs-field-attachment.scss?tag=verdocs-field-attachment","src/components/fields/verdocs-field-attachment/verdocs-field-attachment.tsx","src/components/fields/verdocs-field-checkbox/verdocs-field-checkbox.scss?tag=verdocs-field-checkbox","src/components/fields/verdocs-field-checkbox/verdocs-field-checkbox.tsx","node_modules/air-datepicker/air-datepicker.js","node_modules/air-datepicker/locale/en.js","src/components/fields/verdocs-field-date/verdocs-field-date.scss?tag=verdocs-field-date","src/components/fields/verdocs-field-date/verdocs-field-date.tsx","src/components/fields/verdocs-field-dropdown/verdocs-field-dropdown.scss?tag=verdocs-field-dropdown","src/components/fields/verdocs-field-dropdown/verdocs-field-dropdown.tsx","src/components/fields/verdocs-field-initial/verdocs-field-initial.scss?tag=verdocs-field-initial","src/components/fields/verdocs-field-initial/verdocs-field-initial.tsx","src/components/fields/verdocs-field-radio/verdocs-field-radio.scss?tag=verdocs-field-radio","src/components/fields/verdocs-field-radio/verdocs-field-radio.tsx","src/components/fields/verdocs-field-signature/verdocs-field-signature.scss?tag=verdocs-field-signature","src/components/fields/verdocs-field-signature/verdocs-field-signature.tsx","src/components/fields/verdocs-field-textarea/verdocs-field-textarea.scss?tag=verdocs-field-textarea","src/components/fields/verdocs-field-textarea/verdocs-field-textarea.tsx","src/components/fields/verdocs-field-textbox/verdocs-field-textbox.scss?tag=verdocs-field-textbox","src/components/fields/verdocs-field-textbox/verdocs-field-textbox.tsx","src/components/fields/verdocs-field-timestamp/verdocs-field-timestamp.scss?tag=verdocs-field-timestamp","src/components/fields/verdocs-field-timestamp/verdocs-field-timestamp.tsx","src/components/dialogs/verdocs-initial-dialog/verdocs-initial-dialog.scss?tag=verdocs-initial-dialog","src/components/dialogs/verdocs-initial-dialog/verdocs-initial-dialog.tsx","src/components/dialogs/verdocs-signature-dialog/verdocs-signature-dialog.scss?tag=verdocs-signature-dialog","src/components/dialogs/verdocs-signature-dialog/verdocs-signature-dialog.tsx","src/components/dialogs/verdocs-upload-dialog/verdocs-upload-dialog.scss?tag=verdocs-upload-dialog","src/components/dialogs/verdocs-upload-dialog/verdocs-upload-dialog.tsx"],"sourcesContent":["@import '../../../theme.scss';\n\nverdocs-field-attachment {\n font-family: $verdocs-primary-font;\n box-sizing: border-box;\n width: 24px;\n height: 24px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n svg {\n width: 16px;\n height: 16px;\n }\n\n &.disabled svg {\n opacity: 0.5;\n\n span {\n cursor: inherit;\n }\n }\n\n .attach {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n width: 24px;\n height: 24px;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n &.required {\n .attach {\n border: 1px solid $verdocs-red-1;\n }\n }\n\n verdocs-button-panel {\n top: 1px;\n left: -19px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, VerdocsEndpoint, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Method, Event, EventEmitter, State, Fragment, Element} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\nexport interface ISelectedFile {\n lastModified: number;\n size: number;\n type: string;\n name: string;\n data: string;\n}\n\nconst PaperclipIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\"><path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M15.172 7l-6.586 6.586a2 2 0 102.828 2.828l6.414-6.586a4 4 0 00-5.656-5.656l-6.415 6.585a6 6 0 108.486 8.486L20.5 13\" /></svg>`;\n\nconst AttachedIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"#339933\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"lucide lucide-file-check\"><path d=\"M15 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7Z\"/><path d=\"M14 2v4a2 2 0 0 0 2 2h4\"/><path d=\"m9 15 2 2 4-4\"/></svg>`;\n\n/**\n * Displays an attachment field.\n */\n@Component({\n tag: 'verdocs-field-attachment',\n styleUrl: 'verdocs-field-attachment.scss',\n shadow: false,\n})\nexport class VerdocsFieldAttachment {\n @Element() el: HTMLElement;\n\n /**\n * The endpoint to use to communicate with Verdocs. If not set, the default endpoint will be used.\n * This component self-manages its resize (width) behavior when in edit-template mode, and uses\n * this endpoint to save changes.\n */\n @Prop() endpoint: VerdocsEndpoint = VerdocsEndpoint.getDefault();\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when a file is attached by the signer.\n */\n @Event({composed: true}) attached: EventEmitter<ISelectedFile>;\n\n /**\n * Event fired when the field is deleted. Note that this is for the FIELD (e.g. in\n * Build) not for any attachments (during signing).\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() dialogOpen?: boolean = false;\n @State() selectedFile?: ISelectedFile | null = null;\n @State() focused = false;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n this.dialogOpen = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n handleShow() {\n this.dialogOpen = true;\n }\n\n handleUploadNext = (e: any) => {\n console.log('Upload next', e);\n this.dialogOpen = false;\n this.selectedFile = e.detail[0];\n this.attached?.emit(e.detail[0]);\n };\n\n handleUploadRemove = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n this.dialogOpen = false;\n this.selectedFile = null;\n this.deleted?.emit({fieldName: this.fieldname});\n };\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, value = '', label = '', settings = {}} = field || {};\n const backgroundColor = getRGBA(index);\n\n const hasFile = value || !!this.selectedFile;\n\n if (done) {\n return (\n <Host class={{done}}>\n <div class=\"attach\" innerHTML={hasFile ? AttachedIcon : PaperclipIcon} />\n </Host>\n );\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <div class=\"attach\" innerHTML={hasFile ? AttachedIcon : PaperclipIcon} onClick={() => !disabled && this.handleShow()} />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Attachments allow the user to attach their own documents (e.g. resumes or disclosures) to a signing flow.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n\n {this.dialogOpen && (\n <verdocs-portal>\n <verdocs-upload-dialog\n existingFile={settings}\n onNext={e => this.handleUploadNext(e)}\n onRemove={e => this.handleUploadRemove(e)}\n onExit={() => (this.dialogOpen = false)}\n />\n </verdocs-portal>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\n// See https://www.kallmanation.com/styling-a-checkbox-with-only-css\nverdocs-field-checkbox {\n padding: 0;\n width: 16px;\n height: 16px;\n display: block;\n scroll-margin: 20px 0;\n box-sizing: border-box;\n transform-origin: bottom left;\n font-family: $verdocs-primary-font;\n\n // To avoid conflicting with the use of a label for the checkbox itself\n div.label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n label {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 14px;\n height: 14px;\n display: block;\n box-sizing: border-box;\n }\n\n &.disabled label {\n opacity: 0.5;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n label > input[type='checkbox'] {\n display: none;\n }\n\n label > input[type='checkbox'] + *::before {\n margin: 0;\n content: '';\n width: 12px;\n height: 12px;\n display: block;\n line-height: 12px;\n border-radius: 2px;\n box-sizing: border-box;\n border: 1px solid $verdocs-grey-2;\n }\n\n label > input[type='checkbox']:checked + * {\n color: $verdocs-green;\n }\n\n label > input[type='checkbox']:checked + *::before {\n content: '✓';\n color: white;\n font-size: 12px;\n text-align: center;\n background: $verdocs-green;\n border-color: $verdocs-green;\n }\n\n &.required {\n border: 1px solid $verdocs-red-1;\n }\n\n &.hide {\n display: none;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n display: block;\n margin-left: -20px;\n margin-top: -17px;\n transform: scale(0.7);\n }\n\n .settings-icon {\n position: absolute;\n top: -5px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, Fragment, h, Host, Method, Prop, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a checkbox.\n */\n@Component({\n tag: 'verdocs-field-checkbox',\n styleUrl: 'verdocs-field-checkbox.scss',\n shadow: false,\n})\nexport class VerdocsFieldCheckbox {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method()\n async focusField() {\n // We don't have a visible input that we can actually focus on, so we fake it\n this.focused = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, label = '', value = false} = field || {};\n const backgroundColor = getRGBA(index);\n\n const checked = value === 'true';\n\n if (done) {\n return <Host class={{done}}>{checked ? '✓' : '☐'}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <div class=\"label\">{label}</div>}\n\n <label htmlFor={fieldname}>\n <input id={fieldname} name={fieldname} type=\"checkbox\" checked={checked} disabled={disabled} required={required} />\n <span />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${field.name}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={field.name}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Check boxes allow the user to select one or more (non-exclusive) options.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </label>\n </Host>\n );\n }\n}\n","!function(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define([],t):\"object\"==typeof exports?exports.AirDatepicker=t():e.AirDatepicker=t()}(this,(function(){return function(){\"use strict\";var e={d:function(t,i){for(var s in i)e.o(i,s)&&!e.o(t,s)&&Object.defineProperty(t,s,{enumerable:!0,get:i[s]})},o:function(e,t){return Object.prototype.hasOwnProperty.call(e,t)}},t={};e.d(t,{default:function(){return R}});var i={days:\"days\",months:\"months\",years:\"years\",day:\"day\",month:\"month\",year:\"year\",eventChangeViewDate:\"changeViewDate\",eventChangeCurrentView:\"changeCurrentView\",eventChangeFocusDate:\"changeFocusDate\",eventChangeSelectedDate:\"changeSelectedDate\",eventChangeTime:\"changeTime\",eventChangeLastSelectedDate:\"changeLastSelectedDate\",actionSelectDate:\"selectDate\",actionUnselectDate:\"unselectDate\",cssClassWeekend:\"-weekend-\"},s={classes:\"\",inline:!1,locale:{days:[\"Воскресенье\",\"Понедельник\",\"Вторник\",\"Среда\",\"Четверг\",\"Пятница\",\"Суббота\"],daysShort:[\"Вос\",\"Пон\",\"Вто\",\"Сре\",\"Чет\",\"Пят\",\"Суб\"],daysMin:[\"Вс\",\"Пн\",\"Вт\",\"Ср\",\"Чт\",\"Пт\",\"Сб\"],months:[\"Январь\",\"Февраль\",\"Март\",\"Апрель\",\"Май\",\"Июнь\",\"Июль\",\"Август\",\"Сентябрь\",\"Октябрь\",\"Ноябрь\",\"Декабрь\"],monthsShort:[\"Янв\",\"Фев\",\"Мар\",\"Апр\",\"Май\",\"Июн\",\"Июл\",\"Авг\",\"Сен\",\"Окт\",\"Ноя\",\"Дек\"],today:\"Сегодня\",clear:\"Очистить\",dateFormat:\"dd.MM.yyyy\",timeFormat:\"HH:mm\",firstDay:1},startDate:new Date,firstDay:\"\",weekends:[6,0],dateFormat:\"\",altField:\"\",altFieldDateFormat:\"T\",toggleSelected:!0,keyboardNav:!0,selectedDates:!1,container:\"\",isMobile:!1,visible:!1,position:\"bottom left\",offset:12,view:i.days,minView:i.days,showOtherMonths:!0,selectOtherMonths:!0,moveToOtherMonthsOnSelect:!0,showOtherYears:!0,selectOtherYears:!0,moveToOtherYearsOnSelect:!0,minDate:\"\",maxDate:\"\",disableNavWhenOutOfRange:!0,multipleDates:!1,multipleDatesSeparator:\", \",range:!1,dynamicRange:!0,buttons:!1,monthsField:\"monthsShort\",showEvent:\"focus\",autoClose:!1,fixedHeight:!1,prevHtml:'<svg><path d=\"M 17,12 l -5,5 l 5,5\"></path></svg>',nextHtml:'<svg><path d=\"M 14,12 l 5,5 l -5,5\"></path></svg>',navTitles:{days:\"MMMM, <i>yyyy</i>\",months:\"yyyy\",years:\"yyyy1 - yyyy2\"},timepicker:!1,onlyTimepicker:!1,dateTimeSeparator:\" \",timeFormat:\"\",minHours:0,maxHours:24,minMinutes:0,maxMinutes:59,hoursStep:1,minutesStep:1,onSelect:!1,onChangeViewDate:!1,onChangeView:!1,onRenderCell:!1,onShow:!1,onHide:!1,onClickDayName:!1};function a(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:document;return\"string\"==typeof e?t.querySelector(e):e}function n(){let{tagName:e=\"div\",className:t=\"\",innerHtml:i=\"\",id:s=\"\",attrs:a={}}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=document.createElement(e);return t&&n.classList.add(...t.split(\" \")),s&&(n.id=s),i&&(n.innerHTML=i),a&&r(n,a),n}function r(e,t){for(let[i,s]of Object.entries(t))void 0!==s&&e.setAttribute(i,s);return e}function o(e){return new Date(e.getFullYear(),e.getMonth()+1,0).getDate()}function h(e){let t=e.getHours(),{hours:i,dayPeriod:s}=l(t);return{year:e.getFullYear(),month:e.getMonth(),fullMonth:e.getMonth()+1<10?\"0\"+(e.getMonth()+1):e.getMonth()+1,date:e.getDate(),fullDate:e.getDate()<10?\"0\"+e.getDate():e.getDate(),day:e.getDay(),hours:t,fullHours:d(t),hours12:i,dayPeriod:s,fullHours12:d(i),minutes:e.getMinutes(),fullMinutes:e.getMinutes()<10?\"0\"+e.getMinutes():e.getMinutes()}}function l(e){return{dayPeriod:e>11?\"pm\":\"am\",hours:e%12==0?12:e%12}}function d(e){return e<10?\"0\"+e:e}function c(e){let t=10*Math.floor(e.getFullYear()/10);return[t,t+9]}function u(){let e=[];for(var t=arguments.length,i=new Array(t),s=0;s<t;s++)i[s]=arguments[s];return i.forEach((t=>{if(\"object\"==typeof t)for(let i in t)t[i]&&e.push(i);else t&&e.push(t)})),e.join(\" \")}function p(e,t){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:i.days;if(!e||!t)return!1;let a=h(e),n=h(t);return{[i.days]:a.date===n.date&&a.month===n.month&&a.year===n.year,[i.months]:a.month===n.month&&a.year===n.year,[i.years]:a.year===n.year}[s]}function m(e,t,i){let s=g(e,!1).getTime(),a=g(t,!1).getTime();return i?s>=a:s>a}function v(e,t){return!m(e,t,!0)}function g(e){let t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=new Date(e.getTime());return\"boolean\"!=typeof t||t||function(e){e.setHours(0,0,0,0)}(i),i}function D(e,t,i){e.length?e.forEach((e=>{e.addEventListener(t,i)})):e.addEventListener(t,i)}function y(e,t){return!(!e||e===document||e instanceof DocumentFragment)&&(e.matches(t)?e:y(e.parentNode,t))}function f(e,t,i){return e>i?i:e<t?t:e}function w(e){for(var t=arguments.length,i=new Array(t>1?t-1:0),s=1;s<t;s++)i[s-1]=arguments[s];return i.filter((e=>e)).forEach((t=>{for(let[i,s]of Object.entries(t))if(void 0!==s&&\"[object Object]\"===s.toString()){let t=void 0!==e[i]?e[i].toString():void 0,a=s.toString(),n=Array.isArray(s)?[]:{};e[i]=e[i]?t!==a?n:e[i]:n,w(e[i],s)}else e[i]=s})),e}function b(e){let t=e;return e instanceof Date||(\"string\"==typeof e&&/^\\d{4}-\\d{2}-\\d{2}$/.test(e)&&(e+=\"T00:00:00\"),t=new Date(e)),isNaN(t.getTime())&&(console.log(`Unable to convert value \"${e}\" to Date object`),t=!1),t}function k(e){let t=\"\\\\s|\\\\.|-|/|\\\\\\\\|,|\\\\$|\\\\!|\\\\?|:|;\";return new RegExp(\"(^|>|\"+t+\")(\"+e+\")($|<|\"+t+\")\",\"g\")}function $(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}class C{constructor(){let{type:e,date:t,dp:i,opts:s,body:a}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};$(this,\"focus\",(()=>{this.$cell.classList.add(\"-focus-\"),this.focused=!0})),$(this,\"removeFocus\",(()=>{this.$cell.classList.remove(\"-focus-\"),this.focused=!1})),$(this,\"select\",(()=>{this.$cell.classList.add(\"-selected-\"),this.selected=!0})),$(this,\"removeSelect\",(()=>{this.$cell.classList.remove(\"-selected-\",\"-range-from-\",\"-range-to-\"),this.selected=!1})),$(this,\"onChangeSelectedDate\",(()=>{this.isDisabled||(this._handleSelectedStatus(),this.opts.range&&this._handleRangeStatus())})),$(this,\"onChangeFocusDate\",(e=>{if(!e)return void(this.focused&&this.removeFocus());let t=p(e,this.date,this.type);t?this.focus():!t&&this.focused&&this.removeFocus(),this.opts.range&&this._handleRangeStatus()})),$(this,\"render\",(()=>(this.$cell.innerHTML=this._getHtml(),this._handleClasses(),this.$cell))),this.type=e,this.singleType=this.type.slice(0,-1),this.date=t,this.dp=i,this.opts=s,this.body=a,this.customData=!1,this.init()}init(){var e;let{onRenderCell:t}=this.opts;t&&(this.customData=t({date:this.date,cellType:this.singleType,datepicker:this.dp})),this._createElement(),this._bindDatepickerEvents(),null!==(e=this.customData)&&void 0!==e&&e.disabled&&this.dp.disableDate(this.date)}_bindDatepickerEvents(){this.dp.on(i.eventChangeSelectedDate,this.onChangeSelectedDate),this.dp.on(i.eventChangeFocusDate,this.onChangeFocusDate)}unbindDatepickerEvents(){this.dp.off(i.eventChangeSelectedDate,this.onChangeSelectedDate),this.dp.off(i.eventChangeFocusDate,this.onChangeFocusDate)}_createElement(){var e;let{year:t,month:i,date:s}=h(this.date),a=(null===(e=this.customData)||void 0===e?void 0:e.attrs)||{};this.$cell=n({attrs:{\"data-year\":t,\"data-month\":i,\"data-date\":s,...a}}),this.$cell.adpCell=this}_getClassName(){var e;let t=new Date,{selectOtherMonths:s,selectOtherYears:a}=this.opts,{minDate:n,maxDate:r,isDateDisabled:o}=this.dp,{day:l}=h(this.date),d=this._isOutOfMinMaxRange(),c=o(this.date),m=u(\"air-datepicker-cell\",`-${this.singleType}-`,{\"-current-\":p(t,this.date,this.type),\"-min-date-\":n&&p(n,this.date,this.type),\"-max-date-\":r&&p(r,this.date,this.type)}),v=\"\";switch(this.type){case i.days:v=u({\"-weekend-\":this.dp.isWeekend(l),\"-other-month-\":this.isOtherMonth,\"-disabled-\":this.isOtherMonth&&!s||d||c});break;case i.months:v=u({\"-disabled-\":d});break;case i.years:v=u({\"-other-decade-\":this.isOtherDecade,\"-disabled-\":d||this.isOtherDecade&&!a})}return u(m,v,null===(e=this.customData)||void 0===e?void 0:e.classes).split(\" \")}_getHtml(){var e;let{year:t,month:s,date:a}=h(this.date),{showOtherMonths:n,showOtherYears:r}=this.opts;if(null!==(e=this.customData)&&void 0!==e&&e.html)return this.customData.html;switch(this.type){case i.days:return!n&&this.isOtherMonth?\"\":a;case i.months:return this.dp.locale[this.opts.monthsField][s];case i.years:return!r&&this.isOtherDecade?\"\":t}}_isOutOfMinMaxRange(){let{minDate:e,maxDate:t}=this.dp,{type:s,date:a}=this,{month:n,year:r,date:o}=h(a),l=s===i.days,d=s===i.years,c=!!e&&new Date(r,d?e.getMonth():n,l?o:e.getDate()),u=!!t&&new Date(r,d?t.getMonth():n,l?o:t.getDate());return e&&t?v(c,e)||m(u,t):e?v(c,e):t?m(u,t):void 0}destroy(){this.unbindDatepickerEvents()}_handleRangeStatus(){const{selectedDates:e,focusDate:t,rangeDateTo:i,rangeDateFrom:s}=this.dp,a=e.length;if(!a)return;let n=s,r=i;if(1===a&&t){const i=m(t,e[0]);n=i?e[0]:t,r=i?t:e[0]}let o=u({\"-in-range-\":n&&r&&(h=this.date,l=n,d=r,m(h,l)&&v(h,d)),\"-range-from-\":n&&p(this.date,n,this.type),\"-range-to-\":r&&p(this.date,r,this.type)});var h,l,d;this.$cell.classList.remove(\"-range-from-\",\"-range-to-\",\"-in-range-\"),o&&this.$cell.classList.add(...o.split(\" \"))}_handleSelectedStatus(){let e=this.dp._checkIfDateIsSelected(this.date,this.type);e?this.select():!e&&this.selected&&this.removeSelect()}_handleInitialFocusStatus(){p(this.dp.focusDate,this.date,this.type)&&this.focus()}_handleClasses(){this.$cell.setAttribute(\"class\",\"\"),this._handleInitialFocusStatus(),this.dp.hasSelectedDates&&(this._handleSelectedStatus(),this.dp.opts.range&&this._handleRangeStatus()),this.$cell.classList.add(...this._getClassName())}get isDisabled(){return this.$cell.matches(\".-disabled-\")}get isOtherMonth(){return this.dp.isOtherMonth(this.date)}get isOtherDecade(){return this.dp.isOtherDecade(this.date)}}function _(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}let M={[i.days]:`<div class=\"air-datepicker-body--day-names\"></div><div class=\"air-datepicker-body--cells -${i.days}-\"></div>`,[i.months]:`<div class=\"air-datepicker-body--cells -${i.months}-\"></div>`,[i.years]:`<div class=\"air-datepicker-body--cells -${i.years}-\"></div>`};const S=\".air-datepicker-cell\";class T{constructor(e){let{dp:t,type:s,opts:a}=e;_(this,\"handleClick\",(e=>{let t=e.target.closest(S).adpCell;if(t.isDisabled)return;if(!this.dp.isMinViewReached)return void this.dp.down();let i=this.dp._checkIfDateIsSelected(t.date,t.type);i?this.dp._handleAlreadySelectedDates(i,t.date):this.dp.selectDate(t.date)})),_(this,\"handleDayNameClick\",(e=>{let t=e.target.getAttribute(\"data-day-index\");this.opts.onClickDayName({dayIndex:Number(t),datepicker:this.dp})})),_(this,\"onChangeCurrentView\",(e=>{e!==this.type?this.hide():(this.show(),this.render())})),_(this,\"onMouseOverCell\",(e=>{let t=y(e.target,S);this.dp.setFocusDate(!!t&&t.adpCell.date)})),_(this,\"onMouseOutCell\",(()=>{this.dp.setFocusDate(!1)})),_(this,\"onClickBody\",(e=>{let{onClickDayName:t}=this.opts,i=e.target;i.closest(S)&&this.handleClick(e),t&&i.closest(\".air-datepicker-body--day-name\")&&this.handleDayNameClick(e)})),_(this,\"onMouseDown\",(e=>{this.pressed=!0;let t=y(e.target,S),i=t&&t.adpCell;p(i.date,this.dp.rangeDateFrom)&&(this.rangeFromFocused=!0),p(i.date,this.dp.rangeDateTo)&&(this.rangeToFocused=!0)})),_(this,\"onMouseMove\",(e=>{if(!this.pressed||!this.dp.isMinViewReached)return;e.preventDefault();let t=y(e.target,S),i=t&&t.adpCell,{selectedDates:s,rangeDateTo:a,rangeDateFrom:n}=this.dp;if(!i||i.isDisabled)return;let{date:r}=i;if(2===s.length){if(this.rangeFromFocused&&!m(r,a)){let{hours:e,minutes:t}=h(n);r.setHours(e),r.setMinutes(t),this.dp.rangeDateFrom=r,this.dp.replaceDate(n,r)}if(this.rangeToFocused&&!v(r,n)){let{hours:e,minutes:t}=h(a);r.setHours(e),r.setMinutes(t),this.dp.rangeDateTo=r,this.dp.replaceDate(a,r)}}})),_(this,\"onMouseUp\",(()=>{this.pressed=!1,this.rangeFromFocused=!1,this.rangeToFocused=!1})),_(this,\"onChangeViewDate\",((e,t)=>{if(!this.isVisible)return;let s=c(e),a=c(t);switch(this.dp.currentView){case i.days:if(p(e,t,i.months))return;break;case i.months:if(p(e,t,i.years))return;break;case i.years:if(s[0]===a[0]&&s[1]===a[1])return}this.render()})),_(this,\"render\",(()=>{this.destroyCells(),this._generateCells(),this.cells.forEach((e=>{this.$cells.appendChild(e.render())}))})),this.dp=t,this.type=s,this.opts=a,this.cells=[],this.$el=\"\",this.pressed=!1,this.isVisible=!0,this.init()}init(){this._buildBaseHtml(),this.type===i.days&&this.renderDayNames(),this.render(),this._bindEvents(),this._bindDatepickerEvents()}_bindEvents(){let{range:e,dynamicRange:t}=this.opts;D(this.$el,\"mouseover\",this.onMouseOverCell),D(this.$el,\"mouseout\",this.onMouseOutCell),D(this.$el,\"click\",this.onClickBody),e&&t&&(D(this.$el,\"mousedown\",this.onMouseDown),D(this.$el,\"mousemove\",this.onMouseMove),D(window.document,\"mouseup\",this.onMouseUp))}_bindDatepickerEvents(){this.dp.on(i.eventChangeViewDate,this.onChangeViewDate),this.dp.on(i.eventChangeCurrentView,this.onChangeCurrentView)}_buildBaseHtml(){this.$el=n({className:`air-datepicker-body -${this.type}-`,innerHtml:M[this.type]}),this.$names=a(\".air-datepicker-body--day-names\",this.$el),this.$cells=a(\".air-datepicker-body--cells\",this.$el)}_getDayNamesHtml(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.dp.locale.firstDay,t=\"\",s=this.dp.isWeekend,{onClickDayName:a}=this.opts,n=e,r=0;for(;r<7;){let e=n%7;t+=`<div class=\"${u(\"air-datepicker-body--day-name\",{[i.cssClassWeekend]:s(e),\"-clickable-\":!!a})}\" data-day-index='${e}'>${this.dp.locale.daysMin[e]}</div>`,r++,n++}return t}renderDayNames(){this.$names.innerHTML=this._getDayNamesHtml()}_generateCell(e){let{type:t,dp:i,opts:s}=this;return new C({type:t,dp:i,opts:s,date:e,body:this})}_generateCells(){T.getDatesFunction(this.type)(this.dp,(e=>{this.cells.push(this._generateCell(e))}))}show(){this.isVisible=!0,this.$el.classList.remove(\"-hidden-\")}hide(){this.isVisible=!1,this.$el.classList.add(\"-hidden-\")}destroyCells(){this.cells.forEach((e=>e.destroy())),this.cells=[],this.$cells.innerHTML=\"\"}destroy(){this.destroyCells(),this.dp.off(i.eventChangeViewDate,this.onChangeViewDate),this.dp.off(i.eventChangeCurrentView,this.onChangeCurrentView)}static getDaysDates(e,t){let{viewDate:i,opts:{fixedHeight:s},locale:{firstDay:a}}=e,n=o(i),{year:r,month:l}=h(i),d=new Date(r,l,1),c=new Date(r,l,n),u=d.getDay()-a,p=6-c.getDay()+a;u=u<0?u+7:u,p=p>6?p-7:p;let m=function(e,t){let{year:i,month:s,date:a}=h(e);return new Date(i,s,a-t)}(d,u),v=n+u+p,g=m.getDate(),{year:D,month:y}=h(m),f=0;s&&(v=42);const w=[];for(;f<v;){let e=new Date(D,y,g+f);t&&t(e),w.push(e),f++}return w}static getMonthsDates(e,t){let{year:i}=e.parsedViewDate,s=0,a=[];for(;s<12;){const e=new Date(i,s);a.push(e),t&&t(e),s++}return a}static getYearsDates(e,t){let i=c(e.viewDate),s=i[0]-1,a=i[1]+1,n=s,r=[];for(;n<=a;){const e=new Date(n,0);r.push(e),t&&t(e),n++}return r}static getDatesFunction(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:i.days;return{[i.days]:T.getDaysDates,[i.months]:T.getMonthsDates,[i.years]:T.getYearsDates}[e]}}function F(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}class V{constructor(e){let{dp:t,opts:i}=e;F(this,\"onClickNav\",(e=>{let t=y(e.target,\".air-datepicker-nav--action\");if(!t)return;let i=t.dataset.action;this.dp[i]()})),F(this,\"onChangeViewDate\",(()=>{this.render(),this._resetNavStatus(),this.handleNavStatus()})),F(this,\"onChangeCurrentView\",(()=>{this.render(),this._resetNavStatus(),this.handleNavStatus()})),F(this,\"onClickNavTitle\",(()=>{this.dp.isFinalView||this.dp.up()})),F(this,\"update\",(()=>{let{prevHtml:e,nextHtml:t}=this.opts;this.$prev.innerHTML=e,this.$next.innerHTML=t,this._resetNavStatus(),this.render(),this.handleNavStatus()})),F(this,\"renderDelay\",(()=>{setTimeout(this.render)})),F(this,\"render\",(()=>{this.$title.innerHTML=this._getTitle(),function(e,t){for(let i in t)t[i]?e.classList.add(i):e.classList.remove(i)}(this.$title,{\"-disabled-\":this.dp.isFinalView})})),this.dp=t,this.opts=i,this.init()}init(){this._createElement(),this._buildBaseHtml(),this._defineDOM(),this.render(),this.handleNavStatus(),this._bindEvents(),this._bindDatepickerEvents()}_defineDOM(){this.$title=a(\".air-datepicker-nav--title\",this.$el),this.$prev=a('[data-action=\"prev\"]',this.$el),this.$next=a('[data-action=\"next\"]',this.$el)}_bindEvents(){this.$el.addEventListener(\"click\",this.onClickNav),this.$title.addEventListener(\"click\",this.onClickNavTitle)}_bindDatepickerEvents(){this.dp.on(i.eventChangeViewDate,this.onChangeViewDate),this.dp.on(i.eventChangeCurrentView,this.onChangeCurrentView),this.isNavIsFunction&&(this.dp.on(i.eventChangeSelectedDate,this.renderDelay),this.dp.opts.timepicker&&this.dp.on(i.eventChangeTime,this.render))}destroy(){this.dp.off(i.eventChangeViewDate,this.onChangeViewDate),this.dp.off(i.eventChangeCurrentView,this.onChangeCurrentView),this.isNavIsFunction&&(this.dp.off(i.eventChangeSelectedDate,this.renderDelay),this.dp.opts.timepicker&&this.dp.off(i.eventChangeTime,this.render))}_createElement(){this.$el=n({tagName:\"nav\",className:\"air-datepicker-nav\"})}_getTitle(){let{dp:e,opts:t}=this,i=t.navTitles[e.currentView];return\"function\"==typeof i?i(e):e.formatDate(e.viewDate,i)}handleNavStatus(){let{disableNavWhenOutOfRange:e}=this.opts,{minDate:t,maxDate:s}=this.dp;if(!t&&!s||!e)return;let{year:a,month:n}=this.dp.parsedViewDate,r=!!t&&h(t),o=!!s&&h(s);switch(this.dp.currentView){case i.days:t&&r.month>=n&&r.year>=a&&this._disableNav(\"prev\"),s&&o.month<=n&&o.year<=a&&this._disableNav(\"next\");break;case i.months:t&&r.year>=a&&this._disableNav(\"prev\"),s&&o.year<=a&&this._disableNav(\"next\");break;case i.years:{let e=c(this.dp.viewDate);t&&r.year>=e[0]&&this._disableNav(\"prev\"),s&&o.year<=e[1]&&this._disableNav(\"next\");break}}}_disableNav(e){a('[data-action=\"'+e+'\"]',this.$el).classList.add(\"-disabled-\")}_resetNavStatus(){!function(e){for(var t=arguments.length,i=new Array(t>1?t-1:0),s=1;s<t;s++)i[s-1]=arguments[s];e.length?e.forEach((e=>{e.classList.remove(...i)})):e.classList.remove(...i)}(this.$el.querySelectorAll(\".air-datepicker-nav--action\"),\"-disabled-\")}_buildBaseHtml(){let{prevHtml:e,nextHtml:t}=this.opts;this.$el.innerHTML=`<div class=\"air-datepicker-nav--action\" data-action=\"prev\">${e}</div><div class=\"air-datepicker-nav--title\"></div><div class=\"air-datepicker-nav--action\" data-action=\"next\">${t}</div>`}get isNavIsFunction(){let{navTitles:e}=this.opts;return Object.keys(e).find((t=>\"function\"==typeof e[t]))}}var x={today:{content:e=>e.locale.today,onClick:e=>e.setViewDate(new Date)},clear:{content:e=>e.locale.clear,onClick:e=>e.clear()}};class H{constructor(e){let{dp:t,opts:i}=e;this.dp=t,this.opts=i,this.init()}init(){this.createElement(),this.render()}createElement(){this.$el=n({className:\"air-datepicker-buttons\"})}destroy(){this.$el.parentNode.removeChild(this.$el)}clearHtml(){return this.$el.innerHTML=\"\",this}generateButtons(){let{buttons:e}=this.opts;Array.isArray(e)||(e=[e]),e.forEach((e=>{let t=e;\"string\"==typeof e&&x[e]&&(t=x[e]);let i=this.createButton(t);t.onClick&&this.attachEventToButton(i,t.onClick),this.$el.appendChild(i)}))}attachEventToButton(e,t){e.addEventListener(\"click\",(()=>{t(this.dp)}))}createButton(e){let{content:t,className:i,tagName:s=\"button\",attrs:a={}}=e;return n({tagName:s,innerHtml:`<span tabindex='-1'>${\"function\"==typeof t?t(this.dp):t}</span>`,className:u(\"air-datepicker-button\",i),attrs:a})}render(){this.generateButtons()}}function E(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}class L{constructor(){let{opts:e,dp:t}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};E(this,\"toggleTimepickerIsActive\",(e=>{this.dp.timepickerIsActive=e})),E(this,\"onChangeSelectedDate\",(e=>{let{date:t,updateTime:i=!1}=e;t&&(this.setMinMaxTime(t),this.setCurrentTime(!!i&&t),this.addTimeToDate(t))})),E(this,\"onChangeLastSelectedDate\",(e=>{e&&(this.setTime(e),this.render())})),E(this,\"onChangeInputRange\",(e=>{let t=e.target;this[t.getAttribute(\"name\")]=t.value,this.updateText(),this.dp.trigger(i.eventChangeTime,{hours:this.hours,minutes:this.minutes})})),E(this,\"onMouseEnterLeave\",(e=>{let t=e.target.getAttribute(\"name\"),i=this.$minutesText;\"hours\"===t&&(i=this.$hoursText),i.classList.toggle(\"-focus-\")})),E(this,\"onFocus\",(()=>{this.toggleTimepickerIsActive(!0)})),E(this,\"onBlur\",(()=>{this.toggleTimepickerIsActive(!1)})),this.opts=e,this.dp=t;let{timeFormat:s}=this.dp.locale;s&&(s.match(k(\"h\"))||s.match(k(\"hh\")))&&(this.ampm=!0),this.init()}init(){this.setTime(this.dp.lastSelectedDate||this.dp.viewDate),this.createElement(),this.buildHtml(),this.defineDOM(),this.render(),this.bindDatepickerEvents(),this.bindDOMEvents()}bindDatepickerEvents(){this.dp.on(i.eventChangeSelectedDate,this.onChangeSelectedDate),this.dp.on(i.eventChangeLastSelectedDate,this.onChangeLastSelectedDate)}bindDOMEvents(){let e=\"input\";navigator.userAgent.match(/trident/gi)&&(e=\"change\"),D(this.$ranges,e,this.onChangeInputRange),D(this.$ranges,\"mouseenter\",this.onMouseEnterLeave),D(this.$ranges,\"mouseleave\",this.onMouseEnterLeave),D(this.$ranges,\"focus\",this.onFocus),D(this.$ranges,\"mousedown\",this.onFocus),D(this.$ranges,\"blur\",this.onBlur)}createElement(){this.$el=n({className:u(\"air-datepicker-time\",{\"-am-pm-\":this.dp.ampm})})}destroy(){this.dp.off(i.eventChangeSelectedDate,this.onChangeSelectedDate),this.dp.off(i.eventChangeLastSelectedDate,this.onChangeLastSelectedDate),this.$el.parentNode.removeChild(this.$el)}buildHtml(){let{ampm:e,hours:t,displayHours:i,minutes:s,minHours:a,minMinutes:n,maxHours:r,maxMinutes:o,dayPeriod:h,opts:{hoursStep:l,minutesStep:c}}=this;this.$el.innerHTML=`<div class=\"air-datepicker-time--current\"> <span class=\"air-datepicker-time--current-hours\">${d(i)}</span> <span class=\"air-datepicker-time--current-colon\">:</span> <span class=\"air-datepicker-time--current-minutes\">${d(s)}</span> `+(e?`<span class='air-datepicker-time--current-ampm'>${h}</span>`:\"\")+'</div><div class=\"air-datepicker-time--sliders\"> <div class=\"air-datepicker-time--row\">'+` <input type=\"range\" name=\"hours\" value=\"${t}\" min=\"${a}\" max=\"${r}\" step=\"${l}\"/> </div> <div class=\"air-datepicker-time--row\">`+` <input type=\"range\" name=\"minutes\" value=\"${s}\" min=\"${n}\" max=\"${o}\" step=\"${c}\"/> </div></div>`}defineDOM(){let e=e=>a(e,this.$el);this.$ranges=this.$el.querySelectorAll('[type=\"range\"]'),this.$hours=e('[name=\"hours\"]'),this.$minutes=e('[name=\"minutes\"]'),this.$hoursText=e(\".air-datepicker-time--current-hours\"),this.$minutesText=e(\".air-datepicker-time--current-minutes\"),this.$ampm=e(\".air-datepicker-time--current-ampm\")}setTime(e){this.setMinMaxTime(e),this.setCurrentTime(e)}addTimeToDate(e){e&&(e.setHours(this.hours),e.setMinutes(this.minutes))}setMinMaxTime(e){if(this.setMinMaxTimeFromOptions(),e){let{minDate:t,maxDate:i}=this.dp;t&&p(e,t)&&this.setMinTimeFromMinDate(t),i&&p(e,i)&&this.setMaxTimeFromMaxDate(i)}}setCurrentTime(e){let{hours:t,minutes:i}=e?h(e):this;this.hours=f(t,this.minHours,this.maxHours),this.minutes=f(i,this.minMinutes,this.maxMinutes)}setMinMaxTimeFromOptions(){let{minHours:e,minMinutes:t,maxHours:i,maxMinutes:s}=this.opts;this.minHours=f(e,0,23),this.minMinutes=f(t,0,59),this.maxHours=f(i,0,23),this.maxMinutes=f(s,0,59)}setMinTimeFromMinDate(e){let{lastSelectedDate:t}=this.dp;this.minHours=e.getHours(),t&&t.getHours()>e.getHours()?this.minMinutes=this.opts.minMinutes:this.minMinutes=e.getMinutes()}setMaxTimeFromMaxDate(e){let{lastSelectedDate:t}=this.dp;this.maxHours=e.getHours(),t&&t.getHours()<e.getHours()?this.maxMinutes=this.opts.maxMinutes:this.maxMinutes=e.getMinutes()}updateSliders(){r(this.$hours,{min:this.minHours,max:this.maxHours}).value=this.hours,r(this.$minutes,{min:this.minMinutes,max:this.maxMinutes}).value=this.minutes}updateText(){this.$hoursText.innerHTML=d(this.displayHours),this.$minutesText.innerHTML=d(this.minutes),this.ampm&&(this.$ampm.innerHTML=this.dayPeriod)}set hours(e){this._hours=e;let{hours:t,dayPeriod:i}=l(e);this.displayHours=this.ampm?t:e,this.dayPeriod=i}get hours(){return this._hours}render(){this.updateSliders(),this.updateText()}}function O(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}class A{constructor(e){let{dp:t,opts:i}=e;O(this,\"pressedKeys\",new Set),O(this,\"hotKeys\",new Map([[[[\"Control\",\"ArrowRight\"],[\"Control\",\"ArrowUp\"]],e=>e.month++],[[[\"Control\",\"ArrowLeft\"],[\"Control\",\"ArrowDown\"]],e=>e.month--],[[[\"Shift\",\"ArrowRight\"],[\"Shift\",\"ArrowUp\"]],e=>e.year++],[[[\"Shift\",\"ArrowLeft\"],[\"Shift\",\"ArrowDown\"]],e=>e.year--],[[[\"Alt\",\"ArrowRight\"],[\"Alt\",\"ArrowUp\"]],e=>e.year+=10],[[[\"Alt\",\"ArrowLeft\"],[\"Alt\",\"ArrowDown\"]],e=>e.year-=10],[[\"Control\",\"Shift\",\"ArrowUp\"],(e,t)=>t.up()]])),O(this,\"handleHotKey\",(e=>{let t=this.hotKeys.get(e),i=h(this.getInitialFocusDate());t(i,this.dp);let{year:s,month:a,date:n}=i,r=o(new Date(s,a));r<n&&(n=r);let l=this.dp.getClampedDate(new Date(s,a,n));this.dp.setFocusDate(l,{viewDateTransition:!0})})),O(this,\"isHotKeyPressed\",(()=>{let e=!1,t=this.pressedKeys.size,i=e=>this.pressedKeys.has(e);for(let[s]of this.hotKeys){if(e)break;if(Array.isArray(s[0]))s.forEach((a=>{e||t!==a.length||(e=a.every(i)&&s)}));else{if(t!==s.length)continue;e=s.every(i)&&s}}return e})),O(this,\"isArrow\",(e=>e>=37&&e<=40)),O(this,\"onKeyDown\",(e=>{let{key:t,which:i}=e,{dp:s,dp:{focusDate:a},opts:n}=this;this.registerKey(t);let r=this.isHotKeyPressed();if(r)return e.preventDefault(),void this.handleHotKey(r);if(this.isArrow(i))return e.preventDefault(),void this.focusNextCell(t);if(\"Enter\"===t){if(s.currentView!==n.minView)return void s.down();if(a){let e=s._checkIfDateIsSelected(a);return void(e?s._handleAlreadySelectedDates(e,a):s.selectDate(a))}}\"Escape\"===t&&this.dp.hide()})),O(this,\"onKeyUp\",(e=>{this.removeKey(e.key)})),this.dp=t,this.opts=i,this.init()}init(){this.bindKeyboardEvents()}bindKeyboardEvents(){let{$el:e}=this.dp;e.addEventListener(\"keydown\",this.onKeyDown),e.addEventListener(\"keyup\",this.onKeyUp)}destroy(){let{$el:e}=this.dp;e.removeEventListener(\"keydown\",this.onKeyDown),e.removeEventListener(\"keyup\",this.onKeyUp),this.hotKeys=null,this.pressedKeys=null}getInitialFocusDate(){let{focusDate:e,currentView:t,selectedDates:s,parsedViewDate:{year:a,month:n}}=this.dp,r=e||s[s.length-1];if(!r)switch(t){case i.days:r=new Date(a,n,(new Date).getDate());break;case i.months:r=new Date(a,n,1);break;case i.years:r=new Date(a,0,1)}return r}focusNextCell(e){let t=this.getInitialFocusDate(),{currentView:s}=this.dp,{days:a,months:n,years:r}=i,o=h(t),l=o.year,d=o.month,c=o.date;switch(e){case\"ArrowLeft\":s===a&&(c-=1),s===n&&(d-=1),s===r&&(l-=1);break;case\"ArrowUp\":s===a&&(c-=7),s===n&&(d-=3),s===r&&(l-=4);break;case\"ArrowRight\":s===a&&(c+=1),s===n&&(d+=1),s===r&&(l+=1);break;case\"ArrowDown\":s===a&&(c+=7),s===n&&(d+=3),s===r&&(l+=4)}let u=this.dp.getClampedDate(new Date(l,d,c));this.dp.setFocusDate(u,{viewDateTransition:!0})}registerKey(e){this.pressedKeys.add(e)}removeKey(e){this.pressedKeys.delete(e)}}let N={on(e,t){this.__events||(this.__events={}),this.__events[e]?this.__events[e].push(t):this.__events[e]=[t]},off(e,t){this.__events&&this.__events[e]&&(this.__events[e]=this.__events[e].filter((e=>e!==t)))},removeAllEvents(){this.__events={}},trigger(e){for(var t=arguments.length,i=new Array(t>1?t-1:0),s=1;s<t;s++)i[s-1]=arguments[s];this.__events&&this.__events[e]&&this.__events[e].forEach((e=>{e(...i)}))}};function I(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}let P=\"\",j=\"\",B=!1;class R{static buildGlobalContainer(e){B=!0,P=n({className:e,id:e}),a(\"body\").appendChild(P)}constructor(e,t){var r=this;if(I(this,\"viewIndexes\",[i.days,i.months,i.years]),I(this,\"next\",(()=>{let{year:e,month:t}=this.parsedViewDate;switch(this.currentView){case i.days:this.setViewDate(new Date(e,t+1,1));break;case i.months:this.setViewDate(new Date(e+1,t,1));break;case i.years:this.setViewDate(new Date(e+10,0,1))}})),I(this,\"prev\",(()=>{let{year:e,month:t}=this.parsedViewDate;switch(this.currentView){case i.days:this.setViewDate(new Date(e,t-1,1));break;case i.months:this.setViewDate(new Date(e-1,t,1));break;case i.years:this.setViewDate(new Date(e-10,0,1))}})),I(this,\"_finishHide\",(()=>{this.hideAnimation=!1,this._destroyComponents(),this.$container.removeChild(this.$datepicker)})),I(this,\"setPosition\",(function(e){let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];if(\"function\"==typeof(e=e||r.opts.position))return void(r.customHide=e({$datepicker:r.$datepicker,$target:r.$el,$pointer:r.$pointer,isViewChange:t,done:r._finishHide}));let i,s,{isMobile:a}=r.opts,n=r.$el.getBoundingClientRect(),o=r.$el.getBoundingClientRect(),h=r.$datepicker.offsetParent,l=r.$el.offsetParent,d=r.$datepicker.getBoundingClientRect(),c=e.split(\" \"),u=window.scrollY,p=window.scrollX,m=r.opts.offset,v=c[0],g=c[1];if(a)r.$datepicker.style.cssText=\"left: 50%; top: 50%\";else{if(h===l&&h!==document.body&&(o={top:r.$el.offsetTop,left:r.$el.offsetLeft,width:n.width,height:r.$el.offsetHeight},u=0,p=0),h!==l&&h!==document.body){let e=h.getBoundingClientRect();o={top:n.top-e.top,left:n.left-e.left,width:n.width,height:n.height},u=0,p=0}switch(v){case\"top\":i=o.top-d.height-m;break;case\"right\":s=o.left+o.width+m;break;case\"bottom\":i=o.top+o.height+m;break;case\"left\":s=o.left-d.width-m}switch(g){case\"top\":i=o.top;break;case\"right\":s=o.left+o.width-d.width;break;case\"bottom\":i=o.top+o.height-d.height;break;case\"left\":s=o.left;break;case\"center\":/left|right/.test(v)?i=o.top+o.height/2-d.height/2:s=o.left+o.width/2-d.width/2}r.$datepicker.style.cssText=`left: ${s+p}px; top: ${i+u}px`}})),I(this,\"_setInputValue\",(()=>{let{opts:e,$altField:t,locale:{dateFormat:i}}=this,{altFieldDateFormat:s,altField:a}=e;a&&t&&(t.value=this._getInputValue(s)),this.$el.value=this._getInputValue(i)})),I(this,\"_getInputValue\",(e=>{let{selectedDates:t,opts:i}=this,{multipleDates:s,multipleDatesSeparator:a}=i;if(!t.length)return\"\";let n=\"function\"==typeof e,r=n?e(s?t:t[0]):t.map((t=>this.formatDate(t,e)));return r=n?r:r.join(a),r})),I(this,\"_checkIfDateIsSelected\",(function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:i.days,s=!1;return r.selectedDates.some((i=>{let a=p(e,i,t);return s=a&&i,a})),s})),I(this,\"_scheduleCallAfterTransition\",(e=>{this._cancelScheduledCall(),e&&e(!1),this._onTransitionEnd=()=>{e&&e(!0)},this.$datepicker.addEventListener(\"transitionend\",this._onTransitionEnd,{once:!0})})),I(this,\"_cancelScheduledCall\",(()=>{this.$datepicker.removeEventListener(\"transitionend\",this._onTransitionEnd)})),I(this,\"setViewDate\",(e=>{if(!((e=b(e))instanceof Date))return;if(p(e,this.viewDate))return;let t=this.viewDate;this.viewDate=e;let{onChangeViewDate:s}=this.opts;if(s){let{month:e,year:t}=this.parsedViewDate;s({month:e,year:t,decade:this.curDecade})}this.trigger(i.eventChangeViewDate,e,t)})),I(this,\"setFocusDate\",(function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};(!e||(e=b(e))instanceof Date)&&(r.focusDate=e,r.trigger(i.eventChangeFocusDate,e,t))})),I(this,\"setCurrentView\",(function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(r.viewIndexes.includes(e)){if(r.currentView=e,r.elIsInput&&r.visible&&r.setPosition(void 0,!0),r.trigger(i.eventChangeCurrentView,e),!r.views[e]){let t=r.views[e]=new T({dp:r,opts:r.opts,type:e});r.shouldUpdateDOM&&r.$content.appendChild(t.$el)}r.opts.onChangeView&&!t.silent&&r.opts.onChangeView(e)}})),I(this,\"_updateLastSelectedDate\",(e=>{this.lastSelectedDate=e,this.trigger(i.eventChangeLastSelectedDate,e)})),I(this,\"destroy\",(()=>{if(this.isDestroyed)return;let{showEvent:e,isMobile:t}=this.opts,i=this.$datepicker.parentNode;i&&i.removeChild(this.$datepicker),this.$el.removeEventListener(e,this._onFocus),this.$el.removeEventListener(\"blur\",this._onBlur),window.removeEventListener(\"resize\",this._onResize),t&&this._removeMobileAttributes(),this.keyboardNav&&this.keyboardNav.destroy(),this.views=null,this.nav=null,this.$datepicker=null,this.opts={},this.$customContainer=null,this.viewDate=null,this.focusDate=null,this.selectedDates=[],this.rangeDateFrom=null,this.rangeDateTo=null,this.isDestroyed=!0})),I(this,\"update\",(function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},s=w({},r.opts),{silent:a}=t;w(r.opts,e);let{timepicker:n,buttons:o,range:h,selectedDates:l,isMobile:d}=r.opts,c=r.visible||r.treatAsInline;r._createMinMaxDates(),r._limitViewDateByMaxMinDates(),r._handleLocale(),l&&(r.selectedDates=[],r.selectDate(l,{silent:a})),e.view&&r.setCurrentView(e.view,{silent:a}),r._setInputValue(),s.range&&!h?(r.rangeDateTo=!1,r.rangeDateFrom=!1):!s.range&&h&&r.selectedDates.length&&(r.rangeDateFrom=r.selectedDates[0],r.rangeDateTo=r.selectedDates[1]),s.timepicker&&!n?(c&&r.timepicker.destroy(),r.timepicker=!1,r.$timepicker.parentNode.removeChild(r.$timepicker)):!s.timepicker&&n&&r._addTimepicker(),!s.buttons&&o?r._addButtons():s.buttons&&!o?(r.buttons.destroy(),r.$buttons.parentNode.removeChild(r.$buttons)):c&&s.buttons&&o&&r.buttons.clearHtml().render(),!s.isMobile&&d?(r.treatAsInline||j||r._createMobileOverlay(),r._addMobileAttributes(),r.visible&&r._showMobileOverlay()):s.isMobile&&!d&&(r._removeMobileAttributes(),r.visible&&(j.classList.remove(\"-active-\"),\"function\"!=typeof r.opts.position&&r.setPosition())),c&&(r.nav.update(),r.views[r.currentView].render(),r.currentView===i.days&&r.views[r.currentView].renderDayNames())})),I(this,\"disableDate\",((e,t)=>{(Array.isArray(e)?e:[e]).forEach((e=>{let i=b(e);if(!i)return;let s=t?\"delete\":\"add\";this.disabledDates[s](this.formatDate(i,\"yyyy-MM-dd\"));let a=this.getCell(i,this.currentViewSingular);a&&a.adpCell.render()}),[])})),I(this,\"enableDate\",(e=>{this.disableDate(e,!0)})),I(this,\"isDateDisabled\",(e=>{let t=b(e);return this.disabledDates.has(this.formatDate(t,\"yyyy-MM-dd\"))})),I(this,\"isOtherMonth\",(e=>{let{month:t}=h(e);return t!==this.parsedViewDate.month})),I(this,\"isOtherYear\",(e=>{let{year:t}=h(e);return t!==this.parsedViewDate.year})),I(this,\"isOtherDecade\",(e=>{let{year:t}=h(e),[i,s]=c(this.viewDate);return t<i||t>s})),I(this,\"_onChangeSelectedDate\",(e=>{let{silent:t}=e;setTimeout((()=>{this._setInputValue(),this.opts.onSelect&&!t&&this._triggerOnSelect()}))})),I(this,\"_onChangeFocusedDate\",(function(e){let{viewDateTransition:t}=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!e)return;let i=!1;t&&(i=r.isOtherMonth(e)||r.isOtherYear(e)||r.isOtherDecade(e)),i&&r.setViewDate(e),r.opts.onFocus&&r.opts.onFocus({datepicker:r,date:e})})),I(this,\"_onChangeTime\",(e=>{let{hours:t,minutes:i}=e,s=new Date,{lastSelectedDate:a,opts:{onSelect:n}}=this,r=a;a||(r=s);let o=this.getCell(r,this.currentViewSingular),h=o&&o.adpCell;h&&h.isDisabled||(r.setHours(t),r.setMinutes(i),a?(this._setInputValue(),n&&this._triggerOnSelect()):this.selectDate(r))})),I(this,\"_onFocus\",(e=>{this.visible||this.show()})),I(this,\"_onBlur\",(e=>{this.inFocus||!this.visible||this.opts.isMobile||this.hide()})),I(this,\"_onMouseDown\",(e=>{this.inFocus=!0})),I(this,\"_onMouseUp\",(e=>{this.inFocus=!1,this.$el.focus()})),I(this,\"_onResize\",(()=>{this.visible&&\"function\"!=typeof this.opts.position&&this.setPosition()})),I(this,\"_onClickOverlay\",(()=>{this.visible&&this.hide()})),I(this,\"getViewDates\",(function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:i.days;return T.getDatesFunction(e)(r)})),I(this,\"isWeekend\",(e=>this.opts.weekends.includes(e))),I(this,\"getClampedDate\",(e=>{let{minDate:t,maxDate:i}=this,s=e;return i&&m(e,i)?s=i:t&&v(e,t)&&(s=t),s})),this.$el=a(e),!this.$el)return;this.$datepicker=n({className:\"air-datepicker\"}),this.opts=w({},s,t),this.$customContainer=!!this.opts.container&&a(this.opts.container),this.$altField=a(this.opts.altField||!1);let{view:o,startDate:l}=this.opts;l||(this.opts.startDate=new Date),\"INPUT\"===this.$el.nodeName&&(this.elIsInput=!0),this.inited=!1,this.visible=!1,this.viewDate=b(this.opts.startDate),this.focusDate=!1,this.initialReadonly=this.$el.getAttribute(\"readonly\"),this.customHide=!1,this.currentView=o,this.selectedDates=[],this.disabledDates=new Set,this.isDestroyed=!1,this.views={},this.keys=[],this.rangeDateFrom=\"\",this.rangeDateTo=\"\",this.timepickerIsActive=!1,this.treatAsInline=this.opts.inline||!this.elIsInput,this.init()}init(){let{opts:e,treatAsInline:t,opts:{inline:i,isMobile:s,selectedDates:n,keyboardNav:r,onlyTimepicker:o}}=this,h=a(\"body\");(!B||B&&P&&!h.contains(P))&&!i&&this.elIsInput&&!this.$customContainer&&R.buildGlobalContainer(R.defaultGlobalContainerId),!s||j||t||this._createMobileOverlay(),this._handleLocale(),this._bindSubEvents(),this._createMinMaxDates(),this._limitViewDateByMaxMinDates(),this.elIsInput&&(i||this._bindEvents(),r&&!o&&(this.keyboardNav=new A({dp:this,opts:e}))),n&&this.selectDate(n,{silent:!0}),this.opts.visible&&!t&&this.show(),s&&!t&&this.$el.setAttribute(\"readonly\",!0),t&&this._createComponents()}_createMobileOverlay(){j=n({className:\"air-datepicker-overlay\"}),P.appendChild(j)}_createComponents(){let{opts:e,treatAsInline:t,opts:{inline:i,buttons:s,timepicker:a,position:n,classes:r,onlyTimepicker:o,isMobile:h}}=this;this._buildBaseHtml(),this.elIsInput&&(i||this._setPositionClasses(n)),!i&&this.elIsInput||this.$datepicker.classList.add(\"-inline-\"),r&&this.$datepicker.classList.add(...r.split(\" \")),o&&this.$datepicker.classList.add(\"-only-timepicker-\"),h&&!t&&this._addMobileAttributes(),this.views[this.currentView]=new T({dp:this,type:this.currentView,opts:e}),this.nav=new V({dp:this,opts:e}),a&&this._addTimepicker(),s&&this._addButtons(),this.$content.appendChild(this.views[this.currentView].$el),this.$nav.appendChild(this.nav.$el)}_destroyComponents(){for(let e in this.views)this.views[e].destroy();this.views={},this.nav.destroy(),this.timepicker&&this.timepicker.destroy()}_addMobileAttributes(){j.addEventListener(\"click\",this._onClickOverlay),this.$datepicker.classList.add(\"-is-mobile-\"),this.$el.setAttribute(\"readonly\",!0)}_removeMobileAttributes(){j.removeEventListener(\"click\",this._onClickOverlay),this.$datepicker.classList.remove(\"-is-mobile-\"),this.initialReadonly||\"\"===this.initialReadonly||this.$el.removeAttribute(\"readonly\")}_createMinMaxDates(){let{minDate:e,maxDate:t}=this.opts;this.minDate=!!e&&b(e),this.maxDate=!!t&&b(t)}_addTimepicker(){this.$timepicker=n({className:\"air-datepicker--time\"}),this.$datepicker.appendChild(this.$timepicker),this.timepicker=new L({dp:this,opts:this.opts}),this.$timepicker.appendChild(this.timepicker.$el)}_addButtons(){this.$buttons=n({className:\"air-datepicker--buttons\"}),this.$datepicker.appendChild(this.$buttons),this.buttons=new H({dp:this,opts:this.opts}),this.$buttons.appendChild(this.buttons.$el)}_bindSubEvents(){this.on(i.eventChangeSelectedDate,this._onChangeSelectedDate),this.on(i.eventChangeFocusDate,this._onChangeFocusedDate),this.on(i.eventChangeTime,this._onChangeTime)}_buildBaseHtml(){let{inline:e}=this.opts;var t,i;this.elIsInput?e?(t=this.$datepicker,(i=this.$el).parentNode.insertBefore(t,i.nextSibling)):this.$container.appendChild(this.$datepicker):this.$el.appendChild(this.$datepicker),this.$datepicker.innerHTML='<i class=\"air-datepicker--pointer\"></i><div class=\"air-datepicker--navigation\"></div><div class=\"air-datepicker--content\"></div>',this.$content=a(\".air-datepicker--content\",this.$datepicker),this.$pointer=a(\".air-datepicker--pointer\",this.$datepicker),this.$nav=a(\".air-datepicker--navigation\",this.$datepicker)}_handleLocale(){let{locale:e,dateFormat:t,firstDay:i,timepicker:s,onlyTimepicker:a,timeFormat:n,dateTimeSeparator:r}=this.opts;var o;this.locale=(o=e,JSON.parse(JSON.stringify(o))),t&&(this.locale.dateFormat=t),void 0!==n&&\"\"!==n&&(this.locale.timeFormat=n);let{timeFormat:h}=this.locale;if(\"\"!==i&&(this.locale.firstDay=i),s&&\"function\"!=typeof t){let e=h?r:\"\";this.locale.dateFormat=[this.locale.dateFormat,h||\"\"].join(e)}a&&\"function\"!=typeof t&&(this.locale.dateFormat=this.locale.timeFormat)}_setPositionClasses(e){if(\"function\"==typeof e)return void this.$datepicker.classList.add(\"-custom-position-\");let t=(e=e.split(\" \"))[0],i=`air-datepicker -${t}-${e[1]}- -from-${t}-`;this.$datepicker.classList.add(...i.split(\" \"))}_bindEvents(){this.$el.addEventListener(this.opts.showEvent,this._onFocus),this.$el.addEventListener(\"blur\",this._onBlur),this.$datepicker.addEventListener(\"mousedown\",this._onMouseDown),this.$datepicker.addEventListener(\"mouseup\",this._onMouseUp),window.addEventListener(\"resize\",this._onResize)}_limitViewDateByMaxMinDates(){let{viewDate:e,minDate:t,maxDate:i}=this;i&&m(e,i)&&this.setViewDate(i),t&&v(e,t)&&this.setViewDate(t)}formatDate(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.viewDate,t=arguments.length>1?arguments[1]:void 0;if(e=b(e),!(e instanceof Date))return;let i=t,s=this.locale,a=h(e),n=a.dayPeriod,r=c(e),o=R.replacer,l={T:e.getTime(),m:a.minutes,mm:a.fullMinutes,h:a.hours12,hh:a.fullHours12,H:a.hours,HH:a.fullHours,aa:n,AA:n.toUpperCase(),E:s.daysShort[a.day],EEEE:s.days[a.day],d:a.date,dd:a.fullDate,M:a.month+1,MM:a.fullMonth,MMM:s.monthsShort[a.month],MMMM:s.months[a.month],yy:a.year.toString().slice(-2),yyyy:a.year,yyyy1:r[0],yyyy2:r[1]};for(let[e,t]of Object.entries(l))i=o(i,k(e),t);return i}down(e){this._handleUpDownActions(e,\"down\")}up(e){this._handleUpDownActions(e,\"up\")}selectDate(e){let t,s=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},{currentView:a,parsedViewDate:n,selectedDates:r}=this,{updateTime:o}=s,{moveToOtherMonthsOnSelect:h,moveToOtherYearsOnSelect:l,multipleDates:d,range:c,autoClose:u,onBeforeSelect:p}=this.opts,v=r.length;if(Array.isArray(e))return e.forEach((e=>{this.selectDate(e,s)})),new Promise((e=>{setTimeout(e)}));if((e=b(e))instanceof Date){if(p&&!p({date:e,datepicker:this}))return Promise.resolve();if(a===i.days&&e.getMonth()!==n.month&&h&&(t=new Date(e.getFullYear(),e.getMonth(),1)),a===i.years&&e.getFullYear()!==n.year&&l&&(t=new Date(e.getFullYear(),0,1)),t&&this.setViewDate(t),d&&!c){if(v===d)return;this._checkIfDateIsSelected(e)||r.push(e)}else if(c)switch(v){case 1:r.push(e),this.rangeDateTo||(this.rangeDateTo=e),m(this.rangeDateFrom,this.rangeDateTo)&&(this.rangeDateTo=this.rangeDateFrom,this.rangeDateFrom=e),this.selectedDates=[this.rangeDateFrom,this.rangeDateTo];break;case 2:this.selectedDates=[e],this.rangeDateFrom=e,this.rangeDateTo=\"\";break;default:this.selectedDates=[e],this.rangeDateFrom=e}else this.selectedDates=[e];return this.trigger(i.eventChangeSelectedDate,{action:i.actionSelectDate,silent:null==s?void 0:s.silent,date:e,updateTime:o}),this._updateLastSelectedDate(e),u&&!this.timepickerIsActive&&this.visible&&(d||c?c&&1===v&&this.hide():this.hide()),new Promise((e=>{setTimeout(e)}))}}unselectDate(e){let t=this.selectedDates,s=this;if((e=b(e))instanceof Date)return t.some(((a,n)=>{if(p(a,e))return t.splice(n,1),s.selectedDates.length?(s.rangeDateTo=\"\",s.rangeDateFrom=t[0],s._updateLastSelectedDate(s.selectedDates[s.selectedDates.length-1])):(s.rangeDateFrom=\"\",s.rangeDateTo=\"\",s._updateLastSelectedDate(!1)),this.trigger(i.eventChangeSelectedDate,{action:i.actionUnselectDate,date:e}),!0}))}replaceDate(e,t){let s=this.selectedDates.find((t=>p(t,e,this.currentView))),a=this.selectedDates.indexOf(s);a<0||p(this.selectedDates[a],t,this.currentView)||(this.selectedDates[a]=t,this.trigger(i.eventChangeSelectedDate,{action:i.actionSelectDate,date:t,updateTime:!0}),this._updateLastSelectedDate(t))}clear(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return this.selectedDates=[],this.rangeDateFrom=!1,this.rangeDateTo=!1,this.lastSelectedDate=!1,this.trigger(i.eventChangeSelectedDate,{action:i.actionUnselectDate,silent:e.silent}),new Promise((e=>{setTimeout(e)}))}show(){let{onShow:e,isMobile:t}=this.opts;this._cancelScheduledCall(),this.visible||this.hideAnimation||this._createComponents(),this.setPosition(this.opts.position),this.$datepicker.classList.add(\"-active-\"),this.visible=!0,e&&this._scheduleCallAfterTransition(e),t&&this._showMobileOverlay()}hide(){let{onHide:e,isMobile:t}=this.opts,i=this._hasTransition();this.visible=!1,this.hideAnimation=!0,this.$datepicker.classList.remove(\"-active-\"),this.customHide&&this.customHide(),this.elIsInput&&this.$el.blur(),this._scheduleCallAfterTransition((t=>{!this.customHide&&(t&&i||!t&&!i)&&this._finishHide(),e&&e(t)})),t&&j.classList.remove(\"-active-\")}_triggerOnSelect(){let e=[],t=[],{selectedDates:i,locale:s,opts:{onSelect:a,multipleDates:n,range:r}}=this,o=n||r,h=\"function\"==typeof s.dateFormat;i.length&&(e=i.map(g),t=h?n?s.dateFormat(e):e.map((e=>s.dateFormat(e))):e.map((e=>this.formatDate(e,s.dateFormat)))),a({date:o?e:e[0],formattedDate:o?t:t[0],datepicker:this})}_handleAlreadySelectedDates(e,t){let{selectedDates:i,rangeDateFrom:s,rangeDateTo:a}=this,{range:n,toggleSelected:r}=this.opts,o=i.length,h=\"function\"==typeof r?r({datepicker:this,date:t}):r,l=Boolean(n&&1===o&&e),d=l?g(t):t;n&&!h&&(2!==o&&this.selectDate(d),2===o&&p(s,a))||(h?this.unselectDate(d):this._updateLastSelectedDate(l?d:e))}_handleUpDownActions(e,t){if(!((e=b(e||this.focusDate||this.viewDate))instanceof Date))return;let i=\"up\"===t?this.viewIndex+1:this.viewIndex-1;i>2&&(i=2),i<0&&(i=0),this.setViewDate(new Date(e.getFullYear(),e.getMonth(),1)),this.setCurrentView(this.viewIndexes[i])}getCell(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:i.day;if(!((e=b(e))instanceof Date))return;let{year:s,month:a,date:n}=h(e),r=`[data-year=\"${s}\"]`,o=`[data-month=\"${a}\"]`,l={[i.day]:`${r}${o}[data-date=\"${n}\"]`,[i.month]:`${r}${o}`,[i.year]:`${r}`};return this.views[this.currentView]?this.views[this.currentView].$el.querySelector(l[t]):void 0}_showMobileOverlay(){j.classList.add(\"-active-\")}_hasTransition(){return window.getComputedStyle(this.$datepicker).getPropertyValue(\"transition-duration\").split(\", \").reduce(((e,t)=>parseFloat(t)+e),0)>0}get shouldUpdateDOM(){return this.visible||this.treatAsInline}get parsedViewDate(){return h(this.viewDate)}get currentViewSingular(){return this.currentView.slice(0,-1)}get curDecade(){return c(this.viewDate)}get viewIndex(){return this.viewIndexes.indexOf(this.currentView)}get isFinalView(){return this.currentView===i.years}get hasSelectedDates(){return this.selectedDates.length>0}get isMinViewReached(){return this.currentView===this.opts.minView||this.currentView===i.days}get $container(){return this.$customContainer||P}static replacer(e,t,i){return e.replace(t,(function(e,t,s,a){return t+i+a}))}}var K;return I(R,\"defaults\",s),I(R,\"version\",\"3.5.3\"),I(R,\"defaultGlobalContainerId\",\"air-datepicker-global-container\"),K=R.prototype,Object.assign(K,N),t.default}()}));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _default = {\n days: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n daysShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n daysMin: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],\n monthsShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n today: 'Today',\n clear: 'Clear',\n dateFormat: 'MM/dd/yyyy',\n timeFormat: 'hh:mm aa',\n firstDay: 0\n};\nexports.default = _default;","@import '../../../theme.scss';\n\nverdocs-field-date {\n font-family: $verdocs-primary-font;\n width: 74px;\n height: 20px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n letter-spacing: 0.3px;\n background-color: transparent;\n transform-origin: bottom left;\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n label {\n top: -14px;\n left: 0;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n input {\n position: absolute;\n\n font-size: 12px;\n\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n background: none;\n border: 1px solid $light-border-color;\n appearance: none;\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled input {\n opacity: 0.5;\n }\n\n &.required {\n input {\n border: 1px solid $verdocs-red-1;\n }\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -18px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n.air-datepicker-cell.-year-.-other-decade-,\n.air-datepicker-cell.-day-.-other-month- {\n color: var(--adp-color-other-month);\n}\n.air-datepicker-cell.-year-.-other-decade-:hover,\n.air-datepicker-cell.-day-.-other-month-:hover {\n color: var(--adp-color-other-month-hover);\n}\n.-disabled-.-focus-.air-datepicker-cell.-year-.-other-decade-,\n.-disabled-.-focus-.air-datepicker-cell.-day-.-other-month- {\n color: var(--adp-color-other-month);\n}\n.-selected-.air-datepicker-cell.-year-.-other-decade-,\n.-selected-.air-datepicker-cell.-day-.-other-month- {\n color: #fff;\n background: var(--adp-background-color-selected-other-month);\n}\n.-selected-.-focus-.air-datepicker-cell.-year-.-other-decade-,\n.-selected-.-focus-.air-datepicker-cell.-day-.-other-month- {\n background: var(--adp-background-color-selected-other-month-focused);\n}\n.-in-range-.air-datepicker-cell.-year-.-other-decade-,\n.-in-range-.air-datepicker-cell.-day-.-other-month- {\n background-color: var(--adp-background-color-in-range);\n color: var(--adp-color);\n}\n.-in-range-.-focus-.air-datepicker-cell.-year-.-other-decade-,\n.-in-range-.-focus-.air-datepicker-cell.-day-.-other-month- {\n background-color: var(--adp-background-color-in-range-focused);\n}\n.air-datepicker-cell.-year-.-other-decade-:empty,\n.air-datepicker-cell.-day-.-other-month-:empty {\n background: none;\n border: none;\n}\n.air-datepicker-cell {\n border-radius: var(--adp-cell-border-radius);\n box-sizing: border-box;\n cursor: pointer;\n display: flex;\n position: relative;\n align-items: center;\n justify-content: center;\n z-index: 1;\n}\n.air-datepicker-cell.-focus- {\n background: var(--adp-cell-background-color-hover);\n}\n.air-datepicker-cell.-current- {\n color: var(--adp-color-current-date);\n}\n.air-datepicker-cell.-current-.-focus- {\n color: var(--adp-color);\n}\n.air-datepicker-cell.-current-.-in-range- {\n color: var(--adp-color-current-date);\n}\n.air-datepicker-cell.-disabled- {\n cursor: default;\n color: var(--adp-color-disabled);\n}\n.air-datepicker-cell.-disabled-.-focus- {\n color: var(--adp-color-disabled);\n}\n.air-datepicker-cell.-disabled-.-in-range- {\n color: var(--adp-color-disabled-in-range);\n}\n.air-datepicker-cell.-disabled-.-current-.-focus- {\n color: var(--adp-color-disabled);\n}\n.air-datepicker-cell.-in-range- {\n background: var(--adp-cell-background-color-in-range);\n border-radius: 0;\n}\n.air-datepicker-cell.-in-range-:hover {\n background: var(--adp-cell-background-color-in-range-hover);\n}\n.air-datepicker-cell.-range-from- {\n border: 1px solid var(--adp-cell-border-color-in-range);\n background-color: var(--adp-cell-background-color-in-range);\n border-radius: var(--adp-cell-border-radius) 0 0 var(--adp-cell-border-radius);\n}\n.air-datepicker-cell.-range-to- {\n border: 1px solid var(--adp-cell-border-color-in-range);\n background-color: var(--adp-cell-background-color-in-range);\n border-radius: 0 var(--adp-cell-border-radius) var(--adp-cell-border-radius) 0;\n}\n.air-datepicker-cell.-range-to-.-range-from- {\n border-radius: var(--adp-cell-border-radius);\n}\n.air-datepicker-cell.-selected- {\n color: #fff;\n border: none;\n background: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-cell.-selected-.-current- {\n color: #fff;\n background: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-cell.-selected-.-focus- {\n background: var(--adp-cell-background-color-selected-hover);\n}\n.air-datepicker-body {\n transition: all var(--adp-transition-duration) var(--adp-transition-ease);\n}\n.air-datepicker-body.-hidden- {\n display: none;\n}\n.air-datepicker-body--day-names {\n display: grid;\n grid-template-columns: repeat(7, var(--adp-day-cell-width));\n margin: 8px 0 3px;\n}\n.air-datepicker-body--day-name {\n color: var(--adp-day-name-color);\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n text-align: center;\n text-transform: uppercase;\n font-size: 0.8em;\n}\n.air-datepicker-body--day-name.-clickable- {\n cursor: pointer;\n}\n.air-datepicker-body--day-name.-clickable-:hover {\n color: var(--adp-day-name-color-hover);\n}\n.air-datepicker-body--cells {\n display: grid;\n}\n.air-datepicker-body--cells.-days- {\n grid-template-columns: repeat(7, var(--adp-day-cell-width));\n grid-auto-rows: var(--adp-day-cell-height);\n}\n.air-datepicker-body--cells.-months- {\n grid-template-columns: repeat(3, 1fr);\n grid-auto-rows: var(--adp-month-cell-height);\n}\n.air-datepicker-body--cells.-years- {\n grid-template-columns: repeat(4, 1fr);\n grid-auto-rows: var(--adp-year-cell-height);\n}\n.air-datepicker-nav {\n display: flex;\n justify-content: space-between;\n border-bottom: 1px solid var(--adp-border-color-inner);\n min-height: var(--adp-nav-height);\n padding: var(--adp-padding);\n box-sizing: content-box;\n}\n.-only-timepicker- .air-datepicker-nav {\n display: none;\n}\n.air-datepicker-nav--title,\n.air-datepicker-nav--action {\n display: flex;\n cursor: pointer;\n align-items: center;\n justify-content: center;\n}\n.air-datepicker-nav--action {\n width: var(--adp-nav-action-size);\n border-radius: var(--adp-border-radius);\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n}\n.air-datepicker-nav--action:hover {\n background: var(--adp-background-color-hover);\n}\n.air-datepicker-nav--action:active {\n background: var(--adp-background-color-active);\n}\n.air-datepicker-nav--action.-disabled- {\n visibility: hidden;\n}\n.air-datepicker-nav--action svg {\n width: 32px;\n height: 32px;\n}\n.air-datepicker-nav--action path {\n fill: none;\n stroke: var(--adp-nav-arrow-color);\n stroke-width: 2px;\n}\n.air-datepicker-nav--title {\n border-radius: var(--adp-border-radius);\n padding: 0 8px;\n}\n.air-datepicker-nav--title i {\n font-style: normal;\n color: var(--adp-nav-color-secondary);\n margin-left: 0.3em;\n}\n.air-datepicker-nav--title:hover {\n background: var(--adp-background-color-hover);\n}\n.air-datepicker-nav--title:active {\n background: var(--adp-background-color-active);\n}\n.air-datepicker-nav--title.-disabled- {\n cursor: default;\n background: none;\n}\n.air-datepicker-buttons {\n display: grid;\n grid-auto-columns: 1fr;\n grid-auto-flow: column;\n}\n.air-datepicker-button {\n display: inline-flex;\n color: var(--adp-btn-color);\n border-radius: var(--adp-btn-border-radius);\n cursor: pointer;\n height: var(--adp-btn-height);\n border: none;\n background: rgba(255, 255, 255, 0);\n}\n.air-datepicker-button:hover {\n color: var(--adp-btn-color-hover);\n background: var(--adp-btn-background-color-hover);\n}\n.air-datepicker-button:focus {\n color: var(--adp-btn-color-hover);\n background: var(--adp-btn-background-color-hover);\n outline: none;\n}\n.air-datepicker-button:active {\n background: var(--adp-btn-background-color-active);\n}\n.air-datepicker-button span {\n outline: none;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n height: 100%;\n}\n.air-datepicker-time {\n display: grid;\n grid-template-columns: max-content 1fr;\n grid-column-gap: 12px;\n align-items: center;\n position: relative;\n padding: 0 var(--adp-time-padding-inner);\n}\n.-only-timepicker- .air-datepicker-time {\n border-top: none;\n}\n.air-datepicker-time--current {\n display: flex;\n align-items: center;\n flex: 1;\n font-size: 14px;\n text-align: center;\n}\n.air-datepicker-time--current-colon {\n margin: 0 2px 3px;\n line-height: 1;\n}\n.air-datepicker-time--current-hours,\n.air-datepicker-time--current-minutes {\n line-height: 1;\n font-size: 19px;\n font-family: 'Century Gothic', CenturyGothic, AppleGothic, sans-serif;\n position: relative;\n z-index: 1;\n}\n.air-datepicker-time--current-hours:after,\n.air-datepicker-time--current-minutes:after {\n content: '';\n background: var(--adp-background-color-hover);\n border-radius: var(--adp-border-radius);\n position: absolute;\n left: -2px;\n top: -3px;\n right: -2px;\n bottom: -2px;\n z-index: -1;\n opacity: 0;\n}\n.air-datepicker-time--current-hours.-focus-:after,\n.air-datepicker-time--current-minutes.-focus-:after {\n opacity: 1;\n}\n.air-datepicker-time--current-ampm {\n text-transform: uppercase;\n align-self: flex-end;\n color: var(--adp-time-day-period-color);\n margin-left: 6px;\n font-size: 11px;\n margin-bottom: 1px;\n}\n.air-datepicker-time--row {\n display: flex;\n align-items: center;\n font-size: 11px;\n height: 17px;\n background: linear-gradient(to right, var(--adp-time-track-color), var(--adp-time-track-color)) left 50%/100% var(--adp-time-track-height) no-repeat;\n}\n.air-datepicker-time--row:first-child {\n margin-bottom: 4px;\n}\n.air-datepicker-time--row input[type='range'] {\n background: none;\n cursor: pointer;\n flex: 1;\n height: 100%;\n width: 100%;\n padding: 0;\n margin: 0;\n -webkit-appearance: none;\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-thumb {\n -webkit-appearance: none;\n}\n.air-datepicker-time--row input[type='range']::-ms-tooltip {\n display: none;\n}\n.air-datepicker-time--row input[type='range']:hover::-webkit-slider-thumb {\n border-color: var(--adp-time-track-color-hover);\n}\n.air-datepicker-time--row input[type='range']:hover::-moz-range-thumb {\n border-color: var(--adp-time-track-color-hover);\n}\n.air-datepicker-time--row input[type='range']:hover::-ms-thumb {\n border-color: var(--adp-time-track-color-hover);\n}\n.air-datepicker-time--row input[type='range']:focus {\n outline: none;\n}\n.air-datepicker-time--row input[type='range']:focus::-webkit-slider-thumb {\n background: var(--adp-cell-background-color-selected);\n border-color: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-time--row input[type='range']:focus::-moz-range-thumb {\n background: var(--adp-cell-background-color-selected);\n border-color: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-time--row input[type='range']:focus::-ms-thumb {\n background: var(--adp-cell-background-color-selected);\n border-color: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-thumb {\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n border-radius: 3px;\n border: 1px solid var(--adp-time-track-color);\n background: #fff;\n cursor: pointer;\n -webkit-transition: background var(--adp-transition-duration);\n transition: background var(--adp-transition-duration);\n}\n.air-datepicker-time--row input[type='range']::-moz-range-thumb {\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n border-radius: 3px;\n border: 1px solid var(--adp-time-track-color);\n background: #fff;\n cursor: pointer;\n -moz-transition: background var(--adp-transition-duration);\n transition: background var(--adp-transition-duration);\n}\n.air-datepicker-time--row input[type='range']::-ms-thumb {\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n border-radius: 3px;\n border: 1px solid var(--adp-time-track-color);\n background: #fff;\n cursor: pointer;\n -ms-transition: background var(--adp-transition-duration);\n transition: background var(--adp-transition-duration);\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-thumb {\n margin-top: calc(var(--adp-time-thumb-size) / 2 * -1);\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-runnable-track {\n border: none;\n height: var(--adp-time-track-height);\n cursor: pointer;\n color: rgba(0, 0, 0, 0);\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-moz-range-track {\n border: none;\n height: var(--adp-time-track-height);\n cursor: pointer;\n color: rgba(0, 0, 0, 0);\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-ms-track {\n border: none;\n height: var(--adp-time-track-height);\n cursor: pointer;\n color: rgba(0, 0, 0, 0);\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-ms-fill-lower {\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-ms-fill-upper {\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker {\n --adp-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';\n --adp-font-size: 14px;\n --adp-width: 246px;\n --adp-z-index: 100;\n --adp-padding: 4px;\n --adp-grid-areas: 'nav' 'body' 'timepicker' 'buttons';\n --adp-transition-duration: 0.3s;\n --adp-transition-ease: ease-out;\n --adp-transition-offset: 8px;\n --adp-background-color: #fff;\n --adp-background-color-hover: #f0f0f0;\n --adp-background-color-active: #eaeaea;\n --adp-background-color-in-range: rgba(92, 196, 239, 0.1);\n --adp-background-color-in-range-focused: rgba(92, 196, 239, 0.2);\n --adp-background-color-selected-other-month-focused: #8ad5f4;\n --adp-background-color-selected-other-month: #a2ddf6;\n --adp-color: #4a4a4a;\n --adp-color-secondary: #9c9c9c;\n --adp-accent-color: #4eb5e6;\n --adp-color-current-date: var(--adp-accent-color);\n --adp-color-other-month: #dedede;\n --adp-color-disabled: #aeaeae;\n --adp-color-disabled-in-range: #939393;\n --adp-color-other-month-hover: #c5c5c5;\n --adp-border-color: #dbdbdb;\n --adp-border-color-inner: #efefef;\n --adp-border-radius: 4px;\n --adp-border-color-inline: #d7d7d7;\n --adp-nav-height: 32px;\n --adp-nav-arrow-color: var(--adp-color-secondary);\n --adp-nav-action-size: 32px;\n --adp-nav-color-secondary: var(--adp-color-secondary);\n --adp-day-name-color: #ff9a19;\n --adp-day-name-color-hover: #8ad5f4;\n --adp-day-cell-width: 1fr;\n --adp-day-cell-height: 32px;\n --adp-month-cell-height: 42px;\n --adp-year-cell-height: 56px;\n --adp-pointer-size: 10px;\n --adp-poiner-border-radius: 2px;\n --adp-pointer-offset: 14px;\n --adp-cell-border-radius: 4px;\n --adp-cell-background-color-hover: var(--adp-background-color-hover);\n --adp-cell-background-color-selected: #5cc4ef;\n --adp-cell-background-color-selected-hover: #45bced;\n --adp-cell-background-color-in-range: rgba(92, 196, 239, 0.1);\n --adp-cell-background-color-in-range-hover: rgba(92, 196, 239, 0.2);\n --adp-cell-border-color-in-range: var(--adp-cell-background-color-selected);\n --adp-btn-height: 32px;\n --adp-btn-color: var(--adp-accent-color);\n --adp-btn-color-hover: var(--adp-color);\n --adp-btn-border-radius: var(--adp-border-radius);\n --adp-btn-background-color-hover: var(--adp-background-color-hover);\n --adp-btn-background-color-active: var(--adp-background-color-active);\n --adp-time-track-height: 1px;\n --adp-time-track-color: #dedede;\n --adp-time-track-color-hover: #b1b1b1;\n --adp-time-thumb-size: 12px;\n --adp-time-padding-inner: 10px;\n --adp-time-day-period-color: var(--adp-color-secondary);\n --adp-mobile-font-size: 16px;\n --adp-mobile-nav-height: 40px;\n --adp-mobile-width: 320px;\n --adp-mobile-day-cell-height: 38px;\n --adp-mobile-month-cell-height: 48px;\n --adp-mobile-year-cell-height: 64px;\n}\n.air-datepicker-overlay {\n --adp-overlay-background-color: rgba(0, 0, 0, 0.3);\n --adp-overlay-transition-duration: 0.3s;\n --adp-overlay-transition-ease: ease-out;\n --adp-overlay-z-index: 99;\n}\n.air-datepicker {\n background: var(--adp-background-color);\n border: 1px solid var(--adp-border-color);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n border-radius: var(--adp-border-radius);\n box-sizing: content-box;\n display: grid;\n grid-template-columns: 1fr;\n grid-template-rows: repeat(4, max-content);\n grid-template-areas: var(--adp-grid-areas);\n font-family: var(--adp-font-family), sans-serif;\n font-size: var(--adp-font-size);\n color: var(--adp-color);\n width: var(--adp-width);\n position: absolute;\n transition:\n opacity var(--adp-transition-duration) var(--adp-transition-ease),\n transform var(--adp-transition-duration) var(--adp-transition-ease);\n z-index: var(--adp-z-index);\n}\n.air-datepicker:not(.-custom-position-) {\n opacity: 0;\n}\n.air-datepicker.-from-top- {\n transform: translateY(calc(var(--adp-transition-offset) * -1));\n}\n.air-datepicker.-from-right- {\n transform: translateX(var(--adp-transition-offset));\n}\n.air-datepicker.-from-bottom- {\n transform: translateY(var(--adp-transition-offset));\n}\n.air-datepicker.-from-left- {\n transform: translateX(calc(var(--adp-transition-offset) * -1));\n}\n.air-datepicker.-active-:not(.-custom-position-) {\n transform: translate(0, 0);\n opacity: 1;\n}\n.air-datepicker.-active-.-custom-position- {\n transition: none;\n}\n.air-datepicker.-inline- {\n border-color: var(--adp-border-color-inline);\n box-shadow: none;\n position: static;\n left: auto;\n right: auto;\n opacity: 1;\n transform: none;\n}\n.air-datepicker.-inline- .air-datepicker--pointer {\n display: none;\n}\n.air-datepicker.-is-mobile- {\n --adp-font-size: var(--adp-mobile-font-size);\n --adp-day-cell-height: var(--adp-mobile-day-cell-height);\n --adp-month-cell-height: var(--adp-mobile-month-cell-height);\n --adp-year-cell-height: var(--adp-mobile-year-cell-height);\n --adp-nav-height: var(--adp-mobile-nav-height);\n --adp-nav-action-size: var(--adp-mobile-nav-height);\n position: fixed;\n width: var(--adp-mobile-width);\n border: none;\n}\n.air-datepicker.-is-mobile- * {\n -webkit-tap-highlight-color: rgba(0, 0, 0, 0);\n}\n.air-datepicker.-is-mobile- .air-datepicker--pointer {\n display: none;\n}\n.air-datepicker.-is-mobile-:not(.-custom-position-) {\n transform: translate(-50%, calc(-50% + var(--adp-transition-offset)));\n}\n.air-datepicker.-is-mobile-.-active-:not(.-custom-position-) {\n transform: translate(-50%, -50%);\n}\n.air-datepicker.-custom-position- {\n transition: none;\n}\n.air-datepicker-global-container {\n position: absolute;\n left: 0;\n top: 0;\n}\n.air-datepicker--pointer {\n --pointer-half-size: calc(var(--adp-pointer-size) / 2);\n position: absolute;\n width: var(--adp-pointer-size);\n height: var(--adp-pointer-size);\n z-index: -1;\n}\n.air-datepicker--pointer:after {\n content: '';\n position: absolute;\n background: #fff;\n border-top: 1px solid var(--adp-border-color-inline);\n border-right: 1px solid var(--adp-border-color-inline);\n border-top-right-radius: var(--adp-poiner-border-radius);\n width: var(--adp-pointer-size);\n height: var(--adp-pointer-size);\n box-sizing: border-box;\n}\n.-top-left- .air-datepicker--pointer,\n.-top-center- .air-datepicker--pointer,\n.-top-right- .air-datepicker--pointer,\n[data-popper-placement^='top'] .air-datepicker--pointer {\n top: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-top-left- .air-datepicker--pointer:after,\n.-top-center- .air-datepicker--pointer:after,\n.-top-right- .air-datepicker--pointer:after,\n[data-popper-placement^='top'] .air-datepicker--pointer:after {\n transform: rotate(135deg);\n}\n.-right-top- .air-datepicker--pointer,\n.-right-center- .air-datepicker--pointer,\n.-right-bottom- .air-datepicker--pointer,\n[data-popper-placement^='right'] .air-datepicker--pointer {\n right: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-right-top- .air-datepicker--pointer:after,\n.-right-center- .air-datepicker--pointer:after,\n.-right-bottom- .air-datepicker--pointer:after,\n[data-popper-placement^='right'] .air-datepicker--pointer:after {\n transform: rotate(225deg);\n}\n.-bottom-left- .air-datepicker--pointer,\n.-bottom-center- .air-datepicker--pointer,\n.-bottom-right- .air-datepicker--pointer,\n[data-popper-placement^='bottom'] .air-datepicker--pointer {\n bottom: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-bottom-left- .air-datepicker--pointer:after,\n.-bottom-center- .air-datepicker--pointer:after,\n.-bottom-right- .air-datepicker--pointer:after,\n[data-popper-placement^='bottom'] .air-datepicker--pointer:after {\n transform: rotate(315deg);\n}\n.-left-top- .air-datepicker--pointer,\n.-left-center- .air-datepicker--pointer,\n.-left-bottom- .air-datepicker--pointer,\n[data-popper-placement^='left'] .air-datepicker--pointer {\n left: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-left-top- .air-datepicker--pointer:after,\n.-left-center- .air-datepicker--pointer:after,\n.-left-bottom- .air-datepicker--pointer:after,\n[data-popper-placement^='left'] .air-datepicker--pointer:after {\n transform: rotate(45deg);\n}\n.-top-left- .air-datepicker--pointer,\n.-bottom-left- .air-datepicker--pointer {\n left: var(--adp-pointer-offset);\n}\n.-top-right- .air-datepicker--pointer,\n.-bottom-right- .air-datepicker--pointer {\n right: var(--adp-pointer-offset);\n}\n.-top-center- .air-datepicker--pointer,\n.-bottom-center- .air-datepicker--pointer {\n left: calc(50% - var(--adp-pointer-size) / 2);\n}\n.-left-top- .air-datepicker--pointer,\n.-right-top- .air-datepicker--pointer {\n top: var(--adp-pointer-offset);\n}\n.-left-bottom- .air-datepicker--pointer,\n.-right-bottom- .air-datepicker--pointer {\n bottom: var(--adp-pointer-offset);\n}\n.-left-center- .air-datepicker--pointer,\n.-right-center- .air-datepicker--pointer {\n top: calc(50% - var(--adp-pointer-size) / 2);\n}\n.air-datepicker--navigation {\n grid-area: nav;\n}\n.air-datepicker--content {\n box-sizing: content-box;\n padding: var(--adp-padding);\n grid-area: body;\n}\n.-only-timepicker- .air-datepicker--content {\n display: none;\n}\n.air-datepicker--time {\n grid-area: timepicker;\n}\n.air-datepicker--buttons {\n grid-area: buttons;\n}\n.air-datepicker--buttons,\n.air-datepicker--time {\n padding: var(--adp-padding);\n border-top: 1px solid var(--adp-border-color-inner);\n}\n.air-datepicker-overlay {\n position: fixed;\n background: var(--adp-overlay-background-color);\n left: 0;\n top: 0;\n width: 0;\n height: 0;\n opacity: 0;\n transition:\n opacity var(--adp-overlay-transition-duration) var(--adp-overlay-transition-ease),\n left 0s,\n height 0s,\n width 0s;\n transition-delay: 0s, var(--adp-overlay-transition-duration), var(--adp-overlay-transition-duration), var(--adp-overlay-transition-duration);\n z-index: var(--adp-overlay-z-index);\n}\n.air-datepicker-overlay.-active- {\n opacity: 1;\n width: 100%;\n height: 100%;\n transition:\n opacity var(--adp-overlay-transition-duration) var(--adp-overlay-transition-ease),\n height 0s,\n width 0s;\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {format} from 'date-fns';\nimport {getRGBA} from '@verdocs/js-sdk';\nimport AirDatepicker from 'air-datepicker';\nimport localeEn from 'air-datepicker/locale/en';\nimport type {ITemplateField} from '@verdocs/js-sdk';\nimport {Component, Element, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {FORMAT_DATE} from '../../../utils/Types';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a date field. When tapped or clicked, the input element will display a date picker component.\n */\n@Component({\n tag: 'verdocs-field-date',\n styleUrl: 'verdocs-field-date.scss',\n shadow: false,\n})\nexport class VerdocsFieldDate {\n @Element()\n private hostEl: HTMLInputElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop() field?: ITemplateField;\n\n /**\n * Event fired on every character entered into / deleted from the field.\n */\n @Event({composed: true}) settingsPress: EventEmitter;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() containerId = `verdocs-date-picker-${Math.random().toString(36).substring(2, 11)}`;\n\n @State() showingProperties?: boolean = false;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n this.picker?.show();\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n picker: AirDatepicker<HTMLElement> | null = null;\n\n componentDidLoad() {\n console.log('Activating date picker', this.containerId, document.getElementById(this.containerId));\n this.picker = new AirDatepicker<HTMLElement>(`#${this.containerId}`, {\n locale: localeEn,\n isMobile: true,\n autoClose: true,\n onShow: () => (this.focused = true),\n onHide: () => (this.focused = false),\n onSelect: ({date, formattedDate}) => {\n const event = new CustomEvent('fieldChange', {detail: {date, formattedDate}});\n this.hostEl.dispatchEvent(event);\n },\n });\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n @State() focused?: boolean = false;\n\n // NOTE: We don't use a \"date\" field here because browsers vary widely in their formatting of it.\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n console.log('Rendering date picker', source, sourceid, fieldname);\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, placeholder = 'Date...', value = '', label = ''} = field || {};\n const backgroundColor = getRGBA(index);\n\n const formattedValue = value ? format(new Date(value), FORMAT_DATE) : '';\n\n if (this.done) {\n return <Host class={{done}}>{formattedValue}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <input\n name={fieldname}\n class=\"input-el\"\n type=\"text\"\n value={formattedValue}\n id={this.containerId}\n disabled={disabled}\n placeholder={placeholder}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${field.name}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Date fields allow the user to select a date.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-dropdown {\n font-family: $verdocs-primary-font;\n width: 85px;\n height: 20px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n\n label {\n top: -14px;\n left: 0;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n select {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n position: absolute;\n background: linear-gradient(55deg, transparent 50%, #333 50%), linear-gradient(125deg, #333 50%, transparent 50%), linear-gradient(to right, transparent, transparent);\n background-position:\n calc(100% - 7px) 6px,\n calc(100% - 3px) 6px,\n 100% 0;\n background-size:\n 5px 5px,\n 5px 5px,\n 2.5em 2.5em;\n background-repeat: no-repeat;\n appearance: none;\n\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n font-size: 11px;\n border: 1px solid rgba(0, 0, 0, 0.2);\n padding: 0 5px;\n\n &:focus {\n outline: none;\n }\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled select {\n opacity: 0.5;\n }\n\n &.required {\n select {\n border: 1px solid $verdocs-red-1;\n }\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n display: block;\n margin-left: -33px;\n margin-top: -1px;\n transform: scale(0.7);\n }\n\n .settings-icon {\n position: absolute;\n top: -2px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a dropdown field that allows the user to choose one of a list of options.\n */\n@Component({\n tag: 'verdocs-field-dropdown',\n styleUrl: 'verdocs-field-dropdown.scss',\n shadow: false,\n})\nexport class VerdocsFieldDropdown {\n selectEl: HTMLSelectElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the input field value changes. Note that this will only be fired on blur, tab-out, ENTER key press, etc.\n * It is generally the best event to subscribe to than `input` for most cases EXCEPT autocomplete fields that need to see every\n * keypress.\n */\n @Event({composed: true}) fieldChange: EventEmitter<string>;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused = false;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n\n this.selectEl?.showPicker();\n }\n\n handleChange(e: any) {\n this.fieldChange.emit(e.target.value);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n let {required = false, value = '', label = '', options} = field || {};\n const backgroundColor = getRGBA(index);\n\n if (done) {\n return <Host class={{done}}>{value}</Host>;\n }\n\n // TODO: Look for other places this mistaken assumption was made.\n // Defaults only apply in destructuring if undefined. null doesn't trigger it.\n options ||= [];\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <select disabled={disabled} onChange={e => this.handleChange(e)} ref={el => (this.selectEl = el as HTMLSelectElement)}>\n <option value=\"\">Select...</option>\n {options.map(option => (\n <option value={option.id} selected={option.id === value}>\n {option.label}\n </option>\n ))}\n {!options.length && <option value=\"NA\">N/A</option>}\n </select>\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"Dropdowns are used to capture a recipient's selection of one of several options.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-initial {\n font-family: $verdocs-primary-font;\n width: 83px;\n height: 36px;\n display: block;\n font-size: 11px;\n position: relative;\n letter-spacing: 0.3px;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.done {\n border: none;\n opacity: 1;\n }\n\n img {\n display: block;\n max-width: 100%;\n max-height: 100%;\n }\n\n &.disabled img {\n opacity: 0.5;\n }\n\n button {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n box-sizing: border-box;\n border: none;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n background: none;\n font-size: 11px;\n\n &.hide {\n display: none;\n }\n }\n\n &.required {\n border: 1px solid $verdocs-red-1;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays an initial field. If an initial already exists, it will be displayed and the field\n * will be disabled. Otherwise, a placeholder button will be shown. Clicking the button will\n * show a dialog to adopt an initial.\n *\n * NOTE: When initial fields are completed they will be filled with an initial \"stamp\".\n * This requires operation against a live, valid envelope. If you are testing this component\n * in Storybook, it will not be visible here.\n */\n@Component({\n tag: 'verdocs-field-initial',\n styleUrl: 'verdocs-field-initial.scss',\n shadow: false,\n})\nexport class VerdocsFieldInitial {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * The document or template field to display.\n */\n @Prop({reflect: true}) initials: string = '';\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event emitted when an initial block is adopted by the user. The event detail will contain the base64 string of the initial image.\n */\n @Event({composed: true}) adopt: EventEmitter<string>;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n /**\n * Event fired when the input field value changes. Note that this will only be fired on blur, tab-out, ENTER key press, etc.\n * It is generally the best event to subscribe to than `input` for most cases EXCEPT autocomplete fields that need to see every\n * keypress.\n */\n @Event({composed: true}) fieldChange: EventEmitter<string>;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired on every character entered into / deleted from the field.\n */\n @Event({composed: true}) settingsPress: EventEmitter;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method() async focusField() {\n this.handleShow();\n }\n\n @State()\n tempInitials: string = '';\n\n private dialog?: any;\n\n hideDialog() {\n this.dialog?.remove();\n this.dialog = null;\n this.focused = false;\n }\n\n handleAdopt(e: any) {\n console.log('[INITIAL] Adopted initials');\n this.tempInitials = e.detail;\n this.fieldChange?.emit(this.tempInitials);\n this.hideDialog();\n }\n\n handleShow() {\n this.dialog = document.createElement('verdocs-initial-dialog');\n this.dialog.setAttribute('initials', this.initials);\n // this.dialog.setAttribute('roleindex', this.roleindex);\n this.dialog.addEventListener('exit', () => this.hideDialog());\n this.dialog.addEventListener('next', (e: any) => this.handleAdopt(e));\n document.body.append(this.dialog);\n this.focused = true;\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, value = '', label = '', settings = {}} = field || {};\n const backgroundColor = getRGBA(index);\n const {base64} = settings;\n\n if (done) {\n return <Host class={{done}}>{value && <img src={value} alt=\"Initial\" />}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n {base64 ? <img src={base64} alt=\"Initial\" /> : <button onClick={() => !disabled && this.handleShow()}>Initial</button>}\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: field.name});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"initial fields capture the recipient's initials on a clause or page.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\n// See https://www.sliderrevolution.com/resources/styling-radio-buttons/\nverdocs-field-radio {\n font-family: $verdocs-primary-font;\n width: 14px;\n height: 14px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n border-radius: 100%;\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n svg {\n margin-top: 4px;\n }\n\n &.disabled.done {\n opacity: 1;\n }\n\n // To avoid conflicting with the use of a label for the checkbox itself\n div.label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n div.group {\n top: 14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #bb0589;\n border-bottom-left-radius: 2px;\n border-bottom-right-radius: 2px;\n }\n\n input {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n }\n\n &.disabled input {\n opacity: 0.5;\n }\n\n &.done input[type='radio'] {\n margin: 0;\n padding: 0;\n width: 10px;\n height: 10px;\n }\n\n &:not(.done) input[type='radio'] {\n position: absolute;\n opacity: 0;\n\n + label {\n &:before {\n content: '';\n //background: $verdocs-grey-3;\n border-radius: 100%;\n border: 1px solid rgba(0, 0, 0, 0.6);\n display: inline-block;\n width: 12px;\n height: 12px;\n position: absolute;\n left: 0;\n top: 0;\n cursor: pointer;\n text-align: center;\n transition: all 250ms ease;\n }\n }\n\n &:checked {\n + label {\n &:before {\n background-color: $verdocs-green;\n box-shadow: inset 0 0 0 2px $verdocs-grey-3;\n }\n }\n }\n\n &:focus {\n + label {\n &:before {\n outline: none;\n border-color: $verdocs-green;\n }\n }\n }\n\n &:disabled {\n + label {\n &:before {\n box-shadow: inset 0 0 0 4px $verdocs-grey-3;\n border-color: darken($verdocs-grey-3, 25%);\n background: darken($verdocs-grey-3, 25%);\n }\n }\n }\n\n + label {\n &:empty {\n &:before {\n margin-right: 0;\n }\n }\n }\n }\n\n &.required {\n border: 1px solid $verdocs-red-1;\n }\n\n &.hide {\n display: none;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n margin-left: -20px;\n margin-top: -7px;\n transform: scale(0.7);\n }\n\n .settings-icon {\n position: absolute;\n top: -6px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\nconst RadioIconUnselected = `<svg focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\"><path d=\"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"></path></svg>`;\n\nconst RadioIconSelected = `<svg focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\"><path d=\"M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5zm0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"></path></svg>`;\n\n/**\n * Displays a radio button.\n */\n@Component({\n tag: 'verdocs-field-radio',\n styleUrl: 'verdocs-field-radio.scss',\n shadow: false,\n})\nexport class VerdocsFieldRadio {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used in Storybook mode.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, overrides the field's required object. Primarily used in Storybook mode.\n */\n @Prop({reflect: true}) required?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n @State() showingProperties?: boolean = false;\n @State() focused = false;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {name, required = false, label = '', group = '', value = false} = field || {};\n const backgroundColor = getRGBA(index);\n\n const selected = value === 'true';\n\n if (done) {\n return (\n <Host class={{done}} style={{maxWidth: '10px'}}>\n <span innerHTML={selected ? RadioIconSelected : RadioIconUnselected} />\n </Host>\n );\n }\n\n return (\n <Host class={{required: this.required || required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <div class=\"label\">{label}</div>}\n {editable && group && <div class=\"group\">{group}</div>}\n\n <input id={fieldname} type=\"radio\" name={group || fieldname} value={name} checked={!!selected} disabled={disabled} required={required} />\n <label htmlFor={fieldname} />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"Radio buttons capture the recipient's selection of just one of several related (exclusive) options.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-signature {\n font-family: $verdocs-primary-font;\n width: 83px;\n height: 36px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n letter-spacing: 0.3px;\n background-color: transparent;\n transform-origin: bottom left;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.done {\n border: none;\n opacity: 1;\n }\n\n img {\n display: block;\n max-width: 100%;\n max-height: 100%;\n }\n\n &.disabled img {\n opacity: 0.5;\n }\n\n button {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n box-sizing: border-box;\n border: none;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n background: none;\n font-size: 11px;\n\n &.hide {\n display: none;\n }\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Event, EventEmitter, Method, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a signature field. If a signature already exists, it will be displayed and the field\n * will be disabled. Otherwise, a placeholder button will be shown. Clicking the button will\n * show a dialog to adopt a signature.\n *\n * NOTE: When signature fields are completed they will be filled with a signature \"stamp\".\n * This requires operation against a live, valid envelope. If you are testing this component\n * in Storybook, it will not be visible here.\n */\n@Component({\n tag: 'verdocs-field-signature',\n styleUrl: 'verdocs-field-signature.scss',\n shadow: false,\n})\nexport class VerdocsFieldSignature {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, the signature creation dialog will be initialized with this text.\n */\n @Prop({reflect: true}) name?: string = '';\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event emitted when the field has changed.\n */\n @Event({composed: true}) fieldChange: EventEmitter<string>;\n\n /**\n * Event fired on every character entered into / deleted from the field.\n */\n @Event({composed: true}) settingsPress: EventEmitter;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method() async focusField() {\n this.handleShow();\n }\n\n @State()\n tempSignature: string = '';\n\n private dialog?: any;\n\n hideDialog() {\n this.dialog?.remove();\n this.dialog = null;\n this.focused = false;\n }\n\n handleAdopt(e: any) {\n console.log('[SIGNATURE] Adopted signature');\n this.tempSignature = e.detail;\n this.fieldChange?.emit(this.tempSignature);\n this.hideDialog();\n }\n\n handleShow() {\n this.dialog = document.createElement('verdocs-signature-dialog');\n this.dialog.setAttribute('name', this.name);\n // this.dialog.setAttribute('roleindex', this.roleindex);\n this.dialog.addEventListener('exit', () => this.hideDialog());\n this.dialog.addEventListener('next', (e: any) => this.handleAdopt(e));\n document.body.append(this.dialog);\n this.focused = true;\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n this.showingProperties = false;\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, value = '', label = '', settings = {}} = field || {};\n const {base64} = settings;\n const backgroundColor = getRGBA(index);\n\n if (done) {\n return <Host class={{done}}>{value && <img src={base64} alt=\"\" />}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n {base64 ? <img src={base64} alt=\"\" /> : <button onClick={() => !disabled && this.handleShow()}>Signature</button>}\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => this.hideSettingsPanel()}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"Signature fields capture a recipient's signature on a document.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-textarea {\n width: 150px;\n height: 15px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n box-sizing: border-box;\n background-color: transparent;\n transform-origin: bottom left;\n font-family: $verdocs-primary-font;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n textarea {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 100%;\n height: 100%;\n resize: none;\n border: none;\n outline: none;\n padding: 0 3px;\n font-size: 11px;\n background: none;\n font-weight: 500;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled textarea {\n opacity: 0.5;\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import interact from 'interactjs';\nimport {IEnvelopeField, VerdocsEndpoint} from '@verdocs/js-sdk';\nimport {ITemplateField, updateField, getRGBA} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Method, Event, EventEmitter, Element, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Display a multi-line text input field. Reminder: the \"position\" of the field is specified\n * as the BOTTOM-LEFT corner.\n */\n@Component({\n tag: 'verdocs-field-textarea',\n styleUrl: 'verdocs-field-textarea.scss',\n shadow: false,\n})\nexport class VerdocsFieldTextarea {\n @Element() el: HTMLElement;\n private inputEl: HTMLTextAreaElement;\n\n /**\n * The endpoint to use to communicate with Verdocs. If not set, the default endpoint will be used.\n * This component self-manages its resize (width) behavior when in edit-template mode, and uses\n * this endpoint to save changes.\n */\n @Prop() endpoint: VerdocsEndpoint = VerdocsEndpoint.getDefault();\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n @Method()\n async focusField() {\n this.inputEl.focus();\n }\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n @State() focused?: boolean = false;\n\n componentDidRender() {\n interact.dynamicDrop(true);\n\n if (this.editable) {\n interact(this.el).resizable({\n edges: {top: true, bottom: true, left: true, right: true},\n listeners: {\n start: this.handleResizeStart.bind(this),\n move: this.handleResize.bind(this),\n end: this.handleResizeEnd.bind(this),\n },\n });\n }\n }\n\n handleResizeStart(e: any) {\n e.preventDefault();\n e.stopPropagation();\n }\n\n handleResize(e: any) {\n let {x = 0, y = 0, h = 0} = e.target.dataset;\n let {width, height} = e.rect;\n\n x = (parseFloat(x) || 0) + e.deltaRect.left;\n y = (parseFloat(y) || 0) + e.deltaRect.top;\n h = (parseFloat(h) || 0) + e.deltaRect.height;\n\n Object.assign(e.target.style, {\n width: `${width}px`,\n height: `${height}px`,\n transform: `translate(${x}px, ${y + h}px)`,\n });\n\n Object.assign(e.target.dataset, {x, y, h});\n }\n\n handleResizeEnd(e: any) {\n const {source, sourceid, fieldname} = this;\n const {field} = Store.getField(source, sourceid, fieldname, this.field);\n if (!field) {\n return;\n }\n\n const [translateX, translateY] = e.target.style.transform.split('(')[1].split(')')[0].split(',').map(parseFloat);\n\n const width = Math.round(parseFloat(e.target.style.width) / this.xscale);\n const height = Math.round(parseFloat(e.target.style.height) / this.yscale);\n const x = Math.round(field.x + translateX / this.xscale);\n const y = Math.round(field.y - translateY / this.yscale);\n\n updateField(this.endpoint, this.sourceid, this.fieldname, {x, y, width, height})\n .then(field => {\n this.settingsChanged?.emit({fieldName: this.fieldname, field});\n Object.assign(e.target.dataset, {x: 0, y: 0, h: 0});\n })\n .catch(e => console.log('Field update failed', e));\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, placeholder = '', value = '', label = ''} = field || {};\n const backgroundColor = getRGBA(index);\n\n if (done) {\n return <Host class={{done}}>{value}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <textarea\n name={fieldname}\n disabled={disabled}\n required={required}\n placeholder={placeholder}\n ref={el => (this.inputEl = el)}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n >\n {value}\n </textarea>\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Text areas may be used to create multi-line text fields.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-textbox {\n font-family: $verdocs-primary-font;\n box-sizing: border-box;\n width: 150px;\n height: 15px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n letter-spacing: -0.2px;\n background-color: transparent;\n transform-origin: bottom left;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n .edge-top,\n .edge-right,\n .edge-left,\n .edge-bottom {\n position: absolute;\n z-index: 10;\n }\n\n .edge-top {\n top: -2px;\n left: 0;\n right: 0;\n height: 5px;\n }\n\n .edge-right {\n top: 0;\n bottom: 0;\n right: -2px;\n width: 5px;\n }\n\n .edge-left {\n top: 0;\n left: -2px;\n bottom: 0;\n width: 5px;\n }\n\n .edge-bottom {\n bottom: -2px;\n left: 0;\n right: 0;\n height: 5px;\n }\n\n input {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 100%;\n height: 100%;\n border: none;\n outline: none;\n padding: 0 3px;\n font-size: 11px;\n background: none;\n font-weight: 500;\n position: absolute;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled input {\n opacity: 0.5;\n }\n\n textarea {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 100%;\n height: 100%;\n resize: none;\n border: none;\n outline: none;\n padding: 0 3px;\n font-size: 11px;\n background: none;\n font-weight: 500;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled textarea {\n opacity: 0.5;\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n // @see https://community.logmein.com/t5/LastPass-Support-Discussions/placeholder-text-overrides-data-lpignore-quot-true-quot/td-p/295135\n // LastPass is ignoring the data-lpignore attribute in some cases\n [data-lastpass-icon-root] {\n display: none !important;\n }\n\n .settings-icon {\n position: absolute;\n top: -4px;\n left: -18px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import interact from 'interactjs';\nimport {getRGBA, IEnvelopeField, ITemplateField, updateField, VerdocsEndpoint} from '@verdocs/js-sdk';\nimport {Component, h, Host, Element, Prop, Method, Event, EventEmitter, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Display a simple 1-line text input field.\n */\n@Component({\n tag: 'verdocs-field-textbox',\n styleUrl: 'verdocs-field-textbox.scss',\n shadow: false,\n})\nexport class VerdocsFieldTextbox {\n @Element() el: HTMLElement;\n private inputEl: HTMLInputElement | HTMLTextAreaElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) multiline?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method()\n async focusField() {\n this.inputEl.focus();\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n this.showingProperties = false;\n }\n\n componentDidRender() {\n interact.dynamicDrop(true);\n\n if (this.editable) {\n interact(this.el).resizable({\n edges: {\n top: '.edge-top',\n left: '.edge-left',\n bottom: '.edge-bottom',\n right: '.edge-right',\n },\n modifiers: [\n interact.modifiers.restrictSize({\n min: {width: 30, height: 15},\n }),\n ],\n listeners: {\n start: this.handleResizeStart.bind(this),\n move: this.handleResize.bind(this),\n end: this.handleResizeEnd.bind(this),\n },\n });\n }\n }\n\n handleResizeStart(e: any) {\n e.preventDefault();\n e.stopPropagation();\n }\n\n handleResize(e: any) {\n let {width, height} = e.rect;\n\n const dX = e.deltaRect.left;\n const dY = e.deltaRect.bottom;\n const currentLeft = parseFloat(e.target.style.left);\n const currentBottom = parseFloat(e.target.style.bottom);\n\n width /= this.xscale;\n height /= this.yscale;\n\n Object.assign(e.target.style, {\n width: `${width}px`,\n height: `${height}px`,\n left: `${currentLeft + dX}px`,\n bottom: `${currentBottom - dY}px`,\n });\n }\n\n handleResizeEnd(e: any) {\n const {sourceid, fieldname} = this;\n\n const width = Math.round(parseFloat(e.target.style.width));\n let height = Math.round(parseFloat(e.target.style.height));\n\n if (height < 20) {\n height = 15;\n }\n const multiline = height > 15;\n\n updateField(VerdocsEndpoint.getDefault(), sourceid, fieldname, {width, height, multiline})\n .then(async updatedField => {\n const template = await Store.getTemplate(VerdocsEndpoint.getDefault(), this.sourceid);\n const newTemplate = JSON.parse(JSON.stringify(template));\n const fieldIndex = newTemplate.fields.findIndex(field => field.name === fieldname);\n if (fieldIndex > -1) {\n newTemplate.fields[fieldIndex] = updatedField;\n }\n Store.updateTemplate(this.sourceid, newTemplate);\n\n this.settingsChanged?.emit({fieldName: fieldname, field: updatedField});\n Object.assign(e.target.dataset, {x: 0, y: 0, h: 0});\n })\n .catch(e => console.log('Field update failed', e));\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n let {required = false, placeholder = '', label = '', width = 150, default: value = '', multiline = false} = field || {};\n const backgroundColor = getRGBA(index);\n\n // TODO: Consolidate value/defaultValue handling between template and envelope fields.\n if ((field as any)?.value) {\n value = (field as any)?.value;\n }\n\n // TODO: This is an outdated technique from the old system. We should compute it.\n const maxlength = width / 5;\n\n if (done) {\n return <Host class={{done}}>{value}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {editable && <div class=\"edge-top\" />}\n {editable && <div class=\"edge-right\" />}\n {editable && <div class=\"edge-left\" />}\n {editable && <div class=\"edge-bottom\" />}\n\n {label && <label>{label}</label>}\n\n {multiline ? (\n <textarea\n name={fieldname}\n disabled={disabled}\n required={required}\n placeholder={placeholder}\n ref={el => (this.inputEl = el)}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n >\n {value}\n </textarea>\n ) : (\n <input\n type=\"text\"\n name={fieldname}\n value={value}\n disabled={disabled}\n required={required}\n placeholder={placeholder}\n maxlength={maxlength}\n ref={el => (this.inputEl = el)}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n />\n )}\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => this.hideSettingsPanel()}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\n 'Text boxes may be used to capture simple text input. Participant-entered values will be stored for later retrieval via the \"name\" field.<br /><br />If marked required, the participant must complete the field before proceeding.'\n }\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-timestamp {\n width: 160px;\n height: 15px;\n display: block;\n font-size: 9px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n font-family: $verdocs-primary-font;\n\n &.done {\n opacity: 1;\n }\n\n input {\n position: absolute;\n\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n opacity: 0.5;\n width: 100%;\n height: 100%;\n font-size: 9px;\n background: none;\n font-weight: 500;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n &.hide {\n display: none;\n }\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n","import {format} from 'date-fns/format';\nimport {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Method, Event, EventEmitter, Fragment, State} from '@stencil/core';\nimport {FORMAT_TIMESTAMP} from '../../../utils/Types';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Display a timestamp. Timestamps are not editable by signers. Instead, they are automatically\n * filled when the signer submits the document.\n */\n@Component({\n tag: 'verdocs-field-timestamp',\n styleUrl: 'verdocs-field-timestamp.scss',\n shadow: false,\n})\nexport class VerdocsFieldTimestamp {\n private el: HTMLInputElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop() pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n\n @Method() async focusField() {\n this.el.focus();\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n this.showingProperties = false;\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, placeholder = '', value = '', label = ''} = field || {};\n const backgroundColor = getRGBA(index);\n\n const formatted = format(new Date(value || new Date().toISOString()), FORMAT_TIMESTAMP);\n\n if (done) {\n return <Host class={{done}}>{formatted}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n <input type=\"text\" placeholder={placeholder} value={formatted} disabled={true} ref={el => (this.el = el)} />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => this.hideSettingsPanel()}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Time stamps are automatically set when the recipient signs the document.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-initial-dialog {\n font-family: $primary-font;\n box-sizing: border-box;\n position: fixed;\n z-index: 10000;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n background: #0000007f;\n\n .dialog {\n width: 100%;\n max-width: 340px;\n border-radius: 4px;\n overflow: hidden;\n box-shadow: 3px 3px 5px 1px rgba(40, 40, 40, 0.4);\n background: $dialog-bg;\n }\n\n .heading {\n display: flex;\n flex-direction: row;\n padding: 20px 20px 0 20px;\n line-height: 28px;\n font-size: 20px;\n font-weight: 500;\n }\n\n .content {\n font-size: 14px;\n padding: 20px;\n }\n\n .buttons {\n display: flex;\n margin: 20px 0 0 0;\n flex-direction: row;\n justify-content: flex-end;\n align-items: center;\n\n verdocs-button {\n margin-left: 16px;\n }\n }\n\n canvas {\n background: #fff;\n box-sizing: border-box;\n margin: 0 auto;\n width: 300px;\n // TODO: The original app had an aspect ratio of (80 / 305) * (signatureBodyWidth - 20)\n height: 79px;\n max-width: 100%;\n box-shadow: 0 0 6px 0 #0000001f;\n }\n\n .disclaimer {\n text-align: justify;\n padding: 8px 0;\n font-size: 11px;\n line-height: 14px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .as-shown {\n font-size: 11px;\n margin: 4px 0 20px 4px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .tabs {\n display: flex;\n flex-direction: row;\n\n .tab {\n padding: 8px 15px;\n cursor: pointer;\n\n &.active {\n border-bottom: 2px solid $light-border-color;\n }\n\n &:hover {\n color: $primary-color;\n }\n }\n }\n}\n","import {Component, Prop, Host, h, Event, EventEmitter, State} from '@stencil/core';\n\n/**\n * Display a dialog that allows the user to specify an initials image, either by using a signature-font-generated image\n * based on their full name, or by hand-drawing their initials with a mouse or tablet.\n */\n@Component({\n tag: 'verdocs-initial-dialog',\n styleUrl: 'verdocs-initial-dialog.scss',\n})\nexport class VerdocsInitialDialog {\n private canvasElement?: HTMLCanvasElement;\n\n /**\n * Initial signature text\n */\n @Prop() initials: string = '';\n\n /**\n * Event fired when the initials are adopted.\n */\n @Event({composed: true}) next: EventEmitter<string>;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n @State() fontLoaded = false;\n\n @State() enteredInitials: string = '';\n\n @State() mode: string = 'type';\n\n componentWillLoad() {\n this.enteredInitials = this.initials.toUpperCase();\n\n const ds = new FontFace('Dancing Script', 'url(https://fonts.gstatic.com/s/dancingscript/v19/If2cXTr6YS-zF4S-kcSWSVi_sxjsohD9F50Ruu7BMSo3Sup6hNX6plRP.woff)');\n ds.load().then(font => {\n document.fonts.add(font);\n this.fontLoaded = true;\n });\n }\n\n componentDidLoad() {\n this.redrawSignature();\n }\n\n componentDidUpdate() {\n this.redrawSignature();\n }\n\n redrawSignature() {\n console.log('redrawing sig');\n if (!this.canvasElement) {\n console.log('no canvas');\n return;\n }\n\n const canvasWidth = this.canvasElement.width;\n console.log('cw', canvasWidth);\n\n const context = this.canvasElement.getContext('2d');\n context.clearRect(0, 0, this.canvasElement.width, this.canvasElement.height);\n\n let fontSize = 100;\n do {\n fontSize -= 2;\n context.font = `${fontSize}px Dancing Script`;\n } while (context.measureText(this.enteredInitials).width > canvasWidth - 32); // 32px padding each side\n\n context.textAlign = 'center';\n context.textBaseline = 'middle';\n context.font = `${fontSize}px Dancing Script`;\n context.fillText(this.enteredInitials, this.canvasElement.width / 2, this.canvasElement.height / 2);\n }\n\n handleNameChange(e: any) {\n this.enteredInitials = e.target.value;\n }\n\n handleCancel(e: any) {\n e.stopPropagation();\n e.preventDefault();\n this.exit.emit();\n }\n\n handleAdopt(e: any) {\n e.stopPropagation();\n e.preventDefault();\n const data = this.canvasElement.toDataURL('image/png');\n this.next.emit(data);\n }\n\n /*\n selColor(hex: string) {\n this.color = hex;\n this.animateDraw();\n }\n\n stopDraw() {\n this.paint = false;\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n draw(e) {\n this.paint = true;\n this.addPoints(e, false);\n this.animateDraw();\n }\n\n recordPoints(e) {\n if (this.paint) {\n this.addPoints(e, true);\n this.animateDraw();\n }\n }\n\n animateDraw() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n\n this.canvas.strokeStyle = this.color || '#000000';\n this.canvas.lineJoin = 'round';\n this.canvas.lineWidth = 3;\n\n for (let i = 0; i < this.points.length; i++) {\n this.canvas.beginPath();\n if (this.points[i].drag && i) {\n this.canvas.moveTo(this.points[i - 1].x, this.points[i - 1].y);\n // this.canvas.arc(this.points[i - 1].x, this.points[i - 1].y, 2, 0, 2 * Math.PI, false);\n } else {\n this.canvas.moveTo(this.points[i].x - 1, this.points[i].y);\n // this.canvas.arc(this.points[i].x, this.points[i].y, 2, 0, 2 * Math.PI, false);\n }\n\n this.canvas.lineTo(this.points[i].x, this.points[i].y);\n this.canvas.closePath();\n this.canvas.stroke();\n }\n }\n\n drawCurve(color: string, curve: number) {\n this.canvas.beginPath();\n }\n\n\n\n addPoints(e, drag: boolean) {\n if (window) {\n let x;\n let y;\n e.preventDefault();\n if (e.touches && e.touches.length > 0) {\n x = e.touches[0].clientX;\n } else {\n x = e.clientX;\n }\n\n if (e.touches && e.touches.length > 0) {\n y = e.touches[0].clientY;\n } else {\n y = e.clientY;\n }\n const rect = this.signatureCanvas.nativeElement.getBoundingClientRect();\n this.points.push({\n x: x - rect.left,\n y: y - rect.top,\n drag: drag\n });\n }\n }\n\n clearPad() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n this.points = [];\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n async adoptAndSign() {\n try {\n this.adoptedAndSigned = true;\n await this.updateFullName();\n await this.captureSignatureFromCanvas();\n const message = this.signatureMode === 'Signature' ? 'Saving Signature' : 'Saving Initial';\n this.snackbarService.open(message, 'OK', this.snackbarService.initConfig(null, 'bottom'));\n this.handleMode();\n } catch (err) {\n this.snackbarService.open('Failed to apply signature', 'OK', this.snackbarService.initConfig(null, 'bottom'));\n }\n }\n\n handleMode() {\n let currentField;\n switch (this.mode) {\n case 'signerview':\n if (this.signatureMode === 'Signature') {\n this.signatureService.postSignatureBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateSigned(currentField.fName, true);\n this.signatureService.toggleSig(false);\n this.signatureService.setSignatureId(result.id);\n this.signatureService.putSignatureField(this.envelopeId, this.fieldName, result.id).then(res => {\n this.eventTracker.createEvent({\n category: 'verdoc',\n action: 'verdoc signed',\n label: `verdoc id: ${this.envelopeId}`\n })\n if (res && res.settings) {\n this.signatureService.setSignatureData(res.settings.base64);\n this.signatureService.setSignatureId(res.settings.signature_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_sig: res.settings.base64, sig_id: res.settings.signature_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save signature. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n } else {\n this.signatureService.postInitialBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateInitialed(currentField.fName, true);\n this.signatureService.setInitialId(result.id);\n this.signatureService.toggleSig(false);\n this.signatureService.putInitialField(this.envelopeId, this.fieldName, result.id).then(res => {\n if (res && res.settings) {\n this.signatureService.setInitialData(res.settings.base64);\n this.signatureService.setInitialId(res.settings.initial_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_int: res.settings.base64, int_id: res.settings.initial_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save initial. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n }\n break;\n }\n }\n */\n\n render() {\n return (\n <Host onClick={e => this.handleCancel(e)}>\n <div class=\"dialog\">\n <div class=\"heading\">Create Your Initial</div>\n\n <div class=\"content\">\n <verdocs-text-input placeholder=\"Initials...\" label=\"Initials\" value={this.enteredInitials} onInput={e => this.handleNameChange(e)} />\n <div class=\"as-shown\">As shown on driver's license or govt. ID card.</div>\n\n {/*<div class=\"tabs\">*/}\n {/* <div class={{tab: true, active: this.mode === 'type'}} onClick={() => (this.mode = 'type')}>*/}\n {/* Type*/}\n {/* </div>*/}\n {/* <div class={{tab: true, active: this.mode === 'draw'}} onClick={() => (this.mode = 'draw')}>*/}\n {/* Draw*/}\n {/* </div>*/}\n {/*</div>*/}\n\n {this.fontLoaded ? <canvas ref={el => (this.canvasElement = el as HTMLCanvasElement)} /> : <div style={{display: 'none'}} />}\n\n <div class=\"disclaimer\">\n By clicking Adopt, I agree that the signature will be the electronic representation of my signature for all purposes when I (or my agent) use them on documents,\n including legally binding contracts &mdash; just the same as a pen-and-paper signature or initial.\n </div>\n\n <div class=\"buttons\">\n <verdocs-button label=\"CANCEL\" variant=\"outline\" onClick={e => this.handleCancel(e)} />\n <verdocs-button label=\"Adopt & Sign\" onClick={e => this.handleAdopt(e)} />\n </div>\n </div>\n </div>\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-signature-dialog {\n font-family: $primary-font;\n box-sizing: border-box;\n position: fixed;\n z-index: 10000;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n background: #0000007f;\n\n .dialog {\n width: 100%;\n max-width: 340px;\n border-radius: 4px;\n overflow: hidden;\n box-shadow: 3px 3px 5px 1px rgba(40, 40, 40, 0.4);\n background: $dialog-bg;\n }\n\n .heading {\n display: flex;\n flex-direction: row;\n padding: 20px 20px 0 20px;\n line-height: 28px;\n font-size: 20px;\n font-weight: 500;\n }\n\n .content {\n font-size: 14px;\n padding: 20px;\n }\n\n .buttons {\n display: flex;\n margin: 20px 0 0 0;\n flex-direction: row;\n justify-content: flex-end;\n align-items: center;\n\n verdocs-button {\n margin-left: 16px;\n }\n }\n\n canvas {\n background: $verdocs-grey-4;\n box-sizing: border-box;\n margin: 0 auto;\n width: 300px;\n // TODO: The original app had an aspect ratio of (80 / 305) * (signatureBodyWidth - 20)\n height: 79px;\n max-width: 100%;\n box-shadow: 0 0 6px 0 #0000001f;\n }\n\n .disclaimer {\n text-align: justify;\n padding: 8px 0;\n font-size: 11px;\n line-height: 14px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .as-shown {\n font-size: 11px;\n margin: 4px 0 20px 4px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .tabs {\n display: flex;\n flex-direction: row;\n\n .tab {\n padding: 8px 15px;\n cursor: pointer;\n\n &.active {\n border-bottom: 2px solid $light-border-color;\n }\n\n &:hover {\n color: $primary-color;\n }\n }\n }\n}\n","import {Component, Prop, h, Event, EventEmitter, State, Host} from '@stencil/core';\n\n/**\n * Display a dialog that allows the user to specify a signature image, either by using a signature-font-generated image\n * based on their full name, or by hand-drawing their signature with a mouse or tablet.\n */\n@Component({\n tag: 'verdocs-signature-dialog',\n styleUrl: 'verdocs-signature-dialog.scss',\n})\nexport class VerdocsSignatureDialog {\n private canvasElement?: HTMLCanvasElement;\n\n /**\n * Initial signature text\n */\n @Prop() name: string = '';\n\n /**\n * Fired when the user completes the dialog and clicks Adopt. The event detail will contain a base64-encoded string\n * representation of the signature adopted.\n */\n @Event({composed: true}) next: EventEmitter<string>;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n @State() fontLoaded = false;\n\n @State() enteredName: string = '';\n\n @State() mode: string = 'type';\n\n componentWillLoad() {\n this.enteredName = this.name;\n\n const ds = new FontFace('Dancing Script', 'url(https://fonts.gstatic.com/s/dancingscript/v19/If2cXTr6YS-zF4S-kcSWSVi_sxjsohD9F50Ruu7BMSo3Sup6hNX6plRP.woff)');\n ds.load().then(font => {\n document.fonts.add(font);\n this.fontLoaded = true;\n });\n }\n\n componentDidLoad() {\n this.redrawSignature();\n }\n\n componentDidUpdate() {\n this.redrawSignature();\n }\n\n redrawSignature() {\n if (!this.canvasElement) {\n return;\n }\n\n const canvasWidth = this.canvasElement.width;\n\n const context = this.canvasElement.getContext('2d');\n context.clearRect(0, 0, this.canvasElement.width, this.canvasElement.height);\n\n let fontSize = 100;\n do {\n fontSize -= 2;\n context.font = `${fontSize}px Dancing Script`;\n } while (context.measureText(this.enteredName).width > canvasWidth - 32); // 32px padding each side\n\n context.textAlign = 'center';\n context.textBaseline = 'middle';\n context.font = `${fontSize}px Dancing Script`;\n context.fillText(this.enteredName, this.canvasElement.width / 2, this.canvasElement.height / 2);\n }\n\n handleNameChange(e: any) {\n this.enteredName = e.target.value;\n }\n\n handleCancel(e: any) {\n e.stopPropagation();\n e.preventDefault();\n this.exit.emit();\n }\n\n handleAdopt(e: any) {\n e.stopPropagation();\n e.preventDefault();\n const data = this.canvasElement.toDataURL('image/png');\n this.next.emit(data);\n }\n\n /*\n selColor(hex: string) {\n this.color = hex;\n this.animateDraw();\n }\n\n stopDraw() {\n this.paint = false;\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n draw(e) {\n this.paint = true;\n this.addPoints(e, false);\n this.animateDraw();\n }\n\n recordPoints(e) {\n if (this.paint) {\n this.addPoints(e, true);\n this.animateDraw();\n }\n }\n\n animateDraw() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n\n this.canvas.strokeStyle = this.color || '#000000';\n this.canvas.lineJoin = 'round';\n this.canvas.lineWidth = 3;\n\n for (let i = 0; i < this.points.length; i++) {\n this.canvas.beginPath();\n if (this.points[i].drag && i) {\n this.canvas.moveTo(this.points[i - 1].x, this.points[i - 1].y);\n // this.canvas.arc(this.points[i - 1].x, this.points[i - 1].y, 2, 0, 2 * Math.PI, false);\n } else {\n this.canvas.moveTo(this.points[i].x - 1, this.points[i].y);\n // this.canvas.arc(this.points[i].x, this.points[i].y, 2, 0, 2 * Math.PI, false);\n }\n\n this.canvas.lineTo(this.points[i].x, this.points[i].y);\n this.canvas.closePath();\n this.canvas.stroke();\n }\n }\n\n drawCurve(color: string, curve: number) {\n this.canvas.beginPath();\n }\n\n\n\n addPoints(e, drag: boolean) {\n if (window) {\n let x;\n let y;\n e.preventDefault();\n if (e.touches && e.touches.length > 0) {\n x = e.touches[0].clientX;\n } else {\n x = e.clientX;\n }\n\n if (e.touches && e.touches.length > 0) {\n y = e.touches[0].clientY;\n } else {\n y = e.clientY;\n }\n const rect = this.signatureCanvas.nativeElement.getBoundingClientRect();\n this.points.push({\n x: x - rect.left,\n y: y - rect.top,\n drag: drag\n });\n }\n }\n\n clearPad() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n this.points = [];\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n async adoptAndSign() {\n try {\n this.adoptedAndSigned = true;\n await this.updateFullName();\n await this.captureSignatureFromCanvas();\n const message = this.signatureMode === 'Signature' ? 'Saving Signature' : 'Saving Initial';\n this.snackbarService.open(message, 'OK', this.snackbarService.initConfig(null, 'bottom'));\n this.handleMode();\n } catch (err) {\n this.snackbarService.open('Failed to apply signature', 'OK', this.snackbarService.initConfig(null, 'bottom'));\n }\n }\n\n handleMode() {\n let currentField;\n switch (this.mode) {\n case 'signerview':\n if (this.signatureMode === 'Signature') {\n this.signatureService.postSignatureBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateSigned(currentField.fName, true);\n this.signatureService.toggleSig(false);\n this.signatureService.setSignatureId(result.id);\n this.signatureService.putSignatureField(this.envelopeId, this.fieldName, result.id).then(res => {\n this.eventTracker.createEvent({\n category: 'verdoc',\n action: 'verdoc signed',\n label: `verdoc id: ${this.envelopeId}`\n })\n if (res && res.settings) {\n this.signatureService.setSignatureData(res.settings.base64);\n this.signatureService.setSignatureId(res.settings.signature_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_sig: res.settings.base64, sig_id: res.settings.signature_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save signature. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n } else {\n this.signatureService.postInitialBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateInitialed(currentField.fName, true);\n this.signatureService.setInitialId(result.id);\n this.signatureService.toggleSig(false);\n this.signatureService.putInitialField(this.envelopeId, this.fieldName, result.id).then(res => {\n if (res && res.settings) {\n this.signatureService.setInitialData(res.settings.base64);\n this.signatureService.setInitialId(res.settings.initial_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_int: res.settings.base64, int_id: res.settings.initial_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save initial. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n }\n break;\n }\n }\n */\n\n render() {\n return (\n <Host onClick={e => this.handleCancel(e)}>\n <div class=\"dialog\">\n <div class=\"heading\">Create Your Signature</div>\n\n <div class=\"content\">\n <verdocs-text-input placeholder=\"Full Name...\" label=\"Full Name\" value={this.enteredName} onInput={e => this.handleNameChange(e)} onClick={e => e.stopPropagation()} />\n <div class=\"as-shown\">As shown on driver's license or govt. ID card.</div>\n\n {/*<div class=\"tabs\">*/}\n {/* <div class={{tab: true, active: this.mode === 'type'}} onClick={() => (this.mode = 'type')}>*/}\n {/* Type*/}\n {/* </div>*/}\n {/*<div class={{tab: true, active: this.mode === 'draw'}} onClick={() => (this.mode = 'draw')}>*/}\n {/* Draw*/}\n {/*</div>*/}\n {/*</div>*/}\n\n {this.fontLoaded ? <canvas ref={el => (this.canvasElement = el as HTMLCanvasElement)} /> : <div style={{display: 'none'}} />}\n\n <div class=\"disclaimer\">\n By clicking Adopt, I agree that the signature will be the electronic representation of my signature for all purposes when I (or my agent) use them on documents,\n including legally binding contracts &mdash; just the same as a pen-and-paper signature or initial.\n </div>\n\n <div class=\"buttons\">\n <verdocs-button label=\"CANCEL\" size=\"normal\" variant=\"outline\" onClick={e => this.handleCancel(e)} />\n <verdocs-button label=\"Adopt & Sign\" size=\"normal\" onClick={e => this.handleAdopt(e)} />\n </div>\n </div>\n </div>\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-upload-dialog {\n position: fixed;\n box-sizing: border-box;\n font-family: $primary-font;\n\n div {\n box-sizing: border-box;\n }\n\n .background-overlay {\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n z-index: 10000;\n position: fixed;\n align-items: center;\n background: #0000007f;\n justify-content: center;\n }\n\n // Not simple .dialog to avoid conflicts with ok-dialog. Should review that more.\n .upload-dialog-content {\n width: 320px;\n display: flex;\n flex-direction: column;\n border-radius: 4px;\n overflow: hidden;\n background: $verdocs-grey-4;\n padding: 16px;\n box-shadow: 3px 3px 5px 1px rgba(40, 40, 40, 0.4);\n }\n\n .heading {\n display: flex;\n font-size: 20px;\n font-weight: 500;\n flex-direction: row;\n }\n\n .buttons {\n display: flex;\n align-items: center;\n flex-direction: row;\n justify-content: flex-end;\n\n verdocs-button {\n margin-left: 16px;\n }\n }\n\n .current-label {\n margin: 20px 0 5px 0;\n }\n\n .drop-target {\n opacity: 1;\n width: 100%;\n display: flex;\n margin: 20px 0;\n min-height: 260px;\n padding: 30px 15px;\n text-align: center;\n align-items: center;\n flex-direction: column;\n justify-content: center;\n background-color: #f5f5f5;\n color: $verdocs-grey-1;\n border: 2px dashed #979797;\n\n p {\n margin: 12px 0;\n font-weight: 500;\n\n &.subscript {\n margin: 20px;\n color: $verdocs-bg-4;\n font-size: 14px;\n }\n }\n\n &.dragging-over {\n border: 5px solid $verdocs-deep-blue;\n }\n\n > verdocs-button {\n margin: 12px 0;\n display: inline-block;\n }\n }\n\n .attachments {\n height: 56px;\n font-size: 0;\n margin: 20px 0;\n padding: 0 16px;\n line-height: 56px;\n white-space: normal;\n box-shadow:\n 0 1px 3px 0 rgb(0 0 0 / 20%),\n 0 2px 2px 0 rgb(0 0 0 / 12%),\n 0 0 2px 0 rgb(0 0 0 / 14%);\n\n .attachment {\n gap: 10px;\n display: flex;\n align-items: center;\n flex-direction: row;\n\n .icon {\n width: 18px;\n height: 18px;\n line-height: 18px;\n\n &.trash {\n cursor: pointer;\n }\n }\n\n .name {\n flex: 1;\n font-size: 14px;\n overflow: hidden;\n font-weight: 400;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n }\n }\n\n .error {\n margin: 20px 0;\n color: $verdocs-red-1;\n }\n}\n","import {Component, h, Event, EventEmitter, Fragment, Host, State, Prop} from '@stencil/core';\n\nconst TrashIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\"><path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M19 7l-.867 12.142A2 2 0 0116.138 21H7.862a2 2 0 01-1.995-1.858L5 7m5 4v6m4-6v6m1-10V4a1 1 0 00-1-1h-4a1 1 0 00-1 1v3M4 7h16\" /></svg>`;\n\nconst PaperclipIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\"><path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M15.172 7l-6.586 6.586a2 2 0 102.828 2.828l6.414-6.586a4 4 0 00-5.656-5.656l-6.415 6.585a6 6 0 108.486 8.486L20.5 13\" /></svg>`;\n\n/**\n * Display a file upload tool. Note that the file is not actually transmitted, so it may be used by\n * callers with a variety of workflows. Instead, data about the chosen file will be passed to the\n * caller via the onNext event handler. A delete event is also exposed to delete existing attachments.\n * To represent an existing attachment, set the existingFile property.\n */\n@Component({\n tag: 'verdocs-upload-dialog',\n styleUrl: 'verdocs-upload-dialog.scss',\n})\nexport class VerdocsUploadDialog {\n private fileInput?: HTMLInputElement;\n\n @Prop({mutable: true})\n maxSize: number = 20 * 1024 * 1024;\n\n @Prop({mutable: true})\n existingFile: any;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n /**\n * Event fired when the dialog is closed. The event data will contain the file selected.\n */\n @Event({composed: true}) next: EventEmitter<File[]>;\n\n /**\n * Event fired when an existing attachment is deleted. The parent component is\n * responsible for the actual removal.\n */\n @Event({composed: true}) remove: EventEmitter;\n\n @State() draggingOver = false;\n @State() confirmDelete = false;\n @State() selectedFiles = [] as File[];\n @State() errorMessage = '';\n\n handleCancel() {\n this.exit.emit();\n }\n\n // We need a separate event handler for clicking the background because it can receive events \"through\" other child components\n handleDismiss(e: any) {\n if (e.target.class === 'background-overlay') {\n e.preventDefault();\n this.handleCancel();\n }\n }\n\n handleDone() {\n this.next.emit(this.selectedFiles);\n }\n\n handleDragOver(e) {\n e.preventDefault();\n this.draggingOver = true;\n }\n\n handleDragLeave(e) {\n e.preventDefault();\n this.draggingOver = false;\n }\n\n async handleDrop(e) {\n e.preventDefault();\n this.draggingOver = false;\n this.handleSetSelected(Array.from(e.dataTransfer.files));\n }\n\n handleRemoveAttachment(index: number) {\n const newFiles = [...this.selectedFiles];\n newFiles.splice(index, 1);\n this.handleSetSelected(newFiles);\n }\n\n handleSetSelected(files: any[]) {\n this.selectedFiles = files;\n this.errorMessage = '';\n\n const totalSize = this.selectedFiles.reduce((acc, file) => acc + file.size, 0);\n if (totalSize > this.maxSize) {\n this.errorMessage = 'Total file size must not exceed 20MB.';\n }\n }\n\n handleDeleteAttachment(e: any) {\n // Stop the parent from seeing \"next\" and thinking an upload was done.\n // TODO: Rethink having so many commonalities in nested dialogs (next/exit).\n e.preventDefault();\n e.stopPropagation();\n\n this.remove?.emit();\n this.existingFile = null;\n this.confirmDelete = false;\n }\n\n handleSelectFile() {\n this.fileInput?.click();\n }\n\n async handleFileChange() {\n const selectedFiles = Array.from(this.fileInput?.files);\n let droppedFiles = [] as File[];\n for (let i = 0; i < this.fileInput?.files.length; i++) {\n droppedFiles.push(this.fileInput?.files[i]);\n }\n\n this.handleSetSelected(selectedFiles);\n }\n\n render() {\n const existingFile = this.existingFile?.name ? this.existingFile : null;\n\n return (\n <Host>\n <div class=\"background-overlay\" onClick={e => this.handleDismiss(e)}>\n <div class=\"upload-dialog-content\">\n <div class=\"heading\">Upload attachment</div>\n\n {this.selectedFiles.length < 1 && existingFile && (\n <Fragment>\n <div class=\"current-label\">Current Attachment</div>\n <div class=\"attachments\" style={{marginTop: '0'}}>\n <div class=\"attachment\">\n <div class=\"icon\" innerHTML={PaperclipIcon} />\n <div class=\"name\">{existingFile.name}</div>\n <div class=\"icon trash\" innerHTML={TrashIcon} onClick={() => (this.confirmDelete = true)} />\n </div>\n </div>\n </Fragment>\n )}\n\n {this.selectedFiles.length < 1 && !existingFile && (\n <div\n class={{'drop-target': true, 'dragging-over': this.draggingOver}}\n onDragOver={e => this.handleDragOver(e)}\n onDragLeave={e => this.handleDragLeave(e)}\n onDrop={e => this.handleDrop(e)}\n >\n <p>Drag and drop your files here</p>\n <p class=\"subscript\">Supported files: PDF, Word, JPG, PNG</p>\n\n <verdocs-button label={!!existingFile ? 'Replace files' : 'Select files'} onClick={() => this.handleSelectFile()} />\n <input\n type=\"file\"\n ref={el => (this.fileInput = el as HTMLInputElement)}\n style={{display: 'none'}}\n accept=\".pdf,application/pdf,.doc,.docx,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document,image/*\"\n onChange={() => this.handleFileChange()}\n />\n </div>\n )}\n\n {this.selectedFiles.length > 0 && (\n <div class=\"attachments\">\n {this.selectedFiles.map((file, index) => (\n <div class=\"attachment\">\n <div class=\"icon\" innerHTML={PaperclipIcon} />\n <div class=\"name\">{file.name}</div>\n <div class=\"icon trash\" innerHTML={TrashIcon} onClick={() => this.handleRemoveAttachment(index)} />\n </div>\n ))}\n </div>\n )}\n\n {!!this.errorMessage && <div class=\"error\">{this.errorMessage}</div>}\n\n <div class=\"buttons\">\n <verdocs-button label=\"Cancel\" variant=\"outline\" onClick={() => this.handleCancel()} />\n <verdocs-button label=\"Upload\" onClick={() => this.handleDone()} disabled={!!this.errorMessage || this.selectedFiles.length < 1} />\n </div>\n </div>\n </div>\n\n {this.confirmDelete && (\n <verdocs-ok-dialog\n heading=\"Delete Attachment?\"\n message=\"Are you sure you wish to delete this attachment? This action cannot be undone.\"\n showCancel={true}\n onExit={e => {\n // So we don't close the upload dialog\n e.preventDefault();\n e.stopPropagation();\n this.confirmDelete = false;\n }}\n onNext={e => this.handleDeleteAttachment(e)}\n />\n )}\n </Host>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}